Ticket service #494
|
@ -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
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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'),
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue