UNPKG

air-lib

Version:

This is Air's angular component library

376 lines 39.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, Output, EventEmitter } from '@angular/core'; import * as _ from 'lodash'; import { TranslationService } from '../../services/translation.service'; import { AutocompleteCountSettings } from '../../entities/auto-complete-count-settings'; import { BaseSearchComponent } from './base-search.component'; import { HttpService } from '../../services/http.service'; var SearchComponent = /** @class */ (function (_super) { tslib_1.__extends(SearchComponent, _super); function SearchComponent(httpService, translator) { var _this = _super.call(this, translator, httpService) || this; _this.editInputValue = true; _this.searchPrepared = new EventEmitter(); _this.goUrl = new EventEmitter(); _this.goSearchForPreset = new EventEmitter(); _this.timeDelay = 2000; _this.minNumberValue = 3; _this.hasSearchIcons = true; _this.hasCloseIcons = false; _this.defaultItem = new Array(); return _this; } Object.defineProperty(SearchComponent.prototype, "InitSearch", { set: /** * @param {?} data * @return {?} */ function (data) { var _this = this; if (data) { this.searchSettings = data; this.suggestedList = this.buildPresetsList(); if (this.searchSettings.title) { this.translator.translate(this.searchSettings.title).subscribe(function (result) { _this.searchSettings.title = result; }); } if (this.searchSettings.stateName) { this.buildDefaultOrStateSearchItem() .then(function (res) { if (res && res.id !== '') { _this.defaultItem = [res]; _this.whatsIcon(_this.defaultItem); } else { _this.showSearchIcons(); } }); } else { this.defaultItem = [{ id: '', text: '' }]; } } }, enumerable: true, configurable: true }); Object.defineProperty(SearchComponent.prototype, "ApplySearch", { set: /** * @private * @param {?} event * @return {?} */ function (event) { if (event) { this.saveToState(this.presetItem.id, this.typePreset).then(function (res) { }); } }, enumerable: true, configurable: true }); /** * @param {?} value * @return {?} */ SearchComponent.prototype.searchTextChanged = /** * @param {?} value * @return {?} */ function (value) { if (value && (value.length >= this.minNumberValue)) { /** @type {?} */ var self_1 = this; this.checkedsTextVersion = value; if (this.startTimerSearch) { clearTimeout(this.startTimerSearch); } this.startTimerSearch = setTimeout(function () { self_1.getSearch(value); }, this.timeDelay); } }; /** * @private * @param {?} value * @return {?} */ SearchComponent.prototype.getSearch = /** * @private * @param {?} value * @return {?} */ function (value) { var _this = this; this.hasLoading = true; this.suggestedList = new Array(); if (!value) { this.suggestedList = this.buildPresetsList(); this.hasLoading = false; } else { this.searchSettings.scopeSearch.search = value; /** @type {?} */ var searchJson = JSON.stringify(this.searchSettings.scopeSearch); /** @type {?} */ var encodedJson = window.btoa(encodeURIComponent(searchJson)); /** @type {?} */ var observable = this.searchSettings.httpMethod === 'GET' ? this.httpService.httpGet(this.searchSettings.searchUrl + '?searchQuery=' + encodedJson) // maximum 2048 symbols : this.httpService.httpPost(this.searchSettings.searchUrl, this.searchSettings.scopeSearch); observable .subscribe(function (data) { if (data) { /** @type {?} */ var response_1 = data; /** @type {?} */ var autocompleteCountString_1; _this.translator.translate('autocompleteCountString', { value: '\<b>' + (response_1.count - _this.searchSettings.scopeSearch.pageentries) + '\</b>' }).subscribe(function (res) { autocompleteCountString_1 = res; _this.suggestedList = (_this.checkedsTextVersion === ('' + response_1.search)) ? _this.buildAutoCompleteList(response_1) : new Array(); _this.searchSettings.autocompleteCountSettings = _this.searchSettings.autocompleteCountSettings || new AutocompleteCountSettings(); if (response_1.count > _this.searchSettings.scopeSearch.pageentries) { _this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = true; _this.searchSettings.autocompleteCountSettings.autocompleteCountString = autocompleteCountString_1; } else { _this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = false; } }); } else { _this.searchSettings.autocompleteCountSettings = _this.searchSettings.autocompleteCountSettings || new AutocompleteCountSettings(); _this.suggestedList = _this.buildEmptyList(); _this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = false; } _this.hasLoading = false; }, function (err) { _this.hasLoading = false; console.error(err); }); } }; /** * @param {?} event * @return {?} */ SearchComponent.prototype.selectedItem = /** * @param {?} event * @return {?} */ function (event) { if (event.id === 'noclick') { return; } /** @type {?} */ var self = this; if (_.findIndex(this.searchSettings.presetList, function (row) { self.presetItem = row; return row.id === event.id; }) >= 0) { this.whatsIcon([this.presetItem]); this.goSearchForPreset.emit({ selectedPreset: this.presetItem, isChangePreset: true, isCleared: false }); } else { this.goUrl.emit(event); } }; /** * @param {?} event * @return {?} */ SearchComponent.prototype.onSearchPrepared = /** * @param {?} event * @return {?} */ function (event) { var _this = this; if (event && this.searchSettings.stateName) { this.defaultItem = [{ id: event, text: event }]; this.showCloseIcons(); this.saveToState(event, this.typeString).then(function (res) { _this.searchPrepared.emit(event); }); } }; /** * @param {?} event * @return {?} */ SearchComponent.prototype.removed = /** * @param {?} event * @return {?} */ function (event) { var _this = this; if (this.searchSettings.stateName) { this.buildDefaultSearchItem().then(function (res) { _this.defaultItem = [{ id: _this.searchSettings.defaultSearchValue.id, text: _this.searchSettings.defaultSearchValue.text }]; _this.suggestedList = new Array(); _this.suggestedList = _this.buildPresetsList(); _this.whatsIcon(_this.defaultItem); _this.goSearchForPreset.emit({ selectedPreset: _this.searchSettings.defaultSearchValue, isChangePreset: false, isCleared: true }); }); } }; /** * @private * @param {?} selectedItem * @return {?} */ SearchComponent.prototype.whatsIcon = /** * @private * @param {?} selectedItem * @return {?} */ function (selectedItem) { if (selectedItem[0] && selectedItem[0].id !== '') { (_.findIndex(this.searchSettings.presetList, function (row) { return row.id === selectedItem[0].id; }) >= 0) ? this.showSearchIcons() : this.showCloseIcons(); } else { this.showCloseIcons(); } }; /** * @private * @return {?} */ SearchComponent.prototype.showSearchIcons = /** * @private * @return {?} */ function () { this.hasSearchIcons = true; this.hasCloseIcons = false; }; /** * @private * @return {?} */ SearchComponent.prototype.showCloseIcons = /** * @private * @return {?} */ function () { this.hasSearchIcons = false; this.hasCloseIcons = true; }; /** * @return {?} */ SearchComponent.prototype.closed = /** * @return {?} */ function () { this.hasError = false; this.suggestedList = new Array(); this.suggestedList = this.buildPresetsList(); if (this.searchSettings) { this.searchSettings.autocompleteCountSettings = this.searchSettings.autocompleteCountSettings || new AutocompleteCountSettings(); this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = false; } }; /** * @return {?} */ SearchComponent.prototype.opened = /** * @return {?} */ function () { this.suggestedList = new Array(); this.suggestedList = this.buildPresetsList(); }; SearchComponent.decorators = [ { type: Component, args: [{ selector: 'air-search', template: "<div pg-form-group class=\"global-search\">\r\n <ng-select componentId=\"search\"\r\n [isSearch]= true\r\n [items]=\"suggestedList\"\r\n [active]=\"defaultItem\"\r\n [placeholder]= searchSettings?.placeholder\r\n (selected)=\"selectedItem($event)\"\r\n (inputText)=\"searchTextChanged($event)\"\r\n (removed)=\"removed($event)\"\r\n [title]= searchSettings?.title\r\n [editInputData] = editInputValue\r\n [allowClear] = hasCloseIcons\r\n [allowSearchIcons] = hasSearchIcons\r\n (searchPrepared)=\"onSearchPrepared($event)\"\r\n [hasError]= hasError\r\n (opened)=\"opened()\"\r\n (closed)= \"closed()\"\r\n [autocompleteCountSettings]=\"searchSettings?.autocompleteCountSettings\"\r\n [searchSettings]=\"searchSettings\"\r\n >\r\n </ng-select>\r\n <div class=\"container-preloader-transparent\" [hidden]='!hasLoading'>\r\n <svg class=\"container-preloader\">\r\n <use xlink:href=\"#progress-circle\"></use>\r\n </svg>\r\n </div>\r\n</div>\r\n", styles: [".global-search{position:relative}.global-search ::ng-deep .container-preloader-transparent{left:auto;width:50px}.global-search ::ng-deep .container-preloader-transparent .container-preloader{left:auto;width:30px;height:30px;right:10px}.global-search ::ng-deep .ui-select-container{background:#fff;box-shadow:inset 0 0 0 1px rgba(0,0,0,.07)}.global-search ::ng-deep .ui-select-container:hover{background-color:#fafafa}.global-search ::ng-deep .ui-select-container.ui-select-focusud{background-color:#f0f0f0}.global-search ::ng-deep .ui-select-container.has-error{background-color:#feeeee}.global-search ::ng-deep .ui-select-container.has-error .ui-select-choices-row{background:0 0}.global-search ::ng-deep .ui-select-container.has-error .dropdown-item strong{background:0 0}.global-search ::ng-deep .ui-select-container.has-error .dropdown-item{color:#c00;font-style:italic;cursor:default}.global-search ::ng-deep .ui-select-container .btn.btn-default.form-control.ui-select-toggle{border:none;background:0 0;min-height:33px;padding:6px 12px 9px;height:33px}.global-search ::ng-deep .ui-select-container .btn-default{display:block;background:0 0}.global-search ::ng-deep .ui-select-container .btn-default:hover{background:0 0}.global-search ::ng-deep .ui-select-container .ui-select-choices-row>a{padding:6px 20px}.global-search ::ng-deep .form-control{border:none;background:0 0;height:33px;min-height:33px}.global-search ::ng-deep .title-input{padding-left:12px;margin:0;padding-top:7px;text-align:left}.global-search ::ng-deep .ui-block-icons{position:absolute;right:10px;bottom:6px;height:20px}.global-search ::ng-deep .ui-block-icons .icons{font-size:14px;color:#ccc;float:left;display:block;overflow:hidden;height:20px;cursor:pointer}.global-search ::ng-deep .ui-block-icons .icons .ui-close{font-size:25px;font-weight:500;line-height:20px;font-style:normal}.global-search ::ng-deep .dropdown-item .category{color:#000;cursor:default;font-weight:600;margin:-6px -20px;padding:6px 20px;background:#fff}.global-search ::ng-deep .dropdown-item .category strong{background:0 0;font-weight:600}.global-search ::ng-deep .dropdown-item strong{background:#fff573;font-weight:400}"] }] } ]; SearchComponent.ctorParameters = function () { return [ { type: HttpService }, { type: TranslationService } ]; }; SearchComponent.propDecorators = { InitSearch: [{ type: Input }], ApplySearch: [{ type: Input }], editInputValue: [{ type: Input }], searchPrepared: [{ type: Output }], goUrl: [{ type: Output }], goSearchForPreset: [{ type: Output }] }; return SearchComponent; }(BaseSearchComponent)); export { SearchComponent }; if (false) { /** @type {?} */ SearchComponent.prototype.editInputValue; /** @type {?} */ SearchComponent.prototype.searchPrepared; /** @type {?} */ SearchComponent.prototype.goUrl; /** @type {?} */ SearchComponent.prototype.goSearchForPreset; /** @type {?} */ SearchComponent.prototype.suggestedList; /** @type {?} */ SearchComponent.prototype.defaultItem; /** * @type {?} * @private */ SearchComponent.prototype.startTimerSearch; /** * @type {?} * @private */ SearchComponent.prototype.timeDelay; /** * @type {?} * @private */ SearchComponent.prototype.minNumberValue; /** @type {?} */ SearchComponent.prototype.hasSearchIcons; /** @type {?} */ SearchComponent.prototype.hasCloseIcons; /** * @type {?} * @private */ SearchComponent.prototype.checkedsTextVersion; /** * @type {?} * @private */ SearchComponent.prototype.presetItem; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.component.js","sourceRoot":"ng://air-lib/","sources":["lib/components/search/search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, Output, EventEmitter, ViewEncapsulation, ViewChild} from '@angular/core';\r\nimport * as _ from 'lodash';\r\nimport { TranslationService } from '../../services/translation.service';\r\nimport { ISearchSettings } from '../../interfaces/isearch-settings';\r\nimport { AutocompleteCountSettings } from '../../entities/auto-complete-count-settings';\r\nimport { IPreset } from '../../interfaces/ipreset';\r\nimport { BaseSearchComponent } from './base-search.component';\r\nimport { HttpService } from '../../services/http.service';\r\nimport { ISimpleNgSelectItem } from '../ng2-select-custom/select.module';\r\n\r\n@Component({\r\n    selector: 'air-search',\r\n    templateUrl: 'search.component.html',\r\n    styleUrls: ['search.component.scss']\r\n})\r\n\r\nexport class SearchComponent extends BaseSearchComponent {\r\n\r\n    @Input()\r\n    public set InitSearch(data: ISearchSettings) {\r\n        if (data) {\r\n            this.searchSettings = data;\r\n            this.suggestedList = this.buildPresetsList();\r\n            if (this.searchSettings.title) {\r\n                this.translator.translate(this.searchSettings.title).subscribe((result: string) => {\r\n                    this.searchSettings.title = result;\r\n                });\r\n            }\r\n            if (this.searchSettings.stateName) {\r\n                this.buildDefaultOrStateSearchItem()\r\n                    .then((res: ISimpleNgSelectItem) => {\r\n                        if (res && res.id !== '') {\r\n                            this.defaultItem = [res];\r\n                            this.whatsIcon(this.defaultItem);\r\n                        } else {\r\n                            this.showSearchIcons();\r\n                        }\r\n                    });\r\n            } else {\r\n                this.defaultItem = [{ id: '', text: '' }];\r\n            }\r\n        }\r\n    }\r\n\r\n    @Input()\r\n    private set ApplySearch(event: any) {\r\n        if (event) {\r\n            this.saveToState(this.presetItem.id, this.typePreset).then((res: any) => {\r\n            });\r\n        }\r\n    }\r\n\r\n    @Input() editInputValue = true;\r\n\r\n    @Output() searchPrepared = new EventEmitter();\r\n    @Output() goUrl = new EventEmitter();\r\n    @Output() goSearchForPreset = new EventEmitter();\r\n\r\n    suggestedList: Array<ISimpleNgSelectItem>;\r\n    defaultItem: Array<ISimpleNgSelectItem>;\r\n    private startTimerSearch: any;\r\n    private timeDelay = 2000;\r\n    private minNumberValue = 3;\r\n    hasSearchIcons = true;\r\n    hasCloseIcons = false;\r\n    private checkedsTextVersion: string;\r\n    private presetItem: IPreset;\r\n    constructor(\r\n        httpService: HttpService,\r\n        translator: TranslationService) {\r\n        super(translator, httpService);\r\n        this.defaultItem = new Array<ISimpleNgSelectItem>();\r\n    }\r\n\r\n    searchTextChanged(value: string) {\r\n        if (value && (value.length >= this.minNumberValue)) {\r\n            const self = this;\r\n            this.checkedsTextVersion = value;\r\n            if (this.startTimerSearch) {\r\n                clearTimeout(this.startTimerSearch);\r\n            }\r\n            this.startTimerSearch = setTimeout(function () {\r\n                self.getSearch(value);\r\n            }, this.timeDelay);\r\n        }\r\n    }\r\n\r\n    private getSearch(value: string) {\r\n        this.hasLoading = true;\r\n        this.suggestedList = new Array<ISimpleNgSelectItem>();\r\n        if (!value) {\r\n            this.suggestedList = this.buildPresetsList();\r\n            this.hasLoading = false;\r\n        } else {\r\n            this.searchSettings.scopeSearch.search = value;\r\n            const searchJson = JSON.stringify(this.searchSettings.scopeSearch);\r\n            const encodedJson = window.btoa(encodeURIComponent(searchJson));\r\n\r\n            const observable = this.searchSettings.httpMethod === 'GET'\r\n                ? this.httpService.httpGet(this.searchSettings.searchUrl + '?searchQuery=' + encodedJson  ) // maximum 2048 symbols\r\n                : this.httpService.httpPost(this.searchSettings.searchUrl, this.searchSettings.scopeSearch);\r\n\r\n            observable\r\n                .subscribe((data: any) => {\r\n                    if (data) {\r\n                        const response = data;\r\n                        let autocompleteCountString: string;\r\n                        this.translator.translate('autocompleteCountString', {\r\n                            value: '\\<b>' + (response.count - this.searchSettings.scopeSearch.pageentries) + '\\</b>'\r\n                        }).subscribe((res: string) => {\r\n                            autocompleteCountString = res;\r\n                          this.suggestedList = (this.checkedsTextVersion === ('' + response.search))\r\n                              ? this.buildAutoCompleteList(response)\r\n                              : new Array<ISimpleNgSelectItem>();\r\n\r\n                          this.searchSettings.autocompleteCountSettings = this.searchSettings.autocompleteCountSettings\r\n                              || new AutocompleteCountSettings();\r\n                          if (response.count > this.searchSettings.scopeSearch.pageentries) {\r\n\r\n                              this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = true;\r\n                              this.searchSettings.autocompleteCountSettings.autocompleteCountString = autocompleteCountString;\r\n                          } else {\r\n                              this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = false;\r\n                          }\r\n                      });\r\n                    } else {\r\n                      this.searchSettings.autocompleteCountSettings = this.searchSettings.autocompleteCountSettings\r\n                                                                        || new AutocompleteCountSettings();\r\n                        this.suggestedList = this.buildEmptyList();\r\n                        this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = false;\r\n                    }\r\n                    this.hasLoading = false;\r\n                },\r\n                (err) => {\r\n                    this.hasLoading = false;\r\n                    console.error(err);\r\n                });\r\n        }\r\n    }\r\n\r\n    selectedItem(event: ISimpleNgSelectItem) {\r\n        if (event.id === 'noclick') { return; }\r\n        const self = this;\r\n        if (_.findIndex(this.searchSettings.presetList,\r\n            function (row) {\r\n                self.presetItem = row;\r\n                return row.id === event.id;\r\n            }) >= 0) {\r\n            this.whatsIcon([this.presetItem]);\r\n            this.goSearchForPreset.emit(\r\n                {\r\n                    selectedPreset: this.presetItem,\r\n                    isChangePreset: true,\r\n                    isCleared: false\r\n                }\r\n            );\r\n        } else {\r\n            this.goUrl.emit(event);\r\n        }\r\n    }\r\n\r\n    onSearchPrepared(event: string) {\r\n        if (event && this.searchSettings.stateName) {\r\n            this.defaultItem = [{\r\n                id: event,\r\n                text: event\r\n            }];\r\n            this.showCloseIcons();\r\n            this.saveToState(event, this.typeString).then((res: any) => {\r\n                this.searchPrepared.emit(event);\r\n            });\r\n        }\r\n    }\r\n\r\n    removed(event: string) {\r\n        if (this.searchSettings.stateName) {\r\n            this.buildDefaultSearchItem().then((res: string) => {\r\n                this.defaultItem = [{\r\n                    id: this.searchSettings.defaultSearchValue.id,\r\n                    text: this.searchSettings.defaultSearchValue.text\r\n                }];\r\n                this.suggestedList = new Array<ISimpleNgSelectItem>();\r\n                this.suggestedList = this.buildPresetsList();\r\n                this.whatsIcon(this.defaultItem);\r\n                this.goSearchForPreset.emit(\r\n                    {\r\n                        selectedPreset: this.searchSettings.defaultSearchValue,\r\n                        isChangePreset: false,\r\n                        isCleared: true\r\n                    }\r\n                );\r\n            });\r\n        }\r\n    }\r\n\r\n    private whatsIcon(selectedItem: Array<ISimpleNgSelectItem>) {\r\n        if (selectedItem[0] && selectedItem[0].id !== '') {\r\n            (_.findIndex(this.searchSettings.presetList,\r\n                function (row) { return row.id === selectedItem[0].id; }) >= 0)\r\n                ? this.showSearchIcons()\r\n                : this.showCloseIcons();\r\n        } else {\r\n            this.showCloseIcons();\r\n        }\r\n    }\r\n\r\n    private showSearchIcons() {\r\n        this.hasSearchIcons = true;\r\n        this.hasCloseIcons = false;\r\n    }\r\n\r\n    private showCloseIcons() {\r\n        this.hasSearchIcons = false;\r\n        this.hasCloseIcons = true;\r\n    }\r\n\r\n    closed() {\r\n        this.hasError = false;\r\n        this.suggestedList = new Array<ISimpleNgSelectItem>();\r\n        this.suggestedList = this.buildPresetsList();\r\n        if (this.searchSettings) {\r\n            this.searchSettings.autocompleteCountSettings = this.searchSettings.autocompleteCountSettings\r\n                                                            || new AutocompleteCountSettings();\r\n            this.searchSettings.autocompleteCountSettings.hasAutocompleteCount = false;\r\n        }\r\n\r\n    }\r\n\r\n    opened() {\r\n        this.suggestedList = new Array<ISimpleNgSelectItem>();\r\n        this.suggestedList = this.buildPresetsList();\r\n    }\r\n\r\n}\r\n"]}