From 0e89d9be1d6a2a1ca470f9ca92e0d59e5945ca18 Mon Sep 17 00:00:00 2001 From: Saturnino Abril Date: Thu, 15 Jun 2017 07:45:46 +0800 Subject: create DotMenu components and add dotmenu IDs to posts at center and RHS (#6642) --- webapp/components/dot_menu/dot_menu_item.jsx | 107 +++++++++++++++++++++++++++ 1 file changed, 107 insertions(+) create mode 100644 webapp/components/dot_menu/dot_menu_item.jsx (limited to 'webapp/components/dot_menu/dot_menu_item.jsx') diff --git a/webapp/components/dot_menu/dot_menu_item.jsx b/webapp/components/dot_menu/dot_menu_item.jsx new file mode 100644 index 000000000..ceda0a1a4 --- /dev/null +++ b/webapp/components/dot_menu/dot_menu_item.jsx @@ -0,0 +1,107 @@ +// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +import React from 'react'; +import {FormattedMessage} from 'react-intl'; +import PropTypes from 'prop-types'; + +import {unpinPost, pinPost} from 'actions/post_actions.jsx'; +import {showGetPostLinkModal, showDeletePostModal} from 'actions/global_actions.jsx'; +import * as Utils from 'utils/utils.jsx'; +import Constants from 'utils/constants.jsx'; + +export default function DotMenuItem(props) { + function handlePermalink(e) { + e.preventDefault(); + showGetPostLinkModal(props.post); + } + + function handleUnpinPost(e) { + e.preventDefault(); + unpinPost(props.post.channel_id, props.post.id); + } + + function handlePinPost(e) { + e.preventDefault(); + pinPost(props.post.channel_id, props.post.id); + } + + function handleDeletePost(e) { + e.preventDefault(); + showDeletePostModal(props.post, props.commentCount); + } + + const attrib = {}; + attrib.idPrefix = props.idPrefix; + attrib.class = ''; + + switch (props.idPrefix.substring((props.idPrefix.indexOf('DotMenu') + 7))) { + case 'Reply': + attrib.class = 'link__reply theme'; + attrib.onClick = props.handleOnClick; + attrib.formattedMessageId = 'post_info.reply'; + attrib.formattedDefaultMessage = 'Reply'; + break; + case 'Permalink': + attrib.onClick = handlePermalink; + attrib.formattedMessageId = 'post_info.permalink'; + attrib.formattedDefaultMessage = 'Permalink'; + attrib.post = props.post; + break; + case 'Pin': + attrib.onClick = props.post.is_pinned ? handleUnpinPost : handlePinPost; + attrib.formattedMessageId = props.post.is_pinned ? 'post_info.unpin' : 'post_info.pin'; + attrib.formattedDefaultMessage = props.post.is_pinned ? 'Un-pin from channel' : 'Pin from channel'; + attrib.post = props.post; + break; + case 'Delete': + attrib.onClick = handleDeletePost; + attrib.formattedMessageId = 'post_info.del'; + attrib.formattedDefaultMessage = 'Delete'; + attrib.commentCount = props.commentCount; + break; + default: + } + + let itemId = null; + if (props.idCount > -1) { + itemId = Utils.createSafeId(props.idPrefix + props.idCount); + } + + if (attrib.idPrefix.indexOf(Constants.RHS_ROOT) === 0) { + itemId = attrib.idPrefix; + } + + return ( + + ); +} + +DotMenuItem.propTypes = { + idPrefix: PropTypes.string.isRequired, + idCount: PropTypes.number, + post: PropTypes.object, + handleOnClick: PropTypes.func, + type: PropTypes.string, + commentCount: PropTypes.number +}; + +DotMenuItem.defaultProps = { + idPrefix: '', + idCount: -1 +}; -- cgit v1.2.3-1-g7c22