2023-12-13 13:19:42 +00:00
|
|
|
import { defineStore } from 'pinia';
|
|
|
|
import { useUserConfig } from 'src/composables/useUserConfig';
|
|
|
|
import { exportFile } from 'quasar';
|
2024-01-03 13:16:26 +00:00
|
|
|
import { useArrayData } from 'composables/useArrayData';
|
|
|
|
import useNotify from 'src/composables/useNotify.js';
|
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
import axios from 'axios';
|
2023-12-13 13:19:42 +00:00
|
|
|
|
|
|
|
const { notify } = useNotify();
|
|
|
|
|
|
|
|
export const useInvoiceOutGlobalStore = defineStore({
|
|
|
|
id: 'invoiceOutGlobal',
|
|
|
|
|
|
|
|
state: () => ({
|
|
|
|
initialDataLoading: true,
|
|
|
|
formInitialData: {
|
|
|
|
companyFk: null,
|
|
|
|
invoiceDate: null,
|
|
|
|
maxShipped: null,
|
|
|
|
clientId: null,
|
|
|
|
printer: null,
|
|
|
|
},
|
|
|
|
addresses: [],
|
|
|
|
minInvoicingDate: null,
|
|
|
|
parallelism: null,
|
|
|
|
invoicing: false,
|
|
|
|
isInvoicing: false,
|
|
|
|
status: null,
|
|
|
|
addressIndex: 0,
|
|
|
|
errors: [],
|
|
|
|
printer: null,
|
|
|
|
nRequests: 0,
|
|
|
|
nPdfs: 0,
|
|
|
|
totalPdfs: 0,
|
|
|
|
}),
|
|
|
|
actions: {
|
|
|
|
async init() {
|
|
|
|
await this.fetchAllData();
|
|
|
|
},
|
|
|
|
|
|
|
|
async fetchAllData() {
|
|
|
|
try {
|
|
|
|
const userInfo = await useUserConfig().fetch();
|
|
|
|
const date = Date.vnNew();
|
|
|
|
this.formInitialData.maxShipped = new Date(
|
|
|
|
date.getFullYear(),
|
|
|
|
date.getMonth(),
|
|
|
|
0
|
|
|
|
)
|
|
|
|
.toISOString()
|
|
|
|
.substring(0, 10);
|
|
|
|
|
|
|
|
await Promise.all([
|
|
|
|
this.fetchParallelism(),
|
|
|
|
this.fetchInvoiceOutConfig(userInfo.companyFk),
|
|
|
|
]);
|
|
|
|
|
|
|
|
this.initialDataLoading = false;
|
|
|
|
} catch (err) {
|
|
|
|
console.error('Error fetching invoice out global initial data');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
async fetchInvoiceOutConfig(companyFk) {
|
2023-12-18 20:17:12 +00:00
|
|
|
try {
|
|
|
|
this.formInitialData.companyFk = companyFk;
|
|
|
|
const params = { companyFk: companyFk };
|
|
|
|
|
|
|
|
const { data } = await axios.get('InvoiceOuts/getInvoiceDate', {
|
|
|
|
params,
|
|
|
|
});
|
|
|
|
|
|
|
|
const stringDate = data.issued.substring(0, 10);
|
|
|
|
this.minInvoicingDate = stringDate;
|
|
|
|
this.formInitialData.invoiceDate = stringDate;
|
2024-02-12 11:11:44 +00:00
|
|
|
|
|
|
|
this.minInvoicingDate = new Date(data.issued);
|
|
|
|
this.formInitialData.invoiceDate = this.minInvoicingDate;
|
2023-12-18 20:17:12 +00:00
|
|
|
} catch (err) {
|
|
|
|
console.error('Error fetching invoice out global initial data');
|
|
|
|
throw new Error();
|
|
|
|
}
|
2023-12-13 13:19:42 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
async fetchParallelism() {
|
|
|
|
const filter = { fields: ['parallelism'] };
|
2023-12-18 20:17:12 +00:00
|
|
|
const { data } = await axios.get('InvoiceOutConfigs/findOne', {
|
|
|
|
filter,
|
|
|
|
});
|
|
|
|
this.parallelism = data.parallelism;
|
2023-12-13 13:19:42 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
async makeInvoice(formData, clientsToInvoice) {
|
|
|
|
this.invoicing = true;
|
|
|
|
this.status = 'packageInvoicing';
|
|
|
|
try {
|
|
|
|
this.printer = formData.printer;
|
|
|
|
const params = {
|
|
|
|
invoiceDate: new Date(formData.invoiceDate),
|
|
|
|
maxShipped: new Date(formData.maxShipped),
|
|
|
|
clientId: formData.clientId ? formData.clientId : null,
|
|
|
|
companyFk: formData.companyFk,
|
|
|
|
};
|
|
|
|
|
|
|
|
this.validateMakeInvoceParams(params, clientsToInvoice);
|
|
|
|
|
|
|
|
if (clientsToInvoice == 'all') params.clientId = undefined;
|
|
|
|
|
2024-02-12 11:11:44 +00:00
|
|
|
const { data } = await axios.post('InvoiceOuts/clientsToInvoice', params);
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2024-02-12 11:11:44 +00:00
|
|
|
this.addresses = data;
|
2023-12-13 13:19:42 +00:00
|
|
|
|
|
|
|
if (!this.addresses || !this.addresses.length > 0) {
|
|
|
|
notify(
|
|
|
|
'invoiceOut.globalInvoices.errors.noTicketsToInvoice',
|
|
|
|
'negative'
|
|
|
|
);
|
|
|
|
throw new Error("There aren't addresses to invoice");
|
|
|
|
}
|
|
|
|
|
2024-02-12 11:11:44 +00:00
|
|
|
for (const address of this.addresses) {
|
2023-12-13 13:19:42 +00:00
|
|
|
await this.invoiceClient(address, formData);
|
2024-02-12 11:11:44 +00:00
|
|
|
}
|
2023-12-13 13:19:42 +00:00
|
|
|
} catch (err) {
|
|
|
|
this.handleError(err);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
validateMakeInvoceParams(params, clientsToInvoice) {
|
|
|
|
if (clientsToInvoice === 'one' && !params.clientId) {
|
|
|
|
notify('invoiceOut.globalInvoices.errors.chooseValidClient', 'negative');
|
|
|
|
throw new Error('Invalid client');
|
|
|
|
}
|
|
|
|
if (!params.invoiceDate || !params.maxShipped) {
|
|
|
|
notify('invoiceOut.globalInvoices.errors.fillDates', 'negative');
|
|
|
|
throw new Error('Missing dates');
|
|
|
|
}
|
|
|
|
if (params.invoiceDate < params.maxShipped) {
|
|
|
|
notify(
|
|
|
|
'invoiceOut.globalInvoices.errors.invoiceDateLessThanMaxDate',
|
|
|
|
'negative'
|
|
|
|
);
|
|
|
|
throw new Error('Invalid date range');
|
|
|
|
}
|
|
|
|
|
|
|
|
const invoiceDateTime = new Date(params.invoiceDate).getTime();
|
|
|
|
const minInvoiceDateTime = new Date(this.minInvoicingDate).getTime();
|
|
|
|
|
|
|
|
if (this.minInvoicingDate && invoiceDateTime < minInvoiceDateTime) {
|
|
|
|
notify(
|
|
|
|
'invoiceOut.globalInvoices.errors.invoiceWithFutureDate',
|
|
|
|
'negative'
|
|
|
|
);
|
|
|
|
throw new Error('Invoice date in the future');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!params.companyFk) {
|
|
|
|
notify('invoiceOut.globalInvoices.errors.chooseValidCompany', 'negative');
|
|
|
|
throw new Error('Invalid company');
|
|
|
|
}
|
|
|
|
if (!this.printer) {
|
|
|
|
notify('invoiceOut.globalInvoices.errors.chooseValidPrinter', 'negative');
|
|
|
|
throw new Error('Invalid printer');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
async invoiceClient(address, formData) {
|
2023-12-18 20:17:12 +00:00
|
|
|
try {
|
|
|
|
if (this.nRequests === this.parallelism || this.isInvoicing) return;
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
if (this.status === 'stopping') {
|
|
|
|
if (this.nRequests) return;
|
|
|
|
this.invoicing = false;
|
|
|
|
this.status = 'done';
|
|
|
|
return;
|
|
|
|
}
|
2023-11-20 17:58:41 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
const params = {
|
|
|
|
clientId: address.clientId,
|
|
|
|
addressId: address.id,
|
|
|
|
invoiceDate: new Date(formData.invoiceDate),
|
|
|
|
maxShipped: new Date(formData.maxShipped),
|
|
|
|
companyFk: formData.companyFk,
|
|
|
|
};
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
this.status = 'invoicing';
|
|
|
|
this.invoicing = true;
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2024-02-12 11:11:44 +00:00
|
|
|
const { data } = await axios.post('InvoiceOuts/invoiceClient', params);
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2024-02-12 11:11:44 +00:00
|
|
|
if (data) {
|
|
|
|
await this.makePdfAndNotify(data, address);
|
2023-12-18 20:17:12 +00:00
|
|
|
}
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
this.isInvoicing = false;
|
|
|
|
} catch (err) {
|
|
|
|
if (
|
|
|
|
err &&
|
|
|
|
err.response &&
|
|
|
|
err.response.status >= 400 &&
|
|
|
|
err.response.status < 500
|
|
|
|
) {
|
2024-02-12 11:11:44 +00:00
|
|
|
this.invoiceClientError(address, err.response?.data?.error?.message);
|
2023-12-13 13:19:42 +00:00
|
|
|
this.addressIndex++;
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
this.invoicing = false;
|
|
|
|
this.status = 'done';
|
|
|
|
notify(
|
|
|
|
'invoiceOut.globalInvoices.errors.criticalInvoiceError',
|
|
|
|
'negative'
|
|
|
|
);
|
|
|
|
throw new Error('Critical invoicing error, process stopped');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
async makePdfAndNotify(invoiceId, client) {
|
|
|
|
try {
|
|
|
|
this.nRequests++;
|
|
|
|
this.totalPdfs++;
|
|
|
|
const params = { printerFk: this.printer };
|
2023-12-18 20:17:12 +00:00
|
|
|
await axios.post(`InvoiceOuts/${invoiceId}/makePdfAndNotify`, params);
|
2023-12-13 13:19:42 +00:00
|
|
|
this.nPdfs++;
|
|
|
|
this.nRequests--;
|
|
|
|
} catch (err) {
|
2024-02-12 11:11:44 +00:00
|
|
|
this.invoiceClientError(client, err.response?.data?.error?.message, true);
|
2023-12-13 13:19:42 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2024-02-12 11:11:44 +00:00
|
|
|
invoiceClientError(client, message, isWarning) {
|
2023-12-13 13:19:42 +00:00
|
|
|
this.errors.unshift({ client, message, isWarning });
|
|
|
|
},
|
|
|
|
|
|
|
|
handleError(err) {
|
|
|
|
this.invoicing = false;
|
|
|
|
this.status = null;
|
|
|
|
throw err;
|
|
|
|
},
|
|
|
|
|
2024-01-03 13:16:26 +00:00
|
|
|
async getNegativeBasesCsv() {
|
2023-12-13 13:19:42 +00:00
|
|
|
try {
|
2024-01-03 13:16:26 +00:00
|
|
|
const arrayData = useArrayData('InvoiceOutNegative');
|
|
|
|
const params = arrayData.store.currentFilter;
|
2023-11-28 13:11:24 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
const { data } = await axios.get('InvoiceOuts/negativeBasesCsv', {
|
|
|
|
params,
|
|
|
|
});
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
if (data.data && data.data.error) throw new Error();
|
2023-12-13 13:19:42 +00:00
|
|
|
|
2023-12-18 20:17:12 +00:00
|
|
|
const status = exportFile('negativeBases.csv', data, {
|
2023-12-13 13:19:42 +00:00
|
|
|
encoding: 'windows-1252',
|
|
|
|
mimeType: 'text/csv;charset=windows-1252;',
|
|
|
|
});
|
|
|
|
|
|
|
|
if (status) {
|
|
|
|
notify('globals.downloadCSVSuccess', 'positive');
|
|
|
|
}
|
|
|
|
} catch (err) {
|
|
|
|
notify('invoiceOut.negativeBases.errors.downloadCsvFailed', 'negative');
|
2023-12-18 20:17:12 +00:00
|
|
|
throw new Error();
|
2023-12-13 13:19:42 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// State mutations actions
|
|
|
|
|
|
|
|
setStatusValue(status) {
|
|
|
|
this.status = status;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
getters: {
|
|
|
|
getNAddresses(state) {
|
|
|
|
return state.addresses.length;
|
|
|
|
},
|
|
|
|
getPercentage(state) {
|
|
|
|
if (this.getNAdresses <= 0 || !state.addressIndex) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
let porcentaje = (state.addressIndex / this.getNAddresses) * 100;
|
|
|
|
return porcentaje;
|
|
|
|
},
|
|
|
|
getAddressNumber(state) {
|
|
|
|
return state.addressIndex;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|