forked from matrix/element-web
Merge branch 'develop' of github.com:vector-im/vector-web into develop
This commit is contained in:
commit
d96e5a55e1
src/components/views/settings
|
@ -69,6 +69,11 @@ module.exports = React.createClass({
|
||||||
ERROR: "ERROR" // There was an error
|
ERROR: "ERROR" // There was an error
|
||||||
},
|
},
|
||||||
|
|
||||||
|
propTypes: {
|
||||||
|
// The array of threepids from the JS SDK (required for email notifications)
|
||||||
|
threepids: React.PropTypes.array.isRequired,
|
||||||
|
},
|
||||||
|
|
||||||
getInitialState: function() {
|
getInitialState: function() {
|
||||||
return {
|
return {
|
||||||
phase: this.phases.LOADING,
|
phase: this.phases.LOADING,
|
||||||
|
@ -102,6 +107,26 @@ module.exports = React.createClass({
|
||||||
UserSettingsStore.setEnableNotifications(event.target.checked);
|
UserSettingsStore.setEnableNotifications(event.target.checked);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onEnableEmailNotificationsChange: function(address, event) {
|
||||||
|
var emailPusherPromise;
|
||||||
|
if (event.target.checked) {
|
||||||
|
emailPusherPromise = UserSettingsStore.addEmailPusher(address);
|
||||||
|
} else {
|
||||||
|
var emailPusher = UserSettingsStore.getEmailPusher(this.state.pushers, address);
|
||||||
|
emailPusher.kind = null;
|
||||||
|
emailPusherPromise = MatrixClientPeg.get().setPusher(emailPusher);
|
||||||
|
}
|
||||||
|
emailPusherPromise.done(() => {
|
||||||
|
this._refreshFromServer();
|
||||||
|
}, (error) => {
|
||||||
|
var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
|
||||||
|
Modal.createDialog(ErrorDialog, {
|
||||||
|
title: "Error saving email notification preferences",
|
||||||
|
description: "Vector was unable to save your email notification preferences.",
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
onNotifStateButtonClicked: function(event) {
|
onNotifStateButtonClicked: function(event) {
|
||||||
// FIXME: use .bind() rather than className metadata here surely
|
// FIXME: use .bind() rather than className metadata here surely
|
||||||
var vectorRuleId = event.target.className.split("-")[0];
|
var vectorRuleId = event.target.className.split("-")[0];
|
||||||
|
@ -620,6 +645,24 @@ module.exports = React.createClass({
|
||||||
return rows;
|
return rows;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
emailNotificationsRow: function(address, label) {
|
||||||
|
return (<div className="mx_UserNotifSettings_tableRow">
|
||||||
|
<div className="mx_UserNotifSettings_inputCell">
|
||||||
|
<input id="enableEmailNotifications_{address}"
|
||||||
|
ref="enableEmailNotifications_{address}"
|
||||||
|
type="checkbox"
|
||||||
|
checked={ UserSettingsStore.hasEmailPusher(this.state.pushers, address) }
|
||||||
|
onChange={ this.onEnableEmailNotificationsChange.bind(this, address) }
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="mx_UserNotifSettings_labelCell">
|
||||||
|
<label htmlFor="enableEmailNotifications_{address}">
|
||||||
|
{label}
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>);
|
||||||
|
},
|
||||||
|
|
||||||
render: function() {
|
render: function() {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
|
@ -656,12 +699,29 @@ module.exports = React.createClass({
|
||||||
{masterPushRuleDiv}
|
{masterPushRuleDiv}
|
||||||
|
|
||||||
<div className="mx_UserSettings_notifTable">
|
<div className="mx_UserSettings_notifTable">
|
||||||
All notifications are currently disabled for all devices.
|
All notifications are currently disabled for all targets.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var emailNotificationsRow;
|
||||||
|
if (this.props.threepids.filter(function(tp) {
|
||||||
|
if (tp.medium == "email") {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}).length == 0) {
|
||||||
|
emailNotificationsRow = <div>
|
||||||
|
Add an email address above to configure email notifications
|
||||||
|
</div>;
|
||||||
|
} else {
|
||||||
|
// This only supports the first email address in your profile for now
|
||||||
|
emailNotificationsRow = this.emailNotificationsRow(
|
||||||
|
this.props.threepids[0].address,
|
||||||
|
"Enable email notifications ("+this.props.threepids[0].address+")"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Build external push rules
|
// Build external push rules
|
||||||
var externalRules = [];
|
var externalRules = [];
|
||||||
for (var i in this.state.externalPushRules) {
|
for (var i in this.state.externalPushRules) {
|
||||||
|
@ -682,13 +742,11 @@ module.exports = React.createClass({
|
||||||
|
|
||||||
var devicesSection;
|
var devicesSection;
|
||||||
if (this.state.pushers === undefined) {
|
if (this.state.pushers === undefined) {
|
||||||
devicesSection = <div className="error">Unable to fetch device list</div>
|
devicesSection = <div className="error">Unable to fetch notification target list</div>
|
||||||
} else if (this.state.pushers.length == 0) {
|
} else if (this.state.pushers.length == 0) {
|
||||||
devicesSection = <div className="mx_UserSettings_devicesTable_nodevices">
|
devicesSection = null;
|
||||||
No devices are receiving push notifications
|
|
||||||
</div>
|
|
||||||
} else {
|
} else {
|
||||||
// It would be great to be able to delete pushers from here too,
|
// TODO: It would be great to be able to delete pushers from here too,
|
||||||
// and this wouldn't be hard to add.
|
// and this wouldn't be hard to add.
|
||||||
var rows = [];
|
var rows = [];
|
||||||
for (var i = 0; i < this.state.pushers.length; ++i) {
|
for (var i = 0; i < this.state.pushers.length; ++i) {
|
||||||
|
@ -698,17 +756,17 @@ module.exports = React.createClass({
|
||||||
</tr>);
|
</tr>);
|
||||||
}
|
}
|
||||||
devicesSection = (<table className="mx_UserSettings_devicesTable">
|
devicesSection = (<table className="mx_UserSettings_devicesTable">
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th>Application</th>
|
|
||||||
<th>Device</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tbody>
|
<tbody>
|
||||||
{rows}
|
{rows}
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>);
|
</table>);
|
||||||
}
|
}
|
||||||
|
if (devicesSection) {
|
||||||
|
devicesSection = (<div>
|
||||||
|
<h3>Notification targets</h3>
|
||||||
|
{ devicesSection }
|
||||||
|
</div>);
|
||||||
|
}
|
||||||
|
|
||||||
var advancedSettings;
|
var advancedSettings;
|
||||||
if (externalRules.length) {
|
if (externalRules.length) {
|
||||||
|
@ -766,7 +824,7 @@ module.exports = React.createClass({
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3>General use</h3>
|
{ emailNotificationsRow }
|
||||||
|
|
||||||
<div className="mx_UserNotifSettings_pushRulesTableWrapper">
|
<div className="mx_UserNotifSettings_pushRulesTableWrapper">
|
||||||
<table className="mx_UserNotifSettings_pushRulesTable">
|
<table className="mx_UserNotifSettings_pushRulesTable">
|
||||||
|
@ -788,7 +846,6 @@ module.exports = React.createClass({
|
||||||
|
|
||||||
{ advancedSettings }
|
{ advancedSettings }
|
||||||
|
|
||||||
<h3>Devices</h3>
|
|
||||||
{ devicesSection }
|
{ devicesSection }
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in New Issue