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

80 lines
1.7 KiB
JavaScript
Raw Normal View History

import ngModule from '../module';
2018-07-17 06:44:31 +00:00
class Controller {
constructor($scope, $http, $stateParams) {
this.$scope = $scope;
this.$http = $http;
2018-07-17 06:44:31 +00:00
this.$stateParams = $stateParams;
this.filter = {
include: [{
2018-11-06 09:49:38 +00:00
relation: 'item'
2018-07-17 06:44:31 +00:00
}]
};
this.ticketVolumes = [];
}
2019-03-26 08:33:54 +00:00
get sales() {
return this._sales;
}
set sales(value) {
this._sales = value;
if (value) this.applyVolumes();
}
get volumes() {
return this._volumes;
}
set volumes(value) {
this._volumes = value;
if (value) this.applyVolumes();
}
applyVolumes() {
if (!this.sales || !this.volumes) return;
this.sales.forEach(sale => {
this.volumes.forEach(volume => {
if (sale.id === volume.saleFk)
sale.volume = volume;
2018-11-06 09:49:38 +00:00
});
2019-03-26 08:33:54 +00:00
});
}
2018-05-29 12:33:29 +00:00
showDescriptor(event, itemFk) {
2018-09-04 09:49:00 +00:00
this.quicklinks = {
btnThree: {
icon: 'icon-transaction',
state: `item.card.diary({
id: ${itemFk},
warehouseFk: ${this.ticket.warehouseFk},
ticketFk: ${this.ticket.id}
2018-09-04 09:49:00 +00:00
})`,
tooltip: 'Item diary'
}
};
2018-05-29 12:33:29 +00:00
this.$scope.descriptor.itemFk = itemFk;
this.$scope.descriptor.parent = event.target;
this.$scope.descriptor.show();
}
onDescriptorLoad() {
this.$scope.popover.relocate();
}
}
2018-07-17 06:44:31 +00:00
Controller.$inject = ['$scope', '$http', '$stateParams'];
ngModule.component('vnTicketVolume', {
template: require('./index.html'),
controller: Controller,
bindings: {
ticket: '<'
}
});