Blame view

esm5/lib/attachment-list/attachment-list.component.js 52.8 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
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Component, ViewChild, Input, Output, EventEmitter } from '@angular/core';
import { AppConfigService } from '../app-config/app-config.service';
import { DxDataGridComponent } from 'devextreme-angular';
import { Request } from '../_services/request.service';
import { Common } from '../_services/common.service';
import { ModalAttachmentComponent } from '../modal-attachment/modal-attachment.component';
import * as _ from 'lodash';
import { CreateAlertComponent } from '../alert/alert.component';
import { B2bService } from '../_services/b2b.service';
import { ModalAttachmentViewComponent } from '../modal-attachment-view/modal-attachment-view.component';
var AttachmentListComponent = /** @class */ (function () {
    function AttachmentListComponent(appConfigService, request, common, b2b) {
        this.appConfigService = appConfigService;
        this.request = request;
        this.common = common;
        this.b2b = b2b;
        this.mode = 'CREATE';
        this.type = 2;
        this.showImage = false;
        this.onLoaded = new EventEmitter();
        this.onClickScan = new EventEmitter();
        this.onClickDelete = new EventEmitter();
        this.columns = ['ลำดับที่', 'ผู้แก้ไข', 'วันที่', 'สถานะการติดตาม', 'หมายเหตุ'];
        this.attachmentList = [];
        this.dxgridPageSize = 10;
        this.allowedPageSizes1 = 10;
        this.allowedPageSizes2 = 25;
        this.allowedPageSizes3 = 50;
        this.allowedPageSizes4 = 100;
        this.customers = [];
        this.lastStep = '';
        this.deleteIdList = [];
        this.dsAttachment = [];
        this.selectedAttachment = [];
        this.tmpId = -1;
        this.classifieds = 0;
        this.username_caption = 'ผู้บันทึก/ผู้นำเข้า';
        this.config = appConfigService.getConfig();
    }
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var _this = this;
            return tslib_1.__generator(this, function (_a) {
                setTimeout(function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
                    var _a;
                    return tslib_1.__generator(this, function (_b) {
                        switch (_b.label) {
                            case 0:
                                _a = this;
                                return [4 /*yield*/, this.b2b.getAttachmentToken()];
                            case 1:
                                _a.downloadToken = _b.sent();
                                return [2 /*return*/];
                        }
                    });
                }); }, 500);
                if (this.mode !== "CREATE") {
                    this.getAttachmentList();
                }
                return [2 /*return*/];
            });
        });
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.getAttachmentList = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var e_1, _a, filter, data, _b, _c, i;
            return tslib_1.__generator(this, function (_d) {
                switch (_d.label) {
                    case 0:
                        console.log('getAttachmentList', this.attachmentList, this.option.username_caption);
                        filter = {
                            filter: {
                                ref_table: this.option.data.ref_table,
                                ref_id: this.option.data.ref_id,
                                system_id: this.option.data.system_id
                            },
                            order_by: ["order_no"]
                        };
                        if (this.option.data.result_table_id)
                            filter.filter.result_table_id = this.option.data.result_table_id;
                        return [4 /*yield*/, this.request.post('/search/rc_attachment_prop', filter)];
                    case 1:
                        data = _d.sent();
                        this.attachmentList = data.resultData;
                        this.classifieds = 0;
                        try {
                            for (_b = tslib_1.__values(this.attachmentList), _c = _b.next(); !_c.done; _c = _b.next()) {
                                i = _c.value;
                                if (i.is_classifieds) {
                                    this.classifieds++;
                                }
                            }
                        }
                        catch (e_1_1) { e_1 = { error: e_1_1 }; }
                        finally {
                            try {
                                if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
                            }
                            finally { if (e_1) throw e_1.error; }
                        }
                        console.log('getAttachmentList', this.attachmentList);
                        this.onLoaded.emit();
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.addAttachmentList = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        data.id = this.tmpId;
        this.tmpId--;
        if (this.b2b.getVerifyToken().phoneBookData && this.b2b.getVerifyToken().phoneBookData.length > 0) {
            data.username = this.b2b.getVerifyToken().username;
            data.recorder_name = this.b2b.getVerifyToken().phoneBookData[0].name;
        }
        data.action = "add";
        if (data.is_classifieds) {
            this.classifieds++;
        }
        this.attachmentList.push(data);
        console.log('getAttachmentList', this.attachmentList);
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.editAttachmentList = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        for (var i = 0; i < this.attachmentList.length; i++) {
            if (this.attachmentList[i].id === data.id) {
                if (data.is_classifieds && !this.attachmentList[i].is_classifieds) {
                    this.classifieds++;
                }
                else if (!data.is_classifieds && this.attachmentList[i].is_classifieds) {
                    this.classifieds--;
                }
                this.attachmentList[i] = data;
            }
        }
        console.log('getAttachmentList', this.attachmentList);
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.getRowIndex = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        if (!data.data) {
            return '';
        }
        data.data.order_no = data.component.pageIndex() * data.component.pageSize() + data.rowIndex + 1;
        return data.data.order_no;
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.clickAdd = /**
     * @return {?}
     */
    function () {
        this.option.mode = 'CREATE';
        if (this.attachmentModal) {
            this.attachmentModal.open(this.option);
        }
        else {
            this.modalAttachment.open(this.option);
        }
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.clickEdit = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        console.log('clickEdit', data);
        /** @type {?} */
        var fileName = data.filename;
        /** @type {?} */
        var fileType = fileName.substring(fileName.length - 3, fileName.length);
        console.log('fileType', fileType);
        if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {
            /** @type {?} */
            var editData = _.cloneDeep(this.option);
            editData.data = data;
            editData.mode = 'EDIT';
            editData.downloadToken = this.downloadToken;
            this.onClickScan.emit(editData);
        }
        else {
            /** @type {?} */
            var editData = _.cloneDeep(this.option);
            editData.data = data;
            editData.mode = 'EDIT';
            editData.downloadToken = this.downloadToken;
            if (this.attachmentModal) {
                this.attachmentModal.open(editData);
            }
            else {
                this.modalAttachment.open(editData);
            }
        }
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.clickView = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var fileName = data.filename;
        /** @type {?} */
        var fileType = fileName.substring(fileName.length - 3, fileName.length);
        console.log('fileType', fileType);
        if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {
            /** @type {?} */
            var viewData = _.cloneDeep(this.option);
            viewData.data = data;
            viewData.mode = 'VIEW';
            this.onClickScan.emit(viewData);
        }
        else {
            /** @type {?} */
            var viewData = _.cloneDeep(this.option);
            viewData.data = data;
            viewData.mode = 'VIEW';
            viewData.downloadToken = this.downloadToken;
            if (this.attachmentViewModal) {
                this.attachmentViewModal.open(viewData);
            }
            else {
                this.modalAttachmentView.open(viewData);
            }
        }
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.clickMoveUp = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var tmp = this.attachmentList[data.rowIndex];
        this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex - 1];
        this.attachmentList[data.rowIndex - 1] = tmp;
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.clickMoveDown = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var tmp = this.attachmentList[data.rowIndex];
        this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex + 1];
        this.attachmentList[data.rowIndex + 1] = tmp;
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.clickDownload = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            return tslib_1.__generator(this, function (_a) {
                window.open(data.url + "?downloadToken=" + this.downloadToken);
                return [2 /*return*/];
            });
        });
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.getLastStep = /**
     * @return {?}
     */
    function () {
        return this.lastStep;
    };
    /** START DELETE */
    /**
     * START DELETE
     * @param {?} idList
     * @return {?}
     */
    AttachmentListComponent.prototype.fnClickDelete = /**
     * START DELETE
     * @param {?} idList
     * @return {?}
     */
    function (idList) {
        this.onClickDelete.emit();
        this.deleteIdList = idList;
        if (this.deleteIdList.length > 0) {
            this.confirmDelete();
        }
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.confirmDelete = /**
     * @return {?}
     */
    function () {
        this.goAlert('', '', 'myModalDeleteAttachment');
    };
    /**
     * @param {?} userTitle
     * @param {?} userMessage
     * @param {?} modalId
     * @return {?}
     */
    AttachmentListComponent.prototype.goAlert = /**
     * @param {?} userTitle
     * @param {?} userMessage
     * @param {?} modalId
     * @return {?}
     */
    function (userTitle, userMessage, modalId) {
        /** @type {?} */
        var dataAlert = {
            'modalId': modalId,
            'userTitle': userTitle,
            'userMessage': userMessage
        };
        if (this.alertModal) {
            this.alertModal.openModal(dataAlert);
        }
        else {
            this.myModal.openModal(dataAlert);
        }
    };
    /**
     * @param {?} e
     * @return {?}
     */
    AttachmentListComponent.prototype.onCellPrepared = /**
     * @param {?} e
     * @return {?}
     */
    function (e) {
        if (e.rowType === 'data') {
            e.cellElement.accessKey = e.column.caption;
        }
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.fnDeleteMultiple = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var e_2, _a, _b, _c, id, i;
            return tslib_1.__generator(this, function (_d) {
                console.log("this.deleteIdList", this.deleteIdList);
                console.log("this.attachmentList before", this.attachmentList);
                try {
                    for (_b = tslib_1.__values(this.deleteIdList), _c = _b.next(); !_c.done; _c = _b.next()) {
                        id = _c.value;
                        for (i = this.attachmentList.length - 1; i >= 0; i--) {
                            if (this.attachmentList[i].id === id) {
                                if (this.attachmentList[i].is_classifieds) {
                                    this.classifieds--;
                                }
                                this.attachmentList.splice(i, 1);
                            }
                        }
                    }
                }
                catch (e_2_1) { e_2 = { error: e_2_1 }; }
                finally {
                    try {
                        if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
                    }
                    finally { if (e_2) throw e_2.error; }
                }
                console.log("this.attachmentList after", this.attachmentList);
                return [2 /*return*/];
            });
        });
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.onClickBack = /**
     * @return {?}
     */
    function () {
        console.log("clickback");
    };
    /**
     * @param {?} data
     * @return {?}
     */
    AttachmentListComponent.prototype.getImageLink = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        return data.url + "?downloadToken=" + this.downloadToken;
    };
    /**
     * @return {?}
     */
    AttachmentListComponent.prototype.scan = /**
     * @return {?}
     */
    function () {
        this.option.mode = 'CREATE';
        this.onClickScan.emit(this.option);
    };
    AttachmentListComponent.decorators = [
        { type: Component, args: [{
                    selector: 'soc-attachment-list',
                    template: "<div class=\"col-sm-12\">\n        <div class=\"ibox-heading-total\" style=\"padding: 0px 20px 0;\">\n                <h5 class=\"ibox-title-text\"></h5>\n                <!--<button id=\"btn\" name=\"btn\" type=\"button\" class=\"btn btn-success \" data-toggle=\"tooltip\"-->\n                <!--title=\"\u0E40\u0E1E\u0E34\u0E48\u0E21\u0E02\u0E49\u0E2D\u0E21\u0E39\u0E25\u0E23\u0E32\u0E22\u0E25\u0E30\u0E40\u0E2D\u0E35\u0E22\u0E14\u0E1B\u0E23\u0E30\u0E40\u0E14\u0E47\u0E19\" data-placement=\"top\" style=\"min-width: 80px;padding: 8px 10px;\">\u0E17\u0E33\u0E2A\u0E33\u0E40\u0E19\u0E32</button>-->\n                <button *ngIf=\"mode !== 'VIEW' &&  type === 1\" id=\"btnScan\" name=\"btnScan\" type=\"button\"\n                        class=\"btn btn-success\" data-toggle=\"tooltip\" data-placement=\"top\"\n                        style=\"min-width: 80px;padding: 8px 10px;\" (click)=\"scan()\">\u0E2A\u0E41\u0E01\u0E19</button>\n                <button *ngIf=\"mode !== 'VIEW'\" [disabled]=\"selectedAttachment.length === 0\" id=\"btnDelete\"\n                        name=\"btnDelete\" type=\"button\" class=\"btn btn-success\" data-toggle=\"tooltip\"\n                        data-placement=\"top\" style=\"min-width: 80px;padding: 8px 10px;\"\n                        (click)=\"fnClickDelete(selectedAttachment)\">\u0E25\u0E1A</button>\n                <button *ngIf=\"mode !== 'VIEW'\" id=\"btnAdd\" name=\"btnAdd\" type=\"button\" class=\"btn btn-success\"\n                        data-toggle=\"tooltip\" data-placement=\"top\" style=\"min-width: 80px;padding: 8px 10px;\"\n                        (click)=\"clickAdd()\">\u0E40\u0E1E\u0E34\u0E48\u0E21</button>\n        </div>\n        <div class=\"ibox-body\">\n                <div class=\"table-responsive table-wrapper\">\n                        <!--(onCellPrepared)=\"onCellPrepared1($event)\"-->\n                        <dx-data-grid #dxDataGridPrisoner id=\"dxDataGridPrisoner\" [dataSource]=\"attachmentList\"\n                                keyExpr=\"id\" [hoverStateEnabled]=\"true\" noDataText=\"\" showBorders=\"true\"\n                                [rowAlternationEnabled]=\"true\" [columnAutoWidth]=\"false\" class=\"card-list-table\"\n                                [allowColumnResizing]=\"true\" [allowColumnReordering]=\"true\"\n                                (onCellPrepared)=\"onCellPrepared($event)\" [wordWrapEnabled]=\"false\"\n                                [(selectedRowKeys)]=\"selectedAttachment\" class=\"card-list-table\">\n                                <dxo-paging [pageSize]=\"dxgridPageSize\"></dxo-paging>\n                                <dxo-pager [showPageSizeSelector]=\"true\"\n                                        [allowedPageSizes]=\"[allowedPageSizes1, allowedPageSizes2, allowedPageSizes3, allowedPageSizes4]\"\n                                        [showInfo]=\"false\" [visible]=\"true\" [showNavigationButtons]=\"true\"></dxo-pager>\n                                <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n                                <dxo-remote-operations [sorting]=\"true\" [paging]=\"true\"></dxo-remote-operations>\n                                <dxo-selection *ngIf=\"mode !== 'VIEW'\" selectAllMode=\"page\" showCheckBoxesMode=\"always\"\n                                        mode=\"multiple\" style=\"min-width: 50px !important;\"></dxo-selection>\n                                <dxo-state-storing [enabled]=\"true\" type=\"localStorage\"\n                                        storageKey=\"attachmentListDataGrid\"></dxo-state-storing>\n                                <dxi-column caption=\"\u0E25\u0E33\u0E14\u0E31\u0E1A\u0E17\u0E35\u0E48\" [allowSorting]=\"false\" cellTemplate=\"cellTemplateNo\"\n                                        alignment=\"center\" [width]=\"70\"></dxi-column>\n                                <dxi-column caption=\"\u0E08\u0E31\u0E14\u0E01\u0E32\u0E23\" [allowSorting]=\"false\" cellTemplate=\"cellTemplateAction\"\n                                        alignment=\"center\" [width]=\"mode !== 'VIEW' ? 255 : 105\"></dxi-column>\n                                <dxi-column dataField=\"recorder_name\" [caption]=\"option.username_caption ?option.username_caption :username_caption\"></dxi-column>\n                                <dxi-column *ngIf=\"type === 3\" dataField=\"book_no\" caption=\"\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\"></dxi-column>\n                                <dxi-column *ngIf=\"type === 2 || type === 1\" dataField=\"name\" caption=\"\u0E0A\u0E37\u0E48\u0E2D\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\">\n                                </dxi-column>\n                                <dxi-column dataField=\"doc_type\" caption=\"\u0E1B\u0E23\u0E30\u0E40\u0E20\u0E17\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\"></dxi-column>\n                                <dxi-column *ngIf=\"type === 1\" dataField=\"is_classifieds\" caption=\"\u0E08\u0E31\u0E14\u0E40\u0E02\u0E49\u0E32\u0E27\u0E32\u0E23\u0E30\">\n                                </dxi-column>\n                                <!--<dxi-column dataField=\"order\" caption=\"\u0E25\u0E33\u0E14\u0E31\u0E1A\"></dxi-column>-->\n                                <dxi-column dataField=\"created_at\" caption=\"\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E2A\u0E23\u0E49\u0E32\u0E07/\u0E19\u0E33\u0E40\u0E02\u0E49\u0E32\" dataType=\"date\"\n                                        alignment=\"center\" [width]=\"100\"></dxi-column>\n                                <dxi-column *ngIf=\"type === 3\" dataField=\"record_date\" dataType=\"date\"\n                                        caption=\"\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E08\u0E31\u0E14\u0E40\u0E01\u0E47\u0E1A\" alignment=\"center\" [width]=\"100\"></dxi-column>\n                                <dxi-column *ngIf=\"type === 2 || type === 1\" dataField=\"remark\" caption=\"\u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38\">\n                                </dxi-column>\n                                <!--<dxi-column *ngIf=\"type === 3\" dataField=\"amount\" caption=\"\u0E08\u0E33\u0E19\u0E27\u0E19\"></dxi-column>-->\n                                <!--<dxi-column *ngIf=\"type === 4\" dataField=\"version\" caption=\"\u0E40\u0E27\u0E2D\u0E23\u0E4C\u0E0A\u0E31\u0E48\u0E19\"></dxi-column>-->\n                                <dxi-column *ngIf=\"showImage\" caption=\"\u0E40\u0E04\u0E23\u0E37\u0E48\u0E2D\u0E07\u0E2B\u0E21\u0E32\u0E22\" cellTemplate=\"cellTemplateImage\">\n                                </dxi-column>\n                                <div *dxTemplate=\"let data of 'cellTemplateImage'\" class=\" text-center\">\n                                        <img *ngIf=\"showImage\" [src]=\"getImageLink(data.data)\"\n                                                style=\"width: auto !important;\">\n                                </div>\n                                <div *dxTemplate=\"let data of 'cellTemplateNo'\" class=\" text-center\">\n                                        <span>{{getRowIndex(data)}}</span>\n                                </div>\n                                <div *dxTemplate=\"let data of 'cellTemplateAction'\">\n                                        <a *ngIf=\"mode !== 'VIEW'\" id=\"btnEdit\" (click)=\"clickEdit(data.data)\"\n                                                class=\"btn btn-default btn-sm  icon\" data-toggle=\"tooltip\"\n                                                data-placement=\"top\" title=\"\u0E41\u0E01\u0E49\u0E44\u0E02\"><i class=\"fal fa-pencil-alt\"></i></a>\n                                        <a id=\"btnView\" (click)=\"clickView(data.data)\"\n                                                class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\"\n                                                data-placement=\"top\" title=\"\u0E14\u0E39\u0E02\u0E49\u0E2D\u0E21\u0E39\u0E25\"><i class=\"fal fa-eye\"></i></a>\n                                        <a *ngIf=\"data.rowIndex !== 0 && mode !== 'VIEW'\" id=\"btnMoveUp\"\n                                                (click)=\"clickMoveUp(data)\" class=\"btn btn-default btn-sm icon\"\n                                                data-toggle=\"tooltip\" data-placement=\"top\" title=\"\u0E40\u0E25\u0E37\u0E48\u0E2D\u0E19\u0E02\u0E36\u0E49\u0E19\"><i\n                                                        class=\"fal fa-arrow-up\"></i></a>\n                                        <a *ngIf=\"data.rowIndex < data.component.pageSize() -1 && data.rowIndex < attachmentList.length - 1 && mode !== 'VIEW'\"\n                                                id=\"btnMoveDown\" (click)=\"clickMoveDown(data)\"\n                                                class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\"\n                                                data-placement=\"top\" title=\"\u0E40\u0E25\u0E37\u0E48\u0E2D\u0E19\u0E25\u0E07\"><i\n                                                        class=\"fal fa-arrow-down\"></i></a>\n                                        <a id=\"btnDownload\" (click)=\"clickDownload(data.data)\"\n                                                class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\"\n                                                data-placement=\"top\" title=\"\u0E14\u0E32\u0E27\u0E19\u0E4C\u0E42\u0E2B\u0E25\u0E14\"><i\n                                                        class=\"fal fa-download\"></i></a>\n                                </div>\n                        </dx-data-grid>\n                </div>\n        </div>\n</div>\n<!--End col-sm-12-->\n<!--<modal-step #modalStep (onUpdateModal)='getAttachmentList()' (onCreateModal)=\"addAttachmentList($event)\" [mode]=\"mode\"></modal-step>-->\n<modal-attachment #modalAttachment (onModalCreateSubmit)=\"addAttachmentList($event)\"\n        (onModalEditSubmit)=\"editAttachmentList($event)\" [isImage]=\"showImage\"></modal-attachment>\n<modal-attachment-view #modalAttachmentView [isImage]=\"showImage\"></modal-attachment-view>\n<app-alert #myModal (onOkDeleteAttachment)=\"fnDeleteMultiple()\" (onClickBack)=\"onClickBack()\"></app-alert>\n"
                }] }
    ];
    /** @nocollapse */
    AttachmentListComponent.ctorParameters = function () { return [
        { type: AppConfigService },
        { type: Request },
        { type: Common },
        { type: B2bService }
    ]; };
    AttachmentListComponent.propDecorators = {
        mode: [{ type: Input }],
        type: [{ type: Input }],
        option: [{ type: Input }],
        showImage: [{ type: Input }],
        alertModal: [{ type: Input }],
        attachmentModal: [{ type: Input }],
        attachmentViewModal: [{ type: Input }],
        onLoaded: [{ type: Output }],
        onClickScan: [{ type: Output }],
        onClickDelete: [{ type: Output }],
        dxDataGridAttachmentList: [{ type: ViewChild, args: ['dxDataGridAttachmentList',] }],
        modalAttachment: [{ type: ViewChild, args: ['modalAttachment',] }],
        modalAttachmentView: [{ type: ViewChild, args: ['modalAttachmentView',] }],
        myModal: [{ type: ViewChild, args: ['myModal',] }]
    };
    return AttachmentListComponent;
}());
export { AttachmentListComponent };
if (false) {
    /** @type {?} */
    AttachmentListComponent.prototype.mode;
    /** @type {?} */
    AttachmentListComponent.prototype.type;
    /** @type {?} */
    AttachmentListComponent.prototype.option;
    /** @type {?} */
    AttachmentListComponent.prototype.showImage;
    /** @type {?} */
    AttachmentListComponent.prototype.alertModal;
    /** @type {?} */
    AttachmentListComponent.prototype.attachmentModal;
    /** @type {?} */
    AttachmentListComponent.prototype.attachmentViewModal;
    /** @type {?} */
    AttachmentListComponent.prototype.onLoaded;
    /** @type {?} */
    AttachmentListComponent.prototype.onClickScan;
    /** @type {?} */
    AttachmentListComponent.prototype.onClickDelete;
    /** @type {?} */
    AttachmentListComponent.prototype.dxDataGridAttachmentList;
    /** @type {?} */
    AttachmentListComponent.prototype.modalAttachment;
    /** @type {?} */
    AttachmentListComponent.prototype.modalAttachmentView;
    /** @type {?} */
    AttachmentListComponent.prototype.myModal;
    /** @type {?} */
    AttachmentListComponent.prototype.columns;
    /** @type {?} */
    AttachmentListComponent.prototype.attachmentList;
    /** @type {?} */
    AttachmentListComponent.prototype.th;
    /** @type {?} */
    AttachmentListComponent.prototype.dxgridPageSize;
    /** @type {?} */
    AttachmentListComponent.prototype.allowedPageSizes1;
    /** @type {?} */
    AttachmentListComponent.prototype.allowedPageSizes2;
    /** @type {?} */
    AttachmentListComponent.prototype.allowedPageSizes3;
    /** @type {?} */
    AttachmentListComponent.prototype.allowedPageSizes4;
    /** @type {?} */
    AttachmentListComponent.prototype.customers;
    /** @type {?} */
    AttachmentListComponent.prototype.url;
    /** @type {?} */
    AttachmentListComponent.prototype.lastStep;
    /** @type {?} */
    AttachmentListComponent.prototype.config;
    /** @type {?} */
    AttachmentListComponent.prototype.deleteIdList;
    /** @type {?} */
    AttachmentListComponent.prototype.dsAttachment;
    /** @type {?} */
    AttachmentListComponent.prototype.selectedAttachment;
    /** @type {?} */
    AttachmentListComponent.prototype.tmpId;
    /** @type {?} */
    AttachmentListComponent.prototype.classifieds;
    /** @type {?} */
    AttachmentListComponent.prototype.downloadToken;
    /** @type {?} */
    AttachmentListComponent.prototype.username_caption;
    /** @type {?} */
    AttachmentListComponent.prototype.appConfigService;
    /** @type {?} */
    AttachmentListComponent.prototype.request;
    /** @type {?} */
    AttachmentListComponent.prototype.common;
    /** @type {?} */
    AttachmentListComponent.prototype.b2b;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-list.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/attachment-list/attachment-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ViewChild, Input, Output, EventEmitter } from '@angular/core';\nimport { ModalStepComponent } from '../modal-step/modal-step.component';\nimport { AppConfigService } from '../app-config/app-config.service';\nimport { DxDataGridComponent } from 'devextreme-angular';\nimport { Request } from '../_services/request.service';\nimport { Common } from '../_services/common.service';\nimport { ModalStepViewComponent } from '../modal-step-view/modal-step-view.component';\nimport { ModalAttachmentComponent } from '../modal-attachment/modal-attachment.component';\nimport * as _ from 'lodash';\nimport { CreateAlertComponent } from '../alert/alert.component';\nimport { B2bService } from '../_services/b2b.service';\nimport { ModalAttachmentViewComponent } from '../modal-attachment-view/modal-attachment-view.component';\n\n@Component({\n    selector: 'soc-attachment-list',\n    templateUrl: './attachment-list.component.html'\n})\nexport class AttachmentListComponent implements OnInit {\n\n    @Input() mode: 'CREATE' | 'EDIT' | 'VIEW' = 'CREATE';\n    @Input() type: number = 2;\n    @Input() option: any;\n    @Input() showImage: boolean = false;\n    @Input() alertModal: CreateAlertComponent;\n    @Input() attachmentModal: ModalAttachmentComponent;\n    @Input() attachmentViewModal: ModalAttachmentViewComponent;\n    @Output() onLoaded = new EventEmitter();\n    @Output() onClickScan = new EventEmitter();\n    @Output() onClickDelete = new EventEmitter();\n    @ViewChild('dxDataGridAttachmentList')\n    dxDataGridAttachmentList: DxDataGridComponent;\n    // @ViewChild('modalStep')\n    // modalStep: ModalStepComponent;\n    @ViewChild('modalAttachment')\n    modalAttachment: ModalAttachmentComponent;\n    @ViewChild('modalAttachmentView')\n    modalAttachmentView: ModalAttachmentViewComponent;\n    @ViewChild('myModal') myModal;\n\n    columns = ['ลำดับที่', 'ผู้แก้ไข', 'วันที่', 'สถานะการติดตาม', 'หมายเหตุ'];\n    attachmentList: any = [];\n    th;\n    dxgridPageSize = 10;\n    allowedPageSizes1 = 10;\n    allowedPageSizes2 = 25;\n    allowedPageSizes3 = 50;\n    allowedPageSizes4 = 100;\n    customers = [];\n    url;\n    lastStep = '';\n    config: any;\n    deleteIdList = [];\n    dsAttachment = [];\n    selectedAttachment = [];\n    tmpId = -1;\n    classifieds = 0;\n    downloadToken;\n    username_caption = 'ผู้บันทึก/ผู้นำเข้า'\n    constructor(\n        private appConfigService: AppConfigService,\n        private request: Request,\n        private common: Common,\n        private b2b: B2bService\n    ) {\n        this.config = appConfigService.getConfig();\n    }\n\n    async ngOnInit() {\n        setTimeout(async () => {\n            this.downloadToken = await this.b2b.getAttachmentToken();\n        }, 500)\n        if (this.mode !== \"CREATE\") {\n            this.getAttachmentList();\n        }\n    }\n    async getAttachmentList() {\n\n        console.log('getAttachmentList', this.attachmentList, this.option.username_caption);\n        let filter: any = {\n            filter: {\n                ref_table: this.option.data.ref_table,\n                ref_id: this.option.data.ref_id,\n                system_id: this.option.data.system_id\n            },\n            order_by: [\"order_no\"]\n        }\n        if (this.option.data.result_table_id) filter.filter.result_table_id = this.option.data.result_table_id;\n        const data = await this.request.post('/search/rc_attachment_prop', filter);\n        this.attachmentList = data.resultData;\n        this.classifieds = 0;\n        for (let i of this.attachmentList) {\n            if (i.is_classifieds) {\n                this.classifieds++;\n            }\n        }\n        console.log('getAttachmentList', this.attachmentList);\n        this.onLoaded.emit();\n    }\n\n    addAttachmentList(data) {\n        data.id = this.tmpId;\n        this.tmpId--;\n        if (this.b2b.getVerifyToken().phoneBookData && this.b2b.getVerifyToken().phoneBookData.length > 0) {\n            data.username = this.b2b.getVerifyToken().username;\n            data.recorder_name = this.b2b.getVerifyToken().phoneBookData[0].name;\n        }\n        data.action = \"add\";\n        if (data.is_classifieds) {\n            this.classifieds++;\n        }\n        this.attachmentList.push(data);\n        console.log('getAttachmentList', this.attachmentList);\n    }\n\n    editAttachmentList(data) {\n        for (let i = 0; i < this.attachmentList.length; i++) {\n            if (this.attachmentList[i].id === data.id) {\n                if (data.is_classifieds && !this.attachmentList[i].is_classifieds) {\n                    this.classifieds++;\n                } else if (!data.is_classifieds && this.attachmentList[i].is_classifieds) {\n                    this.classifieds--;\n                }\n                this.attachmentList[i] = data;\n            }\n        }\n        console.log('getAttachmentList', this.attachmentList);\n    }\n\n    getRowIndex(data) {\n        if (!data.data) {\n            return '';\n        }\n        data.data.order_no = data.component.pageIndex() * data.component.pageSize() + data.rowIndex + 1;\n        return data.data.order_no;\n    }\n    clickAdd() {\n        this.option.mode = 'CREATE';\n        if (this.attachmentModal) {\n            this.attachmentModal.open(this.option);\n        } else {\n            this.modalAttachment.open(this.option);\n        }\n    }\n    clickEdit(data) {\n        console.log('clickEdit', data)\n        let fileName = data.filename\n        let fileType = fileName.substring(fileName.length - 3, fileName.length)\n        console.log('fileType', fileType)\n        if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {\n            const editData = _.cloneDeep(this.option);\n            editData.data = data;\n            editData.mode = 'EDIT';\n            editData.downloadToken = this.downloadToken;\n            this.onClickScan.emit(editData);\n        } else {\n\n            const editData = _.cloneDeep(this.option);\n            editData.data = data;\n            editData.mode = 'EDIT';\n            editData.downloadToken = this.downloadToken;\n            if (this.attachmentModal) {\n                this.attachmentModal.open(editData);\n            } else {\n                this.modalAttachment.open(editData);\n            }\n        }\n\n    }\n    clickView(data) {\n        let fileName = data.filename\n        let fileType = fileName.substring(fileName.length - 3, fileName.length)\n        console.log('fileType', fileType)\n        if (this.type == 1 && (fileType == 'pdf' || fileType == 'PDF')) {\n            const viewData = _.cloneDeep(this.option);\n            viewData.data = data;\n            viewData.mode = 'VIEW';\n            this.onClickScan.emit(viewData);\n        } else {\n            const viewData = _.cloneDeep(this.option);\n            viewData.data = data;\n            viewData.mode = 'VIEW';\n            viewData.downloadToken = this.downloadToken;\n            if (this.attachmentViewModal) {\n                this.attachmentViewModal.open(viewData);\n            } else {\n                this.modalAttachmentView.open(viewData);\n            }\n        }\n    }\n    clickMoveUp(data) {\n        let tmp = this.attachmentList[data.rowIndex];\n        this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex - 1];\n        this.attachmentList[data.rowIndex - 1] = tmp;\n    }\n    clickMoveDown(data) {\n        let tmp = this.attachmentList[data.rowIndex];\n        this.attachmentList[data.rowIndex] = this.attachmentList[data.rowIndex + 1];\n        this.attachmentList[data.rowIndex + 1] = tmp;\n    }\n    async clickDownload(data) {\n        window.open(data.url + \"?downloadToken=\" + this.downloadToken);\n    }\n    getLastStep() {\n        return this.lastStep;\n    }\n    /** START DELETE */\n    fnClickDelete(idList: any[]) {\n        this.onClickDelete.emit();\n        this.deleteIdList = idList;\n        if (this.deleteIdList.length > 0) {\n            this.confirmDelete();\n        }\n    }\n    confirmDelete() {\n        this.goAlert('', '', 'myModalDeleteAttachment');\n    }\n\n    goAlert(userTitle, userMessage, modalId) {\n        const dataAlert = {\n            'modalId': modalId,\n            'userTitle': userTitle,\n            'userMessage': userMessage\n        };\n        if (this.alertModal) {\n            this.alertModal.openModal(dataAlert);\n        } else {\n            this.myModal.openModal(dataAlert);\n        }\n    }\n\n    onCellPrepared(e) {\n        if (e.rowType === 'data') {\n            e.cellElement.accessKey = e.column.caption;\n        }\n    }\n\n    async fnDeleteMultiple() {\n        console.log(\"this.deleteIdList\", this.deleteIdList);\n        console.log(\"this.attachmentList before\", this.attachmentList);\n        for (let id of this.deleteIdList) {\n            for (let i = this.attachmentList.length - 1; i >= 0; i--) {\n                if (this.attachmentList[i].id === id) {\n                    if (this.attachmentList[i].is_classifieds) {\n                        this.classifieds--;\n                    }\n                    this.attachmentList.splice(i, 1);\n                }\n            }\n        }\n        console.log(\"this.attachmentList after\", this.attachmentList);\n    }\n    onClickBack() {\n        console.log(\"clickback\");\n    }\n\n    getImageLink(data) {\n        return data.url + \"?downloadToken=\" + this.downloadToken;\n    }\n\n    scan() {\n        this.option.mode = 'CREATE';\n        this.onClickScan.emit(this.option);\n    }\n\n}\n"]}