Blame view

esm5/lib/upload-attachment/upload-attachment.component.js 58.9 KB
75f29219   Anan Sangthongtum   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { AppConfigService } from '../app-config/app-config.service';
import { Http } from '@angular/http';
import { Request } from '../_services/request.service';
import { Common } from '../_services/common.service';
import { NgForm } from '@angular/forms';
import { HttpClient, HttpEventType, HttpHeaders, HttpRequest, HttpResponse } from '@angular/common/http';
import { Observable } from 'rxjs';
import QrCode from 'qrcode-reader';
import * as _ from 'lodash';
var UploadAttachmentComponent = /** @class */ (function () {
    function UploadAttachmentComponent(appConfigService, request, common, http, _http) {
        var _this = this;
        this.appConfigService = appConfigService;
        this.request = request;
        this.common = common;
        this.http = http;
        this._http = _http;
        this.upLoadType = [
            { title: "File", type: 1 },
            // {title:"Scan",type:2},
            { title: "Link", type: 3 },
            { title: "QR Code", type: 4 }
        ];
        this.systemId = '0';
        this.RelatedAgency = 'SOC';
        this.RecordId = '0';
        this.Subject = '-';
        this.TypeId = '0';
        this.onlyImage = false;
        this.uploaded = new EventEmitter();
        // @ViewChild('myModal') myModal;
        this.fileList = [];
        this.fileNameLink = '';
        this.fileNameLinkError = '';
        this.QrCodeFileName = '';
        this.fileNameQr = '';
        this.fileNameLinkQr = '';
        this.fileNameQrError = '';
        this.filter = {};
        this.uploadHeaders = {
            "Authorization": "Basic " + btoa("APPSOC:123456")
        };
        this.isLoading = false;
        this.isDisabled = false;
        this.createAuthorizationHeader = function (headers) {
        };
        this.beforeUpload = function (file, _fileList) {
            return new Observable(function (observer) {
                /** @type {?} */
                var whitelist = [
                    'application/pdf',
                    'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
                    'application/vnd.ms-excel',
                    'application/vnd.msexcel',
                    'application/csv',
                    'text/csv',
                    'application/msword',
                    'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
                    'application/vnd.ms-powerpoint',
                    'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
                    'application/vnd.openxmlformats-officedocument.presentationml.presentation',
                    'text/plain',
                    'text/comma-separated-values',
                    'text/anytext',
                    'image/png',
                    'image/jpeg',
                    'image/gif',
                    'image/bmp'
                ];
                /** @type {?} */
                var isWhitelist = (file && whitelist.indexOf(file.type) > -1);
                if (!isWhitelist) {
                    setTimeout(function () {
                        _this.fileList = [{
                                uid: '999',
                                name: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',
                                status: 'error',
                                response: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',
                                url: null
                            }];
                    }, 50);
                    observer.complete();
                    return;
                }
                /** @type {?} */
                var isLt30M = /** @type {?} */ ((file.size)) / 1024 / 1024 < 30;
                if (!isLt30M) {
                    _this.fileList = [{
                            uid: '999',
                            name: 'File must smaller than 30MB!',
                            status: 'error',
                            response: 'File must smaller than 30MB!',
                            url: null
                        }];
                    observer.complete();
                    return;
                }
                observer.next(isWhitelist && isLt30M);
                observer.complete();
            });
        };
        this.customReq = function (item) {
            /** @type {?} */
            var formData = new FormData();
            // tslint:disable-next-line:no-any
            formData.append('FileData', /** @type {?} */ (item.file));
            formData.append('SystemId', '' + _this.systemId);
            formData.append('RelatedAgency', _this.RelatedAgency);
            formData.append('RecordId', _this.RecordId);
            formData.append('Subject', _this.Subject);
            formData.append('TypeId', _this.TypeId);
            /** @type {?} */
            var headers = new HttpHeaders();
            headers = headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));
            /** @type {?} */
            var req = new HttpRequest('POST', item.action, formData, {
                reportProgress: true,
                headers: headers
            });
            // req.headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));
            return _this.http.request(req).subscribe(function (event) {
                if (event.type === HttpEventType.UploadProgress) {
                    if (event.total > 0) {
                        (/** @type {?} */ (event)).percent = event.loaded / event.total * 100;
                    }
                    // console.log("onProgress", event , this.fileList);
                    item.onProgress(event, item.file);
                }
                else if (event instanceof HttpResponse) {
                    // console.log("event.body", event.body , this.fileList);
                    if (_this.fileList && _this.fileList.length > 1) {
                        _this.fileList = [_this.fileList[_this.fileList.length - 1]];
                    }
                    // let res = JSON.parse(event.body);
                    // this.isDisabled = true;
                    // let res = JSON.parse(event.body);
                    // this.isDisabled = true;
                    _this.isDisabled = false;
                    _this.uploaded.emit(event.body);
                    item.onSuccess(event.body, item.file, event);
                }
            }, function (err) {
                console.log(err);
                item.onError(err, item.file);
            });
        };
        this.config = appConfigService.getConfig();
        this.url = _.get(this.config, 'apiServers.alfresco.url') || "https://portal-uat.soc.go.th/api/mfec/Alfresco";
        this.uploadUrl = _.get(this.config, 'apiServers.alfresco.uploadUrl') || 'https://portal-uat.soc.go.th/microservice-api/gen-processed-file/upload-link-server';
        // || "http://127.0.0.1:5500/microservice-api/gen-processed-file/upload-link-server";
    }
    /**
     * @return {?}
     */
    UploadAttachmentComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        var _this = this;
        console.log('form', this.form);
        this.qr = new QrCode();
        this.qr.callback = function (err, result) {
            console.log('callback');
            _this.fileNameQrError = '';
            /** @type {?} */
            var span = document.querySelector('span') || document.createElement('span');
            if (result) {
                console.log(result.result);
                if (result.result) {
                    _this.fileNameLinkQr = result.result;
                    _this.uploadLinkQr();
                }
                // span.textContent = 'view console';
            }
            else {
                // span.textContent = 'Error! See error message in console!';
                console.error(err);
                _this.fileNameQrError = _this.QrCodeFileName;
                _this.QrCodeFileName = '';
            }
            // preview.appendChild(span);
        };
    };
    /**
     * @return {?}
     */
    UploadAttachmentComponent.prototype.uploadLinkQr = /**
     * @return {?}
     */
    function () {
        var _this = this;
        this.isLoading = true;
        this.fileNameQrError = '';
        this._http.post(this.uploadUrl, {
            SystemId: '' + this.systemId,
            RelatedAgency: this.RelatedAgency,
            RecordId: this.RecordId,
            Subject: this.Subject,
            TypeId: this.TypeId,
            link: this.fileNameLinkQr
        }).map(function (res) {
            return res.json();
        })
            .toPromise().then(function (res) {
            console.log(res);
            _this.isLoading = false;
            if (res.resultCode === 20000 && res.data && res.data.file) {
                _this.fileNameLinkQr = '';
                // this.isDisabled = true;
                // this.isDisabled = true;
                _this.isDisabled = false;
                console.log('res.data', res.data.file);
                _this.fileNameQr = res.data.file.fileName;
                _this.uploaded.emit(res.data.file);
                _this.fileNameLink = '';
                _this.fileNameLinkError = '';
            }
            else {
                _this.fileNameQrError = _this.fileNameLinkQr;
            }
        }).catch(function (err) {
            _this.uploaded.emit({});
            _this.isLoading = false;
            _this.fileNameQrError = _this.fileNameLinkQr;
            console.log(err);
        });
    };
    /**
     * @return {?}
     */
    UploadAttachmentComponent.prototype.btnUpload = /**
     * @return {?}
     */
    function () {
        var _this = this;
        this.isLoading = true;
        this.fileNameLinkError = '';
        this._http.post(this.uploadUrl, {
            SystemId: '' + this.systemId,
            RelatedAgency: this.RelatedAgency,
            RecordId: this.RecordId,
            Subject: this.Subject,
            TypeId: this.TypeId,
            link: this.filter.link
        }).map(function (res) {
            return res.json();
        })
            .toPromise().then(function (res) {
            console.log(res);
            _this.isLoading = false;
            if (res.resultCode === 20000 && res.data && res.data.file) {
                _this.filter = {};
                // this.isDisabled = true;
                // this.isDisabled = true;
                _this.isDisabled = false;
                console.log('res.data', res.data.file);
                _this.fileNameLink = res.data.file.fileName;
                _this.uploaded.emit(res.data.file);
                _this.QrCodeFileName = '';
                _this.fileNameQr = '';
                _this.fileNameLinkQr = '';
                _this.fileNameQrError = '';
            }
            else {
                _this.fileNameLinkError = _this.filter.link;
            }
        }).catch(function (err) {
            _this.uploaded.emit({});
            _this.isLoading = false;
            _this.fileNameLinkError = _this.filter.link;
            console.log(err);
        });
    };
    /**
     * @return {?}
     */
    UploadAttachmentComponent.prototype.onQrCodeChange = /**
     * @return {?}
     */
    function () {
        /** @type {?} */
        var fullPath = document.getElementById('file-upload')['value'];
        if (fullPath) {
            /** @type {?} */
            var startIndex = (fullPath.indexOf('\\') >= 0 ? fullPath.lastIndexOf('\\') : fullPath.lastIndexOf('/'));
            /** @type {?} */
            var filename = fullPath.substring(startIndex);
            if (filename.indexOf('\\') === 0 || filename.indexOf('/') === 0) {
                filename = filename.substring(1);
            }
            this.QrCodeFileName = filename;
        }
        else {
            this.QrCodeFileName = '';
        }
        this.fileNameLinkQr = '';
        /** @type {?} */
        var upload = document.getElementById('file-upload');
        /** @type {?} */
        var preview = document.getElementById('preview');
        /** @type {?} */
        var files_ = document.getElementById('file-upload')['files'];
        // console.log('files_',files_)
        if (files_) {
            var _loop_1 = function () {
                file = files_[i];
                imageType = /^image\//;
                if (!imageType.test(file.type)) {
                    this_1.QrCodeFileName = '';
                    this_1.fileNameQrError = 'File type not valid';
                    console.log('File type not valid');
                }
                else {
                    // Read file
                    reader = new FileReader();
                    /** @type {?} */
                    var self_1 = this_1;
                    reader.addEventListener('load', function () {
                        /** @type {?} */
                        var img = document.querySelector('img') || document.createElement('img');
                        img.src = this.result;
                        // preview.appendChild(img);
                        // Analyse code
                        // preview.appendChild(img);
                        // Analyse code
                        self_1.qr.decode(this.result);
                    }.bind(reader), false);
                    reader.readAsDataURL(file);
                }
            };
            var this_1 = this, file, imageType, reader;
            for (var i = 0; i < files_.length; i++) {
                _loop_1();
            }
        }
        // console.log("onQrCodeChange",jsqrcode)
    };
    /**
     * @param {?} file
     * @return {?}
     */
    UploadAttachmentComponent.prototype.onUploaded = /**
     * @param {?} file
     * @return {?}
     */
    function (file) {
        console.log("file", file);
        /** @type {?} */
        var res = JSON.parse(file.request.response);
        this.uploaded.emit(res);
    };
    /**
     * @param {?} e
     * @return {?}
     */
    UploadAttachmentComponent.prototype.onSelected = /**
     * @param {?} e
     * @return {?}
     */
    function (e) {
        console.log("e", e);
        console.log('form', this.form);
        this.form.ngSubmit.emit();
    };
    /**
     * @param {?} data
     * @return {?}
     */
    UploadAttachmentComponent.prototype.onChange = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        data.fileList = [data.file];
        // console.log("onChange",data);
        if (data.fileList === 0) {
            this.isDisabled = false;
        }
    };
    /**
     * @return {?}
     */
    UploadAttachmentComponent.prototype.clearValue = /**
     * @return {?}
     */
    function () {
        this.isDisabled = false;
        console.log("clearValue");
        this.fileList = [];
        this.fileNameLink = '';
        this.fileNameLinkError = '';
        this.QrCodeFileName = '';
        this.fileNameQr = '';
        this.fileNameLinkQr = '';
        this.fileNameQrError = '';
    };
    UploadAttachmentComponent.decorators = [
        { type: Component, args: [{
                    selector: 'upload-attachment',
                    template: "<!--<p-tabView>-->\n    <!--<p-tabPanel header=\"File\">-->\n        <!--<dx-file-uploader selectButtonText=\"\u0E40\u0E25\u0E37\u0E2D\u0E01\u0E44\u0E1F\u0E25\u0E4C\" labelText=\"\" accept=\"*\" uploadMode=\"useForm\" uploadMethod=\"POST\"-->\n                          <!--multiple=\"true\" uploadMode=\"instantly\" labelText=\"\u0E2B\u0E23\u0E37\u0E2D\u0E27\u0E32\u0E07\u0E44\u0E1F\u0E25\u0E4C\u0E17\u0E35\u0E48\u0E19\u0E35\u0E48\" uploadUrl=\"https://filemanager-dot-smartrms-api.appspot.com/api/http/upload\"-->\n        <!--&gt;-->\n        <!--</dx-file-uploader>-->\n    <!--</p-tabPanel>-->\n    <!--<p-tabPanel header=\"Link\">-->\n        <!--Content 2-->\n    <!--</p-tabPanel>-->\n    <!--<p-tabPanel header=\"QR Code\">-->\n        <!--Content 3-->\n    <!--</p-tabPanel>-->\n<!--</p-tabView>-->\n<!-- [disabled]=\"isDisabled\" -->\n<dx-tab-panel\n        #tabPanel\n        [items]=\"upLoadType\"\n        [selectedIndex]=\"0\"\n        [loop]=\"false\"\n        [animationEnabled]=\"false\"\n        [swipeEnabled]=\"false\"\n        itemTemplate=\"itemTemplate\"\n>\n    <!--<div *dxTemplate=\"let type of upLoadType\">-->\n        <!--<span>{{type.name.toUpperCase()}}</span>-->\n    <!--</div>-->\n    <div *dxTemplate=\"let item of 'itemTemplate'\">\n        <div class=\"tabpanel-item\">\n            <div *ngIf=\"item.type === 1\">\n                <div class=\"col-sm-12\" style=\"text-align: center\">\n                    <br>\n                    <!--<form #f=\"ngForm\" action=\"https://203.154.32.126:2585/api/mfec/Alfresco\" method=\"post\" enctype=\"multipart/form-data\">-->\n                        <!--<input type=\"hidden\" name=\"SystemId\" [value]=\"11\">-->\n                        <!--<input type=\"hidden\" name=\"RelatedAgency\" [value]=\"11\">-->\n                        <!--<input type=\"hidden\" name=\"RecordId\" [value]=\"11\">-->\n                        <!--<input type=\"hidden\" name=\"Subject\" [value]=\"11\">-->\n                        <!--<input type=\"hidden\" name=\"TypeId\" [value]=\"11\">-->\n                        <!--<dx-file-uploader [uploadHeaders]=\"uploadHeaders\" selectButtonText=\"\u0E40\u0E25\u0E37\u0E2D\u0E01\u0E44\u0E1F\u0E25\u0E4C\" labelText=\"\" accept=\"*\" uploadMode=\"useForm\" (onValueChanged)=\"onSelected($event)\"-->\n                                          <!--labelText=\"\u0E2B\u0E23\u0E37\u0E2D\u0E27\u0E32\u0E07\u0E44\u0E1F\u0E25\u0E4C\u0E17\u0E35\u0E48\u0E19\u0E35\u0E48\">-->\n                        <!--</dx-file-uploader>-->\n                        <!--<input type=\"submit\">-->\n                    <!--</form>-->\n                    <nz-upload *ngIf=\"!onlyImage\" nzType=\"drag\"\n                        [nzAction]=\"url\"\n                        [nzCustomRequest]=\"customReq\"\n                        [nzMultiple]=\"false\"\n                        [(nzFileList)]=\"fileList\"\n                        (nzChange)=\"onChange($event)\"\n                        [nzShowButton]=\"fileList.length === 0\"\n                        [nzBeforeUpload]=\"beforeUpload\">\n                    <!--<nz-upload nzType=\"drag\"-->\n                               <!--nzAction=\"https://203.154.32.126:2585/api/mfec/Alfresco\"-->\n                               <!--&gt;-->\n                        <a nz-button>\n                            <i nz-icon type=\"upload\"></i><span>Click to Upload</span>\n                        </a>\n                    </nz-upload>\n                    <nz-upload *ngIf=\"onlyImage\" nzType=\"drag\"\n                           [nzAction]=\"url\"\n                           [nzCustomRequest]=\"customReq\"\n                           [nzMultiple]=\"false\"\n                           nzFileType=\"image/png,image/jpeg,image/gif,image/bmp\"\n                           [(nzFileList)]=\"fileList\"\n                           (nzChange)=\"onChange($event)\"\n                           [nzBeforeUpload]=\"beforeUpload\">\n                        <!--<nz-upload nzType=\"drag\"-->\n                        <!--nzAction=\"https://203.154.32.126:2585/api/mfec/Alfresco\"-->\n                        <!--&gt;-->\n                        <a nz-button>\n                            <i nz-icon type=\"upload\"></i><span>Click to Upload</span>\n                        </a>\n                    </nz-upload>\n                    <br>\n                </div>\n            </div>\n            <div *ngIf=\"item.type === 2\">\n                <div class=\"col-sm-10\" style=\"text-align: center\">\n                    <br>\n                    <br>\n                </div>\n            </div>\n            <div *ngIf=\"item.type === 3\">\n                <div class=\"col-sm-12\" style=\"text-align: center\">\n                  <div class=\"row\" *ngIf=\"!uploadUrl\" >\n                    <br>\n                    <br>\n                  </div>\n                    <div class=\"row\" *ngIf=\"uploadUrl\" style=\"height: 100px;\">\n                      <div class=\"col-sm-12\" style=\"padding: 50px;\">\n                        <div class=\"input-group\">\n                        <input type=\"text\" class=\"form-control m-input\" placeholder=\"\" [(ngModel)]=\"filter.link\">\n                        <span class=\"input-group-btn add-bt\">\n                          <button type=\"button\" class=\"btn btn-success btn-md\"  (click)=\"btnUpload()\" style=\"margin: 0px 0px;\" [disabled]=\"isLoading\">\n                              Upload\n                          </button>\n                        </span>\n                      </div>\n\n                      <div class=\"ant-upload-list-item ant-upload-list-item-done\" *ngIf=\"fileNameLink\">\n                      <div class=\"ant-upload-list-item-info\">\n                          <i nz-icon=\"\" class=\"anticon ng-tns-c8-0 anticon-paper-clip\" style=\"position: absolute;left: 0px;\"></i>\n                          <span class=\"ant-upload-list-item-name ng-tns-c8-0 \" >{{fileNameLink}}</span>\n                          <!-- <i  type=\"close\" class=\"anticon ng-tns-c8-0 anticon-close ng-star-inserted\" ></i> -->\n                        </div>\n                      </div>\n                      <div class=\"ant-upload-list-item ant-upload-list-item-done ant-upload-list-item-error\" *ngIf=\"fileNameLinkError\">\n                      <div class=\"ant-upload-list-item-info\">\n                          <i nz-icon=\"\" class=\"anticon ng-tns-c8-0 anticon-paper-clip\" style=\"position: absolute;left: 0px;\"></i>\n                          <span class=\"ant-upload-list-item-name ng-tns-c8-0 \" >{{fileNameLinkError}}</span>\n                          <i  type=\"close\" class=\"anticon ng-tns-c8-0 anticon-close\" (click)=\"fileNameLinkError = ''\" ></i>\n                        </div>\n                      </div>\n\n\n                  </div>\n                  </div>\n                </div>\n            </div>\n            <div *ngIf=\"item.type === 4\">\n              <div class=\"col-sm-12\" style=\"text-align: center\">\n                <div class=\"row\" *ngIf=\"!uploadUrl\" >\n                  <br>\n                  <br>\n                </div>\n\n                  <div class=\"row\" *ngIf=\"uploadUrl\" style=\"height: 100px;\">\n                    <div class=\"col-sm-12\" style=\"padding: 50px;\">\n                      <div id=\"preview\"></div>\n                      <div class=\"input-group\">\n                            <label for=\"file-upload\" class=\"custom-file-upload\"\n                            style=\"background-color: #2b3a4a !important;display: inline-block;color: #f5f9e2 !important;padding: 7px 14px;cursor: pointer;\">\n                                 Upload\n                            </label>\n                            <!-- -->\n                            <span style=\"padding: 10px;\"> <i  *ngIf=\"isLoading\" class=\"fa fa-spinner fa-spin\" aria-hidden=\"true\" ></i> {{QrCodeFileName}}</span>\n                            <input id=\"file-upload\" type=\"file\" style=\" display: none;\" (change)=\"onQrCodeChange()\" accept=\"image/*\"/>\n                      </div>\n\n                      <div class=\"ant-upload-list-item ant-upload-list-item-done\" *ngIf=\"fileNameQr\">\n                      <div class=\"ant-upload-list-item-info\">\n                          <i nz-icon=\"\" class=\"anticon ng-tns-c8-0 anticon-paper-clip\" style=\"position: absolute;left: 0px;\"></i>\n                          <span class=\"ant-upload-list-item-name ng-tns-c8-0 \" >{{fileNameQr}}</span>\n                          <!-- <i  type=\"close\" class=\"anticon ng-tns-c8-0 anticon-close ng-star-inserted\" ></i> -->\n                        </div>\n                      </div>\n                      <div class=\"ant-upload-list-item ant-upload-list-item-done ant-upload-list-item-error\" *ngIf=\"fileNameQrError\">\n                      <div class=\"ant-upload-list-item-info\">\n                          <i nz-icon=\"\" class=\"anticon ng-tns-c8-0 anticon-paper-clip\" style=\"position: absolute;left: 0px;\"></i>\n                          <span class=\"ant-upload-list-item-name ng-tns-c8-0 \" >{{fileNameQrError}}</span>\n                          <i  type=\"close\" class=\"anticon ng-tns-c8-0 anticon-close\" (click)=\"fileNameQrError = ''\" ></i>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n            </div>\n        </div>\n    </div>\n</dx-tab-panel>\n"
                }] }
    ];
    /** @nocollapse */
    UploadAttachmentComponent.ctorParameters = function () { return [
        { type: AppConfigService },
        { type: Request },
        { type: Common },
        { type: HttpClient },
        { type: Http }
    ]; };
    UploadAttachmentComponent.propDecorators = {
        form: [{ type: ViewChild, args: ['f',] }],
        upLoadType: [{ type: Input }],
        systemId: [{ type: Input }],
        RelatedAgency: [{ type: Input }],
        RecordId: [{ type: Input }],
        Subject: [{ type: Input }],
        TypeId: [{ type: Input }],
        onlyImage: [{ type: Input }],
        uploaded: [{ type: Output }]
    };
    return UploadAttachmentComponent;
}());
export { UploadAttachmentComponent };
if (false) {
    /** @type {?} */
    UploadAttachmentComponent.prototype.form;
    /** @type {?} */
    UploadAttachmentComponent.prototype.upLoadType;
    /** @type {?} */
    UploadAttachmentComponent.prototype.systemId;
    /** @type {?} */
    UploadAttachmentComponent.prototype.RelatedAgency;
    /** @type {?} */
    UploadAttachmentComponent.prototype.RecordId;
    /** @type {?} */
    UploadAttachmentComponent.prototype.Subject;
    /** @type {?} */
    UploadAttachmentComponent.prototype.TypeId;
    /** @type {?} */
    UploadAttachmentComponent.prototype.onlyImage;
    /** @type {?} */
    UploadAttachmentComponent.prototype.uploaded;
    /** @type {?} */
    UploadAttachmentComponent.prototype.fileList;
    /** @type {?} */
    UploadAttachmentComponent.prototype.fileNameLink;
    /** @type {?} */
    UploadAttachmentComponent.prototype.fileNameLinkError;
    /** @type {?} */
    UploadAttachmentComponent.prototype.QrCodeFileName;
    /** @type {?} */
    UploadAttachmentComponent.prototype.fileNameQr;
    /** @type {?} */
    UploadAttachmentComponent.prototype.fileNameLinkQr;
    /** @type {?} */
    UploadAttachmentComponent.prototype.fileNameQrError;
    /** @type {?} */
    UploadAttachmentComponent.prototype.filter;
    /** @type {?} */
    UploadAttachmentComponent.prototype.uploadHeaders;
    /** @type {?} */
    UploadAttachmentComponent.prototype.config;
    /** @type {?} */
    UploadAttachmentComponent.prototype.url;
    /** @type {?} */
    UploadAttachmentComponent.prototype.uploadUrl;
    /** @type {?} */
    UploadAttachmentComponent.prototype.qr;
    /** @type {?} */
    UploadAttachmentComponent.prototype.isLoading;
    /** @type {?} */
    UploadAttachmentComponent.prototype.isDisabled;
    /** @type {?} */
    UploadAttachmentComponent.prototype.createAuthorizationHeader;
    /** @type {?} */
    UploadAttachmentComponent.prototype.beforeUpload;
    /** @type {?} */
    UploadAttachmentComponent.prototype.customReq;
    /** @type {?} */
    UploadAttachmentComponent.prototype.appConfigService;
    /** @type {?} */
    UploadAttachmentComponent.prototype.request;
    /** @type {?} */
    UploadAttachmentComponent.prototype.common;
    /** @type {?} */
    UploadAttachmentComponent.prototype.http;
    /** @type {?} */
    UploadAttachmentComponent.prototype._http;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-attachment.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/upload-attachment/upload-attachment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport {AppConfigService} from '../app-config/app-config.service';\nimport {Http, Headers, Response, URLSearchParams, RequestOptions} from '@angular/http';\nimport {Request} from '../_services/request.service';\nimport {Common} from '../_services/common.service';\nimport {NgForm} from '@angular/forms';\nimport {UploadXHRArgs} from 'ng-zorro-antd';\nimport {HttpClient, HttpEvent, HttpEventType, HttpHeaders, HttpRequest, HttpResponse,HttpErrorResponse} from '@angular/common/http';\nimport {Subscription} from 'rxjs/Rx';\nimport {Observable,throwError} from 'rxjs';\nimport QrCode from 'qrcode-reader';//libs/qrcode\n// import { NzMessageService } from 'ng-zorro-antd/message';\nimport { UploadFile } from 'ng-zorro-antd/upload';\nimport * as _ from 'lodash';\n\n@Component({\n    selector: 'upload-attachment',\n    templateUrl: './upload-attachment.component.html',\n})\nexport class UploadAttachmentComponent implements OnInit {\n    @ViewChild('f') form: NgForm;\n    @Input() upLoadType: any = [\n        {title: \"File\", type: 1},\n        // {title:\"Scan\",type:2},\n        {title: \"Link\", type: 3},\n        {title: \"QR Code\", type: 4}];\n    @Input() systemId: any = '0';\n    @Input() RelatedAgency: any = 'SOC';\n    @Input() RecordId: any = '0';\n    @Input() Subject: any = '-';\n    @Input() TypeId: any = '0';\n    @Input() onlyImage: boolean = false;\n    @Output() uploaded = new EventEmitter();\n    // @ViewChild('myModal') myModal;\n    fileList: any = [];\n    fileNameLink = '';\n    fileNameLinkError = '';\n    QrCodeFileName = ''\n    fileNameQr = '';\n    fileNameLinkQr = '';\n    fileNameQrError = '';\n    filter: any = {}\n    uploadHeaders: any = {\n        \"Authorization\": \"Basic \" + btoa(\"APPSOC:123456\")\n    };\n    // value:any = [];\n    config;\n    url;\n    uploadUrl;\n    qr;\n    isLoading = false;\n    isDisabled = false;\n\n    constructor(private appConfigService: AppConfigService, private request: Request, public common: Common, private http: HttpClient, public _http: Http,) {\n        this.config = appConfigService.getConfig();\n        this.url = _.get(this.config, 'apiServers.alfresco.url') || \"https://portal-uat.soc.go.th/api/mfec/Alfresco\";\n        this.uploadUrl = _.get(this.config, 'apiServers.alfresco.uploadUrl') || 'https://portal-uat.soc.go.th/microservice-api/gen-processed-file/upload-link-server'\n        // || \"http://127.0.0.1:5500/microservice-api/gen-processed-file/upload-link-server\";\n    }\n\n    ngOnInit() {\n        console.log('form', this.form);\n        this.qr = new QrCode();\n        this.qr.callback = (err, result) => {\n            console.log('callback')\n            this.fileNameQrError = '';\n            var span = document.querySelector('span') || document.createElement('span');\n            if (result) {\n                console.log(result.result)\n                if (result.result) {\n                    this.fileNameLinkQr = result.result;\n                    this.uploadLinkQr()\n                }\n\n                // span.textContent = 'view console';\n            }\n            else {\n                // span.textContent = 'Error! See error message in console!';\n                console.error(err);\n\n                this.fileNameQrError = this.QrCodeFileName\n                this.QrCodeFileName = '';\n            }\n            // preview.appendChild(span);\n        }\n    }\n\n    uploadLinkQr() {\n        this.isLoading = true;\n        this.fileNameQrError = '';\n        this._http.post(this.uploadUrl, {\n            SystemId: '' + this.systemId,\n            RelatedAgency: this.RelatedAgency,\n            RecordId: this.RecordId,\n            Subject: this.Subject,\n            TypeId: this.TypeId,\n            link: this.fileNameLinkQr\n        }).map((res: Response) => {\n            return res.json();\n        })\n            .toPromise().then(res => {\n            console.log(res)\n            this.isLoading = false\n\n            if (res.resultCode === 20000 && res.data && res.data.file) {\n                this.fileNameLinkQr = '';\n                // this.isDisabled = true;\n                this.isDisabled = false;\n                console.log('res.data', res.data.file)\n                this.fileNameQr = res.data.file.fileName\n                this.uploaded.emit(res.data.file);\n                this.fileNameLink = '';\n                this.fileNameLinkError = '';\n            } else {\n                this.fileNameQrError = this.fileNameLinkQr\n            }\n        }).catch((err) => {\n            this.uploaded.emit({});\n            this.isLoading = false\n            this.fileNameQrError = this.fileNameLinkQr\n            console.log(err)\n        })\n    }\n\n    btnUpload() {\n        this.isLoading = true;\n        this.fileNameLinkError = '';\n        this._http.post(this.uploadUrl, {\n            SystemId: '' + this.systemId,\n            RelatedAgency: this.RelatedAgency,\n            RecordId: this.RecordId,\n            Subject: this.Subject,\n            TypeId: this.TypeId,\n            link: this.filter.link\n        }).map((res: Response) => {\n            return res.json();\n        })\n            .toPromise().then(res => {\n            console.log(res)\n            this.isLoading = false\n\n            if (res.resultCode === 20000 && res.data && res.data.file) {\n                this.filter = {};\n                // this.isDisabled = true;\n                this.isDisabled = false;\n                console.log('res.data', res.data.file)\n                this.fileNameLink = res.data.file.fileName\n                this.uploaded.emit(res.data.file);\n                this.QrCodeFileName = ''\n                this.fileNameQr = '';\n                this.fileNameLinkQr = '';\n                this.fileNameQrError = '';\n            } else {\n                this.fileNameLinkError = this.filter.link\n            }\n        }).catch((err) => {\n            this.uploaded.emit({});\n            this.isLoading = false\n            this.fileNameLinkError = this.filter.link\n            console.log(err)\n        })\n\n    }\n\n    onQrCodeChange() {\n        let fullPath = document.getElementById('file-upload')['value'];\n        if (fullPath) {\n            var startIndex = (fullPath.indexOf('\\\\') >= 0 ? fullPath.lastIndexOf('\\\\') : fullPath.lastIndexOf('/'));\n            var filename = fullPath.substring(startIndex);\n            if (filename.indexOf('\\\\') === 0 || filename.indexOf('/') === 0) {\n                filename = filename.substring(1);\n            }\n\n            this.QrCodeFileName = filename\n        } else {\n            this.QrCodeFileName = ''\n        }\n        this.fileNameLinkQr = '';\n\n        var upload = document.getElementById('file-upload');\n        var preview = document.getElementById('preview');\n\n        let files_ = document.getElementById('file-upload')['files'];\n        // console.log('files_',files_)\n        if (files_)\n            for (var i = 0; i < files_.length; i++) {\n                var file = files_[i];\n                var imageType = /^image\\//;\n\n                if (!imageType.test(file.type)) {\n                    this.QrCodeFileName = '';\n                    this.fileNameQrError = 'File type not valid';\n                    console.log('File type not valid')\n                }else{\n                  // Read file\n                  var reader = new FileReader();\n                  let self = this;\n                  reader.addEventListener('load', function () {\n                      // Show as preview image\n                      var img = document.querySelector('img') || document.createElement('img');\n                      img.src = this.result;\n                      // preview.appendChild(img);\n\n                      // Analyse code\n                      self.qr.decode(this.result);\n                  }.bind(reader), false);\n                  reader.readAsDataURL(file);\n                }\n\n\n            }\n\n\n        // console.log(\"onQrCodeChange\",jsqrcode)\n    }\n\n\n    onUploaded(file) {\n        console.log(\"file\", file);\n        let res = JSON.parse(file.request.response);\n        this.uploaded.emit(res);\n    }\n\n    onSelected(e) {\n        console.log(\"e\", e);\n        console.log('form', this.form);\n        this.form.ngSubmit.emit();\n    }\n\n    createAuthorizationHeader = (headers: HttpHeaders) => {\n    }\n\n    beforeUpload = (file:any, _fileList:any) => {\n        return new Observable((observer: any) => {\n          let whitelist = [\n              'application/pdf',\n              'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n              'application/vnd.ms-excel',\n              'application/vnd.msexcel',\n              'application/csv',\n              'text/csv',\n              'application/msword',\n              'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n              'application/vnd.ms-powerpoint',\n              'application/vnd.openxmlformats-officedocument.presentationml.slideshow',\n              'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n              'text/plain',\n              'text/comma-separated-values',\n              'text/anytext',\n              'image/png',\n              'image/jpeg',\n              'image/gif',\n              'image/bmp'\n\n            ];\n          const isWhitelist = (file && whitelist.indexOf(file.type) > -1)\n          if(!isWhitelist){\n              setTimeout(() => {\n                this.fileList = [ {\n                      uid: '999',\n                      name: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',\n                      status: 'error',\n                      response: 'สามารถอัพโหลดได้เฉพาะไฟล์  pdf , png  , jpeg  ,gif , text , word , excel , powerpoint',\n                      url: null\n                    }]\n              }, 50);\n              observer.complete();\n              return;\n          }\n\n          const isLt30M = file.size! / 1024 / 1024 < 30;\n          if (!isLt30M) {\n            this.fileList = [ {\n                  uid: '999',\n                  name: 'File must smaller than 30MB!',\n                  status: 'error',\n                  response: 'File must smaller than 30MB!',\n                  url: null\n                }]\n            observer.complete();\n            return;\n          }\n\n          observer.next(isWhitelist && isLt30M);\n          observer.complete();\n        });\n      };\n\n    customReq = (item: UploadXHRArgs) => {\n\n        const formData = new FormData();\n        // tslint:disable-next-line:no-any\n        formData.append('FileData', item.file as any);\n        formData.append('SystemId', '' + this.systemId);\n        formData.append('RelatedAgency', this.RelatedAgency);\n        formData.append('RecordId', this.RecordId);\n        formData.append('Subject', this.Subject);\n        formData.append('TypeId', this.TypeId);\n        let headers = new HttpHeaders();\n        headers = headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));\n        let req = new HttpRequest('POST', item.action, formData, {\n            reportProgress: true,\n            headers: headers\n        });\n        // req.headers.set('Authorization', 'Basic ' + btoa('APPSOC:123456'));\n        return this.http.request(req).subscribe(\n            (event: HttpEvent<{}>) => {\n                if (event.type === HttpEventType.UploadProgress) {\n                    if (event.total > 0) {\n                        (event as any).percent = event.loaded / event.total * 100;\n                    }\n                    // console.log(\"onProgress\", event , this.fileList);\n                    item.onProgress(event, item.file);\n                } else if (event instanceof HttpResponse) {\n                    // console.log(\"event.body\", event.body , this.fileList);\n                    if(this.fileList && this.fileList.length > 1){\n                      this.fileList = [this.fileList[this.fileList.length-1]]\n                    }\n                    // let res = JSON.parse(event.body);\n                    // this.isDisabled = true;\n                    this.isDisabled = false;\n                    this.uploaded.emit(event.body);\n                    item.onSuccess(event.body, item.file, event);\n                }\n            }, (err) => {\n              console.log(err);\n\n                item.onError(err, item.file);\n            });\n    }\n\n    onChange(data) {\n        data.fileList = [data.file];\n\n        // console.log(\"onChange\",data);\n\n        if(data.fileList === 0){\n            this.isDisabled = false;\n        }\n    }\n\n    public clearValue() {\n        this.isDisabled = false;\n        console.log(\"clearValue\")\n        this.fileList = [];\n        this.fileNameLink = '';\n        this.fileNameLinkError = '';\n        this.QrCodeFileName = ''\n\n        this.fileNameQr = '';\n        this.fileNameLinkQr = '';\n        this.fileNameQrError = '';\n    }\n}\n"]}