modal-attachment-view.component.js 59.5 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
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Component, EventEmitter, Input, 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 { UploadAttachmentComponent } from '../upload-attachment/upload-attachment.component';
import * as _ from 'lodash';
var Options = /** @class */ (function () {
    function Options() {
    }
    return Options;
}());
if (false) {
    /**
     * title ที่ต้องการแสดง
     * @type {?}
     */
    Options.prototype.title;
    /**
     * data
     * @type {?}
     */
    Options.prototype.data;
    /** @type {?} */
    Options.prototype.mode;
    /** @type {?} */
    Options.prototype.downloadToken;
    /**
     * name ที่ต้องการแสดง
     * @type {?}
     */
    Options.prototype.config;
}
var ModalAttachmentViewComponent = /** @class */ (function (_super) {
    tslib_1.__extends(ModalAttachmentViewComponent, _super);
    function ModalAttachmentViewComponent(appConfigService, request, formBuilder, common) {
        var _this = _super.call(this) || this;
        _this.appConfigService = appConfigService;
        _this.request = request;
        _this.formBuilder = formBuilder;
        _this.common = common;
        _this.isImage = false;
        _this.onModalCreateSubmit = new EventEmitter();
        _this.onModalEditSubmit = new EventEmitter();
        _this.submitted = false;
        _this.title = '';
        _this.selectList = [];
        _this.modalConfig = {
            ignoreBackdropClick: true
        };
        _this.isMore = false;
        _this.attachmentData = {
            doc_type: null
        };
        _this.tmpData = {};
        _this.filteredDepartments = [];
        _this.departmentList = [];
        _this.disabledForm = false;
        _this.isOpen = false;
        _this.config = appConfigService.getConfig();
        _this.attachmentUrl = _.get(_this.config, 'apiServers.alfresco.url') || "https://203.154.32.126:2585/api/mfec/Alfresco";
        return _this;
    }
    /**
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        this.th = this.common.fnLocalPCalendar('th');
        this.registerForm = this.formBuilder.group({
            name: [{ value: '', disabled: this.disabledForm }],
            doc_type: [{ value: '', disabled: this.disabledForm }],
            url: [{ value: '', disabled: this.disabledForm }],
            is_classifieds: [{ value: '', disabled: this.disabledForm }],
            is_image: [{ value: '', disabled: this.disabledForm }],
            keyword: [{ value: '', disabled: this.disabledForm }],
            book_no: [{ value: '', disabled: this.disabledForm }],
            amount: [{ value: '', disabled: this.disabledForm }],
            record_date: [{ value: '', disabled: this.disabledForm }],
            version: [{ value: '', disabled: this.disabledForm }],
            resolution: [{ value: '', disabled: this.disabledForm }],
            remark: [{ value: '', disabled: this.disabledForm }],
            moreField: this.formBuilder.array([])
        });
    };
    /**
     * @param {?=} options
     * @return {?}
     */
    ModalAttachmentViewComponent.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.attachmentData = {};
                        if (!options) return [3 /*break*/, 2];
                        this.mode = options.mode;
                        this.title = options.title || '';
                        this.downloadToken = options.downloadToken;
                        this.attachmentData = _.cloneDeep(options.data);
                        if (!this.attachmentData.doc_type) {
                            this.attachmentData.doc_type = null;
                        }
                        // ต้องเปลี่ยนเป็นเรียก api
                        _a = this;
                        return [4 /*yield*/, this.request.getDropDown(options.data.system_id, "ประเภทเอกสาร")];
                    case 1:
                        // ต้องเปลี่ยนเป็นเรียก api
                        _a.selectList = _b.sent();
                        _b.label = 2;
                    case 2:
                        if (this.mode !== 'VIEW') {
                            this.uploadAttachment.clearValue();
                            this.disabledForm = false;
                        }
                        else {
                            this.disabledForm = true;
                        }
                        this.modal.show();
                        this.isOpen = true;
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.f = /**
     * @return {?}
     */
    function () {
        return this.registerForm.controls;
    };
    /**
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.closeModal = /**
     * @return {?}
     */
    function () {
        this.submitted = false;
        this.selectList = [];
        this.isMore = false;
        this.moreField = [];
        this.attachmentData = {};
        this.modal.hide();
        this.isOpen = false;
    };
    /**
     * @param {?} modal
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.onYesClick = /**
     * @param {?} modal
     * @return {?}
     */
    function (modal) {
        modal.hide();
    };
    /**
     * @param {?} modal
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.onNoClick = /**
     * @param {?} modal
     * @return {?}
     */
    function (modal) {
        modal.hide();
    };
    /**
     * @param {?} $event
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.onHidden = /**
     * @param {?} $event
     * @return {?}
     */
    function ($event) {
        console.log('LOG MESSAGE: ModalConfirm -> onHidden -> $event', $event);
    };
    /**
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.checkExtraField = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            return tslib_1.__generator(this, function (_a) {
                this.moreField = [];
                if (this.attachmentData.system_id) {
                    // this.addField(newField, +requireFlag);
                    // this.moreField.push(newField);
                    this.isMore = true;
                }
                else {
                    this.isMore = false;
                }
                return [2 /*return*/];
            });
        });
    };
    /**
     * @param {?} e
     * @return {?}
     */
    ModalAttachmentViewComponent.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];
                }
            }
        }
    };
    /**
     * @param {?} data
     * @param {?} required
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.addField = /**
     * @param {?} data
     * @param {?} required
     * @return {?}
     */
    function (data, required) {
        /** @type {?} */
        var control = /** @type {?} */ (this.registerForm.controls['moreField']);
        /** @type {?} */
        var newgroup;
        if (data.type === 'text') {
            if (required) {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];
                newgroup = this.formBuilder.group(group);
            }
            else {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];
                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] = [{ value: '', disabled: this.disabledForm }];
                newgroup = this.formBuilder.group(group);
            }
        }
        else if (data.type === 'special') {
            if (required) {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];
                newgroup = this.formBuilder.group(group);
            }
            else {
                /** @type {?} */
                var group = {};
                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];
                newgroup = this.formBuilder.group(group);
            }
            if (data.field_name === 'amount') {
                /** @type {?} */
                var group = {};
                group['amount_type'] = [{ value: '', disabled: this.disabledForm }];
                control.push(this.formBuilder.group(group));
            }
        }
        control.push(newgroup);
    };
    /**
     * @param {?} i
     * @param {?} field
     * @param {?=} validateType
     * @return {?}
     */
    ModalAttachmentViewComponent.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 {?}
     */
    ModalAttachmentViewComponent.prototype.getRowIndex = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        if (!data.data) {
            return '';
        }
        /** @type {?} */
        var no = data.row.dataIndex + 1;
        return no;
    };
    /**
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.onSubmit = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            return tslib_1.__generator(this, function (_a) {
                this.submitted = true;
                // ถ้า form ไม่ครบหรือผิดตามเงื่อนไขที่ตั้งไว้จะจบที่ตรงนี้
                if (this.registerForm.invalid) {
                    return [2 /*return*/];
                }
                // let postData = [];
                // await this.request.post("/db/rc_attachment",this.attachmentData);
                if (this.mode === 'CREATE') {
                    this.onModalCreateSubmit.emit(this.attachmentData);
                }
                else {
                    this.onModalEditSubmit.emit(this.attachmentData);
                }
                this.closeModal();
                ;
                this.isOpen = false;
                return [2 /*return*/];
            });
        });
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.onUploaded = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        console.log("data", data);
        this.attachmentData.url = this.attachmentUrl + '/' + data.uuid;
        this.attachmentData.uuid = data.uuid;
        this.attachmentData.filename = data.fileName;
    };
    /**
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.clickUrl = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var _a, _b;
            return tslib_1.__generator(this, function (_c) {
                switch (_c.label) {
                    case 0:
                        _b = (_a = window).open;
                        return [4 /*yield*/, this.request.getAttachmentLinkToken(this.attachmentData.url)];
                    case 1:
                        _b.apply(_a, [_c.sent()]);
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @param {?} data
     * @return {?}
     */
    ModalAttachmentViewComponent.prototype.getImageLink = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        return data.url + "?downloadToken=" + this.downloadToken;
    };
    ModalAttachmentViewComponent.decorators = [
        { type: Component, args: [{
                    selector: 'modal-attachment-view',
                    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\">{{title}}</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 *ngIf=\"isOpen\" class=\"m-form m-form&#45;&#45;state m-form&#45;&#45;fit m-form&#45;&#45;label-align-right\" [formGroup]=\"registerForm\" (ngSubmit)=\"onSubmit()\">-->\n                            <div class=\"m-portlet__body\">\n                                <!-- \u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\u0E41\u0E19\u0E1A -->\n                                <div *ngIf=\"attachmentData.system_id !== 17\">\n                                    <div class=\"row\">\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E0A\u0E37\u0E48\u0E2D\u0E40\u0E23\u0E37\u0E48\u0E2D\u0E07 :</span>-->\n                                        <!--</div>-->\n                                        <div class=\"col-sm-12\">\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().name.errors }\">-->\n                                                <label class=\"control-label\">\u0E0A\u0E37\u0E48\u0E2D\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23</label>\n                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" disabled>-->\n                                                <input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" [(ngModel)]=\"attachmentData.name\" disabled>\n                                                <!--<div *ngIf=\"submitted && f().name.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().name.errors.required\">First Name is required</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <div class=\"row\">\n                                    <!--<div class=\"col-sm-2\">-->\n                                        <!--<span>\u0E1B\u0E23\u0E30\u0E40\u0E20\u0E17\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23 :</span>-->\n                                    <!--</div>-->\n                                    <div class=\"col-sm-12\">\n                                        <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().doc_type.errors }\">-->\n                                            <label class=\"control-label\">\u0E1B\u0E23\u0E30\u0E40\u0E20\u0E17\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23</label>\n                                            <select id=\"selNewStatus\" style=\"width: 100%\" [(ngModel)]=\"attachmentData.doc_type\" disabled>\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 data of selectList\" [ngValue]=\"data.name\">{{data.name}}</option>\n                                            </select>\n                                            <!--<div *ngIf=\"submitted && f().doc_type.errors\" class=\"invalid-feedback\">-->\n                                                <!--<div *ngIf=\"f().doc_type.errors.required\">First Name is required</div>-->\n                                            <!--</div>-->\n                                        <!--</div>-->\n                                    </div>\n                                </div>\n                                <div *ngIf=\"attachmentData.system_id !== 17 && attachmentData.system_id !== 11\">\n                                    <div class=\"row\">\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                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtRemark\" formControlName=\"remark\" [(ngModel)]=\"attachmentData.remark\" [disabled]=\"disabledForm\">-->\n                                            <input type=\"text\" class=\"form-control m-input\" id=\"txtRemark\" [(ngModel)]=\"attachmentData.remark\" disabled>\n                                                <!--<div *ngIf=\"submitted && f().remark.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().remark.errors.required\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <div class=\"row\">\n                                    <!--<div class=\"col-sm-2\">-->\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]=\"attachmentData.system_id\" (uploaded)=\"onUploaded($event)\" [onlyImage]=\"isImage\"></upload-attachment>-->\n                                    <!--</div>-->\n                                    <!--<div *ngIf=\"mode === 'VIEW'\" class=\"col-sm-12\">-->\n                                        <label *ngIf=\"!isImage\" class=\"control-label\">\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23\u0E41\u0E19\u0E1A</label>\n                                        <label *ngIf=\"isImage\" class=\"control-label\">\u0E40\u0E04\u0E23\u0E37\u0E48\u0E2D\u0E07\u0E2B\u0E21\u0E32\u0E22</label>\n                                        <br>\n                                        <a *ngIf=\"!isImage\" [href]=\"getImageLink(attachmentData)\" target=\"_blank\">{{attachmentData.url}}</a>\n                                        <img *ngIf=\"isImage\" [src]=\"getImageLink(attachmentData)\" style=\"width: auto !important; text-align: center\">\n                                    </div>\n                                </div>\n                                <br>\n                                <div *ngIf=\"attachmentData.system_id === 11\">\n                                    <div class=\"row\">\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E08\u0E31\u0E14\u0E40\u0E02\u0E49\u0E32\u0E27\u0E32\u0E23\u0E30 :</span>-->\n                                        <!--</div>-->\n                                        <div class=\"col-sm-12\">\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().is_classifieds.errors }\">-->\n                                                <!--<label class=\"control-label\"></label>-->\n                                                <!--<label class=\"control-label\"></label>-->\n                                                <input type=\"checkbox\" class=\"form-control m-input\" id=\"chxIsClassifieds\" [(ngModel)]=\"attachmentData.is_classifieds\" disabled> \u0E08\u0E31\u0E14\u0E40\u0E02\u0E49\u0E32\u0E27\u0E32\u0E23\u0E30\n                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" formControlName=\"name\" [(ngModel)]=\"attachmentData.is_classifieds\">-->\n                                                <!--<div *ngIf=\"submitted && f().is_classifieds.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().is_classifieds.errors.required\">First Name is required</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <div *ngIf=\"attachmentData.system_id === 11\">\n                                    <div class=\"row\">\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E41\u0E1B\u0E25\u0E07\u0E40\u0E1B\u0E47\u0E19\u0E20\u0E32\u0E1E\u0E41\u0E25\u0E49\u0E27 :</span>-->\n                                        <!--</div>-->\n                                        <div class=\"col-sm-12\">\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().is_image.errors }\">-->\n                                                <!--<label class=\"control-label\">\u0E41\u0E1B\u0E25\u0E07\u0E40\u0E1B\u0E47\u0E19\u0E20\u0E32\u0E1E\u0E41\u0E25\u0E49\u0E27</label>-->\n                                                <!--<label class=\"control-label\"></label>-->\n                                                <input type=\"checkbox\" class=\"form-control m-input\" id=\"chxIsImage\" [(ngModel)]=\"attachmentData.is_image\" disabled> \u0E41\u0E1B\u0E25\u0E07\u0E40\u0E1B\u0E47\u0E19\u0E20\u0E32\u0E1E\u0E41\u0E25\u0E49\u0E27\n                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" formControlName=\"name\" [(ngModel)]=\"attachmentData.is_classifieds\">-->\n                                                <!--<div *ngIf=\"submitted && f().is_classifieds.errors\" class=\"invalid-feedback\">-->\n                                                <!--<div *ngIf=\"f().is_classifieds.errors.required\">First Name is required</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <div *ngIf=\"attachmentData.system_id === 11\">\n                                    <div class=\"row\">\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E04\u0E33\u0E2A\u0E33\u0E04\u0E31\u0E0D :</span>-->\n                                        <!--</div>-->\n                                        <div class=\"col-sm-12\">\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().keyword.errors }\">-->\n                                                <label class=\"control-label\">\u0E04\u0E33\u0E2A\u0E33\u0E04\u0E31\u0E0D</label>\n                                                <!--<label class=\"control-label\"></label>-->\n                                                <input type=\"text\" class=\"form-control m-input\" id=\"txtKeyword\" [(ngModel)]=\"attachmentData.keyword\" disabled>\n                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" formControlName=\"name\" [(ngModel)]=\"attachmentData.is_classifieds\">-->\n                                                <!--<div *ngIf=\"submitted && f().keyword.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().keyword.errors.required\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E04\u0E33\u0E2A\u0E33\u0E04\u0E31\u0E0D</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <div *ngIf=\"attachmentData.system_id === 17\">\n                                    <div class=\"row\">\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23 :</span>-->\n                                        <!--</div>-->\n                                        <div class=\"col-sm-12\">\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().book_no.errors }\">-->\n                                                <label class=\"control-label\">\u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23</label>\n                                                <!--<label class=\"control-label\"></label>-->\n                                                <input type=\"text\" class=\"form-control m-input\" id=\"txtBookNo\"[(ngModel)]=\"attachmentData.book_no\" disabled>\n                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" formControlName=\"name\" [(ngModel)]=\"attachmentData.is_classifieds\">-->\n                                                <!--<div *ngIf=\"submitted && f().book_no.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().book_no.errors.required\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E40\u0E25\u0E02\u0E17\u0E35\u0E48\u0E40\u0E2D\u0E01\u0E2A\u0E32\u0E23</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <!--<div *ngIf=\"attachmentData.system_id === 17\">-->\n                                    <!--<div class=\"row\">-->\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E08\u0E33\u0E19\u0E27\u0E19 :</span>-->\n                                        <!--</div>-->\n                                        <!--<div class=\"col-sm-10\">-->\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().amount.errors }\">-->\n                                                <!--&lt;!&ndash;<label class=\"control-label\"></label>&ndash;&gt;-->\n                                                <!--<input type=\"number\" class=\"form-control m-input\" id=\"txtAmount\" name=\"amount\" formControlName=\"amount\" [(ngModel)]=\"attachmentData.amount\">-->\n                                                <!--&lt;!&ndash;<input type=\"text\" class=\"form-control m-input\" id=\"txtCategoryName\" formControlName=\"name\" [(ngModel)]=\"attachmentData.is_classifieds\">&ndash;&gt;-->\n                                                <!--<div *ngIf=\"submitted && f().amount.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().amount.errors.required\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E08\u0E33\u0E19\u0E27\u0E19</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        <!--</div>-->\n                                    <!--</div>-->\n                                <!--</div>-->\n                                <div *ngIf=\"attachmentData.system_id === 17\">\n                                    <div class=\"row\">\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E08\u0E31\u0E14\u0E40\u0E01\u0E47\u0E1A :</span>-->\n                                        <!--</div>-->\n                                        <div class=\"col-sm-12\">\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().record_date.errors }\">-->\n                                                <label class=\"control-label\">\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E08\u0E31\u0E14\u0E40\u0E01\u0E47\u0E1A</label>\n                                                <soc-date-box [id]=\"'txtDate'\" [(value)]=\"attachmentData.record_date\" [disabled]=\"true\"></soc-date-box>\n                                                <!--<div *ngIf=\"submitted && f().record_date.errors\" >-->\n                                                    <!--<div *ngIf=\"f().record_date.errors.required\" class=\"lable-error\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E08\u0E31\u0E14\u0E40\u0E01\u0E47\u0E1A</div>-->\n                                                    <!--<div *ngIf=\"f().record_date.errors.date\" class=\"lable-error\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E08\u0E31\u0E14\u0E40\u0E01\u0E47\u0E1A \u0E43\u0E2B\u0E49\u0E16\u0E39\u0E01\u0E15\u0E49\u0E2D\u0E07</div>-->\n                                                <!--</div>-->\n                                            <!--</div>-->\n                                        </div>\n                                    </div>\n                                </div>\n                                <!--<div *ngIf=\"attachmentData.system_id === 17\">-->\n                                    <!--<div class=\"row\">-->\n                                        <!--<div class=\"col-sm-2\">-->\n                                            <!--<span>\u0E40\u0E27\u0E2D\u0E23\u0E4C\u0E0A\u0E31\u0E48\u0E19/\u0E40\u0E25\u0E02\u0E23\u0E38\u0E48\u0E19 :</span>-->\n                                        <!--</div>-->\n                                        <!--<div class=\"col-sm-10\">-->\n                                            <!--<div class=\"form-group m-form__group\" [ngClass]=\"{ 'has-error': submitted && f().version.errors }\">-->\n                                                <!--<input type=\"text\" class=\"form-control m-input\" id=\"txtVersion\"  name=\"version\" formControlName=\"version\" [(ngModel)]=\"attachmentData.version\">-->\n                                                <!--<div *ngIf=\"submitted && f().version.errors\" class=\"invalid-feedback\">-->\n                                                    <!--<div *ngIf=\"f().version.errors.required\">\u0E01\u0E23\u0E38\u0E13\u0E32\u0E01\u0E23\u0E2D\u0E01 \u0E40\u0E27\u0E2D\u0E23\u0E4C\u0E0A\u0E31\u0E48\u0E19/\u0E40\u0E25\u0E02\u0E23\u0E38\u0E48\u0E19</div>-->\n                                                <!--</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 *ngIf=\"mode !== 'VIEW'\" type=\"submit\" class=\"btn btn-success btn-md btn-md-save\">-->\n                                        <!--\u0E1A\u0E31\u0E19\u0E17\u0E36\u0E01-->\n                                    <!--</button>-->\n                                    <button type=\"button\" 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>"
                }] }
    ];
    /** @nocollapse */
    ModalAttachmentViewComponent.ctorParameters = function () { return [
        { type: AppConfigService },
        { type: Request },
        { type: FormBuilder },
        { type: Common }
    ]; };
    ModalAttachmentViewComponent.propDecorators = {
        isImage: [{ type: Input }],
        onModalCreateSubmit: [{ type: Output }],
        onModalEditSubmit: [{ type: Output }],
        modal: [{ type: ViewChild, args: ['modal',] }],
        uploadAttachment: [{ type: ViewChild, args: ['uploadAttachment',] }]
    };
    return ModalAttachmentViewComponent;
}(Options));
export { ModalAttachmentViewComponent };
if (false) {
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.isImage;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.onModalCreateSubmit;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.onModalEditSubmit;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.modal;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.uploadAttachment;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.registerForm;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.control;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.submitted;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.title;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.selectList;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.modalConfig;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.th;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.isMore;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.moreField;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.config;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.attachmentData;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.tmpData;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.filteredDepartments;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.departmentList;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.attachmentUrl;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.disabledForm;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.isOpen;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.appConfigService;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.request;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.formBuilder;
    /** @type {?} */
    ModalAttachmentViewComponent.prototype.common;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-attachment-view.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/modal-attachment-view/modal-attachment-view.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 {UploadAttachmentComponent} from '../upload-attachment/upload-attachment.component';\nimport * as _ from 'lodash';\n\nclass Options {\n    /** title ที่ต้องการแสดง */\n    title?: String;\n    /** data */\n    data: any;\n    mode: any;\n    downloadToken: any;\n    /** name ที่ต้องการแสดง */\n    config: any;\n}\n\n@Component({\n    selector: 'modal-attachment-view',\n    templateUrl: './modal-attachment-view.component.html',\n})\nexport class ModalAttachmentViewComponent extends Options implements OnInit {\n\n    @Input() isImage :boolean = false;\n    @Output() onModalCreateSubmit = new EventEmitter();\n    @Output() onModalEditSubmit = new EventEmitter();\n    @ViewChild('modal') modal: ModalDirective;\n    @ViewChild('uploadAttachment') uploadAttachment: UploadAttachmentComponent;\n    registerForm: FormGroup;\n    control: AbstractControl;\n    submitted = false;\n    title: any = '';\n    selectList: any = [];\n    modalConfig: ModalOptions = {\n        ignoreBackdropClick: true\n    };\n    th;\n    isMore = false;\n    moreField: any;\n    public config: any;\n    attachmentData: any = {\n        doc_type:null\n    };\n    tmpData:any = {};\n    filteredDepartments:any = [];\n    departmentList:any = [];\n    attachmentUrl;\n    disabledForm = false;\n    isOpen = false;\n\n    constructor(private appConfigService: AppConfigService, private request: Request, private formBuilder: FormBuilder, public common: Common) {\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    }\n\n    ngOnInit() {\n        this.th = this.common.fnLocalPCalendar('th');\n        this.registerForm = this.formBuilder.group({\n            name: [{ value: '', disabled: this.disabledForm }],\n            doc_type: [{ value: '', disabled: this.disabledForm }],\n            url: [{ value: '', disabled: this.disabledForm }],\n            is_classifieds: [{ value: '', disabled: this.disabledForm }],\n            is_image: [{ value: '', disabled: this.disabledForm }],\n            keyword: [{ value: '', disabled: this.disabledForm }],\n            book_no: [{ value: '', disabled: this.disabledForm }],\n            amount: [{ value: '', disabled: this.disabledForm }],\n            record_date: [{ value: '', disabled: this.disabledForm }],\n            version: [{ value: '', disabled: this.disabledForm }],\n            resolution: [{ value: '', disabled: this.disabledForm }],\n            remark: [{ value: '', disabled: this.disabledForm }],\n            moreField: this.formBuilder.array([])\n        });\n    }\n\n    async open(options?: Options) {\n        console.log(options);\n        this.attachmentData = {};\n        if (options) {\n            this.mode = options.mode;\n            this.title = options.title || '';\n            this.downloadToken = options.downloadToken;\n            this.attachmentData = _.cloneDeep(options.data);\n            if(!this.attachmentData.doc_type){\n                this.attachmentData.doc_type = null;\n            }\n            // ต้องเปลี่ยนเป็นเรียก api\n            this.selectList = await this.request.getDropDown(options.data.system_id,\"ประเภทเอกสาร\");\n        }\n        if(this.mode !== 'VIEW'){\n            this.uploadAttachment.clearValue();\n            this.disabledForm = false;\n        }else{\n            this.disabledForm = true;\n        }\n        this.modal.show();\n        this.isOpen = true;\n    }\n\n    f() {\n        return this.registerForm.controls;\n    }\n\n    closeModal() {\n        this.submitted = false;\n        this.selectList = [];\n        this.isMore = false;\n        this.moreField = [];\n        this.attachmentData = {};\n        this.modal.hide();\n        this.isOpen = false;\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    async checkExtraField() {\n        this.moreField = [];\n        if (this.attachmentData.system_id ) {\n            // this.addField(newField, +requireFlag);\n            // this.moreField.push(newField);\n            this.isMore = true;\n        } else {\n            this.isMore = false;\n        }\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    addField(data, required) {\n        const control = <FormArray>this.registerForm.controls['moreField'];\n        let newgroup;\n        if (data.type === 'text') {\n            if (required) {\n                const group: any = {};\n                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];\n                newgroup = this.formBuilder.group(group);\n            } else {\n                const group: any = {};\n                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];\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] = [{ value: '', disabled: this.disabledForm }];\n                newgroup = this.formBuilder.group(group);\n            }\n        } else if (data.type === 'special'){\n            if (required) {\n                const group: any = {};\n                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];\n                newgroup = this.formBuilder.group(group);\n            } else {\n                const group: any = {};\n                group[data.field_name] = [{ value: '', disabled: this.disabledForm }];\n                newgroup = this.formBuilder.group(group);\n            }\n            if(data.field_name === 'amount'){\n                const group: any = {};\n                group['amount_type'] = [{ value: '', disabled: this.disabledForm }];\n                control.push(this.formBuilder.group(group));\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    async onSubmit() {\n        this.submitted = true;\n        // ถ้า form ไม่ครบหรือผิดตามเงื่อนไขที่ตั้งไว้จะจบที่ตรงนี้\n        if (this.registerForm.invalid) {\n            return;\n        }\n        // let postData = [];\n        // await this.request.post(\"/db/rc_attachment\",this.attachmentData);\n        if(this.mode === 'CREATE'){\n            this.onModalCreateSubmit.emit(this.attachmentData);\n        }else{\n            this.onModalEditSubmit.emit(this.attachmentData);\n        }\n        this.closeModal();;\n        this.isOpen = false;\n    }\n\n    onUploaded(data){\n        console.log(\"data\",data);\n        this.attachmentData.url = this.attachmentUrl+'/'+data.uuid;\n        this.attachmentData.uuid = data.uuid;\n        this.attachmentData.filename = data.fileName;\n    }\n\n    async clickUrl(){\n        window.open(await this.request.getAttachmentLinkToken(this.attachmentData.url));\n    }\n\n    getImageLink(data){\n        return data.url+\"?downloadToken=\"+this.downloadToken;\n    }\n}\n"]}