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
This commit is contained in:
Isaac Janzen 2023-07-17 15:06:30 -05:00 committed by GitHub
parent 80a1709965
commit bdaecc90c4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 90 additions and 67 deletions

View File

@ -7,7 +7,7 @@
{{/if}} {{/if}}
<div class="control-group buttons group-manage-save-button"> <div class="control-group buttons group-manage-save-button">
<DButton <DButton
@action={{action "save"}} @action={{this.save}}
@disabled={{or this.disabled this.saving}} @disabled={{or this.disabled this.saving}}
@class="btn btn-primary group-manage-save" @class="btn btn-primary group-manage-save"
@translatedLabel={{this.savingText}} @translatedLabel={{this.savingText}}

View File

@ -3,10 +3,13 @@ import I18n from "I18n";
import discourseComputed from "discourse-common/utils/decorators"; import discourseComputed from "discourse-common/utils/decorators";
import { popupAjaxError } from "discourse/lib/ajax-error"; import { popupAjaxError } from "discourse/lib/ajax-error";
import { popupAutomaticMembershipAlert } from "discourse/controllers/groups-new"; import { popupAutomaticMembershipAlert } from "discourse/controllers/groups-new";
import showModal from "discourse/lib/show-modal";
import { or } from "@ember/object/computed"; import { or } from "@ember/object/computed";
import { action } from "@ember/object";
import { inject as service } from "@ember/service";
import GroupDefaultNotificationsModal from "discourse/components/modal/group-default-notifications";
export default Component.extend({ export default Component.extend({
modal: service(),
saving: null, saving: null,
disabled: false, disabled: false,
updateExistingUsers: null, updateExistingUsers: null,
@ -38,7 +41,12 @@ export default Component.extend({
} }
}, },
actions: { @action
setUpdateExistingUsers(value) {
this.updateExistingUsers = value;
},
@action
save() { save() {
if (this.beforeSave) { if (this.beforeSave) {
this.beforeSave(); this.beforeSave();
@ -72,19 +80,22 @@ export default Component.extend({
.catch((error) => { .catch((error) => {
const json = error.jqXHR.responseJSON; const json = error.jqXHR.responseJSON;
if (error.jqXHR.status === 422 && json.user_count) { if (error.jqXHR.status === 422 && json.user_count) {
const controller = showModal("group-default-notifications", { this.editGroupNotifications(json);
model: { count: json.user_count },
});
controller.set("onClose", () => {
this.updateExistingUsers = controller.updateExistingUsers;
this.send("save");
});
} else { } else {
popupAjaxError(error); popupAjaxError(error);
} }
}) })
.finally(() => this.set("saving", false)); .finally(() => this.set("saving", false));
}, },
@action
async editGroupNotifications(json) {
await this.modal.show(GroupDefaultNotificationsModal, {
model: {
count: json.user_count,
setUpdateExistingUsers: this.setUpdateExistingUsers,
},
});
this.save();
}, },
}); });

View File

@ -0,0 +1,19 @@
<DModal
@title={{i18n "groups.default_notifications.modal_title"}}
@closeModal={{@closeModal}}
>
<:body>
{{i18n "groups.default_notifications.modal_description" count=@model.count}}
</:body>
<:footer>
<DButton
@action={{this.updateExistingUsers}}
@label="groups.default_notifications.modal_yes"
class="btn-primary"
/>
<DButton
@action={{this.cancel}}
@label="groups.default_notifications.modal_no"
/>
</:footer>
</DModal>

View File

@ -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();
}
}

View File

@ -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);

View File

@ -1,18 +0,0 @@
<DModalBody @title="groups.default_notifications.modal_title">
{{i18n
"groups.default_notifications.modal_description"
count=this.model.count
}}
</DModalBody>
<div class="modal-footer">
<DButton
@action={{action "updateExistingUsers"}}
@class="btn-primary"
@label="groups.default_notifications.modal_yes"
/>
<DButton
@action={{action "cancel"}}
@label="groups.default_notifications.modal_no"
/>
</div>