ngx-histaff-alpha 0.7.0 → 0.7.2

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.
@@ -51,9 +51,14 @@ export class CoreDropdownComponent extends CoreFormControlBaseComponent {
51
51
  this.subscriptions.push(this.options$.subscribe((x) => {
52
52
  this.options = x;
53
53
  this.localOptions = x;
54
+ /*
55
+ // Không cần set lại text because basically it has been set by getById
54
56
  if (!!this.value) {
55
- this.text = this.options.filter(m => m.value === this.value)[0]?.text;
57
+ if (!this.text) {
58
+ this.text = this.options.filter(m => m.value === this.value)[0]?.text
59
+ }
56
60
  }
61
+ */
57
62
  }));
58
63
  this.subscriptions.push(this.getByIdObject$?.subscribe((x) => {
59
64
  if (!!x) {
@@ -179,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
179
184
  type: ViewChild,
180
185
  args: ['container']
181
186
  }] } });
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Injector, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild, ViewEncapsulation, isDevMode, } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, Subscription, filter } from 'rxjs';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { ICoreDropdownOption } from '../../../interfaces/ICoreDropdownOption';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreScrollComponent } from '../../core-scroll/core-scroll/core-scroll.component';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\n\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'core-dropdown',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreScrollComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './core-dropdown.component.html',\r\n  styleUrls: ['./core-dropdown.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreDropdownComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreDropdownComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\r\n  ngControl!: NgControl;\r\n\r\n  @Input() getByIdObject$!: BehaviorSubject<any>;\r\n  @Input() paramMode!: boolean;\r\n  @Input() shownFrom!: string; // take this field from GetById response innerBody to bind to the text\r\n  @Input() options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n  @Input() height!: string;\r\n  @Input() placeholder: string = 'UI_COMMON_PLACE_HOLDER_SEARCH_HERE';\r\n  @Input() loading!: boolean;\r\n  @Input() warningDisable!: boolean;\r\n  @Input() itemHeight!: number;\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  listenerFn!: () => void;\r\n\r\n  options!: ICoreDropdownOption[];\r\n\r\n  localOptions!: ICoreDropdownOption[];\r\n  override value!: string | number | null;\r\n\r\n  lang!: string;\r\n  placeholderText!: string;\r\n  text!: string;\r\n  searchText!: string;\r\n  searchHeight: number = 38;\r\n  expandState!: boolean;\r\n\r\n  subscriptions: Subscription[] = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private domService: DomService,\r\n    private alertService: AlertService,\r\n    private injector: Injector,\r\n    private mls: MultiLanguageService,\r\n  ) {\r\n    super();\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!!!this.itemHeight) this.itemHeight = 40;\r\n\r\n    this.ngControl = this.injector.get(NgControl);\r\n\r\n    /* START: CHECK INPUT ERROR */\r\n    if (!!!this.options$ && isDevMode() && !!!this.warningDisable) {\r\n      this.alertService.error(\r\n        `\r\n        CoreDropdownComponent required this input: options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n        Also, it needs to receive a new value that usually comes from and API GetAll() action\r\n        `,\r\n        noneAutoClosedAlertOptions,\r\n      );\r\n    }\r\n\r\n    if (!!!this.paramMode) {\r\n      //getByIdObject$\r\n      if (!!!this.getByIdObject$ && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n                getByIdObject$: BehaviorSubject&lt;any&gt; (for '${this.ngControl.name}')`,\r\n        );\r\n      }\r\n\r\n      if (!!!this.shownFrom && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n              shownFrom: string; (for '${this.ngControl.name}')`,\r\n          noneAutoClosedAlertOptions,\r\n        );\r\n      }\r\n    }\r\n\r\n    /* END: CHECK INPUT ERROR */\r\n\r\n    this.subscriptions.push(\r\n      this.options$.subscribe((x) => {\r\n        this.options = x;\r\n        this.localOptions = x;\r\n        if (!!this.value) {\r\n          this.text = this.options.filter(m => m.value === this.value)[0]?.text\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.getByIdObject$?.subscribe((x) => {\r\n        if (!!x) {\r\n          this.text = x[this.shownFrom];\r\n        } else {\r\n          this.text = '';\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => {\r\n        this.lang = x;\r\n        this.placeholderText = this.mls.trans(this.placeholder, x)\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    /**\r\n     * This events get called by all clicks on the page\r\n     */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n       * handle click outside\r\n       */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.expandState = false;\r\n        this.searchText = '';\r\n        this.localOptions = this.options$.value;\r\n      }\r\n    });\r\n\r\n    const maxZIndex = this.domService.getMaxZIndex();\r\n    this.container.nativeElement.style.setProperty('--max-z-index', maxZIndex + 1);\r\n    this.container.nativeElement.style.setProperty('--search-height', this.searchHeight + 'px');\r\n    this.container.nativeElement.style.setProperty('--item-height', this.itemHeight + 'px');\r\n    if (!!this.height) this.container.nativeElement.style.setProperty('--height', this.height);\r\n  }\r\n\r\n  override writeValue(obj: string | number | null): void {\r\n    this.value = obj;\r\n    const filter = this.options?.filter(m => m.value === obj)\r\n    if (!!filter?.length) {\r\n      this.text = this.options.filter(m => m.value === obj)[0].text\r\n    } else {\r\n      this.text = \"\"\r\n    }\r\n\r\n  }\r\n\r\n  onSearchTextChange(value: string) {\r\n    this.localOptions = this.options.filter((x) => x.text.toLowerCase().indexOf(value.toLocaleLowerCase()) >= 0);\r\n  }\r\n\r\n  onListItemClick(option: ICoreDropdownOption): void {\r\n    if (this.disabled) return;\r\n    this.writeValue(option.value)\r\n    // this.text = option.text;\r\n    this.markAsTouched(); // do this before onChange\r\n    this.onChange(option.value);\r\n    this.expandState = false;\r\n  }\r\n\r\n  toggleExpanded(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.expandState = !!!this.expandState;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!!changes['options']) return;\r\n    this.localOptions = changes['options']?.currentValue;\r\n  }\r\n\r\n  onClickClear() {\r\n    this.writeValue(null);\r\n    this.markAsTouched();\r\n    this.onChange(null);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listenerFn) this.listenerFn();\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n  <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n  <div class=\"input-wrapper\">\r\n    <input class=\"value\" [value]=\"value\" />\r\n    <label\r\n      type=\"text\"\r\n      class=\"text form-control\"\r\n      [class.form-control-disabled]=\"disabled\"\r\n    >\r\n      <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n      <div class=\"icon\" (click)=\"toggleExpanded()\">\r\n        <i class=\"feather-chevron-down\"></i>\r\n      </div>\r\n    </label>\r\n    <div\r\n      class=\"clear-icon-wrapper\"\r\n      [class.d-none]=\"!!disabled || !!!value\"\r\n      (click)=\"onClickClear()\"\r\n    >\r\n      <div\r\n        class=\"flex-wrapper\"\r\n        [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\"\r\n      >\r\n        <i class=\"feather-x\"></i>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    class=\"dropdown\"\r\n    [class.form-control-disabled]=\"disabled\"\r\n    *ngIf=\"!!expandState\"\r\n  >\r\n    <input\r\n      class=\"search\"\r\n      type=\"text\"\r\n      [placeholder]=\"placeholderText\"\r\n      [(ngModel)]=\"searchText\"\r\n      (ngModelChange)=\"onSearchTextChange($event)\"\r\n      autocomplete=\"false\"\r\n      [class.form-control-disabled]=\"disabled\"\r\n      [disabled]=\"disabled\"\r\n    />\r\n    <core-scroll\r\n      [localOptions]=\"localOptions\"\r\n      [itemTemplate]=\"itemTemplateRef\"\r\n      [itemCount]=\"localOptions.length\"\r\n      [height]=\"400 - searchHeight\"\r\n      [childHeight]=\"itemHeight\"\r\n    ></core-scroll>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n  <li\r\n    (click)=\"onListItemClick(context)\"\r\n    [ngStyle]=\"{ height: itemHeight + 'px' }\"\r\n  >\r\n    <label\r\n      [ngStyle]=\"{\r\n        width: '100%',\r\n        overflow: 'hidden',\r\n        textOverflow: 'ellipsis',\r\n        whiteSpace: 'nowrap'\r\n      }\"\r\n      [appTooltip]=\"context.text\"\r\n      >{{ context.text | translate : lang }}</label\r\n    >\r\n  </li>\r\n</ng-template>\r\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Injector, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild, ViewEncapsulation, isDevMode, } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, Subscription, filter } from 'rxjs';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { ICoreDropdownOption } from '../../../interfaces/ICoreDropdownOption';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreScrollComponent } from '../../core-scroll/core-scroll/core-scroll.component';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\n\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'core-dropdown',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreScrollComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './core-dropdown.component.html',\r\n  styleUrls: ['./core-dropdown.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreDropdownComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreDropdownComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\r\n  ngControl!: NgControl;\r\n\r\n  @Input() getByIdObject$!: BehaviorSubject<any>;\r\n  @Input() paramMode!: boolean;\r\n  @Input() shownFrom!: string; // take this field from GetById response innerBody to bind to the text\r\n  @Input() options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n  @Input() height!: string;\r\n  @Input() placeholder: string = 'UI_COMMON_PLACE_HOLDER_SEARCH_HERE';\r\n  @Input() loading!: boolean;\r\n  @Input() warningDisable!: boolean;\r\n  @Input() itemHeight!: number;\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  listenerFn!: () => void;\r\n\r\n  options!: ICoreDropdownOption[];\r\n\r\n  localOptions!: ICoreDropdownOption[];\r\n  override value!: string | number | null;\r\n\r\n  lang!: string;\r\n  placeholderText!: string;\r\n  text!: string;\r\n  searchText!: string;\r\n  searchHeight: number = 38;\r\n  expandState!: boolean;\r\n\r\n  subscriptions: Subscription[] = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private domService: DomService,\r\n    private alertService: AlertService,\r\n    private injector: Injector,\r\n    private mls: MultiLanguageService,\r\n  ) {\r\n    super();\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!!!this.itemHeight) this.itemHeight = 40;\r\n\r\n    this.ngControl = this.injector.get(NgControl);\r\n\r\n    /* START: CHECK INPUT ERROR */\r\n    if (!!!this.options$ && isDevMode() && !!!this.warningDisable) {\r\n      this.alertService.error(\r\n        `\r\n        CoreDropdownComponent required this input: options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n        Also, it needs to receive a new value that usually comes from and API GetAll() action\r\n        `,\r\n        noneAutoClosedAlertOptions,\r\n      );\r\n    }\r\n\r\n    if (!!!this.paramMode) {\r\n      //getByIdObject$\r\n      if (!!!this.getByIdObject$ && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n                getByIdObject$: BehaviorSubject&lt;any&gt; (for '${this.ngControl.name}')`,\r\n        );\r\n      }\r\n\r\n      if (!!!this.shownFrom && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n              shownFrom: string; (for '${this.ngControl.name}')`,\r\n          noneAutoClosedAlertOptions,\r\n        );\r\n      }\r\n    }\r\n\r\n    /* END: CHECK INPUT ERROR */\r\n\r\n    this.subscriptions.push(\r\n      this.options$.subscribe((x) => {\r\n        this.options = x;\r\n        this.localOptions = x;\r\n        /*\r\n        // Không cần set lại text because basically it has been set by getById\r\n        if (!!this.value) {\r\n          if (!this.text) {\r\n            this.text = this.options.filter(m => m.value === this.value)[0]?.text\r\n          }\r\n        }\r\n        */\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.getByIdObject$?.subscribe((x) => {\r\n        if (!!x) {\r\n          this.text = x[this.shownFrom];\r\n        } else {\r\n          this.text = '';\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => {\r\n        this.lang = x;\r\n        this.placeholderText = this.mls.trans(this.placeholder, x)\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    /**\r\n     * This events get called by all clicks on the page\r\n     */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n       * handle click outside\r\n       */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.expandState = false;\r\n        this.searchText = '';\r\n        this.localOptions = this.options$.value;\r\n      }\r\n    });\r\n\r\n    const maxZIndex = this.domService.getMaxZIndex();\r\n    this.container.nativeElement.style.setProperty('--max-z-index', maxZIndex + 1);\r\n    this.container.nativeElement.style.setProperty('--search-height', this.searchHeight + 'px');\r\n    this.container.nativeElement.style.setProperty('--item-height', this.itemHeight + 'px');\r\n    if (!!this.height) this.container.nativeElement.style.setProperty('--height', this.height);\r\n  }\r\n\r\n  override writeValue(obj: string | number | null): void {\r\n    this.value = obj;\r\n    const filter = this.options?.filter(m => m.value === obj)\r\n    if (!!filter?.length) {\r\n      this.text = this.options.filter(m => m.value === obj)[0].text\r\n    } else {\r\n      this.text = \"\"\r\n    }\r\n\r\n  }\r\n\r\n  onSearchTextChange(value: string) {\r\n    this.localOptions = this.options.filter((x) => x.text.toLowerCase().indexOf(value.toLocaleLowerCase()) >= 0);\r\n  }\r\n\r\n  onListItemClick(option: ICoreDropdownOption): void {\r\n    if (this.disabled) return;\r\n    this.writeValue(option.value)\r\n    // this.text = option.text;\r\n    this.markAsTouched(); // do this before onChange\r\n    this.onChange(option.value);\r\n    this.expandState = false;\r\n  }\r\n\r\n  toggleExpanded(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.expandState = !!!this.expandState;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!!changes['options']) return;\r\n    this.localOptions = changes['options']?.currentValue;\r\n  }\r\n\r\n  onClickClear() {\r\n    this.writeValue(null);\r\n    this.markAsTouched();\r\n    this.onChange(null);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listenerFn) this.listenerFn();\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n  <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n  <div class=\"input-wrapper\">\r\n    <input class=\"value\" [value]=\"value\" />\r\n    <label\r\n      type=\"text\"\r\n      class=\"text form-control\"\r\n      [class.form-control-disabled]=\"disabled\"\r\n    >\r\n      <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n      <div class=\"icon\" (click)=\"toggleExpanded()\">\r\n        <i class=\"feather-chevron-down\"></i>\r\n      </div>\r\n    </label>\r\n    <div\r\n      class=\"clear-icon-wrapper\"\r\n      [class.d-none]=\"!!disabled || !!!value\"\r\n      (click)=\"onClickClear()\"\r\n    >\r\n      <div\r\n        class=\"flex-wrapper\"\r\n        [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\"\r\n      >\r\n        <i class=\"feather-x\"></i>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    class=\"dropdown\"\r\n    [class.form-control-disabled]=\"disabled\"\r\n    *ngIf=\"!!expandState\"\r\n  >\r\n    <input\r\n      class=\"search\"\r\n      type=\"text\"\r\n      [placeholder]=\"placeholderText\"\r\n      [(ngModel)]=\"searchText\"\r\n      (ngModelChange)=\"onSearchTextChange($event)\"\r\n      autocomplete=\"false\"\r\n      [class.form-control-disabled]=\"disabled\"\r\n      [disabled]=\"disabled\"\r\n    />\r\n    <core-scroll\r\n      [localOptions]=\"localOptions\"\r\n      [itemTemplate]=\"itemTemplateRef\"\r\n      [itemCount]=\"localOptions.length\"\r\n      [height]=\"400 - searchHeight\"\r\n      [childHeight]=\"itemHeight\"\r\n    ></core-scroll>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n  <li\r\n    (click)=\"onListItemClick(context)\"\r\n    [ngStyle]=\"{ height: itemHeight + 'px' }\"\r\n  >\r\n    <label\r\n      [ngStyle]=\"{\r\n        width: '100%',\r\n        overflow: 'hidden',\r\n        textOverflow: 'ellipsis',\r\n        whiteSpace: 'nowrap'\r\n      }\"\r\n      [appTooltip]=\"context.text\"\r\n      >{{ context.text | translate : lang }}</label\r\n    >\r\n  </li>\r\n</ng-template>\r\n"]}