/** * @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'; var SocAutoComplete2Component = /** @class */ (function () { function SocAutoComplete2Component(request) { var _this = this; 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 = function (result) { _this.storeOnLoaded.emit(result); return result; }; /** * START Bind Value */ this.onModelChange = function () { }; this.onModelTouched = function () { }; } /** * @return {?} */ SocAutoComplete2Component.prototype.ngOnInit = /** * @return {?} */ function () { return tslib_1.__awaiter(this, void 0, void 0, function () { return tslib_1.__generator(this, function (_a) { 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 [2 /*return*/]; }); }); }; /** * @return {?} */ SocAutoComplete2Component.prototype.ngAfterViewInit = /** * @return {?} */ function () { }; /** * @return {?} */ SocAutoComplete2Component.prototype.fnStartDataSourceLocal = /** * @return {?} */ function () { return tslib_1.__awaiter(this, void 0, void 0, function () { var params, resData; return tslib_1.__generator(this, function (_a) { switch (_a.label) { case 0: 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; return [4 /*yield*/, this.fnPreResponse(params)]; case 1: resData = _a.sent(); this.ds = new DataSource({ store: new ArrayStore({ data: resData, onLoaded: this.fnCustomStoreOnLoaded }) }); return [2 /*return*/]; } }); }); }; /** * @return {?} */ SocAutoComplete2Component.prototype.fnStartDataSourceRemote = /** * @return {?} */ function () { return tslib_1.__awaiter(this, void 0, void 0, function () { var _this = this; return tslib_1.__generator(this, function (_a) { this.ds = new DataSource({ store: new CustomStore({ byKey: function (key) { return tslib_1.__awaiter(_this, void 0, void 0, function () { return tslib_1.__generator(this, function (_a) { this.onLoad.emit(key); return [2 /*return*/, this.fnGetCustomStore(key)]; }); }); }, load: function (loadOptions) { return tslib_1.__awaiter(_this, void 0, void 0, function () { return tslib_1.__generator(this, function (_a) { this.onLoad.emit(loadOptions.searchValue); return [2 /*return*/, this.fnGetCustomStore(loadOptions.searchValue)]; }); }); }, onLoaded: this.fnCustomStoreOnLoaded }) }); return [2 /*return*/]; }); }); }; /** * @param {?} key * @return {?} */ SocAutoComplete2Component.prototype.fnGetCustomStore = /** * @param {?} key * @return {?} */ function (key) { /** @type {?} */ var 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 {?} */ SocAutoComplete2Component.prototype.onValueChanged = /** * @param {?} e * @return {?} */ function (e) { this.onValueSelete(e); console.log("​SocAutoCompleteComponent -> onValueChanged -> e", e); this.valueChange.emit(e.value); }; /** * @param {?} e * @return {?} */ SocAutoComplete2Component.prototype.onValueSelete = /** * @param {?} e * @return {?} */ function (e) { var _this = this; /** @type {?} */ var temp = _.find(this.loadOptionData, function (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 {?} */ SocAutoComplete2Component.prototype.fnPreResponse = /** * @param {?} params * @return {?} */ function (params) { return tslib_1.__awaiter(this, void 0, void 0, function () { var resData, _resData, i, temp; var _this = this; return tslib_1.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.request.get(this.api + params)]; case 1: resData = _a.sent(); resData = _.map(resData, function (obj) { return obj; //[this.field] }); _resData = []; for (i in resData) { temp = _.find(_resData, function (r) { return r[_this.field] === resData[i][_this.field]; }); if (!temp) { _resData.push(resData[i]); } } this.loadOptionData = _resData; return [2 /*return*/, _.map(_resData, function (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 {?} */ SocAutoComplete2Component.prototype.onOpened = /** * @param {?} e * @return {?} */ function (e) { /** @type {?} */ var 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 {?} */ SocAutoComplete2Component.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { }; /** * @param {?} fn * @return {?} */ SocAutoComplete2Component.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { }; /** * @param {?} fn * @return {?} */ SocAutoComplete2Component.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { }; SocAutoComplete2Component.decorators = [ { type: Component, args: [{ selector: 'soc-auto-complete-2', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(function () { return SocAutoComplete2Component; }), multi: true }], template: "\n \n" }] } ]; /** @nocollapse */ SocAutoComplete2Component.ctorParameters = function () { return [ { 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 }] }; return SocAutoComplete2Component; }()); export { SocAutoComplete2Component }; 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; } var SharedAutoComplete2Module = /** @class */ (function () { function SharedAutoComplete2Module() { } SharedAutoComplete2Module.decorators = [ { type: NgModule, args: [{ imports: [CommonModule, FormsModule, SharedModule, DxSelectBoxModule], exports: [SocAutoComplete2Component, SharedModule], declarations: [SocAutoComplete2Component], },] } ]; return SharedAutoComplete2Module; }()); export { SharedAutoComplete2Module }; //# 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"]}