2019-10-31 11:43:04 +00:00
|
|
|
const Component = require(`${appPath}/core/component`);
|
2019-11-07 10:19:05 +00:00
|
|
|
const db = require(`${appPath}/core/database`);
|
2019-10-29 06:46:44 +00:00
|
|
|
const reportHeader = new Component('report-header');
|
|
|
|
const reportFooter = new Component('report-footer');
|
2019-03-05 13:59:18 +00:00
|
|
|
|
|
|
|
module.exports = {
|
2019-10-24 05:41:54 +00:00
|
|
|
name: 'receipt',
|
|
|
|
async serverPrefetch() {
|
|
|
|
this.client = await this.fetchClient(this.receiptId);
|
|
|
|
this.receipt = await this.fetchReceipt(this.receiptId);
|
2019-03-05 13:59:18 +00:00
|
|
|
|
2019-10-31 11:43:04 +00:00
|
|
|
if (!this.receipt)
|
|
|
|
throw new Error('Something went wrong');
|
2019-03-05 13:59:18 +00:00
|
|
|
},
|
|
|
|
methods: {
|
2019-10-24 05:41:54 +00:00
|
|
|
fetchClient(receiptId) {
|
|
|
|
return db.findOne(
|
2019-03-05 13:59:18 +00:00
|
|
|
`SELECT
|
|
|
|
c.id,
|
|
|
|
c.socialName,
|
|
|
|
u.lang locale
|
|
|
|
FROM receipt r
|
|
|
|
JOIN client c ON c.id = r.clientFk
|
|
|
|
JOIN account.user u ON u.id = c.id
|
2019-10-24 05:41:54 +00:00
|
|
|
WHERE r.id = ?`, [receiptId]);
|
2019-03-05 13:59:18 +00:00
|
|
|
},
|
2019-10-24 05:41:54 +00:00
|
|
|
fetchReceipt(receiptId) {
|
|
|
|
return db.findOne(
|
2019-03-05 13:59:18 +00:00
|
|
|
`SELECT
|
|
|
|
r.id,
|
|
|
|
r.amountPaid,
|
|
|
|
r.amountUnpaid,
|
|
|
|
r.payed,
|
|
|
|
r.companyFk
|
|
|
|
FROM receipt r
|
|
|
|
JOIN client c ON c.id = r.clientFk
|
2019-10-24 05:41:54 +00:00
|
|
|
WHERE r.id = ?`, [receiptId]);
|
2019-10-31 11:43:04 +00:00
|
|
|
}
|
2019-10-29 06:46:44 +00:00
|
|
|
},
|
|
|
|
components: {
|
|
|
|
'report-header': reportHeader.build(),
|
|
|
|
'report-footer': reportFooter.build()
|
2019-03-05 13:59:18 +00:00
|
|
|
},
|
2019-10-31 11:43:04 +00:00
|
|
|
props: {
|
|
|
|
receiptId: {
|
|
|
|
required: true
|
|
|
|
}
|
|
|
|
}
|
2019-03-05 13:59:18 +00:00
|
|
|
};
|