FEATURE: add a Dismiss link to user menu that dismisses all notifications

This commit is contained in:
Neil Lalonde 2017-11-07 10:41:12 -05:00
parent 8f560f0bf4
commit 814502f7bb
5 changed files with 76 additions and 9 deletions

View File

@ -1,6 +1,7 @@
import { createWidget } from 'discourse/widgets/widget';
import { h } from 'virtual-dom';
import { formatUsername } from 'discourse/lib/utilities';
import { ajax } from 'discourse/lib/ajax';
let extraGlyphs;
@ -87,6 +88,46 @@ createWidget('user-menu-links', {
}
});
createWidget('user-menu-dismiss-link', {
tagName: 'div.dismiss-link',
buildKey: () => 'user-menu-dismiss-link',
defaultState() {
return { showDismiss: false };
},
html() {
if (this.state.showDismiss) {
return h('ul.menu-links',
h('li',
this.attach('link', {
action: 'dismissNotifications',
className: 'dismiss',
icon: 'check',
label: 'user.dismiss'
})
)
);
} else {
return '';
}
},
showDismissLink() {
this.state.showDismiss = true;
this.scheduleRerender();
},
dismissNotifications() {
ajax('/notifications/mark-read', { method: 'PUT' }).then(() => {
userNotifications.notificationsChanged();
});
}
});
let userNotifications = null,
dismissLink = null;
export default createWidget('user-menu', {
tagName: 'div.user-menu',
@ -96,16 +137,26 @@ export default createWidget('user-menu', {
panelContents() {
const path = this.currentUser.get('path');
userNotifications = this.attach('user-notifications', { path });
dismissLink = this.attach('user-menu-dismiss-link');
return [this.attach('user-menu-links', { path }),
this.attach('user-notifications', { path }),
return [
this.attach('user-menu-links', { path }),
userNotifications,
h('div.logout-link', [
h('ul.menu-links',
h('li', this.attach('link', { action: 'logout',
h('li',
this.attach('link', {
action: 'logout',
className: 'logout',
icon: 'sign-out',
label: 'user.log_out' })))
])];
label: 'user.log_out'
})
)
)
]),
dismissLink
];
},
html() {
@ -117,5 +168,9 @@ export default createWidget('user-menu', {
clickOutside() {
this.sendWidgetAction('toggleUserMenu');
},
notificationsLoaded() {
dismissLink.showDismissLink();
}
});

View File

@ -50,6 +50,9 @@ export default createWidget('user-notifications', {
}).finally(() => {
state.loading = false;
state.loaded = true;
if (state.notifications.get('length') > 0) {
this.sendWidgetAction('notificationsLoaded');
}
this.scheduleRerender();
});
},

View File

@ -257,6 +257,13 @@
/* as a big ol' click target, don't let text inside be selected */
@include unselectable;
}
.logout-link, .dismiss-link {
display: inline-block;
}
.dismiss-link {
float: right;
}
}
.notifications .logout {

View File

@ -590,6 +590,7 @@ en:
enable: "Enable Notifications"
currently_disabled: ""
each_browser_note: "Note: You have to change this setting on every browser you use."
dismiss: 'Dismiss'
dismiss_notifications: "Dismiss All"
dismiss_notifications_tooltip: "Mark all unread notifications as read"
first_notification: "Your first notification! Select it to begin."

View File

@ -11,6 +11,7 @@ widgetTest('basics', {
assert.ok(this.$('.user-bookmarks-link').length);
assert.ok(this.$('.user-preferences-link').length);
assert.ok(this.$('.notifications').length);
assert.ok(this.$('.dismiss-link').length);
}
});