step-list.component.js 19.9 KB
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Component, ViewChild, Input } from '@angular/core';
import { AppConfigService } from '../app-config/app-config.service';
import { DxDataGridComponent } from 'devextreme-angular';
import { Request } from '../_services/request.service';
import { Common } from '../_services/common.service';
import { ModalStepViewComponent } from '../modal-step-view/modal-step-view.component';
import { B2bService } from '../_services/b2b.service';
var StepListComponent = /** @class */ (function () {
    function StepListComponent(appConfigService, request, common, b2b) {
        this.appConfigService = appConfigService;
        this.request = request;
        this.common = common;
        this.b2b = b2b;
        this.mode = 'CREATE';
        this.columns = ['ลำดับที่', 'ผู้แก้ไข', 'วันที่', 'สถานะการติดตาม', 'หมายเหตุ'];
        this.stepList = [];
        this.dxgridPageSize = 10;
        this.allowedPageSizes1 = 10;
        this.allowedPageSizes2 = 25;
        this.allowedPageSizes3 = 50;
        this.allowedPageSizes4 = 100;
        this.customers = [];
        this.lastStep = '';
        this.config = appConfigService.getConfig();
    }
    /**
     * @return {?}
     */
    StepListComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
        var _this = this;
        setTimeout(function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
            var _a;
            return tslib_1.__generator(this, function (_b) {
                switch (_b.label) {
                    case 0:
                        _a = this;
                        return [4 /*yield*/, this.b2b.getAttachmentToken()];
                    case 1:
                        _a.downloadToken = _b.sent();
                        return [2 /*return*/];
                }
            });
        }); }, 500);
        if (this.mode !== "CREATE") {
            this.getStepList();
        }
    };
    /**
     * @return {?}
     */
    StepListComponent.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', this.stepList);
                        filter = {
                            filter: {
                                ref_table: "=" + this.option.data.ref_table,
                                ref_id: this.option.data.ref_id,
                                system_id: this.option.data.system_id
                            },
                            order_by: ["step_date desc"]
                        };
                        return [4 /*yield*/, this.request.post('/search/ct_step_data', filter)];
                    case 1:
                        data = _a.sent();
                        this.stepList = data.resultData;
                        if (this.stepList && this.stepList.length > 0) {
                            this.lastStep = this.stepList[0].name;
                        }
                        console.log('getStepList', this.stepList);
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @param {?} data
     * @return {?}
     */
    StepListComponent.prototype.addStepList = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var userData = this.b2b.getVerifyToken();
        data.username = userData.username;
        this.stepList.push(data);
        console.log('getStepList', this.stepList);
    };
    /**
     * @param {?} data
     * @return {?}
     */
    StepListComponent.prototype.getRowIndex = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        if (!data.data) {
            return '';
        }
        /** @type {?} */
        var page = this.dxDataGridStepList.instance.option('paging.pageIndex') || 0;
        /** @type {?} */
        var pageSize = this.dxDataGridStepList.instance.option('paging.pageSize');
        /** @type {?} */
        var no = data.row.dataIndex + 1;
        return page * pageSize + no;
    };
    /**
     * @param {?} data
     * @return {?}
     */
    StepListComponent.prototype.view = /**
     * @param {?} data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var viewData = {
            option: this.option,
            data: data,
            downloadToken: this.downloadToken
        };
        this.modalStepView.open(viewData);
    };
    /**
     * @return {?}
     */
    StepListComponent.prototype.getLastStep = /**
     * @return {?}
     */
    function () {
        return this.lastStep;
    };
    /**
     * @param {?} e
     * @return {?}
     */
    StepListComponent.prototype.onCellPrepared = /**
     * @param {?} e
     * @return {?}
     */
    function (e) {
        if (e.rowType === 'data') {
            e.cellElement.accessKey = e.column.caption;
        }
    };
    StepListComponent.decorators = [
        { type: Component, args: [{
                    selector: 'soc-step-list',
                    template: "<div class=\"col-sm-12\">\n    <!--[selectedRowKeys]=\"selectRowKeyId\" (onInitialized)=\"onInitialized($event)\" (onSelectionChanged)=\"selectRow($event)\"-->\n    <div class=\"table-responsive table-wrapper\">\n      <!--<dx-data-grid #dxDataGridStepList id=\"dxDataGridStepList\" [dataSource]=\"ds\" [hoverStateEnabled]=\"true\" noDataText=\"\"-->\n                    <!--showBorders=\"true\" [rowAlternationEnabled]=\"true\" [columnAutoWidth]=\"true\"-->\n                    <!--[columns]=\"columns\"-->\n                    <!--class=\"card-list-table\"-->\n                    <!--[allowColumnResizing]=\"true\"-->\n                    <!--[allowColumnReordering]=\"true\"-->\n                    <!--[wordWrapEnabled]=\"true\"-->\n                    <!--[columnMinWidth]=\"'100%'\" class=\"card-list-table\">-->\n        <!--<dxo-paging [pageSize]=\"dxgridPageSize\"></dxo-paging>-->\n        <!--<dxo-pager [showPageSizeSelector]=\"true\" [allowedPageSizes]=\"[allowedPageSizes1, allowedPageSizes2, allowedPageSizes3, allowedPageSizes4]\"-->\n                   <!--[showInfo]=\"false\" [visible]=\"true\" [showNavigationButtons]=\"true\">-->\n        <!--</dxo-pager>-->\n        <!--<dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>-->\n        <!--<dxo-remote-operations [sorting]=\"true\" [paging]=\"true\">-->\n        <!--</dxo-remote-operations>-->\n      <!--</dx-data-grid>-->\n      <dx-data-grid #dxDataGridStepList\n            id=\"gridContainer\" noDataText=\"\" showBorders=\"true\" class=\"card-list-table\"\n            (onCellPrepared)=\"onCellPrepared($event)\" [dataSource]=\"stepList\"\n            [hoverStateEnabled]=\"true\" [rowAlternationEnabled]=\"true\" [columnAutoWidth]=\"false\"\n            [allowColumnResizing]=\"true\" [allowColumnReordering]=\"true\" [wordWrapEnabled]=\"false\"\n            [showBorders]=\"true\">\n            <dxi-column caption=\"\u0E25\u0E33\u0E14\u0E31\u0E1A\u0E17\u0E35\u0E48\" [allowSorting]=\"false\" cellTemplate=\"cellTemplate\" alignment=\"center\" [width]=\"70\"></dxi-column>\n            <dxi-column caption=\"\u0E08\u0E31\u0E14\u0E01\u0E32\u0E23\" [allowSorting]=\"false\" cellTemplate=\"cellTemplateAction\" alignment=\"center\" [width]=\"70\"></dxi-column>\n            <dxi-column dataField=\"username\" caption=\"\u0E1C\u0E39\u0E49\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23\"></dxi-column>\n            <dxi-column dataField=\"step_date\" [caption]=\"option.data.system_id === 161?'\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48':'\u0E27\u0E31\u0E19\u0E17\u0E35\u0E48\u0E14\u0E33\u0E40\u0E19\u0E34\u0E19\u0E01\u0E32\u0E23'\" dataType=\"date\" alignment=\"center\" [width]=\"100\"></dxi-column>\n            <dxi-column dataField=\"step_name\" caption=\"\u0E2A\u0E16\u0E32\u0E19\u0E30\u0E01\u0E32\u0E23\u0E15\u0E34\u0E14\u0E15\u0E32\u0E21\"></dxi-column>\n            <dxi-column dataField=\"remark\" caption=\"\u0E2B\u0E21\u0E32\u0E22\u0E40\u0E2B\u0E15\u0E38\"></dxi-column>\n            <dxo-paging [pageSize]=\"dxgridPageSize\"></dxo-paging>\n            <dxo-pager [showPageSizeSelector]=\"true\" [allowedPageSizes]=\"[allowedPageSizes1, allowedPageSizes2, allowedPageSizes3, allowedPageSizes4]\"\n            [showInfo]=\"false\" [visible]=\"true\" [showNavigationButtons]=\"true\">\n            </dxo-pager>\n            <dxo-state-storing [enabled]=\"true\" type=\"localStorage\" storageKey=\"stepListDataGrid\"></dxo-state-storing>\n            <div *dxTemplate=\"let data of 'cellTemplate'\">\n              {{getRowIndex(data)}}\n            </div>\n            <div *dxTemplate=\"let data of 'cellTemplateAction'\">\n              <a id=\"btnView\" (click)=\"view(data.data)\" class=\"btn btn-default btn-sm icon\" data-toggle=\"tooltip\" data-placement=\"top\" title=\"\u0E14\u0E39\u0E02\u0E49\u0E2D\u0E21\u0E39\u0E25\"><i class=\"fal fa-eye\"></i></a>\n            </div>\n      </dx-data-grid>\n    </div>\n</div><!--End col-sm-12-->\n<!--<modal-step #modalStep (onUpdateModal)='getStepList()' (onCreateModal)=\"addStepList($event)\" [mode]=\"mode\"></modal-step>-->\n<modal-step-view #modalStepView ></modal-step-view>\n"
                }] }
    ];
    /** @nocollapse */
    StepListComponent.ctorParameters = function () { return [
        { type: AppConfigService },
        { type: Request },
        { type: Common },
        { type: B2bService }
    ]; };
    StepListComponent.propDecorators = {
        mode: [{ type: Input }],
        option: [{ type: Input }],
        dxDataGridStepList: [{ type: ViewChild, args: ['dxDataGridStepList',] }],
        modalStepView: [{ type: ViewChild, args: ['modalStepView',] }]
    };
    return StepListComponent;
}());
export { StepListComponent };
if (false) {
    /** @type {?} */
    StepListComponent.prototype.mode;
    /** @type {?} */
    StepListComponent.prototype.option;
    /** @type {?} */
    StepListComponent.prototype.dxDataGridStepList;
    /** @type {?} */
    StepListComponent.prototype.modalStepView;
    /** @type {?} */
    StepListComponent.prototype.columns;
    /** @type {?} */
    StepListComponent.prototype.stepList;
    /** @type {?} */
    StepListComponent.prototype.th;
    /** @type {?} */
    StepListComponent.prototype.dxgridPageSize;
    /** @type {?} */
    StepListComponent.prototype.allowedPageSizes1;
    /** @type {?} */
    StepListComponent.prototype.allowedPageSizes2;
    /** @type {?} */
    StepListComponent.prototype.allowedPageSizes3;
    /** @type {?} */
    StepListComponent.prototype.allowedPageSizes4;
    /** @type {?} */
    StepListComponent.prototype.customers;
    /** @type {?} */
    StepListComponent.prototype.url;
    /** @type {?} */
    StepListComponent.prototype.lastStep;
    /** @type {?} */
    StepListComponent.prototype.config;
    /** @type {?} */
    StepListComponent.prototype.downloadToken;
    /** @type {?} */
    StepListComponent.prototype.appConfigService;
    /** @type {?} */
    StepListComponent.prototype.request;
    /** @type {?} */
    StepListComponent.prototype.common;
    /** @type {?} */
    StepListComponent.prototype.b2b;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-list.component.js","sourceRoot":"ng://soc-app-library/","sources":["lib/step-list/step-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, AfterViewInit, ViewChild, Input} from '@angular/core';\nimport {ModalStepComponent} from '../modal-step/modal-step.component';\nimport {AppConfigService} from '../app-config/app-config.service';\nimport {DxDataGridComponent} from 'devextreme-angular';\nimport { Request } from '../_services/request.service';\nimport {Common} from '../_services/common.service';\nimport {ModalStepViewComponent} from '../modal-step-view/modal-step-view.component';\nimport {B2bService} from '../_services/b2b.service';\n\n@Component({\n  selector: 'soc-step-list',\n  templateUrl: './step-list.component.html'\n})\nexport class StepListComponent implements OnInit {\n\n    @Input() mode: 'CREATE'|'EDIT'|'VIEW' = 'CREATE';\n    @Input() option: any;\n    @ViewChild('dxDataGridStepList')\n    dxDataGridStepList: DxDataGridComponent;\n    // @ViewChild('modalStep')\n    // modalStep: ModalStepComponent;\n    @ViewChild('modalStepView')\n    modalStepView: ModalStepViewComponent;\n\n    columns = ['ลำดับที่', 'ผู้แก้ไข', 'วันที่', 'สถานะการติดตาม', 'หมายเหตุ'];\n    stepList: any = [];\n    th;\n    dxgridPageSize = 10;\n    allowedPageSizes1 = 10;\n    allowedPageSizes2 = 25;\n    allowedPageSizes3 = 50;\n    allowedPageSizes4 = 100;\n    customers = [];\n    url;\n    lastStep = '';\n    config: any;\n    downloadToken;\n    constructor(\n        private appConfigService: AppConfigService,\n        private request: Request,\n        public common: Common,\n        private b2b:B2bService) {\n        this.config = appConfigService.getConfig();\n    }\n\n    ngOnInit() {\n        setTimeout(async ()=>{\n            this.downloadToken = await this.b2b.getAttachmentToken();\n        },500)\n        if(this.mode !== \"CREATE\"){\n            this.getStepList();\n        }\n    }\n    async getStepList() {\n        console.log('getStepList',this.stepList);\n        let filter = {\n            filter:{\n                ref_table:\"=\"+this.option.data.ref_table,\n                ref_id:this.option.data.ref_id,\n                system_id:this.option.data.system_id\n            },\n            order_by:[\"step_date desc\"]\n        }\n        const data = await this.request.post('/search/ct_step_data', filter);\n        this.stepList = data.resultData;\n        if (this.stepList && this.stepList.length > 0) {\n            this.lastStep = this.stepList[0].name;\n        }\n        console.log('getStepList',this.stepList);\n    }\n\n    addStepList(data) {\n        let userData:any = this.b2b.getVerifyToken();\n        data.username = userData.username;\n        this.stepList.push(data);\n        console.log('getStepList',this.stepList);\n    }\n\n    getRowIndex(data) {\n        if (!data.data) {\n            return '';\n        }\n        const page = this.dxDataGridStepList.instance.option('paging.pageIndex') || 0;\n        const pageSize = this.dxDataGridStepList.instance.option('paging.pageSize');\n        const no = data.row.dataIndex + 1;\n        return page * pageSize + no;\n    }\n    view(data) {\n        const viewData = {\n            option: this.option,\n            data: data,\n            downloadToken: this.downloadToken\n        };\n        this.modalStepView.open(viewData);\n    }\n    getLastStep(){\n        return this.lastStep;\n    }\n\n    onCellPrepared(e) {\n        if (e.rowType === 'data') {\n            e.cellElement.accessKey = e.column.caption;\n        }\n    }\n}\n"]}