178 lines
5.5 KiB
JavaScript
178 lines
5.5 KiB
JavaScript
import ngModule from '../module';
|
|
import './style.scss';
|
|
|
|
class Controller {
|
|
constructor($stateParams, $scope, $http, $translate, vnApp) {
|
|
this.$stateParams = $stateParams;
|
|
this.$ = $scope;
|
|
this.$http = $http;
|
|
this.$translate = $translate;
|
|
this.vnApp = vnApp;
|
|
this.filter = {
|
|
where: {claimFk: $stateParams.id},
|
|
include: [
|
|
{relation: 'sale',
|
|
scope: {
|
|
fields: ['concept', 'ticketFk', 'price', 'quantity', 'discount', 'itemFk'],
|
|
include: {
|
|
relation: 'ticket'
|
|
}
|
|
}
|
|
},
|
|
{relation: 'claimBeggining'}
|
|
]
|
|
};
|
|
this.resolvedState = 3;
|
|
}
|
|
|
|
openAddSalesDialog() {
|
|
this.getClaimedSales();
|
|
this.$.addSales.show();
|
|
}
|
|
|
|
getClaimedSales() {
|
|
let json = encodeURIComponent(JSON.stringify(this.claim.id));
|
|
|
|
let query = `/claim/api/ClaimBeginnings/${json}`;
|
|
this.$http.get(query).then(res => {
|
|
if (res.data)
|
|
this.claimedSales = res.data;
|
|
});
|
|
}
|
|
|
|
addClaimedSale(saleFk) {
|
|
let saleToAdd = {saleFk: saleFk, claimFk: this.claim.id, workerFk: this.claim.workerFk, claimDestinationFk: 1};
|
|
let query = `claim/api/ClaimEnds/`;
|
|
this.$http.post(query, saleToAdd).then(() => {
|
|
this.$.model.refresh();
|
|
this.$.addSales.hide();
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
});
|
|
}
|
|
|
|
deleteClaimedSale(id) {
|
|
let json = encodeURIComponent(JSON.stringify(id));
|
|
let query = `claim/api/ClaimEnds/${json}`;
|
|
this.$http.delete(query).then(() => {
|
|
this.$.model.refresh();
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
});
|
|
}
|
|
|
|
importToNewRefundTicket() {
|
|
let query = `claim/api/ClaimBeginnings/${this.$stateParams.id}/importToNewRefundTicket`;
|
|
this.$http.post(query).then(() => {
|
|
this.$.model.refresh();
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
});
|
|
}
|
|
|
|
showTicketDescriptor(event, ticketFk) {
|
|
this.$.ticketDescriptor.ticketFk = ticketFk;
|
|
this.$.ticketDescriptor.parent = event.target;
|
|
this.$.ticketDescriptor.show();
|
|
|
|
event.preventDefault();
|
|
}
|
|
|
|
focusLastInput() {
|
|
let inputs = document.querySelectorAll('#claimDestinationFk');
|
|
inputs[inputs.length - 1].querySelector('input').focus();
|
|
this.calculateTotals();
|
|
}
|
|
|
|
setClaimDestination(id, claimDestinationFk) {
|
|
if (claimDestinationFk) {
|
|
let params = {id: id, claimDestinationFk: claimDestinationFk};
|
|
let query = `claim/api/ClaimEnds/`;
|
|
this.$http.patch(query, params).then(() => {
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
});
|
|
}
|
|
}
|
|
|
|
calculateTotals() {
|
|
this.claimedTotal = 0;
|
|
this.salesClaimed.forEach(sale => {
|
|
this.claimedTotal += (sale.sale.quantity * sale.sale.price) - ((sale.sale.discount * (sale.sale.quantity * sale.sale.price)) / 100);
|
|
});
|
|
}
|
|
|
|
showLastTickets(event) {
|
|
let pastWeek = new Date();
|
|
pastWeek.setDate(-7);
|
|
|
|
let filter = {
|
|
include: [
|
|
{relation: 'agencyMode', fields: ['name']},
|
|
{relation: 'warehouse', fields: ['name']}
|
|
],
|
|
where: {
|
|
created: {gt: pastWeek},
|
|
clientFk: this.claim.clientFk
|
|
}
|
|
};
|
|
this.$.lastTicketsModel.filter = filter;
|
|
this.$.lastTicketsModel.refresh();
|
|
this.$.lastTicketsPopover.parent = event.target;
|
|
this.$.lastTicketsPopover.show();
|
|
}
|
|
|
|
importTicketLines(ticketFk) {
|
|
let data = {claimFk: this.$stateParams.id, ticketFk: ticketFk};
|
|
|
|
let query = `/claim/api/ClaimEnds/importTicketSales`;
|
|
this.$http.post(query, data).then(() => {
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
this.$.lastTicketsPopover.hide();
|
|
this.$.model.refresh();
|
|
});
|
|
}
|
|
|
|
regularize() {
|
|
let data = {claimFk: this.$stateParams.id};
|
|
let query = `/claim/api/Claims/regularizeClaim`;
|
|
this.$http.post(query, data).then(() => {
|
|
this.card.reload();
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
});
|
|
}
|
|
|
|
// Item Descriptor
|
|
showDescriptor(event, itemFk) {
|
|
this.quicklinks = {
|
|
btnThree: {
|
|
icon: 'icon-transaction',
|
|
state: `item.card.diary({
|
|
id: ${itemFk}
|
|
})`,
|
|
tooltip: 'Item diary'
|
|
}
|
|
};
|
|
this.$.descriptor.itemFk = itemFk;
|
|
this.$.descriptor.parent = event.target;
|
|
this.$.descriptor.show();
|
|
}
|
|
|
|
saveResponsibility(value) {
|
|
let query = `/api/Claims/${this.$stateParams.id}/updateClaim`;
|
|
|
|
this.$http.post(query, {responsibility: value}).then(() => {
|
|
this.vnApp.showSuccess(this.$translate.instant('Data saved!'));
|
|
});
|
|
}
|
|
}
|
|
|
|
Controller.$inject = ['$stateParams', '$scope', '$http', '$translate', 'vnApp'];
|
|
|
|
ngModule.component('vnClaimAction', {
|
|
template: require('./index.html'),
|
|
controller: Controller,
|
|
bindings: {
|
|
claim: '<'
|
|
},
|
|
require: {
|
|
card: '^vnClaimCard'
|
|
}
|
|
});
|