import ngModule from '../module'; import Summary from 'salix/components/summary'; import './style.scss'; class Controller extends Summary { get ticket() { return this._ticket; } set ticket(value) { this._ticket = value; if (value) this.loadData(); } get formattedAddress() { if (!this.summary) return ''; let address = this.summary.address; let province = address.province ? `(${address.province.name})` : ''; return `${address.street} - ${address.city} ${province}`; } loadData() { return this.$http.get(`Tickets/${this.ticket.id}/summary`).then(res => { if (res && res.data) this.summary = res.data; }); } reload() { this.loadData() .then(() => { if (this.card) this.card.reload(); // Refresh index model if (this.model) this.model.refresh(); }); } get isEditable() { try { return !this.ticket.ticketState.state.alertLevel; } catch (e) {} return true; } showInvoiceOutDescriptor(event, refFk) { if (!refFk) return; this.$.invoiceOutDescriptor.show(event.target, this.summary.invoiceOut.id); } setOkState() { let params = {}; if (this.$params.id) params = {ticketFk: this.$params.id}; if (!this.$params.id) params = {ticketFk: this.ticket.id}; params.code = 'OK'; this.$http.post(`TicketTrackings/changeState`, params) .then(() => this.reload()) .then(() => { this.vnApp.showSuccess(this.$t('Data saved!')); }); } getRequestState(state) { switch (state) { case null: return 'New'; case false: return 'Denied'; case true: return 'Acepted'; } } } ngModule.vnComponent('vnTicketSummary', { template: require('./index.html'), controller: Controller, bindings: { ticket: '<', model: '