summaryrefslogtreecommitdiffstats
path: root/web/react/components/channel_notifications.jsx
diff options
context:
space:
mode:
authorhmhealey <harrisonmhealey@gmail.com>2015-11-10 15:45:19 -0500
committerhmhealey <harrisonmhealey@gmail.com>2015-11-17 11:04:32 -0500
commit69e378c556e817ce494af8511220389407dbed89 (patch)
tree64e44392d80213a134c63bf08780dc1a6ac8263d /web/react/components/channel_notifications.jsx
parent66638c4f70adb3fa2777af03c6175347b8dbee6b (diff)
downloadchat-69e378c556e817ce494af8511220389407dbed89.tar.gz
chat-69e378c556e817ce494af8511220389407dbed89.tar.bz2
chat-69e378c556e817ce494af8511220389407dbed89.zip
Converted ChannelNotificationsModal to React-Bootstrap
Diffstat (limited to 'web/react/components/channel_notifications.jsx')
-rw-r--r--web/react/components/channel_notifications.jsx394
1 files changed, 0 insertions, 394 deletions
diff --git a/web/react/components/channel_notifications.jsx b/web/react/components/channel_notifications.jsx
deleted file mode 100644
index f57fc12c5..000000000
--- a/web/react/components/channel_notifications.jsx
+++ /dev/null
@@ -1,394 +0,0 @@
-// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
-// See License.txt for license information.
-
-var SettingItemMin = require('./setting_item_min.jsx');
-var SettingItemMax = require('./setting_item_max.jsx');
-
-var Utils = require('../utils/utils.jsx');
-var Client = require('../utils/client.jsx');
-var UserStore = require('../stores/user_store.jsx');
-var ChannelStore = require('../stores/channel_store.jsx');
-
-export default class ChannelNotifications extends React.Component {
- constructor(props) {
- super(props);
-
- this.onListenerChange = this.onListenerChange.bind(this);
- this.updateSection = this.updateSection.bind(this);
-
- this.handleSubmitNotifyLevel = this.handleSubmitNotifyLevel.bind(this);
- this.handleUpdateNotifyLevel = this.handleUpdateNotifyLevel.bind(this);
- this.createNotifyLevelSection = this.createNotifyLevelSection.bind(this);
-
- this.handleSubmitMarkUnreadLevel = this.handleSubmitMarkUnreadLevel.bind(this);
- this.handleUpdateMarkUnreadLevel = this.handleUpdateMarkUnreadLevel.bind(this);
- this.createMarkUnreadLevelSection = this.createMarkUnreadLevelSection.bind(this);
- this.onShow = this.onShow.bind(this);
-
- this.state = {
- notifyLevel: '',
- markUnreadLevel: '',
- title: '',
- channelId: '',
- activeSection: ''
- };
- }
- onShow(e) {
- var button = e.relatedTarget;
- var channelId = button.getAttribute('data-channelid');
-
- const member = ChannelStore.getMember(channelId);
- var notifyLevel = member.notify_props.desktop;
- var markUnreadLevel = member.notify_props.mark_unread;
-
- this.setState({
- notifyLevel,
- markUnreadLevel,
- title: button.getAttribute('data-title'),
- channelId
- });
- }
- componentDidMount() {
- ChannelStore.addChangeListener(this.onListenerChange);
-
- $(ReactDOM.findDOMNode(this.refs.modal)).on('show.bs.modal', this.onShow);
- }
- componentWillUnmount() {
- ChannelStore.removeChangeListener(this.onListenerChange);
- }
- onListenerChange() {
- if (!this.state.channelId) {
- return;
- }
-
- const member = ChannelStore.getMember(this.state.channelId);
- var notifyLevel = member.notify_props.desktop;
- var markUnreadLevel = member.notify_props.mark_unread;
-
- var newState = this.state;
- newState.notifyLevel = notifyLevel;
- newState.markUnreadLevel = markUnreadLevel;
-
- if (!Utils.areObjectsEqual(this.state, newState)) {
- this.setState(newState);
- }
- }
- updateSection(section) {
- this.setState({activeSection: section});
- }
- handleSubmitNotifyLevel() {
- var channelId = this.state.channelId;
- var notifyLevel = this.state.notifyLevel;
-
- if (ChannelStore.getMember(channelId).notify_props.desktop === notifyLevel) {
- this.updateSection('');
- return;
- }
-
- var data = {};
- data.channel_id = channelId;
- data.user_id = UserStore.getCurrentId();
- data.desktop = notifyLevel;
-
- Client.updateNotifyProps(data,
- () => {
- var member = ChannelStore.getMember(channelId);
- member.notify_props.desktop = notifyLevel;
- ChannelStore.setChannelMember(member);
- this.updateSection('');
- },
- (err) => {
- this.setState({serverError: err.message});
- }
- );
- }
- handleUpdateNotifyLevel(notifyLevel) {
- this.setState({notifyLevel});
- ReactDOM.findDOMNode(this.refs.modal).focus();
- }
- createNotifyLevelSection(serverError) {
- var handleUpdateSection;
-
- const user = UserStore.getCurrentUser();
- const globalNotifyLevel = user.notify_props.desktop;
-
- let globalNotifyLevelName;
- if (globalNotifyLevel === 'all') {
- globalNotifyLevelName = 'For all activity';
- } else if (globalNotifyLevel === 'mention') {
- globalNotifyLevelName = 'Only for mentions';
- } else {
- globalNotifyLevelName = 'Never';
- }
-
- if (this.state.activeSection === 'desktop') {
- var notifyActive = [false, false, false, false];
- if (this.state.notifyLevel === 'default') {
- notifyActive[0] = true;
- } else if (this.state.notifyLevel === 'all') {
- notifyActive[1] = true;
- } else if (this.state.notifyLevel === 'mention') {
- notifyActive[2] = true;
- } else {
- notifyActive[3] = true;
- }
-
- var inputs = [];
-
- inputs.push(
- <div key='channel-notification-level-radio'>
- <div className='radio'>
- <label>
- <input
- type='radio'
- checked={notifyActive[0]}
- onChange={this.handleUpdateNotifyLevel.bind(this, 'default')}
- />
- {`Global default (${globalNotifyLevelName})`}
- </label>
- <br/>
- </div>
- <div className='radio'>
- <label>
- <input
- type='radio'
- checked={notifyActive[1]}
- onChange={this.handleUpdateNotifyLevel.bind(this, 'all')}
- />
- {'For all activity'}
- </label>
- <br/>
- </div>
- <div className='radio'>
- <label>
- <input
- type='radio'
- checked={notifyActive[2]}
- onChange={this.handleUpdateNotifyLevel.bind(this, 'mention')}
- />
- {'Only for mentions'}
- </label>
- <br/>
- </div>
- <div className='radio'>
- <label>
- <input
- type='radio'
- checked={notifyActive[3]}
- onChange={this.handleUpdateNotifyLevel.bind(this, 'none')}
- />
- {'Never'}
- </label>
- </div>
- </div>
- );
-
- handleUpdateSection = function updateSection(e) {
- this.updateSection('');
- this.onListenerChange();
- e.preventDefault();
- }.bind(this);
-
- const extraInfo = (
- <span>
- {'Selecting an option other than "Default" will override the global notification settings. Desktop notifications are available on Firefox, Safari, and Chrome.'}
- </span>
- );
-
- return (
- <SettingItemMax
- title='Send desktop notifications'
- inputs={inputs}
- submit={this.handleSubmitNotifyLevel}
- server_error={serverError}
- updateSection={handleUpdateSection}
- extraInfo={extraInfo}
- />
- );
- }
-
- var describe;
- if (this.state.notifyLevel === 'default') {
- describe = `Global default (${globalNotifyLevelName})`;
- } else if (this.state.notifyLevel === 'mention') {
- describe = 'Only for mentions';
- } else if (this.state.notifyLevel === 'all') {
- describe = 'For all activity';
- } else {
- describe = 'Never';
- }
-
- handleUpdateSection = function updateSection(e) {
- this.updateSection('desktop');
- e.preventDefault();
- }.bind(this);
-
- return (
- <SettingItemMin
- title='Send desktop notifications'
- describe={describe}
- updateSection={handleUpdateSection}
- />
- );
- }
-
- handleSubmitMarkUnreadLevel() {
- const channelId = this.state.channelId;
- const markUnreadLevel = this.state.markUnreadLevel;
-
- if (ChannelStore.getMember(channelId).notify_props.mark_unread === markUnreadLevel) {
- this.updateSection('');
- return;
- }
-
- const data = {
- channel_id: channelId,
- user_id: UserStore.getCurrentId(),
- mark_unread: markUnreadLevel
- };
-
- Client.updateNotifyProps(data,
- () => {
- var member = ChannelStore.getMember(channelId);
- member.notify_props.mark_unread = markUnreadLevel;
- ChannelStore.setChannelMember(member);
- this.updateSection('');
- },
- (err) => {
- this.setState({serverError: err.message});
- }
- );
- }
-
- handleUpdateMarkUnreadLevel(markUnreadLevel) {
- this.setState({markUnreadLevel});
- ReactDOM.findDOMNode(this.refs.modal).focus();
- }
-
- createMarkUnreadLevelSection(serverError) {
- let content;
-
- if (this.state.activeSection === 'markUnreadLevel') {
- const inputs = [(
- <div key='channel-notification-unread-radio'>
- <div className='radio'>
- <label>
- <input
- type='radio'
- checked={this.state.markUnreadLevel === 'all'}
- onChange={this.handleUpdateMarkUnreadLevel.bind(this, 'all')}
- />
- {'For all unread messages'}
- </label>
- <br />
- </div>
- <div className='radio'>
- <label>
- <input
- type='radio'
- checked={this.state.markUnreadLevel === 'mention'}
- onChange={this.handleUpdateMarkUnreadLevel.bind(this, 'mention')}
- />
- {'Only for mentions'}
- </label>
- <br />
- </div>
- </div>
- )];
-
- const handleUpdateSection = function handleUpdateSection(e) {
- this.updateSection('');
- this.onListenerChange();
- e.preventDefault();
- }.bind(this);
-
- const extraInfo = <span>{'The channel name is bolded in the sidebar when there are unread messages. Selecting "Only for mentions" will bold the channel only when you are mentioned.'}</span>;
-
- content = (
- <SettingItemMax
- title='Mark Channel Unread'
- inputs={inputs}
- submit={this.handleSubmitMarkUnreadLevel}
- server_error={serverError}
- updateSection={handleUpdateSection}
- extraInfo={extraInfo}
- />
- );
- } else {
- let describe;
-
- if (!this.state.markUnreadLevel || this.state.markUnreadLevel === 'all') {
- describe = 'For all unread messages';
- } else {
- describe = 'Only for mentions';
- }
-
- const handleUpdateSection = function handleUpdateSection(e) {
- this.updateSection('markUnreadLevel');
- e.preventDefault();
- }.bind(this);
-
- content = (
- <SettingItemMin
- title='Mark Channel Unread'
- describe={describe}
- updateSection={handleUpdateSection}
- />
- );
- }
-
- return content;
- }
-
- render() {
- var serverError = null;
- if (this.state.serverError) {
- serverError = <div className='form-group has-error'><label className='control-label'>{this.state.serverError}</label></div>;
- }
-
- return (
- <div
- className='modal fade'
- id='channel_notifications'
- ref='modal'
- tabIndex='-1'
- role='dialog'
- aria-hidden='true'
- >
- <div className='modal-dialog settings-modal'>
- <div className='modal-content'>
- <div className='modal-header'>
- <button
- type='button'
- className='close'
- data-dismiss='modal'
- >
- <span aria-hidden='true'>&times;</span>
- <span className='sr-only'>{'Close'}</span>
- </button>
- <h4 className='modal-title'>Notification Preferences for <span className='name'>{this.state.title}</span></h4>
- </div>
- <div className='modal-body'>
- <div className='settings-table'>
- <div className='settings-content'>
- <div
- ref='wrapper'
- className='user-settings'
- >
- <br/>
- <div className='divider-dark first'/>
- {this.createNotifyLevelSection(serverError)}
- <div className='divider-light'/>
- {this.createMarkUnreadLevelSection(serverError)}
- <div className='divider-dark'/>
- </div>
- </div>
- </div>
- {serverError}
- </div>
- </div>
- </div>
- </div>
- );
- }
-}