summaryrefslogtreecommitdiffstats
path: root/web/react/components/get_post_link_modal.jsx
diff options
context:
space:
mode:
authorhmhealey <harrisonmhealey@gmail.com>2016-02-09 15:22:24 -0500
committerhmhealey <harrisonmhealey@gmail.com>2016-02-09 15:22:24 -0500
commitb05c317c656b74d773f3977aaf0e2e8e83b1380b (patch)
treeac866abbef6be9e0bae8dd74188fc8b24f2b04df /web/react/components/get_post_link_modal.jsx
parent137920b479b9cb6688a4ad683c67280549680c70 (diff)
downloadchat-b05c317c656b74d773f3977aaf0e2e8e83b1380b.tar.gz
chat-b05c317c656b74d773f3977aaf0e2e8e83b1380b.tar.bz2
chat-b05c317c656b74d773f3977aaf0e2e8e83b1380b.zip
Replaced Permalink popover with a Permalink modal
Diffstat (limited to 'web/react/components/get_post_link_modal.jsx')
-rw-r--r--web/react/components/get_post_link_modal.jsx76
1 files changed, 76 insertions, 0 deletions
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 (
+ <GetLinkModal
+ show={this.state.show}
+ onHide={this.hide}
+ title={formatMessage(holders.title)}
+ helpText={formatMessage(holders.help)}
+ link={TeamStore.getCurrentTeamUrl() + '/pl/' + this.state.post.id}
+ />
+ );
+ }
+}
+
+GetPostLinkModal.propTypes = {
+ intl: intlShape.isRequired
+};
+
+export default injectIntl(GetPostLinkModal);