salix/print/templates/reports/invoice/invoice.js

131 lines
4.2 KiB
JavaScript
Raw Normal View History

2021-02-17 12:00:06 +00:00
const Component = require(`${appPath}/core/component`);
2021-02-24 06:51:05 +00:00
const Report = require(`${appPath}/core/report`);
2021-02-17 12:00:06 +00:00
const reportHeader = new Component('report-header');
const reportFooter = new Component('report-footer');
2021-03-01 10:25:37 +00:00
const invoiceIncoterms = new Report('invoice-incoterms');
2021-02-24 06:51:05 +00:00
const db = require(`${appPath}/core/database`);
2021-02-17 12:00:06 +00:00
module.exports = {
name: 'invoice',
async serverPrefetch() {
this.invoice = await this.fetchInvoice(this.invoiceId);
2021-02-18 12:01:01 +00:00
this.client = await this.fetchClient(this.invoiceId);
2021-02-24 06:51:05 +00:00
this.taxes = await this.fetchTaxes(this.invoiceId);
this.intrastat = await this.fetchIntrastat(this.invoiceId);
this.rectified = await this.fetchRectified(this.invoiceId);
2021-03-01 10:25:37 +00:00
this.hasIncoterms = await this.fetchHasIncoterms(this.invoiceId);
2021-02-24 06:51:05 +00:00
const tickets = await this.fetchTickets(this.invoiceId);
const sales = await this.fetchSales(this.invoiceId);
const map = new Map();
for (let ticket of tickets)
map.set(ticket.id, ticket);
for (let sale of sales) {
const ticket = map.get(sale.ticketFk);
if (!ticket.sales) ticket.sales = [];
ticket.sales.push(sale);
}
this.tickets = tickets;
2021-02-17 12:00:06 +00:00
if (!this.invoice)
throw new Error('Something went wrong');
},
data() {
return {totalBalance: 0.00};
},
computed: {
2021-02-24 06:51:05 +00:00
ticketsId() {
const tickets = this.tickets.map(ticket => ticket.id);
2021-02-17 12:00:06 +00:00
2021-02-24 06:51:05 +00:00
return tickets.join(', ');
},
botanical() {
let phytosanitary = [];
for (let ticket of this.tickets) {
for (let sale of ticket.sales) {
if (sale.botanical)
phytosanitary.push(sale.botanical);
}
}
2021-02-17 12:00:06 +00:00
2021-02-24 06:51:05 +00:00
return phytosanitary.filter((item, index) =>
phytosanitary.indexOf(item) == index
).join(', ');
2021-02-17 12:00:06 +00:00
},
2021-02-24 06:51:05 +00:00
taxTotal() {
const base = this.sumTotal(this.taxes, 'base');
const vat = this.sumTotal(this.taxes, 'vat');
return base + vat;
}
2021-02-17 12:00:06 +00:00
},
methods: {
fetchInvoice(invoiceId) {
return this.findOneFromDef('invoice', [invoiceId]);
},
2021-02-24 06:51:05 +00:00
fetchClient(invoiceId) {
return this.findOneFromDef('client', [invoiceId]);
2021-02-17 12:00:06 +00:00
},
2021-02-24 06:51:05 +00:00
fetchTickets(invoiceId) {
return this.rawSqlFromDef('tickets', [invoiceId]);
2021-02-17 12:00:06 +00:00
},
2021-02-24 06:51:05 +00:00
async fetchSales(invoiceId) {
2021-04-27 08:29:09 +00:00
const connection = await db.getConnection('default');
2021-02-24 06:51:05 +00:00
await this.rawSql(`DROP TEMPORARY TABLE IF EXISTS tmp.invoiceTickets`, connection);
await this.rawSqlFromDef('invoiceTickets', [invoiceId], connection);
const sales = this.rawSqlFromDef('sales', connection);
await this.rawSql(`DROP TEMPORARY TABLE tmp.invoiceTickets`, connection);
await connection.release();
return sales;
2021-02-17 12:00:06 +00:00
},
2021-02-24 06:51:05 +00:00
fetchTaxes(invoiceId) {
return this.rawSqlFromDef(`taxes`, [invoiceId]);
2021-02-17 12:00:06 +00:00
},
2021-02-24 06:51:05 +00:00
fetchIntrastat(invoiceId) {
return this.rawSqlFromDef(`intrastat`, [invoiceId]);
2021-02-17 12:00:06 +00:00
},
2021-02-24 06:51:05 +00:00
fetchRectified(invoiceId) {
return this.rawSqlFromDef(`rectified`, [invoiceId]);
2021-02-17 12:00:06 +00:00
},
2021-03-01 10:25:37 +00:00
fetchHasIncoterms(invoiceId) {
return this.findValueFromDef(`hasIncoterms`, [invoiceId]);
},
2021-02-25 08:00:49 +00:00
saleImport(sale) {
const price = sale.quantity * sale.price;
return price * (1 - sale.discount / 100);
},
ticketSubtotal(ticket) {
2021-02-17 12:00:06 +00:00
let subTotal = 0.00;
2021-02-25 08:00:49 +00:00
for (let sale of ticket.sales)
subTotal += this.saleImport(sale);
2021-02-17 12:00:06 +00:00
return subTotal;
},
2021-02-24 06:51:05 +00:00
sumTotal(rows, prop) {
let total = 0.00;
for (let row of rows)
total += parseFloat(row[prop]);
2021-02-17 12:00:06 +00:00
2021-02-24 06:51:05 +00:00
return total;
2021-02-17 12:00:06 +00:00
}
},
components: {
'report-header': reportHeader.build(),
2021-03-01 10:25:37 +00:00
'report-footer': reportFooter.build(),
'invoice-incoterms': invoiceIncoterms.build()
2021-02-17 12:00:06 +00:00
},
props: {
invoiceId: {
type: String,
required: true
}
}
};