/** * @flow * @file Collapsed Version component */ import * as React from 'react'; import { FormattedMessage, injectIntl } from 'react-intl'; import type { IntlShape } from 'react-intl'; import ActivityCard from '../ActivityCard'; import IconInfo from '../../../../icons/general/IconInfo'; import PlainButton from '../../../../components/plain-button'; import messages from '../../../common/messages'; import selectors from '../../../common/selectors/version'; import { ACTIVITY_TARGETS } from '../../../common/interactionTargets'; import type { User, FileVersions } from '../../../../common/types/core'; import { ACTION_TYPE_CREATED, ACTION_TYPE_RESTORED, ACTION_TYPE_TRASHED } from '../../../../constants'; import './Version.scss'; function getMessageForAction( action: string, collaborators: { [collaborator_id: string]: User } = {}, version_start: number, version_end: number, shouldUseUAA?: boolean, action_by?: User[], ): React.Node { if ( action !== 'upload' && action !== ACTION_TYPE_RESTORED && action !== ACTION_TYPE_TRASHED && action !== ACTION_TYPE_CREATED ) { return null; } let singleUserMessage = messages.versionUploadCollapsed; let multipleUsersMessage = messages.versionMultipleUsersUploaded; switch (action) { case ACTION_TYPE_CREATED: singleUserMessage = messages.versionUploadCollapsed; multipleUsersMessage = messages.versionMultipleUsersUploaded; break; case ACTION_TYPE_RESTORED: singleUserMessage = messages.versionRestoreCollapsed; multipleUsersMessage = messages.versionMultipleUsersRestored; break; case ACTION_TYPE_TRASHED: singleUserMessage = messages.versionTrashCollapsed; multipleUsersMessage = messages.versionMultipleUsersTrashed; break; default: break; } const collaboratorIDs = Object.keys(collaborators); const numberOfCollaborators = shouldUseUAA ? action_by?.length : collaboratorIDs.length; const versionRange: React.Node = ( {version_start} - {version_end} ); if (numberOfCollaborators === 1) { const collaborator = shouldUseUAA ? action_by?.[0] : collaborators[collaboratorIDs[0]]; if (shouldUseUAA) { return ( {collaborator?.name}, versions: versionRange, }} /> ); } return ( {collaborator?.name}, versions: versionRange, }} /> ); } if (shouldUseUAA) { return ( ); } return ( ); } type Props = { action_by?: User[], action_type?: string, collaborators: { [collaborator_id: string]: User }, id: string, intl: IntlShape, onInfo?: Function, shouldUseUAA?: boolean, version_end: number, version_start: number, versions: FileVersions, }; const CollapsedVersion = (props: Props): React.Node => { const { action_by, action_type = ACTION_TYPE_CREATED, collaborators, id, intl, onInfo, shouldUseUAA, versions, version_start, version_end, } = props; // $FlowFixMe const action = shouldUseUAA ? action_type : selectors.getVersionAction(props); return ( {getMessageForAction(action, collaborators, version_start, version_end, shouldUseUAA, action_by)} {onInfo ? ( { onInfo(shouldUseUAA ? { id, version_number: version_end } : { versions }); }} type="button" > ) : null} ); }; export { CollapsedVersion as CollapsedVersionBase }; export default injectIntl(CollapsedVersion);