ng-zenduit 1.0.44 → 1.0.46

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.
@@ -82,7 +82,7 @@ export class ZenduSelectComponent {
82
82
  return;
83
83
  }
84
84
  // hide the menu for outside click
85
- this.hideDropDown();
85
+ this.hideDropDown(true);
86
86
  }
87
87
  scroll() {
88
88
  this.updatePlacement();
@@ -122,7 +122,7 @@ export class ZenduSelectComponent {
122
122
  singleSelect(value) {
123
123
  this.selectModel = value;
124
124
  // Hide dropdown if single select
125
- this.hideDropDown();
125
+ this.hideDropDown(true);
126
126
  }
127
127
  toggleExpand() {
128
128
  this.isExpanded = !this.isExpanded;
@@ -286,9 +286,12 @@ export class ZenduSelectComponent {
286
286
  }
287
287
  }, object);
288
288
  }
289
- async hideDropDown() {
289
+ async hideDropDown(userAction = false) {
290
+ // Only emit closed event if it was open AND triggered by user action
291
+ if (userAction && this.isExpanded) {
292
+ this.closed.emit(this.selectModel);
293
+ }
290
294
  this.isExpanded = false;
291
- this.closed.emit(this.selectModel);
292
295
  }
293
296
  emitChange() {
294
297
  // notify with timeout
@@ -330,11 +333,11 @@ export class ZenduSelectComponent {
330
333
  }
331
334
  handleAddNewOption() {
332
335
  this.addNewOption.emit({ value: this.searchText });
333
- this.hideDropDown();
336
+ this.hideDropDown(true);
334
337
  }
335
338
  handleRemoveOption() {
336
339
  this.removeOption.emit({ removed: true });
337
- this.hideDropDown();
340
+ this.hideDropDown(true);
338
341
  }
339
342
  async loadMore(showSelectedOnTop) {
340
343
  try {
@@ -436,4 +439,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
436
439
  type: HostListener,
437
440
  args: ['window:scroll', []]
438
441
  }] } });
439
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-select.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/select/zendu-select.component.ts","../../../../../projects/ng-zenduit/src/lib/select/zendu-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, ContentChild } from '@angular/core';\n\nimport { ZenduSelectOptionDirective } from './templates/zendu-select-option.directive';\nimport { ZenduSelectValueDirective } from './templates/zendu-select-value.directive';\nimport { ZenduSelectButtonDirective } from './templates/zendu-select-button.directive';\nimport { DataSource } from '../filter/filtersConfig';\n\n@Component({\n    selector: 'zen-select',\n    templateUrl: './zendu-select.component.html',\n    styleUrls: ['./zendu-select.component.scss']\n})\nexport class ZenduSelectComponent implements OnChanges {\n    /**\n     * 2-Way component property for selected items.\n     * Don't initialize property on constructor to prevent change source parameter\n     */\n    @Input() selectModel: any | any[];\n\n    /**\n     * callback to emit changes for parent component\n     */\n    @Output() selectModelChange = new EventEmitter<any>();\n\n    /**\n     * List of options for select\n     */\n    @Input() options: any[] = [];\n\n    /**\n     * Property to set custom placeholder value\n     */\n    @Input() placeholder = 'Select Items';\n\n    /**\n     * This is a key value to get display name from option object\n     */\n    @Input() displayProp: string;\n\n    /**\n     * This is a key value to get id from option object\n     */\n    @Input() idProp: string;\n\n    /**\n     * Component property to enable search\n     */\n    @Input() hasSearch: boolean;\n\n    /**\n     * Component property to return whole option object\n     * By default only id value is returned\n     */\n    @Input() returnOption: boolean;\n\n    /**\n     * Component property to enable multiselect\n     */\n    @Input() isMultiselect: boolean;\n\n    /**\n     * Component property to disable component\n     */\n    @Input() disabled = false;\n\n    /**\n     * Show the custom icon for toggle\n     */\n    @Input() customIcon = \"\";\n\n    /**\n     * Color for custom icon\n     */\n    @Input() customIconColor = \"\";\n\n    /**\n     * Truncate text with \"...\" at the end\n     */\n    @Input() isTruncate: boolean = false;\n\n    /**\n     * show Add New Option at first place\n     */\n    @Input() enableAddNewOption: boolean = false;\n\n    /**\n     * display custom text for Add New Option\n     */\n    @Input() newOptionText: string;\n\n    /**\n     * Emit event when Add New Option is clicked\n     */\n    @Output() addNewOption: EventEmitter<any> = new EventEmitter<any>();\n\n    /**\n       * show remove Option at first place\n       */\n    @Input() enableRemoveOption: boolean = false;\n\n    /**\n     * display custom text for remove Option\n     */\n    @Input() removeOptionText: string;\n\n    /**\n     * Enable lazy loading for options\n     */\n    @Input() isLazyLoading = false;\n\n    /**\n     * Lazy loader function to fetch options\n     */\n    @Input() lazyLoader?: (search: { text?: string, ids?: string[] }, offset: number, limit: number) => Promise<DataSource[]>;\n\n    /**\n     * Emit event when remove Option is clicked\n     */\n    @Output() removeOption: EventEmitter<any> = new EventEmitter<any>();\n\n    /**\n     * Emit event when select is closed, sending the selected data\n     */\n    @Output() closed: EventEmitter<any> = new EventEmitter<any>();\n\n    /**\n     * Filtered items visible on dropdown\n     */\n    public filteredOptions: any[];\n\n    /**\n     * Is dropdown expanded\n     */\n    public isExpanded = false;\n\n    public searchText = '';\n\n    public labelText = '';\n\n    public isTopMenuDirection = false;\n\n    public option: any\n\n    public canLoadMore = false;\n\n    public isLoadingNow = false;\n\n    public constructor(\n        private _element: ElementRef) {\n    }\n\n    /**\n     * Select Option Template for custom HTML\n     */\n    @ContentChild(ZenduSelectOptionDirective) optionTemplate: ZenduSelectOptionDirective;\n\n    /**\n     * Select Value Template for custom HTML\n     */\n    @ContentChild(ZenduSelectValueDirective) valueTemplate: ZenduSelectValueDirective;\n\n    /**\n     * Select Option Template for custom HTML\n     */\n    @ContentChild(ZenduSelectButtonDirective) buttonTemplate: ZenduSelectButtonDirective;\n\n\n    @HostListener('window:mousedown', ['$event'])\n    outsideHandling(event) {\n        if (!document.body.contains(event.target)) {\n            // element not in the DOM\n            return;\n        }\n        if (this._element.nativeElement.contains(event.target)) {\n            return;\n        }\n        // hide the menu for outside click\n        this.hideDropDown();\n    }\n\n    @HostListener('window:scroll', [])\n    scroll() {\n        this.updatePlacement();\n    }\n\n    public ngOnChanges(changeObj: any): void {\n        this.filterOptions();\n        this.updateLabel();\n\n        if (changeObj[\"selectModel\"]) {\n            if (this.isLazyLoading && this.selectModel?.length) {\n                if (!this.filteredOptions?.length && !this.isExpanded) {\n                    // preload data to show the labels\n                    this.loadMore(true);\n                }\n            }\n        }\n    }\n\n    public isModelEmpty(): boolean {\n        if (this.isMultiselect) {\n            return !this.selectModel || !this.selectModel.length;\n        } else {\n            return typeof this.selectModel === 'undefined' || this.selectModel === null;\n        }\n    }\n\n    public handleOptionClick(option: string | object) {\n        this.option = option;\n        const optionValue = this.returnOption ? option : this.getId(option);\n\n        if (this.isMultiselect) {\n            this.toggleOption(optionValue);\n        } else {\n            this.singleSelect(optionValue);\n        }\n\n        this.emitChange();\n    }\n\n    // Logic for single select\n    private singleSelect(value: string | object) {\n        this.selectModel = value;\n\n        //  Hide dropdown if single select\n        this.hideDropDown();\n    }\n\n    public toggleExpand() {\n        this.isExpanded = !this.isExpanded;\n        this.searchText = \"\";\n        this.filterOptions();\n        this.updatePlacement();\n\n        if (this.isExpanded && this.isLazyLoading) {\n            this.loadMore(true);\n        }\n    }\n\n    // Logic for multiselect\n    private toggleOption(value: string | object): void {\n        if (!Array.isArray(this.selectModel)) {\n            this.selectModel = [];\n        }\n\n        const index = this.getElementIndex(value);\n\n        if (index < 0) {\n            this.selectModel.push(value);\n            this.toggleChildren(true);\n        } else {\n            this.selectModel.splice(index, 1);\n            this.toggleChildren(false);\n        }\n\n        this.updateLabel();\n    }\n\n    private toggleChildren(checked: boolean): void {\n        if (!this.option || !this.option.Childrens?.length) {\n            return;\n        }\n        this.option.Childrens.forEach((child: string) => {\n            this.option = this.options.find(el => this.getId(el) === child);\n            const childIndex = this.selectModel.findIndex(el => this.getId(el) === child);\n            if (this.option && checked && childIndex < 0) {\n                this.selectModel.push(child);\n            } else if (!checked && childIndex >= 0) {\n                this.selectModel.splice(childIndex, 1);\n            }\n            // Recursive call to handle nested children\n            this.toggleChildren(checked);\n        });\n    }\n\n    private getElementIndex(value: string | object): number {\n        if (typeof value === 'object') {\n            const valueId = this.getId(value);\n            return this.selectModel.findIndex(el => this.getId(el) === valueId);\n        } else {\n            return this.selectModel.indexOf(value);\n        }\n    }\n\n    public toggleAll(): void {\n        if (this.selectModel.length !== this.options.length) {\n            this.selectModel = this.options.map(el => this.returnOption ? el : this.getId(el));\n        } else {\n            this.selectModel = [];\n        }\n\n        this.emitChange();\n    }\n\n    public onSearchChange(): void {\n        this.filterOptions();\n\n        if (this.isLazyLoading) {\n            this.filteredOptions = [];\n            this.canLoadMore = true;\n            this.loadMore(false);\n        }\n    }\n\n    private filterOptions(): void {\n        const options = this.options.slice(0);\n\n        if (!this.searchText) {\n            this.filteredOptions = options;\n            return;\n        }\n\n        const regex = new RegExp(this.searchText, 'i');\n        this.filteredOptions = options.filter(option => regex.test(this.getName(option)));\n    }\n\n    public isSelected(option: string | object): boolean {\n        if (this.isModelEmpty()) {\n            return false;\n        }\n\n        const optionId = this.getId(option);\n\n        if (this.isMultiselect) {\n            return this.selectModel.findIndex(el => this.getId(el) === optionId) >= 0;\n        } else {\n            return this.getId(this.selectModel) === optionId;\n        }\n    }\n\n    public updateLabel() {\n        if (this.isModelEmpty()) {\n            return;\n        }\n\n        if (this.isMultiselect) {\n            const selectedCount = this.selectModel.length;\n\n            if (selectedCount === 1) {\n                this.labelText = this.getNameFromValue(this.selectModel[0]);\n            } else {\n                this.labelText = `${selectedCount} Selected`;\n            }\n        } else {\n            this.labelText = this.getNameFromValue(this.selectModel);\n        }\n    }\n\n    public getNameFromValue(val: string | object): string {\n        if (this.returnOption) {\n            return this.getName(val);\n        } else {\n            if (this.isLazyLoading) {\n                const opt = this.filteredOptions?.find(i => i.id == val);\n                return this.getName(opt);\n            }\n            else {\n                if (!this.options || !this.options.length) {\n                    return '';\n                }\n                let option = this.options.find(el => this.getId(el) === val)\n                return this.getName(option ?? val);\n            }\n        }\n    }\n\n    public getName(option: string | object): string {\n        if (typeof option === 'object') {\n            if (this.displayProp) {\n                return this.GetRecursiveProperty(option, this.displayProp);\n            } else {\n                console.error('App-Select: when using objects as model, a displayProp value is mandatory.');\n                return \"\";\n            }\n        } else {\n            return option;\n        }\n    }\n\n    private getId(option: string | object): string {\n        if (typeof option === 'object') {\n            if (this.idProp) {\n                return this.GetRecursiveProperty(option, this.idProp);\n            } else {\n                console.error('App-Select: when using objects as model, a idProp value is mandatory.');\n                return \"\";\n            }\n        } else {\n            return option;\n        }\n    }\n\n    private GetRecursiveProperty(object: any, path: string): string {\n        return path.split('.').reduce((obj, x) => {\n            if (obj) {\n                return obj[x];\n            } else {\n                return null;\n            }\n        }, object);\n    }\n\n    public async hideDropDown(): Promise<void> {\n        this.isExpanded = false;\n        this.closed.emit(this.selectModel);\n    }\n\n    private emitChange() {\n        // notify with timeout\n        // allow output property \"enabled\" applied by parent first and then emit the onChange\n        setTimeout(() => {\n            this.selectModelChange.emit(this.selectModel);\n        }, 1);\n    }\n\n    private updatePlacement() {\n        // update menu position base on scroll\n        this.isTopMenuDirection = this.getMenuDirection() === \"top\";\n    }\n\n    private getMenuDirection(): \"bottom\" | \"top\" {\n\n        const element = this._element.nativeElement;\n        const top = element.getBoundingClientRect().top;\n\n        const height = window.innerHeight;\n\n        if (top > (height / 2)) {\n            return \"top\";\n        }\n        else {\n            return \"bottom\"\n        }\n    }\n\n    private getMaxMenuHeight() {\n        const containerElement = this.getContainerElement();\n        if (!containerElement || !containerElement.clientHeight) {\n            return \"190px\";\n        }\n\n        const parentHeight = containerElement.clientHeight;\n        let height = Math.round((parentHeight / 2) - 25);\n        height = Math.min(216, height);\n        height = Math.max(96, height);\n        return `${height}px`;\n    }\n\n    private getContainerElement() {\n        const component = this._element.nativeElement as HTMLElement;\n        const container = component.getElementsByClassName(\"app-select\").item(0) as HTMLElement;\n        return container.offsetParent;\n    }\n\n    public handleAddNewOption() {\n        this.addNewOption.emit({ value: this.searchText })\n        this.hideDropDown()\n    }\n\n    public handleRemoveOption() {\n        this.removeOption.emit({ removed: true })\n        this.hideDropDown()\n    }\n\n\n\n    public async loadMore(showSelectedOnTop: boolean) {\n        try {\n            this.isLoadingNow = true;\n            if (!this.lazyLoader) {\n                throw `loader is not available`\n            }\n            if (!this.filteredOptions) {\n                this.filteredOptions = [];\n            }\n\n            // load first 10 records for the the first time\n            const limit = (this.filteredOptions.length == 0) ? 10 : 100;\n            let newItems = await this.lazyLoader({ text: this.searchText || \"\" }, this.filteredOptions.length, limit);\n\n            this.canLoadMore = (newItems.length == limit);\n\n            // the selectModel contains the selected items ids\n            const checkedIds = this.selectModel as string[];\n\n            if (showSelectedOnTop && checkedIds?.length) {\n\n                // remove the checked items first\n                this.filteredOptions = this.filteredOptions.filter(i => !checkedIds.includes(i.id));\n                newItems = newItems.filter(i => !checkedIds.includes(i.id as string));\n\n                // add all checked items to the top                \n                const checkedItems = await this.lazyLoader({ ids: checkedIds }, 0, 100);\n                this.filteredOptions = checkedItems.concat(this.filteredOptions);\n\n                this.updateLabel();\n            }\n\n\n            // the filteredDataSource contains the items that is visilible to user at the current moment\n            this.filteredOptions = this.filteredOptions.concat(newItems);\n\n        }\n        catch (err) {\n            console.error(err);\n        }\n        finally {\n            this.isLoadingNow = false;\n        }\n    }\n}\n","<div class=\"app-select\">\n    <button class=\"app-select-toggle\"\n            [disabled]=\"disabled\"\n            (click)=\"toggleExpand()\"\n            [ngClass]=\"{'active': isExpanded}\">\n        <div class=\"app-select-label\">\n            <div class=\"placeholder\"\n                 *ngIf=\"isModelEmpty()\">\n                <span>{{placeholder | translate}}</span>\n            </div>\n            <div class=\"selected-item\"\n                 *ngIf=\"!isMultiselect && !isModelEmpty()\">\n                <ng-template *ngIf=\"valueTemplate && selectModel[0]; else tplValueText\"\n                             [ngTemplateOutlet]=\"valueTemplate.template\"\n                             [ngTemplateOutletContext]=\"{ selectModel: selectModel, labelText: labelText }\"></ng-template>\n                <ng-template #tplValueText>\n                    <span>{{ labelText | translate }}</span>\n                </ng-template>\n            </div>\n            <div class=\"selected-item\"\n                 *ngIf=\"isMultiselect && !isModelEmpty()\">\n                <span>{{ labelText | translate  }}</span>\n            </div>\n        </div>\n        <i *ngIf=\"!customIcon\"\n           class=\"material-icons app-select-icon\">expand_more</i>\n        <i *ngIf=\"customIcon\"\n           class=\"material-icons-outlined custom-icon\"\n           [style.color]=\"customIconColor\">{{customIcon}}</i>\n    </button>\n\n    <div class=\"action-menu-container\">\n        <div class=\"action-menu app-select-dropdown-wrapper\"\n             [ngClass]=\"{ 'show-top': isTopMenuDirection }\">\n            <div class=\"app-select-dropdown\"\n                 *ngIf=\"isExpanded\">\n                <div class=\"action-menu-header\"\n                     *ngIf=\"hasSearch\">\n                    <!--Search options-->\n                    <div class=\"search-wrapper\">\n                        <zen-search-box [(text)]=\"searchText\"\n                                        (textChange)=\"onSearchChange()\"></zen-search-box>\n                    </div>\n                </div>\n                <ng-template *ngIf=\"buttonTemplate\"\n                             [ngTemplateOutlet]=\"buttonTemplate.template\">\n                </ng-template>\n                <div class=\"action-menu-body\">\n                    <!--No options found-->\n                    <div class=\"no-options-found\"\n                         *ngIf=\"!filteredOptions.length && !isLoadingNow\">\n                        {{ 'No matching options found' | translate }}\n                    </div>\n\n                    <!--Select All Option-->\n                    <div class=\"action-item-checkbox select-all\"\n                         *ngIf=\"isMultiselect && !searchText && !isLazyLoading\"\n                         (click)=\"toggleAll()\">\n                        <zen-checkbox [checked]=\"selectModel.length === options.length\"\n                                      [indeterminate]=\"selectModel.length !== options.length && selectModel.length\"\n                                      [disableValueChange]=\"true\"\n                                      [label]=\"'Select All' | translate\"></zen-checkbox>\n                    </div>\n\n                    <!--Single select Options-->\n                    <ng-container *ngIf=\"!isMultiselect\">\n                        <a class=\"action-item\"\n                           *ngIf=\"enableAddNewOption\"\n                           (click)=\"handleAddNewOption()\">\n                            <span *ngIf=\"newOptionText\">\n                                {{ newOptionText | translate }}\n                            </span>\n                            <span *ngIf=\"!newOptionText\">\n                                {{'Add New' | translate}}\n                            </span>\n                        </a>\n\n                        <a class=\"action-item remove-item\"\n                           *ngIf=\"enableRemoveOption\"\n                           (click)=\"handleRemoveOption()\">\n                            <span *ngIf=\"removeOptionText\">\n                                {{ removeOptionText | translate }}\n                            </span>\n                            <span *ngIf=\"!removeOptionText\">\n                                {{'Remove Selected' | translate}}\n                            </span>\n                        </a>\n\n                        <a class=\"action-item\"\n                           *ngFor=\"let option of filteredOptions\"\n                           (click)=\"handleOptionClick(option)\"\n                           [ngClass]=\"{ 'active': isSelected(option) }\">\n                            <span *ngIf=\"!isMultiselect\"\n                                  [class.action-item-truncate]=\"isTruncate\">\n                                <ng-template *ngIf=\"optionTemplate; else tplOptionText\"\n                                             [ngTemplateOutlet]=\"optionTemplate.template\"\n                                             [ngTemplateOutletContext]=\"{ option: option }\">\n                                </ng-template>\n                                <ng-template #tplOptionText>\n                                    {{ getName(option) | translate }}\n                                </ng-template>\n                            </span>\n                        </a>\n                    </ng-container>\n\n                    <!--Multiselect Options-->\n                    <ng-container *ngIf=\"isMultiselect\">\n                        <div class=\"action-item-checkbox\"\n                             *ngFor=\"let option of filteredOptions\"\n                             (click)=\"handleOptionClick(option)\">\n                            <zen-checkbox *ngIf=\"isMultiselect\"\n                                          [checked]=\"isSelected(option)\"\n                                          [label]=\"getName(option)\"\n                                          [disableValueChange]=\"true\"></zen-checkbox>\n                        </div>\n\n                        <ng-container *ngIf=\"isLazyLoading\">\n                            <div *ngIf=\"canLoadMore && !isLoadingNow\"\n                                 class=\"action-item\">\n                                <button (click)=\"loadMore(false)\"\n                                        class=\"button-stroked full-width\">\n                                    {{'Load More' | translate}}\n                                </button>\n                            </div>\n                            <div *ngIf=\"isLoadingNow\"\n                                 class=\"loader-more-spinner\">\n                                <zen-spinner size=\"small\"></zen-spinner>\n                            </div>\n                        </ng-container>\n\n                    </ng-container>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
442
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-select.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/select/zendu-select.component.ts","../../../../../projects/ng-zenduit/src/lib/select/zendu-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, ContentChild } from '@angular/core';\n\nimport { ZenduSelectOptionDirective } from './templates/zendu-select-option.directive';\nimport { ZenduSelectValueDirective } from './templates/zendu-select-value.directive';\nimport { ZenduSelectButtonDirective } from './templates/zendu-select-button.directive';\nimport { DataSource } from '../filter/filtersConfig';\n\n@Component({\n    selector: 'zen-select',\n    templateUrl: './zendu-select.component.html',\n    styleUrls: ['./zendu-select.component.scss']\n})\nexport class ZenduSelectComponent implements OnChanges {\n    /**\n     * 2-Way component property for selected items.\n     * Don't initialize property on constructor to prevent change source parameter\n     */\n    @Input() selectModel: any | any[];\n\n    /**\n     * callback to emit changes for parent component\n     */\n    @Output() selectModelChange = new EventEmitter<any>();\n\n    /**\n     * List of options for select\n     */\n    @Input() options: any[] = [];\n\n    /**\n     * Property to set custom placeholder value\n     */\n    @Input() placeholder = 'Select Items';\n\n    /**\n     * This is a key value to get display name from option object\n     */\n    @Input() displayProp: string;\n\n    /**\n     * This is a key value to get id from option object\n     */\n    @Input() idProp: string;\n\n    /**\n     * Component property to enable search\n     */\n    @Input() hasSearch: boolean;\n\n    /**\n     * Component property to return whole option object\n     * By default only id value is returned\n     */\n    @Input() returnOption: boolean;\n\n    /**\n     * Component property to enable multiselect\n     */\n    @Input() isMultiselect: boolean;\n\n    /**\n     * Component property to disable component\n     */\n    @Input() disabled = false;\n\n    /**\n     * Show the custom icon for toggle\n     */\n    @Input() customIcon = \"\";\n\n    /**\n     * Color for custom icon\n     */\n    @Input() customIconColor = \"\";\n\n    /**\n     * Truncate text with \"...\" at the end\n     */\n    @Input() isTruncate: boolean = false;\n\n    /**\n     * show Add New Option at first place\n     */\n    @Input() enableAddNewOption: boolean = false;\n\n    /**\n     * display custom text for Add New Option\n     */\n    @Input() newOptionText: string;\n\n    /**\n     * Emit event when Add New Option is clicked\n     */\n    @Output() addNewOption: EventEmitter<any> = new EventEmitter<any>();\n\n    /**\n       * show remove Option at first place\n       */\n    @Input() enableRemoveOption: boolean = false;\n\n    /**\n     * display custom text for remove Option\n     */\n    @Input() removeOptionText: string;\n\n    /**\n     * Enable lazy loading for options\n     */\n    @Input() isLazyLoading = false;\n\n    /**\n     * Lazy loader function to fetch options\n     */\n    @Input() lazyLoader?: (search: { text?: string, ids?: string[] }, offset: number, limit: number) => Promise<DataSource[]>;\n\n    /**\n     * Emit event when remove Option is clicked\n     */\n    @Output() removeOption: EventEmitter<any> = new EventEmitter<any>();\n\n    /**\n     * Emit event when select is closed, sending the selected data\n     */\n    @Output() closed: EventEmitter<any> = new EventEmitter<any>();\n\n    /**\n     * Filtered items visible on dropdown\n     */\n    public filteredOptions: any[];\n\n    /**\n     * Is dropdown expanded\n     */\n    public isExpanded = false;\n\n    public searchText = '';\n\n    public labelText = '';\n\n    public isTopMenuDirection = false;\n\n    public option: any\n\n    public canLoadMore = false;\n\n    public isLoadingNow = false;\n\n    public constructor(\n        private _element: ElementRef) {\n    }\n\n    /**\n     * Select Option Template for custom HTML\n     */\n    @ContentChild(ZenduSelectOptionDirective) optionTemplate: ZenduSelectOptionDirective;\n\n    /**\n     * Select Value Template for custom HTML\n     */\n    @ContentChild(ZenduSelectValueDirective) valueTemplate: ZenduSelectValueDirective;\n\n    /**\n     * Select Option Template for custom HTML\n     */\n    @ContentChild(ZenduSelectButtonDirective) buttonTemplate: ZenduSelectButtonDirective;\n\n\n    @HostListener('window:mousedown', ['$event'])\n    outsideHandling(event) {\n        if (!document.body.contains(event.target)) {\n            // element not in the DOM\n            return;\n        }\n        if (this._element.nativeElement.contains(event.target)) {\n            return;\n        }\n        // hide the menu for outside click\n        this.hideDropDown(true);\n    }\n\n    @HostListener('window:scroll', [])\n    scroll() {\n        this.updatePlacement();\n    }\n\n    public ngOnChanges(changeObj: any): void {\n        this.filterOptions();\n        this.updateLabel();\n\n        if (changeObj[\"selectModel\"]) {\n            if (this.isLazyLoading && this.selectModel?.length) {\n                if (!this.filteredOptions?.length && !this.isExpanded) {\n                    // preload data to show the labels\n                    this.loadMore(true);\n                }\n            }\n        }\n    }\n\n    public isModelEmpty(): boolean {\n        if (this.isMultiselect) {\n            return !this.selectModel || !this.selectModel.length;\n        } else {\n            return typeof this.selectModel === 'undefined' || this.selectModel === null;\n        }\n    }\n\n    public handleOptionClick(option: string | object) {\n        this.option = option;\n        const optionValue = this.returnOption ? option : this.getId(option);\n\n        if (this.isMultiselect) {\n            this.toggleOption(optionValue);\n        } else {\n            this.singleSelect(optionValue);\n        }\n\n        this.emitChange();\n    }\n\n    // Logic for single select\n    private singleSelect(value: string | object) {\n        this.selectModel = value;\n\n        //  Hide dropdown if single select\n        this.hideDropDown(true);\n    }\n\n    public toggleExpand() {\n        this.isExpanded = !this.isExpanded;\n        this.searchText = \"\";\n        this.filterOptions();\n        this.updatePlacement();\n\n        if (this.isExpanded && this.isLazyLoading) {\n            this.loadMore(true);\n        }\n    }\n\n    // Logic for multiselect\n    private toggleOption(value: string | object): void {\n        if (!Array.isArray(this.selectModel)) {\n            this.selectModel = [];\n        }\n\n        const index = this.getElementIndex(value);\n\n        if (index < 0) {\n            this.selectModel.push(value);\n            this.toggleChildren(true);\n        } else {\n            this.selectModel.splice(index, 1);\n            this.toggleChildren(false);\n        }\n\n        this.updateLabel();\n    }\n\n    private toggleChildren(checked: boolean): void {\n        if (!this.option || !this.option.Childrens?.length) {\n            return;\n        }\n        this.option.Childrens.forEach((child: string) => {\n            this.option = this.options.find(el => this.getId(el) === child);\n            const childIndex = this.selectModel.findIndex(el => this.getId(el) === child);\n            if (this.option && checked && childIndex < 0) {\n                this.selectModel.push(child);\n            } else if (!checked && childIndex >= 0) {\n                this.selectModel.splice(childIndex, 1);\n            }\n            // Recursive call to handle nested children\n            this.toggleChildren(checked);\n        });\n    }\n\n    private getElementIndex(value: string | object): number {\n        if (typeof value === 'object') {\n            const valueId = this.getId(value);\n            return this.selectModel.findIndex(el => this.getId(el) === valueId);\n        } else {\n            return this.selectModel.indexOf(value);\n        }\n    }\n\n    public toggleAll(): void {\n        if (this.selectModel.length !== this.options.length) {\n            this.selectModel = this.options.map(el => this.returnOption ? el : this.getId(el));\n        } else {\n            this.selectModel = [];\n        }\n\n        this.emitChange();\n    }\n\n    public onSearchChange(): void {\n        this.filterOptions();\n\n        if (this.isLazyLoading) {\n            this.filteredOptions = [];\n            this.canLoadMore = true;\n            this.loadMore(false);\n        }\n    }\n\n    private filterOptions(): void {\n        const options = this.options.slice(0);\n\n        if (!this.searchText) {\n            this.filteredOptions = options;\n            return;\n        }\n\n        const regex = new RegExp(this.searchText, 'i');\n        this.filteredOptions = options.filter(option => regex.test(this.getName(option)));\n    }\n\n    public isSelected(option: string | object): boolean {\n        if (this.isModelEmpty()) {\n            return false;\n        }\n\n        const optionId = this.getId(option);\n\n        if (this.isMultiselect) {\n            return this.selectModel.findIndex(el => this.getId(el) === optionId) >= 0;\n        } else {\n            return this.getId(this.selectModel) === optionId;\n        }\n    }\n\n    public updateLabel() {\n        if (this.isModelEmpty()) {\n            return;\n        }\n\n        if (this.isMultiselect) {\n            const selectedCount = this.selectModel.length;\n\n            if (selectedCount === 1) {\n                this.labelText = this.getNameFromValue(this.selectModel[0]);\n            } else {\n                this.labelText = `${selectedCount} Selected`;\n            }\n        } else {\n            this.labelText = this.getNameFromValue(this.selectModel);\n        }\n    }\n\n    public getNameFromValue(val: string | object): string {\n        if (this.returnOption) {\n            return this.getName(val);\n        } else {\n            if (this.isLazyLoading) {\n                const opt = this.filteredOptions?.find(i => i.id == val);\n                return this.getName(opt);\n            }\n            else {\n                if (!this.options || !this.options.length) {\n                    return '';\n                }\n                let option = this.options.find(el => this.getId(el) === val)\n                return this.getName(option ?? val);\n            }\n        }\n    }\n\n    public getName(option: string | object): string {\n        if (typeof option === 'object') {\n            if (this.displayProp) {\n                return this.GetRecursiveProperty(option, this.displayProp);\n            } else {\n                console.error('App-Select: when using objects as model, a displayProp value is mandatory.');\n                return \"\";\n            }\n        } else {\n            return option;\n        }\n    }\n\n    private getId(option: string | object): string {\n        if (typeof option === 'object') {\n            if (this.idProp) {\n                return this.GetRecursiveProperty(option, this.idProp);\n            } else {\n                console.error('App-Select: when using objects as model, a idProp value is mandatory.');\n                return \"\";\n            }\n        } else {\n            return option;\n        }\n    }\n\n    private GetRecursiveProperty(object: any, path: string): string {\n        return path.split('.').reduce((obj, x) => {\n            if (obj) {\n                return obj[x];\n            } else {\n                return null;\n            }\n        }, object);\n    }\n\n    public async hideDropDown(userAction: boolean = false): Promise<void> {\n        // Only emit closed event if it was open AND triggered by user action\n        if (userAction && this.isExpanded) {\n            this.closed.emit(this.selectModel);\n        }\n        \n        this.isExpanded = false;\n    }\n\n    private emitChange() {\n        // notify with timeout\n        // allow output property \"enabled\" applied by parent first and then emit the onChange\n        setTimeout(() => {\n            this.selectModelChange.emit(this.selectModel);\n        }, 1);\n    }\n\n    private updatePlacement() {\n        // update menu position base on scroll\n        this.isTopMenuDirection = this.getMenuDirection() === \"top\";\n    }\n\n    private getMenuDirection(): \"bottom\" | \"top\" {\n\n        const element = this._element.nativeElement;\n        const top = element.getBoundingClientRect().top;\n\n        const height = window.innerHeight;\n\n        if (top > (height / 2)) {\n            return \"top\";\n        }\n        else {\n            return \"bottom\"\n        }\n    }\n\n    private getMaxMenuHeight() {\n        const containerElement = this.getContainerElement();\n        if (!containerElement || !containerElement.clientHeight) {\n            return \"190px\";\n        }\n\n        const parentHeight = containerElement.clientHeight;\n        let height = Math.round((parentHeight / 2) - 25);\n        height = Math.min(216, height);\n        height = Math.max(96, height);\n        return `${height}px`;\n    }\n\n    private getContainerElement() {\n        const component = this._element.nativeElement as HTMLElement;\n        const container = component.getElementsByClassName(\"app-select\").item(0) as HTMLElement;\n        return container.offsetParent;\n    }\n\n    public handleAddNewOption() {\n        this.addNewOption.emit({ value: this.searchText })\n        this.hideDropDown(true)\n    }\n\n    public handleRemoveOption() {\n        this.removeOption.emit({ removed: true })\n        this.hideDropDown(true)\n    }\n\n\n\n    public async loadMore(showSelectedOnTop: boolean) {\n        try {\n            this.isLoadingNow = true;\n            if (!this.lazyLoader) {\n                throw `loader is not available`\n            }\n            if (!this.filteredOptions) {\n                this.filteredOptions = [];\n            }\n\n            // load first 10 records for the the first time\n            const limit = (this.filteredOptions.length == 0) ? 10 : 100;\n            let newItems = await this.lazyLoader({ text: this.searchText || \"\" }, this.filteredOptions.length, limit);\n\n            this.canLoadMore = (newItems.length == limit);\n\n            // the selectModel contains the selected items ids\n            const checkedIds = this.selectModel as string[];\n\n            if (showSelectedOnTop && checkedIds?.length) {\n\n                // remove the checked items first\n                this.filteredOptions = this.filteredOptions.filter(i => !checkedIds.includes(i.id));\n                newItems = newItems.filter(i => !checkedIds.includes(i.id as string));\n\n                // add all checked items to the top                \n                const checkedItems = await this.lazyLoader({ ids: checkedIds }, 0, 100);\n                this.filteredOptions = checkedItems.concat(this.filteredOptions);\n\n                this.updateLabel();\n            }\n\n\n            // the filteredDataSource contains the items that is visilible to user at the current moment\n            this.filteredOptions = this.filteredOptions.concat(newItems);\n\n        }\n        catch (err) {\n            console.error(err);\n        }\n        finally {\n            this.isLoadingNow = false;\n        }\n    }\n}\n","<div class=\"app-select\">\n    <button class=\"app-select-toggle\"\n            [disabled]=\"disabled\"\n            (click)=\"toggleExpand()\"\n            [ngClass]=\"{'active': isExpanded}\">\n        <div class=\"app-select-label\">\n            <div class=\"placeholder\"\n                 *ngIf=\"isModelEmpty()\">\n                <span>{{placeholder | translate}}</span>\n            </div>\n            <div class=\"selected-item\"\n                 *ngIf=\"!isMultiselect && !isModelEmpty()\">\n                <ng-template *ngIf=\"valueTemplate && selectModel[0]; else tplValueText\"\n                             [ngTemplateOutlet]=\"valueTemplate.template\"\n                             [ngTemplateOutletContext]=\"{ selectModel: selectModel, labelText: labelText }\"></ng-template>\n                <ng-template #tplValueText>\n                    <span>{{ labelText | translate }}</span>\n                </ng-template>\n            </div>\n            <div class=\"selected-item\"\n                 *ngIf=\"isMultiselect && !isModelEmpty()\">\n                <span>{{ labelText | translate  }}</span>\n            </div>\n        </div>\n        <i *ngIf=\"!customIcon\"\n           class=\"material-icons app-select-icon\">expand_more</i>\n        <i *ngIf=\"customIcon\"\n           class=\"material-icons-outlined custom-icon\"\n           [style.color]=\"customIconColor\">{{customIcon}}</i>\n    </button>\n\n    <div class=\"action-menu-container\">\n        <div class=\"action-menu app-select-dropdown-wrapper\"\n             [ngClass]=\"{ 'show-top': isTopMenuDirection }\">\n            <div class=\"app-select-dropdown\"\n                 *ngIf=\"isExpanded\">\n                <div class=\"action-menu-header\"\n                     *ngIf=\"hasSearch\">\n                    <!--Search options-->\n                    <div class=\"search-wrapper\">\n                        <zen-search-box [(text)]=\"searchText\"\n                                        (textChange)=\"onSearchChange()\"></zen-search-box>\n                    </div>\n                </div>\n                <ng-template *ngIf=\"buttonTemplate\"\n                             [ngTemplateOutlet]=\"buttonTemplate.template\">\n                </ng-template>\n                <div class=\"action-menu-body\">\n                    <!--No options found-->\n                    <div class=\"no-options-found\"\n                         *ngIf=\"!filteredOptions.length && !isLoadingNow\">\n                        {{ 'No matching options found' | translate }}\n                    </div>\n\n                    <!--Select All Option-->\n                    <div class=\"action-item-checkbox select-all\"\n                         *ngIf=\"isMultiselect && !searchText && !isLazyLoading\"\n                         (click)=\"toggleAll()\">\n                        <zen-checkbox [checked]=\"selectModel.length === options.length\"\n                                      [indeterminate]=\"selectModel.length !== options.length && selectModel.length\"\n                                      [disableValueChange]=\"true\"\n                                      [label]=\"'Select All' | translate\"></zen-checkbox>\n                    </div>\n\n                    <!--Single select Options-->\n                    <ng-container *ngIf=\"!isMultiselect\">\n                        <a class=\"action-item\"\n                           *ngIf=\"enableAddNewOption\"\n                           (click)=\"handleAddNewOption()\">\n                            <span *ngIf=\"newOptionText\">\n                                {{ newOptionText | translate }}\n                            </span>\n                            <span *ngIf=\"!newOptionText\">\n                                {{'Add New' | translate}}\n                            </span>\n                        </a>\n\n                        <a class=\"action-item remove-item\"\n                           *ngIf=\"enableRemoveOption\"\n                           (click)=\"handleRemoveOption()\">\n                            <span *ngIf=\"removeOptionText\">\n                                {{ removeOptionText | translate }}\n                            </span>\n                            <span *ngIf=\"!removeOptionText\">\n                                {{'Remove Selected' | translate}}\n                            </span>\n                        </a>\n\n                        <a class=\"action-item\"\n                           *ngFor=\"let option of filteredOptions\"\n                           (click)=\"handleOptionClick(option)\"\n                           [ngClass]=\"{ 'active': isSelected(option) }\">\n                            <span *ngIf=\"!isMultiselect\"\n                                  [class.action-item-truncate]=\"isTruncate\">\n                                <ng-template *ngIf=\"optionTemplate; else tplOptionText\"\n                                             [ngTemplateOutlet]=\"optionTemplate.template\"\n                                             [ngTemplateOutletContext]=\"{ option: option }\">\n                                </ng-template>\n                                <ng-template #tplOptionText>\n                                    {{ getName(option) | translate }}\n                                </ng-template>\n                            </span>\n                        </a>\n                    </ng-container>\n\n                    <!--Multiselect Options-->\n                    <ng-container *ngIf=\"isMultiselect\">\n                        <div class=\"action-item-checkbox\"\n                             *ngFor=\"let option of filteredOptions\"\n                             (click)=\"handleOptionClick(option)\">\n                            <zen-checkbox *ngIf=\"isMultiselect\"\n                                          [checked]=\"isSelected(option)\"\n                                          [label]=\"getName(option)\"\n                                          [disableValueChange]=\"true\"></zen-checkbox>\n                        </div>\n\n                        <ng-container *ngIf=\"isLazyLoading\">\n                            <div *ngIf=\"canLoadMore && !isLoadingNow\"\n                                 class=\"action-item\">\n                                <button (click)=\"loadMore(false)\"\n                                        class=\"button-stroked full-width\">\n                                    {{'Load More' | translate}}\n                                </button>\n                            </div>\n                            <div *ngIf=\"isLoadingNow\"\n                                 class=\"loader-more-spinner\">\n                                <zen-spinner size=\"small\"></zen-spinner>\n                            </div>\n                        </ng-container>\n\n                    </ng-container>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -2040,7 +2040,7 @@ class ZenduSelectComponent {
2040
2040
  return;
2041
2041
  }
2042
2042
  // hide the menu for outside click
2043
- this.hideDropDown();
2043
+ this.hideDropDown(true);
2044
2044
  }
2045
2045
  scroll() {
2046
2046
  this.updatePlacement();
@@ -2081,7 +2081,7 @@ class ZenduSelectComponent {
2081
2081
  singleSelect(value) {
2082
2082
  this.selectModel = value;
2083
2083
  // Hide dropdown if single select
2084
- this.hideDropDown();
2084
+ this.hideDropDown(true);
2085
2085
  }
2086
2086
  toggleExpand() {
2087
2087
  this.isExpanded = !this.isExpanded;
@@ -2247,10 +2247,13 @@ class ZenduSelectComponent {
2247
2247
  }
2248
2248
  }, object);
2249
2249
  }
2250
- hideDropDown() {
2250
+ hideDropDown(userAction = false) {
2251
2251
  return __awaiter(this, void 0, void 0, function* () {
2252
+ // Only emit closed event if it was open AND triggered by user action
2253
+ if (userAction && this.isExpanded) {
2254
+ this.closed.emit(this.selectModel);
2255
+ }
2252
2256
  this.isExpanded = false;
2253
- this.closed.emit(this.selectModel);
2254
2257
  });
2255
2258
  }
2256
2259
  emitChange() {
@@ -2293,11 +2296,11 @@ class ZenduSelectComponent {
2293
2296
  }
2294
2297
  handleAddNewOption() {
2295
2298
  this.addNewOption.emit({ value: this.searchText });
2296
- this.hideDropDown();
2299
+ this.hideDropDown(true);
2297
2300
  }
2298
2301
  handleRemoveOption() {
2299
2302
  this.removeOption.emit({ removed: true });
2300
- this.hideDropDown();
2303
+ this.hideDropDown(true);
2301
2304
  }
2302
2305
  loadMore(showSelectedOnTop) {
2303
2306
  return __awaiter(this, void 0, void 0, function* () {