import { Fragment } from 'react' import { openModal } from '../actions/modal' import { defineMessages, injectIntl } from 'react-intl' import { MODAL_HOME_TIMELINE_SETTINGS } from '../constants' import { me } from '../initial_state' // import IntersectionObserverArticle from '../components/intersection_observer_article' // import IntersectionObserverWrapper from '../features/ui/util/intersection_observer_wrapper' import PageTitle from '../features/ui/util/page_title' import GroupsPanel from '../components/panel/groups_panel' import ListsPanel from '../components/panel/lists_panel' import LinkFooter from '../components/link_footer' import WhoToFollowPanel from '../components/panel/who_to_follow_panel' import ProgressPanel from '../components/panel/progress_panel' import ProPanel from '../components/panel/pro_panel' import UserPanel from '../components/panel/user_panel' import TrendsPanel from '../components/panel/trends_panel' import DefaultLayout from '../layouts/default_layout' import TimelineComposeBlock from '../components/timeline_compose_block' import Divider from '../components/divider' import PullToRefresher from '../components/pull_to_refresher' const messages = defineMessages({ home: { id: 'home', defaultMessage: 'Home' }, }) const mapStateToProps = (state) => ({ totalQueuedItemsCount: state.getIn(['timelines', 'home', 'totalQueuedItemsCount']), isPro: state.getIn(['accounts', me, 'is_pro']), }) const mapDispatchToProps = (dispatch) => ({ onOpenHomePageSettingsModal() { dispatch(openModal(MODAL_HOME_TIMELINE_SETTINGS)) }, }) export default @injectIntl @connect(mapStateToProps, mapDispatchToProps) class HomePage extends PureComponent { static propTypes = { children: PropTypes.node.isRequired, intl: PropTypes.object.isRequired, onOpenHomePageSettingsModal: PropTypes.func.isRequired, totalQueuedItemsCount: PropTypes.number.isRequired, isPro: PropTypes.bool, } // intersectionObserverWrapper = new IntersectionObserverWrapper() // componentDidMount() { // this.attachIntersectionObserver() // } // componentWillUnmount() { // this.detachIntersectionObserver() // } // attachIntersectionObserver() { // this.intersectionObserverWrapper.connect() // } // detachIntersectionObserver() { // this.intersectionObserverWrapper.disconnect() // } render() { const { intl, children, totalQueuedItemsCount, onOpenHomePageSettingsModal, isPro, } = this.props return ( )} > {children} ) } }