sms alarming flag
This commit is contained in:
parent
66026d667d
commit
794de7e3c8
8 changed files with 40 additions and 4 deletions
|
@ -93,6 +93,10 @@
|
||||||
<input type="checkbox" id="isNewsletterMain" />
|
<input type="checkbox" id="isNewsletterMain" />
|
||||||
<label for="isNewsletterMain">Newsletter hier hin versenden?</label>
|
<label for="isNewsletterMain">Newsletter hier hin versenden?</label>
|
||||||
</div>
|
</div>
|
||||||
|
<div v-if="selectedCommunicationType?.fields.includes('mobile')" class="flex flex-row items-center gap-2">
|
||||||
|
<input type="checkbox" id="isSMSAlarming" />
|
||||||
|
<label for="isSMSAlarming">SMS-Alarmierung hier hin versenden?</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="flex flex-row gap-2">
|
<div class="flex flex-row gap-2">
|
||||||
<button primary type="submit" :disabled="status == 'loading' || status?.status == 'success'">erstellen</button>
|
<button primary type="submit" :disabled="status == 'loading' || status?.status == 'success'">erstellen</button>
|
||||||
|
@ -163,6 +167,7 @@ export default defineComponent({
|
||||||
streetNumber: formData.streetNumber?.value,
|
streetNumber: formData.streetNumber?.value,
|
||||||
streetNumberAddition: formData.streetNumberAddition?.value,
|
streetNumberAddition: formData.streetNumberAddition?.value,
|
||||||
isNewsletterMain: formData.isNewsletterMain.checked,
|
isNewsletterMain: formData.isNewsletterMain.checked,
|
||||||
|
isSMSAlarming: formData.isSMSAlarming?.checked,
|
||||||
typeId: this.selectedCommunicationType.id,
|
typeId: this.selectedCommunicationType.id,
|
||||||
};
|
};
|
||||||
this.createCommunication(createCommunication)
|
this.createCommunication(createCommunication)
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<br />
|
<br />
|
||||||
<Spinner v-if="loading == 'loading'" class="mx-auto" />
|
<Spinner v-if="loading == 'loading'" class="mx-auto" />
|
||||||
<p v-else-if="loading == 'failed'" @click="fetchItem" class="cursor-pointer">↺ laden fehlgeschlagen</p>
|
<p v-else-if="loading == 'failed'" @click="fetchItem" class="cursor-pointer">↺ laden fehlgeschlagen</p>
|
||||||
<form v-else-if="communication != null" class="flex flex-col gap-4 py-2" @submit.prevent="triggerCreate">
|
<form v-else-if="communication != null" class="flex flex-col gap-4 py-2" @submit.prevent="triggerUpdate">
|
||||||
<div>
|
<div>
|
||||||
<p>Type: {{ communication.type.type }}</p>
|
<p>Type: {{ communication.type.type }}</p>
|
||||||
</div>
|
</div>
|
||||||
|
@ -42,6 +42,10 @@
|
||||||
<input type="checkbox" id="isNewsletterMain" v-model="communication.isNewsletterMain" />
|
<input type="checkbox" id="isNewsletterMain" v-model="communication.isNewsletterMain" />
|
||||||
<label for="isNewsletterMain">Newsletter hier hin versenden?</label>
|
<label for="isNewsletterMain">Newsletter hier hin versenden?</label>
|
||||||
</div>
|
</div>
|
||||||
|
<div v-if="communication.type.fields.includes('mobile')" class="flex flex-row items-center gap-2">
|
||||||
|
<input type="checkbox" id="isSMSAlarming" v-model="communication.isSMSAlarming" />
|
||||||
|
<label for="isSMSAlarming">SMS-Alarmierung hier hin versenden?</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="flex flex-row gap-2">
|
<div class="flex flex-row gap-2">
|
||||||
<button primary-outline type="reset" :disabled="canSaveOrReset" @click="resetForm">verwerfen</button>
|
<button primary-outline type="reset" :disabled="canSaveOrReset" @click="resetForm">verwerfen</button>
|
||||||
|
@ -120,7 +124,7 @@ export default defineComponent({
|
||||||
this.loading = "failed";
|
this.loading = "failed";
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
triggerCreate(e: any) {
|
triggerUpdate(e: any) {
|
||||||
if (this.communication == null) return;
|
if (this.communication == null) return;
|
||||||
let formData = e.target.elements;
|
let formData = e.target.elements;
|
||||||
let updateCommunication: UpdateCommunicationViewModel = {
|
let updateCommunication: UpdateCommunicationViewModel = {
|
||||||
|
@ -133,6 +137,7 @@ export default defineComponent({
|
||||||
streetNumber: formData.streetNumber?.value,
|
streetNumber: formData.streetNumber?.value,
|
||||||
streetNumberAddition: formData.streetNumberAddition?.value,
|
streetNumberAddition: formData.streetNumberAddition?.value,
|
||||||
isNewsletterMain: formData.isNewsletterMain.checked,
|
isNewsletterMain: formData.isNewsletterMain.checked,
|
||||||
|
isSMSAlarming: formData.isSMSAlarming?.checked,
|
||||||
};
|
};
|
||||||
this.updateCommunication(updateCommunication)
|
this.updateCommunication(updateCommunication)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="flex flex-col h-fit w-full border border-primary rounded-md">
|
<div class="flex flex-col h-fit w-full border border-primary rounded-md">
|
||||||
<div class="bg-primary p-2 text-white flex flex-row gap-2 justify-between items-center">
|
<div class="bg-primary p-2 text-white flex flex-row gap-2 justify-between items-center">
|
||||||
|
<FireIcon class="h-5 w-5 pr-1 box-content" v-if="communication.isSMSAlarming" />
|
||||||
<EnvelopeIcon class="h-5 w-5 pr-1 box-content" v-if="communication.isNewsletterMain" />
|
<EnvelopeIcon class="h-5 w-5 pr-1 box-content" v-if="communication.isNewsletterMain" />
|
||||||
<p class="grow">{{ communication.type.type }} {{ communication.preferred ? "(bevorzugt)" : "" }}</p>
|
<p class="grow">{{ communication.type.type }} {{ communication.preferred ? "(bevorzugt)" : "" }}</p>
|
||||||
<PencilIcon v-if="can('update', 'club', 'member')" class="w-5 h-5 cursor-pointer" @click="openEditModal" />
|
<PencilIcon v-if="can('update', 'club', 'member')" class="w-5 h-5 cursor-pointer" @click="openEditModal" />
|
||||||
|
@ -16,7 +17,7 @@
|
||||||
import { defineAsyncComponent, defineComponent, markRaw, type PropType } from "vue";
|
import { defineAsyncComponent, defineComponent, markRaw, type PropType } from "vue";
|
||||||
import { mapState, mapActions } from "pinia";
|
import { mapState, mapActions } from "pinia";
|
||||||
import type { CommunicationViewModel } from "@/viewmodels/admin/communication.models";
|
import type { CommunicationViewModel } from "@/viewmodels/admin/communication.models";
|
||||||
import { EnvelopeIcon, PencilIcon, TrashIcon } from "@heroicons/vue/24/outline";
|
import { EnvelopeIcon, PencilIcon, TrashIcon, FireIcon } from "@heroicons/vue/24/outline";
|
||||||
import { useModalStore } from "@/stores/modal";
|
import { useModalStore } from "@/stores/modal";
|
||||||
import { useAbilityStore } from "@/stores/ability";
|
import { useAbilityStore } from "@/stores/ability";
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -56,7 +56,8 @@ body {
|
||||||
@apply w-full h-full overflow-hidden flex flex-col;
|
@apply w-full h-full overflow-hidden flex flex-col;
|
||||||
}
|
}
|
||||||
|
|
||||||
button:not([class*="ql"] *):not([class*="fc"]):not([headlessui]):not([id*="headlessui"]):not([class*="headlessui"]),
|
/*:not([headlessui]):not([id*="headlessui"]):not([class*="headlessui"])*/
|
||||||
|
button:not([class*="ql"] *):not([class*="fc"]),
|
||||||
a[button] {
|
a[button] {
|
||||||
@apply relative box-border h-10 w-full flex justify-center py-2 px-4 text-sm font-medium rounded-md focus:outline-none focus:ring-0;
|
@apply relative box-border h-10 w-full flex justify-center py-2 px-4 text-sm font-medium rounded-md focus:outline-none focus:ring-0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,6 +47,7 @@ export const useCommunicationStore = defineStore("communication", {
|
||||||
streetNumberAddition: communication.streetNumberAddition,
|
streetNumberAddition: communication.streetNumberAddition,
|
||||||
typeId: communication.typeId,
|
typeId: communication.typeId,
|
||||||
isNewsletterMain: communication.isNewsletterMain,
|
isNewsletterMain: communication.isNewsletterMain,
|
||||||
|
isSMSAlarming: communication.isSMSAlarming,
|
||||||
});
|
});
|
||||||
this.fetchCommunicationsForMember();
|
this.fetchCommunicationsForMember();
|
||||||
return result;
|
return result;
|
||||||
|
@ -62,6 +63,7 @@ export const useCommunicationStore = defineStore("communication", {
|
||||||
streetNumber: communication.streetNumber,
|
streetNumber: communication.streetNumber,
|
||||||
streetNumberAddition: communication.streetNumberAddition,
|
streetNumberAddition: communication.streetNumberAddition,
|
||||||
isNewsletterMain: communication.isNewsletterMain,
|
isNewsletterMain: communication.isNewsletterMain,
|
||||||
|
isSMSAlarming: communication.isSMSAlarming,
|
||||||
});
|
});
|
||||||
this.fetchCommunicationsForMember();
|
this.fetchCommunicationsForMember();
|
||||||
return result;
|
return result;
|
||||||
|
|
|
@ -11,6 +11,7 @@ export interface CommunicationViewModel {
|
||||||
streetNumberAddition: string;
|
streetNumberAddition: string;
|
||||||
type: CommunicationTypeViewModel;
|
type: CommunicationTypeViewModel;
|
||||||
isNewsletterMain: boolean;
|
isNewsletterMain: boolean;
|
||||||
|
isSMSAlarming: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface CreateCommunicationViewModel {
|
export interface CreateCommunicationViewModel {
|
||||||
|
@ -23,6 +24,7 @@ export interface CreateCommunicationViewModel {
|
||||||
streetNumberAddition: string;
|
streetNumberAddition: string;
|
||||||
typeId: number;
|
typeId: number;
|
||||||
isNewsletterMain: boolean;
|
isNewsletterMain: boolean;
|
||||||
|
isSMSAlarming: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface UpdateCommunicationViewModel {
|
export interface UpdateCommunicationViewModel {
|
||||||
|
@ -35,4 +37,5 @@ export interface UpdateCommunicationViewModel {
|
||||||
streetNumber: number;
|
streetNumber: number;
|
||||||
streetNumberAddition: string;
|
streetNumberAddition: string;
|
||||||
isNewsletterMain: boolean;
|
isNewsletterMain: boolean;
|
||||||
|
isSMSAlarming: boolean;
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,6 +12,7 @@ export interface MemberViewModel {
|
||||||
firstMembershipEntry?: MembershipViewModel;
|
firstMembershipEntry?: MembershipViewModel;
|
||||||
lastMembershipEntry?: MembershipViewModel;
|
lastMembershipEntry?: MembershipViewModel;
|
||||||
sendNewsletter?: CommunicationViewModel;
|
sendNewsletter?: CommunicationViewModel;
|
||||||
|
smsAlarming?: Array<CommunicationViewModel>;
|
||||||
preferredCommunication?: Array<CommunicationViewModel>;
|
preferredCommunication?: Array<CommunicationViewModel>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -74,6 +74,24 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div v-if="activeMemberObj.smsAlarming?.length != 0">
|
||||||
|
<p>sende SMS-Alarmierung an:</p>
|
||||||
|
<div class="flex flex-col gap-2">
|
||||||
|
<div
|
||||||
|
v-for="com in activeMemberObj.smsAlarming"
|
||||||
|
class="flex flex-col h-fit w-full border border-primary rounded-md"
|
||||||
|
>
|
||||||
|
<div class="bg-primary p-2 text-white flex flex-row justify-between items-center">
|
||||||
|
<p>
|
||||||
|
{{ com.type.type }}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div class="p-2">
|
||||||
|
<p v-for="field in com.type.fields" :key="field">{{ field }}: {{ com[field] || "--" }}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div v-if="activeMemberObj.sendNewsletter">
|
<div v-if="activeMemberObj.sendNewsletter">
|
||||||
<p>Newsletter Kommunikationswege</p>
|
<p>Newsletter Kommunikationswege</p>
|
||||||
<div class="flex flex-col h-fit w-full border border-primary rounded-md">
|
<div class="flex flex-col h-fit w-full border border-primary rounded-md">
|
||||||
|
|
Loading…
Reference in a new issue