ng-zenduit 1.0.21 → 1.0.22

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.
@@ -128,18 +128,18 @@ export class ZenduSelectComponent {
128
128
  this.updateLabel();
129
129
  }
130
130
  toggleChildren(checked) {
131
- if (!this.option.Childrens?.length) {
131
+ if (!this.option || !this.option.Childrens?.length) {
132
132
  return;
133
133
  }
134
134
  this.option.Childrens.forEach((child) => {
135
+ this.option = this.options.find(el => this.getId(el) === child);
135
136
  const childIndex = this.selectModel.findIndex(el => this.getId(el) === child);
136
- if (checked && childIndex < 0) {
137
+ if (this.option && checked && childIndex < 0) {
137
138
  this.selectModel.push(child);
138
139
  }
139
140
  else if (!checked && childIndex >= 0) {
140
141
  this.selectModel.splice(childIndex, 1);
141
142
  }
142
- this.option = this.options.find(el => this.getId(el) === child);
143
143
  // Recursive call to handle nested children
144
144
  this.toggleChildren(checked);
145
145
  });
@@ -361,4 +361,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
361
361
  type: HostListener,
362
362
  args: ['window:scroll', []]
363
363
  }] } });
364
- //# 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';\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   * Emit event when remove Option is clicked\n   */\n  @Output() removeOption: 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 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\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\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.Childrens?.length) {\n        return;\n    }\n    this.option.Childrens.forEach((child: string) => {\n      const childIndex = this.selectModel.findIndex(el => this.getId(el) === child);\n      if (checked && childIndex < 0) {\n        this.selectModel.push(child);\n      } else if (!checked && childIndex >= 0) {\n        this.selectModel.splice(childIndex, 1);\n      }\n      this.option = this.options.find(el => this.getId(el) === child);\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\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.options || !this.options.length) {\n        return '';\n      }\n\n      return this.getName(this.options.find(el => this.getId(el) === val));\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  }\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","<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\">\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\"\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                    </ng-container>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
364
+ //# 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';\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   * Emit event when remove Option is clicked\n   */\n  @Output() removeOption: 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 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\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\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\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.options || !this.options.length) {\n        return '';\n      }\n\n      return this.getName(this.options.find(el => this.getId(el) === val));\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  }\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","<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\">\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\"\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                    </ng-container>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -1821,18 +1821,18 @@ class ZenduSelectComponent {
1821
1821
  }
1822
1822
  toggleChildren(checked) {
1823
1823
  var _a;
1824
- if (!((_a = this.option.Childrens) === null || _a === void 0 ? void 0 : _a.length)) {
1824
+ if (!this.option || !((_a = this.option.Childrens) === null || _a === void 0 ? void 0 : _a.length)) {
1825
1825
  return;
1826
1826
  }
1827
1827
  this.option.Childrens.forEach((child) => {
1828
+ this.option = this.options.find(el => this.getId(el) === child);
1828
1829
  const childIndex = this.selectModel.findIndex(el => this.getId(el) === child);
1829
- if (checked && childIndex < 0) {
1830
+ if (this.option && checked && childIndex < 0) {
1830
1831
  this.selectModel.push(child);
1831
1832
  }
1832
1833
  else if (!checked && childIndex >= 0) {
1833
1834
  this.selectModel.splice(childIndex, 1);
1834
1835
  }
1835
- this.option = this.options.find(el => this.getId(el) === child);
1836
1836
  // Recursive call to handle nested children
1837
1837
  this.toggleChildren(checked);
1838
1838
  });