Refine dismiss notification confirmation (#15017)

This commit is contained in:
Natalie Tay 2021-11-22 09:11:24 +08:00 committed by GitHub
parent fa6b87a1bf
commit d46e450733
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 48 additions and 31 deletions

View File

@ -0,0 +1,11 @@
import Controller from "@ember/controller";
import ModalFunctionality from "discourse/mixins/modal-functionality";
export default Controller.extend(ModalFunctionality, {
actions: {
dismiss() {
this.send("closeModal");
this.dismissNotifications();
},
},
});

View File

@ -0,0 +1,15 @@
{{#d-modal-body headerClass="hidden" class="dismiss-notification-confirmation"}}
{{i18n "notifications.dismiss_confirmation.body" count=count}}
{{/d-modal-body}}
<div class="modal-footer">
{{d-button
icon="check"
class="btn-primary"
action=(action "dismiss")
label="notifications.dismiss_confirmation.dismiss"}}
{{d-button
action=(route-action "closeModal")
label="notifications.dismiss_confirmation.cancel"
class="btn-default"}}
</div>

View File

@ -1,8 +1,7 @@
import { later } from "@ember/runloop"; import { later } from "@ember/runloop";
import bootbox from "bootbox";
import { createWidget } from "discourse/widgets/widget"; import { createWidget } from "discourse/widgets/widget";
import I18n from "I18n";
import { h } from "virtual-dom"; import { h } from "virtual-dom";
import showModal from "discourse/lib/show-modal";
const UserMenuAction = { const UserMenuAction = {
QUICK_ACCESS: "quickAccess", QUICK_ACCESS: "quickAccess",
@ -256,18 +255,10 @@ export default createWidget("user-menu", {
); );
if (unreadHighPriorityNotifications > 0) { if (unreadHighPriorityNotifications > 0) {
return bootbox.confirm( return showModal("dismiss-notification-confirmation").setProperties({
I18n.t("notifications.dismiss_confirmation.body", { count: unreadHighPriorityNotifications,
count: unreadHighPriorityNotifications, dismissNotifications: () => this.state.markRead(),
}), });
I18n.t("notifications.dismiss_confirmation.cancel"),
I18n.t("notifications.dismiss_confirmation.confirm"),
(result) => {
if (result) {
this.state.markRead();
}
}
);
} else { } else {
return this.state.markRead(); return this.state.markRead();
} }

View File

@ -5,6 +5,7 @@ import {
query, query,
updateCurrentUser, updateCurrentUser,
} from "discourse/tests/helpers/qunit-helpers"; } from "discourse/tests/helpers/qunit-helpers";
import I18n from "I18n";
import { test } from "qunit"; import { test } from "qunit";
import pretender from "../helpers/create-pretender"; import pretender from "../helpers/create-pretender";
@ -19,7 +20,7 @@ acceptance("Dismiss notification confirmation", function (needs) {
await visit("/"); await visit("/");
await click(".current-user"); await click(".current-user");
await click(".notifications-dismiss"); await click(".notifications-dismiss");
assert.notOk(exists(".bootbox.modal")); assert.notOk(exists(".dismiss-notification-confirmation"));
}); });
test("shows confirmation modal", async function (assert) { test("shows confirmation modal", async function (assert) {
@ -29,13 +30,12 @@ acceptance("Dismiss notification confirmation", function (needs) {
await visit("/"); await visit("/");
await click(".current-user"); await click(".current-user");
await click(".notifications-dismiss"); await click(".notifications-dismiss");
assert.ok(exists(".bootbox.modal")); assert.ok(exists(".dismiss-notification-confirmation"));
assert.strictEqual( assert.strictEqual(
query(".bootbox.modal .modal-body").innerText, query(".dismiss-notification-confirmation-modal .modal-body").innerText,
"You have 2 important notifications, are you sure you would like to dismiss?" I18n.t("notifications.dismiss_confirmation.body", { count: 2 })
); );
await click(".bootbox.modal .btn-default");
}); });
test("marks unread when confirm and closes modal", async function (assert) { test("marks unread when confirm and closes modal", async function (assert) {
@ -47,19 +47,19 @@ acceptance("Dismiss notification confirmation", function (needs) {
await click(".notifications-dismiss"); await click(".notifications-dismiss");
assert.strictEqual( assert.strictEqual(
query(".bootbox.modal .btn-primary span").innerText, query(".dismiss-notification-confirmation-modal .btn-primary").innerText,
"Confirm" I18n.t("notifications.dismiss_confirmation.dismiss")
); );
pretender.put("/notifications/mark-read", () => { pretender.put("/notifications/mark-read", () => {
return [200, { "Content-Type": "application/json" }, { success: true }]; return [200, { "Content-Type": "application/json" }, { success: true }];
}); });
await click(".bootbox.modal .btn-primary"); await click(".dismiss-notification-confirmation-modal .btn-primary");
assert.notOk(exists(".bootbox.modal")); assert.notOk(exists(".dismiss-notification-confirmation"));
}); });
test("marks unread when cancel and closes modal", async function (assert) { test("does marks unread when cancel and closes modal", async function (assert) {
updateCurrentUser({ updateCurrentUser({
unread_high_priority_notifications: 2, unread_high_priority_notifications: 2,
}); });
@ -68,12 +68,12 @@ acceptance("Dismiss notification confirmation", function (needs) {
await click(".notifications-dismiss"); await click(".notifications-dismiss");
assert.strictEqual( assert.strictEqual(
query(".bootbox.modal .btn-default span").innerText, query(".dismiss-notification-confirmation-modal .btn-default").innerText,
"Cancel" I18n.t("notifications.dismiss_confirmation.cancel")
); );
await click(".bootbox.modal .btn-default"); await click(".dismiss-notification-confirmation-modal .btn-default");
assert.notOk(exists(".bootbox.modal")); assert.notOk(exists(".dismiss-notification-confirmation"));
}); });
}); });

View File

@ -2287,9 +2287,9 @@ en:
votes_released: "%{description} - completed" votes_released: "%{description} - completed"
dismiss_confirmation: dismiss_confirmation:
body: body:
one: "You have %{count} important notification, are you sure you would like to dismiss?" one: "Are you sure? You have %{count} important notification."
other: "You have %{count} important notifications, are you sure you would like to dismiss?" other: "Are you sure? You have %{count} important notifications."
confirm: "Confirm" dismiss: "Dismiss"
cancel: "Cancel" cancel: "Cancel"
group_message_summary: group_message_summary: