Ticket service #494

Merged
jsegarra merged 10 commits from :feature/TicketService into dev 2024-07-01 12:53:52 +00:00
3 changed files with 97 additions and 73 deletions
Showing only changes of commit db4c3a6799 - Show all commits

View File

@ -441,7 +441,7 @@ ticket:
sms: Sms sms: Sms
notes: Notas notes: Notas
sale: Lineas del pedido sale: Lineas del pedido
service: Servicios services: Servicios
list: list:
nickname: Alias nickname: Alias
state: Estado state: Estado

View File

@ -1,5 +1,5 @@
<script setup> <script setup>
import { ref, watch, computed } from 'vue'; import { ref, watch, computed, onMounted } from 'vue';
import { useRoute, useRouter } from 'vue-router'; import { useRoute, useRouter } from 'vue-router';
import { useI18n } from 'vue-i18n'; import { useI18n } from 'vue-i18n';
@ -26,6 +26,7 @@ const { store } = arrayData;
const { notify } = useNotify(); const { notify } = useNotify();
const selectedServices = ref(new Set()); const selectedServices = ref(new Set());
const defaultTaxClass = ref(null);
const toggleCheckSelection = (id) => { const toggleCheckSelection = (id) => {
if (selectedServices.value.has(id)) selectedServices.value.delete(id); if (selectedServices.value.has(id)) selectedServices.value.delete(id);
@ -36,7 +37,10 @@ const crudModelFilter = computed(() => ({
where: { ticketFk: route.params.id }, where: { ticketFk: route.params.id },
})); }));
const crudModelRequiredData = computed(() => ({ ticketFk: route.params.id })); const crudModelRequiredData = computed(() => ({
ticketFk: route.params.id,
taxClassFk: defaultTaxClass.value?.id,
}));
watch( watch(
() => route.params.id, () => route.params.id,
@ -68,6 +72,23 @@ const createRefund = async () => {
console.error(error); console.error(error);
} }
}; };
const getDefaultTaxClass = async () => {
try {
let filter = {
where: { code: 'G' },
};
const { data } = await axios.get('TaxClasses/findOne', {
params: { filter: JSON.stringify(filter) },
});
defaultTaxClass.value = data;
console.log('defaultTaxClass', defaultTaxClass.value);
} catch (error) {
console.error(error);
}
};
onMounted(async () => await getDefaultTaxClass());
</script> </script>
<template> <template>
@ -85,80 +106,83 @@ const createRefund = async () => {
@click.stop="createRefund()" @click.stop="createRefund()"
/> />
</Teleport> </Teleport>
<CrudModel <div class="flex justify-center">
ref="ticketServiceCrudRef" <CrudModel
data-key="TicketService" ref="ticketServiceCrudRef"
url="TicketServices" data-key="TicketService"
model="TicketService" url="TicketServices"
:filter="crudModelFilter" model="TicketService"
:data-required="crudModelRequiredData" :filter="crudModelFilter"
:default-remove="false" :data-required="crudModelRequiredData"
auto-load :default-remove="false"
> auto-load
<template #body="{ rows }"> style="max-width: 800px"
<QCard class="q-px-lg q-py-md"> >
<div <template #body="{ rows }">
v-for="(row, index) in rows" <QCard class="q-px-lg q-py-md">
:key="index" <div
class="q-mb-md row items-center q-gutter-x-md" v-for="(row, index) in rows"
> :key="index"
<QCheckbox class="q-mb-md row items-center q-gutter-x-md"
size="sm"
@update:model-value="toggleCheckSelection(row.id)"
:model-value="selectedServices.has(row.id)"
:toggle-indeterminate="false"
/>
<VnSelectDialog
:label="t('service.description')"
v-model="row.ticketServiceTypeFk"
:options="ticketServiceOptions"
option-label="name"
option-value="id"
hide-selected
> >
<template #form> <QCheckbox
<TicketCreateServiceType size="sm"
@on-data-saved="ticketServiceTypeFetchRef.fetch()" @update:model-value="toggleCheckSelection(row.id)"
/> :model-value="selectedServices.has(row.id)"
</template> :toggle-indeterminate="false"
</VnSelectDialog> />
<VnInput <VnSelectDialog
:label="t('service.quantity')" :label="t('service.description')"
v-model="row.quantity" v-model="row.ticketServiceTypeFk"
type="number" :options="ticketServiceOptions"
min="0" option-label="name"
:info="t('service.quantityInfo')" option-value="id"
/> hide-selected
<VnInput >
:label="t('service.price')" <template #form>
v-model="row.price" <TicketCreateServiceType
type="number" @on-data-saved="ticketServiceTypeFetchRef.fetch()"
min="0" />
/> </template>
</VnSelectDialog>
<VnInput
:label="t('service.quantity')"
v-model.number="row.quantity"
type="number"
min="0"
:info="t('service.quantityInfo')"
/>
<VnInput
:label="t('service.price')"
v-model.number="row.price"
type="number"
min="0"
/>
<QIcon
name="delete"
size="sm"
class="cursor-pointer"
color="primary"
@click="ticketServiceCrudRef.remove([row])"
>
<QTooltip>
{{ t('service.removeNote') }}
</QTooltip>
</QIcon>
</div>
<QIcon <QIcon
name="delete" name="add_circle"
class="fill-icon-on-hover q-ml-md"
size="sm" size="sm"
class="cursor-pointer"
color="primary" color="primary"
@click="ticketServiceCrudRef.remove([row])" @click="ticketServiceCrudRef.insert()"
> >
<QTooltip> <QTooltip>
{{ t('service.removeNote') }} {{ t('service.addService') }}
</QTooltip> </QTooltip>
</QIcon> </QIcon>
</div> </QCard>
<QIcon </template>
name="add_circle" </CrudModel>
class="fill-icon-on-hover q-ml-md" </div>
size="sm"
color="primary"
@click="ticketServiceCrudRef.insert()"
>
<QTooltip>
{{ t('service.addService') }}
</QTooltip>
</QIcon>
</QCard>
</template>
</CrudModel>
</template> </template>

View File

@ -98,8 +98,8 @@ export default {
path: 'service', path: 'service',
name: 'TicketService', name: 'TicketService',
meta: { meta: {
title: 'service', title: 'services',
icon: 'cloud_upload', icon: 'vn:services',
}, },
component: () => import('src/pages/Ticket/Card/TicketService.vue'), component: () => import('src/pages/Ticket/Card/TicketService.vue'),
}, },