feat: refs #7346 add seriaType option #626

Merged
jgallego merged 7 commits from 7346-invoiceOutMultilple into dev 2024-08-23 09:08:53 +00:00
3 changed files with 45 additions and 8 deletions
Showing only changes of commit 06c0f49128 - Show all commits

View File

@ -20,20 +20,18 @@ const { initialDataLoading, formInitialData, invoicing, status } =
const { makeInvoice, setStatusValue } = invoiceOutGlobalStore;
const clientsToInvoice = ref('all');
const companiesOptions = ref([]);
const printersOptions = ref([]);
const clientsOptions = ref([]);
const serialTypesOptions = ref([]);
const formData = ref({});
const optionsInitialData = computed(() => {
return (

variable === null es lo mismo que hacer !variable

Por otra parte

    serialTypesOptions.value = Array.from(
        new Set(data.map((item) => item.type).filter((type) => type))
    );
};

variable === null es lo mismo que hacer !variable Por otra parte ``` serialTypesOptions.value = Array.from( new Set(data.map((item) => item.type).filter((type) => type)) ); }; ```
companiesOptions.value.length > 0 &&
jsegarra marked this conversation as resolved Outdated

Para tener una condición con 4 condiciones que siguen el mismo criterio, propondria usar el método "every"

Para tener una condición con 4 condiciones que siguen el mismo criterio, propondria usar el método "every"
printersOptions.value.length > 0 &&
clientsOptions.value.length > 0
clientsOptions.value.length > 0 &&
serialTypesOptions.value.length > 0
);
});
@ -60,7 +58,22 @@ onMounted(async () => {
/>
<FetchData url="Printers" @on-fetch="(data) => (printersOptions = data)" auto-load />
<FetchData url="Clients" @on-fetch="(data) => (clientsOptions = data)" auto-load />
<FetchData
url="invoiceOutSerials"
@on-fetch="
(data) => {

Al tener tanta lógica, propondria definir una función en la parte de script.setup

Al tener tanta lógica, propondria definir una función en la parte de script.setup
const uniqueTypes = new Set();
serialTypesOptions = data.filter((item) => {
if (item.type === null || uniqueTypes.has(item.type)) {
return false;
}
uniqueTypes.add(item.type);
return true;
});
}
"
auto-load
/>
<QForm
v-if="!initialDataLoading && optionsInitialData"
@submit="makeInvoice(formData, clientsToInvoice)"
@ -95,6 +108,17 @@ onMounted(async () => {
outlined
rounded
/>
<VnSelect

Si printas la variable serialTypesOptions, te sale algo asi: [ { "code": "A", "description": "Global nacional", "isTaxed": true, "isCEE": false, "taxAreaFk": "NATIONAL" } ]

Type no aparece por ningún lado

Si printas la variable serialTypesOptions, te sale algo asi: [ { "code": "A", "description": "Global nacional", "isTaxed": true, "isCEE": false, "taxAreaFk": "NATIONAL" } ] Type no aparece por ningún lado

creo que eso se debe a que no lo has probado descargando también el back de la 7346

creo que eso se debe a que no lo has probado descargando también el back de la 7346

Puede ser.
Lo pruebo con esa rama

Puede ser. Lo pruebo con esa rama
:label="t('invoiceOutSerialType')"
v-model="formData.invoiceType"
:options="serialTypesOptions"
option-value="type"
option-label="type"
hide-selected
dense
outlined
rounded
/>
<VnInputDate
v-model="formData.invoiceDate"
:label="t('invoiceDate')"
@ -168,6 +192,7 @@ en:
printer: Printer
invoiceOut: Invoice out
client: Client
invoiceOutSerialType: Serial Type
stop: Stop
es:
@ -179,5 +204,6 @@ es:
printer: Impresora
invoiceOut: Facturar
client: Cliente
invoiceOutSerialType: Tipo de Serie
stop: Parar
</i18n>

View File

@ -198,7 +198,7 @@ watchEffect(selectedRows);
:url="`${MODEL}/filter`"
:create="{
urlCreate: 'InvoiceOuts/createManualInvoice',
title: t('Create Manual Invoice'),
title: t('Create manual invoice'),
onDataSaved: ({ id }) => tableRef.redirect(id),
formInitialData: {
active: true,
@ -275,10 +275,12 @@ en:
fileAllowed: Successful download of CSV file
youCanSearchByInvoiceReference: You can search by invoice reference
createInvoice: Make invoice
Create manual invoice: Create manual invoice
es:
searchInvoice: Buscar factura emitida
fileDenied: El navegador denegó la descarga de archivos...
fileAllowed: Descarga exitosa de archivo CSV
youCanSearchByInvoiceReference: Puedes buscar por referencia de la factura
createInvoice: Crear factura
Create manual invoice: Crear factura manual
</i18n>

View File

@ -19,6 +19,7 @@ export const useInvoiceOutGlobalStore = defineStore({
maxShipped: null,
clientId: null,
printer: null,
invoiceType: null,
},
addresses: [],
minInvoicingDate: null,
@ -100,6 +101,7 @@ export const useInvoiceOutGlobalStore = defineStore({
maxShipped: new Date(formData.maxShipped),
clientId: formData.clientId ? formData.clientId : null,
companyFk: formData.companyFk,
invoiceType: formData.invoiceType,
};
this.validateMakeInvoceParams(params, clientsToInvoice);
@ -152,7 +154,13 @@ export const useInvoiceOutGlobalStore = defineStore({
);
throw new Error('Invoice date in the future');
}
if (!params.invoiceType) {
notify(
'invoiceOut.globalInvoices.errors.chooseValidinvoiceType',
'negative'
);
throw new Error('Invalid Serial Type');
}
if (!params.companyFk) {
notify('invoiceOut.globalInvoices.errors.chooseValidCompany', 'negative');
throw new Error('Invalid company');
@ -180,6 +188,7 @@ export const useInvoiceOutGlobalStore = defineStore({
invoiceDate: new Date(formData.invoiceDate),
maxShipped: new Date(formData.maxShipped),
companyFk: formData.companyFk,
invoiceType: formData.invoiceType,
};
this.status = 'invoicing';