import { Map as ImmutableMap, List as ImmutableList } from 'immutable'; import { normalizeStatus } from 'soapbox/normalizers/status'; import { calculateStatus } from 'soapbox/reducers/statuses'; import { makeGetAccount } from 'soapbox/selectors'; import type { PendingStatus } from 'soapbox/reducers/pending_statuses'; import type { RootState } from 'soapbox/store'; const getAccount = makeGetAccount(); const buildMentions = (pendingStatus: PendingStatus) => { if (pendingStatus.in_reply_to_id) { return ImmutableList(pendingStatus.to || []).map(acct => ImmutableMap({ acct })); } else { return ImmutableList(); } }; const buildPoll = (pendingStatus: PendingStatus) => { if (pendingStatus.hasIn(['poll', 'options'])) { return pendingStatus.poll!.update('options', (options: ImmutableMap) => { return options.map((title: string) => ImmutableMap({ title })); }); } else { return null; } }; export const buildStatus = (state: RootState, pendingStatus: PendingStatus, idempotencyKey: string) => { const me = state.me as string; const account = getAccount(state, me); const inReplyToId = pendingStatus.in_reply_to_id; const status = ImmutableMap({ account, content: pendingStatus.status.replace(new RegExp('\n', 'g'), '
'), /* eslint-disable-line no-control-regex */ id: `ęœ«pending-${idempotencyKey}`, in_reply_to_account_id: state.statuses.getIn([inReplyToId, 'account'], null), in_reply_to_id: inReplyToId, media_attachments: (pendingStatus.media_ids || ImmutableList()).map((id: string) => ImmutableMap({ id })), mentions: buildMentions(pendingStatus), poll: buildPoll(pendingStatus), quote: pendingStatus.quote_id, sensitive: pendingStatus.sensitive, visibility: pendingStatus.visibility, }); return calculateStatus(normalizeStatus(status)); };