diff options
author | David Lu <david.lu@hotmail.com> | 2016-06-04 08:23:44 -0700 |
---|---|---|
committer | Joram Wilander <jwawilander@gmail.com> | 2016-06-04 11:23:44 -0400 |
commit | 6f0a7e4b137e193e6cfaac6aa90f0c91ec6b139c (patch) | |
tree | 6739f11fd6b0d303a0e997ec12bd7193d6dac302 | |
parent | 06b16467983e63c24bbf60535f88b1b2898e52ed (diff) | |
download | chat-6f0a7e4b137e193e6cfaac6aa90f0c91ec6b139c.tar.gz chat-6f0a7e4b137e193e6cfaac6aa90f0c91ec6b139c.tar.bz2 chat-6f0a7e4b137e193e6cfaac6aa90f0c91ec6b139c.zip |
PLT-2981 Disabled Push Notifications section in Settings if disabled by admin (#3225)
* Added push notifications disabled message to settings
* Update user_settings_notifications.jsx
-rw-r--r-- | webapp/components/user_settings/user_settings_notifications.jsx | 148 | ||||
-rw-r--r-- | webapp/i18n/en.json | 2 |
2 files changed, 87 insertions, 63 deletions
diff --git a/webapp/components/user_settings/user_settings_notifications.jsx b/webapp/components/user_settings/user_settings_notifications.jsx index 410ce1a4e..6b07f59e2 100644 --- a/webapp/components/user_settings/user_settings_notifications.jsx +++ b/webapp/components/user_settings/user_settings_notifications.jsx @@ -263,71 +263,89 @@ class NotificationsTab extends React.Component { } let inputs = []; + let extraInfo = null; + let submit = null; - inputs.push( - <div key='userNotificationLevelOption'> - <div className='radio'> - <label> - <input - type='radio' - name='pushNotificationLevel' - checked={notifyActive[0]} - onChange={this.handlePushRadio.bind(this, 'all')} - /> - <FormattedMessage - id='user.settings.push_notification.allActivity' - defaultMessage='For all activity' - /> - </label> - <br/> - </div> - <div className='radio'> - <label> - <input - type='radio' - name='pushNotificationLevel' - checked={notifyActive[1]} - onChange={this.handlePushRadio.bind(this, 'mention')} - /> - <FormattedMessage - id='user.settings.push_notifications.onlyMentions' - defaultMessage='For mentions and direct messages' - /> - </label> - <br/> - </div> - <div className='radio'> - <label> - <input - type='radio' - name='pushNotificationLevel' - checked={notifyActive[2]} - onChange={this.handlePushRadio.bind(this, 'none')} - /> - <FormattedMessage - id='user.settings.push_notifications.off' - defaultMessage='Off' - /> - </label> + if (global.window.mm_config.SendPushNotifications === 'true') { + inputs.push( + <div key='userNotificationLevelOption'> + <div className='radio'> + <label> + <input + type='radio' + name='pushNotificationLevel' + checked={notifyActive[0]} + onChange={this.handlePushRadio.bind(this, 'all')} + /> + <FormattedMessage + id='user.settings.push_notification.allActivity' + defaultMessage='For all activity' + /> + </label> + <br/> + </div> + <div className='radio'> + <label> + <input + type='radio' + name='pushNotificationLevel' + checked={notifyActive[1]} + onChange={this.handlePushRadio.bind(this, 'mention')} + /> + <FormattedMessage + id='user.settings.push_notification.onlyMentions' + defaultMessage='For mentions and direct messages' + /> + </label> + <br/> + </div> + <div className='radio'> + <label> + <input + type='radio' + name='pushNotificationLevel' + checked={notifyActive[2]} + onChange={this.handlePushRadio.bind(this, 'none')} + /> + <FormattedMessage + id='user.settings.push_notification.off' + defaultMessage='Off' + /> + </label> + </div> </div> - </div> - ); + ); - const extraInfo = ( - <span> - <FormattedMessage - id='user.settings.push_notifications.info' - defaultMessage='Notification alerts are pushed to your mobile device when there is activity in Mattermost.' - /> - </span> - ); + extraInfo = ( + <span> + <FormattedMessage + id='user.settings.push_notification.info' + defaultMessage='Notification alerts are pushed to your mobile device when there is activity in Mattermost.' + /> + </span> + ); + + submit = this.handleSubmit(); + } else { + inputs.push( + <div + key='oauthEmailInfo' + className='form-group' + > + <FormattedMessage + id='user.settings.push_notification.disabled_long' + defaultMessage='Push notifications for mobile devices have been disabled by your System Administrator.' + /> + </div> + ); + } return ( <SettingItemMax title={Utils.localizeMessage('user.settings.notifications.push', 'Mobile push notifications')} extraInfo={extraInfo} inputs={inputs} - submit={this.handleSubmit} + submit={submit} server_error={this.state.serverError} updateSection={this.handleCancel} /> @@ -345,14 +363,21 @@ class NotificationsTab extends React.Component { } else if (this.state.notifyPushLevel === 'none') { describe = ( <FormattedMessage - id='user.settings.push_notifications.off' + id='user.settings.push_notification.off' defaultMessage='Off' /> ); + } else if (global.window.mm_config.SendPushNotifications === 'false') { + describe = ( + <FormattedMessage + id='user.settings.push_notification.disabled' + defaultMessage='Disabled by system administrator' + /> + ); } else { describe = ( <FormattedMessage - id='user.settings.push_notifications.onlyMentions' + id='user.settings.push_notification.onlyMentions' defaultMessage='For mentions and direct messages' /> ); @@ -364,7 +389,7 @@ class NotificationsTab extends React.Component { return ( <SettingItemMin - title={Utils.localizeMessage('user.settings.notifications.push', 'Mobile push notifications')} + title={Utils.localizeMessage('user.settings.notification.push', 'Mobile push notifications')} describe={describe} updateSection={handleUpdateDesktopSection} /> @@ -911,10 +936,7 @@ class NotificationsTab extends React.Component { ); } - let pushNotificationSection; - if (global.window.mm_config.SendPushNotifications === 'true') { - pushNotificationSection = this.createPushNotificationSection(); - } + const pushNotificationSection = this.createPushNotificationSection(); return ( <div> diff --git a/webapp/i18n/en.json b/webapp/i18n/en.json index 19ff71f95..086868cbd 100644 --- a/webapp/i18n/en.json +++ b/webapp/i18n/en.json @@ -1393,6 +1393,8 @@ "user.settings.push_notification.info": "Notification alerts are pushed to your mobile device when there is activity in Mattermost.", "user.settings.push_notification.off": "Off", "user.settings.push_notification.onlyMentions": "For mentions and direct messages", + "user.settings.push_notification.disabled": "Disabled by system administrator", + "user.settings.push_notification.disabled_long": "Push notifications for mobile devices have been disabled by your System Administrator.", "user.settings.security.close": "Close", "user.settings.security.currentPassword": "Current Password", "user.settings.security.currentPasswordError": "Please enter your current password", |