2020-08-17 15:07:16 -05:00
|
|
|
import React from 'react'
|
2020-08-17 15:59:29 -05:00
|
|
|
import PropTypes from 'prop-types'
|
2020-08-17 15:39:25 -05:00
|
|
|
import { connect } from 'react-redux'
|
2020-05-03 01:22:49 -04:00
|
|
|
import ImmutablePropTypes from 'react-immutable-proptypes'
|
|
|
|
import ImmutablePureComponent from 'react-immutable-pure-component'
|
2020-07-21 22:27:48 -05:00
|
|
|
import {
|
|
|
|
fetchStatus,
|
|
|
|
fetchComments,
|
|
|
|
fetchContext,
|
|
|
|
} from '../actions/statuses'
|
2020-04-29 18:32:49 -04:00
|
|
|
import StatusContainer from '../containers/status_container'
|
2020-07-28 15:11:51 -05:00
|
|
|
import StatusPlaceholder from '../components/placeholder/status_placeholder'
|
2020-05-03 01:22:49 -04:00
|
|
|
|
|
|
|
class Status extends ImmutablePureComponent {
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
const statusId = this.props.id || this.props.params.statusId
|
|
|
|
this.props.onFetchStatus(statusId)
|
2020-07-21 23:44:35 -05:00
|
|
|
|
|
|
|
if (!!this.props.status) {
|
|
|
|
this.shouldFetchStatusParts(this.props.status)
|
|
|
|
}
|
2020-05-03 01:22:49 -04:00
|
|
|
}
|
2020-04-29 18:32:49 -04:00
|
|
|
|
2020-07-21 22:27:48 -05:00
|
|
|
componentDidUpdate(prevProps) {
|
|
|
|
const { status } = this.props
|
|
|
|
|
|
|
|
if (prevProps.status !== status && !!status) {
|
2020-07-21 23:44:35 -05:00
|
|
|
this.shouldFetchStatusParts(status)
|
|
|
|
}
|
2020-12-31 17:48:59 -05:00
|
|
|
if (prevProps.statusId !== this.props.statusId && !this.props.status) {
|
|
|
|
this.props.onFetchStatus(this.props.statusId)
|
|
|
|
}
|
2020-07-21 23:44:35 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
shouldFetchStatusParts = (status) => {
|
|
|
|
if (!status) return
|
|
|
|
|
|
|
|
const isComment = !!status.get('in_reply_to_account_id')
|
|
|
|
const hasComments = status.get('replies_count') > 0
|
|
|
|
|
|
|
|
if (isComment) {
|
|
|
|
this.props.onFetchContext(status.get('id'))
|
|
|
|
} else if (!isComment && hasComments) {
|
|
|
|
this.props.onFetchComments(status.get('id'))
|
2020-07-21 22:27:48 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-29 18:32:49 -04:00
|
|
|
render() {
|
2020-05-03 01:22:49 -04:00
|
|
|
const { status } = this.props
|
2020-05-05 01:16:01 -04:00
|
|
|
|
2020-05-03 01:22:49 -04:00
|
|
|
if (!status) {
|
2020-07-28 15:11:51 -05:00
|
|
|
return <StatusPlaceholder />
|
2020-05-03 01:22:49 -04:00
|
|
|
}
|
|
|
|
|
2020-04-29 18:32:49 -04:00
|
|
|
return (
|
2020-05-04 14:44:37 -04:00
|
|
|
<StatusContainer {...this.props} contextType='feature' />
|
2020-04-29 18:32:49 -04:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-08-18 19:22:15 -05:00
|
|
|
|
|
|
|
const mapStateToProps = (state, props) => {
|
|
|
|
const statusId = props.id || props.params.statusId
|
|
|
|
|
|
|
|
return {
|
2020-12-20 12:27:24 -05:00
|
|
|
statusId,
|
2020-08-18 19:22:15 -05:00
|
|
|
status: state.getIn(['statuses', statusId]),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const mapDispatchToProps = (dispatch) => ({
|
|
|
|
onFetchStatus: (id) => dispatch(fetchStatus(id)),
|
|
|
|
onFetchContext: (id) => dispatch(fetchContext(id)),
|
|
|
|
onFetchComments: (id) => dispatch(fetchComments(id)),
|
|
|
|
})
|
|
|
|
|
|
|
|
Status.propTypes = {
|
|
|
|
onFetchContext: PropTypes.func.isRequired,
|
|
|
|
onFetchStatus: PropTypes.func.isRequired,
|
|
|
|
onFetchComments: PropTypes.func.isRequired,
|
|
|
|
params: PropTypes.object,
|
|
|
|
status: ImmutablePropTypes.map,
|
|
|
|
}
|
|
|
|
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(Status)
|