2022-04-04 21:26:49 +03:00
|
|
|
import Component from '@glimmer/component';
|
2022-04-27 12:36:43 +03:00
|
|
|
import ConfirmNewsletterEmailModal from './confirm-newsletter-email';
|
2022-04-04 21:26:49 +03:00
|
|
|
import {action} from '@ember/object';
|
2022-04-13 21:34:48 +03:00
|
|
|
import {inject as service} from '@ember/service';
|
2022-04-04 21:26:49 +03:00
|
|
|
import {task} from 'ember-concurrency';
|
|
|
|
import {tracked} from '@glimmer/tracking';
|
|
|
|
|
|
|
|
export default class EditNewsletterModal extends Component {
|
2022-04-13 21:34:48 +03:00
|
|
|
@service modals;
|
|
|
|
|
2022-04-04 21:26:49 +03:00
|
|
|
static modalOptions = {
|
|
|
|
className: 'fullscreen-modal-full-overlay fullscreen-modal-portal-settings'
|
|
|
|
};
|
|
|
|
|
2022-04-28 11:24:12 +03:00
|
|
|
@tracked openSection = null;
|
2022-04-04 21:26:49 +03:00
|
|
|
|
|
|
|
willDestroy() {
|
|
|
|
super.willDestroy(...arguments);
|
|
|
|
this.args.data.newsletter.rollbackAttributes();
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
saveViaKeyboard(event, responder) {
|
|
|
|
responder.stopPropagation();
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
this.saveTask.perform();
|
|
|
|
}
|
|
|
|
|
2022-04-28 11:24:12 +03:00
|
|
|
@action
|
|
|
|
toggleSection(section) {
|
|
|
|
if (this.openSection === section) {
|
|
|
|
this.openSection = null;
|
|
|
|
} else {
|
|
|
|
this.openSection = section;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
toggleSetting(property, event) {
|
|
|
|
this.args.data.newsletter[property] = event.target.checked;
|
|
|
|
}
|
|
|
|
|
2022-04-04 21:26:49 +03:00
|
|
|
@task
|
|
|
|
*saveTask() {
|
2022-05-04 16:57:18 +03:00
|
|
|
const newsletter = this.args.data.newsletter;
|
2022-04-04 21:26:49 +03:00
|
|
|
try {
|
2022-05-04 16:57:18 +03:00
|
|
|
yield newsletter.validate({});
|
2022-04-19 22:01:08 +03:00
|
|
|
|
2022-05-04 16:57:18 +03:00
|
|
|
const newEmail = newsletter.senderEmail;
|
2022-04-13 21:34:48 +03:00
|
|
|
|
2022-05-05 12:31:45 +03:00
|
|
|
const result = yield newsletter.save({
|
|
|
|
adapterOptions: {
|
|
|
|
include: 'count.members,count.posts'
|
|
|
|
}
|
|
|
|
});
|
2022-04-04 21:26:49 +03:00
|
|
|
|
2022-04-13 21:34:48 +03:00
|
|
|
if (result._meta?.sent_email_verification) {
|
|
|
|
yield this.modals.open(ConfirmNewsletterEmailModal, {
|
|
|
|
newEmail,
|
2022-05-04 16:57:18 +03:00
|
|
|
currentEmail: newsletter.senderEmail
|
2022-04-13 21:34:48 +03:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-04-04 21:26:49 +03:00
|
|
|
this.args.data.afterSave?.(result);
|
|
|
|
|
|
|
|
return result;
|
2022-05-04 16:57:18 +03:00
|
|
|
} catch (error) {
|
|
|
|
if (error === undefined) {
|
2022-04-28 11:50:27 +03:00
|
|
|
// Validation error
|
|
|
|
return;
|
2022-04-04 21:26:49 +03:00
|
|
|
}
|
|
|
|
|
2022-05-04 16:57:18 +03:00
|
|
|
// Do we have an error that we can show inline?
|
|
|
|
if (error.payload && error.payload.errors) {
|
|
|
|
for (const payloadError of error.payload.errors) {
|
|
|
|
if (payloadError.type === 'ValidationError' && payloadError.property && (payloadError.context || payloadError.message)) {
|
|
|
|
// Context has a better error message for validation errors
|
|
|
|
newsletter.errors.add(payloadError.property, payloadError.context || payloadError.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
throw error;
|
2022-04-04 21:26:49 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|