{"version":3,"sources":["webpack:///app/javascript/opt/mastodon/app/javascript/flavours/glitch/features/account_timeline/index.js"],"names":["emptyList","ImmutableList","RemoteHint","url","resource","id","defaultMessage","AccountTimeline","connect","state","params","acct","tagged","withReplies","accountId","getIn","normalizeForLookup","isLoading","isAccount","statusIds","path","remote","remoteUrl","featuredStatusIds","hasMore","suspended","hidden","getAccountHidden","ImmutablePureComponent","handleHeaderClick","this","column","scrollTop","handleLoadMore","maxId","props","dispatch","expandAccountTimeline","setRef","c","_load","fetchAccount","expandAccountFeaturedTimeline","fetchFeaturedTags","componentDidMount","lookupAccount","componentDidUpdate","prevProps","componentWillReceiveProps","nextProps","render","multiColumn","isEmpty","emptyMessage","forceEmptyState","remoteMessage","ref","name","onClick","prepend","hideTabs","alwaysPrepend","append","scrollKey","onLoadMore","bindToDocument","timelineId","propTypes","PropTypes","shape","string","isRequired","func","ImmutablePropTypes","list","bool"],"mappings":"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","file":"js/flavours/glitch/async/account_timeline-cf668bf036985f4cf9b2.chunk.js","sourcesContent":["import React from 'react';\nimport { connect } from 'react-redux';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport { lookupAccount, 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 ColumnBackButton from 'flavours/glitch/components/column_back_button';\nimport { List as ImmutableList } from 'immutable';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport { FormattedMessage } from 'react-intl';\nimport MissingIndicator from 'flavours/glitch/components/missing_indicator';\nimport TimelineHint from 'flavours/glitch/components/timeline_hint';\nimport LimitedAccountHint from './components/limited_account_hint';\nimport { getAccountHidden } from 'flavours/glitch/selectors';\nimport { normalizeForLookup } from 'flavours/glitch/reducers/accounts_map';\nimport { fetchFeaturedTags } from '../../actions/featured_tags';\n\nconst emptyList = ImmutableList();\n\nconst mapStateToProps = (state, { params: { acct, id, tagged }, withReplies = false }) => {\n  const accountId = id || state.getIn(['accounts_map', normalizeForLookup(acct)]);\n\n  if (accountId === null) {\n    return {\n      isLoading: false,\n      isAccount: false,\n      statusIds: emptyList,\n    };\n  } else if (!accountId) {\n    return {\n      isLoading: true,\n      statusIds: emptyList,\n    };\n  }\n\n  const path = withReplies ? `${accountId}:with_replies` : `${accountId}${tagged ? `:${tagged}` : ''}`;\n\n  return {\n    accountId,\n    remote: !!(state.getIn(['accounts', accountId, 'acct']) !== state.getIn(['accounts', accountId, 'username'])),\n    remoteUrl: state.getIn(['accounts', accountId, 'url']),\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${tagged ? `:${tagged}` : ''}`, 'items'], ImmutableList()),\n    isLoading: state.getIn(['timelines', `account:${path}`, 'isLoading']),\n    hasMore:   state.getIn(['timelines', `account:${path}`, 'hasMore']),\n    suspended: state.getIn(['accounts', accountId, 'suspended'], false),\n    hidden: getAccountHidden(state, accountId),\n  };\n};\n\nconst RemoteHint = ({ url }) => (\n  <TimelineHint url={url} resource={<FormattedMessage id='timeline_hint.resources.statuses' defaultMessage='Older posts' />} />\n);\n\nRemoteHint.propTypes = {\n  url: PropTypes.string.isRequired,\n};\n\nexport default @connect(mapStateToProps)\nclass AccountTimeline extends ImmutablePureComponent {\n\n  static propTypes = {\n    params: PropTypes.shape({\n      acct: PropTypes.string,\n      id: PropTypes.string,\n      tagged: PropTypes.string,\n    }).isRequired,\n    accountId: PropTypes.string,\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    suspended: PropTypes.bool,\n    hidden: PropTypes.bool,\n    remote: PropTypes.bool,\n    remoteUrl: PropTypes.string,\n    multiColumn: PropTypes.bool,\n  };\n\n  _load () {\n    const { accountId, withReplies, params: { tagged }, dispatch } = this.props;\n\n    dispatch(fetchAccount(accountId));\n\n    if (!withReplies) {\n      dispatch(expandAccountFeaturedTimeline(accountId, { tagged }));\n    }\n\n    dispatch(fetchFeaturedTags(accountId));\n    dispatch(expandAccountTimeline(accountId, { withReplies, tagged }));\n  }\n\n  componentDidMount () {\n    const { params: { acct }, accountId, dispatch } = this.props;\n\n    if (accountId) {\n      this._load();\n    } else {\n      dispatch(lookupAccount(acct));\n    }\n  }\n\n  componentDidUpdate (prevProps) {\n    const { params: { acct, tagged }, accountId, withReplies, dispatch } = this.props;\n\n    if (prevProps.accountId !== accountId && accountId) {\n      this._load();\n    } else if (prevProps.params.acct !== acct) {\n      dispatch(lookupAccount(acct));\n    } else if (prevProps.params.tagged !== tagged) {\n      if (!withReplies) {\n        dispatch(expandAccountFeaturedTimeline(accountId, { tagged }));\n      }\n      dispatch(expandAccountTimeline(accountId, { withReplies, tagged }));\n    }\n  }\n\n  componentWillReceiveProps (nextProps) {\n    const { dispatch } = this.props;\n\n    if ((nextProps.params.accountId !== this.props.params.accountId && nextProps.params.accountId) || nextProps.withReplies !== this.props.withReplies) {\n      dispatch(fetchAccount(nextProps.params.accountId));\n\n      if (!nextProps.withReplies) {\n        dispatch(expandAccountFeaturedTimeline(nextProps.params.accountId));\n      }\n\n      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.accountId, { maxId, withReplies: this.props.withReplies, tagged: this.props.params.tagged }));\n  }\n\n  setRef = c => {\n    this.column = c;\n  }\n\n  render () {\n    const { accountId, statusIds, featuredStatusIds, isLoading, hasMore, suspended, isAccount, hidden, multiColumn, remote, remoteUrl } = this.props;\n\n    if (isLoading && statusIds.isEmpty()) {\n      return (\n        <Column>\n          <LoadingIndicator />\n        </Column>\n      );\n    } else if (!isLoading && !isAccount) {\n      return (\n        <Column>\n          <ColumnBackButton multiColumn={multiColumn} />\n          <MissingIndicator />\n        </Column>\n      );\n    }\n\n    let emptyMessage;\n\n    const forceEmptyState = suspended || hidden;\n\n    if (suspended) {\n      emptyMessage = <FormattedMessage id='empty_column.account_suspended' defaultMessage='Account suspended' />;\n    } else if (hidden) {\n      emptyMessage = <LimitedAccountHint accountId={accountId} />;\n    } else if (remote && statusIds.isEmpty()) {\n      emptyMessage = <RemoteHint url={remoteUrl} />;\n    } else {\n      emptyMessage = <FormattedMessage id='empty_column.account_timeline' defaultMessage='No posts found' />;\n    }\n\n    const remoteMessage = remote ? <RemoteHint url={remoteUrl} /> : null;\n\n    return (\n      <Column ref={this.setRef} name='account'>\n        <ProfileColumnHeader onClick={this.handleHeaderClick} multiColumn={multiColumn} />\n\n        <StatusList\n          prepend={<HeaderContainer accountId={this.props.accountId} hideTabs={forceEmptyState} tagged={this.props.params.tagged} />}\n          alwaysPrepend\n          append={remoteMessage}\n          scrollKey='account_timeline'\n          statusIds={forceEmptyState ? emptyList : statusIds}\n          featuredStatusIds={featuredStatusIds}\n          isLoading={isLoading}\n          hasMore={!forceEmptyState && hasMore}\n          onLoadMore={this.handleLoadMore}\n          emptyMessage={emptyMessage}\n          bindToDocument={!multiColumn}\n          timelineId='account'\n        />\n      </Column>\n    );\n  }\n\n}\n"],"sourceRoot":""}