import React, { Component } from 'react' import PropTypes from 'prop-types' import Markdown from 'react-markdown' import { connect } from 'react-redux' import { withRouter } from 'react-router-dom' import { compose } from 'recompose' import debounce from 'lodash.debounce' import { markNoticeRead } from '../../../../ui/app/actions' import Identicon from '../../../../ui/app/components/identicon' import Breadcrumbs from './breadcrumbs' import { INITIALIZE_BACKUP_PHRASE_ROUTE } from '../../../../ui/app/routes' import LoadingScreen from './loading-screen' class NoticeScreen extends Component { static propTypes = { address: PropTypes.string.isRequired, lastUnreadNotice: PropTypes.shape({ title: PropTypes.string, date: PropTypes.string, body: PropTypes.string, }), location: PropTypes.shape({ state: PropTypes.shape({ next: PropTypes.func.isRequired, }), }), markNoticeRead: PropTypes.func, history: PropTypes.object, isLoading: PropTypes.bool, noActiveNotices: PropTypes.bool, }; static defaultProps = { lastUnreadNotice: {}, }; state = { atBottom: false, } componentDidMount () { if (this.props.noActiveNotices) { this.props.history.push(INITIALIZE_BACKUP_PHRASE_ROUTE) } this.onScroll() } acceptTerms = () => { const { markNoticeRead, lastUnreadNotice, history } = this.props markNoticeRead(lastUnreadNotice) .then(hasActiveNotices => { if (!hasActiveNotices) { history.push(INITIALIZE_BACKUP_PHRASE_ROUTE) } else { this.setState({ atBottom: false }) this.onScroll() } }) } onScroll = debounce(() => { if (this.state.atBottom) return const target = document.querySelector('.tou__body') const {scrollTop, offsetHeight, scrollHeight} = target const atBottom = scrollTop + offsetHeight >= scrollHeight this.setState({atBottom: atBottom}) }, 25) render () { const { address, lastUnreadNotice: { title, body }, isLoading, } = this.props const { atBottom } = this.state return ( isLoading ? : (
{title}
) ) } } const mapStateToProps = ({ metamask, appState }) => { const { selectedAddress, lastUnreadNotice, noActiveNotices } = metamask const { isLoading } = appState return { address: selectedAddress, lastUnreadNotice, noActiveNotices, isLoading, } } export default compose( withRouter, connect( mapStateToProps, dispatch => ({ markNoticeRead: notice => dispatch(markNoticeRead(notice)), }) ) )(NoticeScreen)