mirror of https://github.com/vector-im/riot-web
Merge branch 'vector' into irc-style-commands
commit
00c45e48a9
|
@ -22,6 +22,7 @@ var MRoomMemberTileController = require("../../../../src/controllers/molecules/M
|
||||||
|
|
||||||
var MatrixClientPeg = require("../../../../src/MatrixClientPeg");
|
var MatrixClientPeg = require("../../../../src/MatrixClientPeg");
|
||||||
var ComponentBroker = require('../../../../src/ComponentBroker');
|
var ComponentBroker = require('../../../../src/ComponentBroker');
|
||||||
|
var TextForEvent = require('../../../../src/TextForEvent');
|
||||||
var MessageTimestamp = ComponentBroker.get('atoms/MessageTimestamp');
|
var MessageTimestamp = ComponentBroker.get('atoms/MessageTimestamp');
|
||||||
|
|
||||||
module.exports = React.createClass({
|
module.exports = React.createClass({
|
||||||
|
@ -29,34 +30,7 @@ module.exports = React.createClass({
|
||||||
mixins: [MRoomMemberTileController],
|
mixins: [MRoomMemberTileController],
|
||||||
|
|
||||||
getMemberEventText: function() {
|
getMemberEventText: function() {
|
||||||
var ev = this.props.mxEvent;
|
return TextForEvent.textForEvent(this.props.mxEvent);
|
||||||
// XXX: SYJS-16
|
|
||||||
var senderName = ev.sender ? ev.sender.name : "Someone";
|
|
||||||
var targetName = ev.target ? ev.target.name : "Someone";
|
|
||||||
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':
|
|
||||||
return targetName + " joined the room.";
|
|
||||||
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.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
render: function() {
|
render: function() {
|
||||||
|
|
|
@ -19,32 +19,14 @@ limitations under the License.
|
||||||
var NotifierController = require("../../../../src/controllers/organisms/Notifier");
|
var NotifierController = require("../../../../src/controllers/organisms/Notifier");
|
||||||
|
|
||||||
var MatrixClientPeg = require("../../../../src/MatrixClientPeg");
|
var MatrixClientPeg = require("../../../../src/MatrixClientPeg");
|
||||||
|
var TextForEvent = require("../../../../src/TextForEvent");
|
||||||
var extend = require("../../../../src/extend");
|
var extend = require("../../../../src/extend");
|
||||||
var dis = require("../../../../src/dispatcher");
|
var dis = require("../../../../src/dispatcher");
|
||||||
|
|
||||||
|
|
||||||
var NotifierView = {
|
var NotifierView = {
|
||||||
notificationMessageForEvent: function(ev) {
|
notificationMessageForEvent: function(ev) {
|
||||||
var senderDisplayName = ev.sender ? ev.sender.name : '';
|
return TextForEvent.textForEvent(ev);
|
||||||
var message = null;
|
|
||||||
|
|
||||||
if (ev.event.type === "m.room.message") {
|
|
||||||
message = ev.getContent().body;
|
|
||||||
if (ev.getContent().msgtype === "m.emote") {
|
|
||||||
message = "* " + senderDisplayName + " " + message;
|
|
||||||
} else if (ev.getContent().msgtype === "m.image") {
|
|
||||||
message = senderDisplayName + " sent an image.";
|
|
||||||
}
|
|
||||||
} else if (ev.event.type == "m.room.member") {
|
|
||||||
if (ev.event.state_key !== MatrixClientPeg.get().credentials.userId && "join" === ev.getContent().membership) {
|
|
||||||
// Notify when another user joins
|
|
||||||
message = senderDisplayName + " joined";
|
|
||||||
} else if (ev.event.state_key === MatrixClientPeg.get().credentials.userId && "invite" === ev.getContent().membership) {
|
|
||||||
// notify when you are invited
|
|
||||||
message = senderDisplayName + " invited you to a room";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return message;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
displayNotification: function(ev, room) {
|
displayNotification: function(ev, room) {
|
||||||
|
@ -61,8 +43,18 @@ var NotifierView = {
|
||||||
var title;
|
var title;
|
||||||
if (!ev.sender || room.name == ev.sender.name) {
|
if (!ev.sender || room.name == ev.sender.name) {
|
||||||
title = room.name;
|
title = room.name;
|
||||||
|
// notificationMessageForEvent includes sender,
|
||||||
|
// but we already have the sender here
|
||||||
|
if (ev.getContent().body) msg = ev.getContent().body;
|
||||||
|
} else if (ev.getType() == 'm.room.member') {
|
||||||
|
// context is all in the message here, we don't need
|
||||||
|
// to display sender info
|
||||||
|
title = room.name;
|
||||||
} else if (ev.sender) {
|
} else if (ev.sender) {
|
||||||
title = ev.sender.name + " (" + room.name + ")";
|
title = ev.sender.name + " (" + room.name + ")";
|
||||||
|
// notificationMessageForEvent includes sender,
|
||||||
|
// but we've just out sender in the title
|
||||||
|
if (ev.getContent().body) msg = ev.getContent().body;
|
||||||
}
|
}
|
||||||
|
|
||||||
var notification = new global.Notification(
|
var notification = new global.Notification(
|
||||||
|
|
|
@ -0,0 +1,67 @@
|
||||||
|
|
||||||
|
function textForMemberEvent(ev) {
|
||||||
|
// XXX: SYJS-16
|
||||||
|
var senderName = ev.sender ? ev.sender.name : ev.getSender();
|
||||||
|
var targetName = ev.target ? ev.target.name : ev.getContent().target;
|
||||||
|
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) {
|
||||||
|
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 {
|
||||||
|
return targetName + " joined the room.";
|
||||||
|
}
|
||||||
|
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 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;
|
||||||
|
};
|
||||||
|
|
||||||
|
var handlers = {
|
||||||
|
'm.room.message': textForMessageEvent,
|
||||||
|
'm.room.member': textForMemberEvent
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
textForEvent(ev) {
|
||||||
|
var hdlr = handlers[ev.getType()];
|
||||||
|
if (!hdlr) return "Unknown entry event";
|
||||||
|
return hdlr(ev);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue