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