import ngModule from '../../module'; import Component from 'core/lib/component'; import './style.scss'; class Controller extends Component { get travel() { return this._travel; } set travel(value) { this._travel = value; if (value) { this.setDefaultParams(); this.getAllowedContentTypes(); } } getAllowedContentTypes() { this.$http.get('TravelThermographs/allowedContentTypes').then(res => { const contentTypes = res.data.join(', '); this.allowedContentTypes = contentTypes; }); } get contentTypesInfo() { return this.$translate.instant('ContentTypesInfo', { allowedContentTypes: this.allowedContentTypes }); } setDefaultParams() { const path = `Dms/${this.$params.dmsId}`; this.$http.get(path).then(res => { const dms = res.data && res.data; this.dms = { reference: dms.reference, warehouseId: dms.warehouseFk, companyId: dms.companyFk, dmsTypeId: dms.dmsTypeFk, description: dms.description, hasFile: dms.hasFile, hasFileAttached: false, files: [] }; }); } onSubmit() { const query = `dms/${this.$params.dmsId}/updateFile`; 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) { this.vnApp.showSuccess(this.$translate.instant('Data saved!')); this.$.watcher.updateOriginalData(); this.$state.go('worker.card.dms.index'); } }); } } ngModule.component('vnTravelThermographEdit', { template: require('./index.html'), controller: Controller, bindings: { travel: '<' } });