Conflicts: app/javascript/mastodon/components/status_list.js app/javascript/mastodon/features/notifications/index.js app/javascript/mastodon/features/ui/components/modal_root.js app/javascript/mastodon/features/ui/components/onboarding_modal.js app/javascript/mastodon/features/ui/index.js app/javascript/styles/about.scss app/javascript/styles/accounts.scss app/javascript/styles/components.scss app/presenters/instance_presenter.rb app/services/post_status_service.rb app/services/reblog_service.rb app/views/about/more.html.haml app/views/about/show.html.haml app/views/accounts/_header.html.haml config/webpack/loaders/babel.js spec/controllers/api/v1/accounts/credentials_controller_spec.rb
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import React from 'react';
 | |
| import ImmutablePropTypes from 'react-immutable-proptypes';
 | |
| import PropTypes from 'prop-types';
 | |
| import StatusContainer from '../../glitch/components/status/container';
 | |
| import LoadMore from './load_more';
 | |
| import ImmutablePureComponent from 'react-immutable-pure-component';
 | |
| import ScrollableList from './scrollable_list';
 | |
| 
 | |
| export default class StatusList extends ImmutablePureComponent {
 | |
| 
 | |
|   static propTypes = {
 | |
|     scrollKey: PropTypes.string.isRequired,
 | |
|     statusIds: ImmutablePropTypes.list.isRequired,
 | |
|     onScrollToBottom: PropTypes.func,
 | |
|     onScrollToTop: PropTypes.func,
 | |
|     onScroll: PropTypes.func,
 | |
|     trackScroll: PropTypes.bool,
 | |
|     shouldUpdateScroll: PropTypes.func,
 | |
|     isLoading: PropTypes.bool,
 | |
|     hasMore: PropTypes.bool,
 | |
|     prepend: PropTypes.node,
 | |
|     emptyMessage: PropTypes.node,
 | |
|   };
 | |
| 
 | |
|   static defaultProps = {
 | |
|     trackScroll: true,
 | |
|   };
 | |
| 
 | |
|   render () {
 | |
|     const { statusIds, ...other } = this.props;
 | |
|     const { isLoading } = other;
 | |
| 
 | |
|     const scrollableContent = (isLoading || statusIds.size > 0) ? (
 | |
|       statusIds.map((statusId) => (
 | |
|         <StatusContainer key={statusId} id={statusId} />
 | |
|       ))
 | |
|     ) : null;
 | |
| 
 | |
|     return (
 | |
|       <ScrollableList {...other}>
 | |
|         {scrollableContent}
 | |
|       </ScrollableList>
 | |
|     );
 | |
|   }
 | |
| 
 | |
| }
 |