From bdaecc90c448315bb3d3ef06bf74eb84e1e26b4f Mon Sep 17 00:00:00 2001 From: Isaac Janzen <50783505+janzenisaac@users.noreply.github.com> Date: Mon, 17 Jul 2023 15:06:30 -0500 Subject: [PATCH] DEV: Convert group-default-notifications modal to component-based API (#22521) This PR converts the `group-default-notifications` modal to make use of the new component-based API --- .../components/group-manage-save-button.hbs | 2 +- .../components/group-manage-save-button.js | 97 +++++++++++-------- .../modal/group-default-notifications.hbs | 19 ++++ .../modal/group-default-notifications.js | 16 +++ .../group-default-notifications.js | 5 - .../modal/group-default-notifications.hbs | 18 ---- 6 files changed, 90 insertions(+), 67 deletions(-) create mode 100644 app/assets/javascripts/discourse/app/components/modal/group-default-notifications.hbs create mode 100644 app/assets/javascripts/discourse/app/components/modal/group-default-notifications.js delete mode 100644 app/assets/javascripts/discourse/app/controllers/group-default-notifications.js delete mode 100644 app/assets/javascripts/discourse/app/templates/modal/group-default-notifications.hbs diff --git a/app/assets/javascripts/discourse/app/components/group-manage-save-button.hbs b/app/assets/javascripts/discourse/app/components/group-manage-save-button.hbs index c726861637d..7e249bd3640 100644 --- a/app/assets/javascripts/discourse/app/components/group-manage-save-button.hbs +++ b/app/assets/javascripts/discourse/app/components/group-manage-save-button.hbs @@ -7,7 +7,7 @@ {{/if}}
{ - this.setProperties({ - saved: true, - updateExistingUsers: null, - }); + const opts = {}; + if (this.updateExistingUsers !== null) { + opts.update_existing_users = this.updateExistingUsers; + } - if (this.afterSave) { - this.afterSave(); - } - }) - .catch((error) => { - const json = error.jqXHR.responseJSON; - if (error.jqXHR.status === 422 && json.user_count) { - const controller = showModal("group-default-notifications", { - model: { count: json.user_count }, - }); + return group + .save(opts) + .then(() => { + this.setProperties({ + saved: true, + updateExistingUsers: null, + }); - controller.set("onClose", () => { - this.updateExistingUsers = controller.updateExistingUsers; - this.send("save"); - }); - } else { - popupAjaxError(error); - } - }) - .finally(() => this.set("saving", false)); - }, + if (this.afterSave) { + this.afterSave(); + } + }) + .catch((error) => { + const json = error.jqXHR.responseJSON; + if (error.jqXHR.status === 422 && json.user_count) { + this.editGroupNotifications(json); + } else { + popupAjaxError(error); + } + }) + .finally(() => this.set("saving", false)); + }, + + @action + async editGroupNotifications(json) { + await this.modal.show(GroupDefaultNotificationsModal, { + model: { + count: json.user_count, + setUpdateExistingUsers: this.setUpdateExistingUsers, + }, + }); + this.save(); }, }); diff --git a/app/assets/javascripts/discourse/app/components/modal/group-default-notifications.hbs b/app/assets/javascripts/discourse/app/components/modal/group-default-notifications.hbs new file mode 100644 index 00000000000..a27d0ac6d74 --- /dev/null +++ b/app/assets/javascripts/discourse/app/components/modal/group-default-notifications.hbs @@ -0,0 +1,19 @@ + + <:body> + {{i18n "groups.default_notifications.modal_description" count=@model.count}} + + <:footer> + + + + \ No newline at end of file diff --git a/app/assets/javascripts/discourse/app/components/modal/group-default-notifications.js b/app/assets/javascripts/discourse/app/components/modal/group-default-notifications.js new file mode 100644 index 00000000000..1c6dae86ff3 --- /dev/null +++ b/app/assets/javascripts/discourse/app/components/modal/group-default-notifications.js @@ -0,0 +1,16 @@ +import Component from "@glimmer/component"; +import { action } from "@ember/object"; + +export default class GroupDefaultNotifications extends Component { + @action + updateExistingUsers() { + this.args.model.setUpdateExistingUsers(true); + this.args.closeModal(); + } + + @action + cancel() { + this.args.model.setUpdateExistingUsers(false); + this.args.closeModal(); + } +} diff --git a/app/assets/javascripts/discourse/app/controllers/group-default-notifications.js b/app/assets/javascripts/discourse/app/controllers/group-default-notifications.js deleted file mode 100644 index 8c3a2648989..00000000000 --- a/app/assets/javascripts/discourse/app/controllers/group-default-notifications.js +++ /dev/null @@ -1,5 +0,0 @@ -import Controller from "@ember/controller"; -import ModalFunctionality from "discourse/mixins/modal-functionality"; -import ModalUpdateExistingUsers from "discourse/mixins/modal-update-existing-users"; - -export default Controller.extend(ModalFunctionality, ModalUpdateExistingUsers); diff --git a/app/assets/javascripts/discourse/app/templates/modal/group-default-notifications.hbs b/app/assets/javascripts/discourse/app/templates/modal/group-default-notifications.hbs deleted file mode 100644 index 10250ecf0c7..00000000000 --- a/app/assets/javascripts/discourse/app/templates/modal/group-default-notifications.hbs +++ /dev/null @@ -1,18 +0,0 @@ - - {{i18n - "groups.default_notifications.modal_description" - count=this.model.count - }} - - - \ No newline at end of file