auto-complete2.js 30.1 KB
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { NgModule, Component, Input, Output, EventEmitter, forwardRef } from '@angular/core';
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
import { CommonModule } from '@angular/common';
import { SharedModule } from 'primeng/primeng';
import { Request } from '../_services/request.service';
import * as _ from 'lodash';
import { DxSelectBoxModule } from 'devextreme-angular';
import DataSource from 'devextreme/data/data_source';
import CustomStore from 'devextreme/data/custom_store';
import ArrayStore from 'devextreme/data/array_store';
export class SocAutoComplete2Component {
    /**
     * @param {?} request
     */
    constructor(request) {
        this.request = request;
        this.filteredOptions = [];
        /**
         * local, remote
         */
        this.mode = 'local';
        /**
         * API ที่ต้องการเรียกใช้เมื่อพิมพ์ auto complete
         */
        this.api = '';
        /**
         * field ที่ต้องการ query เมื่อยิง API
         */
        this.field = '';
        this.fieldApi = '';
        this.id = '';
        this.placeholder = '';
        this.disabled = false;
        this.orderBy = '';
        this.filter = '';
        this.ex_type_view = '';
        this.limit = 1000;
        this.onLoad = new EventEmitter();
        this.valueChange = new EventEmitter();
        this.valueSelete = new EventEmitter();
        this.storeOnLoaded = new EventEmitter();
        this.acceptCustomValue = true;
        this.resData = [];
        this.loadOptionData = [];
        this.openOnFieldClick = false;
        this.showDropDownButton = false;
        // acceptCustomValue = true;
        this.searchEnabled = true;
        this.inputValue = '';
        this.fnCustomStoreOnLoaded = (result) => {
            this.storeOnLoaded.emit(result);
            return result;
        };
        /**
         * START Bind Value
         */
        this.onModelChange = () => { };
        this.onModelTouched = () => { };
    }
    /**
     * @return {?}
     */
    ngOnInit() {
        return tslib_1.__awaiter(this, void 0, void 0, function* () {
            if (this.mode === 'dropdown') {
                this.acceptCustomValue = false;
                this.searchEnabled = false;
            }
            /** ถ้าเป็น โหมด local จะแสดง list ให้เลือกเลย แตถ้่เป็น remote จะต้องขึ้นเมื่อพิมพ์เท่านั้น */
            if (this.mode === 'local' || this.mode === 'dropdown') {
                this.openOnFieldClick = true;
                this.showDropDownButton = true;
                this.fnStartDataSourceLocal();
            }
            else {
                this.fnStartDataSourceRemote();
            }
        });
    }
    /**
     * @return {?}
     */
    ngAfterViewInit() {
    }
    /**
     * @return {?}
     */
    fnStartDataSourceLocal() {
        return tslib_1.__awaiter(this, void 0, void 0, function* () {
            /** @type {?} */
            let params = `?_fields=${this.fieldApi ? this.fieldApi : this.field}`;
            if (this.filter) {
                params += this.filter; //`&_where=(${this.filter})`
            }
            if (this.orderBy && this.orderBy !== '') {
                params += `&_sort=${this.orderBy}`;
            }
            params += `&_limit=${this.limit}`;
            /** @type {?} */
            let resData = yield this.fnPreResponse(params);
            this.ds = new DataSource({
                store: new ArrayStore({
                    data: resData,
                    onLoaded: this.fnCustomStoreOnLoaded
                })
            });
        });
    }
    /**
     * @return {?}
     */
    fnStartDataSourceRemote() {
        return tslib_1.__awaiter(this, void 0, void 0, function* () {
            this.ds = new DataSource({
                store: new CustomStore({
                    byKey: (key) => tslib_1.__awaiter(this, void 0, void 0, function* () {
                        this.onLoad.emit(key);
                        return this.fnGetCustomStore(key);
                    }),
                    load: (loadOptions) => tslib_1.__awaiter(this, void 0, void 0, function* () {
                        this.onLoad.emit(loadOptions.searchValue);
                        return this.fnGetCustomStore(loadOptions.searchValue);
                        ;
                    }),
                    onLoaded: this.fnCustomStoreOnLoaded
                })
            });
        });
    }
    /**
     * @param {?} key
     * @return {?}
     */
    fnGetCustomStore(key) {
        /** @type {?} */
        let params = `?_fields=${this.fieldApi ? this.fieldApi : this.field}&_where=(${this.field},like,$${key}$)`;
        if (this.filter) {
            params = `?_fields=${this.fieldApi ? this.fieldApi : this.field}&_where=((${this.field},like,$${key}$)$and(${this.filter}))`;
        }
        if (this.orderBy && this.orderBy !== '') {
            params += `&_sort=${this.orderBy}`;
        }
        params += `&_limit=${this.limit}`;
        return this.fnPreResponse(params);
        ;
    }
    /**
     * @param {?} e
     * @return {?}
     */
    onValueChanged(e) {
        this.onValueSelete(e);
        console.log("​SocAutoCompleteComponent -> onValueChanged -> e", e);
        this.valueChange.emit(e.value);
    }
    /**
     * @param {?} e
     * @return {?}
     */
    onValueSelete(e) {
        /** @type {?} */
        let temp = _.find(this.loadOptionData, r => {
            if (this.ex_type_view === "ct_dropdown") {
                return `${r.code} - ${r.name}` === e.value;
            }
            else if (this.ex_type_view === "ct_ext_departmen") {
                return `${r.short_name} - ${r.name}` === e.value;
            }
            return r[this.field] === e.value;
        });
        console.log("​SocAutoCompleteComponent -> onValueSelete -> e", e, temp);
        this.valueSelete.emit(temp);
    }
    /**
     * @param {?} params
     * @return {?}
     */
    fnPreResponse(params) {
        return tslib_1.__awaiter(this, void 0, void 0, function* () {
            /** @type {?} */
            let resData = yield this.request.get(this.api + params);
            resData = _.map(resData, (obj) => {
                return obj; //[this.field]
            });
            /** @type {?} */
            let _resData = [];
            for (let i in resData) {
                /** @type {?} */
                let temp = _.find(_resData, r => r[this.field] === resData[i][this.field]);
                if (!temp) {
                    _resData.push(resData[i]);
                }
            }
            this.loadOptionData = _resData;
            return _.map(_resData, (obj) => {
                if (this.ex_type_view === "ct_dropdown") {
                    return `${obj.code} - ${obj.name}`;
                }
                else if (this.ex_type_view === "ct_ext_departmen") {
                    return `${obj.short_name} - ${obj.name}`;
                }
                return obj[this.field];
            });
        });
    }
    /**
     * @param {?} e
     * @return {?}
     */
    onOpened(e) {
        /** @type {?} */
        const element = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-dropdownlist-popup-wrapper.dx-selectbox-popup-wrapper');
        element.setAttribute('style', 'z-index:9999;');
    }
    /**
     * @param {?} value
     * @return {?}
     */
    writeValue(value) { }
    /**
     * @param {?} fn
     * @return {?}
     */
    registerOnChange(fn) { }
    /**
     * @param {?} fn
     * @return {?}
     */
    registerOnTouched(fn) { }
}
SocAutoComplete2Component.decorators = [
    { type: Component, args: [{
                selector: 'soc-auto-complete-2',
                providers: [{
                        provide: NG_VALUE_ACCESSOR,
                        useExisting: forwardRef(() => SocAutoComplete2Component),
                        multi: true
                    }],
                template: `
      <dx-select-box [dataSource]="ds"
                [searchEnabled]="searchEnabled"
                [openOnFieldClick]="openOnFieldClick"
                [showClearButton]="true"
                [showDropDownButton]="showDropDownButton"
                [inputAttr]="{ id: id }"
                [acceptCustomValue]="acceptCustomValue"
                [placeholder]="placeholder"
                [(value)]="value"
                (onValueChanged)="onValueChanged($event)"
                (onOpened)="onOpened($event)"
                [disabled]="disabled"
                noDataText="ไม่พบข้อมูล"
                placeholder="กรุณาเลือกรายการ"
            ></dx-select-box>
`
            }] }
];
/** @nocollapse */
SocAutoComplete2Component.ctorParameters = () => [
    { type: Request }
];
SocAutoComplete2Component.propDecorators = {
    mode: [{ type: Input }],
    api: [{ type: Input }],
    field: [{ type: Input }],
    fieldApi: [{ type: Input }],
    id: [{ type: Input }],
    placeholder: [{ type: Input }],
    value: [{ type: Input }],
    disabled: [{ type: Input }],
    orderBy: [{ type: Input }],
    filter: [{ type: Input }],
    ex_type_view: [{ type: Input }],
    limit: [{ type: Input }],
    onLoad: [{ type: Output }],
    valueChange: [{ type: Output }],
    valueSelete: [{ type: Output }],
    storeOnLoaded: [{ type: Output }],
    acceptCustomValue: [{ type: Input }]
};
if (false) {
    /** @type {?} */
    SocAutoComplete2Component.prototype.filteredOptions;
    /**
     * local, remote
     * @type {?}
     */
    SocAutoComplete2Component.prototype.mode;
    /**
     * API ที่ต้องการเรียกใช้เมื่อพิมพ์ auto complete
     * @type {?}
     */
    SocAutoComplete2Component.prototype.api;
    /**
     * field ที่ต้องการ query เมื่อยิง API
     * @type {?}
     */
    SocAutoComplete2Component.prototype.field;
    /** @type {?} */
    SocAutoComplete2Component.prototype.fieldApi;
    /** @type {?} */
    SocAutoComplete2Component.prototype.id;
    /** @type {?} */
    SocAutoComplete2Component.prototype.placeholder;
    /** @type {?} */
    SocAutoComplete2Component.prototype.value;
    /** @type {?} */
    SocAutoComplete2Component.prototype.disabled;
    /** @type {?} */
    SocAutoComplete2Component.prototype.orderBy;
    /** @type {?} */
    SocAutoComplete2Component.prototype.filter;
    /** @type {?} */
    SocAutoComplete2Component.prototype.ex_type_view;
    /** @type {?} */
    SocAutoComplete2Component.prototype.limit;
    /** @type {?} */
    SocAutoComplete2Component.prototype.onLoad;
    /** @type {?} */
    SocAutoComplete2Component.prototype.valueChange;
    /** @type {?} */
    SocAutoComplete2Component.prototype.valueSelete;
    /** @type {?} */
    SocAutoComplete2Component.prototype.storeOnLoaded;
    /** @type {?} */
    SocAutoComplete2Component.prototype.acceptCustomValue;
    /** @type {?} */
    SocAutoComplete2Component.prototype.resData;
    /** @type {?} */
    SocAutoComplete2Component.prototype.loadOptionData;
    /** @type {?} */
    SocAutoComplete2Component.prototype.openOnFieldClick;
    /** @type {?} */
    SocAutoComplete2Component.prototype.showDropDownButton;
    /** @type {?} */
    SocAutoComplete2Component.prototype.searchEnabled;
    /** @type {?} */
    SocAutoComplete2Component.prototype.inputValue;
    /**
     * ds
     * @type {?}
     */
    SocAutoComplete2Component.prototype.ds;
    /** @type {?} */
    SocAutoComplete2Component.prototype.fnCustomStoreOnLoaded;
    /**
     * START Bind Value
     * @type {?}
     */
    SocAutoComplete2Component.prototype.onModelChange;
    /** @type {?} */
    SocAutoComplete2Component.prototype.onModelTouched;
    /** @type {?} */
    SocAutoComplete2Component.prototype.request;
}
export class SharedAutoComplete2Module {
}
SharedAutoComplete2Module.decorators = [
    { type: NgModule, args: [{
                imports: [CommonModule, FormsModule, SharedModule, DxSelectBoxModule],
                exports: [SocAutoComplete2Component, SharedModule],
                declarations: [SocAutoComplete2Component],
            },] }
];

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete2.js","sourceRoot":"ng://soc-app-library/","sources":["lib/_template/auto-complete2.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    NgModule, Component, OnInit, Input, Output, EventEmitter, forwardRef, AfterViewInit\n} from '@angular/core';\nimport { FormsModule, NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { SharedModule } from 'primeng/primeng';\nimport { Request } from '../_services/request.service';\nimport * as _ from 'lodash';\nimport { DxSelectBoxModule } from 'devextreme-angular';\nimport DataSource from 'devextreme/data/data_source';\nimport CustomStore from 'devextreme/data/custom_store';\nimport ArrayStore from 'devextreme/data/array_store';\n\n@Component({\n    selector: 'soc-auto-complete-2',\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => SocAutoComplete2Component),\n        multi: true\n    }],\n    template: `\n      <dx-select-box [dataSource]=\"ds\"\n                [searchEnabled]=\"searchEnabled\"\n                [openOnFieldClick]=\"openOnFieldClick\"\n                [showClearButton]=\"true\"\n                [showDropDownButton]=\"showDropDownButton\"\n                [inputAttr]=\"{ id: id }\"\n                [acceptCustomValue]=\"acceptCustomValue\"\n                [placeholder]=\"placeholder\"\n                [(value)]=\"value\"\n                (onValueChanged)=\"onValueChanged($event)\"\n                (onOpened)=\"onOpened($event)\"\n                [disabled]=\"disabled\"\n                noDataText=\"ไม่พบข้อมูล\"\n                placeholder=\"กรุณาเลือกรายการ\"\n            ></dx-select-box>\n`\n})\nexport class SocAutoComplete2Component implements ControlValueAccessor, OnInit, AfterViewInit {\n    filteredOptions = [];\n    /** local, remote */\n    @Input() mode: 'local' | 'remote' | 'dropdown' = 'local';\n    /** API ที่ต้องการเรียกใช้เมื่อพิมพ์ auto complete */\n    @Input() api = '';\n    /** field ที่ต้องการ query เมื่อยิง API */\n    @Input() field = '';\n    @Input() fieldApi = '';\n\n    @Input() id = '';\n    @Input() placeholder = '';\n    @Input() value: String;\n    @Input() disabled = false;\n    @Input() orderBy = '';\n    @Input() filter = '';\n    @Input() ex_type_view = '';\n\n    @Input() limit = 1000;\n    @Output() onLoad: EventEmitter<any> = new EventEmitter<any>();\n    @Output() valueChange: EventEmitter<string> = new EventEmitter<string>();\n    @Output() valueSelete: EventEmitter<string> = new EventEmitter<string>();\n    @Output() storeOnLoaded: EventEmitter<string> = new EventEmitter<string>();\n\n    @Input() acceptCustomValue = true;\n    resData = [];\n    loadOptionData = [];\n    openOnFieldClick = false;\n    showDropDownButton = false;\n    // acceptCustomValue = true;\n    searchEnabled = true;\n    inputValue = '';\n    /** ds */\n    ds: DataSource;\n    constructor(private request: Request) { }\n    async ngOnInit() {\n        if (this.mode === 'dropdown') {\n            this.acceptCustomValue = false;\n            this.searchEnabled = false;\n        }\n        /** ถ้าเป็น โหมด local จะแสดง list ให้เลือกเลย แตถ้่เป็น remote จะต้องขึ้นเมื่อพิมพ์เท่านั้น */\n        if (this.mode === 'local' || this.mode === 'dropdown') {\n            this.openOnFieldClick = true;\n            this.showDropDownButton = true;\n            this.fnStartDataSourceLocal();\n        } else {\n            this.fnStartDataSourceRemote();\n        }\n    }\n    ngAfterViewInit() {\n    }\n\n    async fnStartDataSourceLocal() {\n        let params = `?_fields=${this.fieldApi?this.fieldApi:this.field}`\n        if(this.filter) {\n            params += this.filter//`&_where=(${this.filter})`\n        }\n        if (this.orderBy && this.orderBy !== '') {\n            params += `&_sort=${this.orderBy}`;\n        }\n        params += `&_limit=${this.limit}`;\n        let resData = await this.fnPreResponse(params);\n        this.ds = new DataSource({\n            store: new ArrayStore({\n                data: resData,\n                onLoaded: this.fnCustomStoreOnLoaded\n            })\n        });\n    }\n    async fnStartDataSourceRemote() {\n        this.ds = new DataSource({\n            store: new CustomStore({\n                byKey: async (key) => {\n                    this.onLoad.emit(key);\n                    return this.fnGetCustomStore(key);\n                },\n                load: async (loadOptions: any) => {\n                    this.onLoad.emit(loadOptions.searchValue);\n                    return this.fnGetCustomStore(loadOptions.searchValue);;\n                },\n                onLoaded: this.fnCustomStoreOnLoaded\n            })\n        });\n    }\n    fnGetCustomStore(key: any) {\n        let params = `?_fields=${this.fieldApi?this.fieldApi:this.field}&_where=(${this.field},like,$${key}$)`;\n        if (this.filter) {\n            params = `?_fields=${this.fieldApi?this.fieldApi:this.field}&_where=((${this.field},like,$${key}$)$and(${this.filter}))`;\n        }\n        if (this.orderBy && this.orderBy !== '') {\n            params += `&_sort=${this.orderBy}`;\n        }\n        params += `&_limit=${this.limit}`;\n        return this.fnPreResponse(params);;\n    }\n    fnCustomStoreOnLoaded = (result) => {\n        this.storeOnLoaded.emit(result);\n        return result;\n    }\n    onValueChanged(e: any) {\n        this.onValueSelete(e)\n        console.log(\"​SocAutoCompleteComponent -> onValueChanged -> e\", e)\n        this.valueChange.emit(e.value);\n\n    }\n    onValueSelete(e: any) {\n        let temp = _.find(this.loadOptionData ,r=>{\n          if(this.ex_type_view===\"ct_dropdown\"){\n            return `${r.code} - ${r.name}` ===  e.value\n          }else if(this.ex_type_view===\"ct_ext_departmen\"){\n            return `${r.short_name} - ${r.name}` ===  e.value\n          }\n\n\n\n          return r[this.field]  === e.value\n        });\n        console.log(\"​SocAutoCompleteComponent -> onValueSelete -> e\", e,temp)\n        this.valueSelete.emit(temp);\n\n    }\n\n    async fnPreResponse(params) {\n        let resData = await this.request.get(this.api + params);\n        resData = _.map(resData, (obj: any) => {\n            return obj //[this.field]\n        });\n        let _resData = [];\n        for(let i in resData){\n          let temp = _.find(_resData , r=>r[this.field] === resData[i][this.field]);\n          if(!temp){\n            _resData.push(resData[i])\n          }\n        }\n        this.loadOptionData = _resData;\n        return _.map(_resData, (obj: any) => {\n          if(this.ex_type_view===\"ct_dropdown\"){\n            return `${obj.code} - ${obj.name}`\n          }else if(this.ex_type_view===\"ct_ext_departmen\"){\n            return `${obj.short_name} - ${obj.name}`\n          }\n\n\n\n            return obj[this.field]\n        });\n    }\n    onOpened(e) {\n        const element = document.querySelector('.dx-overlay-wrapper.dx-dropdowneditor-overlay.dx-popup-wrapper.dx-dropdownlist-popup-wrapper.dx-selectbox-popup-wrapper');\n        element.setAttribute('style', 'z-index:9999;');\n    }\n    /** START Bind Value */\n    onModelChange: Function = () => { };\n    onModelTouched: Function = () => { };\n    writeValue(value: any): void { }\n    registerOnChange(fn: Function): void { }\n    registerOnTouched(fn: Function): void { }\n    /** END Bind Value */\n\n}\n\n@NgModule({\n    imports: [CommonModule, FormsModule, SharedModule, DxSelectBoxModule],\n    exports: [SocAutoComplete2Component, SharedModule],\n    declarations: [SocAutoComplete2Component],\n})\nexport class SharedAutoComplete2Module { }\n"]}