124 lines
3.3 KiB
JavaScript
124 lines
3.3 KiB
JavaScript
|
import ngModule from '../../module';
|
||
|
import Section from 'salix/components/section';
|
||
|
import './style.scss';
|
||
|
|
||
|
class Controller extends Section {
|
||
|
constructor($element, $) {
|
||
|
super($element, $);
|
||
|
this.dms = {
|
||
|
files: [],
|
||
|
hasFile: false,
|
||
|
hasFileAttached: false
|
||
|
};
|
||
|
this.addedDms;
|
||
|
}
|
||
|
|
||
|
get route() {
|
||
|
return this._route;
|
||
|
}
|
||
|
|
||
|
set route(value) {
|
||
|
this._route = value;
|
||
|
|
||
|
this.setDefaultParams();
|
||
|
this.getAllowedContentTypes();
|
||
|
}
|
||
|
|
||
|
$onChanges() {
|
||
|
if (this.$params && this.$params.q)
|
||
|
this.params = JSON.parse(this.$params.q);
|
||
|
}
|
||
|
|
||
|
getAllowedContentTypes() {
|
||
|
this.$http.get('DmsContainers/allowedContentTypes').then(res => {
|
||
|
const contentTypes = res.data.join(', ');
|
||
|
this.allowedContentTypes = contentTypes;
|
||
|
});
|
||
|
}
|
||
|
|
||
|
get contentTypesInfo() {
|
||
|
return this.$t('ContentTypesInfo', {
|
||
|
allowedContentTypes: this.allowedContentTypes
|
||
|
});
|
||
|
}
|
||
|
|
||
|
setDefaultParams() {
|
||
|
const params = {filter: {
|
||
|
where: {code: 'invoiceIn'}
|
||
|
}};
|
||
|
this.$http.get('DmsTypes/findOne', {params}).then(res => {
|
||
|
const dmsType = res.data && res.data;
|
||
|
const companyId = this.vnConfig.companyFk;
|
||
|
const warehouseId = this.vnConfig.warehouseFk;
|
||
|
const defaultParams = {
|
||
|
warehouseId: warehouseId,
|
||
|
companyId: companyId,
|
||
|
dmsTypeId: dmsType.id,
|
||
|
description: this.params.supplierName
|
||
|
};
|
||
|
|
||
|
this.dms = Object.assign(this.dms, defaultParams);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
onSubmit() {
|
||
|
const query = `dms/uploadFile`;
|
||
|
const options = {
|
||
|
method: 'POST',
|
||
|
url: query,
|
||
|
params: this.dms,
|
||
|
headers: {
|
||
|
'Content-Type': undefined
|
||
|
},
|
||
|
transformRequest: files => {
|
||
|
const formData = new FormData();
|
||
|
|
||
|
for (let i = 0; i < files.length; i++)
|
||
|
formData.append(files[i].name, files[i]);
|
||
|
|
||
|
return formData;
|
||
|
},
|
||
|
data: this.dms.files
|
||
|
};
|
||
|
this.$http(options).then(res => {
|
||
|
if (res) {
|
||
|
let addedDms = res.data;
|
||
|
this.vnApp.showSuccess(this.$t('Data saved!'));
|
||
|
this.$.watcher.updateOriginalData();
|
||
|
|
||
|
const params = {
|
||
|
rows: this.params.rows,
|
||
|
dms: addedDms
|
||
|
};
|
||
|
|
||
|
this.$http.post('AgencyTerms/createInvoiceIn', params)
|
||
|
.then(() => {
|
||
|
this.$state.go('route.agencyTerm.index');
|
||
|
this.vnApp.showSuccess(this.$t('InvoiceIn created'));
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
onFileChange(files) {
|
||
|
let hasFileAttached = false;
|
||
|
|
||
|
if (files.length > 0)
|
||
|
hasFileAttached = true;
|
||
|
|
||
|
this.$.$applyAsync(() => {
|
||
|
this.dms.hasFileAttached = hasFileAttached;
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
Controller.$inject = ['$element', '$scope'];
|
||
|
|
||
|
ngModule.vnComponent('vnAgencyTermCreateInvoiceIn', {
|
||
|
template: require('./index.html'),
|
||
|
controller: Controller,
|
||
|
bindings: {
|
||
|
route: '<'
|
||
|
}
|
||
|
});
|