Support config for email notifs

Add support to notif settings for adding an email pusher, only for the first email address for now.
This commit is contained in:
David Baker 2016-04-12 16:19:20 +01:00
parent be55882f46
commit 5d9c8f3726
1 changed files with 67 additions and 6 deletions
src/components/views/settings

View File

@ -226,6 +226,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,
@ -883,6 +888,41 @@ 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={ (e) => {
var emailPusherPromise;
if (e.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.",
});
});
}} />
</div>
<div className="mx_UserNotifSettings_labelCell">
<label htmlFor="enableEmailNotifications_{address}">
{label}
</label>
</div>
</div>);
},
render: function() { render: function() {
var self = this; var self = this;
@ -928,6 +968,23 @@ module.exports = React.createClass({
); );
} }
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) {
@ -958,17 +1015,19 @@ module.exports = React.createClass({
// 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) {
rows.push(<tr> var p = this.state.pushers[i];
<td>{this.state.pushers[i].app_display_name}</td>
<td>{this.state.pushers[i].device_display_name}</td> rows.push(<tr key={p.app_id+p.pushkey}>
<td>{p.app_display_name}</td>
<td>{p.device_display_name}</td>
</tr>); </tr>);
} }
devicesSection = (<table className="mx_UserSettings_devicesTable"> devicesSection = (<table className="mx_UserSettings_devicesTable"><thead>
<tr> <tr>
<th>Application</th> <th>Application</th>
<th>Device</th> <th>Device</th>
</tr> </tr></thead>
{rows} <tbody>{rows}</tbody>
</table>); </table>);
} }
@ -1026,6 +1085,8 @@ module.exports = React.createClass({
</div> </div>
</div> </div>
{ emailNotificationsRow }
<h3>General use</h3> <h3>General use</h3>
<div className="mx_UserNotifSettings_pushRulesTableWrapper"> <div className="mx_UserNotifSettings_pushRulesTableWrapper">