salix/print/templates/email/payment-update/payment-update.js

42 lines
1.1 KiB
JavaScript
Raw Normal View History

2019-11-04 12:55:20 +00:00
const Component = require(`${appPath}/core/component`);
const db = require(`${appPath}/core/database`);
2019-11-04 12:55:20 +00:00
const emailHeader = new Component('email-header');
const emailFooter = new Component('email-footer');
module.exports = {
name: 'payment-update',
async serverPrefetch() {
2019-11-19 11:53:25 +00:00
this.payMethod = await this.fetchPayMethod(this.clientId);
2019-11-04 12:55:20 +00:00
2019-11-19 11:53:25 +00:00
if (!this.payMethod)
2019-11-04 12:55:20 +00:00
throw new Error('Something went wrong');
},
computed: {
accountAddress: function() {
2019-11-19 11:53:25 +00:00
return this.payMethod.iban.slice(-4);
2019-11-04 12:55:20 +00:00
},
},
methods: {
2019-11-19 11:53:25 +00:00
fetchPayMethod(clientId) {
2019-11-04 12:55:20 +00:00
return db.findOne(
`SELECT
c.dueDay,
c.iban,
2019-11-19 11:53:25 +00:00
pm.name,
pm.code
2019-11-04 12:55:20 +00:00
FROM client c
JOIN payMethod pm ON pm.id = c.payMethodFk
2019-11-19 11:53:25 +00:00
WHERE c.id = :clientId`, {clientId: clientId});
2019-11-04 12:55:20 +00:00
}
},
components: {
'email-header': emailHeader.build(),
'email-footer': emailFooter.build()
},
props: {
clientId: {
required: true
}
}
};