164 lines
4.9 KiB
JavaScript
164 lines
4.9 KiB
JavaScript
import ngModule from '../module';
|
|
import Section from 'salix/components/section';
|
|
import './style.scss';
|
|
|
|
class Controller extends Section {
|
|
constructor($element, $, vnReport, vnEmail) {
|
|
super($element, $);
|
|
this.vnReport = vnReport;
|
|
this.vnEmail = vnEmail;
|
|
}
|
|
|
|
get invoiceOut() {
|
|
return this._invoiceOut;
|
|
}
|
|
|
|
set invoiceOut(value) {
|
|
this._invoiceOut = value;
|
|
if (value)
|
|
this.id = value.id;
|
|
}
|
|
|
|
get hasInvoicing() {
|
|
return this.aclService.hasAny(['invoicing']);
|
|
}
|
|
|
|
loadData() {
|
|
const filter = {
|
|
include: [
|
|
{
|
|
relation: 'company',
|
|
scope: {
|
|
fields: ['id', 'code']
|
|
}
|
|
}, {
|
|
relation: 'client',
|
|
scope: {
|
|
fields: ['id', 'name', 'email']
|
|
}
|
|
}
|
|
]
|
|
};
|
|
return this.$http.get(`InvoiceOuts/${this.invoiceOut.id}`, {filter})
|
|
.then(res => this.invoiceOut = res.data);
|
|
}
|
|
reload() {
|
|
return this.loadData().then(() => {
|
|
if (this.parentReload)
|
|
this.parentReload();
|
|
});
|
|
}
|
|
|
|
cardReload() {
|
|
// Prevents error when not defined
|
|
}
|
|
|
|
deleteInvoiceOut() {
|
|
return this.$http.post(`InvoiceOuts/${this.invoiceOut.id}/delete`)
|
|
.then(() => {
|
|
const isInsideInvoiceOut = this.$state.current.name.startsWith('invoiceOut');
|
|
if (isInsideInvoiceOut)
|
|
this.$state.go('invoiceOut.index');
|
|
else
|
|
this.$state.reload();
|
|
})
|
|
.then(() => this.vnApp.showSuccess(this.$t('InvoiceOut deleted')));
|
|
}
|
|
|
|
bookInvoiceOut() {
|
|
return this.$http.post(`InvoiceOuts/${this.invoiceOut.ref}/book`)
|
|
.then(() => this.$state.reload())
|
|
.then(() => this.vnApp.showSuccess(this.$t('InvoiceOut booked')));
|
|
}
|
|
|
|
createPdfInvoice() {
|
|
return this.$http.post(`InvoiceOuts/${this.id}/createPdf`)
|
|
.then(() => this.reload())
|
|
.then(() => {
|
|
const snackbarMessage = this.$t(
|
|
`The invoice PDF document has been regenerated`);
|
|
this.vnApp.showSuccess(snackbarMessage);
|
|
});
|
|
}
|
|
|
|
showCsvInvoice() {
|
|
this.vnReport.showCsv('invoice', {
|
|
recipientId: this.invoiceOut.client.id,
|
|
invoiceId: this.id
|
|
});
|
|
}
|
|
|
|
sendPdfInvoice($data) {
|
|
if (!$data.email)
|
|
return this.vnApp.showError(this.$t(`The email can't be empty`));
|
|
|
|
return this.vnEmail.send('invoice', {
|
|
recipientId: this.invoiceOut.client.id,
|
|
recipient: $data.email,
|
|
invoiceId: this.id
|
|
});
|
|
}
|
|
|
|
sendCsvInvoice($data) {
|
|
if (!$data.email)
|
|
return this.vnApp.showError(this.$t(`The email can't be empty`));
|
|
|
|
return this.vnEmail.sendCsv('invoice', {
|
|
recipientId: this.invoiceOut.client.id,
|
|
recipient: $data.email,
|
|
invoiceId: this.id
|
|
});
|
|
}
|
|
|
|
showExportationLetter() {
|
|
this.vnReport.show('exportation', {
|
|
recipientId: this.invoiceOut.client.id,
|
|
invoiceId: this.id
|
|
});
|
|
}
|
|
|
|
refundInvoiceOut() {
|
|
let filter = {
|
|
where: {refFk: this.invoiceOut.ref}
|
|
};
|
|
this.$http.get('Tickets', {filter})
|
|
.then(res => {
|
|
this.tickets = res.data;
|
|
this.ticketsIds = [];
|
|
for (let ticket of this.tickets)
|
|
this.ticketsIds.push(ticket.id);
|
|
|
|
filter = {
|
|
where: {ticketFk: {inq: this.ticketsIds}}
|
|
};
|
|
this.$http.get('Sales', {filter})
|
|
.then(res => {
|
|
this.sales = res.data;
|
|
this.$http.get('TicketServices', {filter})
|
|
.then(res => {
|
|
this.services = res.data;
|
|
const params = {
|
|
sales: this.sales,
|
|
services: this.services
|
|
};
|
|
const query = `Sales/refund`;
|
|
return this.$http.post(query, params).then(res => {
|
|
this.$state.go('ticket.card.sale', {id: res.data});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
Controller.$inject = ['$element', '$scope', 'vnReport', 'vnEmail'];
|
|
|
|
ngModule.vnComponent('vnInvoiceOutDescriptorMenu', {
|
|
template: require('./index.html'),
|
|
controller: Controller,
|
|
bindings: {
|
|
invoiceOut: '<',
|
|
parentReload: '&'
|
|
}
|
|
});
|