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( -
+
- +
{ label }