Backport Notifier improvements from Vector, including TextForEvent
This commit is contained in:
parent
25ab56106a
commit
a4cbbf0d92
3 changed files with 211 additions and 36 deletions
106
src/TextForEvent.js
Normal file
106
src/TextForEvent.js
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
|
||||||
|
function textForMemberEvent(ev) {
|
||||||
|
// XXX: SYJS-16
|
||||||
|
var senderName = ev.sender ? ev.sender.name : ev.getSender();
|
||||||
|
var targetName = ev.target ? ev.target.name : ev.getStateKey();
|
||||||
|
var reason = ev.getContent().reason ? (
|
||||||
|
" Reason: " + ev.getContent().reason
|
||||||
|
) : "";
|
||||||
|
switch (ev.getContent().membership) {
|
||||||
|
case 'invite':
|
||||||
|
return senderName + " invited " + targetName + ".";
|
||||||
|
case 'ban':
|
||||||
|
return senderName + " banned " + targetName + "." + reason;
|
||||||
|
case 'join':
|
||||||
|
if (ev.getPrevContent() && ev.getPrevContent().membership == 'join') {
|
||||||
|
if (ev.getPrevContent().displayname && ev.getContent().displayname && ev.getPrevContent().displayname != ev.getContent().displayname) {
|
||||||
|
return ev.getSender() + " changed their display name from " +
|
||||||
|
ev.getPrevContent().displayname + " to " +
|
||||||
|
ev.getContent().displayname;
|
||||||
|
} else if (!ev.getPrevContent().displayname && ev.getContent().displayname) {
|
||||||
|
return ev.getSender() + " set their display name to " + ev.getContent().displayname;
|
||||||
|
} else if (ev.getPrevContent().displayname && !ev.getContent().displayname) {
|
||||||
|
return ev.getSender() + " removed their display name";
|
||||||
|
} else if (ev.getPrevContent().avatar_url && !ev.getContent().avatar_url) {
|
||||||
|
return ev.getSender() + " removed their profile picture";
|
||||||
|
} else if (ev.getPrevContent().avatar_url && ev.getContent().avatar_url && ev.getPrevContent().avatar_url != ev.getContent().avatar_url) {
|
||||||
|
return ev.getSender() + " changed their profile picture";
|
||||||
|
} else if (!ev.getPrevContent().avatar_url && ev.getContent().avatar_url) {
|
||||||
|
return ev.getSender() + " set a profile picture";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (!ev.target) console.warn("Join message has no target! -- " + ev.getContent().state_key);
|
||||||
|
return targetName + " joined the room.";
|
||||||
|
}
|
||||||
|
return '';
|
||||||
|
case 'leave':
|
||||||
|
if (ev.getSender() === ev.getStateKey()) {
|
||||||
|
return targetName + " left the room.";
|
||||||
|
}
|
||||||
|
else if (ev.getPrevContent().membership === "ban") {
|
||||||
|
return senderName + " unbanned " + targetName + ".";
|
||||||
|
}
|
||||||
|
else if (ev.getPrevContent().membership === "join") {
|
||||||
|
return senderName + " kicked " + targetName + "." + reason;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return targetName + " left the room.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function textForTopicEvent(ev) {
|
||||||
|
var senderDisplayName = ev.sender && ev.sender.name ? ev.sender.name : ev.getSender();
|
||||||
|
|
||||||
|
return senderDisplayName + ' changed the topic to, "' + ev.getContent().topic + '"';
|
||||||
|
};
|
||||||
|
|
||||||
|
function textForMessageEvent(ev) {
|
||||||
|
var senderDisplayName = ev.sender && ev.sender.name ? ev.sender.name : ev.getSender();
|
||||||
|
|
||||||
|
var message = senderDisplayName + ': ' + ev.getContent().body;
|
||||||
|
if (ev.getContent().msgtype === "m.emote") {
|
||||||
|
message = "* " + senderDisplayName + " " + message;
|
||||||
|
} else if (ev.getContent().msgtype === "m.image") {
|
||||||
|
message = senderDisplayName + " sent an image.";
|
||||||
|
}
|
||||||
|
return message;
|
||||||
|
};
|
||||||
|
|
||||||
|
function textForCallAnswerEvent(event) {
|
||||||
|
var senderName = event.sender ? event.sender.name : "Someone";
|
||||||
|
return senderName + " answered the call.";
|
||||||
|
};
|
||||||
|
|
||||||
|
function textForCallHangupEvent(event) {
|
||||||
|
var senderName = event.sender ? event.sender.name : "Someone";
|
||||||
|
return senderName + " ended the call.";
|
||||||
|
};
|
||||||
|
|
||||||
|
function textForCallInviteEvent(event) {
|
||||||
|
var senderName = event.sender ? event.sender.name : "Someone";
|
||||||
|
// FIXME: Find a better way to determine this from the event?
|
||||||
|
var type = "voice";
|
||||||
|
if (event.getContent().offer && event.getContent().offer.sdp &&
|
||||||
|
event.getContent().offer.sdp.indexOf('m=video') !== -1) {
|
||||||
|
type = "video";
|
||||||
|
}
|
||||||
|
return senderName + " placed a " + type + " call.";
|
||||||
|
};
|
||||||
|
|
||||||
|
var handlers = {
|
||||||
|
'm.room.message': textForMessageEvent,
|
||||||
|
'm.room.topic': textForTopicEvent,
|
||||||
|
'm.room.member': textForMemberEvent,
|
||||||
|
'm.call.invite': textForCallInviteEvent,
|
||||||
|
'm.call.answer': textForCallAnswerEvent,
|
||||||
|
'm.call.hangup': textForCallHangupEvent,
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
textForEvent: function(ev) {
|
||||||
|
var hdlr = handlers[ev.getType()];
|
||||||
|
if (!hdlr) return "";
|
||||||
|
return hdlr(ev);
|
||||||
|
}
|
||||||
|
}
|
|
@ -15,53 +15,43 @@ limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
var sdk = require('../../index');
|
||||||
|
var Notifier = sdk.getComponent('organisms/Notifier');
|
||||||
|
var dis = require("../../dispatcher");
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
notificationsAvailable: function() {
|
|
||||||
return !!global.Notification;
|
componentDidMount: function() {
|
||||||
|
this.dispatcherRef = dis.register(this.onAction);
|
||||||
},
|
},
|
||||||
|
|
||||||
havePermission: function() {
|
componentWillUnmount: function() {
|
||||||
return global.Notification.permission == 'granted';
|
dis.unregister(this.dispatcherRef);
|
||||||
|
},
|
||||||
|
|
||||||
|
onAction: function(payload) {
|
||||||
|
if (payload.action !== "notifier_enabled") {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.forceUpdate();
|
||||||
},
|
},
|
||||||
|
|
||||||
enabled: function() {
|
enabled: function() {
|
||||||
if (!this.havePermission()) return false;
|
return Notifier.isEnabled();
|
||||||
|
|
||||||
if (!global.localStorage) return true;
|
|
||||||
|
|
||||||
var enabled = global.localStorage.getItem('notifications_enabled');
|
|
||||||
if (enabled === null) return true;
|
|
||||||
return enabled === 'true';
|
|
||||||
},
|
|
||||||
|
|
||||||
disable: function() {
|
|
||||||
if (!global.localStorage) return;
|
|
||||||
global.localStorage.setItem('notifications_enabled', 'false');
|
|
||||||
this.forceUpdate();
|
|
||||||
},
|
|
||||||
|
|
||||||
enable: function() {
|
|
||||||
if (!this.havePermission()) {
|
|
||||||
var that = this;
|
|
||||||
global.Notification.requestPermission(function() {
|
|
||||||
that.forceUpdate();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!global.localStorage) return;
|
|
||||||
global.localStorage.setItem('notifications_enabled', 'true');
|
|
||||||
this.forceUpdate();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
onClick: function() {
|
onClick: function() {
|
||||||
if (!this.notificationsAvailable()) {
|
var self = this;
|
||||||
|
if (!Notifier.supportsDesktopNotifications()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!this.enabled()) {
|
if (!Notifier.isEnabled()) {
|
||||||
this.enable();
|
Notifier.setEnabled(true, function() {
|
||||||
|
self.forceUpdate();
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
this.disable();
|
Notifier.setEnabled(false);
|
||||||
}
|
}
|
||||||
|
this.forceUpdate();
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
|
@ -17,11 +17,21 @@ limitations under the License.
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var MatrixClientPeg = require("../../MatrixClientPeg");
|
var MatrixClientPeg = require("../../MatrixClientPeg");
|
||||||
|
var dis = require("../../dispatcher");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Dispatches:
|
||||||
|
* {
|
||||||
|
* action: "notifier_enabled",
|
||||||
|
* value: boolean
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
start: function() {
|
start: function() {
|
||||||
this.boundOnRoomTimeline = this.onRoomTimeline.bind(this);
|
this.boundOnRoomTimeline = this.onRoomTimeline.bind(this);
|
||||||
MatrixClientPeg.get().on('Room.timeline', this.boundOnRoomTimeline);
|
MatrixClientPeg.get().on('Room.timeline', this.boundOnRoomTimeline);
|
||||||
|
this.state = { 'toolbarHidden' : false };
|
||||||
},
|
},
|
||||||
|
|
||||||
stop: function() {
|
stop: function() {
|
||||||
|
@ -30,12 +40,81 @@ module.exports = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
supportsDesktopNotifications: function() {
|
||||||
|
return !!global.Notification;
|
||||||
|
},
|
||||||
|
|
||||||
|
havePermission: function() {
|
||||||
|
if (!this.supportsDesktopNotifications()) return false;
|
||||||
|
return global.Notification.permission == 'granted';
|
||||||
|
},
|
||||||
|
|
||||||
|
setEnabled: function(enable, callback) {
|
||||||
|
if(enable) {
|
||||||
|
if (!this.havePermission()) {
|
||||||
|
var self = this;
|
||||||
|
global.Notification.requestPermission(function() {
|
||||||
|
if (callback) {
|
||||||
|
callback();
|
||||||
|
dis.dispatch({
|
||||||
|
action: "notifier_enabled",
|
||||||
|
value: true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!global.localStorage) return;
|
||||||
|
global.localStorage.setItem('notifications_enabled', 'true');
|
||||||
|
|
||||||
|
if (this.havePermission) {
|
||||||
|
dis.dispatch({
|
||||||
|
action: "notifier_enabled",
|
||||||
|
value: true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (!global.localStorage) return;
|
||||||
|
global.localStorage.setItem('notifications_enabled', 'false');
|
||||||
|
dis.dispatch({
|
||||||
|
action: "notifier_enabled",
|
||||||
|
value: false
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setToolbarHidden(false);
|
||||||
|
},
|
||||||
|
|
||||||
|
isEnabled: function() {
|
||||||
|
if (!this.havePermission()) return false;
|
||||||
|
|
||||||
|
if (!global.localStorage) return true;
|
||||||
|
|
||||||
|
var enabled = global.localStorage.getItem('notifications_enabled');
|
||||||
|
if (enabled === null) return true;
|
||||||
|
return enabled === 'true';
|
||||||
|
},
|
||||||
|
|
||||||
|
setToolbarHidden: function(hidden) {
|
||||||
|
this.state.toolbarHidden = hidden;
|
||||||
|
dis.dispatch({
|
||||||
|
action: "notifier_enabled",
|
||||||
|
value: this.isEnabled()
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
isToolbarHidden: function() {
|
||||||
|
return this.state.toolbarHidden;
|
||||||
|
},
|
||||||
|
|
||||||
onRoomTimeline: function(ev, room, toStartOfTimeline) {
|
onRoomTimeline: function(ev, room, toStartOfTimeline) {
|
||||||
if (toStartOfTimeline) return;
|
if (toStartOfTimeline) return;
|
||||||
if (ev.sender && ev.sender.userId == MatrixClientPeg.get().credentials.userId) return;
|
if (ev.sender && ev.sender.userId == MatrixClientPeg.get().credentials.userId) return;
|
||||||
|
|
||||||
var enabled = global.localStorage.getItem('notifications_enabled');
|
if (!this.isEnabled()) {
|
||||||
if (enabled === 'false') return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
var actions = MatrixClientPeg.get().getPushActionsForEvent(ev);
|
var actions = MatrixClientPeg.get().getPushActionsForEvent(ev);
|
||||||
if (actions && actions.notify) {
|
if (actions && actions.notify) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue