salix/modules/client/front/sample/create/index.js

189 lines
5.1 KiB
JavaScript
Raw Permalink Normal View History

2018-07-31 09:08:22 +00:00
import ngModule from '../../module';
2020-03-17 10:17:50 +00:00
import Section from 'salix/components/section';
2018-07-31 09:08:22 +00:00
import './style.scss';
2020-03-17 10:17:50 +00:00
class Controller extends Section {
2022-09-26 06:07:45 +00:00
constructor($element, $, vnEmail) {
super($element, $);
2022-09-26 06:07:45 +00:00
this.vnEmail = vnEmail;
2018-07-31 09:08:22 +00:00
}
2019-11-04 12:55:20 +00:00
get client() {
return this._client;
}
set client(value) {
this._client = value;
2023-10-03 08:15:16 +00:00
if (value) {
this.setClientSample(value);
2023-10-03 08:15:16 +00:00
this.clientAddressesList(value.id);
}
2019-11-04 12:55:20 +00:00
}
get companyId() {
if (!this.clientSample.companyFk)
this.clientSample.companyFk = this.vnConfig.companyFk;
return this.clientSample.companyFk;
}
set companyId(value) {
this.clientSample.companyFk = value;
}
2023-10-03 08:15:16 +00:00
get addressId() {
if (!this.clientSample.addressId)
this.clientSample.addressId = this.client.defaultAddressFk;
return this.clientSample.addressId;
}
set addressId(value) {
this.clientSample.addressId = value;
}
2020-02-18 10:14:02 +00:00
onSubmit() {
this.$.watcher.check();
2022-10-04 07:21:24 +00:00
const validationMessage = this.validate();
if (validationMessage)
return this.vnApp.showError(this.$t(validationMessage));
2022-09-26 06:07:45 +00:00
this.$.watcher.realSubmit().then(() => this.send());
2020-02-18 10:14:02 +00:00
}
2018-07-31 09:08:22 +00:00
2022-10-04 07:21:24 +00:00
validate() {
2022-09-26 06:07:45 +00:00
const sampleType = this.$.sampleType.selection;
2022-10-04 07:21:24 +00:00
if (!this.clientSample.recipient)
return 'Email cannot be blank';
2022-09-26 06:07:45 +00:00
if (!sampleType)
2022-10-04 07:21:24 +00:00
return 'Choose a sample';
2022-09-26 06:07:45 +00:00
if (sampleType.hasCompany && !this.clientSample.companyFk)
2022-10-04 07:21:24 +00:00
return 'Choose a company';
if (sampleType.datepickerEnabled && !this.clientSample.from)
return 'Choose a date';
return;
}
setParams(params) {
const sampleType = this.$.sampleType.selection;
2022-09-26 06:07:45 +00:00
if (sampleType.hasCompany)
params.companyId = this.clientSample.companyFk;
if (sampleType.datepickerEnabled)
params.from = this.clientSample.from;
2023-10-03 08:15:16 +00:00
if (this.clientSample.addressId)
params.addressId = this.clientSample.addressId;
2022-09-26 06:07:45 +00:00
}
2022-09-22 13:44:35 +00:00
preview() {
2020-02-18 10:14:02 +00:00
const sampleType = this.$.sampleType.selection;
2022-09-22 13:44:35 +00:00
2020-02-18 10:14:02 +00:00
const params = {
2022-10-04 07:21:24 +00:00
recipientId: this.$params.id
2019-11-04 12:55:20 +00:00
};
2018-07-31 09:08:22 +00:00
2022-10-04 07:21:24 +00:00
const validationMessage = this.validate();
if (validationMessage)
return this.vnApp.showError(this.$t(validationMessage));
this.setParams(params);
2022-09-26 06:07:45 +00:00
const path = `${sampleType.model}/${this.$params.id}/${sampleType.code}-html`;
2022-09-22 13:44:35 +00:00
this.$http.get(path, {params})
.then(response => {
this.$.showPreview.show();
const dialog = document.body.querySelector('div.vn-dialog');
const body = dialog.querySelector('tpl-body');
const scroll = dialog.querySelector('div:first-child');
body.innerHTML = response.data;
scroll.scrollTop = 0;
});
}
2022-09-22 13:44:35 +00:00
send() {
2022-09-26 06:07:45 +00:00
const sampleType = this.$.sampleType.selection;
const params = {
recipientId: this.client.id,
recipient: this.clientSample.recipient,
replyTo: this.clientSample.replyTo
};
2022-10-04 07:21:24 +00:00
const validationMessage = this.validate();
if (validationMessage)
return this.vnApp.showError(this.$t(validationMessage));
this.setParams(params);
2022-09-26 06:07:45 +00:00
const path = `${sampleType.model}/${this.$params.id}/${sampleType.code}-email`;
this.vnEmail.send(path, params)
.then(() => this.$state.go('client.card.sample.index'));
2018-07-31 09:08:22 +00:00
}
setClientSample(client) {
const userId = window.localStorage.currentUserWorkerId;
const params = {filter: {where: {userFk: userId}}};
this.$http.get('EmailUsers', params).then(res => {
const [worker] = res && res.data;
this.clientSample = {
clientFk: this.$params.id,
companyId: this.vnConfig.companyFk,
recipient: client.email,
replyTo: worker.email
};
});
}
2023-10-03 08:15:16 +00:00
clientAddressesList(value) {
let filter = {
include: [
{
relation: 'province',
scope: {
fields: ['name']
}
},
{
relation: 'agencyMode',
scope: {
fields: ['name']
}
}
]
};
filter = encodeURIComponent(JSON.stringify(filter));
let query = `Clients/${value}/addresses?filter=${filter}`;
this.$http.get(query).then(res => {
if (res.data)
this.addresses = res.data;
});
}
getClientDefaultAddress(value) {
let query = `Clients/${value}`;
this.$http.get(query).then(res => {
if (res.data)
this.addressId = res.data.defaultAddressFk;
});
}
2018-07-31 09:08:22 +00:00
}
2022-09-26 06:07:45 +00:00
Controller.$inject = ['$element', '$scope', 'vnEmail'];
2018-07-31 09:08:22 +00:00
ngModule.vnComponent('vnClientSampleCreate', {
2018-07-31 09:08:22 +00:00
template: require('./index.html'),
2019-11-04 12:55:20 +00:00
controller: Controller,
bindings: {
client: '<'
}
2018-07-31 09:08:22 +00:00
});