From b05c317c656b74d773f3977aaf0e2e8e83b1380b Mon Sep 17 00:00:00 2001 From: hmhealey Date: Tue, 9 Feb 2016 15:22:24 -0500 Subject: Replaced Permalink popover with a Permalink modal --- web/react/components/get_post_link_modal.jsx | 76 ++++++++++++++++++++++++++ web/react/components/post_info.jsx | 81 ++-------------------------- web/react/dispatcher/event_helpers.jsx | 8 +++ web/react/pages/channel.jsx | 2 + web/react/stores/modal_store.jsx | 1 + web/react/utils/constants.jsx | 1 + web/static/i18n/en.json | 5 +- web/static/i18n/es.json | 3 +- 8 files changed, 97 insertions(+), 80 deletions(-) create mode 100644 web/react/components/get_post_link_modal.jsx diff --git a/web/react/components/get_post_link_modal.jsx b/web/react/components/get_post_link_modal.jsx new file mode 100644 index 000000000..b7b2a8e7c --- /dev/null +++ b/web/react/components/get_post_link_modal.jsx @@ -0,0 +1,76 @@ +// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +import Constants from '../utils/constants.jsx'; +import GetLinkModal from './get_link_modal.jsx'; +import ModalStore from '../stores/modal_store.jsx'; +import TeamStore from '../stores/team_store.jsx'; + +import {intlShape, injectIntl, defineMessages} from 'mm-intl'; + +const holders = defineMessages({ + title: { + id: 'get_post_link_modal.title', + defaultMessage: 'Copy Permalink' + }, + help: { + id: 'get_post_link_modal.help', + defaultMessage: 'The link below allows authorized users to see your post.' + } +}); + +class GetPostLinkModal extends React.Component { + constructor(props) { + super(props); + + this.handleToggle = this.handleToggle.bind(this); + + this.hide = this.hide.bind(this); + + this.state = { + show: false, + post: {} + }; + } + + componentDidMount() { + ModalStore.addModalListener(Constants.ActionTypes.TOGGLE_GET_POST_LINK_MODAL, this.handleToggle); + } + + componentWillUnmount() { + ModalStore.removeModalListener(Constants.ActionTypes.TOGGLE_GET_POST_LINK_MODAL, this.handleToggle); + } + + handleToggle(value, args) { + this.setState({ + show: value, + post: args.post + }); + } + + hide() { + this.setState({ + show: false + }); + } + + render() { + const {formatMessage} = this.props.intl; + + return ( + + ); + } +} + +GetPostLinkModal.propTypes = { + intl: intlShape.isRequired +}; + +export default injectIntl(GetPostLinkModal); diff --git a/web/react/components/post_info.jsx b/web/react/components/post_info.jsx index b1bc8ca14..6d82423d5 100644 --- a/web/react/components/post_info.jsx +++ b/web/react/components/post_info.jsx @@ -2,7 +2,6 @@ // See License.txt for license information. import UserStore from '../stores/user_store.jsx'; -import TeamStore from '../stores/team_store.jsx'; import * as Utils from '../utils/utils.jsx'; import TimeSince from './time_since.jsx'; import * as EventHelpers from '../dispatcher/event_helpers.jsx'; @@ -11,18 +10,11 @@ import Constants from '../utils/constants.jsx'; import {FormattedMessage} from 'mm-intl'; -const Overlay = ReactBootstrap.Overlay; -const Popover = ReactBootstrap.Popover; - export default class PostInfo extends React.Component { constructor(props) { super(props); - this.state = { - copiedLink: false, - show: false - }; - this.handlePermalinkCopy = this.handlePermalinkCopy.bind(this); + this.handlePermalink = this.handlePermalink.bind(this); this.removePost = this.removePost.bind(this); } createDropdown() { @@ -72,7 +64,7 @@ export default class PostInfo extends React.Component { > this.setState({target: e.target, show: !this.state.show})} + onClick={this.handlePermalink} > - - - ) : (); - - const permalinkOverlay = ( - -
- - -
-
- ); - - const containerPadding = 20; - return (
  • @@ -273,17 +213,6 @@ export default class PostInfo extends React.Component { {dropdown} {comments} - ReactDOM.findDOMNode(this.refs.dotMenu)} - onHide={() => this.setState({show: false})} - placement='left' - container={this} - containerPadding={containerPadding} - rootClose={true} - > - {permalinkOverlay} - {this.createRemovePostButton(post)}
diff --git a/web/react/dispatcher/event_helpers.jsx b/web/react/dispatcher/event_helpers.jsx index 5476d707f..47a16950e 100644 --- a/web/react/dispatcher/event_helpers.jsx +++ b/web/react/dispatcher/event_helpers.jsx @@ -117,6 +117,14 @@ export function showDeletePostModal(post, commentCount = 0) { }); } +export function showGetPostLinkModal(post) { + AppDispatcher.handleViewAction({ + type: ActionTypes.TOGGLE_GET_POST_LINK_MODAL, + value: true, + post + }); +} + export function showGetTeamInviteLinkModal() { AppDispatcher.handleViewAction({ type: Constants.ActionTypes.TOGGLE_GET_TEAM_INVITE_LINK_MODAL, diff --git a/web/react/pages/channel.jsx b/web/react/pages/channel.jsx index bfb95e1fc..2c1d256b2 100644 --- a/web/react/pages/channel.jsx +++ b/web/react/pages/channel.jsx @@ -6,6 +6,7 @@ import ChannelLoader from '../components/channel_loader.jsx'; import ErrorBar from '../components/error_bar.jsx'; import * as Client from '../utils/client.jsx'; +import GetPostLinkModal from '../components/get_post_link_modal.jsx'; import GetTeamInviteLinkModal from '../components/get_team_invite_link_modal.jsx'; import RenameChannelModal from '../components/rename_channel_modal.jsx'; import EditPostModal from '../components/edit_post_modal.jsx'; @@ -69,6 +70,7 @@ class Root extends React.Component { + diff --git a/web/react/stores/modal_store.jsx b/web/react/stores/modal_store.jsx index 9f33cf022..931443f62 100644 --- a/web/react/stores/modal_store.jsx +++ b/web/react/stores/modal_store.jsx @@ -34,6 +34,7 @@ class ModalStoreClass extends EventEmitter { case ActionTypes.TOGGLE_IMPORT_THEME_MODAL: case ActionTypes.TOGGLE_INVITE_MEMBER_MODAL: case ActionTypes.TOGGLE_DELETE_POST_MODAL: + case ActionTypes.TOGGLE_GET_POST_LINK_MODAL: case ActionTypes.TOGGLE_GET_TEAM_INVITE_LINK_MODAL: case ActionTypes.TOGGLE_REGISTER_APP_MODAL: this.emit(type, value, args); diff --git a/web/react/utils/constants.jsx b/web/react/utils/constants.jsx index 9689591a6..0a055d55c 100644 --- a/web/react/utils/constants.jsx +++ b/web/react/utils/constants.jsx @@ -54,6 +54,7 @@ export default { TOGGLE_IMPORT_THEME_MODAL: null, TOGGLE_INVITE_MEMBER_MODAL: null, TOGGLE_DELETE_POST_MODAL: null, + TOGGLE_GET_POST_LINK_MODAL: null, TOGGLE_GET_TEAM_INVITE_LINK_MODAL: null, TOGGLE_REGISTER_APP_MODAL: null, diff --git a/web/static/i18n/en.json b/web/static/i18n/en.json index ff25d98c2..b4a68425e 100644 --- a/web/static/i18n/en.json +++ b/web/static/i18n/en.json @@ -625,6 +625,8 @@ "get_link.copy": "Copy Link", "get_link.clipboard": " Link copied to clipboard.", "get_link.close": "Close", + "get_post_link_modal.title": "Copy Permalink", + "get_post_link_modal.help": "The link below allows authorized users to see your post.", "get_team_invite_link_modal.title": "Team Invite Link", "get_team_invite_link_modal.help": "Send teammates the link below for them to sign-up to this team site.", "get_team_invite_link_modal.helpDisabled": "User creation has been disabled for your team. Please ask your team administrator for details.", @@ -787,7 +789,6 @@ "post_info.permalink": "Permalink", "post_info.del": "Delete", "post_info.edit": "Edit", - "post_info.copy": "Copy ", "posts_view.newMsg": "New Messages", "posts_view.loadMore": "Load more messages", "register_app.required": "Required", @@ -1261,4 +1262,4 @@ "intro_messages.beginning": "Beginning of {name}", "intro_messages.invite": "Invite others to this {type}", "intro_messages.setHeader": "Set a Header" -} \ No newline at end of file +} diff --git a/web/static/i18n/es.json b/web/static/i18n/es.json index 19582b836..a3c7e13a7 100644 --- a/web/static/i18n/es.json +++ b/web/static/i18n/es.json @@ -823,7 +823,6 @@ "post_delete.okay": "Ok", "post_delete.someone": "Alguien borró el mensaje que querías comentar.", "post_focus_view.beginning": "Inicio de los Archivos del Canal", - "post_info.copy": "Copiar ", "post_info.del": "Borrar", "post_info.edit": "Editar", "post_info.permalink": "Enlace permanente", @@ -1261,4 +1260,4 @@ "view_image_popover.download": "Descargar", "view_image_popover.file": "Archivo {count} de {total}", "view_image_popover.publicLink": "Obtener Enlace Público" -} \ No newline at end of file +} -- cgit v1.2.3-1-g7c22