salix/modules/client/front/address/index/index.js

82 lines
2.1 KiB
JavaScript
Raw Normal View History

2018-05-23 12:26:51 +00:00
import ngModule from '../../module';
2019-09-02 07:25:18 +00:00
import './style.scss';
2018-05-23 12:26:51 +00:00
class Controller {
2018-07-16 06:00:04 +00:00
constructor($http, $scope, $stateParams) {
2017-09-28 12:34:18 +00:00
this.$http = $http;
this.$scope = $scope;
2018-07-16 06:00:04 +00:00
this.$stateParams = $stateParams;
2019-09-02 07:25:18 +00:00
this.filter = {
fields: [
'id',
'isDefaultAddress',
'isActive',
'nickname',
'street',
'city',
'provinceFk',
'phone',
'mobile',
'isEqualizated'
],
order: [
'isDefaultAddress DESC',
'isActive DESC',
'nickname ASC'],
include: [
{
relation: 'observations',
scope: {
include: 'observationType'
}
}, {
relation: 'province',
scope: {
fields: ['id', 'name']
}
}
]
};
}
onStarClick(event) {
event.stopPropagation();
event.preventDefault();
}
2018-02-08 08:04:29 +00:00
setDefault(address) {
let query = `/client/api/Clients/${this.$stateParams.id}`;
let params = {defaultAddressFk: address.id};
this.$http.patch(query, params).then(res => {
if (res.data) {
this.client.defaultAddressFk = res.data.defaultAddressFk;
this.sortAddresses();
}
});
}
isDefaultAddress(address) {
2019-06-18 07:34:32 +00:00
if (this.client)
return this.client.defaultAddressFk === address.id;
}
/**
* Sort address by default address
*/
sortAddresses() {
if (!this.client || !this.addresses) return;
2019-06-18 07:34:32 +00:00
this.addresses = this.addresses.sort((a, b) => {
return this.isDefaultAddress(b) - this.isDefaultAddress(a);
});
2017-09-28 12:34:18 +00:00
}
}
2018-07-16 06:00:04 +00:00
Controller.$inject = ['$http', '$scope', '$stateParams'];
2017-09-28 12:34:18 +00:00
2018-05-23 12:26:51 +00:00
ngModule.component('vnClientAddressIndex', {
template: require('./index.html'),
controller: Controller,
bindings: {
client: '<'
}
2017-06-03 11:01:47 +00:00
});