diff --git a/src/components/views/rooms/RoomSettings.js b/src/components/views/rooms/RoomSettings.js
index 8269c539f1..c996719614 100644
--- a/src/components/views/rooms/RoomSettings.js
+++ b/src/components/views/rooms/RoomSettings.js
@@ -587,7 +587,7 @@ module.exports = React.createClass({
- Mute notifications for this room
+ 'Mention only' notifications for this room
Who can access this room?
diff --git a/src/components/views/rooms/RoomTile.js b/src/components/views/rooms/RoomTile.js
index ae87e6737d..132f02a1e2 100644
--- a/src/components/views/rooms/RoomTile.js
+++ b/src/components/views/rooms/RoomTile.js
@@ -68,7 +68,7 @@ module.exports = React.createClass({
case 'notification_change':
// Is the notification about this room?
if (payload.roomId === this.props.room.roomId) {
- this.setState( { areNotifsMuted : payload.isMuted });
+ this.setState( { areNotifsMuted : payload.areNotifsMuted });
}
break;
}
@@ -137,6 +137,8 @@ module.exports = React.createClass({
});
this.setState({ menu: true });
}
+ // Prevent the RoomTile onClick event firing as well
+ e.stopPropagation();
},
onAvatarClicked: function(e) {
@@ -178,22 +180,20 @@ module.exports = React.createClass({
'mx_RoomTile': true,
'mx_RoomTile_selected': this.props.selected,
'mx_RoomTile_unread': this.props.unread,
- 'mx_RoomTile_unreadNotify': notificationCount > 0,
- 'mx_RoomTile_read': !(this.props.highlight || notificationCount > 0),
+ 'mx_RoomTile_unreadNotify': notificationCount > 0 && !this.state.areNotifsMuted,
'mx_RoomTile_highlight': this.props.highlight,
'mx_RoomTile_invited': (me && me.membership == 'invite'),
'mx_RoomTile_menu': this.state.menu,
+ 'mx_RoomTile_noBadges': !(this.props.highlight || (notificationCount > 0 && !this.state.areNotifsMuted))
});
var avatarClasses = classNames({
'mx_RoomTile_avatar': true,
- 'mx_RoomTile_mute': this.state.areNotifsMuted,
});
var badgeClasses = classNames({
'mx_RoomTile_badge': true,
'mx_RoomTile_badgeButton': this.state.badgeHover || this.state.menu,
- 'mx_RoomTile_badgeMute': this.state.areNotifsMuted,
});
// XXX: We should never display raw room IDs, but sometimes the
@@ -206,18 +206,14 @@ module.exports = React.createClass({
if (this.state.badgeHover || this.state.menu) {
badgeContent = "\u00B7\u00B7\u00B7";
- } else if (this.props.highlight || notificationCount > 0) {
+ } else if (this.props.highlight || (notificationCount > 0 && !this.state.areNotifsMuted)) {
var limitedCount = (notificationCount > 99) ? '99+' : notificationCount;
badgeContent = notificationCount ? limitedCount : '!';
} else {
badgeContent = '\u200B';
}
- if (this.state.areNotifsMuted && !(this.state.badgeHover || this.state.menu)) {
- badge =
;
- } else {
- badge =
{ badgeContent }
;
- }
+ badge =
{ badgeContent }
;
var label;
var tooltip;
@@ -225,17 +221,16 @@ module.exports = React.createClass({
var nameClasses = classNames({
'mx_RoomTile_name': true,
'mx_RoomTile_invite': this.props.isInvite,
- 'mx_RoomTile_mute': this.state.areNotifsMuted,
- 'mx_RoomTile_badgeShown': this.props.highlight || notificationCount > 0 || this.state.badgeHover || this.state.menu || this.state.areNotifsMuted,
+ 'mx_RoomTile_badgeShown': this.props.highlight || (notificationCount > 0 && !this.state.areNotifsMuted) || this.state.badgeHover || this.state.menu,
});
let nameHTML = emojifyText(name);
if (this.props.selected) {
let nameSelected =
;
- label =
{ nameSelected }
;
+ label =
{ nameSelected }
;
} else {
- label =
;
+ label =
;
}
}
else if (this.state.hover) {
@@ -258,9 +253,9 @@ module.exports = React.createClass({
var connectDropTarget = this.props.connectDropTarget;
return connectDragSource(connectDropTarget(
-