summaryrefslogtreecommitdiffstats
path: root/webapp/components/get_post_link_modal.jsx
diff options
context:
space:
mode:
authorChristopher Speller <crspeller@gmail.com>2016-03-14 08:50:46 -0400
committerChristopher Speller <crspeller@gmail.com>2016-03-16 18:02:55 -0400
commit12896bd23eeba79884245c1c29fdc568cf21a7fa (patch)
tree4e7f83d3e2564b9b89d669e9f7905ff11768b11a /webapp/components/get_post_link_modal.jsx
parent29fe6a3d13c9c7aa490fffebbe5d1b5fdf1e3090 (diff)
downloadchat-12896bd23eeba79884245c1c29fdc568cf21a7fa.tar.gz
chat-12896bd23eeba79884245c1c29fdc568cf21a7fa.tar.bz2
chat-12896bd23eeba79884245c1c29fdc568cf21a7fa.zip
Converting to Webpack. Stage 1.
Diffstat (limited to 'webapp/components/get_post_link_modal.jsx')
-rw-r--r--webapp/components/get_post_link_modal.jsx78
1 files changed, 78 insertions, 0 deletions
diff --git a/webapp/components/get_post_link_modal.jsx b/webapp/components/get_post_link_modal.jsx
new file mode 100644
index 000000000..4c56d4d64
--- /dev/null
+++ b/webapp/components/get_post_link_modal.jsx
@@ -0,0 +1,78 @@
+// 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 'react-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.'
+ }
+});
+
+import React from 'react';
+
+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);