60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
<template>
 | 
						|
    <page-layout page-class="pb-6">
 | 
						|
        <template #toolbar>
 | 
						|
            <page-toolbar-button :href="meta.links.create" color="primary" icon="plus">Tätigkeit
 | 
						|
                erstellen</page-toolbar-button>
 | 
						|
        </template>
 | 
						|
        <ui-popup v-if="deleting !== null" heading="Bitte bestätigen" @close="deleting = null">
 | 
						|
            <div>
 | 
						|
                <p class="mt-4">Diese Aktivität löschen?</p>
 | 
						|
                <div class="grid grid-cols-2 gap-3 mt-6">
 | 
						|
                    <a href="#" class="text-center btn btn-danger" @click.prevent="remove">Löschen</a>
 | 
						|
                    <a href="#" class="text-center btn btn-primary" @click.prevent="deleting = null">Abbrechen</a>
 | 
						|
                </div>
 | 
						|
            </div>
 | 
						|
        </ui-popup>
 | 
						|
        <table cellspacing="0" cellpadding="0" border="0" class="custom-table custom-table-sm table">
 | 
						|
            <thead>
 | 
						|
                <th>Name</th>
 | 
						|
                <th></th>
 | 
						|
            </thead>
 | 
						|
 | 
						|
            <tr v-for="(activity, index) in data" :key="index">
 | 
						|
                <td v-text="activity.name"></td>
 | 
						|
                <td>
 | 
						|
                    <div class="flex space-x-1">
 | 
						|
                        <i-link v-tooltip="`Bearbeiten`" :href="activity.links.edit"
 | 
						|
                            class="inline-flex btn btn-warning btn-sm"><ui-sprite src="pencil"></ui-sprite></i-link>
 | 
						|
                        <a v-tooltip="`Entfernen`" href="#" class="inline-flex btn btn-danger btn-sm"
 | 
						|
                            @click.prevent="deleting = activity"><ui-sprite src="trash"></ui-sprite></a>
 | 
						|
                    </div>
 | 
						|
                </td>
 | 
						|
            </tr>
 | 
						|
        </table>
 | 
						|
 | 
						|
        <div class="px-6">
 | 
						|
            <ui-pagination class="mt-4" :value="meta" :only="['data']"></ui-pagination>
 | 
						|
        </div>
 | 
						|
    </page-layout>
 | 
						|
</template>
 | 
						|
 | 
						|
<script setup>
 | 
						|
import { ref, defineProps } from 'vue';
 | 
						|
import { indexProps, useIndex } from '../../composables/useIndex.js';
 | 
						|
 | 
						|
const props = defineProps(indexProps);
 | 
						|
const { router, data, meta } = useIndex(props.data, 'activity');
 | 
						|
const deleting = ref(null);
 | 
						|
 | 
						|
function remove() {
 | 
						|
    router.delete(deleting.value.links.destroy, {
 | 
						|
        preserveState: true,
 | 
						|
        onSuccess: (page) => {
 | 
						|
            data.value = page.props.data.data;
 | 
						|
            meta.value = page.props.data.meta;
 | 
						|
            deleting.value = null;
 | 
						|
        },
 | 
						|
    });
 | 
						|
}
 | 
						|
</script>
 |