2020-11-09 13:52:25 +00:00
|
|
|
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 ticketId() {
|
|
|
|
return this._ticketId;
|
|
|
|
}
|
|
|
|
|
|
|
|
set ticketId(value) {
|
|
|
|
this._ticketId = value;
|
|
|
|
this.id = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
get id() {
|
|
|
|
return this._id;
|
|
|
|
}
|
|
|
|
|
|
|
|
set id(value) {
|
|
|
|
this._id = value;
|
|
|
|
|
2020-11-10 09:38:25 +00:00
|
|
|
if (!value) return;
|
|
|
|
|
|
|
|
this.loadData().then(() => {
|
2021-05-03 10:09:12 +00:00
|
|
|
if (this.$params.sendSMS) {
|
|
|
|
this.showSMSDialog({
|
|
|
|
message: this.$params.message
|
|
|
|
});
|
|
|
|
}
|
2020-11-10 09:38:25 +00:00
|
|
|
});
|
2020-11-09 13:52:25 +00:00
|
|
|
}
|
|
|
|
|
2021-10-04 08:19:53 +00:00
|
|
|
get isInvoiced() {
|
|
|
|
return this.ticket.refFk !== null;
|
|
|
|
}
|
|
|
|
|
|
|
|
get isTicketModule() {
|
|
|
|
return this.$state.getCurrentPath()[1].state.name === 'ticket';
|
|
|
|
}
|
|
|
|
|
|
|
|
get hasInvoicing() {
|
|
|
|
return this.aclService.hasAny(['invoicing']);
|
|
|
|
}
|
|
|
|
|
2020-11-09 13:52:25 +00:00
|
|
|
loadData() {
|
|
|
|
const filter = {
|
|
|
|
include: [{
|
|
|
|
relation: 'address',
|
2022-07-01 07:15:07 +00:00
|
|
|
},
|
|
|
|
{
|
2020-11-09 13:52:25 +00:00
|
|
|
relation: 'client',
|
|
|
|
scope: {
|
|
|
|
fields: [
|
|
|
|
'salesPersonFk',
|
|
|
|
'name',
|
|
|
|
'isActive',
|
|
|
|
'isFreezed',
|
|
|
|
'isTaxDataChecked',
|
|
|
|
'credit',
|
|
|
|
'email',
|
|
|
|
'phone',
|
|
|
|
'mobile'
|
|
|
|
],
|
|
|
|
include: {
|
|
|
|
relation: 'salesPersonUser',
|
|
|
|
scope: {
|
|
|
|
fields: ['id', 'name']
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2022-07-01 07:15:07 +00:00
|
|
|
{
|
|
|
|
relation: 'invoiceOut'
|
|
|
|
}]
|
2020-11-09 13:52:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
return this.$http.get(`Tickets/${this.ticketId}`, {filter})
|
|
|
|
.then(res => this.ticket = res.data)
|
|
|
|
.then(() => {
|
|
|
|
this.isTicketEditable();
|
2022-02-21 07:48:53 +00:00
|
|
|
this.hasDocuware();
|
2020-11-09 13:52:25 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
reload() {
|
2020-11-10 09:38:25 +00:00
|
|
|
return this.loadData().then(() => {
|
|
|
|
if (this.parentReload)
|
|
|
|
this.parentReload();
|
|
|
|
});
|
2020-11-09 13:52:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
isTicketEditable() {
|
|
|
|
if (!this.ticket) return;
|
|
|
|
|
|
|
|
this.$http.get(`Tickets/${this.id}/isEditable`).then(res => {
|
|
|
|
this.isEditable = res.data;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
addTurn(day) {
|
|
|
|
const params = {
|
|
|
|
ticketFk: this.id,
|
|
|
|
weekDay: day,
|
|
|
|
agencyModeFk: this.ticket.agencyModeFk
|
|
|
|
};
|
|
|
|
return this.$http.patch(`TicketWeeklies`, params)
|
|
|
|
.then(() => {
|
|
|
|
this.$.addTurn.hide();
|
|
|
|
this.vnApp.showSuccess(this.$t('Data saved!'));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-03-22 06:38:14 +00:00
|
|
|
showPdfDeliveryNote(type) {
|
2020-11-09 13:52:25 +00:00
|
|
|
this.vnReport.show('delivery-note', {
|
|
|
|
recipientId: this.ticket.client.id,
|
|
|
|
ticketId: this.id,
|
2022-03-22 06:38:14 +00:00
|
|
|
type: type
|
2020-11-09 13:52:25 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-02-16 13:57:47 +00:00
|
|
|
hasDocuware() {
|
2022-02-21 07:48:53 +00:00
|
|
|
const params = {
|
|
|
|
fileCabinet: 'deliveryClient',
|
|
|
|
dialog: 'findTicket'
|
|
|
|
};
|
|
|
|
this.$http.post(`Docuwares/${this.id}/checkFile`, params)
|
2022-02-28 12:37:44 +00:00
|
|
|
.then(res => this.hasDocuwareFile = res.data);
|
2022-02-16 13:57:47 +00:00
|
|
|
}
|
|
|
|
|
2021-10-07 08:04:50 +00:00
|
|
|
showCsvDeliveryNote() {
|
|
|
|
this.vnReport.showCsv('delivery-note', {
|
2021-10-01 10:41:31 +00:00
|
|
|
recipientId: this.ticket.client.id,
|
|
|
|
ticketId: this.id,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-10-07 08:04:50 +00:00
|
|
|
sendPdfDeliveryNote($data) {
|
2020-11-09 13:52:25 +00:00
|
|
|
return this.vnEmail.send('delivery-note', {
|
|
|
|
recipientId: this.ticket.client.id,
|
2021-10-01 10:41:31 +00:00
|
|
|
recipient: $data.email,
|
|
|
|
ticketId: this.id
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-10-07 08:04:50 +00:00
|
|
|
sendCsvDeliveryNote($data) {
|
|
|
|
return this.vnEmail.sendCsv('delivery-note', {
|
2021-10-01 10:41:31 +00:00
|
|
|
recipientId: this.ticket.client.id,
|
|
|
|
recipient: $data.email,
|
2020-11-09 13:52:25 +00:00
|
|
|
ticketId: this.id
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
deleteTicket() {
|
|
|
|
return this.$http.post(`Tickets/${this.id}/setDeleted`)
|
|
|
|
.then(() => this.reload())
|
|
|
|
.then(() => {
|
2022-01-20 10:06:15 +00:00
|
|
|
const isInsideTicket = this.$state.current.name.startsWith('ticket');
|
|
|
|
if (isInsideTicket)
|
|
|
|
this.$state.go('ticket.index');
|
|
|
|
|
2020-11-09 13:52:25 +00:00
|
|
|
this.vnApp.showSuccess(this.$t('Ticket deleted. You can undo this action within the first hour'));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
get canRestoreTicket() {
|
|
|
|
const isDeleted = this.ticket.isDeleted;
|
|
|
|
const now = new Date();
|
|
|
|
const maxDate = new Date(this.ticket.updated);
|
|
|
|
maxDate.setHours(maxDate.getHours() + 1);
|
|
|
|
|
|
|
|
return isDeleted && (now <= maxDate);
|
|
|
|
}
|
|
|
|
|
|
|
|
restoreTicket() {
|
|
|
|
return this.$http.post(`Tickets/${this.id}/restore`)
|
|
|
|
.then(() => this.reload())
|
|
|
|
.then(() => this.vnApp.showSuccess(this.$t('Data saved!')));
|
|
|
|
}
|
|
|
|
|
|
|
|
showChangeShipped() {
|
|
|
|
this.newShipped = this.ticket.shipped;
|
|
|
|
this.$.changeShippedDialog.show();
|
|
|
|
}
|
|
|
|
|
|
|
|
changeShipped() {
|
|
|
|
const data = {shipped: this.newShipped};
|
|
|
|
return this.$http.post(`Tickets/${this.id}/updateEditableTicket`, data)
|
|
|
|
.then(() => this.reload())
|
|
|
|
.then(() => this.vnApp.showSuccess(this.$t('Shipped hour updated')));
|
|
|
|
}
|
|
|
|
|
|
|
|
sendImportSms() {
|
|
|
|
const params = {
|
|
|
|
ticketId: this.id,
|
|
|
|
created: this.ticket.updated
|
|
|
|
};
|
|
|
|
this.showSMSDialog({
|
2021-04-08 11:39:11 +00:00
|
|
|
message: this.$t('Minimum is needed', params)
|
2020-11-09 13:52:25 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
sendPaymentSms() {
|
|
|
|
this.showSMSDialog({
|
2021-04-08 11:39:11 +00:00
|
|
|
message: this.$t('Make a payment')
|
2020-11-09 13:52:25 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
showSMSDialog(params) {
|
|
|
|
const address = this.ticket.address;
|
|
|
|
const client = this.ticket.client;
|
|
|
|
const phone = this.$params.phone
|
|
|
|
|| address.mobile
|
|
|
|
|| address.phone
|
|
|
|
|| client.mobile
|
|
|
|
|| client.phone;
|
|
|
|
|
|
|
|
this.newSMS = Object.assign({
|
|
|
|
ticketId: this.id,
|
|
|
|
destinationFk: this.ticket.clientFk,
|
|
|
|
destination: phone
|
|
|
|
}, params);
|
|
|
|
this.$.sms.open();
|
|
|
|
}
|
|
|
|
|
|
|
|
makeInvoice() {
|
2021-07-01 12:03:28 +00:00
|
|
|
const params = {ticketsIds: [this.id]};
|
|
|
|
return this.$http.post(`Tickets/makeInvoice`, params)
|
2020-11-09 13:52:25 +00:00
|
|
|
.then(() => this.reload())
|
|
|
|
.then(() => this.vnApp.showSuccess(this.$t('Ticket invoiced')));
|
|
|
|
}
|
|
|
|
|
2021-10-07 11:36:23 +00:00
|
|
|
createPdfInvoice() {
|
2020-11-09 13:52:25 +00:00
|
|
|
const invoiceId = this.ticket.invoiceOut.id;
|
2021-03-15 12:43:22 +00:00
|
|
|
return this.$http.post(`InvoiceOuts/${invoiceId}/createPdf`)
|
2021-10-01 12:31:42 +00:00
|
|
|
.then(() => this.reload())
|
2020-11-09 13:52:25 +00:00
|
|
|
.then(() => {
|
|
|
|
const snackbarMessage = this.$t(
|
2021-03-15 12:43:22 +00:00
|
|
|
`The invoice PDF document has been regenerated`);
|
2020-11-09 13:52:25 +00:00
|
|
|
this.vnApp.showSuccess(snackbarMessage);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
recalculateComponents() {
|
|
|
|
return this.$http.post(`Tickets/${this.id}/recalculateComponents`)
|
|
|
|
.then(() => this.reload())
|
|
|
|
.then(() => this.vnApp.showSuccess(this.$t('Data saved!')));
|
|
|
|
}
|
2022-04-04 11:26:53 +00:00
|
|
|
|
2022-05-20 10:08:12 +00:00
|
|
|
async refund() {
|
2022-04-22 09:45:14 +00:00
|
|
|
const filter = {
|
|
|
|
where: {ticketFk: this.id}
|
|
|
|
};
|
2022-05-20 10:08:12 +00:00
|
|
|
const sales = await this.$http.get('Sales', {filter});
|
|
|
|
this.sales = sales.data;
|
|
|
|
|
|
|
|
const ticketServices = await this.$http.get('TicketServices', {filter});
|
|
|
|
this.services = ticketServices.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});
|
|
|
|
});
|
2022-04-04 11:26:53 +00:00
|
|
|
}
|
2020-11-09 13:52:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Controller.$inject = ['$element', '$scope', 'vnReport', 'vnEmail'];
|
|
|
|
|
|
|
|
ngModule.vnComponent('vnTicketDescriptorMenu', {
|
|
|
|
template: require('./index.html'),
|
|
|
|
controller: Controller,
|
|
|
|
bindings: {
|
|
|
|
ticketId: '<',
|
2020-11-10 09:38:25 +00:00
|
|
|
parentReload: '&'
|
2020-11-09 13:52:25 +00:00
|
|
|
}
|
|
|
|
});
|