From c46d9cc2bc15743d17e098cf2685b5a328735f6f Mon Sep 17 00:00:00 2001 From: Taslan Graham Date: Wed, 6 Nov 2024 16:01:00 -0500 Subject: [PATCH] pkp/pkp-lib#10571 WIP: Allow admins and managers to assign user groups to email templates within a mailable --- src/components/Container/ManageEmailsPage.vue | 27 +++++++-- src/components/Form/FormGroup.vue | 2 + .../FieldEmailTemplateUserGroupSettings.vue | 55 +++++++++++++++++++ src/pages/manageEmails/EditTemplateModal.vue | 1 + 4 files changed, 81 insertions(+), 4 deletions(-) create mode 100644 src/components/Form/fields/FieldEmailTemplateUserGroupSettings.vue diff --git a/src/components/Container/ManageEmailsPage.vue b/src/components/Container/ManageEmailsPage.vue index d685a9b1b..0d08cc697 100644 --- a/src/components/Container/ManageEmailsPage.vue +++ b/src/components/Container/ManageEmailsPage.vue @@ -346,16 +346,35 @@ export default { template = template || {}; this.currentTemplate = template; const {openSideModal} = useModal(); - this.$nextTick(() => - openSideModal(EditTemplateModal, { + + this.$nextTick(() => { + // Remove use group field if current mailable does not support specifying user group access + if (!this.currentMailable.canAssignUserGroupToTemplates) { + this.currentTemplateForm.fields = + this.currentTemplateForm.value.fileds.filter( + (field) => field.name !== 'userGroupIds', + ); + } else { + const userGroupField = this.currentTemplateForm.fields.find( + (field) => field.name === 'userGroupIds', + ); + userGroupField.assignableUserGroups = + this.currentMailable['assignableTemplateUserGroups']; + userGroupField.assignedUserGroupIds = + this.currentTemplate['assignedUserGroupIds']; + } + + return openSideModal(EditTemplateModal, { title: this.currentTemplate ? t('manager.mailables.editTemplate') : t('manager.emails.addEmail'), currentTemplateForm: this.currentTemplateForm, + canAssignUserGroups: + this.currentMailable.canAssignUserGroupToTemplates, onUpdateCurrentTemplateForm: this.updateCurrentTemplateForm, onTemplateSaved: this.templateSaved, - }), - ); + }); + }); }, /** diff --git a/src/components/Form/FormGroup.vue b/src/components/Form/FormGroup.vue index ce7b6087c..d427190b1 100644 --- a/src/components/Form/FormGroup.vue +++ b/src/components/Form/FormGroup.vue @@ -78,6 +78,7 @@ import FieldTextarea from './fields/FieldTextarea.vue'; import FieldUpload from './fields/FieldUpload.vue'; import FieldSlider from './fields/FieldSlider.vue'; import FieldUploadImage from './fields/FieldUploadImage.vue'; +import FieldEmailTemplateUserGroupSettings from './fields/FieldEmailTemplateUserGroupSettings.vue'; import {shouldShowFieldWithinGroup} from './formHelpers'; @@ -109,6 +110,7 @@ export default { FieldSlider, FieldUpload, FieldUploadImage, + FieldEmailTemplateUserGroupSettings, }, props: { id: String, diff --git a/src/components/Form/fields/FieldEmailTemplateUserGroupSettings.vue b/src/components/Form/fields/FieldEmailTemplateUserGroupSettings.vue new file mode 100644 index 000000000..38b5e6c5d --- /dev/null +++ b/src/components/Form/fields/FieldEmailTemplateUserGroupSettings.vue @@ -0,0 +1,55 @@ + + + diff --git a/src/pages/manageEmails/EditTemplateModal.vue b/src/pages/manageEmails/EditTemplateModal.vue index 0ae12712d..9579f0fd6 100644 --- a/src/pages/manageEmails/EditTemplateModal.vue +++ b/src/pages/manageEmails/EditTemplateModal.vue @@ -23,6 +23,7 @@ import PkpForm from '@/components/Form/Form.vue'; defineProps({ title: {type: String, required: true}, currentTemplateForm: {required: true, type: Object}, + canAssignUserGroups: {default: false, type: Boolean}, }); const emit = defineEmits(['updateCurrentTemplateForm', 'templateSaved']);