Also, since the root component connects to the stream that updates home/notification columns, there is pretty much no case for refreshing those columns beyond initial load. So, move the loading of those columns into the root component, to prevent unneccessary reloads when switching tabs on mobile or resizing desktop window between mobile/desktop layouts
		
			
				
	
	
		
			107 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import ColumnsArea from './components/columns_area';
 | |
| import NotificationsContainer from './containers/notifications_container';
 | |
| import PureRenderMixin from 'react-addons-pure-render-mixin';
 | |
| import LoadingBarContainer from './containers/loading_bar_container';
 | |
| import HomeTimeline from '../home_timeline';
 | |
| import MentionsTimeline from '../mentions_timeline';
 | |
| import Compose from '../compose';
 | |
| import TabsBar from './components/tabs_bar';
 | |
| import ModalContainer from './containers/modal_container';
 | |
| import Notifications from '../notifications';
 | |
| import { connect } from 'react-redux';
 | |
| import { isMobile } from '../../is_mobile';
 | |
| import { debounce } from 'react-decoration';
 | |
| import { uploadCompose } from '../../actions/compose';
 | |
| import { refreshTimeline } from '../../actions/timelines';
 | |
| import { refreshNotifications } from '../../actions/notifications';
 | |
| 
 | |
| const UI = React.createClass({
 | |
| 
 | |
|   propTypes: {
 | |
|     dispatch: React.PropTypes.func.isRequired,
 | |
|     children: React.PropTypes.node
 | |
|   },
 | |
| 
 | |
|   getInitialState () {
 | |
|     return {
 | |
|       width: window.innerWidth
 | |
|     };
 | |
|   },
 | |
| 
 | |
|   mixins: [PureRenderMixin],
 | |
| 
 | |
|   @debounce(500)
 | |
|   handleResize () {
 | |
|     this.setState({ width: window.innerWidth });
 | |
|   },
 | |
| 
 | |
|   handleDragOver (e) {
 | |
|     e.preventDefault();
 | |
|     e.stopPropagation();
 | |
| 
 | |
|     e.dataTransfer.dropEffect = 'copy';
 | |
| 
 | |
|     if (e.dataTransfer.effectAllowed === 'all' || e.dataTransfer.effectAllowed === 'uninitialized') {
 | |
|       //
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   handleDrop (e) {
 | |
|     e.preventDefault();
 | |
| 
 | |
|     if (e.dataTransfer && e.dataTransfer.files.length === 1) {
 | |
|       this.props.dispatch(uploadCompose(e.dataTransfer.files));
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   componentWillMount () {
 | |
|     window.addEventListener('resize', this.handleResize, { passive: true });
 | |
|     window.addEventListener('dragover', this.handleDragOver);
 | |
|     window.addEventListener('drop', this.handleDrop);
 | |
| 
 | |
|     this.props.dispatch(refreshTimeline('home'));
 | |
|     this.props.dispatch(refreshNotifications());
 | |
|   },
 | |
| 
 | |
|   componentWillUnmount () {
 | |
|     window.removeEventListener('resize', this.handleResize);
 | |
|     window.removeEventListener('dragover', this.handleDragOver);
 | |
|     window.removeEventListener('drop', this.handleDrop);
 | |
|   },
 | |
| 
 | |
|   render () {
 | |
|     let mountedColumns;
 | |
| 
 | |
|     if (isMobile(this.state.width)) {
 | |
|       mountedColumns = (
 | |
|         <ColumnsArea>
 | |
|           {this.props.children}
 | |
|         </ColumnsArea>
 | |
|       );
 | |
|     } else {
 | |
|       mountedColumns = (
 | |
|         <ColumnsArea>
 | |
|           <Compose withHeader={true} />
 | |
|           <HomeTimeline trackScroll={false} />
 | |
|           <Notifications trackScroll={false} />
 | |
|           {this.props.children}
 | |
|         </ColumnsArea>
 | |
|       );
 | |
|     }
 | |
| 
 | |
|     return (
 | |
|       <div style={{ flex: '0 0 auto', display: 'flex', flexDirection: 'column', width: '100%', height: '100%', background: '#1a1c23' }}>
 | |
|         <TabsBar />
 | |
| 
 | |
|         {mountedColumns}
 | |
| 
 | |
|         <NotificationsContainer />
 | |
|         <LoadingBarContainer style={{ backgroundColor: '#2b90d9', left: '0', top: '0' }} />
 | |
|         <ModalContainer />
 | |
|       </div>
 | |
|     );
 | |
|   }
 | |
| 
 | |
| });
 | |
| 
 | |
| export default connect()(UI);
 |