{"version":3,"sources":["webpack:///app/javascript/builds/pleroma/mastofe/app/javascript/flavours/glitch/features/account_timeline/index.js"],"names":["AccountTimeline","connect","state","_ref","accountId","params","_ref$withReplies","withReplies","path","isAccount","getIn","statusIds","ImmutableList","featuredStatusIds","isLoading","hasMore","_this","column","scrollTop","maxId","props","dispatch","expandAccountTimeline","c","componentWillMount","_this$props","this","fetchAccount","fetchAccountIdentityProofs","expandAccountFeaturedTimeline","componentWillReceiveProps","nextProps","render","_this$props2","Object","_babel_runtime_helpers_esm_jsx__WEBPACK_IMPORTED_MODULE_0__","_ui_components_column__WEBPACK_IMPORTED_MODULE_12__","_components_loading_indicator__WEBPACK_IMPORTED_MODULE_11__","react__WEBPACK_IMPORTED_MODULE_4___default","a","createElement","ref","setRef","name","flavours_glitch_features_account_components_profile_column_header__WEBPACK_IMPORTED_MODULE_13__","onClick","handleHeaderClick","_components_status_list__WEBPACK_IMPORTED_MODULE_10__","prepend","_containers_header_container__WEBPACK_IMPORTED_MODULE_14__","alwaysPrepend","scrollKey","onLoadMore","handleLoadMore","emptyMessage","react_intl__WEBPACK_IMPORTED_MODULE_17__","id","defaultMessage","flavours_glitch_components_missing_indicator__WEBPACK_IMPORTED_MODULE_19__","ImmutablePureComponent","PropTypes","object","isRequired","func","ImmutablePropTypes","list","bool"],"mappings":"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","file":"flavours/glitch/async/account_timeline.js","sourcesContent":["import React from 'react';\nimport { connect } from 'react-redux';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport { fetchAccount } from 'flavours/glitch/actions/accounts';\nimport { expandAccountFeaturedTimeline, expandAccountTimeline } from 'flavours/glitch/actions/timelines';\nimport StatusList from '../../components/status_list';\nimport LoadingIndicator from '../../components/loading_indicator';\nimport Column from '../ui/components/column';\nimport ProfileColumnHeader from 'flavours/glitch/features/account/components/profile_column_header';\nimport HeaderContainer from './containers/header_container';\nimport { List as ImmutableList } from 'immutable';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport { FormattedMessage } from 'react-intl';\nimport { fetchAccountIdentityProofs } from '../../actions/identity_proofs';\nimport MissingIndicator from 'flavours/glitch/components/missing_indicator';\n\nconst mapStateToProps = (state, { params: { accountId }, withReplies = false }) => {\n const path = withReplies ? `${accountId}:with_replies` : accountId;\n\n return {\n isAccount: !!state.getIn(['accounts', accountId]),\n statusIds: state.getIn(['timelines', `account:${path}`, 'items'], ImmutableList()),\n featuredStatusIds: withReplies ? ImmutableList() : state.getIn(['timelines', `account:${accountId}:pinned`, 'items'], ImmutableList()),\n isLoading: state.getIn(['timelines', `account:${path}`, 'isLoading']),\n hasMore: state.getIn(['timelines', `account:${path}`, 'hasMore']),\n };\n};\n\n@connect(mapStateToProps)\nexport default class AccountTimeline extends ImmutablePureComponent {\n\n static propTypes = {\n params: PropTypes.object.isRequired,\n dispatch: PropTypes.func.isRequired,\n statusIds: ImmutablePropTypes.list,\n featuredStatusIds: ImmutablePropTypes.list,\n isLoading: PropTypes.bool,\n hasMore: PropTypes.bool,\n withReplies: PropTypes.bool,\n isAccount: PropTypes.bool,\n };\n\n componentWillMount () {\n const { params: { accountId }, withReplies } = this.props;\n\n this.props.dispatch(fetchAccount(accountId));\n this.props.dispatch(fetchAccountIdentityProofs(accountId));\n if (!withReplies) {\n this.props.dispatch(expandAccountFeaturedTimeline(accountId));\n }\n this.props.dispatch(expandAccountTimeline(accountId, { withReplies }));\n }\n\n componentWillReceiveProps (nextProps) {\n if ((nextProps.params.accountId !== this.props.params.accountId && nextProps.params.accountId) || nextProps.withReplies !== this.props.withReplies) {\n this.props.dispatch(fetchAccount(nextProps.params.accountId));\n this.props.dispatch(fetchAccountIdentityProofs(nextProps.params.accountId));\n if (!nextProps.withReplies) {\n this.props.dispatch(expandAccountFeaturedTimeline(nextProps.params.accountId));\n }\n this.props.dispatch(expandAccountTimeline(nextProps.params.accountId, { withReplies: nextProps.params.withReplies }));\n }\n }\n\n handleHeaderClick = () => {\n this.column.scrollTop();\n }\n\n handleLoadMore = maxId => {\n this.props.dispatch(expandAccountTimeline(this.props.params.accountId, { maxId, withReplies: this.props.withReplies }));\n }\n\n setRef = c => {\n this.column = c;\n }\n\n render () {\n const { statusIds, featuredStatusIds, isLoading, hasMore, isAccount } = this.props;\n\n if (!isAccount) {\n return (\n <Column>\n <MissingIndicator />\n </Column>\n );\n }\n\n if (!statusIds && isLoading) {\n return (\n <Column>\n <LoadingIndicator />\n </Column>\n );\n }\n\n return (\n <Column ref={this.setRef} name='account'>\n <ProfileColumnHeader onClick={this.handleHeaderClick} />\n\n <StatusList\n prepend={<HeaderContainer accountId={this.props.params.accountId} />}\n alwaysPrepend\n scrollKey='account_timeline'\n statusIds={statusIds}\n featuredStatusIds={featuredStatusIds}\n isLoading={isLoading}\n hasMore={hasMore}\n onLoadMore={this.handleLoadMore}\n emptyMessage={<FormattedMessage id='empty_column.account_timeline' defaultMessage='No toots here!' />}\n />\n </Column>\n );\n }\n\n}\n"],"sourceRoot":""}