ng-virtual-list 16.7.9 → 16.7.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,10 +1,10 @@
1
1
  import { ChangeDetectionStrategy, Component } from '@angular/core';
2
2
  import { DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN, PART_ITEM_FOCUSED, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, POSITION_STICKY, PX, SIZE_100_PERSENT, SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE, ZEROS_TRANSLATE_3D, } from '../const';
3
3
  import { BaseVirtualListItemComponent } from '../models/base-virtual-list-item-component';
4
- import { map, tap } from 'rxjs/operators';
5
- import { BehaviorSubject, combineLatest, fromEvent } from 'rxjs';
4
+ import { map, takeUntil, tap } from 'rxjs/operators';
5
+ import { BehaviorSubject, combineLatest, fromEvent, Subject } from 'rxjs';
6
6
  import { MethodsForSelectingTypes } from '../enums/method-for-selecting-types';
7
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
7
+ import { validateBoolean } from '../utils/validation';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "../ng-virtual-list.service";
10
10
  import * as i2 from "@angular/common";
@@ -22,6 +22,7 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
22
22
  _cdr;
23
23
  _elementRef;
24
24
  _service;
25
+ _$unsubscribe = new Subject();
25
26
  _id;
26
27
  get id() {
27
28
  return this._id;
@@ -85,6 +86,11 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
85
86
  * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
86
87
  */
87
88
  (selected = undefined) => {
89
+ const valid = validateBoolean(selected, true);
90
+ if (!valid) {
91
+ console.error('The "selected" parameter must be of type `boolean` or `undefined`.');
92
+ return;
93
+ }
88
94
  this._service.select(data, selected);
89
95
  };
90
96
  _collapseHandler = (data) =>
@@ -93,6 +99,11 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
93
99
  * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.
94
100
  */
95
101
  (collapsed = undefined) => {
102
+ const valid = validateBoolean(collapsed, true);
103
+ if (!valid) {
104
+ console.error('The "collapsed" parameter must be of type `boolean` or `undefined`.');
105
+ return;
106
+ }
96
107
  this._service.collapse(data, collapsed);
97
108
  };
98
109
  constructor(_cdr, _elementRef, _service) {
@@ -103,20 +114,20 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
103
114
  this._id = this._service.generateComponentId();
104
115
  const $data = this.$data, $focus = this.$focus;
105
116
  this._elementRef.nativeElement.setAttribute('id', String(this._id));
106
- $focus.pipe(takeUntilDestroyed(), tap(v => {
117
+ $focus.pipe(takeUntil(this._$unsubscribe), tap(v => {
107
118
  this._service.areaFocus(v ? this._id : this._service.focusedId === this._id ? null : this._service.focusedId);
108
119
  })).subscribe();
109
- fromEvent(this.element, EVENT_FOCUS_IN).pipe(takeUntilDestroyed(), tap(e => {
120
+ fromEvent(this.element, EVENT_FOCUS_IN).pipe(takeUntil(this._$unsubscribe), tap(e => {
110
121
  this._$focus.next(true);
111
122
  this.updateConfig(this.data);
112
123
  this.updatePartStr(this.data, this._isSelected, this._isCollapsed);
113
124
  })).subscribe(),
114
- fromEvent(this.element, EVENT_FOCUS_OUT).pipe(takeUntilDestroyed(), tap(e => {
125
+ fromEvent(this.element, EVENT_FOCUS_OUT).pipe(takeUntil(this._$unsubscribe), tap(e => {
115
126
  this._$focus.next(false);
116
127
  this.updateConfig(this.data);
117
128
  this.updatePartStr(this.data, this._isSelected, this._isCollapsed);
118
129
  })).subscribe(),
119
- fromEvent(this.element, EVENT_KEY_DOWN).pipe(takeUntilDestroyed(), tap(e => {
130
+ fromEvent(this.element, EVENT_KEY_DOWN).pipe(takeUntil(this._$unsubscribe), tap(e => {
120
131
  switch (e.key) {
121
132
  case KEY_SPACE: {
122
133
  e.stopImmediatePropagation();
@@ -159,7 +170,7 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
159
170
  break;
160
171
  }
161
172
  })).subscribe();
162
- combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(takeUntilDestroyed(), map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })), tap(({ method, selectedIds, collapsedIds }) => {
173
+ combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(takeUntil(this._$unsubscribe), map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })), tap(({ method, selectedIds, collapsedIds }) => {
163
174
  switch (method) {
164
175
  case MethodsForSelectingTypes.SELECT: {
165
176
  const id = selectedIds, isSelected = id === this.itemId;
@@ -314,6 +325,12 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
314
325
  onClickHandler() {
315
326
  this._service.itemClick(this.data);
316
327
  }
328
+ ngOnDestroy() {
329
+ if (this._$unsubscribe) {
330
+ this._$unsubscribe.next();
331
+ this._$unsubscribe.complete();
332
+ }
333
+ }
317
334
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.NgVirtualListService }], target: i0.ɵɵFactoryTarget.Component });
318
335
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { attributes: { "role": "listitem" }, classAttribute: "ngvl__item" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut, 'focus': $focus | async}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
319
336
  }
@@ -324,4 +341,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
324
341
  'role': 'listitem',
325
342
  }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut, 'focus': $focus | async}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"] }]
326
343
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.NgVirtualListService }]; } });
327
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list-item.component.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts","../../../../../projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, TemplateRef } from '@angular/core';\r\nimport { IRenderVirtualListItem } from '../models/render-item.model';\r\nimport { Id, IRect, ISize } from '../types';\r\nimport {\r\n  DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN, PART_ITEM_FOCUSED, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, POSITION_STICKY, PX, SIZE_100_PERSENT,\r\n  SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE, ZEROS_TRANSLATE_3D,\r\n} from '../const';\r\nimport { BaseVirtualListItemComponent } from '../models/base-virtual-list-item-component';\r\nimport { NgVirtualListService } from '../ng-virtual-list.service';\r\nimport { map, tap } from 'rxjs/operators';\r\nimport { BehaviorSubject, combineLatest, fromEvent, Subject } from 'rxjs';\r\nimport { IRenderVirtualListItemConfig } from '../models/render-item-config.model';\r\nimport { MethodsForSelectingTypes } from '../enums/method-for-selecting-types';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\ninterface IItemConfig extends IRenderVirtualListItemConfig {\r\n  /**\r\n   * Determines whether the element has focus or not.\r\n   */\r\n  focus: boolean;\r\n  /**\r\n   * Determines whether the element is selected or not.\r\n   */\r\n  selected: boolean;\r\n  /**\r\n   * Determines whether the element is collapsed or not.\r\n   */\r\n  collapsed: boolean;\r\n  /**\r\n    * Selects a list item\r\n    * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n    */\r\n  select: (selected: boolean | undefined) => void;\r\n  /**\r\n    * Collapse list items\r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n  collapse: (collapsed: boolean | undefined) => void;\r\n}\r\n\r\nconst ATTR_AREA_SELECTED = 'area-selected', TABINDEX = 'ng-vl-index',\r\n  KEY_SPACE = \" \", KEY_ARR_LEFT = \"ArrowLeft\", KEY_ARR_UP = \"ArrowUp\", KEY_ARR_RIGHT = \"ArrowRight\", KEY_ARR_DOWN = \"ArrowDown\",\r\n  EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown';\r\n\r\nconst getElementByIndex = (index: number) => {\r\n  return `[${TABINDEX}=\"${index}\"]`;\r\n};\r\n\r\n/**\r\n * Virtual list item component\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts\r\n * @author Evgenii Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\n@Component({\r\n  selector: 'ng-virtual-list-item',\r\n  templateUrl: './ng-virtual-list-item.component.html',\r\n  styleUrls: ['./ng-virtual-list-item.component.scss'],\r\n  host: {\r\n    'class': 'ngvl__item',\r\n    'role': 'listitem',\r\n  },\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NgVirtualListItemComponent extends BaseVirtualListItemComponent {\r\n  private _id!: number;\r\n  get id() {\r\n    return this._id;\r\n  }\r\n\r\n  private _part = PART_DEFAULT_ITEM;\r\n  get part() { return this._part; }\r\n\r\n  private _isSelected: boolean = false;\r\n\r\n  private _isCollapsed: boolean = false;\r\n\r\n  private _$config = new BehaviorSubject<IItemConfig>({} as IItemConfig);\r\n  $config = this._$config.asObservable();\r\n\r\n  measures = new BehaviorSubject<IRect & {\r\n    /**\r\n     * Delta is calculated for Snapping Method.ADVANCED\r\n     */\r\n    delta: number;\r\n  } | undefined>(undefined);\r\n\r\n  private _$focus = new BehaviorSubject<boolean>(false);\r\n  $focus = this._$focus.asObservable();\r\n\r\n  private _$part = new BehaviorSubject<string>(PART_DEFAULT_ITEM);\r\n  $part = this._$part.asObservable();\r\n\r\n  regular: boolean = false;\r\n\r\n  data: IRenderVirtualListItem | undefined = undefined;\r\n\r\n  private _$data = new BehaviorSubject<IRenderVirtualListItem | undefined>(this.data);\r\n  private $data = this._$data.asObservable();\r\n\r\n  set item(v: IRenderVirtualListItem | undefined) {\r\n    if (this.data === v) {\r\n      return;\r\n    }\r\n\r\n    this.data = v;\r\n\r\n    this.updatePartStr(v, this._isSelected, this._isCollapsed);\r\n\r\n    this.updateConfig(v);\r\n\r\n    this.updateMeasures(v);\r\n\r\n    this.update();\r\n\r\n    this._$data.next(v);\r\n\r\n    this._cdr.detectChanges();\r\n  }\r\n\r\n  private _regularLength: string = SIZE_100_PERSENT;\r\n  set regularLength(v: string) {\r\n    if (this._regularLength === v) {\r\n      return;\r\n    }\r\n\r\n    this._regularLength = v;\r\n\r\n    this.update();\r\n\r\n    this._cdr.detectChanges();\r\n  }\r\n\r\n  get item() {\r\n    return this.data;\r\n  }\r\n\r\n  get itemId() {\r\n    return this.data?.id;\r\n  }\r\n\r\n  itemRenderer: TemplateRef<any> | undefined;\r\n\r\n  set renderer(v: TemplateRef<any> | undefined) {\r\n    if (this.itemRenderer === v) {\r\n      return;\r\n    }\r\n\r\n    this.itemRenderer = v;\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  get element() {\r\n    return this._elementRef.nativeElement;\r\n  }\r\n\r\n  private _selectHandler = (data: IRenderVirtualListItem<any> | undefined) =>\r\n    /**\r\n     * Selects a list item\r\n     * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n     */\r\n    (selected: boolean | undefined = undefined) => {\r\n      this._service.select(data, selected);\r\n    };\r\n\r\n  private _collapseHandler = (data: IRenderVirtualListItem<any> | undefined) =>\r\n    /**\r\n    * Collapse list items\r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n    (collapsed: boolean | undefined = undefined) => {\r\n      this._service.collapse(data, collapsed);\r\n    };\r\n\r\n  constructor(private _cdr: ChangeDetectorRef, private _elementRef: ElementRef<HTMLElement>, private _service: NgVirtualListService) {\r\n    super();\r\n    this._id = this._service.generateComponentId();\r\n\r\n    const $data = this.$data,\r\n      $focus = this.$focus;\r\n\r\n    this._elementRef.nativeElement.setAttribute('id', String(this._id));\r\n\r\n    $focus.pipe(\r\n      takeUntilDestroyed(),\r\n      tap(v => {\r\n        this._service.areaFocus(v ? this._id : this._service.focusedId === this._id ? null : this._service.focusedId);\r\n      }),\r\n    ).subscribe();\r\n\r\n    fromEvent(this.element, EVENT_FOCUS_IN).pipe(\r\n      takeUntilDestroyed(),\r\n      tap(e => {\r\n        this._$focus.next(true);\r\n\r\n        this.updateConfig(this.data);\r\n\r\n        this.updatePartStr(this.data, this._isSelected, this._isCollapsed);\r\n      }),\r\n    ).subscribe(),\r\n\r\n      fromEvent(this.element, EVENT_FOCUS_OUT).pipe(\r\n        takeUntilDestroyed(),\r\n        tap(e => {\r\n          this._$focus.next(false);\r\n\r\n          this.updateConfig(this.data);\r\n\r\n          this.updatePartStr(this.data, this._isSelected, this._isCollapsed);\r\n        }),\r\n      ).subscribe(),\r\n\r\n      fromEvent<KeyboardEvent>(this.element, EVENT_KEY_DOWN).pipe(\r\n        takeUntilDestroyed(),\r\n        tap(e => {\r\n          switch (e.key) {\r\n            case KEY_SPACE: {\r\n              e.stopImmediatePropagation();\r\n              e.preventDefault();\r\n              if (this._service.selectByClick) {\r\n                this._service.select(this.data);\r\n              }\r\n              if (this._service.collapseByClick) {\r\n                this._service.collapse(this.data);\r\n              }\r\n              break;\r\n            }\r\n            case KEY_ARR_LEFT:\r\n              if (!this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusPrev();\r\n              }\r\n              break;\r\n            case KEY_ARR_UP:\r\n              if (this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusPrev();\r\n              }\r\n              break;\r\n            case KEY_ARR_RIGHT:\r\n              if (!this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusNext();\r\n              }\r\n              break;\r\n            case KEY_ARR_DOWN:\r\n              if (this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusNext();\r\n              }\r\n              break;\r\n          }\r\n        }),\r\n      ).subscribe();\r\n\r\n    combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(\r\n      takeUntilDestroyed(),\r\n      map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })),\r\n      tap(({ method, selectedIds, collapsedIds }) => {\r\n        switch (method) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const id = selectedIds as Id | undefined, isSelected = id === this.itemId;\r\n            this.element.setAttribute(ATTR_AREA_SELECTED, String(isSelected));\r\n            this._isSelected = isSelected;\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.MULTI_SELECT: {\r\n            const actualIds = selectedIds as Array<Id>, isSelected = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n            this.element.setAttribute(ATTR_AREA_SELECTED, String(isSelected));\r\n            this._isSelected = isSelected;\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.NONE:\r\n          default: {\r\n            this.element.removeAttribute(ATTR_AREA_SELECTED);\r\n            this._isSelected = false;\r\n            break;\r\n          }\r\n        }\r\n\r\n        const actualIds = collapsedIds, isCollapsed = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n        this._isCollapsed = isCollapsed;\r\n\r\n        this.updatePartStr(this.data, this._isSelected, isCollapsed);\r\n\r\n        this.updateConfig(this.data);\r\n\r\n        this.updateMeasures(this.data);\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  private focusNext() {\r\n    if (this._service.listElement) {\r\n      const tabIndex = this.data?.config?.tabIndex ?? 0, length = this._service.collection?.length ?? 0;\r\n      let index = tabIndex;\r\n      while (index <= length) {\r\n        index++;\r\n        const el = this._service.listElement.querySelector<HTMLDivElement>(getElementByIndex(index));\r\n        if (el) {\r\n          this._service.focus(el);\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private focusPrev() {\r\n    if (this._service.listElement) {\r\n      const tabIndex = this.data?.config?.tabIndex ?? 0;\r\n      let index = tabIndex;\r\n      while (index >= 0) {\r\n        index--;\r\n        const el = this._service.listElement.querySelector<HTMLDivElement>(getElementByIndex(index));\r\n        if (el) {\r\n          this._service.focus(el);\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private updateMeasures(v: IRenderVirtualListItem<any> | undefined) {\r\n    this.measures.next(v?.measures ? { ...v.measures } : undefined)\r\n  }\r\n\r\n  private updateConfig(v: IRenderVirtualListItem<any> | undefined) {\r\n    this._$config.next({\r\n      ...v?.config || {} as IItemConfig, selected: this._isSelected, collapsed: this._isCollapsed, focus: this._$focus.getValue(),\r\n      collapse: this._collapseHandler(v), select: this._selectHandler(v)\r\n    });\r\n  }\r\n\r\n  private update() {\r\n    const data = this.data, regular = this.regular, length = this._regularLength;\r\n    if (data) {\r\n      const styles = this._elementRef.nativeElement.style;\r\n      styles.zIndex = data.config.zIndex;\r\n      if (data.config.snapped) {\r\n        this._elementRef.nativeElement.setAttribute('position', data.config.sticky === 1 ? '0' : `${data.config.isVertical ? data.measures.y : data.measures.x}`);\r\n        styles.transform = data.config.sticky === 1 ? ZEROS_TRANSLATE_3D : `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;\r\n        if (!data.config.isSnappingMethodAdvanced) {\r\n          styles.position = POSITION_STICKY;\r\n        }\r\n      } else {\r\n        styles.position = POSITION_ABSOLUTE;\r\n        if (regular) {\r\n          this._elementRef.nativeElement.setAttribute('position', '0');\r\n          styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.delta}${PX}, ${data.config.isVertical ? data.measures.delta : 0}${PX} , 0)`;\r\n        } else {\r\n          this._elementRef.nativeElement.setAttribute('position', `${data.config.isVertical ? data.measures.y : data.measures.x}`);\r\n          styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;\r\n        }\r\n      }\r\n      styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;\r\n      styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;\r\n    }\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  private updatePartStr(v: IRenderVirtualListItem | undefined, isSelected: boolean, isCollapsed: boolean) {\r\n    let odd = false;\r\n    if (v?.index !== undefined) {\r\n      odd = v.index % 2 === 0;\r\n    }\r\n\r\n    let part = PART_DEFAULT_ITEM;\r\n    part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;\r\n    if (v ? v.config.snapped : false) {\r\n      part += PART_ITEM_SNAPPED;\r\n    }\r\n    if (isSelected) {\r\n      part += PART_ITEM_SELECTED;\r\n    }\r\n    if (isCollapsed) {\r\n      part += PART_ITEM_COLLAPSED;\r\n    }\r\n    if (this._$focus.getValue()) {\r\n      part += PART_ITEM_FOCUSED;\r\n    }\r\n    this._$part.next(part);\r\n  }\r\n\r\n  getBounds(): ISize {\r\n    const el: HTMLElement = this._elementRef.nativeElement,\r\n      { width, height } = el.getBoundingClientRect();\r\n    return { width, height };\r\n  }\r\n\r\n  show() {\r\n    const styles = this._elementRef.nativeElement.style;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_BLOCK) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_BLOCK;\r\n    } else {\r\n      if (styles.visibility === VISIBILITY_VISIBLE) {\r\n        return;\r\n      }\r\n\r\n      styles.visibility = VISIBILITY_VISIBLE;\r\n    }\r\n    styles.zIndex = this.data?.config?.zIndex ?? DEFAULT_ZINDEX;\r\n  }\r\n\r\n  hide() {\r\n    const styles = this._elementRef.nativeElement.style;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_NONE) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_NONE;\r\n    } else {\r\n      if (styles.visibility === VISIBILITY_HIDDEN) {\r\n        return;\r\n      }\r\n\r\n      styles.visibility = VISIBILITY_HIDDEN;\r\n    }\r\n    styles.position = POSITION_ABSOLUTE;\r\n    styles.transform = ZEROS_TRANSLATE_3D;\r\n    styles.zIndex = HIDDEN_ZINDEX;\r\n  }\r\n\r\n  onClickHandler() {\r\n    this._service.itemClick(this.data);\r\n  }\r\n}\r\n","<ng-container *ngIf=\"data\">\r\n    <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n        'snapped-out': data.config.snappedOut, 'focus': $focus | async}\" (click)=\"onClickHandler()\">\r\n        <ng-container *ngIf=\"itemRenderer\">\r\n            <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n                [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n</ng-container>"]}
344
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list-item.component.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts","../../../../../projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, TemplateRef } from '@angular/core';\r\nimport { IRenderVirtualListItem } from '../models/render-item.model';\r\nimport { Id, IRect, ISize } from '../types';\r\nimport {\r\n  DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN,\r\n  PART_ITEM_FOCUSED, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, POSITION_STICKY, PX, SIZE_100_PERSENT,\r\n  SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE, ZEROS_TRANSLATE_3D,\r\n} from '../const';\r\nimport { BaseVirtualListItemComponent } from '../models/base-virtual-list-item-component';\r\nimport { NgVirtualListService } from '../ng-virtual-list.service';\r\nimport { map, takeUntil, tap } from 'rxjs/operators';\r\nimport { BehaviorSubject, combineLatest, fromEvent, Subject } from 'rxjs';\r\nimport { IRenderVirtualListItemConfig } from '../models/render-item-config.model';\r\nimport { MethodsForSelectingTypes } from '../enums/method-for-selecting-types';\r\nimport { validateBoolean } from '../utils/validation';\r\n\r\ninterface IItemConfig extends IRenderVirtualListItemConfig {\r\n  /**\r\n   * Determines whether the element has focus or not.\r\n   */\r\n  focus: boolean;\r\n  /**\r\n   * Determines whether the element is selected or not.\r\n   */\r\n  selected: boolean;\r\n  /**\r\n   * Determines whether the element is collapsed or not.\r\n   */\r\n  collapsed: boolean;\r\n  /**\r\n    * Selects a list item\r\n    * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n    */\r\n  select: (selected: boolean | undefined) => void;\r\n  /**\r\n    * Collapse list items\r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n  collapse: (collapsed: boolean | undefined) => void;\r\n}\r\n\r\nconst ATTR_AREA_SELECTED = 'area-selected', TABINDEX = 'ng-vl-index',\r\n  KEY_SPACE = \" \", KEY_ARR_LEFT = \"ArrowLeft\", KEY_ARR_UP = \"ArrowUp\", KEY_ARR_RIGHT = \"ArrowRight\", KEY_ARR_DOWN = \"ArrowDown\",\r\n  EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown';\r\n\r\nconst getElementByIndex = (index: number) => {\r\n  return `[${TABINDEX}=\"${index}\"]`;\r\n};\r\n\r\n/**\r\n * Virtual list item component\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts\r\n * @author Evgenii Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\n@Component({\r\n  selector: 'ng-virtual-list-item',\r\n  templateUrl: './ng-virtual-list-item.component.html',\r\n  styleUrls: ['./ng-virtual-list-item.component.scss'],\r\n  host: {\r\n    'class': 'ngvl__item',\r\n    'role': 'listitem',\r\n  },\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NgVirtualListItemComponent extends BaseVirtualListItemComponent {\r\n  protected _$unsubscribe = new Subject<void>();\r\n\r\n  private _id!: number;\r\n  get id() {\r\n    return this._id;\r\n  }\r\n\r\n  private _part = PART_DEFAULT_ITEM;\r\n  get part() { return this._part; }\r\n\r\n  private _isSelected: boolean = false;\r\n\r\n  private _isCollapsed: boolean = false;\r\n\r\n  private _$config = new BehaviorSubject<IItemConfig>({} as IItemConfig);\r\n  $config = this._$config.asObservable();\r\n\r\n  measures = new BehaviorSubject<IRect & {\r\n    /**\r\n     * Delta is calculated for Snapping Method.ADVANCED\r\n     */\r\n    delta: number;\r\n  } | undefined>(undefined);\r\n\r\n  private _$focus = new BehaviorSubject<boolean>(false);\r\n  $focus = this._$focus.asObservable();\r\n\r\n  private _$part = new BehaviorSubject<string>(PART_DEFAULT_ITEM);\r\n  $part = this._$part.asObservable();\r\n\r\n  regular: boolean = false;\r\n\r\n  data: IRenderVirtualListItem | undefined = undefined;\r\n\r\n  private _$data = new BehaviorSubject<IRenderVirtualListItem | undefined>(this.data);\r\n  private $data = this._$data.asObservable();\r\n\r\n  set item(v: IRenderVirtualListItem | undefined) {\r\n    if (this.data === v) {\r\n      return;\r\n    }\r\n\r\n    this.data = v;\r\n\r\n    this.updatePartStr(v, this._isSelected, this._isCollapsed);\r\n\r\n    this.updateConfig(v);\r\n\r\n    this.updateMeasures(v);\r\n\r\n    this.update();\r\n\r\n    this._$data.next(v);\r\n\r\n    this._cdr.detectChanges();\r\n  }\r\n\r\n  private _regularLength: string = SIZE_100_PERSENT;\r\n  set regularLength(v: string) {\r\n    if (this._regularLength === v) {\r\n      return;\r\n    }\r\n\r\n    this._regularLength = v;\r\n\r\n    this.update();\r\n\r\n    this._cdr.detectChanges();\r\n  }\r\n\r\n  get item() {\r\n    return this.data;\r\n  }\r\n\r\n  get itemId() {\r\n    return this.data?.id;\r\n  }\r\n\r\n  itemRenderer: TemplateRef<any> | undefined;\r\n\r\n  set renderer(v: TemplateRef<any> | undefined) {\r\n    if (this.itemRenderer === v) {\r\n      return;\r\n    }\r\n\r\n    this.itemRenderer = v;\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  get element() {\r\n    return this._elementRef.nativeElement;\r\n  }\r\n\r\n  private _selectHandler = (data: IRenderVirtualListItem<any> | undefined) =>\r\n    /**\r\n     * Selects a list item\r\n     * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n     */\r\n    (selected: boolean | undefined = undefined) => {\r\n      const valid = validateBoolean(selected, true);\r\n      if (!valid) {\r\n        console.error('The \"selected\" parameter must be of type `boolean` or `undefined`.');\r\n        return;\r\n      }\r\n      this._service.select(data, selected);\r\n    };\r\n\r\n  private _collapseHandler = (data: IRenderVirtualListItem<any> | undefined) =>\r\n    /**\r\n    * Collapse list items\r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n    (collapsed: boolean | undefined = undefined) => {\r\n      const valid = validateBoolean(collapsed, true);\r\n      if (!valid) {\r\n        console.error('The \"collapsed\" parameter must be of type `boolean` or `undefined`.');\r\n        return;\r\n      }\r\n      this._service.collapse(data, collapsed);\r\n    };\r\n\r\n  constructor(private _cdr: ChangeDetectorRef, private _elementRef: ElementRef<HTMLElement>, private _service: NgVirtualListService) {\r\n    super();\r\n    this._id = this._service.generateComponentId();\r\n\r\n    const $data = this.$data,\r\n      $focus = this.$focus;\r\n\r\n    this._elementRef.nativeElement.setAttribute('id', String(this._id));\r\n\r\n    $focus.pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      tap(v => {\r\n        this._service.areaFocus(v ? this._id : this._service.focusedId === this._id ? null : this._service.focusedId);\r\n      }),\r\n    ).subscribe();\r\n\r\n    fromEvent(this.element, EVENT_FOCUS_IN).pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      tap(e => {\r\n        this._$focus.next(true);\r\n\r\n        this.updateConfig(this.data);\r\n\r\n        this.updatePartStr(this.data, this._isSelected, this._isCollapsed);\r\n      }),\r\n    ).subscribe(),\r\n\r\n      fromEvent(this.element, EVENT_FOCUS_OUT).pipe(\r\n        takeUntil(this._$unsubscribe),\r\n        tap(e => {\r\n          this._$focus.next(false);\r\n\r\n          this.updateConfig(this.data);\r\n\r\n          this.updatePartStr(this.data, this._isSelected, this._isCollapsed);\r\n        }),\r\n      ).subscribe(),\r\n\r\n      fromEvent<KeyboardEvent>(this.element, EVENT_KEY_DOWN).pipe(\r\n        takeUntil(this._$unsubscribe),\r\n        tap(e => {\r\n          switch (e.key) {\r\n            case KEY_SPACE: {\r\n              e.stopImmediatePropagation();\r\n              e.preventDefault();\r\n              if (this._service.selectByClick) {\r\n                this._service.select(this.data);\r\n              }\r\n              if (this._service.collapseByClick) {\r\n                this._service.collapse(this.data);\r\n              }\r\n              break;\r\n            }\r\n            case KEY_ARR_LEFT:\r\n              if (!this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusPrev();\r\n              }\r\n              break;\r\n            case KEY_ARR_UP:\r\n              if (this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusPrev();\r\n              }\r\n              break;\r\n            case KEY_ARR_RIGHT:\r\n              if (!this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusNext();\r\n              }\r\n              break;\r\n            case KEY_ARR_DOWN:\r\n              if (this._$config.getValue().isVertical) {\r\n                e.stopImmediatePropagation();\r\n                e.preventDefault();\r\n                this.focusNext();\r\n              }\r\n              break;\r\n          }\r\n        }),\r\n      ).subscribe();\r\n\r\n    combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })),\r\n      tap(({ method, selectedIds, collapsedIds }) => {\r\n        switch (method) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const id = selectedIds as Id | undefined, isSelected = id === this.itemId;\r\n            this.element.setAttribute(ATTR_AREA_SELECTED, String(isSelected));\r\n            this._isSelected = isSelected;\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.MULTI_SELECT: {\r\n            const actualIds = selectedIds as Array<Id>, isSelected = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n            this.element.setAttribute(ATTR_AREA_SELECTED, String(isSelected));\r\n            this._isSelected = isSelected;\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.NONE:\r\n          default: {\r\n            this.element.removeAttribute(ATTR_AREA_SELECTED);\r\n            this._isSelected = false;\r\n            break;\r\n          }\r\n        }\r\n\r\n        const actualIds = collapsedIds, isCollapsed = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n        this._isCollapsed = isCollapsed;\r\n\r\n        this.updatePartStr(this.data, this._isSelected, isCollapsed);\r\n\r\n        this.updateConfig(this.data);\r\n\r\n        this.updateMeasures(this.data);\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  private focusNext() {\r\n    if (this._service.listElement) {\r\n      const tabIndex = this.data?.config?.tabIndex ?? 0, length = this._service.collection?.length ?? 0;\r\n      let index = tabIndex;\r\n      while (index <= length) {\r\n        index++;\r\n        const el = this._service.listElement.querySelector<HTMLDivElement>(getElementByIndex(index));\r\n        if (el) {\r\n          this._service.focus(el);\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private focusPrev() {\r\n    if (this._service.listElement) {\r\n      const tabIndex = this.data?.config?.tabIndex ?? 0;\r\n      let index = tabIndex;\r\n      while (index >= 0) {\r\n        index--;\r\n        const el = this._service.listElement.querySelector<HTMLDivElement>(getElementByIndex(index));\r\n        if (el) {\r\n          this._service.focus(el);\r\n          break;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private updateMeasures(v: IRenderVirtualListItem<any> | undefined) {\r\n    this.measures.next(v?.measures ? { ...v.measures } : undefined)\r\n  }\r\n\r\n  private updateConfig(v: IRenderVirtualListItem<any> | undefined) {\r\n    this._$config.next({\r\n      ...v?.config || {} as IItemConfig, selected: this._isSelected, collapsed: this._isCollapsed, focus: this._$focus.getValue(),\r\n      collapse: this._collapseHandler(v), select: this._selectHandler(v)\r\n    });\r\n  }\r\n\r\n  private update() {\r\n    const data = this.data, regular = this.regular, length = this._regularLength;\r\n    if (data) {\r\n      const styles = this._elementRef.nativeElement.style;\r\n      styles.zIndex = data.config.zIndex;\r\n      if (data.config.snapped) {\r\n        this._elementRef.nativeElement.setAttribute('position', data.config.sticky === 1 ? '0' : `${data.config.isVertical ? data.measures.y : data.measures.x}`);\r\n        styles.transform = data.config.sticky === 1 ? ZEROS_TRANSLATE_3D : `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;\r\n        if (!data.config.isSnappingMethodAdvanced) {\r\n          styles.position = POSITION_STICKY;\r\n        }\r\n      } else {\r\n        styles.position = POSITION_ABSOLUTE;\r\n        if (regular) {\r\n          this._elementRef.nativeElement.setAttribute('position', '0');\r\n          styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.delta}${PX}, ${data.config.isVertical ? data.measures.delta : 0}${PX} , 0)`;\r\n        } else {\r\n          this._elementRef.nativeElement.setAttribute('position', `${data.config.isVertical ? data.measures.y : data.measures.x}`);\r\n          styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;\r\n        }\r\n      }\r\n      styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;\r\n      styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;\r\n    }\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  private updatePartStr(v: IRenderVirtualListItem | undefined, isSelected: boolean, isCollapsed: boolean) {\r\n    let odd = false;\r\n    if (v?.index !== undefined) {\r\n      odd = v.index % 2 === 0;\r\n    }\r\n\r\n    let part = PART_DEFAULT_ITEM;\r\n    part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;\r\n    if (v ? v.config.snapped : false) {\r\n      part += PART_ITEM_SNAPPED;\r\n    }\r\n    if (isSelected) {\r\n      part += PART_ITEM_SELECTED;\r\n    }\r\n    if (isCollapsed) {\r\n      part += PART_ITEM_COLLAPSED;\r\n    }\r\n    if (this._$focus.getValue()) {\r\n      part += PART_ITEM_FOCUSED;\r\n    }\r\n    this._$part.next(part);\r\n  }\r\n\r\n  getBounds(): ISize {\r\n    const el: HTMLElement = this._elementRef.nativeElement,\r\n      { width, height } = el.getBoundingClientRect();\r\n    return { width, height };\r\n  }\r\n\r\n  show() {\r\n    const styles = this._elementRef.nativeElement.style;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_BLOCK) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_BLOCK;\r\n    } else {\r\n      if (styles.visibility === VISIBILITY_VISIBLE) {\r\n        return;\r\n      }\r\n\r\n      styles.visibility = VISIBILITY_VISIBLE;\r\n    }\r\n    styles.zIndex = this.data?.config?.zIndex ?? DEFAULT_ZINDEX;\r\n  }\r\n\r\n  hide() {\r\n    const styles = this._elementRef.nativeElement.style;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_NONE) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_NONE;\r\n    } else {\r\n      if (styles.visibility === VISIBILITY_HIDDEN) {\r\n        return;\r\n      }\r\n\r\n      styles.visibility = VISIBILITY_HIDDEN;\r\n    }\r\n    styles.position = POSITION_ABSOLUTE;\r\n    styles.transform = ZEROS_TRANSLATE_3D;\r\n    styles.zIndex = HIDDEN_ZINDEX;\r\n  }\r\n\r\n  onClickHandler() {\r\n    this._service.itemClick(this.data);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this._$unsubscribe) {\r\n      this._$unsubscribe.next();\r\n      this._$unsubscribe.complete();\r\n    }\r\n  }\r\n}\r\n\r\n","<ng-container *ngIf=\"data\">\r\n    <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n        'snapped-out': data.config.snappedOut, 'focus': $focus | async}\" (click)=\"onClickHandler()\">\r\n        <ng-container *ngIf=\"itemRenderer\">\r\n            <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n                [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n</ng-container>"]}