salix/modules/ticket/front/descriptor/index.js

359 lines
10 KiB
JavaScript
Raw Normal View History

import ngModule from '../module';
2020-04-25 09:50:04 +00:00
import Descriptor from 'salix/components/descriptor';
2020-04-25 09:50:04 +00:00
class Controller extends Descriptor {
constructor($element, $, $httpParamSerializer) {
2019-11-12 07:51:50 +00:00
super($element, $);
this.$httpParamSerializer = $httpParamSerializer;
2018-11-08 14:20:42 +00:00
this.moreOptions = [
2020-02-13 07:31:29 +00:00
{
name: 'Add turn',
2020-03-30 15:30:03 +00:00
callback: this.showAddTurnDialog,
acl: 'buyer'
}, {
name: 'Show Delivery Note',
callback: this.showDeliveryNote
}, {
name: 'Send Delivery Note',
callback: this.confirmDeliveryNote
}, {
name: 'Delete ticket',
callback: this.showDeleteTicketDialog
}, {
name: 'Change shipped hour',
callback: this.showChangeShipped
}, {
name: 'SMS Pending payment',
callback: this.sendPaymentSms
}, {
name: 'SMS Minimum import',
callback: this.sendImportSms
}, {
2019-04-26 06:52:43 +00:00
name: 'Add stowaway',
callback: this.showAddStowaway,
show: () => this.canShowStowaway
2020-03-30 15:30:03 +00:00
}, {
2019-12-17 12:25:30 +00:00
name: 'Delete stowaway',
2019-12-17 07:38:36 +00:00
callback: this.showDeleteStowaway,
show: () => this.shouldShowDeleteStowaway()
2020-03-30 15:30:03 +00:00
}, {
2019-04-26 06:52:43 +00:00
name: 'Make invoice',
callback: this.showMakeInvoiceDialog,
2020-03-30 15:30:03 +00:00
show: () => !this.hasInvoice(),
acl: 'invoicing'
}, {
2019-04-26 06:52:43 +00:00
name: 'Regenerate invoice',
callback: this.showRegenerateInvoiceDialog,
2020-03-30 15:30:03 +00:00
show: () => this.hasInvoice(),
acl: 'invoicing'
}, {
2019-11-20 05:53:37 +00:00
name: 'Recalculate components',
callback: this.comfirmRecalculateComponents,
show: () => this.isEditable
},
2018-11-08 14:20:42 +00:00
];
}
2019-12-17 07:38:36 +00:00
get ticket() {
return this._ticket;
}
set ticket(value) {
this._ticket = value;
if (!value) return;
if (this.$params.sendSMS)
this.showSMSDialog();
this.canStowaway();
let links = {
btnOne: {
icon: 'person',
state: `client.card.summary({id: ${value.clientFk}})`,
tooltip: 'Client card'
}};
if (value.stowaway) {
links.btnTwo = {
icon: 'icon-stowaway',
state: `ticket.card.summary({id: ${value.stowaway.shipFk}})`,
tooltip: 'Ship stowaways'
};
}
if (value.ship) {
links.btnThree = {
icon: 'icon-stowaway',
state: `ticket.card.summary({id: ${value.ship.id}})`,
tooltip: 'Stowaway'
};
}
this._quicklinks = links;
}
2019-01-21 07:45:02 +00:00
showChangeShipped() {
if (!this.isEditable) {
2020-03-30 15:30:03 +00:00
this.vnApp.showError(this.$t(`This ticket can't be modified`));
2019-01-21 07:45:02 +00:00
return;
}
2020-03-30 15:30:03 +00:00
this.newShipped = this.ticket.shipped;
2019-11-12 07:51:50 +00:00
this.$.changeShippedDialog.show();
2019-01-21 07:45:02 +00:00
}
2020-03-30 15:30:03 +00:00
changeShipped() {
let data = {shipped: this.newShipped};
let query = `Tickets/${this.ticket.id}/updateEditableTicket`;
this.$http.post(query, data)
.then(() => this.cardReload())
.then(() => this.vnApp.showSuccess(this.$t('Shipped hour updated')));
2019-01-21 07:45:02 +00:00
}
isTicketModule() {
let path = this.$state.getCurrentPath();
const isTicket = path[1].state.name === 'ticket';
if (isTicket)
return true;
return false;
}
2018-11-08 14:20:42 +00:00
onMoreChange(callback) {
callback.call(this);
}
2019-01-18 12:36:13 +00:00
goToTicket(ticketID) {
this.$state.go('ticket.card.sale', {id: ticketID}, {absolute: true});
2019-01-18 12:36:13 +00:00
}
onMoreOpen() {
2019-04-15 12:34:33 +00:00
let options = this.moreOptions.filter(option => {
2019-04-15 12:37:12 +00:00
const hasShowProperty = Object.hasOwnProperty.call(option, 'show');
const hasAclProperty = Object.hasOwnProperty.call(option, 'acl');
const hasAcl = !hasAclProperty || (hasAclProperty && this.aclService.hasAny([option.acl]));
2019-04-12 11:54:31 +00:00
2019-04-15 12:37:12 +00:00
return (!hasShowProperty || option.show === true ||
typeof option.show === 'function' && option.show()) && hasAcl;
2019-01-18 12:36:13 +00:00
});
2019-11-12 07:51:50 +00:00
this.$.moreButton.data = options;
2019-01-18 12:36:13 +00:00
}
2018-11-08 14:20:42 +00:00
get isEditable() {
try {
return !this.ticket.tracking.state.alertLevel;
} catch (e) {}
return true;
}
showAddTurnDialog() {
2019-11-12 07:51:50 +00:00
this.$.addTurn.show();
2018-11-08 14:20:42 +00:00
}
addTurn(day) {
let params = {
ticketFk: this.ticket.id,
weekDay: day,
agencyModeFk: this.ticket.agencyModeFk};
this.$http.patch(`TicketWeeklies`, params).then(() => {
2019-11-12 07:51:50 +00:00
this.$.addTurn.hide();
2020-03-30 15:30:03 +00:00
this.vnApp.showSuccess(this.$t('Data saved!'));
2018-11-08 14:20:42 +00:00
});
}
showDeleteTicketDialog() {
if (!this.isEditable) {
2020-03-30 15:30:03 +00:00
this.vnApp.showError(this.$t('This ticket cant be deleted'));
2018-11-08 14:20:42 +00:00
return;
}
2019-11-12 07:51:50 +00:00
this.$.deleteConfirmation.show();
2018-11-08 14:20:42 +00:00
}
deleteTicket(response) {
2019-10-30 15:57:14 +00:00
if (response === 'accept') {
const query = `Tickets/${this.ticket.id}/setDeleted`;
this.$http.post(query).then(() => {
2018-11-08 14:20:42 +00:00
this.$state.go('ticket.index');
2020-03-30 15:30:03 +00:00
this.vnApp.showSuccess(this.$t('Ticket deleted'));
2018-11-08 14:20:42 +00:00
});
}
}
2019-12-17 07:38:36 +00:00
canStowaway() {
if (!this.isTicketModule()) return;
2019-01-18 12:36:13 +00:00
2019-12-17 07:38:36 +00:00
this.$http.get(`Tickets/${this.ticket.id}/canHaveStowaway`).then(response => {
if (response.data === true)
return this.canShowStowaway = true;
2019-01-18 12:36:13 +00:00
2019-12-17 07:38:36 +00:00
return this.canShowStowaway = false;
});
}
2019-12-17 07:38:36 +00:00
shouldShowDeleteStowaway() {
if (!this._ticket || !this.isTicketModule())
return false;
2019-01-21 07:45:02 +00:00
2019-12-17 07:38:36 +00:00
return this._ticket.stowaway || this._ticket.ship;
}
2019-01-21 07:45:02 +00:00
2019-12-17 07:38:36 +00:00
showAddStowaway() {
this.$.addStowaway.show();
2018-09-04 09:49:00 +00:00
}
2019-12-17 07:38:36 +00:00
showDeleteStowaway() {
this.$.deleteStowaway.show();
2018-09-04 09:49:00 +00:00
}
2019-12-17 07:38:36 +00:00
deleteStowaway() {
const query = `Tickets/${this.ticket.id}/deleteStowaway`;
this.$http.post(query).then(res => {
2020-03-30 15:30:03 +00:00
this.vnApp.showSuccess(this.$t('Data saved!'));
2019-12-17 07:38:36 +00:00
this.cardReload();
});
2018-09-04 09:49:00 +00:00
}
showDeliveryNote() {
const params = {
clientId: this.ticket.client.id,
ticketId: this.ticket.id,
authorization: this.vnToken.token
};
const serializedParams = this.$httpParamSerializer(params);
let url = `api/report/delivery-note?${serializedParams}`;
window.open(url);
}
2019-11-06 08:32:54 +00:00
sendDeliveryNote() {
const params = {
recipient: this.ticket.client.email,
clientId: this.ticket.client.id,
ticketId: this.ticket.id
};
2020-03-18 07:35:59 +00:00
this.$http.get(`email/delivery-note`, {params}).then(
2020-03-30 15:30:03 +00:00
() => this.vnApp.showMessage(this.$t('Notification sent!'))
2019-11-06 08:32:54 +00:00
);
}
2020-03-10 14:01:33 +00:00
sendImportSms() {
const params = {
ticketId: this.ticket.id,
created: this.ticket.created
};
2020-03-30 15:30:03 +00:00
const message = this.$params.message || this.$t('Minimum is needed', params);
2020-03-10 14:01:33 +00:00
this.newSMS = {message};
this.showSMSDialog();
}
sendPaymentSms() {
2020-03-30 15:30:03 +00:00
const message = this.$params.message || this.$t('Make a payment');
2020-03-10 14:01:33 +00:00
this.newSMS = {message};
this.showSMSDialog();
}
showSMSDialog() {
const address = this.ticket.address;
2020-02-21 07:37:37 +00:00
const client = this.ticket.client;
const phone = this.$params.phone || address.mobile || address.phone ||
client.mobile || client.phone;
2020-03-10 14:01:33 +00:00
this.newSMS.destinationFk = this.ticket.clientFk;
this.newSMS.destination = phone;
2019-11-12 07:51:50 +00:00
this.$.sms.open();
}
2019-04-12 11:54:31 +00:00
/**
* Shows an invoice confirmation
*/
2019-04-26 06:52:43 +00:00
showMakeInvoiceDialog() {
2019-11-12 07:51:50 +00:00
this.$.makeInvoiceConfirmation.show();
2019-04-12 11:54:31 +00:00
}
/**
* Makes an invoice
* from current ticket
*
* @param {String} response - Response result
*/
2019-04-26 06:52:43 +00:00
makeInvoice(response) {
2019-10-30 15:57:14 +00:00
if (response === 'accept') {
const query = `Tickets/${this.ticket.id}/makeInvoice`;
2019-04-12 11:54:31 +00:00
this.$http.post(query).then(() => {
2020-03-30 15:30:03 +00:00
this.vnApp.showSuccess(this.$t('Ticket invoiced'));
2019-04-12 11:54:31 +00:00
this.$state.reload();
});
}
}
2019-04-26 06:52:43 +00:00
/**
* Shows an invoice confirmation
*/
showRegenerateInvoiceDialog() {
2019-11-12 07:51:50 +00:00
this.$.regenerateInvoiceConfirmation.show();
2019-04-26 06:52:43 +00:00
}
/**
* Sends an invoice to a regeneration queue
* for the current ticket
*
* @param {String} response - Response result
*/
regenerateInvoice(response) {
2019-10-30 15:57:14 +00:00
if (response === 'accept') {
2019-04-26 06:52:43 +00:00
const invoiceId = this.ticket.invoiceOut.id;
const query = `InvoiceOuts/${invoiceId}/regenerate`;
2019-04-26 06:52:43 +00:00
this.$http.post(query).then(() => {
2020-03-30 15:30:03 +00:00
const snackbarMessage = this.$t(
2019-04-26 06:52:43 +00:00
`Invoice sent for a regeneration, will be available in a few minutes`);
this.vnApp.showSuccess(snackbarMessage);
});
}
}
/**
* Returns if the current ticket
* is already invoiced
* @return {Boolean} - True if invoiced
*/
hasInvoice() {
return this.ticket.refFk !== null;
}
2019-09-06 09:06:44 +00:00
2019-11-20 05:53:37 +00:00
/**
* Shows a delivery-note send confirmation
*/
2019-09-06 09:06:44 +00:00
confirmDeliveryNote() {
2019-11-12 07:51:50 +00:00
this.$.confirmDeliveryNote.show();
2019-09-06 09:06:44 +00:00
}
2019-11-20 05:53:37 +00:00
/**
* Shows an invoice confirmation
*/
comfirmRecalculateComponents() {
this.$.recalculateComponentsConfirmation.show();
}
recalculateComponents() {
const query = `Tickets/${this.ticket.id}/recalculateComponents`;
this.$http.post(query).then(res => {
2020-03-30 15:30:03 +00:00
this.vnApp.showSuccess(this.$t('Data saved!'));
2019-11-20 05:53:37 +00:00
});
}
}
Controller.$inject = ['$element', '$scope', '$httpParamSerializer'];
2020-04-25 09:50:04 +00:00
ngModule.vnComponent('vnTicketDescriptor', {
template: require('./index.html'),
2020-04-25 09:50:04 +00:00
controller: Controller,
bindings: {
ticket: '<',
cardReload: '&'
2020-04-25 09:50:04 +00:00
}
});