refactor: kebab action

This commit is contained in:
puriphatt 2024-08-27 11:46:26 +07:00
parent 5ec6d1c9d5
commit bc578d569c
11 changed files with 518 additions and 1357 deletions

View file

@ -0,0 +1,125 @@
<script lang="ts" setup>
import ToggleButton from '../button/ToggleButton.vue';
withDefaults(
defineProps<{
idName: string;
status: string;
disableDelete?: boolean;
}>(),
{
idName: '',
status: 'ACTIVE',
},
);
defineEmits<{
(e: 'view'): void;
(e: 'edit'): void;
(e: 'delete'): void;
(e: 'changeStatus'): void;
}>();
</script>
<template>
<q-btn
flat
dense
round
size="sm"
icon="mdi-dots-vertical"
:id="`btn-kebab-action-${idName}`"
@click.stop
>
<q-menu class="bordered">
<q-list>
<q-item
v-close-popup
dense
clickable
class="row q-py-sm"
style="white-space: nowrap"
:id="`btn-kebab-view-detail-${idName}`"
@click.stop="() => $emit('view')"
>
<q-icon
size="xs"
class="col-3"
name="mdi-eye-outline"
style="color: hsl(var(--green-6-hsl))"
/>
<span class="col-9 q-px-md flex items-center">
{{ $t('general.viewDetail') }}
</span>
</q-item>
<q-item
v-if="status !== 'INACTIVE'"
v-close-popup
dense
clickable
class="row q-py-sm"
style="white-space: nowrap"
:id="`btn-kebab-edit-${idName}`"
@click.stop="() => $emit('edit')"
>
<q-icon
size="xs"
class="col-3"
name="mdi-pencil-outline"
style="color: hsl(var(--cyan-6-hsl))"
/>
<span class="col-9 q-px-md flex items-center">
{{ $t('general.edit') }}
</span>
</q-item>
<q-item
v-if="status !== 'INACTIVE'"
v-close-popup
dense
class="row"
style="white-space: nowrap"
:clickable="!disableDelete"
:id="`btn-kebab-delete-${idName}`"
:class="{
'surface-3': disableDelete,
'app-text-muted': disableDelete,
}"
@click.stop="() => $emit('delete')"
>
<q-icon
size="xs"
name="mdi-trash-can-outline"
class="col-3"
:class="{
'app-text-negative': !disableDelete,
}"
/>
<span class="col-9 q-px-md flex items-center">
{{ $t('general.delete') }}
</span>
</q-item>
<q-item dense>
<q-item-section class="q-py-sm">
<div class="q-pa-sm surface-2 rounded flex items-center">
<ToggleButton
two-way
:id="`btn-kebab-status-${idName}`"
:model-value="status !== 'INACTIVE'"
@click="() => $emit('changeStatus')"
/>
<span class="q-pl-md">
{{
status !== 'INACTIVE'
? $t('general.open')
: $t('general.close')
}}
</span>
</div>
</q-item-section>
</q-item>
</q-list>
</q-menu>
</q-btn>
</template>

View file

@ -3,7 +3,7 @@ import { Icon } from '@iconify/vue';
import AppBox from 'components/app/AppBox.vue';
import AppCircle from 'components/app/AppCircle.vue';
import ToggleButton from '../button/ToggleButton.vue';
import KebabAction from './KebabAction.vue';
defineProps<{
data: {
@ -74,91 +74,18 @@ defineEmits<{
@click.stop="$emit('history')"
/>
<q-btn
:id="`btn-dots-${prefixId}`"
:key="data.code"
flat
round
padding="xs"
class="app-text-muted-2"
icon="mdi-dots-vertical"
size="sm"
@click.stop
>
<q-menu class="bordered">
<q-list v-close-popup>
<q-item
clickable
dense
class="row q-py-sm"
style="white-space: nowrap"
v-close-popup
@click.stop="
separateEnter
? $emit('viewCard', 'INFO')
: $emit('enterCard', 'INFO')
"
>
<q-icon
name="mdi-eye-outline"
class="col-3"
size="xs"
style="color: hsl(var(--green-6-hsl))"
/>
<span class="col-9 q-px-md flex items-center">
{{ $t('general.viewDetail') }}
</span>
</q-item>
<q-item
dense
clickable
class="row q-py-sm"
style="white-space: nowrap"
@click="$emit('updateCard', 'INFO', true)"
v-close-popup
>
<q-icon
name="mdi-pencil-outline"
class="col-3"
size="xs"
style="color: hsl(var(--cyan-6-hsl))"
/>
<span class="col-9 q-px-md flex items-center">
{{ $t('general.edit') }}
</span>
</q-item>
<q-item
dense
clickable
@click="$emit('deleteCard')"
v-close-popup
>
<q-icon
name="mdi-trash-can-outline"
size="xs"
class="col-3 app-text-negative"
/>
<span class="col-9 q-px-md flex items-center">
{{ $t('general.delete') }}
</span>
</q-item>
<q-item dense>
<q-item-section class="q-py-sm">
<div class="q-pa-sm surface-2 rounded flex items-center">
<ToggleButton
two-way
:model-value="!disabled"
@click="$emit('toggleStatus', disabled === false)"
/>
<span class="q-pl-md">
{{ !disabled ? $t('general.open') : $t('general.close') }}
</span>
</div>
</q-item-section>
</q-item>
</q-list>
</q-menu>
</q-btn>
<KebabAction
:id-name="prefixId"
:status="disabled ? 'INACTIVE' : 'ACTIVE'"
@view="
separateEnter
? $emit('viewCard', 'INFO')
: $emit('enterCard', 'INFO')
"
@edit="$emit('updateCard', 'INFO', true)"
@delete="$emit('deleteCard')"
@change-status="$emit('toggleStatus', disabled === false)"
/>
</div>
<!-- profile -->