on click roomsublist notif badge, goto first room with notif

Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
This commit is contained in:
Michael Telatynski 2018-06-27 09:16:37 +01:00
parent f40802e9d8
commit b3341e6664
No known key found for this signature in database
GPG key ID: 3F879DA5AD802A5E
2 changed files with 30 additions and 1 deletions

View file

@ -91,6 +91,10 @@ limitations under the License.
background-color: $accent-color; background-color: $accent-color;
} }
.mx_RoomSubList_label .mx_RoomSubList_badge:hover {
filter: brightness($focus-brightness);
}
/* /*
.collapsed .mx_RoomSubList_badge { .collapsed .mx_RoomSubList_badge {
display: none; display: none;

View file

@ -237,6 +237,29 @@ const RoomSubList = React.createClass({
}); });
}, },
_onNotifBadgeClick: function(e) {
// prevent the roomsublist collapsing
e.preventDefault();
e.stopPropagation();
// find first room which has notifications and switch to it
for (const room of this.state.sortedList) {
const roomNotifState = RoomNotifs.getRoomNotifsState(room.roomId);
const highlight = room.getUnreadNotificationCount('highlight') > 0;
const notificationCount = room.getUnreadNotificationCount();
const notifBadges = notificationCount > 0 && this._shouldShowNotifBadge(roomNotifState);
const mentionBadges = highlight && this._shouldShowMentionBadge(roomNotifState);
if (notifBadges || mentionBadges) {
dis.dispatch({
action: 'view_room',
room_id: room.roomId,
});
return;
}
}
},
_getHeaderJsx: function() { _getHeaderJsx: function() {
const subListNotifications = this.roomNotificationCount(); const subListNotifications = this.roomNotificationCount();
const subListNotifCount = subListNotifications[0]; const subListNotifCount = subListNotifications[0];
@ -258,7 +281,9 @@ const RoomSubList = React.createClass({
let badge; let badge;
if (subListNotifCount > 0) { if (subListNotifCount > 0) {
badge = <div className={badgeClasses}>{FormattingUtils.formatCount(subListNotifCount)}</div>; badge = <div className={badgeClasses} onClick={this._onNotifBadgeClick}>
{ FormattingUtils.formatCount(subListNotifCount) }
</div>;
} else if (this.props.isInvite) { } else if (this.props.isInvite) {
// no notifications but highlight anyway because this is an invite badge // no notifications but highlight anyway because this is an invite badge
badge = <div className={badgeClasses}>!</div>; badge = <div className={badgeClasses}>!</div>;