modal-step.component.js 137 KB
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 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Component, EventEmitter, Output, ViewChild } from '@angular/core';
import { ModalDirective } from 'ngx-bootstrap';
import { AppConfigService } from '../app-config/app-config.service';
import { Request } from '../_services/request.service';
import { Common } from '../_services/common.service';
import { FormBuilder, Validators } from '@angular/forms';
import { CustomValidators } from 'ng2-validation';
import { DxDataGridComponent } from 'devextreme-angular';
import * as _ from 'lodash';
import { DateService } from '../_services/date.service';
import { UploadAttachmentComponent } from '../upload-attachment/upload-attachment.component';
import { B2bService } from '../_services/b2b.service';
var Options = /** @class */ (function () {
    function Options() {
    }
    return Options;
}());
if (false) {
    /**
     * title เธ—เธตเนˆเธ•เน‰เธญเธ‡เธเธฒเธฃเนเธชเธ”เธ‡
     * @type {?}
     */
    Options.prototype.title;
    /**
     * data
     * @type {?}
     */
    Options.prototype.data;
}
var ModalStepComponent = /** @class */ (function (_super) {
    tslib_1.__extends(ModalStepComponent, _super);
    function ModalStepComponent(appConfigService, request, formBuilder, common, date, b2bService) {
        var _this = _super.call(this) || this;
        _this.appConfigService = appConfigService;
        _this.request = request;
        _this.formBuilder = formBuilder;
        _this.common = common;
        _this.date = date;
        _this.b2bService = b2bService;
        _this.onUpdateModal = new EventEmitter();
        _this.submitted = false;
        _this.submittedSend = false;
        _this.submittedRecieve = false;
        _this.title = '';
        _this.selectList = [];
        _this.sendList = [];
        _this.recieveList = [];
        _this.modalConfig = {
            ignoreBackdropClick: true
        };
        _this.selectedStep = null;
        _this.isMore = false;
        _this.stepData = {};
        _this.sendData = {};
        _this.recieveData = {};
        _this.lastStep = '';
        _this.isSend = false;
        _this.isRecieve = false;
        _this.isEditSend = false;
        _this.isEditRecieve = false;
        _this.tmpData = {};
        _this.filteredDepartments = [];
        _this.departmentList = [];
        _this.departmentUrl = "/db/ct_ext_department";
        _this.causeUrl = "/db/ct_dropdown";
        _this.causeFilter = "system_id,eq,23)$and(dropdown_type,like,เน€เธฃเธทเนˆเธญเธ‡เธชเนˆเธ‡เธ„เธทเธ™";
        _this.tempId = -1;
        _this.filter_ref_ext_department_id = false;
        _this.filter_ref_ext_department_id_show = true;
        _this.config = appConfigService.getConfig();
        _this.attachmentUrl = _.get(_this.config, 'apiServers.alfresco.url') || "https://203.154.32.126:2585/api/mfec/Alfresco";
        _this.system_id = _.get(_this.config, 'system_id');
        return _this;
    }
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        this.th = this.common.fnLocalPCalendar('th');
        this.recieveForm = this.formBuilder.group({
            book_no: ['', [Validators.required]],
            recv_date: [''],
        });
        this.sendForm = this.formBuilder.group({
            send_to: [''],
            book_no: [''],
            send_date: [''],
            is_important: [''],
        });
        this.registerForm = this.formBuilder.group({
            name: [''],
            step_id: ['', Validators.required],
            step_date: [''],
            remark: [''],
            lastStep: [''],
            moreField: this.formBuilder.array([]),
            soc_recv_no: [''],
            soc_recv_date: [''],
            gtc_recv_no: [''],
            gtc_recv_date: [''],
            book_no: [''],
            book_date: [''],
            'for': [''],
            dept_name: [''],
            ministry: ['']
        });
    };
    /**
     * @param {?=} options
     * @return {?}
     */
    ModalStepComponent.prototype.open = /**
     * @param {?=} options
     * @return {?}
     */
    function (options) {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var _a;
            return tslib_1.__generator(this, function (_b) {
                switch (_b.label) {
                    case 0:
                        console.log(options);
                        this.stepData = {};
                        if (!options) return [3 /*break*/, 2];
                        this.title = options.title || '';
                        this.lastStep = options.data.lastStep;
                        this.stepData = JSON.parse(JSON.stringify(options.data));
                        this.stepData.step_date = this.date.getNow();
                        delete this.stepData['lastStep'];
                        _a = this;
                        return [4 /*yield*/, this.request.get('/db/ct_step?_where=(category_id,eq,' + options.data.category_id + ')&_sort=seq_no')];
                    case 1:
                        _a.selectList = _b.sent();
                        _b.label = 2;
                    case 2:
                        this.uploadAttachment.clearValue();
                        this.modal.show();
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.f = /**
     * @return {?}
     */
    function () { return this.registerForm.controls; };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.fs = /**
     * @return {?}
     */
    function () { return this.sendForm.controls; };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.fr = /**
     * @return {?}
     */
    function () { return this.recieveForm.controls; };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.closeModal = /**
     * @return {?}
     */
    function () {
        this.submitted = false;
        this.selectList = [];
        this.sendList = [];
        this.selectedStep = null;
        this.isMore = false;
        this.isSend = false;
        this.moreField = [];
        this.stepData = {};
        this.lastStep = '';
        this.modal.hide();
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.closeSendModal = /**
     * @return {?}
     */
    function () {
        this.submittedSend = false;
        this.sendData = {};
        this.isEditSend = false;
        this.tmpData = {};
        this.sendModal.hide();
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.closeRecieveModal = /**
     * @return {?}
     */
    function () {
        this.submittedRecieve = false;
        this.recieveData = {};
        this.isEditRecieve = false;
        this.tmpData = {};
        this.recieveModal.hide();
    };
    /**
     * @param {?} modal
     * @return {?}
     */
    ModalStepComponent.prototype.onYesClick = /**
     * @param {?} modal
     * @return {?}
     */
    function (modal) {
        modal.hide();
    };
    /**
     * @param {?} modal
     * @return {?}
     */
    ModalStepComponent.prototype.onNoClick = /**
     * @param {?} modal
     * @return {?}
     */
    function (modal) {
        modal.hide();
    };
    /**
     * @param {?} $event
     * @return {?}
     */
    ModalStepComponent.prototype.onHidden = /**
     * @param {?} $event
     * @return {?}
     */
    function ($event) {
        console.log('LOG MESSAGE: ModalConfirm -> onHidden -> $event', $event);
    };
    /**
     * @param {?} value
     * @return {?}
     */
    ModalStepComponent.prototype.valueSeleteMinistry = /**
     * @param {?} value
     * @return {?}
     */
    function (value) {
        var _this = this;
        this.filter_ref_ext_department_id_show = false;
        console.log('value', value);
        // this.stepData.ministry_id = value && value.id ? value.id : null
        if (value && value.id) {
            this.stepData.dept_name = null;
            this.filter_ref_ext_department_id = "&_where=(ref_ext_department_id,eq," + value.id + ")$and(type,in,2,3,4,5)";
        }
        else {
            this.filter_ref_ext_department_id = false;
        }
        setTimeout(function () {
            _this.filter_ref_ext_department_id_show = true;
        }, 50);
    };
    /**
     * @param {?} value
     * @return {?}
     */
    ModalStepComponent.prototype.valueSeleteDeptName = /**
     * @param {?} value
     * @return {?}
     */
    function (value) {
        console.log('value', value);
        this.stepData.code_dept = value && value.id ? value.id : null;
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.checkExtraField = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var i, flag, requireFlag, ct_step_flag, newField, _a;
            return tslib_1.__generator(this, function (_b) {
                switch (_b.label) {
                    case 0:
                        this.stepData.step_id = this.selectedStep.id;
                        this.stepData.step_name = this.selectedStep.name;
                        console.log(this.isMore);
                        this.moreField = [];
                        if (!(this.selectedStep.flag && this.selectedStep.flag !== '')) return [3 /*break*/, 6];
                        i = 0;
                        _b.label = 1;
                    case 1:
                        if (!(i < this.selectedStep.flag.length)) return [3 /*break*/, 5];
                        flag = this.selectedStep.flag.charAt(i);
                        requireFlag = this.selectedStep.require_flag ? this.selectedStep.require_flag.charAt(i) : 0;
                        return [4 /*yield*/, this.request.get('/db/ct_step_flag?_where=(flag,eq,' + flag + ')')];
                    case 2:
                        ct_step_flag = _b.sent();
                        newField = ct_step_flag[0];
                        return [4 /*yield*/, this.addField(newField, +requireFlag)];
                    case 3:
                        _b.sent();
                        this.moreField.push(newField);
                        console.log(this.f);
                        _b.label = 4;
                    case 4:
                        i++;
                        return [3 /*break*/, 1];
                    case 5:
                        this.isMore = true;
                        this.isSend = false;
                        this.isRecieve = false;
                        return [3 /*break*/, 9];
                    case 6:
                        this.isMore = false;
                        if (!(this.selectedStep.type_id === 8 || this.selectedStep.type_id === 13)) return [3 /*break*/, 8];
                        _a = this;
                        return [4 /*yield*/, this.request.get('/db/ct_ext_department?_sort=name')];
                    case 7:
                        _a.departmentList = _b.sent();
                        this.departmentList = this.departmentList.map(function (a) { return a.name; });
                        this.isSend = true;
                        this.isRecieve = false;
                        // } else if (this.selectedStep.type_id === 9 || this.selectedStep.type_id === 14) {
                        //     const data = await this.request.post('/sql/getLastSend', this.stepData);
                        //     if (data.resultData && data.resultData.length > 0) {
                        //         const ct_step_data_id = data.resultData[0].id;
                        //         const ct_sendList = await this.request.get('/db/ct_send?_where=(ct_step_data_id,eq,' + ct_step_data_id + ')');
                        //         for (const ct_send of ct_sendList) {
                        //             const recvData: any = {
                        //                 ct_send_id: ct_send.id,
                        //                 send_book_no: ct_send.book_no,
                        //                 send_date: ct_send.send_date,
                        //                 recv_from: ct_send.send_to,
                        //                 name: ct_send.name
                        //             };
                        //             this.recieveList.push(recvData);
                        //         }
                        //     }
                        //     this.isRecieve = true;
                        //     this.isSend = false;
                        return [3 /*break*/, 9];
                    case 8:
                        this.isSend = false;
                        this.isRecieve = false;
                        _b.label = 9;
                    case 9: return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.getFieldId = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var id = '';
        if (data.type === 'text') {
            id += 'txt';
        }
        else if (data.type === 'datetime') {
            id += 'txt';
        }
        else {
            id += 'txt';
        }
        /** @type {?} */
        var field = data.field_name.charAt(0).toLocaleUpperCase() + data.field_name.substring(1);
        id += field;
        return id;
    };
    /**
     * @param {?} data
     * @param {?} required
     * @return {?}
     */
    ModalStepComponent.prototype.addField = /**
     * @param {?} data
     * @param {?} required
     * @return {?}
     */
    function (data, required) {
        /** @type {?} */
        var control = /** @type {?} */ (this.registerForm.controls['moreField']);
        /** @type {?} */
        var newgroup;
        this.stepData[data.field_name] = null;
        if (data.type === 'text') {
            if (required) {
                /** @type {?} */
                var group = {};
                group[data.field_name] = ['', Validators.required];
                newgroup = this.formBuilder.group(group);
            }
            else {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [''];
                newgroup = this.formBuilder.group(group);
            }
        }
        else if (data.type === 'datetime') {
            if (required) {
                /** @type {?} */
                var group = {};
                group[data.field_name] = ['', Validators.required, CustomValidators.date];
                newgroup = this.formBuilder.group(group);
            }
            else {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [''];
                newgroup = this.formBuilder.group(group);
            }
            this.stepData[data.field_name] = this.date.getNow();
        }
        else if (data.type === 'number') {
            if (required) {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [Validators.required];
                newgroup = this.formBuilder.group(group);
            }
            else {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [''];
                newgroup = this.formBuilder.group(group);
            }
        }
        else if (data.type === 'special') {
            if (data.field_name === 'amount') {
                if (required) {
                    /** @type {?} */
                    var group = {};
                    group[data.field_name] = ['', Validators.required];
                    group['amount_type'] = ['', Validators.required];
                    newgroup = this.formBuilder.group(group);
                }
                else {
                    /** @type {?} */
                    var group = {};
                    group[data.field_name] = [''];
                    group['amount_type'] = [''];
                    newgroup = this.formBuilder.group(group);
                }
            }
            else if (data.field_name === 'follow') {
                if (required) {
                    /** @type {?} */
                    var group = {};
                    group[data.field_name] = ['', Validators.required];
                    group['follow_remark'] = ['', Validators.required];
                    newgroup = this.formBuilder.group(group);
                }
                else {
                    /** @type {?} */
                    var group = {};
                    group[data.field_name] = [''];
                    group['follow_remark'] = [''];
                    newgroup = this.formBuilder.group(group);
                }
            }
            else {
                if (required) {
                    /** @type {?} */
                    var group = {};
                    group[data.field_name] = ['', Validators.required];
                    newgroup = this.formBuilder.group(group);
                }
                else {
                    /** @type {?} */
                    var group = {};
                    group[data.field_name] = [''];
                    newgroup = this.formBuilder.group(group);
                }
            }
        }
        control.push(newgroup);
    };
    /**
     * @param {?} i
     * @param {?} field
     * @param {?=} validateType
     * @return {?}
     */
    ModalStepComponent.prototype.getValidateMoreField = /**
     * @param {?} i
     * @param {?} field
     * @param {?=} validateType
     * @return {?}
     */
    function (i, field, validateType) {
        /** @type {?} */
        var formMoreField = this.f()['moreField'];
        if (validateType) {
            formMoreField = formMoreField.controls[i];
            formMoreField = formMoreField.controls[field];
            if (formMoreField.errors) {
                return formMoreField.errors[validateType];
            }
            else {
                return formMoreField.errors;
            }
        }
        else {
            return formMoreField.errors;
        }
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.getRowIndex = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        if (!data.data) {
            return '';
        }
        /** @type {?} */
        var no = data.row.dataIndex + 1;
        return no;
    };
    /**
     * @param {?} e
     * @return {?}
     */
    ModalStepComponent.prototype.onCellPrepared = /**
     * @param {?} e
     * @return {?}
     */
    function (e) {
        if (e.rowType === 'data') {
            for (var i in e.component.columns) {
                if (e.column.dataField === e.component.columns[i]) {
                    e.cellElement.accessKey = e.component.columns[i];
                }
            }
        }
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.addSend = /**
     * @return {?}
     */
    function () {
        this.sendData.send_date = this.date.getNow();
        this.sendModal.show();
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.editSend = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        this.tmpData = data;
        this.sendData = JSON.parse(JSON.stringify(data));
        // this.sendData.send_date = new Date(this.sendData.send_date);
        this.isEditSend = true;
        this.sendModal.show();
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.editRecieve = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        this.tmpData = data;
        this.recieveData = JSON.parse(JSON.stringify(data));
        this.recieveData.recv_date = this.recieveData.recv_date ? new Date(this.recieveData.recv_date) : this.recieveData.recv_date;
        this.isEditRecieve = true;
        this.recieveModal.show();
    };
    /**
     * @param {?} event
     * @return {?}
     */
    ModalStepComponent.prototype.filterDepartments = /**
     * @param {?} event
     * @return {?}
     */
    function (event) {
        this.filteredDepartments = [];
        for (var i = 0; i < this.departmentList.length; i++) {
            /** @type {?} */
            var department = this.departmentList[i];
            if (department.toLowerCase().indexOf(event.query.toLowerCase()) == 0) {
                this.filteredDepartments.push(department);
            }
        }
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.onSubmit = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var e_1, _a, e_2, _b, postData, data, userData, main, ct_send, ct_recieve, _c, _d, data_1, ct_recieve, _e, _f, data_2, postResponse, stepList;
            return tslib_1.__generator(this, function (_g) {
                switch (_g.label) {
                    case 0:
                        this.submitted = true;
                        // เธ–เน‰เธฒ form เน„เธกเนˆเธ„เธฃเธšเธซเธฃเธทเธญเธœเธดเธ”เธ•เธฒเธกเน€เธ‡เธทเนˆเธญเธ™เน„เธ‚เธ—เธตเนˆเธ•เธฑเน‰เธ‡เน„เธงเน‰เธˆเธฐเธˆเธšเธ—เธตเนˆเธ•เธฃเธ‡เธ™เธตเน‰
                        console.log('this.registerForm.invalid: ', this.registerForm.invalid);
                        if (this.registerForm.invalid) {
                            return [2 /*return*/];
                        }
                        postData = [];
                        data = _.cloneDeep(this.stepData);
                        data.action = "add";
                        userData = this.b2bService.getVerifyToken();
                        data.username = userData.username;
                        if (data.remind_date)
                            data.remind_date = this.date.getNow().add(data.remind_date, 'd').toDate();
                        delete data["ct_main_id"];
                        delete data["update_date"];
                        main = {
                            "ct_step_data": [data]
                        };
                        postData.push(main);
                        if (this.sendList && this.sendList.length > 0) {
                            ct_send = {
                                "ct_send": []
                            };
                            ct_recieve = {
                                "ct_recieve": []
                            };
                            try {
                                for (_c = tslib_1.__values(this.sendList), _d = _c.next(); !_d.done; _d = _c.next()) {
                                    data_1 = _d.value;
                                    data_1.name = data_1.name;
                                    data_1.action = "add";
                                    delete data_1.id;
                                    ct_send.ct_send.push(data_1);
                                }
                            }
                            catch (e_1_1) { e_1 = { error: e_1_1 }; }
                            finally {
                                try {
                                    if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
                                }
                                finally { if (e_1) throw e_1.error; }
                            }
                            postData.push(ct_send);
                        }
                        if (this.recieveList && this.recieveList.length > 0) {
                            ct_recieve = {
                                "ct_recieve": []
                            };
                            try {
                                for (_e = tslib_1.__values(this.recieveList), _f = _e.next(); !_f.done; _f = _e.next()) {
                                    data_2 = _f.value;
                                    delete data_2['send_book_no'];
                                    delete data_2['send_date'];
                                    data_2.name = data_2.name;
                                    data_2.action = "add";
                                    ct_recieve.ct_recieve.push(data_2);
                                }
                            }
                            catch (e_2_1) { e_2 = { error: e_2_1 }; }
                            finally {
                                try {
                                    if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
                                }
                                finally { if (e_2) throw e_2.error; }
                            }
                            postData.push(ct_recieve);
                        }
                        console.log('postData', postData);
                        return [4 /*yield*/, this.request.post("/ct/main", postData)];
                    case 1:
                        postResponse = _g.sent();
                        if (!this.stepData.update_date) return [3 /*break*/, 5];
                        return [4 /*yield*/, this.getStepList()];
                    case 2:
                        stepList = _g.sent();
                        console.log("stepList", stepList);
                        if (!(stepList.length > 0)) return [3 /*break*/, 4];
                        return [4 /*yield*/, this.request.put("/db/" + this.stepData.ref_table + "/" + this.stepData.ref_id, { status: stepList[0].step_name, status_date: stepList[0].step_date })];
                    case 3:
                        _g.sent();
                        this.common.fnCheckResponse(postResponse, this.myModal);
                        _g.label = 4;
                    case 4: return [3 /*break*/, 7];
                    case 5: return [4 /*yield*/, this.request.put("/db/" + this.stepData.ref_table + "/" + this.stepData.ref_id, { status: this.stepData.step_name })];
                    case 6:
                        _g.sent();
                        this.common.fnCheckResponse(postResponse, this.myModal);
                        _g.label = 7;
                    case 7:
                        // }else{
                        //     this.onCreateModal.emit(postData);
                        // }
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.getStepList = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var filter, data;
            return tslib_1.__generator(this, function (_a) {
                switch (_a.label) {
                    case 0:
                        console.log('getStepList');
                        filter = {
                            filter: {
                                ref_table: "=" + this.stepData.ref_table,
                                ref_id: this.stepData.ref_id,
                                system_id: this.stepData.system_id
                            },
                            order_by: ["step_date desc"]
                        };
                        return [4 /*yield*/, this.request.post('/search/ct_step_data', filter)];
                    case 1:
                        data = _a.sent();
                        return [2 /*return*/, data.resultData || []];
                }
            });
        });
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.onClickBack = /**
     * @return {?}
     */
    function () {
        this.onUpdateModal.emit();
        this.closeModal();
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.onSubmitSend = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var e_3, _a, tmpList, _b, _c, tmpSend;
            return tslib_1.__generator(this, function (_d) {
                this.submittedSend = true;
                // เธ–เน‰เธฒ form เน„เธกเนˆเธ„เธฃเธšเธซเธฃเธทเธญเธœเธดเธ”เธ•เธฒเธกเน€เธ‡เธทเนˆเธญเธ™เน„เธ‚เธ—เธตเนˆเธ•เธฑเน‰เธ‡เน„เธงเน‰เธˆเธฐเธˆเธšเธ—เธตเนˆเธ•เธฃเธ‡เธ™เธตเน‰
                if (this.sendForm.invalid) {
                    return [2 /*return*/];
                }
                if (this.isEditSend) {
                    tmpList = [];
                    try {
                        for (_b = tslib_1.__values(this.sendList), _c = _b.next(); !_c.done; _c = _b.next()) {
                            tmpSend = _c.value;
                            if (tmpSend.id === this.tmpData.id) {
                                tmpList.push(this.sendData);
                            }
                            else {
                                tmpList.push(tmpSend);
                            }
                        }
                    }
                    catch (e_3_1) { e_3 = { error: e_3_1 }; }
                    finally {
                        try {
                            if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
                        }
                        finally { if (e_3) throw e_3.error; }
                    }
                    this.sendList = tmpList;
                }
                else {
                    this.sendData.id = this.tempId;
                    this.tempId--;
                    this.sendList.push(this.sendData);
                }
                this.closeSendModal();
                return [2 /*return*/];
            });
        });
    };
    /**
     * @return {?}
     */
    ModalStepComponent.prototype.onSubmitRecieve = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var e_4, _a, tmpList, _b, _c, tmpSend;
            return tslib_1.__generator(this, function (_d) {
                this.submittedSend = true;
                // เธ–เน‰เธฒ form เน„เธกเนˆเธ„เธฃเธšเธซเธฃเธทเธญเธœเธดเธ”เธ•เธฒเธกเน€เธ‡เธทเนˆเธญเธ™เน„เธ‚เธ—เธตเนˆเธ•เธฑเน‰เธ‡เน„เธงเน‰เธˆเธฐเธˆเธšเธ—เธตเนˆเธ•เธฃเธ‡เธ™เธตเน‰
                if (this.recieveForm.invalid) {
                    return [2 /*return*/];
                }
                if (this.isEditRecieve) {
                    tmpList = [];
                    try {
                        for (_b = tslib_1.__values(this.recieveList), _c = _b.next(); !_c.done; _c = _b.next()) {
                            tmpSend = _c.value;
                            if (tmpSend.recv_from === this.tmpData.recv_from) {
                                tmpList.push(this.recieveData);
                            }
                            else {
                                tmpList.push(tmpSend);
                            }
                        }
                    }
                    catch (e_4_1) { e_4 = { error: e_4_1 }; }
                    finally {
                        try {
                            if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
                        }
                        finally { if (e_4) throw e_4.error; }
                    }
                    this.recieveList = tmpList;
                }
                else {
                    this.recieveList.push(this.recieveData);
                }
                this.closeRecieveModal();
                return [2 /*return*/];
            });
        });
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.isImportant = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        return data.is_important ? "เธชเธณเธ„เธฑเธ" : "";
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.onUploaded = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        this.stepData.url = this.attachmentUrl + '/' + data.uuid;
        this.stepData.uuid = data.uuid;
    };
    /**
     * @param {?} field
     * @return {?}
     */
    ModalStepComponent.prototype.checkDisable = /**
     * @param {?} field
     * @return {?}
     */
    function (field) {
        if (this.stepData[field.field_name] !== 'เน„เธกเนˆเธ—เธฒเธ‡เธเธฒเธฃ') {
            return true;
        }
        else {
            return false;
        }
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalStepComponent.prototype.getImageLink = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var url;
            return tslib_1.__generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this.request.getAttachmentLinkToken(data.url)];
                    case 1:
                        url = _a.sent();
                        return [2 /*return*/, url];
                }
            });
        });
    };
    ModalStepComponent.decorators = [
        { type: Component, args: [{
                    selector: 'modal-step',
                    template: "<div class=\"modal fade\" bsModal #modal=\"bs-modal\" [config]=\"{backdrop: 'static'}\"\n     tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"dialog-static-name1\">\n    <div class=\"modal-dialog modal-lg\">\n        <div class=\"modal-content\">\n            <div class=\"modal-header\">\n                <h4 id=\"dialog-static-name\" class=\"modal-title pull-left\"><label>{{title}}</label></h4>\n                <button type=\"button\" class=\"close pull-right\" aria-label=\"Close\" (click)=\"closeModal()\">\n                    <span aria-hidden=\"true\">&times;</span>\n                </button>\n            </div>\n            <div class=\"modal-body\">\n                <div class=\"row\">\n                    <div class=\"col-lg-12\">\n                        <form class=\"m-form m-form--state m-form--fit m-form--label-align-right\" [formGroup]=\"registerForm\" (ngSubmit)=\"onSubmit()\">\n                            <div class=\"m-portlet__body\">\n\n                                <!-- \u0E2A\u0E16\u0E32\u0E19\u0E30\u0E25\u0E48\u0E32\u0E2A\u0E38\u0E14 -->\n                                <div class=\"row\">\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E2A\u0E16\u0E32\u0E19\u0E30\u0E1B\u0E31\u0E08\u0E08\u0E38\u0E1A\u0E31\u0E19 :</span>-->\n                                    <!--</div>-->\n                                    <div class=\"col-sm-6\">\n                                        <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().lastStep.errors }\">\n                                            <label class=\"control-label\">\u0E2A\u0E16\u0E32\u0E19\u0E30\u0E1B\u0E31\u0E08\u0E08\u0E38\u0E1A\u0E31\u0E19</label>\n                                            <input type=\"text\" formControlName=\"lastStep\" class=\"form-control m-input\" id=\"txtLastStatus\" [(ngModel)]=\"lastStep\" disabled>\n                                        </div>\n                                    </div>\n                                    <div class=\"col-sm-6\">\n                                        <!--<select id=\"selNewStatus\" style=\"width: 100%\">-->\n                                        <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().step_id.errors }\">\n                                            <label class=\"control-label\">\u0E2A\u0E16\u0E32\u0E19\u0E30\u0E43\u0E2B\u0E21\u0E48<span class=\"color-red\">&nbsp;*</span></label>\n                                            <select id=\"selNewStatus\" class=\"form-control\" style=\"width: 100%\" [(ngModel)]=\"selectedStep\" formControlName=\"step_id\" (change)=\"checkExtraField()\">\n                                                <option value=\"null\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E40\u0E25\u0E37\u0E2D\u0E01\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23</option>\n                                                <option *ngFor=\"let step of selectList\" [ngValue]=\"step\">{{step.name}}</option>\n                                            </select>\n                                            <!-- <div *ngIf=\"submitted && f().step_id.errors\" class=\"invalid-feedback\">\n                                                <div *ngIf=\"f().step_id.errors.required\"><font color=\"red\"> * \u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01</font></div>\n                                            </div> -->\n                                        </div>\n                                    </div>\n                                </div>\n                                <br>\n                                <!--<div class=\"row\">-->\n                                    <!-- \u0E2A\u0E16\u0E32\u0E19\u0E30\u0E43\u0E2B\u0E21\u0E48 -->\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E2A\u0E16\u0E32\u0E19\u0E30\u0E43\u0E2B\u0E21\u0E48 :</span>-->\n                                    <!--</div>-->\n                                <!--</div>-->\n                                <!--<br>-->\n                                <div class=\"row\">\n                                    <!-- \u0E27\u0E31\u0E19\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 -->\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 :</span>-->\n                                    <!--</div>-->\n                                    <div class=\"col-sm-6\">\n                                        <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().step_date.errors }\">\n                                            <label class=\"control-label\" *ngIf=\"stepData.system_id === 161\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48</label>\n                                            <label class=\"control-label\" *ngIf=\"stepData.system_id !== 161\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23</label>\n                                            <soc-date-box [id]=\"'txtDate'\" [(value)]=\"stepData.step_date\"></soc-date-box>\n                                            <div *ngIf=\"submitted && f().step_date.errors\" >\n                                                <div *ngIf=\"f().step_date.errors.required\" class=\"lable-error\">Date is required</div>\n                                                <div *ngIf=\"f().step_date.errors.date\" class=\"lable-error\">Date is invalid</div>\n                                            </div>\n                                        </div>\n                                    </div>\n                                </div>\n                                <br>\n                                \n                                \n                                \n                                <!--<div class=\"row\" *ngIf=\"stepData.system_id === 23\">-->\n                                    <!-- \u0E27\u0E31\u0E19\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 -->\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 :</span>-->\n                                    <!--</div>-->\n                                <!--    <div class=\"col-sm-6\">-->\n                                <!--      <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D</label>-->\n                                <!--      <input type=\"text\" class=\"form-control m-input\" id=\"book_no\" [(ngModel)]=\"stepData.book_no\"-->\n                                <!--      formControlName=\"book_no\">-->\n                                <!--  </div>-->\n                                <!--  <div class=\"col-sm-6\">-->\n                                <!--      <label class=\"control-label\">\u0E25\u0E07\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48</label>-->\n                                <!--      <soc-date-box [id]=\"'book_date'\" [(value)]=\"stepData.book_date\" formControlName=\"book_date\"></soc-date-box>-->\n                                      <!-- <input type=\"text\" class=\"form-control m-input\" id=\"book_date\" [(ngModel)]=\"stepData.book_date\"-->\n                                <!--      formControlName=\"book_date\"> -->\n                                <!--  </div>-->\n\n                                <!--</div>-->\n                                <!--<br>-->\n                                <!--<div class=\"row\" *ngIf=\"stepData.system_id === 23\">-->\n                                    <!-- \u0E27\u0E31\u0E19\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 -->\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 :</span>-->\n                                    <!--</div>-->\n                                <!--     <div class=\"col-sm-6\">-->\n                                <!--        <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A \u0E2A\u0E25\u0E04.</label>-->\n                                <!--        <input type=\"text\" class=\"form-control m-input\" id=\"soc_recv_no\" formControlName=\"soc_recv_no\" [(ngModel)]=\"stepData.soc_recv_no\">-->\n                                <!--    </div>-->\n                                <!--    <div class=\"col-sm-6\">-->\n                                <!--        <label class=\"control-label\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A \u0E2A\u0E25\u0E04.</label>-->\n                                <!--        <soc-date-box [id]=\"'soc_recv_date'\" [(value)]=\"stepData.soc_recv_date\" formControlName=\"soc_recv_date\"></soc-date-box>-->\n                                <!--    </div>-->\n                                <!--</div>-->\n                                <!--<br>-->\n                                <!--<div class=\"row\" *ngIf=\"stepData.system_id === 23\">-->\n                                    <!-- \u0E27\u0E31\u0E19\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 -->\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23 :</span>-->\n                                    <!--</div>-->\n                                <!--     <div class=\"col-sm-6\">-->\n                                <!--      <label class=\"control-label\">\u0E2B\u0E19\u0E48\u0E27\u0E22\u0E07\u0E32\u0E19\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A-\u0E2A\u0E48\u0E07</label>-->\n                                <!--      <input type=\"text\" class=\"form-control m-input\" id=\"dept_name\" [(ngModel)]=\"stepData.dept_name\" formControlName=\"dept_name\">-->\n                                <!--  </div>-->\n                                <!--</div>-->\n                                <!--<br>-->\n                                \n                                \n                                \n                                <div class=\"row\" *ngIf=\"stepData.system_id === 23\">\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A \u0E2A\u0E25\u0E04.</label>\n                                        <input type=\"text\" class=\"form-control m-input\" id=\"soc_recv_no\" formControlName=\"soc_recv_no\" [(ngModel)]=\"stepData.soc_recv_no\">\n                                    </div>\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A \u0E2A\u0E25\u0E04.</label>\n                                        <soc-date-box [id]=\"'soc_recv_date'\" [(value)]=\"stepData.soc_recv_date\" formControlName=\"soc_recv_date\"></soc-date-box>\n                                    </div>\n                                </div>\n                                <br>\n                                <div class=\"row\" *ngIf=\"stepData.system_id === 23\">\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A \u0E01\u0E2D\u0E04.</label>\n                                        <input type=\"text\" class=\"form-control m-input\" id=\"gtc_recv_no\" [(ngModel)]=\"stepData.gtc_recv_no\" formControlName=\"gtc_recv_no\">\n                                    </div>\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A \u0E01\u0E2D\u0E04.</label>\n                                        <soc-date-box [id]=\"'gtc_recv_date'\" [(value)]=\"stepData.gtc_recv_date\" formControlName=\"gtc_recv_date\"></soc-date-box>\n                                    </div>\n                                </div>\n                                <br>\n                                <div class=\"row\" *ngIf=\"stepData.system_id === 23\">\n                                  <div class=\"col-sm-6\">\n                                      <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D</label>\n                                      <input type=\"text\" class=\"form-control m-input\" id=\"book_no\" [(ngModel)]=\"stepData.book_no\"\n                                      formControlName=\"book_no\">\n                                  </div>\n                                  <div class=\"col-sm-6\">\n                                      <label class=\"control-label\">\u0E25\u0E07\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48</label>\n                                      <soc-date-box [id]=\"'book_date'\" [(value)]=\"stepData.book_date\" formControlName=\"book_date\"></soc-date-box>\n                                      <!-- <input type=\"text\" class=\"form-control m-input\" id=\"book_date\" [(ngModel)]=\"stepData.book_date\"\n                                      formControlName=\"book_date\"> -->\n                                  </div>\n                                </div>\n                                <br>\n                                <div class=\"row\" *ngIf=\"stepData.system_id === 23\">\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E40\u0E23\u0E35\u0E22\u0E19</label>\n                                        <input type=\"text\" class=\"form-control m-input\" id=\"for\" [(ngModel)]=\"stepData.for\" formControlName=\"for\">\n                                    </div>\n\n                                </div>\n                                <br>\n                                <div class=\"row\" *ngIf=\"stepData.system_id === 23\">\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E01\u0E23\u0E30\u0E17\u0E23\u0E27\u0E07</label>\n                                        <soc-auto-complete-2 [id]=\"'ministry'\"  mode=\"local\"\n                                          [api]=\"'/db/ct_ext_department'\" [acceptCustomValue]=\"false\" field=\"name\" fieldApi=\"id,name,code,type\"\n                                          [filter]=\"'&_where=(type,in,1,9)'\" (valueSelete)=\"valueSeleteMinistry($event)\"\n                                          [(value)]=\"stepData.ministry\" [(ngModel)]=\"stepData.ministry\"\n                                          formControlName=\"ministry\">\n                                        </soc-auto-complete-2>\n                                    </div>\n                                    <div class=\"col-sm-6\">\n                                        <label class=\"control-label\">\u0E01\u0E23\u0E21</label>\n                                        <div *ngIf=\"filter_ref_ext_department_id_show\">\n                                        <soc-auto-complete-2 [acceptCustomValue]=\"false\" [id]=\"'dept_name'\"\n                                          mode=\"local\" [filter]=\"filter_ref_ext_department_id\"\n                                           [api]=\"'/db/ct_ext_department'\" field=\"name\"\n                                          fieldApi=\"id,name,code,type\" [(value)]=\"stepData.dept_name\" (valueSelete)=\"valueSeleteDeptName($event)\"\n                                          [(ngModel)]=\"stepData.dept_name\" [disabled]=\"!filter_ref_ext_department_id\"\n                                          formControlName=\"dept_name\">\n                                        </soc-auto-complete-2>\n                                        </div>\n                                    </div>\n\n                                </div>\n                                <br>\n                                \n                                <!-- \u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38 -->\n                                <div class=\"row\">\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38 :</span>-->\n                                    <!--</div>-->\n                                    <div class=\"col-sm-12\">\n                                        <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().remark.errors }\">\n                                            <label class=\"control-label\">\u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38</label>\n                                            <textarea class=\"form-control m-input\" id=\"txtRemark\" rows=\"5\" formControlName=\"remark\" [(ngModel)]=\"stepData.remark\"></textarea>\n                                        </div>\n                                    </div>\n                                </div>\n                                <br>\n                                <!-- \u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\u0E41\u0E19\u0E1A -->\n                                <div class=\"row\">\n                                    <!--<div class=\"col-sm-3\">-->\n                                        <!--<span>\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\u0E41\u0E19\u0E1A :</span>-->\n                                    <!--</div>-->\n                                    <div class=\"col-sm-12\">\n                                        <label class=\"control-label\">\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\u0E41\u0E19\u0E1A</label>\n                                        <upload-attachment #uploadAttachment [systemId]=\"stepData.system_id\" (uploaded)=\"onUploaded($event)\"></upload-attachment>\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                                        <!--&gt;-->\n                                            <!--&lt;!&ndash;<div *dxTemplate=\"let type of upLoadType\">&ndash;&gt;-->\n                                                <!--&lt;!&ndash;<span>{{type.name.toUpperCase()}}</span>&ndash;&gt;-->\n                                            <!--&lt;!&ndash;</div>&ndash;&gt;-->\n                                            <!--<div *dxTemplate=\"let item of 'itemTemplate'\">-->\n                                                <!--<div class=\"tabpanel-item\">-->\n                                                    <!--<div *ngIf=\"item.type === 1\">-->\n                                                        <!--<div class=\"col-sm-10\" style=\"text-align: center\">-->\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                                                        <!--</div>-->\n                                                    <!--</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        <!--</dx-tab-panel>-->\n                                    </div>\n                                </div>\n                                <br>\n                                <!-- field \u0E40\u0E1E\u0E34\u0E48\u0E21\u0E40\u0E15\u0E34\u0E21 -->\n                                <div *ngIf=\"isMore\">\n                                    <div formArrayName=\"moreField\">\n                                        <div *ngFor=\"let field of moreField; let i=index\">\n                                            <div [formGroupName]=\"i\">\n                                                <div class=\"row\">\n                                                    <!--<div class=\"col-sm-3\">-->\n                                                        <!--<span>field.display_name :</span>-->\n                                                    <!--</div>-->\n                                                    <!-- field \u0E40\u0E1E\u0E34\u0E48\u0E21\u0E40\u0E15\u0E34\u0E21 type text -->\n                                                    <div *ngIf=\"field.type === 'text'\">\n                                                        <div class=\"col-sm-12\">\n                                                            <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,field.field_name) }\">\n                                                                <label class=\"control-label\">{{field.display_name}}</label>\n                                                                <input type=\"text\" class=\"form-control m-input\" [id]=\"getFieldId(field)\" [formControlName]=\"field.field_name\" [(ngModel)]=\"stepData[field.field_name]\">\n                                                                <div *ngIf=\"submitted && getValidateMoreField(i,field.field_name)\" class=\"invalid-feedback\">\n                                                                    <div *ngIf=\"getValidateMoreField(i,field.field_name,'required')\"><font color=\"red\"> * \u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01</font></div>\n                                                                </div>\n                                                            </div>\n                                                        </div>\n                                                    </div>\n                                                    <!-- field \u0E40\u0E1E\u0E34\u0E48\u0E21\u0E40\u0E15\u0E34\u0E21 type datetime -->\n                                                    <div *ngIf=\"field.type === 'datetime'\">\n\n                                                        <div class=\"col-sm-6\">\n                                                            <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,field.field_name) }\">\n                                                                <label class=\"control-label\">{{field.display_name}}</label>\n                                                                <soc-date-box  [id]=\"getFieldId(field)\" [(value)]=\"stepData[field.field_name]\"></soc-date-box>\n                                                                <!--<div *ngIf=\"getValidateMoreField(i,field.field_name,'required')\" class=\"lable-error\">Date is required</div>-->\n                                                                <!--<div *ngIf=\"getValidateMoreField(i,field.field_name,'date')\" class=\"lable-error\">Date is invalid</div>-->\n                                                            </div>\n                                                        </div>\n                                                    </div>\n                                                    <div *ngIf=\"field.type === 'number'\">\n                                                        <div class=\"col-sm-4\">\n                                                            <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,field.field_name) }\">\n                                                                <label class=\"control-label\">{{field.display_name}}</label>\n                                                                <div class=\"input-group\">\n                                                                    <input type=\"number\" class=\"form-control m-input\" [id]=\"getFieldId(field)\" [formControlName]=\"field.field_name\" [(ngModel)]=\"stepData[field.field_name]\">\n                                                                    <div *ngIf=\"field.field_name === 'remind_date'\" class=\"input-group-addon\"><span>\u0E27\u0E31\u0E19</span></div>\n                                                                </div>\n                                                                <div *ngIf=\"submitted && getValidateMoreField(i,field.field_name)\" class=\"invalid-feedback\">\n                                                                    <div *ngIf=\"getValidateMoreField(i,field.field_name,'required')\"><font color=\"red\"> * \u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01</font></div>\n                                                                </div>\n                                                            </div>\n                                                        </div>\n                                                        <!--<div class=\"col-sm-2\" *ngIf=\"field.field_name === 'remind_date'\">-->\n                                                            <!--<span>\u0E27\u0E31\u0E19</span>-->\n                                                        <!--</div>-->\n                                                    </div>\n                                                    <div *ngIf=\"field.type === 'special'\">\n                                                        <div *ngIf=\"field.field_name === 'term'\">\n\n                                                        </div>\n                                                        <div *ngIf=\"field.field_name === 'amount'\">\n                                                            <div class=\"col-sm-6\">\n                                                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,field.field_name) }\">\n                                                                    <label class=\"control-label\">{{field.display_name}}</label>\n                                                                    <input type=\"number\" class=\"form-control m-input\" [id]=\"getFieldId(field)\" [formControlName]=\"field.field_name\" [(ngModel)]=\"stepData[field.field_name]\">\n                                                                    <div *ngIf=\"submitted && getValidateMoreField(i,field.field_name)\" class=\"invalid-feedback\">\n                                                                        <div *ngIf=\"getValidateMoreField(i,field.field_name,'required')\"><font color=\"red\"> * \u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01</font></div>\n                                                                    </div>\n                                                                </div>\n                                                            </div>\n                                                            <div class=\"col-sm-6\">\n                                                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,'amount_type') }\">\n                                                                    <div class=\"m-radio-inline\">\n                                                                        <label class=\"m-radio\">\n                                                                            <input type=\"radio\" id=\"rdlAmountType1\" name=\"amount_type\" value=\"0\" [formControlName]=\"'amount_type'\" [(ngModel)]=\"stepData['amount_type']\" checked>\n                                                                            \u0E19\u0E31\u0E1A\u0E41\u0E15\u0E48<span></span>\n                                                                        </label>\n                                                                        <label class=\"m-radio\">\n                                                                            <input type=\"radio\" id=\"rdlAmountType2\" name=\"amount_type\" value=\"1\" [formControlName]=\"'amount_type'\" [(ngModel)]=\"stepData['amount_type']\">\n                                                                            \u0E19\u0E31\u0E1A\u0E16\u0E31\u0E14<span></span>\n                                                                        </label>\n                                                                    </div>\n                                                                </div>\n                                                            </div>\n                                                        </div>\n                                                        <div *ngIf=\"field.field_name === 'follow'\">\n                                                            <div class=\"col-sm-6\">\n                                                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,'amount_type') }\">\n                                                                    <label class=\"control-label\">{{field.display_name}}</label>\n                                                                    <div class=\"m-radio-inline\">\n                                                                        <label class=\"m-radio\">\n                                                                            <input type=\"radio\" [id]=\"getFieldId(field) + '1'\" [name]=\"field.field_name\" value=\"\u0E17\u0E32\u0E07\u0E01\u0E32\u0E23\" [formControlName]=\"field.field_name\" [(ngModel)]=\"stepData[field.field_name]\" checked>\n                                                                            \u0E17\u0E32\u0E07\u0E01\u0E32\u0E23<span></span>\n                                                                        </label>\n                                                                        <label class=\"m-radio\">\n                                                                            <input type=\"radio\" [id]=\"getFieldId(field) + '2'\" [name]=\"field.field_name\" value=\"\u0E44\u0E21\u0E48\u0E17\u0E32\u0E07\u0E01\u0E32\u0E23\" [formControlName]=\"field.field_name\" [(ngModel)]=\"stepData[field.field_name]\">\n                                                                            \u0E44\u0E21\u0E48\u0E17\u0E32\u0E07\u0E01\u0E32\u0E23<span></span>\n                                                                        </label>\n                                                                    </div>\n                                                                </div>\n                                                            </div>\n                                                            <!--<div class=\"col-sm-3\">-->\n                                                                <!--<span>\u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38 :</span>-->\n                                                            <!--</div>-->\n                                                            <div class=\"col-sm-6\">\n                                                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,'follow_remark') }\">\n                                                                    <label class=\"control-label\">\u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38</label>\n                                                                    <input type=\"text\" class=\"form-control m-input\" id=\"txtFollowRemark\" [formControlName]=\"'follow_remark'\" [(ngModel)]=\"stepData['follow_remark']\" [disableControl]=\"checkDisable(field)\">\n                                                                    <!--<div *ngIf=\"submitted && getValidateMoreField(i,'follow_remark')\" class=\"invalid-feedback\">-->\n                                                                        <!--<div *ngIf=\"getValidateMoreField(i,'follow_remark','required')\">First Name is required</div>-->\n                                                                    <!--</div>-->\n                                                                </div>\n                                                            </div>\n                                                        </div>\n                                                        <div *ngIf=\"field.field_name === 'cause'\">\n                                                            <div class=\"col-sm-6\">\n                                                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && getValidateMoreField(i,field.field_name) }\">\n                                                                    <label class=\"control-label\">{{field.display_name}}</label>\n                                                                    <soc-auto-complete id=\"'txtCause'\" mode=\"local\" [orderBy]=\"'name'\" [filter]=\"causeFilter\"\n                                                                                       [api]=\"causeUrl\" field=\"name\" [(value)]=\"stepData['cause']\"></soc-auto-complete>\n                                                                    <div *ngIf=\"submitted && getValidateMoreField(i,field.field_name)\" class=\"invalid-feedback\">\n                                                                        <div *ngIf=\"getValidateMoreField(i,field.field_name,'required')\"><font color=\"red\"> * \u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01</font></div>\n                                                                    </div>\n                                                                </div>\n                                                            </div>\n                                                        </div>\n                                                    </div>\n                                                </div>\n                                            </div>\n                                        </div>\n                                        <br>\n                                    </div>\n                                </div>\n                                <div *ngIf=\"isSend\">\n                                    <div class=\"row\">\n                                        <div class=\"col-sm-3\">\n                                            <span>\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E2A\u0E48\u0E07 :</span>\n                                        </div>\n                                        <div class=\"col-sm-9\">\n                                            <!--<a id=\"btnSendAdd\" (click)=\"sendModal.show()\" class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\" data-placement=\"top\" title=\"Add\"><i class=\"fal fa-plus\"></i></a>-->\n                                            <a id=\"btnSendAdd\" class=\"btn btn-default btn-md btn-md-search\" (click)=\"addSend()\">\u0E40\u0E1E\u0E34\u0E48\u0E21\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E2A\u0E48\u0E07</a>\n                                        </div>\n                                    </div>\n                                    <br>\n                                    <dx-data-grid #dxDataGridStepSendList class=\"card-list-table\"\n                                                  id=\"gridStepSendList\" noDataText=\"\"\n                                                  (onCellPrepared)=\"onCellPrepared($event)\" [dataSource]=\"sendList\"\n                                                  [wordWrapEnabled]=\"true\"\n                                                  [showBorders]=\"true\">\n                                        <dxi-column caption=\"\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E17\u0E35\u0E48\" [allowSorting]=\"false\" cellTemplate=\"cellTemplate\" alignment=\"center\"></dxi-column>\n                                        <dxi-column caption=\"\u0E08\u0E31\u0E14\u0E01\u0E32\u0E23\" [allowSorting]=\"false\" cellTemplate=\"cellTemplateAction\" alignment=\"center\"></dxi-column>\n                                        <dxi-column dataField=\"send_to\" caption=\"\u0E2B\u0E19\u0E48\u0E27\u0E22\u0E07\u0E32\u0E19\"></dxi-column>\n                                        <dxi-column dataField=\"book_no\" caption=\"\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D\u0E2A\u0E48\u0E07\u0E2D\u0E2D\u0E01\"></dxi-column>\n                                        <dxi-column dataField=\"send_date\" caption=\"\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E2A\u0E48\u0E07\u0E2D\u0E2D\u0E01\" dataType=\"date\" alignment=\"center\"></dxi-column>\n                                        <dxi-column [calculateCellValue]=\"isImportant\" caption=\"\u0E04\u0E27\u0E32\u0E21\u0E2A\u0E33\u0E04\u0E31\u0E0D\"></dxi-column>\n                                        <div *dxTemplate=\"let data of 'cellTemplate'\">\n                                            {{getRowIndex(data)}}\n                                        </div>\n                                        <div *dxTemplate=\"let data of 'cellTemplateAction'\">\n                                            <a id=\"btnEditSend\" (click)=\"editSend(data.data)\" class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\" data-placement=\"top\" title=\"\u0E41\u0E01\u0E49\u0E44\u0E02\"><i class=\"fal fa-pencil-alt\"></i></a>\n                                        </div>\n                                    </dx-data-grid>\n                                    <br>\n                                </div>\n                                <div *ngIf=\"isRecieve\">\n                                    <div class=\"row\">\n                                        <div class=\"col-sm-3\">\n                                            <span>\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E23\u0E31\u0E1A :</span>\n                                        </div>\n                                        <div class=\"col-sm-9\">\n                                            <!--<a id=\"btnSendAdd\" (click)=\"sendModal.show()\" class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\" data-placement=\"top\" title=\"Add\"><i class=\"fal fa-plus\"></i></a>-->\n                                            <a id=\"btnRecieveAdd\" class=\"btn btn-default btn-md btn-md-search\" (click)=\"recieveModal.show()\">\u0E40\u0E1E\u0E34\u0E48\u0E21\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E23\u0E31\u0E1A</a>\n                                        </div>\n                                    </div>\n                                    <br>\n                                    <dx-data-grid #dxDataGridStepRecieveList class=\"card-list-table\"\n                                                  id=\"gridStepRecieveList\" noDataText=\"\"\n                                                  (onCellPrepared)=\"onCellPrepared($event)\" [dataSource]=\"recieveList\"\n                                                  [wordWrapEnabled]=\"true\"\n                                                  [showBorders]=\"true\">\n                                        <dxi-column caption=\"\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E17\u0E35\u0E48\" [allowSorting]=\"false\" cellTemplate=\"cellTemplate\"></dxi-column>\n                                        <dxi-column caption=\"\u0E08\u0E31\u0E14\u0E01\u0E32\u0E23\" [allowSorting]=\"false\" cellTemplate=\"cellTemplateAction\"></dxi-column>\n                                        <dxi-column dataField=\"recv_from\" caption=\"\u0E2B\u0E19\u0E48\u0E27\u0E22\u0E07\u0E32\u0E19\"></dxi-column>\n                                        <dxi-column dataField=\"send_book_no\" caption=\"\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D\u0E2A\u0E48\u0E07\u0E2D\u0E2D\u0E01\"></dxi-column>\n                                        <dxi-column dataField=\"send_date\" caption=\"\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E2A\u0E48\u0E07\u0E2D\u0E2D\u0E01\" dataType=\"date\"></dxi-column>\n                                        <dxi-column dataField=\"book_no\" caption=\"\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D\"></dxi-column>\n                                        <dxi-column dataField=\"recv_date\" caption=\"\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A\" dataType=\"date\"></dxi-column>\n                                        <div *dxTemplate=\"let data of 'cellTemplate'\">\n                                            {{getRowIndex(data)}}\n                                        </div>\n                                        <div *dxTemplate=\"let data of 'cellTemplateAction'\">\n                                            <a id=\"btnEditRecieve\" (click)=\"editRecieve(data.data)\" class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\" data-placement=\"top\" title=\"\u0E41\u0E01\u0E49\u0E44\u0E02\"><i class=\"fal fa-pencil-alt\"></i></a>\n                                        </div>\n                                    </dx-data-grid>\n                                    <br>\n                                </div>\n                            </div>\n                            <div class=\"m-portlet__foot m-portlet__foot--fit text-right\">\n                                <div class=\"m-form__actions\">\n                                    <button type=\"submit\" class=\"btn btn-success btn-md btn-md-save\">\n                                        \u0E1A\u0E31\u0E19\u0E17\u0E36\u0E01\n                                    </button>\n                                    <button type=\"reset\" class=\"btn btn-default btn-md btn-md-search\" (click)=\"closeModal()\">\n                                        \u0E22\u0E01\u0E40\u0E25\u0E34\u0E01\n                                    </button>\n                                </div>\n                            </div>\n                        </form>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n<div class=\"modal fade\" bsModal #sendModal=\"bs-modal\" tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"dialog-static-name2\" [config]=\"{backdrop: 'static'}\">\n    <div class=\"modal-dialog modal-md\">\n        <div class=\"modal-content\">\n            <div class=\"modal-header\">\n                <h4 id=\"dialog-static-send\" class=\"modal-title pull-left\"><label>\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E2A\u0E48\u0E07</label></h4>\n                <button type=\"button\" class=\"close pull-right\" aria-label=\"Close\" (click)=\"closeSendModal()\">\n                    <span aria-hidden=\"true\">&times;</span>\n                </button>\n            </div>\n            <div class=\"modal-body\">\n                <form class=\"m-form m-form--state m-form--fit m-form--label-align-right\" [formGroup]=\"sendForm\" (ngSubmit)=\"onSubmitSend()\">\n                    <div class=\"ibox-body\">\n                        <div class=\"row\">\n                            <div class=\"form-group\">\n                                <label class=\"control-label\">\u0E2B\u0E19\u0E48\u0E27\u0E22\u0E07\u0E32\u0E19</label>\n                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submittedSend && fs().send_to.errors }\">\n                                    <soc-auto-complete [id]=\"'txtSendTo'\" mode=\"local\" [orderBy]=\"'name'\"\n                                                       [api]=\"departmentUrl\" field=\"name\" [(value)]=\"sendData.send_to\"></soc-auto-complete>\n                                    <!--<p-autoComplete type=\"text\" styleClass=\"form-control m-input\" id=\"txtSendTo\" formControlName=\"send_to\" [(ngModel)]=\"sendData.send_to\"-->\n                                                    <!--[suggestions]=\"filteredDepartments\" (completeMethod)=\"filterDepartments($event)\"></p-autoComplete>-->\n                                    <div *ngIf=\"submittedSend && fs().send_to.errors\" class=\"invalid-feedback\">\n                                        <div *ngIf=\"fs().send_to.errors.required\">First Name is required</div>\n                                    </div>\n                                </div>\n                            </div>\n                            <div class=\"form-group\">\n                                <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D\u0E2A\u0E48\u0E07\u0E2D\u0E2D\u0E01</label>\n                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submittedSend && fs().book_no.errors }\">\n                                    <input type=\"text\" class=\"form-control m-input\" id=\"txtSendBookNo\" formControlName=\"book_no\" [(ngModel)]=\"sendData.book_no\">\n                                    <div *ngIf=\"submittedSend && fs().book_no.errors\" class=\"invalid-feedback\">\n                                        <div *ngIf=\"fs().book_no.errors.required\">First Name is required</div>\n                                    </div>\n                                </div>\n                            </div>\n                            <div class=\"form-group\">\n                                <label class=\"control-label\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E2A\u0E48\u0E07\u0E2D\u0E2D\u0E01</label>\n                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submittedSend && fs().send_date.errors }\">\n                                    <soc-date-box [id]=\"'txtSendDate'\" [(value)]=\"sendData.send_date\"></soc-date-box>\n                                    <div *ngIf=\"submittedSend && fs().send_date.errors\" >\n                                        <div *ngIf=\"fs().send_date.errors.required\" class=\"lable-error\">Date is required</div>\n                                        <div *ngIf=\"fs().send_date.errors.date\" class=\"lable-error\">Date is invalid</div>\n                                    </div>\n                                </div>\n                            </div>\n                            <div class=\"form-group\">\n                                <label class=\"control-label\"></label>\n                                <input type=\"checkbox\" id=\"chkIsImportant\"  name=\"is_important\" formControlName=\"is_important\" [(ngModel)]=\"sendData.is_important\" ng-checked> \u0E2A\u0E33\u0E04\u0E31\u0E0D\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"m-portlet__foot m-portlet__foot--fit text-right\">\n                        <div class=\"m-form__actions\">\n                            <button type=\"submit\" class=\"btn btn-success btn-md btn-md-save\">\n                                \u0E1A\u0E31\u0E19\u0E17\u0E36\u0E01\n                            </button>\n                            <button type=\"reset\" class=\"btn btn-default btn-md btn-md-search\" (click)=\"closeSendModal()\">\n                                \u0E22\u0E01\u0E40\u0E25\u0E34\u0E01\n                            </button>\n                        </div>\n                    </div>\n                </form>\n            </div>\n        </div>\n    </div>\n</div>\n<div class=\"modal fade\" bsModal #recieveModal=\"bs-modal\" tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"dialog-static-name2\" [config]=\"{backdrop: 'static'}\">\n    <div class=\"modal-dialog modal-md\">\n        <div class=\"modal-content\">\n            <div class=\"modal-header\">\n                <h4 id=\"dialog-static-recieve\" class=\"modal-title pull-left\"><label>\u0E23\u0E31\u0E1A\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D \u0E15\u0E2D\u0E1A\u0E04\u0E27\u0E32\u0E21\u0E40\u0E2B\u0E47\u0E19</label></h4>\n                <button type=\"button\" class=\"close pull-right\" aria-label=\"Close\" (click)=\"closeRecieveModal()\">\n                    <span aria-hidden=\"true\">&times;</span>\n                </button>\n            </div>\n            <div class=\"modal-body\">\n                <form class=\"m-form m-form--state m-form--fit m-form--label-align-right\" [formGroup]=\"recieveForm\" (ngSubmit)=\"onSubmitRecieve()\">\n                    <div class=\"ibox-body\">\n                        <div class=\"row\">\n                            <div class=\"form-group\">\n                                <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A\u0E2B\u0E19\u0E31\u0E07\u0E2A\u0E37\u0E2D</label>\n                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submittedRecieve && fr().book_no.errors }\">\n                                    <input type=\"text\" class=\"form-control m-input\" id=\"txtRecieveBookNo\" formControlName=\"book_no\" [(ngModel)]=\"recieveData.book_no\">\n                                    <div *ngIf=\"submittedRecieve && fr().book_no.errors\" class=\"invalid-feedback\">\n                                        <div *ngIf=\"fr().book_no.errors.required\">First Name is required</div>\n                                    </div>\n                                </div>\n                            </div>\n                            <div class=\"form-group\">\n                                <label class=\"control-label\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E23\u0E31\u0E1A</label>\n                                <div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submittedRecieve && fr().recv_date.errors }\">\n                                    <soc-date-box [id]=\"'txtRecieveDate'\" [(value)]=\"recieveData.recv_date\"></soc-date-box>\n                                    <div *ngIf=\"submittedRecieve && fr().recv_date.errors\" >\n                                        <div *ngIf=\"fr().recv_date.errors.required\" class=\"lable-error\">Date is required</div>\n                                        <div *ngIf=\"fr().recv_date.errors.date\" class=\"lable-error\">Date is invalid</div>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"m-portlet__foot m-portlet__foot--fit text-right\">\n                        <div class=\"m-form__actions\">\n                            <button type=\"submit\" class=\"btn btn-success btn-md btn-md-save\">\n                                \u0E1A\u0E31\u0E19\u0E17\u0E36\u0E01\n                            </button>\n                            <button type=\"reset\" class=\"btn btn-default btn-md btn-md-search\" (click)=\"closeRecieveModal()\">\n                                \u0E22\u0E01\u0E40\u0E25\u0E34\u0E01\n                            </button>\n                        </div>\n                    </div>\n                </form>\n            </div>\n        </div>\n    </div>\n</div>\n<app-alert #myModal (onClickBack)=\"onClickBack()\"></app-alert>\n"
                }] }
    ];
    /** @nocollapse */
    ModalStepComponent.ctorParameters = function () { return [
        { type: AppConfigService },
        { type: Request },
        { type: FormBuilder },
        { type: Common },
        { type: DateService },
        { type: B2bService }
    ]; };
    ModalStepComponent.propDecorators = {
        onUpdateModal: [{ type: Output }],
        modal: [{ type: ViewChild, args: ['modal',] }],
        myModal: [{ type: ViewChild, args: ['myModal',] }],
        sendModal: [{ type: ViewChild, args: ['sendModal',] }],
        recieveModal: [{ type: ViewChild, args: ['recieveModal',] }],
        dxDataGridStepSendList: [{ type: ViewChild, args: ['dxDataGridStepSendList',] }],
        uploadAttachment: [{ type: ViewChild, args: ['uploadAttachment',] }]
    };
    return ModalStepComponent;
}(Options));
export { ModalStepComponent };
if (false) {
    /** @type {?} */
    ModalStepComponent.prototype.onUpdateModal;
    /** @type {?} */
    ModalStepComponent.prototype.modal;
    /** @type {?} */
    ModalStepComponent.prototype.myModal;
    /** @type {?} */
    ModalStepComponent.prototype.sendModal;
    /** @type {?} */
    ModalStepComponent.prototype.recieveModal;
    /** @type {?} */
    ModalStepComponent.prototype.dxDataGridStepSendList;
    /** @type {?} */
    ModalStepComponent.prototype.uploadAttachment;
    /** @type {?} */
    ModalStepComponent.prototype.registerForm;
    /** @type {?} */
    ModalStepComponent.prototype.sendForm;
    /** @type {?} */
    ModalStepComponent.prototype.recieveForm;
    /** @type {?} */
    ModalStepComponent.prototype.submitted;
    /** @type {?} */
    ModalStepComponent.prototype.submittedSend;
    /** @type {?} */
    ModalStepComponent.prototype.submittedRecieve;
    /** @type {?} */
    ModalStepComponent.prototype.title;
    /** @type {?} */
    ModalStepComponent.prototype.selectList;
    /** @type {?} */
    ModalStepComponent.prototype.sendList;
    /** @type {?} */
    ModalStepComponent.prototype.recieveList;
    /** @type {?} */
    ModalStepComponent.prototype.modalConfig;
    /** @type {?} */
    ModalStepComponent.prototype.th;
    /** @type {?} */
    ModalStepComponent.prototype.selectedStep;
    /** @type {?} */
    ModalStepComponent.prototype.isMore;
    /** @type {?} */
    ModalStepComponent.prototype.moreField;
    /** @type {?} */
    ModalStepComponent.prototype.config;
    /** @type {?} */
    ModalStepComponent.prototype.stepData;
    /** @type {?} */
    ModalStepComponent.prototype.sendData;
    /** @type {?} */
    ModalStepComponent.prototype.recieveData;
    /** @type {?} */
    ModalStepComponent.prototype.lastStep;
    /** @type {?} */
    ModalStepComponent.prototype.isSend;
    /** @type {?} */
    ModalStepComponent.prototype.isRecieve;
    /** @type {?} */
    ModalStepComponent.prototype.isEditSend;
    /** @type {?} */
    ModalStepComponent.prototype.isEditRecieve;
    /** @type {?} */
    ModalStepComponent.prototype.tmpData;
    /** @type {?} */
    ModalStepComponent.prototype.filteredDepartments;
    /** @type {?} */
    ModalStepComponent.prototype.departmentList;
    /** @type {?} */
    ModalStepComponent.prototype.departmentUrl;
    /** @type {?} */
    ModalStepComponent.prototype.causeUrl;
    /** @type {?} */
    ModalStepComponent.prototype.causeFilter;
    /** @type {?} */
    ModalStepComponent.prototype.tempId;
    /** @type {?} */
    ModalStepComponent.prototype.attachmentUrl;
    /** @type {?} */
    ModalStepComponent.prototype.system_id;
    /** @type {?} */
    ModalStepComponent.prototype.filter_ref_ext_department_id;
    /** @type {?} */
    ModalStepComponent.prototype.filter_ref_ext_department_id_show;
    /** @type {?} */
    ModalStepComponent.prototype.appConfigService;
    /** @type {?} */
    ModalStepComponent.prototype.request;
    /** @type {?} */
    ModalStepComponent.prototype.formBuilder;
    /** @type {?} */
    ModalStepComponent.prototype.common;
    /** @type {?} */
    ModalStepComponent.prototype.date;
    /** @type {?} */
    ModalStepComponent.prototype.b2bService;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-step.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/modal-step/modal-step.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport {ModalOptions, ModalDirective} from 'ngx-bootstrap';\nimport {AppConfigService} from '../app-config/app-config.service';\nimport { Request } from '../_services/request.service';\nimport {Common} from '../_services/common.service';\nimport {FormBuilder, FormArray, FormGroup, Validators, AbstractControl} from '@angular/forms';\nimport {CustomValidators} from 'ng2-validation';\nimport {DxDataGridComponent} from 'devextreme-angular';\nimport * as uuid from 'uuid';\nimport * as _ from 'lodash';\nimport {DateService} from '../_services/date.service';\nimport {UploadAttachmentComponent} from '../upload-attachment/upload-attachment.component';\nimport {B2bService} from '../_services/b2b.service';\n\nclass Options {\n    /** title ที่ต้องการแสดง */\n    title?: String;\n    /** data */\n    data: any;\n}\n\n@Component({\n    selector: 'modal-step',\n    templateUrl: './modal-step.component.html',\n})\nexport class ModalStepComponent extends Options implements OnInit {\n    @Output() onUpdateModal = new EventEmitter();\n    // @Output() onCreateModal = new EventEmitter();\n    @ViewChild('modal') modal: ModalDirective;\n    @ViewChild('myModal') myModal;\n    @ViewChild('sendModal') sendModal: ModalDirective;\n    @ViewChild('recieveModal') recieveModal: ModalDirective;\n    @ViewChild('dxDataGridStepSendList')\n    dxDataGridStepSendList: DxDataGridComponent;\n    @ViewChild('uploadAttachment') uploadAttachment: UploadAttachmentComponent;\n\n    registerForm: FormGroup;\n    sendForm: FormGroup;\n    recieveForm: FormGroup;\n    submitted = false;\n    submittedSend = false;\n    submittedRecieve = false;\n    title: any = '';\n    selectList: any = [];\n    sendList: any = [];\n    recieveList: any = [];\n    modalConfig: ModalOptions = {\n        ignoreBackdropClick: true\n    };\n    th;\n    selectedStep: any = null;\n    isMore = false;\n    moreField: any;\n    public config: any;\n    stepData: any = {};\n    sendData: any = {};\n    recieveData: any = {};\n    lastStep = '';\n    isSend = false;\n    isRecieve = false;\n    isEditSend = false;\n    isEditRecieve = false;\n    tmpData:any = {};\n    filteredDepartments:any = [];\n    departmentList:any = [];\n    departmentUrl = \"/db/ct_ext_department\";\n    causeUrl = \"/db/ct_dropdown\";\n    causeFilter = \"system_id,eq,23)$and(dropdown_type,like,เรื่องส่งคืน\";\n    tempId = -1;\n    attachmentUrl;\n    system_id;\n    filter_ref_ext_department_id: any = false;\n    filter_ref_ext_department_id_show = true;\n    constructor(private appConfigService: AppConfigService, private request: Request, private formBuilder: FormBuilder, public common: Common, public date: DateService, public b2bService: B2bService) {\n        super();\n        this.config = appConfigService.getConfig();\n        this.attachmentUrl = _.get(this.config, 'apiServers.alfresco.url') || \"https://203.154.32.126:2585/api/mfec/Alfresco\";\n        this.system_id = _.get(this.config, 'system_id');\n    }\n\n    ngOnInit() {\n        this.th = this.common.fnLocalPCalendar('th');\n        this.recieveForm = this.formBuilder.group({\n            book_no: ['', [Validators.required]],\n            recv_date: [''],\n        });\n        this.sendForm = this.formBuilder.group({\n            send_to: [''],\n            book_no: [''],\n            send_date: [''],\n            is_important: [''],\n        });\n        this.registerForm = this.formBuilder.group({\n            name: [''],\n            step_id: ['', Validators.required],\n            step_date: [''],\n            remark: [''],\n            lastStep: [''],\n            moreField: this.formBuilder.array([]),\n            soc_recv_no: [''],\n            soc_recv_date: [''],\n            gtc_recv_no: [''],\n            gtc_recv_date: [''],\n            book_no: [''],\n            book_date: [''],\n            'for': [''],\n            dept_name: [''],\n            ministry: ['']\n\n        });\n    }\n\n    async open(options?: Options) {\n        console.log(options);\n        this.stepData = {};\n        if (options) {\n            this.title = options.title || '';\n            this.lastStep = options.data.lastStep;\n            this.stepData = JSON.parse(JSON.stringify(options.data));\n            this.stepData.step_date = this.date.getNow();\n            delete this.stepData['lastStep'];\n            this.selectList = await this.request.get('/db/ct_step?_where=(category_id,eq,' + options.data.category_id + ')&_sort=seq_no');\n        }\n        this.uploadAttachment.clearValue();\n        this.modal.show();\n    }\n\n    f() { return this.registerForm.controls; }\n    fs() { return this.sendForm.controls; }\n    fr() { return this.recieveForm.controls; }\n\n    closeModal() {\n        this.submitted = false;\n        this.selectList = [];\n        this.sendList = [];\n        this.selectedStep = null;\n        this.isMore = false;\n        this.isSend = false;\n        this.moreField = [];\n        this.stepData = {};\n        this.lastStep = '';\n        this.modal.hide();\n    }\n\n    closeSendModal() {\n        this.submittedSend = false;\n        this.sendData = {};\n        this.isEditSend = false;\n        this.tmpData = {};\n        this.sendModal.hide();\n    }\n\n    closeRecieveModal() {\n        this.submittedRecieve = false;\n        this.recieveData = {};\n        this.isEditRecieve = false;\n        this.tmpData = {};\n        this.recieveModal.hide();\n    }\n\n    onYesClick(modal) {\n        modal.hide();\n    }\n\n    onNoClick(modal) {\n        modal.hide();\n    }\n\n    onHidden($event: ModalDirective) {\n        console.log('LOG MESSAGE: ModalConfirm -> onHidden -> $event', $event);\n\n    }\n    \n    valueSeleteMinistry(value) {\n      this.filter_ref_ext_department_id_show = false;\n      console.log('value', value)\n      // this.stepData.ministry_id = value && value.id ? value.id : null\n      if (value && value.id) {\n        this.stepData.dept_name = null\n        this.filter_ref_ext_department_id = `&_where=(ref_ext_department_id,eq,${value.id})$and(type,in,2,3,4,5)`\n      } else {\n        this.filter_ref_ext_department_id = false;\n      }\n      setTimeout(() => {\n        this.filter_ref_ext_department_id_show = true;\n      }, 50)\n\n    }\n\n    valueSeleteDeptName(value) {\n      console.log('value', value)\n      this.stepData.code_dept = value && value.id ? value.id : null\n    }\n\n\n    async checkExtraField() {\n        this.stepData.step_id = this.selectedStep.id;\n        this.stepData.step_name = this.selectedStep.name;\n        console.log(this.isMore);\n        this.moreField = [];\n        if (this.selectedStep.flag && this.selectedStep.flag !== '') {\n            for (let i = 0; i < this.selectedStep.flag.length; i++) {\n                const flag = this.selectedStep.flag.charAt(i);\n                const requireFlag = this.selectedStep.require_flag ? this.selectedStep.require_flag.charAt(i) : 0;\n                const ct_step_flag = await this.request.get('/db/ct_step_flag?_where=(flag,eq,' + flag + ')');\n                const newField = ct_step_flag[0];\n                await this.addField(newField, +requireFlag);\n                this.moreField.push(newField);\n                console.log(this.f);\n            }\n            this.isMore = true;\n            this.isSend = false;\n            this.isRecieve = false;\n        } else {\n            this.isMore = false;\n            if (this.selectedStep.type_id === 8 || this.selectedStep.type_id === 13) {\n                this.departmentList = await this.request.get('/db/ct_ext_department?_sort=name');\n                this.departmentList = this.departmentList.map(a => a.name);\n                this.isSend = true;\n                this.isRecieve = false;\n            // } else if (this.selectedStep.type_id === 9 || this.selectedStep.type_id === 14) {\n            //     const data = await this.request.post('/sql/getLastSend', this.stepData);\n            //     if (data.resultData && data.resultData.length > 0) {\n            //         const ct_step_data_id = data.resultData[0].id;\n            //         const ct_sendList = await this.request.get('/db/ct_send?_where=(ct_step_data_id,eq,' + ct_step_data_id + ')');\n            //         for (const ct_send of ct_sendList) {\n            //             const recvData: any = {\n            //                 ct_send_id: ct_send.id,\n            //                 send_book_no: ct_send.book_no,\n            //                 send_date: ct_send.send_date,\n            //                 recv_from: ct_send.send_to,\n            //                 name: ct_send.name\n            //             };\n            //             this.recieveList.push(recvData);\n            //         }\n            //     }\n            //     this.isRecieve = true;\n            //     this.isSend = false;\n            } else {\n                this.isSend = false;\n                this.isRecieve = false;\n            }\n        }\n    }\n\n    getFieldId(data) {\n        let id = '';\n        if (data.type === 'text') {\n            id += 'txt';\n        } else if (data.type === 'datetime') {\n            id += 'txt';\n        } else {\n            id += 'txt';\n        }\n        const field = data.field_name.charAt(0).toLocaleUpperCase() + data.field_name.substring(1);\n        id += field;\n        return id;\n    }\n\n    addField(data, required) {\n        let control:any = <FormArray>this.registerForm.controls['moreField'];\n        let newgroup;\n        this.stepData[data.field_name] = null;\n        if (data.type === 'text') {\n            if (required) {\n                const group: any = {};\n                group[data.field_name] = ['', Validators.required];\n                newgroup = this.formBuilder.group(group);\n            } else {\n                const group: any = {};\n                group[data.field_name] = [''];\n                newgroup = this.formBuilder.group(group);\n            }\n        } else if (data.type === 'datetime') {\n            if (required) {\n                const group: any = {};\n                group[data.field_name] = ['',Validators.required, CustomValidators.date];\n                newgroup = this.formBuilder.group(group);\n            } else {\n                const group: any = {};\n                group[data.field_name] = [''];\n                newgroup = this.formBuilder.group(group);\n            }\n            this.stepData[data.field_name] = this.date.getNow();\n        } else if (data.type === 'number') {\n            if (required) {\n                const group: any = {};\n                group[data.field_name] = [Validators.required];\n                newgroup = this.formBuilder.group(group);\n            } else {\n                const group: any = {};\n                group[data.field_name] = [''];\n                newgroup = this.formBuilder.group(group);\n            }\n        } else if (data.type === 'special'){\n            if(data.field_name === 'amount'){\n                if (required) {\n                    const group: any = {};\n                    group[data.field_name] = ['', Validators.required];\n                    group['amount_type'] = ['', Validators.required];\n                    newgroup = this.formBuilder.group(group);\n                } else {\n                    const group: any = {};\n                    group[data.field_name] = [''];\n                    group['amount_type'] = [''];\n                    newgroup = this.formBuilder.group(group);\n                }\n            }else if(data.field_name === 'follow'){\n                if (required) {\n                    const group: any = {};\n                    group[data.field_name] = ['', Validators.required];\n                    group['follow_remark'] = ['', Validators.required];\n                    newgroup = this.formBuilder.group(group);\n                } else {\n                    const group: any = {};\n                    group[data.field_name] = [''];\n                    group['follow_remark'] = [''];\n                    newgroup = this.formBuilder.group(group);\n                }\n            }else{\n                if (required) {\n                    const group: any = {};\n                    group[data.field_name] = ['', Validators.required];\n                    newgroup = this.formBuilder.group(group);\n                } else {\n                    const group: any = {};\n                    group[data.field_name] = [''];\n                    newgroup = this.formBuilder.group(group);\n                }\n            }\n        }\n\n        control.push(newgroup);\n    }\n\n    getValidateMoreField(i, field, validateType?) {\n        let formMoreField: any = this.f()['moreField'];\n        if (validateType) {\n            formMoreField = formMoreField.controls[i];\n            formMoreField = formMoreField.controls[field];\n            if (formMoreField.errors) {\n                return formMoreField.errors[validateType];\n            } else {\n                return formMoreField.errors;\n            }\n        } else {\n            return formMoreField.errors;\n        }\n    }\n\n    getRowIndex(data) {\n        if (!data.data) {\n            return '';\n        }\n        const no = data.row.dataIndex + 1;\n        return no;\n    }\n\n    onCellPrepared(e) {\n        if (e.rowType === 'data') {\n            for (const i in e.component.columns) {\n                if (e.column.dataField === e.component.columns[i]) {\n                    e.cellElement.accessKey = e.component.columns[i];\n                }\n            }\n        }\n    }\n\n    addSend(){\n        this.sendData.send_date = this.date.getNow();\n        this.sendModal.show();\n    }\n\n    editSend(data) {\n        this.tmpData = data;\n        this.sendData = JSON.parse(JSON.stringify(data));\n        // this.sendData.send_date = new Date(this.sendData.send_date);\n        this.isEditSend = true;\n        this.sendModal.show();\n    }\n\n    editRecieve(data) {\n        this.tmpData = data;\n        this.recieveData = JSON.parse(JSON.stringify(data));\n        this.recieveData.recv_date = this.recieveData.recv_date ? new Date(this.recieveData.recv_date) : this.recieveData.recv_date;\n        this.isEditRecieve = true;\n        this.recieveModal.show();\n    }\n\n    filterDepartments(event) {\n        this.filteredDepartments = [];\n        for (let i = 0; i < this.departmentList.length; i++) {\n            const department = this.departmentList[i];\n            if (department.toLowerCase().indexOf(event.query.toLowerCase()) == 0) {\n                this.filteredDepartments.push(department);\n            }\n        }\n    }\n\n    async onSubmit() {\n        this.submitted = true;\n        // ถ้า form ไม่ครบหรือผิดตามเงื่อนไขที่ตั้งไว้จะจบที่ตรงนี้\n        console.log('this.registerForm.invalid: ', this.registerForm.invalid);\n        if (this.registerForm.invalid) {\n            return;\n        }\n        let postData = [];\n        let data = _.cloneDeep(this.stepData);\n        data.action = \"add\";\n        let userData:any = this.b2bService.getVerifyToken();\n        data.username = userData.username;\n        if(data.remind_date) data.remind_date = this.date.getNow().add(data.remind_date, 'd').toDate();\n        delete data[\"ct_main_id\"];\n        delete data[\"update_date\"];\n        let main = {\n            \"ct_step_data\":[data]\n        }\n        postData.push(main);\n        if(this.sendList && this.sendList.length > 0){\n            let ct_send = {\n                \"ct_send\":[]\n            };\n            let ct_recieve = {\n                \"ct_recieve\":[]\n            };\n            for(let data of this.sendList){\n                data.name = data.name;\n                data.action = \"add\";\n                delete data.id;\n                ct_send.ct_send.push(data);\n            }\n            postData.push(ct_send);\n        }\n        if(this.recieveList && this.recieveList.length > 0){\n            let ct_recieve = {\n                \"ct_recieve\":[]\n            };\n            for(let data of this.recieveList){\n                delete data['send_book_no'];\n                delete data['send_date'];\n                data.name = data.name;\n                data.action = \"add\";\n                ct_recieve.ct_recieve.push(data);\n            }\n            postData.push(ct_recieve);\n        }\n        console.log('postData',postData);\n        // if(this.mode === 'EDIT'){\n        let postResponse = await this.request.post(\"/ct/main\",postData);\n        if(this.stepData.update_date){\n          let stepList = await this.getStepList();\n          console.log(\"stepList\",stepList)\n          if(stepList.length > 0){\n            await this.request.put(\"/db/\"+this.stepData.ref_table+\"/\"+this.stepData.ref_id,{status:stepList[0].step_name,status_date:stepList[0].step_date});\n            this.common.fnCheckResponse(postResponse, this.myModal)\n          }\n        }else{\n          await this.request.put(\"/db/\"+this.stepData.ref_table+\"/\"+this.stepData.ref_id,{status:this.stepData.step_name});\n          this.common.fnCheckResponse(postResponse, this.myModal)\n        }\n\n        // }else{\n        //     this.onCreateModal.emit(postData);\n        // }\n    }\n\n    async getStepList() {\n        console.log('getStepList');\n        let filter = {\n            filter:{\n                ref_table:\"=\"+this.stepData.ref_table,\n                ref_id:this.stepData.ref_id,\n                system_id:this.stepData.system_id\n            },\n            order_by:[\"step_date desc\"]\n        }\n        const data = await this.request.post('/search/ct_step_data', filter);\n        return data.resultData || [];\n    }\n\n\n    onClickBack(){\n        this.onUpdateModal.emit();\n        this.closeModal();\n    }\n\n    async onSubmitSend() {\n        this.submittedSend = true;\n        // ถ้า form ไม่ครบหรือผิดตามเงื่อนไขที่ตั้งไว้จะจบที่ตรงนี้\n        if (this.sendForm.invalid) {\n            return;\n        }\n        if (this.isEditSend) {\n            const tmpList = [];\n            for (const tmpSend of this.sendList) {\n                if (tmpSend.id === this.tmpData.id) {\n                    tmpList.push(this.sendData);\n                } else {\n                    tmpList.push(tmpSend);\n                }\n            }\n            this.sendList = tmpList;\n        } else {\n            this.sendData.id = this.tempId;\n            this.tempId--;\n            this.sendList.push(this.sendData);\n        }\n        this.closeSendModal();\n    }\n\n    async onSubmitRecieve() {\n        this.submittedSend = true;\n\n        // ถ้า form ไม่ครบหรือผิดตามเงื่อนไขที่ตั้งไว้จะจบที่ตรงนี้\n        if (this.recieveForm.invalid) {\n            return;\n        }\n        if (this.isEditRecieve) {\n            const tmpList = [];\n            for (const tmpSend of this.recieveList) {\n                if (tmpSend.recv_from === this.tmpData.recv_from) {\n                    tmpList.push(this.recieveData);\n                } else {\n                    tmpList.push(tmpSend);\n                }\n            }\n            this.recieveList = tmpList;\n        } else {\n            this.recieveList.push(this.recieveData);\n        }\n        this.closeRecieveModal();\n    }\n    isImportant(data){\n        return data.is_important?\"สำคัญ\":\"\";\n    }\n    onUploaded(data){\n        this.stepData.url = this.attachmentUrl+'/'+data.uuid;\n        this.stepData.uuid = data.uuid;\n    }\n    checkDisable(field){\n        if(this.stepData[field.field_name] !== 'ไม่ทางการ'){\n            return true;\n        }else{\n            return false;\n        }\n    }\n\n    async getImageLink(data){\n        let url = await this.request.getAttachmentLinkToken(data.url);\n        return url;\n    }\n}\n"]}