95 lines
2.7 KiB
JavaScript
95 lines
2.7 KiB
JavaScript
import ngModule from '../module';
|
|
import Section from 'salix/components/section';
|
|
import './style.scss';
|
|
|
|
class Controller extends Section {
|
|
constructor($element, $) {
|
|
super($element, $);
|
|
this.filter = {
|
|
include: [
|
|
{
|
|
relation: 'item'
|
|
},
|
|
{
|
|
relation: 'saleTracking',
|
|
scope: {
|
|
fields: ['isChecked']
|
|
}
|
|
},
|
|
{
|
|
relation: 'saleGroupDetail',
|
|
scope: {
|
|
fields: ['saleGroupFk'],
|
|
include: {
|
|
relation: 'saleGroup',
|
|
scope: {
|
|
fields: ['parkingFk'],
|
|
include: {
|
|
relation: 'parking',
|
|
scope: {
|
|
fields: ['code']
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
]
|
|
};
|
|
}
|
|
|
|
get sales() {
|
|
return this._sales;
|
|
}
|
|
|
|
set sales(value) {
|
|
this._sales = value;
|
|
if (value) {
|
|
const query = `Sales/${this.$params.id}/salePreparingList`;
|
|
this.$http.get(query)
|
|
.then(res => {
|
|
this.salePreparingList = res.data;
|
|
for (const salePreparing of this.salePreparingList) {
|
|
for (const sale of this.sales) {
|
|
if (salePreparing.saleFk == sale.id)
|
|
sale.preparingList = salePreparing;
|
|
}
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
showItemDescriptor(event, sale) {
|
|
this.quicklinks = {
|
|
btnThree: {
|
|
icon: 'icon-transaction',
|
|
state: `item.card.diary({
|
|
id: ${sale.item.id},
|
|
warehouseFk: ${this.ticket.warehouseFk},
|
|
lineFk: ${sale.id}
|
|
})`,
|
|
tooltip: 'Item diary'
|
|
}
|
|
};
|
|
this.$.itemDescriptor.show(event.target, sale.item.id);
|
|
}
|
|
|
|
showSaleTracking(sale) {
|
|
this.saleId = sale.id;
|
|
this.$.saleTracking.show();
|
|
}
|
|
|
|
showItemShelvingSale(sale) {
|
|
this.saleId = sale.id;
|
|
this.$.itemShelvingSale.show();
|
|
}
|
|
}
|
|
|
|
ngModule.vnComponent('vnTicketSaleTracking', {
|
|
template: require('./index.html'),
|
|
controller: Controller,
|
|
bindings: {
|
|
ticket: '<'
|
|
}
|
|
});
|