2018-04-04 11:56:16 +00:00
|
|
|
import ngModule from '../../module';
|
2019-02-05 10:25:47 +00:00
|
|
|
import './style.scss';
|
2018-04-04 11:56:16 +00:00
|
|
|
|
|
|
|
class Controller {
|
2018-05-22 06:14:16 +00:00
|
|
|
constructor($scope, $http, $translate, vnApp) {
|
2018-04-04 11:56:16 +00:00
|
|
|
this.$scope = $scope;
|
2018-05-16 06:13:39 +00:00
|
|
|
this.$http = $http;
|
|
|
|
this.$translate = $translate;
|
|
|
|
this.vnApp = vnApp;
|
|
|
|
}
|
|
|
|
|
2018-07-11 07:11:45 +00:00
|
|
|
$onInit() {
|
2019-07-26 09:48:01 +00:00
|
|
|
this.basicData.registerChild(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
get ticket() {
|
|
|
|
return this._ticket;
|
2018-07-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
set ticket(value) {
|
|
|
|
this._ticket = value;
|
|
|
|
|
|
|
|
if (!value || !value.id) return;
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
this.onChangeClient(value.clientFk);
|
2018-07-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
get clientId() {
|
|
|
|
if (this.ticket)
|
|
|
|
return this.ticket.clientFk;
|
|
|
|
|
|
|
|
return null;
|
2018-07-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
set clientId(value) {
|
2018-07-02 11:14:14 +00:00
|
|
|
this.ticket.clientFk = value;
|
|
|
|
this.ticket.addressFk = null;
|
2018-07-11 07:11:45 +00:00
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
this.onChangeClient(value);
|
2018-07-02 11:14:14 +00:00
|
|
|
}
|
|
|
|
|
2018-08-16 11:12:18 +00:00
|
|
|
set shipped(value) {
|
|
|
|
this.ticket.shipped = value;
|
|
|
|
this.onChangeShipped(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
get shipped() {
|
|
|
|
if (this.ticket)
|
|
|
|
return this.ticket.shipped;
|
2019-01-24 14:41:48 +00:00
|
|
|
|
|
|
|
return null;
|
2018-08-16 11:12:18 +00:00
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
get landed() {
|
|
|
|
if (this.ticket)
|
|
|
|
return this.ticket.landed;
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2018-07-24 10:14:35 +00:00
|
|
|
set landed(value) {
|
|
|
|
this.ticket.landed = value;
|
|
|
|
this.onChangeLanded(value);
|
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
get agencyModeId() {
|
2018-07-24 10:14:35 +00:00
|
|
|
if (this.ticket)
|
2019-07-26 09:48:01 +00:00
|
|
|
return this.ticket.agencyModeFk;
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
set agencyModeId(value) {
|
|
|
|
this.ticket.agencyModeFk = value;
|
|
|
|
|
|
|
|
if (value)
|
|
|
|
this.onChangeAgencyMode(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
get zoneId() {
|
|
|
|
if (this.ticket)
|
|
|
|
return this.ticket.zoneFk;
|
2019-01-24 14:41:48 +00:00
|
|
|
|
|
|
|
return null;
|
2018-07-24 10:14:35 +00:00
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
set zoneId(value) {
|
|
|
|
this.ticket.zoneFk = value;
|
|
|
|
|
|
|
|
if (value)
|
|
|
|
this.onChangeZone(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Autocompletes address on client change
|
|
|
|
*/
|
|
|
|
onChangeClient(value) {
|
|
|
|
let filter = {
|
|
|
|
include: [
|
|
|
|
{
|
|
|
|
relation: 'province',
|
|
|
|
scope: {
|
|
|
|
fields: ['name']
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
relation: 'agencyMode',
|
|
|
|
scope: {
|
|
|
|
fields: ['name']
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
filter = encodeURIComponent(JSON.stringify(filter));
|
|
|
|
|
|
|
|
let query = `/api/Clients/${value}/addresses?filter=${filter}`;
|
|
|
|
this.$http.get(query).then(res => {
|
|
|
|
if (res.data)
|
|
|
|
this.addresses = res.data;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Returns a landing date
|
|
|
|
*/
|
|
|
|
getLanded(params) {
|
|
|
|
let query = `/api/Agencies/getLanded`;
|
|
|
|
return this.$http.get(query, {params});
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Returns a shipment date
|
|
|
|
*/
|
|
|
|
getShipped(params) {
|
|
|
|
let query = `/api/Agencies/getShipped`;
|
|
|
|
return this.$http.get(query, {params});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
onChangeShipped(shipped) {
|
2019-05-30 06:41:08 +00:00
|
|
|
let params = {
|
2019-07-26 09:48:01 +00:00
|
|
|
shipped: shipped,
|
2018-08-16 11:12:18 +00:00
|
|
|
addressFk: this.ticket.addressFk,
|
|
|
|
agencyModeFk: this.ticket.agencyModeFk,
|
|
|
|
warehouseFk: this.ticket.warehouseFk
|
|
|
|
};
|
2019-05-30 06:41:08 +00:00
|
|
|
let query = `/api/Agencies/getLanded`;
|
|
|
|
this.$http.get(query, {params}).then(res => {
|
2018-08-16 11:12:18 +00:00
|
|
|
if (res.data && res.data.landed)
|
|
|
|
this.ticket.landed = res.data.landed;
|
2019-03-26 11:02:11 +00:00
|
|
|
else {
|
|
|
|
return this.vnApp.showError(
|
2019-07-26 09:48:01 +00:00
|
|
|
this.$translate.instant(`No delivery zone available for this shipping date`)
|
2019-03-26 11:02:11 +00:00
|
|
|
);
|
|
|
|
}
|
2018-08-16 11:12:18 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
onChangeLanded(landed) {
|
2019-05-30 06:41:08 +00:00
|
|
|
let params = {
|
2019-07-26 09:48:01 +00:00
|
|
|
landed: landed,
|
2018-07-24 10:14:35 +00:00
|
|
|
addressFk: this.ticket.addressFk,
|
2019-03-14 09:43:14 +00:00
|
|
|
agencyModeFk: this.ticket.agencyModeFk,
|
|
|
|
warehouseFk: this.ticket.warehouseFk
|
2018-07-24 10:14:35 +00:00
|
|
|
};
|
2019-05-30 06:41:08 +00:00
|
|
|
let query = `/api/Agencies/getShipped`;
|
|
|
|
this.$http.get(query, {params}).then(res => {
|
|
|
|
if (res.data)
|
2019-07-26 09:48:01 +00:00
|
|
|
this.ticket.shipped = res.data.shipped;
|
2019-03-26 11:02:11 +00:00
|
|
|
else {
|
|
|
|
return this.vnApp.showError(
|
2019-07-26 09:48:01 +00:00
|
|
|
this.$translate.instant(`No delivery zone available for this landing date`)
|
2019-03-26 11:02:11 +00:00
|
|
|
);
|
|
|
|
}
|
2018-07-24 10:14:35 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
/*
|
|
|
|
* Gets an agency from an specified zone
|
|
|
|
*/
|
|
|
|
onChangeZone(zoneId) {
|
|
|
|
const query = `/api/Zones/${zoneId}`;
|
|
|
|
this.$http.get(query).then(res => {
|
|
|
|
if (res.data)
|
|
|
|
this.ticket.agencyModeFk = res.data.agencyModeFk;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Gets a zone from an agency
|
|
|
|
*/
|
|
|
|
onChangeAgencyMode(agencyModeId) {
|
|
|
|
let params = {
|
|
|
|
landed: this.ticket.landed,
|
|
|
|
addressFk: this.ticket.addressFk,
|
|
|
|
agencyModeFk: agencyModeId,
|
|
|
|
warehouseFk: this.ticket.warehouseFk
|
2018-07-11 07:11:45 +00:00
|
|
|
};
|
2018-05-17 06:44:34 +00:00
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
this.ticket.zoneFk = null;
|
|
|
|
let query = `/api/Agencies/getShipped`;
|
|
|
|
this.$http.get(query, {params}).then(res => {
|
2018-07-11 07:11:45 +00:00
|
|
|
if (res.data)
|
2019-07-26 09:48:01 +00:00
|
|
|
this.ticket.zoneFk = res.data.id;
|
|
|
|
else {
|
|
|
|
return this.vnApp.showMessage(
|
|
|
|
this.$translate.instant('No delivery zone available for this parameters')
|
|
|
|
);
|
|
|
|
}
|
2018-07-11 07:11:45 +00:00
|
|
|
});
|
2018-05-17 06:44:34 +00:00
|
|
|
}
|
|
|
|
|
2019-04-01 12:49:12 +00:00
|
|
|
async onStepChange() {
|
2019-01-24 14:41:48 +00:00
|
|
|
if (this.isFormInvalid()) {
|
2018-05-16 06:13:39 +00:00
|
|
|
return this.vnApp.showError(
|
|
|
|
this.$translate.instant('Some fields are invalid')
|
|
|
|
);
|
2019-01-24 14:41:48 +00:00
|
|
|
}
|
2018-05-16 06:13:39 +00:00
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
let query = `/api/tickets/${this.ticket.id}/priceDifference`;
|
|
|
|
let params = {
|
2019-02-26 11:51:01 +00:00
|
|
|
landed: this.ticket.landed,
|
2019-07-26 09:48:01 +00:00
|
|
|
addressId: this.ticket.addressFk,
|
|
|
|
agencyModeId: this.ticket.agencyModeFk,
|
|
|
|
zoneId: this.ticket.zoneFk,
|
|
|
|
warehouseId: this.ticket.warehouseFk
|
2018-05-16 06:13:39 +00:00
|
|
|
};
|
2018-05-25 15:25:35 +00:00
|
|
|
|
2019-07-26 09:48:01 +00:00
|
|
|
return this.$http.post(query, params).then(res => {
|
2018-05-22 06:14:16 +00:00
|
|
|
if (res.data)
|
2018-05-16 06:13:39 +00:00
|
|
|
this.ticket.sale = res.data;
|
|
|
|
|
2018-05-22 06:14:16 +00:00
|
|
|
return true;
|
2019-04-01 12:49:12 +00:00
|
|
|
}, err => {
|
2019-07-26 09:48:01 +00:00
|
|
|
this.vnApp.showError(
|
|
|
|
this.$translate.instant(err.data.error.message)
|
|
|
|
);
|
2018-05-16 06:13:39 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
isFormInvalid() {
|
2018-05-22 06:14:16 +00:00
|
|
|
return !this.ticket.clientFk || !this.ticket.addressFk || !this.ticket.agencyModeFk
|
2019-07-26 09:48:01 +00:00
|
|
|
|| !this.ticket.companyFk || !this.ticket.shipped || !this.ticket.landed
|
|
|
|
|| !this.ticket.zoneFk;
|
2018-04-04 11:56:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-22 06:14:16 +00:00
|
|
|
Controller.$inject = ['$scope', '$http', '$translate', 'vnApp'];
|
2018-04-04 11:56:16 +00:00
|
|
|
|
2019-04-16 13:00:21 +00:00
|
|
|
ngModule.component('vnTicketBasicDataStepOne', {
|
2018-05-25 08:03:45 +00:00
|
|
|
template: require('./index.html'),
|
2018-04-18 07:47:05 +00:00
|
|
|
controller: Controller,
|
2018-04-04 11:56:16 +00:00
|
|
|
bindings: {
|
|
|
|
ticket: '<'
|
2018-05-16 06:13:39 +00:00
|
|
|
},
|
|
|
|
require: {
|
2019-07-26 09:48:01 +00:00
|
|
|
basicData: '^vnTicketBasicData'
|
2018-04-18 07:47:05 +00:00
|
|
|
}
|
2018-04-04 11:56:16 +00:00
|
|
|
});
|