adrema/resources/js/views/member/VIndex.vue

205 lines
10 KiB
Vue
Raw Normal View History

2020-06-02 23:45:25 +02:00
<template>
2023-04-29 23:41:26 +02:00
<page-layout page-class="pb-6">
2023-05-20 02:38:38 +02:00
<template #toolbar>
<page-toolbar-button :href="meta.links.create" color="primary" icon="plus">Mitglied anlegen</page-toolbar-button>
2023-05-20 02:38:38 +02:00
</template>
2023-07-27 17:22:06 +02:00
<ui-popup v-if="deleting !== null" heading="Mitglied löschen?" @close="deleting.reject()">
2023-05-09 01:34:19 +02:00
<div>
<p class="mt-4">Das Mitglied "{{ deleting.member.fullname }}" löschen?</p>
<p class="mt-2">Alle Zuordnungen (Ausbildungen, Rechnungen, Zahlungen, Tätigkeiten) werden ebenfalls entfernt.</p>
<ui-note v-if="!deleting.member.has_nami" class="mt-5" type="warning"> Dieses Mitglied ist nicht in NaMi vorhanden und wird daher nur in der AdReMa gelöscht werden. </ui-note>
2023-07-27 17:22:06 +02:00
<ui-note v-if="deleting.member.has_nami" class="mt-5" type="danger">
Dieses Mitglied ist in NaMi vorhanden und wird daher in NaMi abgemeldet werden. Sofern "Datenweiterverwendung" eingeschaltet ist, wird das Mitglied auf inaktiv gesetzt.
2023-05-19 01:06:46 +02:00
</ui-note>
2023-05-09 01:34:19 +02:00
<div class="grid grid-cols-2 gap-3 mt-6">
2023-07-27 17:22:06 +02:00
<a href="#" class="text-center btn btn-danger" @click.prevent="deleting.resolve">Mitglied loschen</a>
<a href="#" class="text-center btn btn-primary" @click.prevent="deleting.reject">Abbrechen</a>
2023-05-09 01:34:19 +02:00
</div>
</div>
2023-05-19 01:06:46 +02:00
</ui-popup>
<ui-popup v-if="membershipFilters !== null" heading="Nach Mitgliedschaften filtern" full @close="membershipFilters = null">
<button class="btn btn-primary label mt-2" @click.prevent="membershipFilters.push({...meta.default_membership_filter})">
2024-01-29 00:13:03 +01:00
<ui-sprite class="w-3 h-3 xl:mr-2" src="plus"></ui-sprite>
<span class="hidden xl:inline">Hinzufügen</span>
</button>
<div v-for="(filter, index) in membershipFilters" :key="index" class="flex space-x-2 mt-2">
2024-06-28 14:26:12 +02:00
<f-multipleselect :id="`group_ids-multiple-${index}`" v-model="filter.group_ids" :options="meta.groups" label="Gruppierung" size="sm"></f-multipleselect>
<f-multipleselect :id="`activity_ids-multiple-${index}`" v-model="filter.activity_ids" :options="meta.filterActivities" label="Tätigkeiten" size="sm"></f-multipleselect>
<f-multipleselect :id="`subactivity_ids-multiple-${index}`" v-model="filter.subactivity_ids" :options="meta.filterSubactivities" label="Untertätigkeiten" size="sm"></f-multipleselect>
2024-01-29 00:13:03 +01:00
</div>
<button
class="btn btn-primary label mt-3"
@click.prevent="
setFilter('memberships', membershipFilters);
membershipFilters = null;
"
>
2024-01-29 00:13:03 +01:00
<span class="hidden xl:inline">Anwenden</span>
</button>
</ui-popup>
2023-08-20 23:37:11 +02:00
<page-filter breakpoint="xl">
2024-07-13 18:48:11 +02:00
<template #fields>
2024-08-28 13:32:52 +02:00
<f-switch
v-show="hasModule('bill')"
id="ausstand"
name="ausstand"
:model-value="getFilter('ausstand')"
label="Nur Ausstände"
size="sm"
@update:model-value="setFilter('ausstand', $event)"
></f-switch>
2025-01-04 23:35:00 +01:00
<f-select
id="has_vk"
name="has_vk"
:model-value="getFilter('has_vk')"
label="Verhaltenskodex unterschrieben"
size="sm"
:options="meta.boolean_filter"
@update:model-value="setFilter('has_vk', $event)"
></f-select>
<f-select
id="has_svk"
name="has_svk"
:model-value="getFilter('has_svk')"
label="SVK unterschrieben"
size="sm"
:options="meta.boolean_filter"
@update:model-value="setFilter('has_svk', $event)"
></f-select>
2024-07-13 18:48:11 +02:00
<f-multipleselect
id="group_ids"
:options="meta.groups"
:model-value="getFilter('group_ids')"
label="Gruppierungen"
size="sm"
@update:model-value="setFilter('group_ids', $event)"
></f-multipleselect>
<f-select
v-show="hasModule('bill')"
id="billKinds"
name="billKinds"
:options="meta.billKinds"
:model-value="getFilter('bill_kind')"
label="Rechnung"
size="sm"
@update:model-value="setFilter('bill_kind', $event)"
></f-select>
<button class="btn btn-primary label mr-2" @click.prevent="membershipFilters = getFilter('memberships')">
<ui-sprite class="w-3 h-3 xl:mr-2" src="filter"></ui-sprite>
<span class="hidden xl:inline">Mitgliedschaften</span>
</button>
</template>
<template #buttons>
<f-text id="search" :model-value="getFilter('search')" label="Suchen …" size="sm" @update:model-value="setFilter('search', $event)"></f-text>
<button class="btn btn-primary label mr-2" @click.prevent="exportMembers">
<ui-sprite class="w-3 h-3 xl:mr-2" src="save"></ui-sprite>
<span class="hidden xl:inline">Exportieren</span>
</button>
</template>
2023-08-20 23:37:11 +02:00
</page-filter>
2021-08-22 05:51:25 +02:00
2022-11-24 00:59:40 +01:00
<table cellspacing="0" cellpadding="0" border="0" class="custom-table custom-table-sm hidden md:table">
2021-08-22 19:31:20 +02:00
<thead>
<th></th>
<th>Nachname</th>
<th>Vorname</th>
2023-08-20 23:37:11 +02:00
<th class="!hidden 2xl:!table-cell">Ort</th>
2021-08-22 19:31:20 +02:00
<th>Tags</th>
2023-08-20 23:37:11 +02:00
<th class="!hidden xl:!table-cell">Alter</th>
2023-11-16 12:10:07 +01:00
<th v-if="hasModule('bill')" class="!hidden xl:!table-cell">Rechnung</th>
<th v-if="hasModule('bill')">Ausstand</th>
2021-08-22 19:31:20 +02:00
<th></th>
</thead>
2021-04-11 02:55:26 +02:00
2023-07-27 17:22:06 +02:00
<tr v-for="(member, index) in data" :key="index">
2023-06-14 17:10:50 +02:00
<td><ui-age-groups :member="member"></ui-age-groups></td>
2021-08-22 19:31:20 +02:00
<td v-text="member.lastname"></td>
<td v-text="member.firstname"></td>
2023-08-20 23:37:11 +02:00
<td class="!hidden 2xl:!table-cell" v-text="member.full_address"></td>
2023-07-27 17:22:06 +02:00
<td>
<tags :member="member"></tags>
</td>
2023-08-20 23:37:11 +02:00
<td class="!hidden xl:!table-cell" v-text="member.age"></td>
2023-11-16 12:10:07 +01:00
<td v-if="hasModule('bill')" class="!hidden xl:!table-cell">
2023-05-19 01:06:46 +02:00
<ui-label :value="member.bill_kind_name" fallback="kein"></ui-label>
2021-08-22 19:31:20 +02:00
</td>
2023-11-16 12:10:07 +01:00
<td v-if="hasModule('bill')">
2023-05-19 01:06:46 +02:00
<ui-label :value="member.pending_payment" fallback="---"></ui-label>
2021-08-22 19:31:20 +02:00
</td>
2022-11-18 15:55:44 +01:00
<td>
2023-09-12 16:54:13 +02:00
<actions :member="member" @sidebar="openSidebar($event, member)" @remove="remove(member)"></actions>
2021-08-22 19:31:20 +02:00
</td>
</tr>
</table>
2021-04-11 02:55:26 +02:00
2022-11-24 00:59:40 +01:00
<div class="md:hidden p-3 grid gap-3">
2023-08-20 22:47:17 +02:00
<ui-box v-for="(member, index) in data" :key="index" class="relative" :heading="member.fullname">
2023-07-27 17:22:06 +02:00
<template #in-title>
2023-06-14 17:10:50 +02:00
<ui-age-groups class="ml-2" :member="member" icon-class="w-4 h-4"></ui-age-groups>
2023-07-27 17:22:06 +02:00
</template>
2022-11-24 00:59:40 +01:00
<div class="text-xs text-gray-200" v-text="member.full_address"></div>
2022-12-05 00:21:24 +01:00
<div class="flex items-center mt-1 space-x-4">
2022-11-24 00:59:40 +01:00
<tags :member="member"></tags>
<ui-label v-show="hasModule('bill')" class="text-gray-100 block" :value="member.pending_payment" fallback=""></ui-label>
2022-11-24 00:59:40 +01:00
</div>
<actions class="mt-2" :member="member" @sidebar="openSidebar($event, member)" @remove="remove(member)"> </actions>
2022-11-24 00:59:40 +01:00
<div class="absolute right-0 top-0 h-full flex items-center mr-2">
<i-link v-tooltip="`Details`" :href="member.links.show"><ui-sprite src="chevron" class="w-6 h-6 text-teal-100 -rotate-90"></ui-sprite></i-link>
2022-11-24 00:59:40 +01:00
</div>
2023-05-19 01:06:46 +02:00
</ui-box>
2022-11-24 00:59:40 +01:00
</div>
2021-04-11 02:55:26 +02:00
<div class="px-6">
2023-10-31 10:38:32 +01:00
<ui-pagination class="mt-4" :value="meta" @reload="reloadPage"></ui-pagination>
2021-04-11 02:55:26 +02:00
</div>
2021-07-04 16:56:07 +02:00
2023-10-13 13:07:16 +02:00
<ui-sidebar v-if="single !== null" @close="closeSidebar">
<member-invoice-positions v-if="single.type === 'invoicePosition'" :url="single.model.links.invoiceposition_index" @close="closeSidebar"></member-invoice-positions>
<member-memberships v-if="single.type === 'membership'" :url="single.model.links.membership_index" @close="closeSidebar"></member-memberships>
<member-courses v-if="single.type === 'courses'" :url="single.model.links.course_index" @close="closeSidebar"></member-courses>
2023-10-13 13:07:16 +02:00
</ui-sidebar>
2023-04-29 23:41:26 +02:00
</page-layout>
2020-06-02 23:45:25 +02:00
</template>
2024-07-03 16:37:58 +02:00
<script lang="js" setup>
2023-12-17 21:13:52 +01:00
import MemberInvoicePositions from './MemberInvoicePositions.vue';
2022-02-12 14:47:07 +01:00
import MemberMemberships from './MemberMemberships.vue';
2022-02-12 14:28:56 +01:00
import MemberCourses from './MemberCourses.vue';
Update to vue 3 Squashed commit of the following: commit a91f51113b9680a0dd343aa8ab9b7bfaf6e8833b Author: Philipp Lang <privat@zoomyboy.de> Date: Thu Jul 6 13:55:42 2023 +0200 change toast position commit d99771122067d125404181580374e4497fa356b4 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 18:26:15 2023 +0200 Add tooltips commit c65efb92592a46b63d738a39c2205787bf8fc37a Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 18:01:20 2023 +0200 Add prettier commit fc0ecd6a6b93d867a498960d3c7613b087b3147e Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 17:57:56 2023 +0200 Fix toolbar button tooltip commit 4c2b2463ff9ab90a0f96a0909d5773c845962b38 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 17:39:38 2023 +0200 Fixed maildispatcher index button commit 33e46bb38880d16d236f6e4673d0a2efd58a3bff Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 17:37:40 2023 +0200 Fix mailgateway form commit ffb0a0ba120c447f162ea592cf87ec6ad51b4391 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 17:34:30 2023 +0200 Fix filter for Maildispatcher commit 64548178c0d65c5b69eee59cdafcf38d0d053a21 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 17:13:11 2023 +0200 Add back button to initialize commit 401d138e647e049058ee2821af7ee9e30d7786ec Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:42:21 2023 +0200 Fix settings success message commit 1e09006f5b73696e1fc0272dcb3112ea84392d2d Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:38:00 2023 +0200 Fix save button in Settings commit ad21a2a3bf28a61472c469fe64a704737bc54d69 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:32:11 2023 +0200 Fix event name commit cb7df3f5acc774b864a688a9e61cba9ac481fa7c Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:29:58 2023 +0200 Fix event name commit 46c52237de412397f88f4948a5617fb42fe7d142 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:27:17 2023 +0200 Fixed hasFlash messages commit 37b9e724cde5af7458be9847550334e62345e15b Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:27:00 2023 +0200 Fix pagination reload event commit a9be327a59680ff11d5f76356f64523fa06fd300 Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:26:37 2023 +0200 Remove console log commit 39119c5be593074018cac883af45104f87a7640a Author: philipp lang <philipp@aweos.de> Date: Sun Jul 2 00:04:52 2023 +0200 Fix notification component in InstallLayout commit a867053cd1283ce5fed0139e2ab66de804d7657a Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 03:08:20 2023 +0200 Remove console log commit 637338ad3456232892966e2d43fd3587e739f10e Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 03:07:23 2023 +0200 Fix: import toasted commit d190f814a23584f2f1de500e49e3b137eb8f4cfc Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 03:07:05 2023 +0200 Update hasFlash toast commit 6cd96ef5eafbbb3db8c0d21869bf3c91557d758c Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 03:06:38 2023 +0200 Add toast notification on axios error commit 1ba3d221e7e5fa2fd19d3d316de45c3daa6bedf8 Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 01:34:40 2023 +0200 Fix save button in activity VForm commit 8089f8f0834a6dc64b959f2574e9fddcaa2724a8 Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 01:32:03 2023 +0200 Lint commit cba4f25d317eba277baf527e61d4a810bbe03107 Author: philipp lang <philipp@aweos.de> Date: Sat Jul 1 01:31:15 2023 +0200 Fix import for subactivity form commit 83bbf9c4c44aea7ff33869e8ae27b86dba59985f Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 15:44:33 2023 +0200 Drop leaflet map commit f8d1fe08fa146ae8c637873add8901a2f6e5b0b2 Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 15:29:51 2023 +0200 fix toolbar commit 44c48ec02b0a27e6296d5107fb53c99ad846aeb3 Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 14:28:49 2023 +0200 install new inertia middleware commit b9b9cde58918d40e530afa8786e54a0f9eba2b73 Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 13:49:33 2023 +0200 Update save button commit 8c1e9b143a2349bf33e934a21a039c8966d8e143 Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 13:40:06 2023 +0200 fix select commit 46b6418f84e9bfc4ec5ce1ab9e6b02669fe7227d Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 13:09:08 2023 +0200 update select commit ea274669fded1fb905c89cd20b62f672b8f7b57a Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 13:07:22 2023 +0200 fix switch commit 048f9f1324c5c54f13d45f0a819855bb8274df6f Author: Philipp Lang <privat@zoomyboy.de> Date: Fri Jun 30 12:15:38 2023 +0200 fix components commit e4700e06aaa912d519d0313e2f2e76288e12dd9b Author: Philipp Lang <privat@zoomyboy.de> Date: Thu Jun 22 16:34:44 2023 +0200 vue3 update commit 2b196f2bd285e843ca86cd624f0dadbefe759786 Author: Philipp Lang <privat@zoomyboy.de> Date: Thu Jun 22 13:08:55 2023 +0200 Add page title commit 30dfc5dca25b95ff5f25b976ae66c1ff350b0ebe Author: Philipp Lang <privat@zoomyboy.de> Date: Thu Jun 22 12:59:47 2023 +0200 Fix map commit 43f7d335f32691f1b02dcbbd4d01943dd4b7c752 Author: Philipp Lang <privat@zoomyboy.de> Date: Thu Jun 22 12:58:33 2023 +0200 Update inertia
2023-07-06 13:56:19 +02:00
import Tags from './Tags.vue';
import Actions from './index/Actions.vue';
2024-07-03 16:37:58 +02:00
import { indexProps, useIndex } from '../../composables/useIndex.js';
import { ref, defineProps } from 'vue';
2020-06-02 23:45:25 +02:00
2023-07-27 17:22:06 +02:00
const single = ref(null);
const deleting = ref(null);
2024-01-29 00:13:03 +01:00
const membershipFilters = ref(null);
2021-08-22 05:15:56 +02:00
2023-07-27 17:22:06 +02:00
const props = defineProps(indexProps);
2024-07-03 16:37:58 +02:00
var { router, data, meta, getFilter, setFilter, filterString, reloadPage } = useIndex(props.data, 'member');
2023-07-27 17:22:06 +02:00
function exportMembers() {
window.open(`/member-export?filter=${filterString.value}`);
}
2021-07-04 16:56:07 +02:00
2023-07-27 17:22:06 +02:00
async function remove(member) {
new Promise((resolve, reject) => {
2024-07-03 16:37:58 +02:00
deleting.value = { resolve, reject, member };
2023-07-27 17:22:06 +02:00
})
.then(() => {
router.delete(`/member/${member.id}`);
deleting.value = null;
})
.catch(() => (deleting.value = null));
}
2021-07-04 19:09:59 +02:00
2023-09-12 16:54:13 +02:00
function openSidebar(type, model) {
single.value = {
type: type,
model: model,
};
2023-07-27 17:22:06 +02:00
}
function closeSidebar() {
single.value = null;
}
2020-06-02 23:45:25 +02:00
</script>