// @flow import * as React from 'react'; import classNames from 'classnames'; import noop from 'lodash/noop'; import { FormattedMessage } from 'react-intl'; import TetherComponent from 'react-tether'; import Checkmark16 from '../../../../icon/line/Checkmark16'; import Trash16 from '../../../../icon/line/Trash16'; import Pencil16 from '../../../../icon/line/Pencil16'; import X16 from '../../../../icon/fill/X16'; import Avatar from '../Avatar'; import Media from '../../../../components/media'; import { MenuItem } from '../../../../components/menu'; import { ACTIVITY_TARGETS } from '../../../common/interactionTargets'; import DeleteConfirmation from '../common/delete-confirmation'; import ActivityTimestamp from '../common/activity-timestamp'; import UserLink from '../common/user-link'; import ActivityCard from '../ActivityCard'; import ActivityError from '../common/activity-error'; import ActivityMessage from '../common/activity-message'; import ActivityStatus from '../common/activity-status'; import CommentForm from '../comment-form'; import { COMMENT_STATUS_OPEN, COMMENT_STATUS_RESOLVED, PLACEHOLDER_USER } from '../../../../constants'; import messages from './messages'; import type { GetAvatarUrlCallback, GetProfileUrlCallback } from '../../../common/flowTypes'; import type { Translations } from '../../flowTypes'; import type { SelectorItems, User, BoxItem } from '../../../../common/types/core'; import type { ActionItemError, BoxCommentPermission, FeedItemStatus } from '../../../../common/types/feed'; import './Comment.scss'; import { type OnCommentEdit } from './types'; type Props = { created_at: string | number, created_by: User, currentUser?: User, error?: ActionItemError, file?: BoxItem, getAvatarUrl: GetAvatarUrlCallback, getMentionWithQuery?: Function, getUserProfileUrl?: GetProfileUrlCallback, id: string, isDisabled?: boolean, isPending?: boolean, mentionSelectorContacts?: SelectorItems<>, modified_at?: string | number, onDelete: ({ id: string, permissions?: BoxCommentPermission }) => any, onEdit: OnCommentEdit, onSelect: (isSelected: boolean) => void, permissions: BoxCommentPermission, status?: FeedItemStatus, tagged_message: string, translatedTaggedMessage?: string, translations?: Translations, }; type State = { isConfirmingDelete: boolean, isEditing: boolean, isInputOpen: boolean, }; class Comment extends React.Component { static defaultProps = { onDelete: noop, onEdit: noop, onSelect: noop, }; state = { isConfirmingDelete: false, isEditing: false, isInputOpen: false, }; selectComment = (isSelected: boolean = true) => { const { onSelect } = this.props; onSelect(isSelected); }; handleDeleteConfirm = (): void => { const { id, onDelete, permissions } = this.props; onDelete({ id, permissions }); this.selectComment(false); }; handleDeleteCancel = (): void => { this.setState({ isConfirmingDelete: false }); this.selectComment(false); }; handleDeleteClick = () => { this.setState({ isConfirmingDelete: true }); this.selectComment(); }; handleEditClick = (): void => { this.setState({ isEditing: true, isInputOpen: true }); this.selectComment(); }; handleMenuClose = (): void => { const { isConfirmingDelete, isEditing, isInputOpen } = this.state; if (isConfirmingDelete || isEditing || isInputOpen) { return; } this.selectComment(false); }; handleMenuOpen = (): void => { this.selectComment(); }; commentFormFocusHandler = (): void => { this.setState({ isInputOpen: true }); this.selectComment(); }; commentFormCancelHandler = (): void => { this.setState({ isInputOpen: false, isEditing: false }); this.selectComment(false); }; commentFormSubmitHandler = (): void => { this.setState({ isInputOpen: false, isEditing: false }); this.selectComment(false); }; handleMessageUpdate = ({ id, text, hasMention }: { hasMention: boolean, id: string, text: string }): void => { const { onEdit, permissions } = this.props; onEdit({ id, text, hasMention, permissions }); this.commentFormSubmitHandler(); }; handleStatusUpdate = (status: FeedItemStatus): void => { const { id, onEdit, permissions } = this.props; onEdit({ id, status, hasMention: false, permissions }); }; render(): React.Node { const { created_by, created_at, permissions = {}, id, isPending, error, file, tagged_message = '', translatedTaggedMessage, translations, currentUser, isDisabled, getAvatarUrl, getUserProfileUrl, getMentionWithQuery, mentionSelectorContacts, modified_at, onEdit, status, } = this.props; const { isConfirmingDelete, isEditing, isInputOpen } = this.state; const canDelete = permissions.can_delete; const canEdit = onEdit !== noop && permissions.can_edit; const canResolve = onEdit !== noop && permissions.can_resolve; const createdAtTimestamp = new Date(created_at).getTime(); const createdByUser = created_by || PLACEHOLDER_USER; const isEdited = modified_at !== undefined && modified_at !== created_at; const isMenuVisible = (canDelete || canEdit || canResolve) && !isPending; const isResolved = status === COMMENT_STATUS_RESOLVED; return ( {isMenuVisible && ( (
{canResolve && isResolved && ( this.handleStatusUpdate(COMMENT_STATUS_OPEN)} > )} {canResolve && !isResolved && ( this.handleStatusUpdate(COMMENT_STATUS_RESOLVED)} > )} {canEdit && ( )} {canDelete && ( )}
)} renderElement={ref => isConfirmingDelete ? (
) : null } /> )}
{isEditing ? ( ) : ( )}
{/* $FlowFixMe */} {error ? : null}
); } } export default Comment;