ng-zenduit 1.0.39 → 1.0.41

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyc0NvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXplbmR1aXQvc3JjL2xpYi9maWx0ZXIvZmlsdGVyc0NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgREFURVBJQ0tFUl9QT1NJVElPTiB9IGZyb20gJy4uL2RhdGVwaWNrZXIvZGF0ZXBpY2tlcic7XG5pbXBvcnQgeyBEYXRlUmFuZ2UgfSBmcm9tIFwiLi9kYXRlUmFuZ2VcIjtcbmltcG9ydCB7IE51bWJlclJhbmdlIH0gZnJvbSBcIi4vbnVtYmVyUmFuZ2VcIlxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlcnNDb25maWcge1xuICAgIGl0ZW1zOiBGaWx0ZXJzQ29uZmlnSXRlbVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlcnNDb25maWdJdGVtIHtcbiAgICAvKipcbiAgICAgKiBTZWN0aW9uIHRpdGxlXG4gICAgICovXG4gICAgdGl0bGU6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEtleSBmb3IgcmVzdWx0IHN0b3JlXG4gICAgICovXG4gICAga2V5OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBEYXRhIHR5cGVcbiAgICAgKi9cbiAgICB0eXBlOiBcIm11bHRpc2VsZWN0XCIgfCBcInNlbGVjdFwiIHwgXCJkYXRlUmFuZ2VcIiB8IFwibnVtYmVyUmFuZ2VcIiB8IFwidG9nZ2xlXCIgfCBcImRhdGVcIiB8IFwicmFkaW9cIiB8IFwiZGl2aWRlclwiIHwgXCJ0ZXh0XCIgfCBcImR1cmF0aW9uXCIgfCBcImRpc3RhbmNlXCI7XG5cbiAgICAvKipcbiAgICAgKiBTaG93IHRpbWUgZm9yIGRhdGUgcGlja2Vycy4gQnkgZGVmYXVsdCBpcyB0cnVlXG4gICAgICovXG4gICAgc2hvd1RpbWU/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogRGF0YSBzb3VyY2UgZm9yIHR5cGUgTXVsdGlzZWxlY3RcbiAgICAgKi9cbiAgICBkYXRhU291cmNlPzogRGF0YVNvdXJjZVtdO1xuXG4gICAgZmlsdGVyZWREYXRhU291cmNlPzogRGF0YVNvdXJjZVtdO1xuXG4gICAgLyoqXG4gICAgICogRGF0ZSByYW5nZSBmb3IgdHlwZSBEYXRlUmFuZ2VcbiAgICAgKi9cbiAgICBkYXRlUmFuZ2U/OiBEYXRlUmFuZ2U7XG5cbiAgICAvKipcbiAgICAgKiBEYXRlIHJlc3VsdCBmb3IgdHlwZSBEYXRlXG4gICAgICovXG4gICAgZGF0ZT86IERhdGU7XG5cbiAgICAvKipcbiAgICAgKiBOdW1iZXIgcmFuZ2UgZm9yIHR5cGUgTnVtYmVyUmFuZ2VcbiAgICAgKi9cbiAgICBudW1iZXJSYW5nZT86IE51bWJlclJhbmdlO1xuXG4gICAgLyoqXG4gICAgICogT3B0aW9uIGZvciBSYWRpb1xuICAgICAqIFNlbGVjdGVkIGFkZGVkIGhlcmUgZm9yIHJlc2V0IEZpbHRlci5cbiAgICAgKi9cbiAgICByYWRpb09wdGlvbnM/OiBBcnJheTx7IGlkOiBzdHJpbmcsIG5hbWU6IHN0cmluZywgc2VsZWN0ZWQ/OiBib29sZWFuLCBkaXNhYmxlZD86IGJvb2xlYW4sIGltYWdlVXJsPzogc3RyaW5nIH0+O1xuXG4gICAgLyoqXG4gICAgICogU2VsZWN0ZWQgUmFkaW8gYnV0dG9uIHJlc3VsdFxuICAgICAqL1xuICAgIHNlbGVjdGVkUmFkaW8/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBFbmFibGUvRGlzYWJsZWQgc3RhdGUgZm9yIHRoZSB0eXBlIFRvZ2dsZVxuICAgICAqL1xuICAgIGVuYWJsZWQ/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogTWVudSBpcyBleHBhbmRlZFxuICAgICAqL1xuICAgIGV4cGFuZGVkPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIElzIHNlbGVjdGVkIGFsbFxuICAgICAqL1xuICAgIGlzU2VsZWN0ZWRBbGw/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogRGlzYWJsZSBtZW51IGNvbGxhcHNlXG4gICAgICovXG4gICAgZGlzYWJsZUNvbGxhcHNlPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIENvbmZpZ3NcbiAgICAgKi9cbiAgICBjb25maWc/OiB7XG4gICAgICAgIC8vIERhdGUgcGlja2VyIHBvc2l0aW9uXG4gICAgICAgIHlQb3NpdGlvbj86IERBVEVQSUNLRVJfUE9TSVRJT05cbiAgICB9O1xuXG4gICAgLyoqXG4gICAgICogU2hvdyBwcmVkZWZpbmVkIGRhdGUtcmFuZ2Ugb3B0aW9ucy4gQnkgZGVmYXVsdCBpcyBmYWxzZVxuICAgICAqL1xuICAgIHNob3dEYXRlUmFuZ2VPcHRpb25zPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIExpc3Qgb2YgY3VzdG9tIGRhdGUtcmFuZ2Ugb3B0aW9ucyB0byByZXBsYWNlIGRlZmF1bHQgb3B0aW9uc1xuICAgICAqL1xuICAgIGRhdGVSYW5nZU9wdGlvbnM/OiB7IG5hbWU6IHN0cmluZywgZGF0ZVJhbmdlOiBEYXRlUmFuZ2UgfVtdO1xuXG4gICAgLyoqXG4gICAgICogSXMgbGF6eSBsb2FkaW5nIG1vZGUgYWN0aXZhdGVkIGZvciBkYXRhIHNvdXJjZXNcbiAgICAgKi9cbiAgICBpc0xhenlMb2FkaW5nPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIGxhenkgbG9hZGluZyBoYW5kbGVyXG4gICAgICovXG4gICAgbGF6eUxvYWRlcj86IChzZWFyY2g6IHN0cmluZywgb2Zmc2V0OiBudW1iZXIsIGxpbWl0OiBudW1iZXIpID0+IFByb21pc2U8RGF0YVNvdXJjZVtdPjtcblxuICAgIC8qKlxuICAgICAqIGlzIGRhdGEgaXMgbG9hZGluZyBub3dcbiAgICAgKi9cbiAgICBpc0xvYWRpbmdOb3c/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogSWYgdHJ1ZSwgdGhlIGJ1dHRvbiAnTG9hZCBtb3JlJyB3aWxsIGJlIGRpc3BsYXllZFxuICAgICAqL1xuICAgIGNhbkxvYWRNb3JlPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEYXRhU291cmNlIHtcbiAgICBpZDogc3RyaW5nIHwgbnVtYmVyLFxuICAgIG5hbWU6IHN0cmluZyB8IG51bWJlcixcbiAgICBjaGVja2VkPzogYm9vbGVhbixcbiAgICBpbWFnZVVybD86IHN0cmluZyxcbiAgICBpc09wZW4/OiBib29sZWFuLFxuICAgIGNoaWxkcmVuPzogc3RyaW5nW10sXG4gICAgaW5kZXg/OiBudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNdWx0aVNlbGVjdEl0ZW0ge1xuICAgIGlkOiBzdHJpbmcgfCBudW1iZXIsXG4gICAgbmFtZTogc3RyaW5nIHwgbnVtYmVyLFxuICAgIGluZGV4OiBudW1iZXJcbn0iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyc0NvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXplbmR1aXQvc3JjL2xpYi9maWx0ZXIvZmlsdGVyc0NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgREFURVBJQ0tFUl9QT1NJVElPTiB9IGZyb20gJy4uL2RhdGVwaWNrZXIvZGF0ZXBpY2tlcic7XG5pbXBvcnQgeyBEYXRlUmFuZ2UgfSBmcm9tIFwiLi9kYXRlUmFuZ2VcIjtcbmltcG9ydCB7IE51bWJlclJhbmdlIH0gZnJvbSBcIi4vbnVtYmVyUmFuZ2VcIlxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlcnNDb25maWcge1xuICAgIGl0ZW1zOiBGaWx0ZXJzQ29uZmlnSXRlbVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlcnNDb25maWdJdGVtIHtcbiAgICAvKipcbiAgICAgKiBTZWN0aW9uIHRpdGxlXG4gICAgICovXG4gICAgdGl0bGU6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEtleSBmb3IgcmVzdWx0IHN0b3JlXG4gICAgICovXG4gICAga2V5OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBEYXRhIHR5cGVcbiAgICAgKi9cbiAgICB0eXBlOiBcIm11bHRpc2VsZWN0XCIgfCBcInNlbGVjdFwiIHwgXCJkYXRlUmFuZ2VcIiB8IFwibnVtYmVyUmFuZ2VcIiB8IFwidG9nZ2xlXCIgfCBcImRhdGVcIiB8IFwicmFkaW9cIiB8IFwiZGl2aWRlclwiIHwgXCJ0ZXh0XCIgfCBcImR1cmF0aW9uXCIgfCBcImRpc3RhbmNlXCI7XG5cbiAgICAvKipcbiAgICAgKiBTaG93IHRpbWUgZm9yIGRhdGUgcGlja2Vycy4gQnkgZGVmYXVsdCBpcyB0cnVlXG4gICAgICovXG4gICAgc2hvd1RpbWU/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogRGF0YSBzb3VyY2UgZm9yIHR5cGUgTXVsdGlzZWxlY3RcbiAgICAgKi9cbiAgICBkYXRhU291cmNlPzogRGF0YVNvdXJjZVtdO1xuXG4gICAgZmlsdGVyZWREYXRhU291cmNlPzogRGF0YVNvdXJjZVtdO1xuXG4gICAgLyoqXG4gICAgICogRGF0ZSByYW5nZSBmb3IgdHlwZSBEYXRlUmFuZ2VcbiAgICAgKi9cbiAgICBkYXRlUmFuZ2U/OiBEYXRlUmFuZ2U7XG5cbiAgICAvKipcbiAgICAgKiBEYXRlIHJlc3VsdCBmb3IgdHlwZSBEYXRlXG4gICAgICovXG4gICAgZGF0ZT86IERhdGU7XG5cbiAgICAvKipcbiAgICAgKiBOdW1iZXIgcmFuZ2UgZm9yIHR5cGUgTnVtYmVyUmFuZ2VcbiAgICAgKi9cbiAgICBudW1iZXJSYW5nZT86IE51bWJlclJhbmdlO1xuXG4gICAgLyoqXG4gICAgICogT3B0aW9uIGZvciBSYWRpb1xuICAgICAqIFNlbGVjdGVkIGFkZGVkIGhlcmUgZm9yIHJlc2V0IEZpbHRlci5cbiAgICAgKi9cbiAgICByYWRpb09wdGlvbnM/OiBBcnJheTx7IGlkOiBzdHJpbmcsIG5hbWU6IHN0cmluZywgc2VsZWN0ZWQ/OiBib29sZWFuLCBkaXNhYmxlZD86IGJvb2xlYW4sIGltYWdlVXJsPzogc3RyaW5nIH0+O1xuXG4gICAgLyoqXG4gICAgICogU2VsZWN0ZWQgUmFkaW8gYnV0dG9uIHJlc3VsdFxuICAgICAqL1xuICAgIHNlbGVjdGVkUmFkaW8/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBFbmFibGUvRGlzYWJsZWQgc3RhdGUgZm9yIHRoZSB0eXBlIFRvZ2dsZVxuICAgICAqL1xuICAgIGVuYWJsZWQ/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogTWVudSBpcyBleHBhbmRlZFxuICAgICAqL1xuICAgIGV4cGFuZGVkPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIElzIHNlbGVjdGVkIGFsbFxuICAgICAqL1xuICAgIGlzU2VsZWN0ZWRBbGw/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogRGlzYWJsZSBtZW51IGNvbGxhcHNlXG4gICAgICovXG4gICAgZGlzYWJsZUNvbGxhcHNlPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIENvbmZpZ3NcbiAgICAgKi9cbiAgICBjb25maWc/OiB7XG4gICAgICAgIC8vIERhdGUgcGlja2VyIHBvc2l0aW9uXG4gICAgICAgIHlQb3NpdGlvbj86IERBVEVQSUNLRVJfUE9TSVRJT05cbiAgICB9O1xuXG4gICAgLyoqXG4gICAgICogU2hvdyBwcmVkZWZpbmVkIGRhdGUtcmFuZ2Ugb3B0aW9ucy4gQnkgZGVmYXVsdCBpcyBmYWxzZVxuICAgICAqL1xuICAgIHNob3dEYXRlUmFuZ2VPcHRpb25zPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIExpc3Qgb2YgY3VzdG9tIGRhdGUtcmFuZ2Ugb3B0aW9ucyB0byByZXBsYWNlIGRlZmF1bHQgb3B0aW9uc1xuICAgICAqL1xuICAgIGRhdGVSYW5nZU9wdGlvbnM/OiB7IG5hbWU6IHN0cmluZywgZGF0ZVJhbmdlOiBEYXRlUmFuZ2UgfVtdO1xuXG4gICAgLyoqXG4gICAgICogSXMgbGF6eSBsb2FkaW5nIG1vZGUgYWN0aXZhdGVkIGZvciBkYXRhIHNvdXJjZXNcbiAgICAgKi9cbiAgICBpc0xhenlMb2FkaW5nPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIGxhenkgbG9hZGluZyBoYW5kbGVyXG4gICAgICovXG4gICAgbGF6eUxvYWRlcj86IChzZWFyY2g6IHsgdGV4dD86IHN0cmluZywgaWRzPzogc3RyaW5nW10gfSwgb2Zmc2V0OiBudW1iZXIsIGxpbWl0OiBudW1iZXIpID0+IFByb21pc2U8RGF0YVNvdXJjZVtdPjtcblxuICAgIC8qKlxuICAgICAqIGlzIGRhdGEgaXMgbG9hZGluZyBub3dcbiAgICAgKi9cbiAgICBpc0xvYWRpbmdOb3c/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogSWYgdHJ1ZSwgdGhlIGJ1dHRvbiAnTG9hZCBtb3JlJyB3aWxsIGJlIGRpc3BsYXllZFxuICAgICAqL1xuICAgIGNhbkxvYWRNb3JlPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEYXRhU291cmNlIHtcbiAgICBpZDogc3RyaW5nIHwgbnVtYmVyLFxuICAgIG5hbWU6IHN0cmluZyB8IG51bWJlcixcbiAgICBjaGVja2VkPzogYm9vbGVhbixcbiAgICBpbWFnZVVybD86IHN0cmluZyxcbiAgICBpc09wZW4/OiBib29sZWFuLFxuICAgIGNoaWxkcmVuPzogc3RyaW5nW10sXG4gICAgaW5kZXg/OiBudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNdWx0aVNlbGVjdEl0ZW0ge1xuICAgIGlkOiBzdHJpbmcgfCBudW1iZXIsXG4gICAgbmFtZTogc3RyaW5nIHwgbnVtYmVyLFxuICAgIGluZGV4OiBudW1iZXJcbn0iXX0=
@@ -249,7 +249,7 @@ export class ZenduFilterComponent {
249
249
  }
250
250
  // load first 10 records for the the first time
251
251
  const limit = (item.filteredDataSource.length == 0) ? 10 : 100;
252
- const newItems = await item.lazyLoader(this.searchText || "", item.filteredDataSource.length, limit);
252
+ const newItems = await item.lazyLoader({ text: this.searchText || "" }, item.filteredDataSource.length, limit);
253
253
  item.canLoadMore = (newItems.length == limit);
254
254
  // the filteredDataSource contains the items that is visilible to user at the current moment
255
255
  item.filteredDataSource = item.filteredDataSource.concat(newItems);
@@ -670,4 +670,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
670
670
  type: HostListener,
671
671
  args: ['window:keydown', ['$event']]
672
672
  }] } });
673
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/filter/zendu-filter.component.ts","../../../../../projects/ng-zenduit/src/lib/filter/zendu-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { DataSource, FiltersConfig, FiltersConfigItem, MultiSelectItem } from './filtersConfig';\nimport uniqBy from 'lodash.uniqby';\nimport moment from 'moment/moment';\nimport { ZenduSearchBoxComponent } from '../search-box/zendu-search-box.component';\nimport { Util } from '../util';\nimport { DATEPICKER_POSITION } from '../datepicker/datepicker';\nimport { DateRange } from \"./dateRange\";\n\n@Component({\n    selector: 'zen-filter',\n    templateUrl: './zendu-filter.component.html',\n    styleUrls: ['./zendu-filter.component.scss']\n})\nexport class ZenduFilterComponent implements OnChanges {\n\n    @Input() config: FiltersConfig = { items: [] };\n\n    @Input() filter: object;\n\n    @Input() position = 'right';\n\n    @Input() resetBehavior: \"set_all\" | \"clear\" = 'clear';\n\n    @Output() filterChange = new EventEmitter<object>();\n\n    @Input() isVisible = false;\n\n    @Output() isVisibleChange = new EventEmitter<boolean>();\n\n    @Input() customTrigger = false;\n\n    @Input() imageUrl: string;\n\n    @Input() label: string;\n\n    @Input() showOptions: boolean;\n\n    @Input() customOptions: string;\n\n    @Input() wrapperBodyClass: string;\n\n    public searchText = '';\n\n    public isApplied = false;\n\n    private lastAppliedFilter: any = {};\n\n    private resetedFilter: any;\n\n    public menuLeft = \"0px\";\n\n    public menuRight = \"0px\";\n\n    public menuTop = \"0px\";\n\n    public menuBottom = \"0px\";\n\n    public showNoFilterResult: boolean;\n\n    public errorMessage: string[] = []\n\n    public datepickerPosition = DATEPICKER_POSITION;\n\n    public selectedDateRangeOptions: { [key: string]: string } = {};\n\n    @ViewChild('searchBox', { static: false }) searchBox: ZenduSearchBoxComponent;\n\n    @ViewChild('mainComponent', { static: false }) _componentElement: ElementRef<HTMLElement>;\n\n    constructor() { }\n\n    public ngOnChanges(changes: any): void {\n        if (changes.config && changes.config.currentValue) {\n\n            // init values\n            for (const item of this.config.items) {\n                if (item.type === 'multiselect') {\n                    item.dataSource = item.dataSource ? this.extractUniqueDataSource(item.dataSource) : [];\n                } else if (item.type === 'dateRange' && !item.dateRange) {\n                    item.dateRange = { start: null, end: null };\n\n                    // init date range options\n                    if (item.showDateRangeOptions && !item.dateRangeOptions?.length) {\n                        item.dateRangeOptions = this.getDefaultDateRangeOptions();\n                    }\n                } else if (item.type === 'numberRange' && !item.numberRange) {\n                    item.numberRange = {};\n                }\n\n                if (typeof item.showTime !== 'boolean') {\n                    item.showTime = true;\n                }\n            }\n\n            this.filterItems();\n\n            this.resetedFilter = this.getFilterObject();\n            this.filter = this.getFilterObject();\n            this.lastAppliedFilter = Util.clone(this.filter);\n        }\n\n        if (changes.filter && changes.filter.currentValue) {\n            this.lastAppliedFilter = Util.clone(changes.filter.currentValue);\n\n            this.updateAppliedState();\n        }\n\n        if (changes.isVisible && changes.isVisible.currentValue) {\n            this.updatePlacement();\n            this.focusSearchBox();\n        }\n    }\n\n    @HostListener('window:mousedown', ['$event'])\n    outsideHandling(event: MouseEvent) {\n        if (!this.isVisible) {\n            return;\n        }\n\n        const target = event.target as HTMLElement;\n        if (!document.body.contains(target)) {\n            // element not in the DOM\n            return;\n        }\n        if (this._componentElement.nativeElement.contains(target)) {\n            return;\n        }\n\n        // hide the menu for outside click\n        this.hide();\n\n        // restore values\n        this.restorePreviousApplied();\n    }\n\n    @HostListener('window:resize', ['$event'])\n    windowSizeHandling() {\n        if (!this.isVisible) {\n            return;\n        }\n\n        this.updatePlacement();\n    }\n\n    @HostListener('window:scroll', ['$event'])\n    windowScroll() {\n        if (!this.isVisible) {\n            return;\n        }\n\n        this.updatePlacement();\n    }\n\n    @HostListener('window:wheel', ['$event'])\n    handleMouseScroll(event: WheelEvent): void {\n        if (!this.isVisible) {\n            return;\n        }\n\n        const target = event.target as HTMLElement;\n        if (!document.body.contains(target)) {\n            return;\n        }\n        if (this._componentElement.nativeElement.contains(target) && !target.classList.contains('button-stroked')) {\n            return;\n        }\n\n        this.hide();\n        this.restorePreviousApplied();\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    onWindowKeyDown(event: KeyboardEvent) {\n        if (!this.isVisible) {\n            return;\n        }\n\n        if (event.key === 'ArrowUp' || event.key === 'ArrowDown' || event.key === 'PageUp' || event.key === 'PageDown' || event.key === 'Home' || event.key === 'End') {\n\n            const target = event.target as HTMLElement;\n            if (!document.body.contains(target)) {\n                return;\n            }\n\n            if (this._componentElement.nativeElement.contains(target) && !target.classList.contains('button-stroked')) {\n                return;\n            }\n            this.hide();\n            this.restorePreviousApplied();\n        }\n    }\n\n    public focusSearchBox() {\n        this.searchBox.doFocus();\n    }\n\n    public isMenuIsVisible(item: FiltersConfigItem) {\n        if (item.isLazyLoading) {\n            if (item.isLoadingNow || item.canLoadMore !== false) {\n                return true;\n            }\n            if (this.searchText) {\n                return item.filteredDataSource?.length > 0;\n            }\n            return true;\n        }\n\n        if (item.filteredDataSource && this.searchText) {\n            if (!item.filteredDataSource.length) {\n                return false;\n            }\n        }\n\n        return true;\n    }\n\n    private extractUniqueDataSource(\n        array: {\n            id: string | number,\n            name: string | number\n        }[]\n    ): MultiSelectItem[] {\n        const items = array.filter(el => {\n            return Boolean(\n                typeof el.id === 'number' ? typeof el.id !== undefined : el.id &&\n                    typeof el.name === 'number' ? typeof el.name !== undefined : el.name\n            );\n        });\n        const uniqItems = uniqBy(items, (el) => el.id);\n        // add index to each uniqItems\n        uniqItems.forEach((el: MultiSelectItem, index: number) => el.index = index);\n        return uniqItems\n    }\n\n    public onSelectAll(item: FiltersConfigItem) {\n        item.dataSource.forEach(d => d.checked = item.isSelectedAll);\n    }\n\n    public isItemActive(item: FiltersConfigItem): boolean {\n        if (item.type === 'multiselect') {\n            const checkedItems = item.dataSource.filter(el => el.checked);\n            item.isSelectedAll = checkedItems.length === item.dataSource.length\n            return checkedItems.length > 0;\n        } else if (item.type === 'radio') {\n            return item.radioOptions.some(ro => ro.selected);\n        } else if (item.type === 'numberRange') {\n            return Boolean(item.numberRange.from || item.numberRange.to);\n        } else if (item.type === 'dateRange') {\n            return Boolean(item.dateRange.start || item.dateRange.end);\n        } else if (item.type === 'date') {\n            return Boolean(item.date);\n        } else {\n            return false;\n        }\n    }\n\n    public searchTextChanged() {\n\n        // run the lazy loading\n        // the filterItems called from onChanges, so call lazy loading only on search change\n        this.resetLazyLoadingSources(false);\n\n        this.filterItems();\n    }\n\n    private async resetLazyLoadingSources(showSelectedOnTop: boolean) {\n        const requests = [];\n        for (const configItem of this.config.items) {\n            if (configItem.isLazyLoading) {\n                configItem.canLoadMore = true;\n                configItem.filteredDataSource = [];\n                requests.push(this.loadMore(configItem, showSelectedOnTop));\n            }\n        }\n\n        await Promise.all(requests);\n\n        // filter non-lazy loading items\n        this.filterItems();\n    }\n\n    private filterItems() {\n        let hasData = false;\n\n        for (const configItem of this.config.items) {\n            if (configItem.type === 'multiselect') {\n                if (configItem.isLazyLoading) {\n                    if (configItem.isLoadingNow) {\n                        // mark as data available in loading state\n                        hasData = true;\n                    }\n                    else if (configItem.filteredDataSource.length) {\n                        hasData = true;\n                    }\n                }\n                else {\n                    configItem.filteredDataSource = configItem.dataSource.filter(el => {\n                        const preparedName = typeof el.name === 'number' ? el.name.toString() : el.name;\n                        return preparedName.toLowerCase().includes(this.searchText.toLowerCase());\n                    });\n\n                    if (configItem.filteredDataSource.length) {\n                        hasData = true;\n                    }\n                }\n            } else if (configItem.type === 'dateRange') {\n                if (this.searchText && !Boolean(configItem.dateRange.start || configItem.dateRange.end)) {\n                    configItem.filteredDataSource = [];\n                }\n            } else if (configItem.type === 'numberRange') {\n                if (this.searchText && !Boolean(configItem.numberRange.from || configItem.numberRange.to)) {\n                    configItem.filteredDataSource = [];\n                }\n            }\n        }\n\n        this.showNoFilterResult = this.searchText && !hasData;\n    }\n\n    public async loadMore(item: FiltersConfigItem, showSelectedOnTop: boolean) {\n        try {\n            item.isLoadingNow = true;\n            if (!item.lazyLoader) {\n                throw `loader is not available`\n            }\n            if (!item.filteredDataSource) {\n                item.filteredDataSource = [];\n            }\n\n            // load first 10 records for the the first time\n            const limit = (item.filteredDataSource.length == 0) ? 10 : 100;\n            const newItems = await item.lazyLoader(this.searchText || \"\", item.filteredDataSource.length, limit);\n\n            item.canLoadMore = (newItems.length == limit);\n\n            // the filteredDataSource contains the items that is visilible to user at the current moment\n            item.filteredDataSource = item.filteredDataSource.concat(newItems);\n\n\n            // the dataSource contains the selected items\n            const checkedIds = item.dataSource.filter(i => i.checked).map(i => i.id);\n\n            if (showSelectedOnTop) {\n                // remove the checked items first\n                item.filteredDataSource = item.filteredDataSource.filter(i => !checkedIds.includes(i.id));\n                // add all checked items to the top                \n                const checkedItems = item.dataSource.filter(i => i.checked);\n                item.filteredDataSource = checkedItems.concat(item.filteredDataSource);\n            }\n            else {\n                // mark as checked based on the dataSource\n                for (let dsItem of item.filteredDataSource) {\n                    dsItem.checked = checkedIds.includes(dsItem.id);\n                }\n            }\n        }\n        catch (err) {\n            console.error(err);\n        }\n        finally {\n            item.isLoadingNow = false;\n        }\n    }\n\n    public toggleItem(item: FiltersConfigItem) {\n        item.expanded = !item.expanded;\n\n        if (item.isLazyLoading) {\n            if (item.expanded) {\n                if (item.canLoadMore !== false &&\n                    !item.filteredDataSource?.length) {\n                    this.loadMore(item, false);\n                }\n            }\n        }\n    }\n\n    private resetFilters() {\n        let selectAll = this.resetBehavior === \"set_all\";\n        this.selectedDateRangeOptions = {};\n\n        for (const item of this.config.items) {\n            if (item.dataSource) {\n                item.isSelectedAll = selectAll;\n\n                for (const dsItem of item.dataSource) {\n                    dsItem.checked = selectAll;\n                }\n            }\n\n            if (item.dateRange) {\n                item.dateRange = { start: null, end: null };\n            }\n\n            if (item.numberRange) {\n                item.numberRange = { from: null, to: null };\n            }\n\n            if (item.date) {\n                item.date = new Date();\n            }\n            if (item.type === 'toggle') {\n                item.enabled = false;\n            }\n            if (item.type === 'radio') {\n                item.radioOptions.forEach(e => {\n                    if (e.id === item.selectedRadio) {\n                        e.selected = true\n                    } else {\n                        e.selected = false\n                    }\n                })\n            }\n        }\n    }\n\n    private restorePreviousApplied(): void {\n        for (const item of this.config.items) {\n            switch (item.type) {\n                case 'multiselect':\n                    if (item.dataSource) {\n                        const selection = this.lastAppliedFilter[item.key];\n\n                        for (const dataItem of item.dataSource) {\n                            dataItem.checked = selection ? selection.includes(dataItem.id) : false;\n                        }\n                    }\n                    break;\n                case 'dateRange':\n                    item.dateRange = this.lastAppliedFilter[item.key] || { start: null, end: null };\n                    break;\n                case 'numberRange':\n                    item.numberRange = this.lastAppliedFilter[item.key] || {};\n                    break;\n                case 'toggle':\n                    item.dateRange = this.lastAppliedFilter[item.key];\n                    break;\n                case 'date':\n                    item.date = this.lastAppliedFilter[item.key];\n                    break;\n                case 'radio':\n                    item.selectedRadio = this.lastAppliedFilter[item.key];\n                    break;\n            }\n        }\n    }\n\n    public reset() {\n        this.resetFilters();\n\n        this.filter = this.getFilterObject();\n        this.resetedFilter = this.getFilterObject();\n\n        this.resetLazyLoadingSources(false);\n    }\n\n    public apply() {\n        this.filter = this.getFilterObject();\n        let hasError = false;\n        for (const iterator of this.config.items) {\n            const itemFlag = this.onCheckValidity(iterator);\n            if (!itemFlag) {\n                hasError = true\n            }\n        }\n        if (hasError) {\n            setTimeout(() => this.errorMessage = [], 5000);\n            return;\n        } else {\n            this.errorMessage = [];\n        }\n        this.lastAppliedFilter = Util.clone(this.filter);\n\n        this.filterChange.emit(this.filter);\n\n        // update the apply state\n        this.updateAppliedState();\n\n        this.hide();\n    }\n\n    private updateAppliedState() {\n        this.isApplied = false;\n        // showing checked items on top of the list\n        for (const item of this.config.items) {\n            if (item.type === 'multiselect') {\n                // resort first based on index\n                item.dataSource.sort((a, b) => a.index - b.index);\n\n                // then sort based on checked items again\n                item.dataSource.sort((a: DataSource, b: DataSource) => Number(b.checked || 0) - Number(a.checked || 0));\n            }\n        }\n\n        if (Object.keys(this.filter).length > 0) {\n            if (this.resetedFilter) {\n                // Filter was reset, so compare the reset filter object with the current filter\n                // When user click on Reset and Then Apply, filter must unhighlighted\n                if (JSON.stringify(this.resetedFilter) !== JSON.stringify(this.filter)) {\n                    this.isApplied = true;\n                }\n            } else {\n                this.isApplied = true;\n            }\n        }\n\n        let wrapperClass = document.querySelector('.action-menu-body');\n        if (this.wrapperBodyClass) {\n            wrapperClass = document.querySelector(`.${this.wrapperBodyClass}`);\n        }\n        if (wrapperClass) {\n            wrapperClass.scrollTo({ top: 0, behavior: 'auto' });\n        }\n    }\n\n    private getFilterObject() {\n        const filter = {};\n\n        for (const item of this.config.items) {\n            switch (item.type) {\n                case 'multiselect':\n                    if (item.dataSource && item.dataSource.length) {\n                        const checkedIds = item.dataSource\n                            .filter(i => i.checked)\n                            .map(i => i.id);\n\n                        if (checkedIds.length) {\n                            filter[item.key] = checkedIds;\n                        }\n                    }\n                    break;\n                case 'dateRange':\n                    if (\n                        item.dateRange &&\n                        item.dateRange.start &&\n                        item.dateRange.end\n                    ) {\n                        filter[item.key] = item.dateRange;\n                    }\n                    break;\n                case 'numberRange':\n                    if (\n                        item.numberRange &&\n                        typeof item?.numberRange?.from === 'number' &&\n                        typeof item?.numberRange?.to === 'number'\n                    ) {\n                        filter[item.key] = item.numberRange;\n                    }\n                    break;\n                case 'toggle':\n                    filter[item.key] = item.enabled || false;\n                    break;\n                case 'date':\n                    if (item.date) {\n                        filter[item.key] = item.date;\n                    }\n                    break;\n                case 'radio':\n                    filter[item.key] = item.radioOptions.find(ro => ro.selected)?.id;\n                    break;\n            }\n        }\n\n        return filter;\n    }\n\n    public hide() {\n        this.isVisible = false;\n        this.searchText = '';\n        this.filterItems();\n\n        this.isVisibleChange.emit(false);\n    }\n\n    public radioChanged(value: string, item: FiltersConfigItem): void {\n        item.radioOptions.forEach(opt => opt.selected = opt.id === value);\n    }\n\n    public checkChanged(item: DataSource, configItem: FiltersConfigItem): void {\n\n        if (configItem.isLazyLoading) {\n            // store the check items in the data source\n            const existItem = configItem.dataSource.find(i => i.id == item.id);\n            if (existItem) {\n                existItem.checked = item.checked;\n            }\n            else {\n                configItem.dataSource.push(item);\n            }\n            // keep only checked\n            configItem.dataSource = configItem.dataSource.filter(d => d.checked);\n        }\n        else {\n            if (!item.children?.length) {\n                return;\n            }\n            configItem.dataSource.forEach((data) => {\n                if (item.id == data.id) {\n                    return\n                }\n                if (item.children.includes(<string>data.id)) {\n                    data.checked = item.checked;\n                    if (data.children?.length) {\n                        this.checkChanged(data, configItem);\n                    }\n                }\n            });\n        }\n    }\n\n    public toggle() {\n        this.isVisible = !this.isVisible;\n        this.updatePlacement();\n        this.focusSearchBox();\n\n        if (this.isVisible) {\n            this.resetLazyLoadingSources(true);\n        }\n    }\n\n    public onCheckValidity(item: FiltersConfigItem) {\n        if (item.type === 'numberRange') {\n            if (typeof item.numberRange.from === 'number' && typeof item.numberRange.to === 'number' && item.numberRange.from > item.numberRange.to) {\n                this.errorMessage.push(`Invalid Number range: The Min number cannot be greater than the Max number.`);\n                return false;\n            }\n        }\n        if (item.type === 'dateRange') {\n            if (item.dateRange.start && item.dateRange.end && new Date(item.dateRange.start) > new Date(item.dateRange.end)) {\n                this.errorMessage.push(`Invalid Date range: The Start date cannot be after the End date.`);\n                return false;\n            }\n        }\n        return true\n    }\n\n    public updatePlacement() {\n        const container = this._componentElement.nativeElement as HTMLElement;\n        const rect = container.getBoundingClientRect();\n        const left = rect.left;\n        const right = rect.right;\n        const top = rect.top;\n        const bottom = window.innerHeight - top;\n\n        //Update left-right position \n        if (this.position.includes(\"auto\")) {\n            const horizontalPosition = this.getHorizontalPosition();\n            this.menuRight = horizontalPosition === \"left\" ? `${window.innerWidth - right}px` : \"unset\";\n            this.menuLeft = horizontalPosition === \"right\" ? `${left}px` : \"unset\";\n        } else if (this.position.includes(\"left\")) {\n            this.menuRight = `${window.innerWidth - right}px`;\n            this.menuLeft = \"unset\";\n        } else {\n            this.menuLeft = `${left}px`;\n            this.menuRight = \"unset\";\n        }\n\n        //Update top-bottom position \n        if (this.position.includes(\"auto\")) {\n            const verticalPosition = this.getVerticalPosition();\n            this.menuTop = verticalPosition === \"bottom\" ? `${top + 42}px` : \"unset\";\n            this.menuBottom = verticalPosition === \"top\" ? `${bottom}px` : \"unset\";\n        } else if (this.position.includes(\"top\")) {\n            this.menuTop = \"unset\";\n            this.menuBottom = `${bottom + 10}px`;\n        } else {\n            this.menuTop = `${top + 55}px`;\n            this.menuBottom = \"unset\";\n        }\n    }\n\n    private getVerticalPosition(): \"bottom\" | \"top\" {\n        const top = this._componentElement.nativeElement.getBoundingClientRect().top;\n        return top > window.innerHeight / 2 ? \"top\" : \"bottom\";\n    }\n\n    private getHorizontalPosition(): \"right\" | \"left\" {\n        const left = this._componentElement.nativeElement.getBoundingClientRect().left;\n        return left > window.innerWidth / 2 ? \"left\" : \"right\";\n    }\n\n    public getDefaultDateRangeOptions(): { name: string, dateRange: DateRange }[] {\n        return [\n            {\n                name: 'Today',\n                dateRange: {\n                    start: moment().startOf(\"day\").toDate(),\n                    end: moment().endOf(\"day\").toDate()\n                }\n            },\n            {\n                name: 'Yesterday',\n                dateRange: {\n                    start: moment().subtract(1, 'days').startOf(\"day\").toDate(),\n                    end: moment().subtract(1, 'days').endOf(\"day\").toDate()\n                }\n            },\n            {\n                name: 'This Week',\n                dateRange: {\n                    start: moment().startOf('week').toDate(),\n                    end: moment().endOf(\"week\").toDate()\n                }\n            },\n            {\n                name: 'Last Week',\n                dateRange: {\n                    start: moment().subtract(7, 'days').startOf('week').toDate(),\n                    end: moment().subtract(7, 'days').endOf('week').toDate()\n                }\n            },\n            {\n                name: 'This Month',\n                dateRange: {\n                    start: moment().startOf('month').toDate(),\n                    end: moment().endOf(\"month\").toDate()\n                }\n            },\n            {\n                name: 'Last Month',\n                dateRange: {\n                    start: moment().subtract(1, 'month').startOf('month').toDate(),\n                    end: moment().subtract(1, 'month').endOf('month').toDate()\n                }\n            }\n        ]\n    }\n\n    public handleDateRangeOptionClick(item, option) {\n        item.dateRange = option.dateRange;\n        this.selectedDateRangeOptions[item.key] = option.name;\n    }\n\n    public handleCustomDateRangeClick(item) {\n        this.selectedDateRangeOptions[item.key] = \"Custom\";\n    }\n\n    public handleEndDateChange(item) {\n        if (!item.showTime) {\n            item.dateRange.end = moment(item.dateRange.end).endOf('day').toDate();\n        }\n    }\n}\n","<div class=\"filters-component\"\n     #mainComponent\n     click-out=\"isVisible && hide()\">\n\n    <ng-container *ngIf=\"!customTrigger\">\n        <button (click)=\"toggle()\"\n                class=\"button-stroked filter {{isApplied ? 'applied' : ''}}\">\n            <zen-icon [src]=\"imageUrl\"\n                      *ngIf=\"imageUrl\"></zen-icon>\n            <i class=\"filter-icon material-icons\"\n               *ngIf=\"!imageUrl\">filter_list</i>\n            <span *ngIf=\"label\">{{ label | translate }}</span>\n        </button>\n    </ng-container>\n\n    <ng-content *ngIf=\"customTrigger\"></ng-content>\n\n    <div [hidden]=\"!isVisible\"\n         class=\"action-menu menu-content\"\n         [class.customTrigger]=\"customTrigger\"\n         [ngStyle]=\"{ 'left': menuLeft, 'right': menuRight, 'top': menuTop, 'bottom': menuBottom  }\">\n        <div class=\"action-menu-header\">\n            <zen-search-box [(text)]=\"searchText\"\n                            #searchBox\n                            (textChange)=\"searchTextChanged()\"></zen-search-box>\n        </div>\n\n        <div class=\"action-menu-body items-wrapper\"\n             ngClass=\"{{wrapperBodyClass}}\">\n            <ng-container *ngIf=\"errorMessage.length\">\n                <li *ngFor=\"let item of errorMessage\"\n                    class=\"error-msg\">{{item | translate }}</li>\n            </ng-container>\n\n            <div *ngFor=\"let item of config.items\">\n                <div class=\"menu-item\"\n                     *ngIf=\"isMenuIsVisible(item)\">\n\n                    <!-- Divider between two filter -->\n                    <div *ngIf=\"item.type === 'divider'\">\n                        <p class=\"filter-divider\"></p>\n                    </div>\n\n                    <!-- Boolean toggle -->\n                    <div *ngIf=\"item.type === 'toggle'\"\n                         class=\"action-item toggle-row\">\n                        <div>{{item.title | translate}}</div>\n                        <zen-toggle-slide [(enabled)]=\"item.enabled\"></zen-toggle-slide>\n                    </div>\n\n                    <button class=\"action-item expander-item\"\n                            *ngIf=\"item.type != 'toggle' && item.type != 'divider' && !item.disableCollapse\"\n                            (click)=\"toggleItem(item)\"\n                            [ngClass]=\"{'active': isItemActive(item), 'expanded': item.expanded}\">\n                        <i class=\"material-icons expand-icon\"\n                           [ngClass]=\"{'active': item.expanded}\">expand_more</i>\n                        {{item.title | translate}}\n                    </button>\n\n                    <ng-container *ngIf=\"item.expanded || item.disableCollapse\">\n                        <div [ngSwitch]=\"item.type\">\n                            <!-- Multiselect -->\n                            <div *ngSwitchCase=\"'multiselect'\">\n                                <!-- Lazy loading mode -->\n                                <ng-container *ngIf=\"item.isLazyLoading\">\n                                    <div *ngFor=\"let dsItem of item.filteredDataSource\"\n                                         class=\"action-item-checkbox ds-item\">\n                                        <zen-checkbox [(checked)]=\"dsItem.checked\"\n                                                      [imageUrl]=\"dsItem.imageUrl\"\n                                                      (checkedChange)=\"checkChanged(dsItem, item)\"\n                                                      [label]=\"dsItem.name?.toString() | translate\"></zen-checkbox>\n                                    </div>\n                                    <div *ngIf=\"item.canLoadMore && !item.isLoadingNow\"\n                                         class=\"action-item\">\n                                        <button (click)=\"loadMore(item, false)\"\n                                                class=\"button-stroked full-width\">\n                                            {{'Load More' | translate}}\n                                        </button>\n                                    </div>\n                                    <div *ngIf=\"item.isLoadingNow\"\n                                         class=\"loader-more-spinner\">\n                                        <zen-spinner size=\"small\"></zen-spinner>\n                                    </div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"!item.isLazyLoading\">\n                                    <div class=\"action-item-checkbox ds-item select-all\">\n                                        <zen-checkbox *ngIf=\"item.dataSource.length === item.filteredDataSource.length\"\n                                                      [(checked)]=\"item.isSelectedAll\"\n                                                      [indeterminate]=\"isItemActive(item) && !item.isSelectedAll\"\n                                                      [label]=\"'Select All' | translate\"\n                                                      (checkedChange)=\"onSelectAll(item)\">\n                                        </zen-checkbox>\n                                    </div>\n\n                                    <div *ngFor=\"let dsItem of item.filteredDataSource\"\n                                         class=\"action-item-checkbox ds-item\">\n                                        <zen-checkbox [(checked)]=\"dsItem.checked\"\n                                                      [imageUrl]=\"dsItem.imageUrl\"\n                                                      (checkedChange)=\"checkChanged(dsItem, item)\"\n                                                      [label]=\"dsItem.name?.toString() | translate\"></zen-checkbox>\n                                    </div>\n                                </ng-container>\n                            </div>\n\n                            <!-- Date range picker -->\n                            <div *ngSwitchCase=\"'dateRange'\">\n                                <!--  Options date range view  -->\n                                <ng-container *ngIf=\"item.dateRangeOptions?.length\">\n                                    <ng-container *ngFor=\"let option of item.dateRangeOptions\">\n                                        <div class=\"action-item-radio ds-item\"\n                                             [ngClass]=\"{'active': selectedDateRangeOptions[item.key] === option.name}\">\n                                            <zen-radio [value]=\"option.name\"\n                                                       [label]=\"option.name | translate\"\n                                                       [name]=\"item.key\"\n                                                       [selected]=\"selectedDateRangeOptions[item.key] === option.name\"\n                                                       (radioChange)=\"handleDateRangeOptionClick(item, option)\"></zen-radio>\n                                        </div>\n                                    </ng-container>\n                                    <div class=\"action-item-radio ds-item\"\n                                         [ngClass]=\"{'active': selectedDateRangeOptions[item.key] === 'Custom'}\">\n                                        <zen-radio [value]=\"'Custom'\"\n                                                   [label]=\"'Custom' | translate\"\n                                                   [name]=\"item.key\"\n                                                   [selected]=\"selectedDateRangeOptions[item.key] === 'Custom'\"\n                                                   (radioChange)=\"handleCustomDateRangeClick(item)\"></zen-radio>\n                                    </div>\n                                    <ng-container *ngIf=\"selectedDateRangeOptions[item.key] === 'Custom'\">\n                                        <div class=\"ds-item filter-row\">\n                                            <div class=\"lbl\">{{'From' | translate}}:</div>\n                                            <zen-datepicker class=\"width-full\"\n                                                            [(date)]=\"item.dateRange.start\"\n                                                            [showTime]=\"item.showTime\"\n                                                            [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                            [parentContainer]=\"mainComponent\">\n                                            </zen-datepicker>\n                                        </div>\n                                        <div class=\"ds-item filter-row\">\n                                            <div class=\"lbl\">{{'To' | translate}}:</div>\n                                            <zen-datepicker class=\"width-full\"\n                                                            [(date)]=\"item.dateRange.end\"\n                                                            [showTime]=\"item.showTime\"\n                                                            [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                            (dateChange)=\"handleEndDateChange(item)\"\n                                                            [parentContainer]=\"mainComponent\">\n                                            </zen-datepicker>\n                                        </div>\n                                    </ng-container>\n                                </ng-container>\n\n                                <!--  Default date range view  -->\n                                <ng-container *ngIf=\"!item.dateRangeOptions?.length\">\n                                    <div class=\"ds-item filter-row\">\n                                        <div class=\"lbl\">{{'From' | translate}}:</div>\n                                        <zen-datepicker class=\"width-full\"\n                                                        [(date)]=\"item.dateRange.start\"\n                                                        [showTime]=\"item.showTime\"\n                                                        [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                        [parentContainer]=\"mainComponent\">\n                                        </zen-datepicker>\n                                    </div>\n                                    <div class=\"ds-item filter-row\">\n                                        <div class=\"lbl\">{{'To' | translate}}:</div>\n                                        <zen-datepicker class=\"width-full\"\n                                                        [(date)]=\"item.dateRange.end\"\n                                                        [showTime]=\"item.showTime\"\n                                                        [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                        (dateChange)=\"handleEndDateChange(item)\"\n                                                        [parentContainer]=\"mainComponent\">\n                                        </zen-datepicker>\n                                    </div>\n                                </ng-container>\n                            </div>\n\n                            <!-- Date picker -->\n                            <div *ngSwitchCase=\"'date'\">\n                                <div class=\"ds-item filter-row\">\n                                    <div class=\"lbl\">{{'Date' | translate}}:</div>\n                                    <zen-datepicker class=\"width-full\"\n                                                    [(date)]=\"item.date\"\n                                                    [showTime]=\"item.showTime\"\n                                                    [parentContainer]=\"mainComponent\">\n                                    </zen-datepicker>\n                                </div>\n                            </div>\n\n                            <!-- Number range -->\n                            <div *ngSwitchCase=\"'numberRange'\"\n                                 class=\"filter-row number-range-row\">\n                                <div>\n                                    <div class=\"lbl\">{{'Min' | translate}}:</div>\n                                    <input class=\"material-input\"\n                                           [(ngModel)]=\"item.numberRange.from\"\n                                           type=\"number\" />\n                                </div>\n                                <div>\n                                    <div class=\"lbl\">{{'Max' | translate}}:</div>\n                                    <input class=\"material-input\"\n                                           [(ngModel)]=\"item.numberRange.to\"\n                                           type=\"number\" />\n                                </div>\n                            </div>\n\n                            <!-- Radio -->\n                            <div *ngSwitchCase=\"'radio'\">\n                                <div *ngFor=\"let option of item.radioOptions\"\n                                     class=\"action-item-radio ds-item\"\n                                     [ngClass]=\"{'active': option.selected}\">\n                                    <zen-radio [value]=\"option.id\"\n                                               [label]=\"option.name | translate\"\n                                               [name]=\"item.key\"\n                                               [imageUrl]=\"option.imageUrl\"\n                                               [selected]=\"option.selected\"\n                                               (radioChange)=\"radioChanged($event, item)\"\n                                               [disabled]=\"option.disabled\"></zen-radio>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n\n                </div>\n            </div>\n            <span *ngIf=\"showNoFilterResult\"\n                  class=\"no-item\">{{'No Results Found' | translate}}..</span>\n        </div>\n\n        <div class=\"action-menu-footer\">\n            <button (click)=\"reset()\"\n                    class=\"button-stroked full-width\">\n                {{'Reset' | translate}}\n            </button>\n            <button (click)=\"apply()\"\n                    class=\"button-flat full-width\">\n                {{'Apply' | translate}}\n            </button>\n        </div>\n\n    </div>\n</div>\n"]}
673
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/filter/zendu-filter.component.ts","../../../../../projects/ng-zenduit/src/lib/filter/zendu-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { DataSource, FiltersConfig, FiltersConfigItem, MultiSelectItem } from './filtersConfig';\nimport uniqBy from 'lodash.uniqby';\nimport moment from 'moment/moment';\nimport { ZenduSearchBoxComponent } from '../search-box/zendu-search-box.component';\nimport { Util } from '../util';\nimport { DATEPICKER_POSITION } from '../datepicker/datepicker';\nimport { DateRange } from \"./dateRange\";\n\n@Component({\n    selector: 'zen-filter',\n    templateUrl: './zendu-filter.component.html',\n    styleUrls: ['./zendu-filter.component.scss']\n})\nexport class ZenduFilterComponent implements OnChanges {\n\n    @Input() config: FiltersConfig = { items: [] };\n\n    @Input() filter: object;\n\n    @Input() position = 'right';\n\n    @Input() resetBehavior: \"set_all\" | \"clear\" = 'clear';\n\n    @Output() filterChange = new EventEmitter<object>();\n\n    @Input() isVisible = false;\n\n    @Output() isVisibleChange = new EventEmitter<boolean>();\n\n    @Input() customTrigger = false;\n\n    @Input() imageUrl: string;\n\n    @Input() label: string;\n\n    @Input() showOptions: boolean;\n\n    @Input() customOptions: string;\n\n    @Input() wrapperBodyClass: string;\n\n    public searchText = '';\n\n    public isApplied = false;\n\n    private lastAppliedFilter: any = {};\n\n    private resetedFilter: any;\n\n    public menuLeft = \"0px\";\n\n    public menuRight = \"0px\";\n\n    public menuTop = \"0px\";\n\n    public menuBottom = \"0px\";\n\n    public showNoFilterResult: boolean;\n\n    public errorMessage: string[] = []\n\n    public datepickerPosition = DATEPICKER_POSITION;\n\n    public selectedDateRangeOptions: { [key: string]: string } = {};\n\n    @ViewChild('searchBox', { static: false }) searchBox: ZenduSearchBoxComponent;\n\n    @ViewChild('mainComponent', { static: false }) _componentElement: ElementRef<HTMLElement>;\n\n    constructor() { }\n\n    public ngOnChanges(changes: any): void {\n        if (changes.config && changes.config.currentValue) {\n\n            // init values\n            for (const item of this.config.items) {\n                if (item.type === 'multiselect') {\n                    item.dataSource = item.dataSource ? this.extractUniqueDataSource(item.dataSource) : [];\n                } else if (item.type === 'dateRange' && !item.dateRange) {\n                    item.dateRange = { start: null, end: null };\n\n                    // init date range options\n                    if (item.showDateRangeOptions && !item.dateRangeOptions?.length) {\n                        item.dateRangeOptions = this.getDefaultDateRangeOptions();\n                    }\n                } else if (item.type === 'numberRange' && !item.numberRange) {\n                    item.numberRange = {};\n                }\n\n                if (typeof item.showTime !== 'boolean') {\n                    item.showTime = true;\n                }\n            }\n\n            this.filterItems();\n\n            this.resetedFilter = this.getFilterObject();\n            this.filter = this.getFilterObject();\n            this.lastAppliedFilter = Util.clone(this.filter);\n        }\n\n        if (changes.filter && changes.filter.currentValue) {\n            this.lastAppliedFilter = Util.clone(changes.filter.currentValue);\n\n            this.updateAppliedState();\n        }\n\n        if (changes.isVisible && changes.isVisible.currentValue) {\n            this.updatePlacement();\n            this.focusSearchBox();\n        }\n    }\n\n    @HostListener('window:mousedown', ['$event'])\n    outsideHandling(event: MouseEvent) {\n        if (!this.isVisible) {\n            return;\n        }\n\n        const target = event.target as HTMLElement;\n        if (!document.body.contains(target)) {\n            // element not in the DOM\n            return;\n        }\n        if (this._componentElement.nativeElement.contains(target)) {\n            return;\n        }\n\n        // hide the menu for outside click\n        this.hide();\n\n        // restore values\n        this.restorePreviousApplied();\n    }\n\n    @HostListener('window:resize', ['$event'])\n    windowSizeHandling() {\n        if (!this.isVisible) {\n            return;\n        }\n\n        this.updatePlacement();\n    }\n\n    @HostListener('window:scroll', ['$event'])\n    windowScroll() {\n        if (!this.isVisible) {\n            return;\n        }\n\n        this.updatePlacement();\n    }\n\n    @HostListener('window:wheel', ['$event'])\n    handleMouseScroll(event: WheelEvent): void {\n        if (!this.isVisible) {\n            return;\n        }\n\n        const target = event.target as HTMLElement;\n        if (!document.body.contains(target)) {\n            return;\n        }\n        if (this._componentElement.nativeElement.contains(target) && !target.classList.contains('button-stroked')) {\n            return;\n        }\n\n        this.hide();\n        this.restorePreviousApplied();\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    onWindowKeyDown(event: KeyboardEvent) {\n        if (!this.isVisible) {\n            return;\n        }\n\n        if (event.key === 'ArrowUp' || event.key === 'ArrowDown' || event.key === 'PageUp' || event.key === 'PageDown' || event.key === 'Home' || event.key === 'End') {\n\n            const target = event.target as HTMLElement;\n            if (!document.body.contains(target)) {\n                return;\n            }\n\n            if (this._componentElement.nativeElement.contains(target) && !target.classList.contains('button-stroked')) {\n                return;\n            }\n            this.hide();\n            this.restorePreviousApplied();\n        }\n    }\n\n    public focusSearchBox() {\n        this.searchBox.doFocus();\n    }\n\n    public isMenuIsVisible(item: FiltersConfigItem) {\n        if (item.isLazyLoading) {\n            if (item.isLoadingNow || item.canLoadMore !== false) {\n                return true;\n            }\n            if (this.searchText) {\n                return item.filteredDataSource?.length > 0;\n            }\n            return true;\n        }\n\n        if (item.filteredDataSource && this.searchText) {\n            if (!item.filteredDataSource.length) {\n                return false;\n            }\n        }\n\n        return true;\n    }\n\n    private extractUniqueDataSource(\n        array: {\n            id: string | number,\n            name: string | number\n        }[]\n    ): MultiSelectItem[] {\n        const items = array.filter(el => {\n            return Boolean(\n                typeof el.id === 'number' ? typeof el.id !== undefined : el.id &&\n                    typeof el.name === 'number' ? typeof el.name !== undefined : el.name\n            );\n        });\n        const uniqItems = uniqBy(items, (el) => el.id);\n        // add index to each uniqItems\n        uniqItems.forEach((el: MultiSelectItem, index: number) => el.index = index);\n        return uniqItems\n    }\n\n    public onSelectAll(item: FiltersConfigItem) {\n        item.dataSource.forEach(d => d.checked = item.isSelectedAll);\n    }\n\n    public isItemActive(item: FiltersConfigItem): boolean {\n        if (item.type === 'multiselect') {\n            const checkedItems = item.dataSource.filter(el => el.checked);\n            item.isSelectedAll = checkedItems.length === item.dataSource.length\n            return checkedItems.length > 0;\n        } else if (item.type === 'radio') {\n            return item.radioOptions.some(ro => ro.selected);\n        } else if (item.type === 'numberRange') {\n            return Boolean(item.numberRange.from || item.numberRange.to);\n        } else if (item.type === 'dateRange') {\n            return Boolean(item.dateRange.start || item.dateRange.end);\n        } else if (item.type === 'date') {\n            return Boolean(item.date);\n        } else {\n            return false;\n        }\n    }\n\n    public searchTextChanged() {\n\n        // run the lazy loading\n        // the filterItems called from onChanges, so call lazy loading only on search change\n        this.resetLazyLoadingSources(false);\n\n        this.filterItems();\n    }\n\n    private async resetLazyLoadingSources(showSelectedOnTop: boolean) {\n        const requests = [];\n        for (const configItem of this.config.items) {\n            if (configItem.isLazyLoading) {\n                configItem.canLoadMore = true;\n                configItem.filteredDataSource = [];\n                requests.push(this.loadMore(configItem, showSelectedOnTop));\n            }\n        }\n\n        await Promise.all(requests);\n\n        // filter non-lazy loading items\n        this.filterItems();\n    }\n\n    private filterItems() {\n        let hasData = false;\n\n        for (const configItem of this.config.items) {\n            if (configItem.type === 'multiselect') {\n                if (configItem.isLazyLoading) {\n                    if (configItem.isLoadingNow) {\n                        // mark as data available in loading state\n                        hasData = true;\n                    }\n                    else if (configItem.filteredDataSource.length) {\n                        hasData = true;\n                    }\n                }\n                else {\n                    configItem.filteredDataSource = configItem.dataSource.filter(el => {\n                        const preparedName = typeof el.name === 'number' ? el.name.toString() : el.name;\n                        return preparedName.toLowerCase().includes(this.searchText.toLowerCase());\n                    });\n\n                    if (configItem.filteredDataSource.length) {\n                        hasData = true;\n                    }\n                }\n            } else if (configItem.type === 'dateRange') {\n                if (this.searchText && !Boolean(configItem.dateRange.start || configItem.dateRange.end)) {\n                    configItem.filteredDataSource = [];\n                }\n            } else if (configItem.type === 'numberRange') {\n                if (this.searchText && !Boolean(configItem.numberRange.from || configItem.numberRange.to)) {\n                    configItem.filteredDataSource = [];\n                }\n            }\n        }\n\n        this.showNoFilterResult = this.searchText && !hasData;\n    }\n\n    public async loadMore(item: FiltersConfigItem, showSelectedOnTop: boolean) {\n        try {\n            item.isLoadingNow = true;\n            if (!item.lazyLoader) {\n                throw `loader is not available`\n            }\n            if (!item.filteredDataSource) {\n                item.filteredDataSource = [];\n            }\n\n            // load first 10 records for the the first time\n            const limit = (item.filteredDataSource.length == 0) ? 10 : 100;\n            const newItems = await item.lazyLoader({ text: this.searchText || \"\" }, item.filteredDataSource.length, limit);\n\n            item.canLoadMore = (newItems.length == limit);\n\n            // the filteredDataSource contains the items that is visilible to user at the current moment\n            item.filteredDataSource = item.filteredDataSource.concat(newItems);\n\n\n            // the dataSource contains the selected items\n            const checkedIds = item.dataSource.filter(i => i.checked).map(i => i.id);\n\n            if (showSelectedOnTop) {\n                // remove the checked items first\n                item.filteredDataSource = item.filteredDataSource.filter(i => !checkedIds.includes(i.id));\n                // add all checked items to the top                \n                const checkedItems = item.dataSource.filter(i => i.checked);\n                item.filteredDataSource = checkedItems.concat(item.filteredDataSource);\n            }\n            else {\n                // mark as checked based on the dataSource\n                for (let dsItem of item.filteredDataSource) {\n                    dsItem.checked = checkedIds.includes(dsItem.id);\n                }\n            }\n        }\n        catch (err) {\n            console.error(err);\n        }\n        finally {\n            item.isLoadingNow = false;\n        }\n    }\n\n    public toggleItem(item: FiltersConfigItem) {\n        item.expanded = !item.expanded;\n\n        if (item.isLazyLoading) {\n            if (item.expanded) {\n                if (item.canLoadMore !== false &&\n                    !item.filteredDataSource?.length) {\n                    this.loadMore(item, false);\n                }\n            }\n        }\n    }\n\n    private resetFilters() {\n        let selectAll = this.resetBehavior === \"set_all\";\n        this.selectedDateRangeOptions = {};\n\n        for (const item of this.config.items) {\n            if (item.dataSource) {\n                item.isSelectedAll = selectAll;\n\n                for (const dsItem of item.dataSource) {\n                    dsItem.checked = selectAll;\n                }\n            }\n\n            if (item.dateRange) {\n                item.dateRange = { start: null, end: null };\n            }\n\n            if (item.numberRange) {\n                item.numberRange = { from: null, to: null };\n            }\n\n            if (item.date) {\n                item.date = new Date();\n            }\n            if (item.type === 'toggle') {\n                item.enabled = false;\n            }\n            if (item.type === 'radio') {\n                item.radioOptions.forEach(e => {\n                    if (e.id === item.selectedRadio) {\n                        e.selected = true\n                    } else {\n                        e.selected = false\n                    }\n                })\n            }\n        }\n    }\n\n    private restorePreviousApplied(): void {\n        for (const item of this.config.items) {\n            switch (item.type) {\n                case 'multiselect':\n                    if (item.dataSource) {\n                        const selection = this.lastAppliedFilter[item.key];\n\n                        for (const dataItem of item.dataSource) {\n                            dataItem.checked = selection ? selection.includes(dataItem.id) : false;\n                        }\n                    }\n                    break;\n                case 'dateRange':\n                    item.dateRange = this.lastAppliedFilter[item.key] || { start: null, end: null };\n                    break;\n                case 'numberRange':\n                    item.numberRange = this.lastAppliedFilter[item.key] || {};\n                    break;\n                case 'toggle':\n                    item.dateRange = this.lastAppliedFilter[item.key];\n                    break;\n                case 'date':\n                    item.date = this.lastAppliedFilter[item.key];\n                    break;\n                case 'radio':\n                    item.selectedRadio = this.lastAppliedFilter[item.key];\n                    break;\n            }\n        }\n    }\n\n    public reset() {\n        this.resetFilters();\n\n        this.filter = this.getFilterObject();\n        this.resetedFilter = this.getFilterObject();\n\n        this.resetLazyLoadingSources(false);\n    }\n\n    public apply() {\n        this.filter = this.getFilterObject();\n        let hasError = false;\n        for (const iterator of this.config.items) {\n            const itemFlag = this.onCheckValidity(iterator);\n            if (!itemFlag) {\n                hasError = true\n            }\n        }\n        if (hasError) {\n            setTimeout(() => this.errorMessage = [], 5000);\n            return;\n        } else {\n            this.errorMessage = [];\n        }\n        this.lastAppliedFilter = Util.clone(this.filter);\n\n        this.filterChange.emit(this.filter);\n\n        // update the apply state\n        this.updateAppliedState();\n\n        this.hide();\n    }\n\n    private updateAppliedState() {\n        this.isApplied = false;\n        // showing checked items on top of the list\n        for (const item of this.config.items) {\n            if (item.type === 'multiselect') {\n                // resort first based on index\n                item.dataSource.sort((a, b) => a.index - b.index);\n\n                // then sort based on checked items again\n                item.dataSource.sort((a: DataSource, b: DataSource) => Number(b.checked || 0) - Number(a.checked || 0));\n            }\n        }\n\n        if (Object.keys(this.filter).length > 0) {\n            if (this.resetedFilter) {\n                // Filter was reset, so compare the reset filter object with the current filter\n                // When user click on Reset and Then Apply, filter must unhighlighted\n                if (JSON.stringify(this.resetedFilter) !== JSON.stringify(this.filter)) {\n                    this.isApplied = true;\n                }\n            } else {\n                this.isApplied = true;\n            }\n        }\n\n        let wrapperClass = document.querySelector('.action-menu-body');\n        if (this.wrapperBodyClass) {\n            wrapperClass = document.querySelector(`.${this.wrapperBodyClass}`);\n        }\n        if (wrapperClass) {\n            wrapperClass.scrollTo({ top: 0, behavior: 'auto' });\n        }\n    }\n\n    private getFilterObject() {\n        const filter = {};\n\n        for (const item of this.config.items) {\n            switch (item.type) {\n                case 'multiselect':\n                    if (item.dataSource && item.dataSource.length) {\n                        const checkedIds = item.dataSource\n                            .filter(i => i.checked)\n                            .map(i => i.id);\n\n                        if (checkedIds.length) {\n                            filter[item.key] = checkedIds;\n                        }\n                    }\n                    break;\n                case 'dateRange':\n                    if (\n                        item.dateRange &&\n                        item.dateRange.start &&\n                        item.dateRange.end\n                    ) {\n                        filter[item.key] = item.dateRange;\n                    }\n                    break;\n                case 'numberRange':\n                    if (\n                        item.numberRange &&\n                        typeof item?.numberRange?.from === 'number' &&\n                        typeof item?.numberRange?.to === 'number'\n                    ) {\n                        filter[item.key] = item.numberRange;\n                    }\n                    break;\n                case 'toggle':\n                    filter[item.key] = item.enabled || false;\n                    break;\n                case 'date':\n                    if (item.date) {\n                        filter[item.key] = item.date;\n                    }\n                    break;\n                case 'radio':\n                    filter[item.key] = item.radioOptions.find(ro => ro.selected)?.id;\n                    break;\n            }\n        }\n\n        return filter;\n    }\n\n    public hide() {\n        this.isVisible = false;\n        this.searchText = '';\n        this.filterItems();\n\n        this.isVisibleChange.emit(false);\n    }\n\n    public radioChanged(value: string, item: FiltersConfigItem): void {\n        item.radioOptions.forEach(opt => opt.selected = opt.id === value);\n    }\n\n    public checkChanged(item: DataSource, configItem: FiltersConfigItem): void {\n\n        if (configItem.isLazyLoading) {\n            // store the check items in the data source\n            const existItem = configItem.dataSource.find(i => i.id == item.id);\n            if (existItem) {\n                existItem.checked = item.checked;\n            }\n            else {\n                configItem.dataSource.push(item);\n            }\n            // keep only checked\n            configItem.dataSource = configItem.dataSource.filter(d => d.checked);\n        }\n        else {\n            if (!item.children?.length) {\n                return;\n            }\n            configItem.dataSource.forEach((data) => {\n                if (item.id == data.id) {\n                    return\n                }\n                if (item.children.includes(<string>data.id)) {\n                    data.checked = item.checked;\n                    if (data.children?.length) {\n                        this.checkChanged(data, configItem);\n                    }\n                }\n            });\n        }\n    }\n\n    public toggle() {\n        this.isVisible = !this.isVisible;\n        this.updatePlacement();\n        this.focusSearchBox();\n\n        if (this.isVisible) {\n            this.resetLazyLoadingSources(true);\n        }\n    }\n\n    public onCheckValidity(item: FiltersConfigItem) {\n        if (item.type === 'numberRange') {\n            if (typeof item.numberRange.from === 'number' && typeof item.numberRange.to === 'number' && item.numberRange.from > item.numberRange.to) {\n                this.errorMessage.push(`Invalid Number range: The Min number cannot be greater than the Max number.`);\n                return false;\n            }\n        }\n        if (item.type === 'dateRange') {\n            if (item.dateRange.start && item.dateRange.end && new Date(item.dateRange.start) > new Date(item.dateRange.end)) {\n                this.errorMessage.push(`Invalid Date range: The Start date cannot be after the End date.`);\n                return false;\n            }\n        }\n        return true\n    }\n\n    public updatePlacement() {\n        const container = this._componentElement.nativeElement as HTMLElement;\n        const rect = container.getBoundingClientRect();\n        const left = rect.left;\n        const right = rect.right;\n        const top = rect.top;\n        const bottom = window.innerHeight - top;\n\n        //Update left-right position \n        if (this.position.includes(\"auto\")) {\n            const horizontalPosition = this.getHorizontalPosition();\n            this.menuRight = horizontalPosition === \"left\" ? `${window.innerWidth - right}px` : \"unset\";\n            this.menuLeft = horizontalPosition === \"right\" ? `${left}px` : \"unset\";\n        } else if (this.position.includes(\"left\")) {\n            this.menuRight = `${window.innerWidth - right}px`;\n            this.menuLeft = \"unset\";\n        } else {\n            this.menuLeft = `${left}px`;\n            this.menuRight = \"unset\";\n        }\n\n        //Update top-bottom position \n        if (this.position.includes(\"auto\")) {\n            const verticalPosition = this.getVerticalPosition();\n            this.menuTop = verticalPosition === \"bottom\" ? `${top + 42}px` : \"unset\";\n            this.menuBottom = verticalPosition === \"top\" ? `${bottom}px` : \"unset\";\n        } else if (this.position.includes(\"top\")) {\n            this.menuTop = \"unset\";\n            this.menuBottom = `${bottom + 10}px`;\n        } else {\n            this.menuTop = `${top + 55}px`;\n            this.menuBottom = \"unset\";\n        }\n    }\n\n    private getVerticalPosition(): \"bottom\" | \"top\" {\n        const top = this._componentElement.nativeElement.getBoundingClientRect().top;\n        return top > window.innerHeight / 2 ? \"top\" : \"bottom\";\n    }\n\n    private getHorizontalPosition(): \"right\" | \"left\" {\n        const left = this._componentElement.nativeElement.getBoundingClientRect().left;\n        return left > window.innerWidth / 2 ? \"left\" : \"right\";\n    }\n\n    public getDefaultDateRangeOptions(): { name: string, dateRange: DateRange }[] {\n        return [\n            {\n                name: 'Today',\n                dateRange: {\n                    start: moment().startOf(\"day\").toDate(),\n                    end: moment().endOf(\"day\").toDate()\n                }\n            },\n            {\n                name: 'Yesterday',\n                dateRange: {\n                    start: moment().subtract(1, 'days').startOf(\"day\").toDate(),\n                    end: moment().subtract(1, 'days').endOf(\"day\").toDate()\n                }\n            },\n            {\n                name: 'This Week',\n                dateRange: {\n                    start: moment().startOf('week').toDate(),\n                    end: moment().endOf(\"week\").toDate()\n                }\n            },\n            {\n                name: 'Last Week',\n                dateRange: {\n                    start: moment().subtract(7, 'days').startOf('week').toDate(),\n                    end: moment().subtract(7, 'days').endOf('week').toDate()\n                }\n            },\n            {\n                name: 'This Month',\n                dateRange: {\n                    start: moment().startOf('month').toDate(),\n                    end: moment().endOf(\"month\").toDate()\n                }\n            },\n            {\n                name: 'Last Month',\n                dateRange: {\n                    start: moment().subtract(1, 'month').startOf('month').toDate(),\n                    end: moment().subtract(1, 'month').endOf('month').toDate()\n                }\n            }\n        ]\n    }\n\n    public handleDateRangeOptionClick(item, option) {\n        item.dateRange = option.dateRange;\n        this.selectedDateRangeOptions[item.key] = option.name;\n    }\n\n    public handleCustomDateRangeClick(item) {\n        this.selectedDateRangeOptions[item.key] = \"Custom\";\n    }\n\n    public handleEndDateChange(item) {\n        if (!item.showTime) {\n            item.dateRange.end = moment(item.dateRange.end).endOf('day').toDate();\n        }\n    }\n}\n","<div class=\"filters-component\"\n     #mainComponent\n     click-out=\"isVisible && hide()\">\n\n    <ng-container *ngIf=\"!customTrigger\">\n        <button (click)=\"toggle()\"\n                class=\"button-stroked filter {{isApplied ? 'applied' : ''}}\">\n            <zen-icon [src]=\"imageUrl\"\n                      *ngIf=\"imageUrl\"></zen-icon>\n            <i class=\"filter-icon material-icons\"\n               *ngIf=\"!imageUrl\">filter_list</i>\n            <span *ngIf=\"label\">{{ label | translate }}</span>\n        </button>\n    </ng-container>\n\n    <ng-content *ngIf=\"customTrigger\"></ng-content>\n\n    <div [hidden]=\"!isVisible\"\n         class=\"action-menu menu-content\"\n         [class.customTrigger]=\"customTrigger\"\n         [ngStyle]=\"{ 'left': menuLeft, 'right': menuRight, 'top': menuTop, 'bottom': menuBottom  }\">\n        <div class=\"action-menu-header\">\n            <zen-search-box [(text)]=\"searchText\"\n                            #searchBox\n                            (textChange)=\"searchTextChanged()\"></zen-search-box>\n        </div>\n\n        <div class=\"action-menu-body items-wrapper\"\n             ngClass=\"{{wrapperBodyClass}}\">\n            <ng-container *ngIf=\"errorMessage.length\">\n                <li *ngFor=\"let item of errorMessage\"\n                    class=\"error-msg\">{{item | translate }}</li>\n            </ng-container>\n\n            <div *ngFor=\"let item of config.items\">\n                <div class=\"menu-item\"\n                     *ngIf=\"isMenuIsVisible(item)\">\n\n                    <!-- Divider between two filter -->\n                    <div *ngIf=\"item.type === 'divider'\">\n                        <p class=\"filter-divider\"></p>\n                    </div>\n\n                    <!-- Boolean toggle -->\n                    <div *ngIf=\"item.type === 'toggle'\"\n                         class=\"action-item toggle-row\">\n                        <div>{{item.title | translate}}</div>\n                        <zen-toggle-slide [(enabled)]=\"item.enabled\"></zen-toggle-slide>\n                    </div>\n\n                    <button class=\"action-item expander-item\"\n                            *ngIf=\"item.type != 'toggle' && item.type != 'divider' && !item.disableCollapse\"\n                            (click)=\"toggleItem(item)\"\n                            [ngClass]=\"{'active': isItemActive(item), 'expanded': item.expanded}\">\n                        <i class=\"material-icons expand-icon\"\n                           [ngClass]=\"{'active': item.expanded}\">expand_more</i>\n                        {{item.title | translate}}\n                    </button>\n\n                    <ng-container *ngIf=\"item.expanded || item.disableCollapse\">\n                        <div [ngSwitch]=\"item.type\">\n                            <!-- Multiselect -->\n                            <div *ngSwitchCase=\"'multiselect'\">\n                                <!-- Lazy loading mode -->\n                                <ng-container *ngIf=\"item.isLazyLoading\">\n                                    <div *ngFor=\"let dsItem of item.filteredDataSource\"\n                                         class=\"action-item-checkbox ds-item\">\n                                        <zen-checkbox [(checked)]=\"dsItem.checked\"\n                                                      [imageUrl]=\"dsItem.imageUrl\"\n                                                      (checkedChange)=\"checkChanged(dsItem, item)\"\n                                                      [label]=\"dsItem.name?.toString() | translate\"></zen-checkbox>\n                                    </div>\n                                    <div *ngIf=\"item.canLoadMore && !item.isLoadingNow\"\n                                         class=\"action-item\">\n                                        <button (click)=\"loadMore(item, false)\"\n                                                class=\"button-stroked full-width\">\n                                            {{'Load More' | translate}}\n                                        </button>\n                                    </div>\n                                    <div *ngIf=\"item.isLoadingNow\"\n                                         class=\"loader-more-spinner\">\n                                        <zen-spinner size=\"small\"></zen-spinner>\n                                    </div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"!item.isLazyLoading\">\n                                    <div class=\"action-item-checkbox ds-item select-all\">\n                                        <zen-checkbox *ngIf=\"item.dataSource.length === item.filteredDataSource.length\"\n                                                      [(checked)]=\"item.isSelectedAll\"\n                                                      [indeterminate]=\"isItemActive(item) && !item.isSelectedAll\"\n                                                      [label]=\"'Select All' | translate\"\n                                                      (checkedChange)=\"onSelectAll(item)\">\n                                        </zen-checkbox>\n                                    </div>\n\n                                    <div *ngFor=\"let dsItem of item.filteredDataSource\"\n                                         class=\"action-item-checkbox ds-item\">\n                                        <zen-checkbox [(checked)]=\"dsItem.checked\"\n                                                      [imageUrl]=\"dsItem.imageUrl\"\n                                                      (checkedChange)=\"checkChanged(dsItem, item)\"\n                                                      [label]=\"dsItem.name?.toString() | translate\"></zen-checkbox>\n                                    </div>\n                                </ng-container>\n                            </div>\n\n                            <!-- Date range picker -->\n                            <div *ngSwitchCase=\"'dateRange'\">\n                                <!--  Options date range view  -->\n                                <ng-container *ngIf=\"item.dateRangeOptions?.length\">\n                                    <ng-container *ngFor=\"let option of item.dateRangeOptions\">\n                                        <div class=\"action-item-radio ds-item\"\n                                             [ngClass]=\"{'active': selectedDateRangeOptions[item.key] === option.name}\">\n                                            <zen-radio [value]=\"option.name\"\n                                                       [label]=\"option.name | translate\"\n                                                       [name]=\"item.key\"\n                                                       [selected]=\"selectedDateRangeOptions[item.key] === option.name\"\n                                                       (radioChange)=\"handleDateRangeOptionClick(item, option)\"></zen-radio>\n                                        </div>\n                                    </ng-container>\n                                    <div class=\"action-item-radio ds-item\"\n                                         [ngClass]=\"{'active': selectedDateRangeOptions[item.key] === 'Custom'}\">\n                                        <zen-radio [value]=\"'Custom'\"\n                                                   [label]=\"'Custom' | translate\"\n                                                   [name]=\"item.key\"\n                                                   [selected]=\"selectedDateRangeOptions[item.key] === 'Custom'\"\n                                                   (radioChange)=\"handleCustomDateRangeClick(item)\"></zen-radio>\n                                    </div>\n                                    <ng-container *ngIf=\"selectedDateRangeOptions[item.key] === 'Custom'\">\n                                        <div class=\"ds-item filter-row\">\n                                            <div class=\"lbl\">{{'From' | translate}}:</div>\n                                            <zen-datepicker class=\"width-full\"\n                                                            [(date)]=\"item.dateRange.start\"\n                                                            [showTime]=\"item.showTime\"\n                                                            [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                            [parentContainer]=\"mainComponent\">\n                                            </zen-datepicker>\n                                        </div>\n                                        <div class=\"ds-item filter-row\">\n                                            <div class=\"lbl\">{{'To' | translate}}:</div>\n                                            <zen-datepicker class=\"width-full\"\n                                                            [(date)]=\"item.dateRange.end\"\n                                                            [showTime]=\"item.showTime\"\n                                                            [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                            (dateChange)=\"handleEndDateChange(item)\"\n                                                            [parentContainer]=\"mainComponent\">\n                                            </zen-datepicker>\n                                        </div>\n                                    </ng-container>\n                                </ng-container>\n\n                                <!--  Default date range view  -->\n                                <ng-container *ngIf=\"!item.dateRangeOptions?.length\">\n                                    <div class=\"ds-item filter-row\">\n                                        <div class=\"lbl\">{{'From' | translate}}:</div>\n                                        <zen-datepicker class=\"width-full\"\n                                                        [(date)]=\"item.dateRange.start\"\n                                                        [showTime]=\"item.showTime\"\n                                                        [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                        [parentContainer]=\"mainComponent\">\n                                        </zen-datepicker>\n                                    </div>\n                                    <div class=\"ds-item filter-row\">\n                                        <div class=\"lbl\">{{'To' | translate}}:</div>\n                                        <zen-datepicker class=\"width-full\"\n                                                        [(date)]=\"item.dateRange.end\"\n                                                        [showTime]=\"item.showTime\"\n                                                        [yPosition]=\"item.config?.yPosition ?? datepickerPosition.AUTO\"\n                                                        (dateChange)=\"handleEndDateChange(item)\"\n                                                        [parentContainer]=\"mainComponent\">\n                                        </zen-datepicker>\n                                    </div>\n                                </ng-container>\n                            </div>\n\n                            <!-- Date picker -->\n                            <div *ngSwitchCase=\"'date'\">\n                                <div class=\"ds-item filter-row\">\n                                    <div class=\"lbl\">{{'Date' | translate}}:</div>\n                                    <zen-datepicker class=\"width-full\"\n                                                    [(date)]=\"item.date\"\n                                                    [showTime]=\"item.showTime\"\n                                                    [parentContainer]=\"mainComponent\">\n                                    </zen-datepicker>\n                                </div>\n                            </div>\n\n                            <!-- Number range -->\n                            <div *ngSwitchCase=\"'numberRange'\"\n                                 class=\"filter-row number-range-row\">\n                                <div>\n                                    <div class=\"lbl\">{{'Min' | translate}}:</div>\n                                    <input class=\"material-input\"\n                                           [(ngModel)]=\"item.numberRange.from\"\n                                           type=\"number\" />\n                                </div>\n                                <div>\n                                    <div class=\"lbl\">{{'Max' | translate}}:</div>\n                                    <input class=\"material-input\"\n                                           [(ngModel)]=\"item.numberRange.to\"\n                                           type=\"number\" />\n                                </div>\n                            </div>\n\n                            <!-- Radio -->\n                            <div *ngSwitchCase=\"'radio'\">\n                                <div *ngFor=\"let option of item.radioOptions\"\n                                     class=\"action-item-radio ds-item\"\n                                     [ngClass]=\"{'active': option.selected}\">\n                                    <zen-radio [value]=\"option.id\"\n                                               [label]=\"option.name | translate\"\n                                               [name]=\"item.key\"\n                                               [imageUrl]=\"option.imageUrl\"\n                                               [selected]=\"option.selected\"\n                                               (radioChange)=\"radioChanged($event, item)\"\n                                               [disabled]=\"option.disabled\"></zen-radio>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n\n                </div>\n            </div>\n            <span *ngIf=\"showNoFilterResult\"\n                  class=\"no-item\">{{'No Results Found' | translate}}..</span>\n        </div>\n\n        <div class=\"action-menu-footer\">\n            <button (click)=\"reset()\"\n                    class=\"button-stroked full-width\">\n                {{'Reset' | translate}}\n            </button>\n            <button (click)=\"apply()\"\n                    class=\"button-flat full-width\">\n                {{'Apply' | translate}}\n            </button>\n        </div>\n\n    </div>\n</div>\n"]}
@@ -54,7 +54,7 @@ export class ZenduPaginationBarComponent {
54
54
  }
55
55
  }
56
56
  ZenduPaginationBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduPaginationBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
57
- ZenduPaginationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduPaginationBarComponent, selector: "zen-pagination-bar", inputs: { page: "page", perPage: "perPage", count: "count" }, outputs: { pageChange: "pageChange", perPageChange: "perPageChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"], dependencies: [{ kind: "component", type: i1.ZenduSelectComponent, selector: "zen-select", inputs: ["selectModel", "options", "placeholder", "displayProp", "idProp", "hasSearch", "returnOption", "isMultiselect", "disabled", "customIcon", "customIconColor", "isTruncate", "enableAddNewOption", "newOptionText", "enableRemoveOption", "removeOptionText"], outputs: ["selectModelChange", "addNewOption", "removeOption"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
57
+ ZenduPaginationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduPaginationBarComponent, selector: "zen-pagination-bar", inputs: { page: "page", perPage: "perPage", count: "count" }, outputs: { pageChange: "pageChange", perPageChange: "perPageChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"], dependencies: [{ kind: "component", type: i1.ZenduSelectComponent, selector: "zen-select", inputs: ["selectModel", "options", "placeholder", "displayProp", "idProp", "hasSearch", "returnOption", "isMultiselect", "disabled", "customIcon", "customIconColor", "isTruncate", "enableAddNewOption", "newOptionText", "enableRemoveOption", "removeOptionText", "isLazyLoading", "lazyLoader"], outputs: ["selectModelChange", "addNewOption", "removeOption"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
58
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduPaginationBarComponent, decorators: [{
59
59
  type: Component,
60
60
  args: [{ selector: 'zen-pagination-bar', template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"] }]