ng-virtual-list 18.7.0 → 18.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.
Files changed (71) hide show
  1. package/README.md +18 -16
  2. package/esm2022/lib/components/ng-virtual-list-item.component.mjs +18 -5
  3. package/esm2022/lib/const/index.mjs +2 -1
  4. package/esm2022/lib/models/index.mjs +1 -1
  5. package/esm2022/lib/models/item-config-map.model.mjs +2 -0
  6. package/esm2022/lib/models/render-item-config.model.mjs +1 -1
  7. package/esm2022/lib/ng-virtual-list.component.mjs +45 -19
  8. package/esm2022/lib/ng-virtual-list.service.mjs +46 -8
  9. package/esm2022/lib/utils/trackBox.mjs +22 -19
  10. package/fesm2022/ng-virtual-list.mjs +126 -46
  11. package/fesm2022/ng-virtual-list.mjs.map +1 -1
  12. package/lib/components/ng-virtual-list-item.component.d.ts +22 -4
  13. package/lib/const/index.d.ts +1 -0
  14. package/lib/models/index.d.ts +2 -2
  15. package/lib/models/item-config-map.model.d.ts +23 -0
  16. package/lib/models/render-item-config.model.d.ts +5 -1
  17. package/lib/ng-virtual-list.component.d.ts +20 -6
  18. package/lib/ng-virtual-list.service.d.ts +7 -0
  19. package/lib/utils/trackBox.d.ts +4 -4
  20. package/package.json +1 -1
  21. package/esm2020/lib/components/ng-virtual-list-item.component.mjs +0 -198
  22. package/esm2020/lib/const/index.mjs +0 -51
  23. package/esm2020/lib/enums/direction.mjs +0 -2
  24. package/esm2020/lib/enums/directions.mjs +0 -18
  25. package/esm2020/lib/enums/index.mjs +0 -5
  26. package/esm2020/lib/enums/method-for-selecting-types.mjs +0 -22
  27. package/esm2020/lib/enums/method-for-selecting.mjs +0 -2
  28. package/esm2020/lib/enums/methods-for-selecting.mjs +0 -22
  29. package/esm2020/lib/enums/snapping-method.mjs +0 -2
  30. package/esm2020/lib/enums/snapping-methods.mjs +0 -18
  31. package/esm2020/lib/models/base-virtual-list-item-component.mjs +0 -9
  32. package/esm2020/lib/models/collection.model.mjs +0 -3
  33. package/esm2020/lib/models/component.model.mjs +0 -2
  34. package/esm2020/lib/models/index.mjs +0 -2
  35. package/esm2020/lib/models/item.model.mjs +0 -2
  36. package/esm2020/lib/models/render-collection.model.mjs +0 -3
  37. package/esm2020/lib/models/render-item-config.model.mjs +0 -2
  38. package/esm2020/lib/models/render-item.model.mjs +0 -3
  39. package/esm2020/lib/models/scroll-direction.model.mjs +0 -2
  40. package/esm2020/lib/models/scroll-event.model.mjs +0 -2
  41. package/esm2020/lib/models/sticky-map.model.mjs +0 -2
  42. package/esm2020/lib/ng-virtual-list.component.mjs +0 -800
  43. package/esm2020/lib/ng-virtual-list.module.mjs +0 -20
  44. package/esm2020/lib/ng-virtual-list.service.mjs +0 -94
  45. package/esm2020/lib/types/id.mjs +0 -2
  46. package/esm2020/lib/types/index.mjs +0 -2
  47. package/esm2020/lib/types/rect.mjs +0 -2
  48. package/esm2020/lib/types/size.mjs +0 -2
  49. package/esm2020/lib/utils/browser.mjs +0 -3
  50. package/esm2020/lib/utils/buffer-interpolation.mjs +0 -27
  51. package/esm2020/lib/utils/cacheMap.mjs +0 -167
  52. package/esm2020/lib/utils/debounce.mjs +0 -31
  53. package/esm2020/lib/utils/disposableComponent.mjs +0 -29
  54. package/esm2020/lib/utils/eventEmitter.mjs +0 -106
  55. package/esm2020/lib/utils/index.mjs +0 -5
  56. package/esm2020/lib/utils/isDirection.mjs +0 -15
  57. package/esm2020/lib/utils/isMethodForSelecting.mjs +0 -18
  58. package/esm2020/lib/utils/scrollEvent.mjs +0 -42
  59. package/esm2020/lib/utils/snapping-method.mjs +0 -9
  60. package/esm2020/lib/utils/toggleClassName.mjs +0 -15
  61. package/esm2020/lib/utils/trackBox.mjs +0 -762
  62. package/esm2020/lib/utils/tracker.mjs +0 -143
  63. package/esm2020/ng-virtual-list.mjs +0 -5
  64. package/esm2020/public-api.mjs +0 -10
  65. package/esm2022/lib/models/sticky-map.model.mjs +0 -2
  66. package/fesm2015/ng-virtual-list.mjs +0 -2582
  67. package/fesm2015/ng-virtual-list.mjs.map +0 -1
  68. package/fesm2020/ng-virtual-list.mjs +0 -2586
  69. package/fesm2020/ng-virtual-list.mjs.map +0 -1
  70. package/lib/models/sticky-map.model.d.ts +0 -14
  71. package/lib/utils/disposableComponent.d.ts +0 -15
@@ -1,10 +1,21 @@
1
1
  import { TemplateRef } from '@angular/core';
2
2
  import { IRenderVirtualListItem } from '../models/render-item.model';
3
- import { Id, ISize } from '../types';
3
+ import { Id, IRect, ISize } from '../types';
4
4
  import { BaseVirtualListItemComponent } from '../models/base-virtual-list-item-component';
5
5
  import { NgVirtualListService } from '../ng-virtual-list.service';
6
6
  import { IRenderVirtualListItemConfig } from '../models/render-item-config.model';
7
7
  import * as i0 from "@angular/core";
8
+ interface IItemConfig extends IRenderVirtualListItemConfig {
9
+ /**
10
+ * Determines whether the element is selected or not.
11
+ */
12
+ selected: boolean;
13
+ /**
14
+ * Selects a list item
15
+ * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
16
+ */
17
+ select: (selected: boolean | undefined) => void;
18
+ }
8
19
  /**
9
20
  * Virtual list item component
10
21
  * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts
@@ -17,9 +28,13 @@ export declare class NgVirtualListItemComponent extends BaseVirtualListItemCompo
17
28
  private _cdr;
18
29
  protected _service: NgVirtualListService;
19
30
  private _isSelected;
20
- config: import("@angular/core").WritableSignal<IRenderVirtualListItemConfig & {
21
- selected: boolean;
22
- }>;
31
+ config: import("@angular/core").WritableSignal<IItemConfig>;
32
+ measures: import("@angular/core").WritableSignal<(IRect & {
33
+ /**
34
+ * Delta is calculated for Snapping Method.ADVANCED
35
+ */
36
+ delta: number;
37
+ }) | undefined>;
23
38
  private _part;
24
39
  get part(): string;
25
40
  regular: boolean;
@@ -34,7 +49,9 @@ export declare class NgVirtualListItemComponent extends BaseVirtualListItemCompo
34
49
  set renderer(v: TemplateRef<any> | undefined);
35
50
  private _elementRef;
36
51
  get element(): HTMLElement;
52
+ private _selectHandler;
37
53
  constructor();
54
+ private updateMeasures;
38
55
  private updateConfig;
39
56
  private update;
40
57
  private updatePartStr;
@@ -45,3 +62,4 @@ export declare class NgVirtualListItemComponent extends BaseVirtualListItemCompo
45
62
  static ɵfac: i0.ɵɵFactoryDeclaration<NgVirtualListItemComponent, never>;
46
63
  static ɵcmp: i0.ɵɵComponentDeclaration<NgVirtualListItemComponent, "ng-virtual-list-item", never, {}, {}, never, never, false, never>;
47
64
  }
65
+ export {};
@@ -5,6 +5,7 @@ export declare const DEFAULT_BUFFER_SIZE = 2;
5
5
  export declare const DEFAULT_MAX_BUFFER_SIZE = 100;
6
6
  export declare const DEFAULT_LIST_SIZE = 400;
7
7
  export declare const DEFAULT_SNAP = false;
8
+ export declare const DEFAULT_SELECT_BY_CLICK = true;
8
9
  export declare const DEFAULT_ENABLED_BUFFER_OPTIMIZATION = false;
9
10
  export declare const DEFAULT_DYNAMIC_SIZE = false;
10
11
  export declare const TRACK_BY_PROPERTY_NAME = "id";
@@ -1,7 +1,7 @@
1
1
  import { ScrollDirection } from './scroll-direction.model';
2
2
  import { IScrollEvent } from './scroll-event.model';
3
3
  import { IVirtualListItem } from './item.model';
4
- import { IVirtualListStickyMap } from './sticky-map.model';
4
+ import { IVirtualListItemConfigMap } from './item-config-map.model';
5
5
  import { IVirtualListCollection } from './collection.model';
6
6
  import { IRenderVirtualListItem } from './render-item.model';
7
- export type { ScrollDirection, IScrollEvent, IVirtualListItem, IVirtualListStickyMap, IVirtualListCollection, IRenderVirtualListItem, };
7
+ export type { ScrollDirection, IScrollEvent, IVirtualListItem, IVirtualListItemConfigMap, IVirtualListCollection, IRenderVirtualListItem, };
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Sets sticky position and selectable for the list item element. If sticky position is greater than 0, then sticky position is applied.
3
+ * If the sticky value is greater than `0`, then the sticky position mode is enabled for the element. `1` - position start, `2` - position end. Default value is `0`.
4
+ * selectable determines whether an element can be selected or not. Default value is `true`.
5
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/models/item-config-map.model.ts
6
+ * @author Evgenii Grebennikov
7
+ * @email djonnyx@gmail.com
8
+ */
9
+ export interface IVirtualListItemConfigMap {
10
+ [id: string | number]: {
11
+ /**
12
+ * Sets sticky position for the element. If sticky position is greater than 0, then sticky position is applied.
13
+ * `1` - position start, `2` - position end.
14
+ * Default value is `0`.
15
+ */
16
+ sticky?: 0 | 1 | 2;
17
+ /**
18
+ * Determines whether an element can be selected or not.
19
+ * Default value is `true`.
20
+ */
21
+ selectable?: boolean;
22
+ };
23
+ }
@@ -17,7 +17,11 @@ export interface IRenderVirtualListItemConfig {
17
17
  /**
18
18
  * If greater than 0, the element will have a sticky position with the given zIndex.
19
19
  */
20
- sticky: number;
20
+ sticky: 0 | 1 | 2;
21
+ /**
22
+ * Determines whether an element can be selected or not. Default value is `true`.
23
+ */
24
+ selectable: boolean;
21
25
  /**
22
26
  * Specifies whether the element will snap.
23
27
  */
@@ -1,6 +1,6 @@
1
1
  import { AfterViewInit, OnDestroy, OnInit, TemplateRef } from '@angular/core';
2
2
  import { Observable } from 'rxjs';
3
- import { IRenderVirtualListItem, IScrollEvent, IVirtualListCollection, IVirtualListStickyMap } from './models';
3
+ import { IRenderVirtualListItem, IScrollEvent, IVirtualListCollection, IVirtualListItemConfigMap } from './models';
4
4
  import { Id, ISize } from './types';
5
5
  import { Direction, Directions, MethodForSelecting, SnappingMethod } from './enums';
6
6
  import * as i0 from "@angular/core";
@@ -54,6 +54,11 @@ export declare class NgVirtualListComponent implements AfterViewInit, OnInit, On
54
54
  * Sets the selected items.
55
55
  */
56
56
  selectedIds: import("@angular/core").InputSignal<Id | Id[] | undefined>;
57
+ /**
58
+ * If false, the element is selected using the config.select method passed to the template;
59
+ * if true, the element is selected by clicking on it. The default value is true.
60
+ */
61
+ selectByClick: import("@angular/core").InputSignal<boolean>;
57
62
  /**
58
63
  * Determines whether elements will snap. Default value is "true".
59
64
  */
@@ -71,10 +76,19 @@ export declare class NgVirtualListComponent implements AfterViewInit, OnInit, On
71
76
  itemRenderer: import("@angular/core").InputSignal<TemplateRef<any>>;
72
77
  private _itemRenderer;
73
78
  /**
74
- * Dictionary zIndex by id of the list element. If the value is not set or equal to 0,
75
- * then a simple element is displayed, if the value is greater than 0, then the sticky position mode is enabled for the element.
79
+ * @deprecated
80
+ * Use `itemConfigMap` instead.
81
+ */
82
+ stickyMap: import("@angular/core").InputSignal<unknown>;
83
+ /**
84
+ * Sets sticky position and selectable for the list item element. If sticky position is greater than 0, then sticky position is applied.
85
+ * If the sticky value is greater than `0`, then the sticky position mode is enabled for the element. `1` - position start, `2` - position end. Default value is `0`.
86
+ * selectable determines whether an element can be selected or not. Default value is `true`.
87
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/models/item-config-map.model.ts
88
+ * @author Evgenii Grebennikov
89
+ * @email djonnyx@gmail.com
76
90
  */
77
- stickyMap: import("@angular/core").InputSignal<IVirtualListStickyMap>;
91
+ itemConfigMap: import("@angular/core").InputSignal<IVirtualListItemConfigMap>;
78
92
  private _itemSizeOptions;
79
93
  /**
80
94
  * If direction = 'vertical', then the height of a typical element. If direction = 'horizontal', then the width of a typical element.
@@ -114,7 +128,7 @@ export declare class NgVirtualListComponent implements AfterViewInit, OnInit, On
114
128
  */
115
129
  snappingMethod: import("@angular/core").InputSignal<SnappingMethod>;
116
130
  /**
117
- * Method for selecting list items.
131
+ * Method for selecting list items. Default value is 'none'.
118
132
  * 'select' - List items are selected one by one.
119
133
  * 'multi-select' - Multiple selection of list items.
120
134
  * 'none' - List items are not selectable.
@@ -198,5 +212,5 @@ export declare class NgVirtualListComponent implements AfterViewInit, OnInit, On
198
212
  private afterViewInit;
199
213
  private dispose;
200
214
  static ɵfac: i0.ɵɵFactoryDeclaration<NgVirtualListComponent, never>;
201
- static ɵcmp: i0.ɵɵComponentDeclaration<NgVirtualListComponent, "ng-virtual-list", never, { "items": { "alias": "items"; "required": true; "isSignal": true; }; "selectedIds": { "alias": "selectedIds"; "required": false; "isSignal": true; }; "snap": { "alias": "snap"; "required": false; "isSignal": true; }; "enabledBufferOptimization": { "alias": "enabledBufferOptimization"; "required": false; "isSignal": true; }; "itemRenderer": { "alias": "itemRenderer"; "required": true; "isSignal": true; }; "stickyMap": { "alias": "stickyMap"; "required": false; "isSignal": true; }; "itemSize": { "alias": "itemSize"; "required": false; "isSignal": true; }; "dynamicSize": { "alias": "dynamicSize"; "required": false; "isSignal": true; }; "direction": { "alias": "direction"; "required": false; "isSignal": true; }; "itemsOffset": { "alias": "itemsOffset"; "required": false; "isSignal": true; }; "bufferSize": { "alias": "bufferSize"; "required": false; "isSignal": true; }; "maxBufferSize": { "alias": "maxBufferSize"; "required": false; "isSignal": true; }; "snappingMethod": { "alias": "snappingMethod"; "required": false; "isSignal": true; }; "methodForSelecting": { "alias": "methodForSelecting"; "required": false; "isSignal": true; }; "trackBy": { "alias": "trackBy"; "required": false; "isSignal": true; }; }, { "onScroll": "onScroll"; "onScrollEnd": "onScrollEnd"; "onViewportChange": "onViewportChange"; "onItemClick": "onItemClick"; "onSelect": "onSelect"; }, never, never, false, never>;
215
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgVirtualListComponent, "ng-virtual-list", never, { "items": { "alias": "items"; "required": true; "isSignal": true; }; "selectedIds": { "alias": "selectedIds"; "required": false; "isSignal": true; }; "selectByClick": { "alias": "selectByClick"; "required": false; "isSignal": true; }; "snap": { "alias": "snap"; "required": false; "isSignal": true; }; "enabledBufferOptimization": { "alias": "enabledBufferOptimization"; "required": false; "isSignal": true; }; "itemRenderer": { "alias": "itemRenderer"; "required": true; "isSignal": true; }; "stickyMap": { "alias": "stickyMap"; "required": false; "isSignal": true; }; "itemConfigMap": { "alias": "itemConfigMap"; "required": false; "isSignal": true; }; "itemSize": { "alias": "itemSize"; "required": false; "isSignal": true; }; "dynamicSize": { "alias": "dynamicSize"; "required": false; "isSignal": true; }; "direction": { "alias": "direction"; "required": false; "isSignal": true; }; "itemsOffset": { "alias": "itemsOffset"; "required": false; "isSignal": true; }; "bufferSize": { "alias": "bufferSize"; "required": false; "isSignal": true; }; "maxBufferSize": { "alias": "maxBufferSize"; "required": false; "isSignal": true; }; "snappingMethod": { "alias": "snappingMethod"; "required": false; "isSignal": true; }; "methodForSelecting": { "alias": "methodForSelecting"; "required": false; "isSignal": true; }; "trackBy": { "alias": "trackBy"; "required": false; "isSignal": true; }; }, { "onScroll": "onScroll"; "onScrollEnd": "onScrollEnd"; "onViewportChange": "onViewportChange"; "onItemClick": "onItemClick"; "onSelect": "onSelect"; }, never, never, false, never>;
202
216
  }
@@ -12,10 +12,17 @@ export declare class NgVirtualListService {
12
12
  private _$methodOfSelecting;
13
13
  $methodOfSelecting: import("rxjs").Observable<MethodsForSelectingTypes>;
14
14
  set methodOfSelecting(v: MethodsForSelectingTypes);
15
+ selectByClick: boolean;
15
16
  private _trackBox;
16
17
  constructor();
17
18
  setSelectedIds(ids: Array<Id> | Id | undefined): void;
18
19
  itemClick(data: IRenderVirtualListItem | undefined): void;
20
+ /**
21
+ * Selects a list item
22
+ * @param data
23
+ * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
24
+ */
25
+ select(data: IRenderVirtualListItem | undefined, selected?: boolean | undefined): void;
19
26
  initialize(trackBox: TrackBox): void;
20
27
  generateComponentId(): number;
21
28
  static ɵfac: i0.ɵɵFactoryDeclaration<NgVirtualListService, never>;
@@ -5,7 +5,7 @@ import { CacheMap, CMap } from "./cacheMap";
5
5
  import { Tracker } from "./tracker";
6
6
  import { ISize } from "../types";
7
7
  import { HEIGHT_PROP_NAME, WIDTH_PROP_NAME } from "../const";
8
- import { IVirtualListStickyMap } from "../models";
8
+ import { IVirtualListItemConfigMap } from "../models";
9
9
  import { BaseVirtualListItemComponent } from "../models/base-virtual-list-item-component";
10
10
  export declare const TRACK_BOX_CHANGE_EVENT_NAME = "change";
11
11
  export interface IMetrics {
@@ -149,13 +149,13 @@ export declare class TrackBox<C extends BaseVirtualListItemComponent = any> exte
149
149
  */
150
150
  getItemPosition<I extends {
151
151
  id: Id;
152
- }, C extends Array<I>>(id: Id, stickyMap: IVirtualListStickyMap, options: IGetItemPositionOptions<I, C>): number;
152
+ }, C extends Array<I>>(id: Id, itemConfigMap: IVirtualListItemConfigMap, options: IGetItemPositionOptions<I, C>): number;
153
153
  /**
154
154
  * Updates the collection of display objects
155
155
  */
156
156
  updateCollection<I extends {
157
157
  id: Id;
158
- }, C extends Array<I>>(items: C, stickyMap: IVirtualListStickyMap, options: IUpdateCollectionOptions<I, C>): IUpdateCollectionReturns;
158
+ }, C extends Array<I>>(items: C, itemConfigMap: IVirtualListItemConfigMap, options: IUpdateCollectionOptions<I, C>): IUpdateCollectionReturns;
159
159
  /**
160
160
  * Finds the closest element in the collection by scrollSize
161
161
  */
@@ -192,7 +192,7 @@ export declare class TrackBox<C extends BaseVirtualListItemComponent = any> exte
192
192
  changes(): void;
193
193
  protected generateDisplayCollection<I extends {
194
194
  id: Id;
195
- }, C extends Array<I>>(items: C, stickyMap: IVirtualListStickyMap, metrics: IMetrics): IRenderVirtualListCollection;
195
+ }, C extends Array<I>>(items: C, itemConfigMap: IVirtualListItemConfigMap, metrics: IMetrics): IRenderVirtualListCollection;
196
196
  /**
197
197
  * tracking by propName
198
198
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ng-virtual-list",
3
- "version": "18.7.0",
3
+ "version": "18.7.2",
4
4
  "author": {
5
5
  "name": "Evgenii Grebennikov",
6
6
  "email": "djonnyx@gmail.com"
@@ -1,198 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_EVEN, 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
- import { BaseVirtualListItemComponent } from '../models/base-virtual-list-item-component';
4
- import { map, takeUntil, tap } from 'rxjs/operators';
5
- import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
6
- import { MethodsForSelectingTypes } from '../enums/method-for-selecting-types';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../ng-virtual-list.service";
9
- import * as i2 from "@angular/common";
10
- const ATTR_AREA_SELECTED = 'area-selected';
11
- /**
12
- * Virtual list item component
13
- * @link https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts
14
- * @author Evgenii Grebennikov
15
- * @email djonnyx@gmail.com
16
- */
17
- export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
18
- get id() {
19
- return this._id;
20
- }
21
- get part() { return this._part; }
22
- set item(v) {
23
- if (this.data === v) {
24
- return;
25
- }
26
- this.data = v;
27
- this.updatePartStr(v, this._isSelected);
28
- this.updateConfig(v);
29
- this.update();
30
- this._$data.next(v);
31
- this._cdr.detectChanges();
32
- }
33
- set regularLength(v) {
34
- if (this._regularLength === v) {
35
- return;
36
- }
37
- this._regularLength = v;
38
- this.update();
39
- this._cdr.detectChanges();
40
- }
41
- get item() {
42
- return this.data;
43
- }
44
- get itemId() {
45
- return this.data?.id;
46
- }
47
- set renderer(v) {
48
- if (this.itemRenderer === v) {
49
- return;
50
- }
51
- this.itemRenderer = v;
52
- this._cdr.markForCheck();
53
- }
54
- get element() {
55
- return this._elementRef.nativeElement;
56
- }
57
- constructor(_cdr, _elementRef, _service) {
58
- super();
59
- this._cdr = _cdr;
60
- this._elementRef = _elementRef;
61
- this._service = _service;
62
- this._$unsubscribe = new Subject();
63
- this._part = PART_DEFAULT_ITEM;
64
- this._isSelected = false;
65
- this.config = new BehaviorSubject({});
66
- this.regular = false;
67
- this._$data = new BehaviorSubject(this.data);
68
- this.$data = this._$data.asObservable();
69
- this._regularLength = SIZE_100_PERSENT;
70
- this._id = this._service.generateComponentId();
71
- const $data = this.$data;
72
- combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds]).pipe(takeUntil(this._$unsubscribe), map(([, m, ids]) => ({ method: m, ids })), tap(({ method, ids }) => {
73
- switch (method) {
74
- case MethodsForSelectingTypes.SELECT: {
75
- const id = ids, isSelected = id === this.itemId;
76
- this._elementRef.nativeElement.setAttribute(ATTR_AREA_SELECTED, String(isSelected));
77
- this._isSelected = isSelected;
78
- break;
79
- }
80
- case MethodsForSelectingTypes.MULTI_SELECT: {
81
- const actualIds = ids, isSelected = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);
82
- this._elementRef.nativeElement.setAttribute(ATTR_AREA_SELECTED, String(isSelected));
83
- this._isSelected = isSelected;
84
- break;
85
- }
86
- case MethodsForSelectingTypes.NONE:
87
- default: {
88
- this._elementRef.nativeElement.removeAttribute(ATTR_AREA_SELECTED);
89
- this._isSelected = false;
90
- break;
91
- }
92
- }
93
- this.updatePartStr(this.data, this._isSelected);
94
- this.updateConfig(this.data);
95
- })).subscribe();
96
- }
97
- updateConfig(v) {
98
- this.config.next({ ...v?.config || {}, selected: this._isSelected });
99
- }
100
- update() {
101
- const data = this.data, regular = this.regular, length = this._regularLength;
102
- if (data) {
103
- const styles = this._elementRef.nativeElement.style;
104
- styles.zIndex = data.config.zIndex;
105
- if (data.config.snapped) {
106
- 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)`;
107
- ;
108
- if (!data.config.isSnappingMethodAdvanced) {
109
- styles.position = POSITION_STICKY;
110
- }
111
- }
112
- else {
113
- styles.position = POSITION_ABSOLUTE;
114
- if (regular) {
115
- styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.delta}${PX}, ${data.config.isVertical ? data.measures.delta : 0}${PX} , 0)`;
116
- }
117
- else {
118
- styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;
119
- }
120
- }
121
- styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;
122
- styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
123
- }
124
- this._cdr.markForCheck();
125
- }
126
- updatePartStr(v, isSelected) {
127
- let odd = false;
128
- if (v?.index !== undefined) {
129
- odd = v.index % 2 === 0;
130
- }
131
- let part = PART_DEFAULT_ITEM;
132
- part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;
133
- if (v ? v.config.snapped : false) {
134
- part += PART_ITEM_SNAPPED;
135
- }
136
- if (isSelected) {
137
- part += PART_ITEM_SELECTED;
138
- }
139
- this._part = part;
140
- }
141
- getBounds() {
142
- const el = this._elementRef.nativeElement, { width, height } = el.getBoundingClientRect();
143
- return { width, height };
144
- }
145
- show() {
146
- const styles = this._elementRef.nativeElement.style;
147
- if (this.regular) {
148
- if (styles.display === DISPLAY_BLOCK) {
149
- return;
150
- }
151
- styles.display = DISPLAY_BLOCK;
152
- }
153
- else {
154
- if (styles.visibility === VISIBILITY_VISIBLE) {
155
- return;
156
- }
157
- styles.visibility = VISIBILITY_VISIBLE;
158
- }
159
- styles.zIndex = this.data?.config?.zIndex ?? DEFAULT_ZINDEX;
160
- }
161
- hide() {
162
- const styles = this._elementRef.nativeElement.style;
163
- if (this.regular) {
164
- if (styles.display === DISPLAY_NONE) {
165
- return;
166
- }
167
- styles.display = DISPLAY_NONE;
168
- }
169
- else {
170
- if (styles.visibility === VISIBILITY_HIDDEN) {
171
- return;
172
- }
173
- styles.visibility = VISIBILITY_HIDDEN;
174
- }
175
- styles.position = POSITION_ABSOLUTE;
176
- styles.transform = ZEROS_TRANSLATE_3D;
177
- styles.zIndex = HIDDEN_ZINDEX;
178
- }
179
- onClickHandler() {
180
- this._service.itemClick(this.data);
181
- }
182
- ngOnDestroy() {
183
- if (this._$unsubscribe) {
184
- this._$unsubscribe.next();
185
- this._$unsubscribe.complete();
186
- }
187
- }
188
- }
189
- NgVirtualListItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: NgVirtualListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.NgVirtualListService }], target: i0.ɵɵFactoryTarget.Component });
190
- NgVirtualListItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, 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}\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 });
191
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: NgVirtualListItemComponent, decorators: [{
192
- type: Component,
193
- args: [{ selector: 'ng-virtual-list-item', host: {
194
- 'class': 'ngvl__item',
195
- 'role': 'listitem',
196
- }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"part\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, 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}\n"] }]
197
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.NgVirtualListService }]; } });
198
- //# 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":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAA2B,MAAM,eAAe,CAAC;AAG/G,OAAO,EACL,cAAc,EAAE,aAAa,EAAE,YAAY,EAAE,aAAa,EAAE,iBAAiB,EAAE,cAAc,EAAE,aAAa,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,eAAe,EAAE,EAAE,EAAE,gBAAgB,EAC7M,SAAS,EAAE,YAAY,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,kBAAkB,GACnF,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,4BAA4B,EAAE,MAAM,4CAA4C,CAAC;AAE1F,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/D,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;;;;AAE/E,MAAM,kBAAkB,GAAG,eAAe,CAAC;AAE3C;;;;;GAKG;AAWH,MAAM,OAAO,0BAA2B,SAAQ,4BAA4B;IAI1E,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAGD,IAAI,IAAI,KAAK,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAYjC,IAAI,IAAI,CAAC,CAAqC;QAC5C,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE;YACnB,OAAO;SACR;QAED,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QAEd,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAExC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAErB,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEpB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAGD,IAAI,aAAa,CAAC,CAAS;QACzB,IAAI,IAAI,CAAC,cAAc,KAAK,CAAC,EAAE;YAC7B,OAAO;SACR;QAED,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QAExB,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;IACvB,CAAC;IAID,IAAI,QAAQ,CAAC,CAA+B;QAC1C,IAAI,IAAI,CAAC,YAAY,KAAK,CAAC,EAAE;YAC3B,OAAO;SACR;QAED,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;QAEtB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;IACxC,CAAC;IAED,YAAoB,IAAuB,EAAU,WAAoC,EAAU,QAA8B;QAC/H,KAAK,EAAE,CAAC;QADU,SAAI,GAAJ,IAAI,CAAmB;QAAU,gBAAW,GAAX,WAAW,CAAyB;QAAU,aAAQ,GAAR,QAAQ,CAAsB;QA3EvH,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOtC,UAAK,GAAG,iBAAiB,CAAC;QAG1B,gBAAW,GAAY,KAAK,CAAC;QACrC,WAAM,GAAG,IAAI,eAAe,CAAuD,EAAS,CAAC,CAAC;QAE9F,YAAO,GAAY,KAAK,CAAC;QAIjB,WAAM,GAAG,IAAI,eAAe,CAAqC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5E,UAAK,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QAoBnC,mBAAc,GAAW,gBAAgB,CAAC;QAuChD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC;QAE/C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAEzB,aAAa,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CACvF,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,EAC7B,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EACzC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,EAAE;YACtB,QAAQ,MAAM,EAAE;gBACd,KAAK,wBAAwB,CAAC,MAAM,CAAC,CAAC;oBACpC,MAAM,EAAE,GAAG,GAAqB,EAAE,UAAU,GAAG,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC;oBAClE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,CAAC,kBAAkB,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;oBACpF,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;oBAC9B,MAAM;iBACP;gBACD,KAAK,wBAAwB,CAAC,YAAY,CAAC,CAAC;oBAC1C,MAAM,SAAS,GAAG,GAAgB,EAAE,UAAU,GAAG,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,SAAS,IAAI,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAC3H,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,CAAC,kBAAkB,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;oBACpF,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;oBAC9B,MAAM;iBACP;gBACD,KAAK,wBAAwB,CAAC,IAAI,CAAC;gBACnC,OAAO,CAAC,CAAC;oBACP,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;oBACnE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;oBACzB,MAAM;iBACP;aACF;YAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YAEhD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC,CAAC,CACH,CAAC,SAAS,EAAE,CAAC;IAChB,CAAC;IAEO,YAAY,CAAC,CAA0C;QAC7D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAS,CAAC,CAAC;IAC9E,CAAC;IAEO,MAAM;QACZ,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC;QAC7E,IAAI,IAAI,EAAE;YACR,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC;YACpD,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YACnC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;gBACvB,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,GAAG,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC;gBAAA,CAAC;gBACtM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,wBAAwB,EAAE;oBACzC,MAAM,CAAC,QAAQ,GAAG,eAAe,CAAC;iBACnC;aACF;iBAAM;gBACL,MAAM,CAAC,QAAQ,GAAG,iBAAiB,CAAC;gBACpC,IAAI,OAAO,EAAE;oBACX,MAAM,CAAC,SAAS,GAAG,GAAG,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC;iBAC9J;qBAAM;oBACL,MAAM,CAAC,SAAS,GAAG,GAAG,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC;iBACtJ;aACF;YACD,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,gBAAgB,CAAC;YAChJ,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,EAAE,EAAE,CAAC;SAC/I;QAED,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAEO,aAAa,CAAC,CAAqC,EAAE,UAAmB;QAC9E,IAAI,GAAG,GAAG,KAAK,CAAC;QAChB,IAAI,CAAC,EAAE,KAAK,KAAK,SAAS,EAAE;YAC1B,GAAG,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;SACzB;QAED,IAAI,IAAI,GAAG,iBAAiB,CAAC;QAC7B,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,cAAc,CAAC;QAC7C,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE;YAChC,IAAI,IAAI,iBAAiB,CAAC;SAC3B;QACD,IAAI,UAAU,EAAE;YACd,IAAI,IAAI,kBAAkB,CAAC;SAC5B;QACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,SAAS;QACP,MAAM,EAAE,GAAgB,IAAI,CAAC,WAAW,CAAC,aAAa,EACpD,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,qBAAqB,EAAE,CAAC;QACjD,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC;QACpD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,MAAM,CAAC,OAAO,KAAK,aAAa,EAAE;gBACpC,OAAO;aACR;YAED,MAAM,CAAC,OAAO,GAAG,aAAa,CAAC;SAChC;aAAM;YACL,IAAI,MAAM,CAAC,UAAU,KAAK,kBAAkB,EAAE;gBAC5C,OAAO;aACR;YAED,MAAM,CAAC,UAAU,GAAG,kBAAkB,CAAC;SACxC;QACD,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,IAAI,cAAc,CAAC;IAC9D,CAAC;IAED,IAAI;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC;QACpD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,MAAM,CAAC,OAAO,KAAK,YAAY,EAAE;gBACnC,OAAO;aACR;YAED,MAAM,CAAC,OAAO,GAAG,YAAY,CAAC;SAC/B;aAAM;YACL,IAAI,MAAM,CAAC,UAAU,KAAK,iBAAiB,EAAE;gBAC3C,OAAO;aACR;YAED,MAAM,CAAC,UAAU,GAAG,iBAAiB,CAAC;SACvC;QACD,MAAM,CAAC,QAAQ,GAAG,iBAAiB,CAAC;QACpC,MAAM,CAAC,SAAS,GAAG,kBAAkB,CAAC;QACtC,MAAM,CAAC,MAAM,GAAG,aAAa,CAAC;IAChC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;YAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;SAC/B;IACH,CAAC;;wHArNU,0BAA0B;4GAA1B,0BAA0B,+JChCvC,kgBAQe;4FDwBF,0BAA0B;kBAVtC,SAAS;+BACE,sBAAsB,QAG1B;wBACJ,OAAO,EAAE,YAAY;wBACrB,MAAM,EAAE,UAAU;qBACnB,mBACgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, TemplateRef } from '@angular/core';\r\nimport { IRenderVirtualListItem } from '../models/render-item.model';\r\nimport { Id, ISize } from '../types';\r\nimport {\r\n  DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_EVEN, 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, Subject } from 'rxjs';\r\nimport { IRenderVirtualListItemConfig } from '../models/render-item-config.model';\r\nimport { MethodsForSelectingTypes } from '../enums/method-for-selecting-types';\r\n\r\nconst ATTR_AREA_SELECTED = 'area-selected';\r\n\r\n/**\r\n * Virtual list item component\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/15.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  config = new BehaviorSubject<IRenderVirtualListItemConfig & { selected: boolean }>({} as any);\r\n\r\n  regular: boolean = false;\r\n\r\n  data: IRenderVirtualListItem | 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);\r\n\r\n    this.updateConfig(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  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\r\n    combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds]).pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      map(([, m, ids]) => ({ method: m, ids })),\r\n      tap(({ method, ids }) => {\r\n        switch (method) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const id = ids as Id | undefined, isSelected = id === this.itemId;\r\n            this._elementRef.nativeElement.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 = ids as Array<Id>, isSelected = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n            this._elementRef.nativeElement.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._elementRef.nativeElement.removeAttribute(ATTR_AREA_SELECTED);\r\n            this._isSelected = false;\r\n            break;\r\n          }\r\n        }\r\n\r\n        this.updatePartStr(this.data, this._isSelected);\r\n\r\n        this.updateConfig(this.data);\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  private updateConfig(v: IRenderVirtualListItem<any> | undefined) {\r\n    this.config.next({ ...v?.config || {}, selected: this._isSelected } as any);\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        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          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          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) {\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    this._part = 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\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n        'snapped-out': data.config.snappedOut}\" (click)=\"onClickHandler()\">\r\n        <ng-container *ngIf=\"itemRenderer\">\r\n            <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n                [ngTemplateOutletContext]=\"{data: data.data || {}, config: config | async}\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n</ng-container>"]}
@@ -1,51 +0,0 @@
1
- import { MethodsForSelecting, SnappingMethods } from "../enums";
2
- import { Directions } from "../enums/directions";
3
- export const DEFAULT_ITEM_SIZE = 24;
4
- export const DEFAULT_BUFFER_SIZE = 2;
5
- export const DEFAULT_MAX_BUFFER_SIZE = 100;
6
- export const DEFAULT_LIST_SIZE = 400;
7
- export const DEFAULT_SNAP = false;
8
- export const DEFAULT_ENABLED_BUFFER_OPTIMIZATION = false;
9
- export const DEFAULT_DYNAMIC_SIZE = false;
10
- export const TRACK_BY_PROPERTY_NAME = 'id';
11
- export const DEFAULT_DIRECTION = Directions.VERTICAL;
12
- export const DISPLAY_OBJECTS_LENGTH_MESUREMENT_ERROR = 1;
13
- export const MAX_SCROLL_TO_ITERATIONS = 5;
14
- export const DEFAULT_SNAPPING_METHOD = SnappingMethods.NORMAL;
15
- export const DEFAULT_SELECT_METHOD = MethodsForSelecting.NONE;
16
- // presets
17
- export const BEHAVIOR_AUTO = 'auto';
18
- export const BEHAVIOR_INSTANT = 'instant';
19
- export const BEHAVIOR_SMOOTH = 'smooth';
20
- export const DISPLAY_BLOCK = 'block';
21
- export const DISPLAY_NONE = 'none';
22
- export const OPACITY_0 = '0';
23
- export const OPACITY_100 = '100';
24
- export const VISIBILITY_VISIBLE = 'visible';
25
- export const VISIBILITY_HIDDEN = 'hidden';
26
- export const SIZE_100_PERSENT = '100%';
27
- export const SIZE_AUTO = 'auto';
28
- export const POSITION_ABSOLUTE = 'absolute';
29
- export const POSITION_STICKY = 'sticky';
30
- export const TRANSLATE_3D = 'translate3d';
31
- export const ZEROS_TRANSLATE_3D = `${TRANSLATE_3D}(0,0,0)`;
32
- export const HIDDEN_ZINDEX = '-1';
33
- export const DEFAULT_ZINDEX = '0';
34
- export const TOP_PROP_NAME = 'top';
35
- export const LEFT_PROP_NAME = 'left';
36
- export const X_PROP_NAME = 'x';
37
- export const Y_PROP_NAME = 'y';
38
- export const WIDTH_PROP_NAME = 'width';
39
- export const HEIGHT_PROP_NAME = 'height';
40
- export const PX = 'px';
41
- export const SCROLL = 'scroll';
42
- export const SCROLL_END = 'scrollend';
43
- export const CLASS_LIST_VERTICAL = 'vertical';
44
- export const CLASS_LIST_HORIZONTAL = 'horizontal';
45
- // styles
46
- export const PART_DEFAULT_ITEM = 'item';
47
- export const PART_ITEM_ODD = ' odd';
48
- export const PART_ITEM_EVEN = ' even';
49
- export const PART_ITEM_SNAPPED = ' snapped';
50
- export const PART_ITEM_SELECTED = ' selected';
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb25zdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVqRCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxFQUFFLENBQUM7QUFFcEMsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxDQUFDO0FBRXJDLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLEdBQUcsQ0FBQztBQUUzQyxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxHQUFHLENBQUM7QUFFckMsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLEtBQUssQ0FBQztBQUVsQyxNQUFNLENBQUMsTUFBTSxtQ0FBbUMsR0FBRyxLQUFLLENBQUM7QUFFekQsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsS0FBSyxDQUFDO0FBRTFDLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLElBQUksQ0FBQztBQUUzQyxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDO0FBRXJELE1BQU0sQ0FBQyxNQUFNLHVDQUF1QyxHQUFHLENBQUMsQ0FBQztBQUV6RCxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLENBQUM7QUFFMUMsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsZUFBZSxDQUFDLE1BQU0sQ0FBQztBQUU5RCxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxtQkFBbUIsQ0FBQyxJQUFJLENBQUM7QUFFOUQsVUFBVTtBQUVWLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUM7QUFFcEMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsU0FBUyxDQUFDO0FBRTFDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxRQUFRLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQztBQUVyQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDO0FBRW5DLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxHQUFHLENBQUM7QUFFN0IsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQztBQUVqQyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxTQUFTLENBQUM7QUFFNUMsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsUUFBUSxDQUFDO0FBRTFDLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQztBQUV2QyxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDO0FBRWhDLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLFVBQVUsQ0FBQztBQUU1QyxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsUUFBUSxDQUFDO0FBRXhDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUM7QUFFMUMsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxZQUFZLFNBQVMsQ0FBQztBQUUzRCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDO0FBRWxDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxHQUFHLENBQUM7QUFFbEMsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLEtBQUssQ0FBQztBQUVuQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDO0FBRXJDLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUM7QUFFL0IsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQztBQUUvQixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDO0FBRXZDLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLFFBQVEsQ0FBQztBQUV6QyxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDO0FBRXZCLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUM7QUFFL0IsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLFdBQVcsQ0FBQztBQUV0QyxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxVQUFVLENBQUM7QUFFOUMsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsWUFBWSxDQUFDO0FBRWxELFNBQVM7QUFFVCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxNQUFNLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUVwQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDO0FBRXRDLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLFVBQVUsQ0FBQztBQUU1QyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNZXRob2RzRm9yU2VsZWN0aW5nLCBTbmFwcGluZ01ldGhvZHMgfSBmcm9tIFwiLi4vZW51bXNcIjtcclxuaW1wb3J0IHsgRGlyZWN0aW9ucyB9IGZyb20gXCIuLi9lbnVtcy9kaXJlY3Rpb25zXCI7XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9JVEVNX1NJWkUgPSAyNDtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0JVRkZFUl9TSVpFID0gMjtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX01BWF9CVUZGRVJfU0laRSA9IDEwMDtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0xJU1RfU0laRSA9IDQwMDtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX1NOQVAgPSBmYWxzZTtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0VOQUJMRURfQlVGRkVSX09QVElNSVpBVElPTiA9IGZhbHNlO1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfRFlOQU1JQ19TSVpFID0gZmFsc2U7XHJcblxyXG5leHBvcnQgY29uc3QgVFJBQ0tfQllfUFJPUEVSVFlfTkFNRSA9ICdpZCc7XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9ESVJFQ1RJT04gPSBEaXJlY3Rpb25zLlZFUlRJQ0FMO1xyXG5cclxuZXhwb3J0IGNvbnN0IERJU1BMQVlfT0JKRUNUU19MRU5HVEhfTUVTVVJFTUVOVF9FUlJPUiA9IDE7XHJcblxyXG5leHBvcnQgY29uc3QgTUFYX1NDUk9MTF9UT19JVEVSQVRJT05TID0gNTtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX1NOQVBQSU5HX01FVEhPRCA9IFNuYXBwaW5nTWV0aG9kcy5OT1JNQUw7XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9TRUxFQ1RfTUVUSE9EID0gTWV0aG9kc0ZvclNlbGVjdGluZy5OT05FO1xyXG5cclxuLy8gcHJlc2V0c1xyXG5cclxuZXhwb3J0IGNvbnN0IEJFSEFWSU9SX0FVVE8gPSAnYXV0byc7XHJcblxyXG5leHBvcnQgY29uc3QgQkVIQVZJT1JfSU5TVEFOVCA9ICdpbnN0YW50JztcclxuXHJcbmV4cG9ydCBjb25zdCBCRUhBVklPUl9TTU9PVEggPSAnc21vb3RoJztcclxuXHJcbmV4cG9ydCBjb25zdCBESVNQTEFZX0JMT0NLID0gJ2Jsb2NrJztcclxuXHJcbmV4cG9ydCBjb25zdCBESVNQTEFZX05PTkUgPSAnbm9uZSc7XHJcblxyXG5leHBvcnQgY29uc3QgT1BBQ0lUWV8wID0gJzAnO1xyXG5cclxuZXhwb3J0IGNvbnN0IE9QQUNJVFlfMTAwID0gJzEwMCc7XHJcblxyXG5leHBvcnQgY29uc3QgVklTSUJJTElUWV9WSVNJQkxFID0gJ3Zpc2libGUnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFZJU0lCSUxJVFlfSElEREVOID0gJ2hpZGRlbic7XHJcblxyXG5leHBvcnQgY29uc3QgU0laRV8xMDBfUEVSU0VOVCA9ICcxMDAlJztcclxuXHJcbmV4cG9ydCBjb25zdCBTSVpFX0FVVE8gPSAnYXV0byc7XHJcblxyXG5leHBvcnQgY29uc3QgUE9TSVRJT05fQUJTT0xVVEUgPSAnYWJzb2x1dGUnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFBPU0lUSU9OX1NUSUNLWSA9ICdzdGlja3knO1xyXG5cclxuZXhwb3J0IGNvbnN0IFRSQU5TTEFURV8zRCA9ICd0cmFuc2xhdGUzZCc7XHJcblxyXG5leHBvcnQgY29uc3QgWkVST1NfVFJBTlNMQVRFXzNEID0gYCR7VFJBTlNMQVRFXzNEfSgwLDAsMClgO1xyXG5cclxuZXhwb3J0IGNvbnN0IEhJRERFTl9aSU5ERVggPSAnLTEnO1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfWklOREVYID0gJzAnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFRPUF9QUk9QX05BTUUgPSAndG9wJztcclxuXHJcbmV4cG9ydCBjb25zdCBMRUZUX1BST1BfTkFNRSA9ICdsZWZ0JztcclxuXHJcbmV4cG9ydCBjb25zdCBYX1BST1BfTkFNRSA9ICd4JztcclxuXHJcbmV4cG9ydCBjb25zdCBZX1BST1BfTkFNRSA9ICd5JztcclxuXHJcbmV4cG9ydCBjb25zdCBXSURUSF9QUk9QX05BTUUgPSAnd2lkdGgnO1xyXG5cclxuZXhwb3J0IGNvbnN0IEhFSUdIVF9QUk9QX05BTUUgPSAnaGVpZ2h0JztcclxuXHJcbmV4cG9ydCBjb25zdCBQWCA9ICdweCc7XHJcblxyXG5leHBvcnQgY29uc3QgU0NST0xMID0gJ3Njcm9sbCc7XHJcblxyXG5leHBvcnQgY29uc3QgU0NST0xMX0VORCA9ICdzY3JvbGxlbmQnO1xyXG5cclxuZXhwb3J0IGNvbnN0IENMQVNTX0xJU1RfVkVSVElDQUwgPSAndmVydGljYWwnO1xyXG5cclxuZXhwb3J0IGNvbnN0IENMQVNTX0xJU1RfSE9SSVpPTlRBTCA9ICdob3Jpem9udGFsJztcclxuXHJcbi8vIHN0eWxlc1xyXG5cclxuZXhwb3J0IGNvbnN0IFBBUlRfREVGQVVMVF9JVEVNID0gJ2l0ZW0nO1xyXG5cclxuZXhwb3J0IGNvbnN0IFBBUlRfSVRFTV9PREQgPSAnIG9kZCc7XHJcblxyXG5leHBvcnQgY29uc3QgUEFSVF9JVEVNX0VWRU4gPSAnIGV2ZW4nO1xyXG5cclxuZXhwb3J0IGNvbnN0IFBBUlRfSVRFTV9TTkFQUEVEID0gJyBzbmFwcGVkJztcclxuXHJcbmV4cG9ydCBjb25zdCBQQVJUX0lURU1fU0VMRUNURUQgPSAnIHNlbGVjdGVkJztcclxuXHJcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvZW51bXMvZGlyZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3Rpb25zIH0gZnJvbSBcIi4vZGlyZWN0aW9uc1wiO1xyXG5cclxuLyoqXHJcbiAqIEF4aXMgb2YgdGhlIGFycmFuZ2VtZW50IG9mIHZpcnR1YWwgbGlzdCBlbGVtZW50cy5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTUueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9kaXJlY3Rpb24udHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IHR5cGUgRGlyZWN0aW9uID0gRGlyZWN0aW9ucyB8ICdob3Jpem9udGFsJyB8ICd2ZXJ0aWNhbCc7XHJcbiJdfQ==
@@ -1,18 +0,0 @@
1
- /**
2
- * Axis of the arrangement of virtual list elements.
3
- * @link https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/enums/directions.ts
4
- * @author Evgenii Grebennikov
5
- * @email djonnyx@gmail.com
6
- */
7
- export var Directions;
8
- (function (Directions) {
9
- /**
10
- * Horizontal axis.
11
- */
12
- Directions["HORIZONTAL"] = "horizontal";
13
- /**
14
- * Vertical axis.
15
- */
16
- Directions["VERTICAL"] = "vertical";
17
- })(Directions || (Directions = {}));
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL2RpcmVjdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQU4sSUFBWSxVQVNYO0FBVEQsV0FBWSxVQUFVO0lBQ2xCOztPQUVHO0lBQ0gsdUNBQXlCLENBQUE7SUFDekI7O09BRUc7SUFDSCxtQ0FBcUIsQ0FBQTtBQUN6QixDQUFDLEVBVFcsVUFBVSxLQUFWLFVBQVUsUUFTckIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQXhpcyBvZiB0aGUgYXJyYW5nZW1lbnQgb2YgdmlydHVhbCBsaXN0IGVsZW1lbnRzLlxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNS54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL2RpcmVjdGlvbnMudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IGVudW0gRGlyZWN0aW9ucyB7XHJcbiAgICAvKipcclxuICAgICAqIEhvcml6b250YWwgYXhpcy5cclxuICAgICAqL1xyXG4gICAgSE9SSVpPTlRBTCA9ICdob3Jpem9udGFsJyxcclxuICAgIC8qKlxyXG4gICAgICogVmVydGljYWwgYXhpcy5cclxuICAgICAqL1xyXG4gICAgVkVSVElDQUwgPSAndmVydGljYWwnLFxyXG59Il19
@@ -1,5 +0,0 @@
1
- import { Directions } from "./directions";
2
- import { MethodsForSelecting } from "./methods-for-selecting";
3
- import { SnappingMethods } from "./snapping-methods";
4
- export { Directions, MethodsForSelecting, SnappingMethods, };
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRTFDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRTlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUdyRCxPQUFPLEVBQ0gsVUFBVSxFQUNWLG1CQUFtQixFQUNuQixlQUFlLEdBQ2xCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3Rpb25zIH0gZnJvbSBcIi4vZGlyZWN0aW9uc1wiO1xyXG5pbXBvcnQgeyBEaXJlY3Rpb24gfSBmcm9tIFwiLi9kaXJlY3Rpb25cIjtcclxuaW1wb3J0IHsgTWV0aG9kc0ZvclNlbGVjdGluZyB9IGZyb20gXCIuL21ldGhvZHMtZm9yLXNlbGVjdGluZ1wiO1xyXG5pbXBvcnQgeyBNZXRob2RGb3JTZWxlY3RpbmcgfSBmcm9tIFwiLi9tZXRob2QtZm9yLXNlbGVjdGluZ1wiO1xyXG5pbXBvcnQgeyBTbmFwcGluZ01ldGhvZHMgfSBmcm9tIFwiLi9zbmFwcGluZy1tZXRob2RzXCI7XHJcbmltcG9ydCB7IFNuYXBwaW5nTWV0aG9kIH0gZnJvbSBcIi4vc25hcHBpbmctbWV0aG9kXCI7XHJcblxyXG5leHBvcnQge1xyXG4gICAgRGlyZWN0aW9ucyxcclxuICAgIE1ldGhvZHNGb3JTZWxlY3RpbmcsXHJcbiAgICBTbmFwcGluZ01ldGhvZHMsXHJcbn07XHJcbmV4cG9ydCB0eXBlIHtcclxuICAgIERpcmVjdGlvbixcclxuICAgIE1ldGhvZEZvclNlbGVjdGluZyxcclxuICAgIFNuYXBwaW5nTWV0aG9kLFxyXG59O1xyXG4iXX0=
@@ -1,22 +0,0 @@
1
- /**
2
- * Methods for selecting list items.
3
- * @link https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/enums/method-for-selecting-types.ts
4
- * @author Evgenii Grebennikov
5
- * @email djonnyx@gmail.com
6
- */
7
- export var MethodsForSelectingTypes;
8
- (function (MethodsForSelectingTypes) {
9
- /**
10
- * List items are not selectable.
11
- */
12
- MethodsForSelectingTypes[MethodsForSelectingTypes["NONE"] = 0] = "NONE";
13
- /**
14
- * List items are selected one by one.
15
- */
16
- MethodsForSelectingTypes[MethodsForSelectingTypes["SELECT"] = 1] = "SELECT";
17
- /**
18
- * Multiple selection of list items.
19
- */
20
- MethodsForSelectingTypes[MethodsForSelectingTypes["MULTI_SELECT"] = 2] = "MULTI_SELECT";
21
- })(MethodsForSelectingTypes || (MethodsForSelectingTypes = {}));
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0aG9kLWZvci1zZWxlY3RpbmctdHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9tZXRob2QtZm9yLXNlbGVjdGluZy10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBTixJQUFZLHdCQWFYO0FBYkQsV0FBWSx3QkFBd0I7SUFDaEM7O09BRUc7SUFDSCx1RUFBUSxDQUFBO0lBQ1I7O09BRUc7SUFDSCwyRUFBVSxDQUFBO0lBQ1Y7O09BRUc7SUFDSCx1RkFBZ0IsQ0FBQTtBQUNwQixDQUFDLEVBYlcsd0JBQXdCLEtBQXhCLHdCQUF3QixRQWFuQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBNZXRob2RzIGZvciBzZWxlY3RpbmcgbGlzdCBpdGVtcy5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTUueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9tZXRob2QtZm9yLXNlbGVjdGluZy10eXBlcy50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgZW51bSBNZXRob2RzRm9yU2VsZWN0aW5nVHlwZXMge1xyXG4gICAgLyoqXHJcbiAgICAgKiBMaXN0IGl0ZW1zIGFyZSBub3Qgc2VsZWN0YWJsZS5cclxuICAgICAqL1xyXG4gICAgTk9ORSA9IDAsXHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbXMgYXJlIHNlbGVjdGVkIG9uZSBieSBvbmUuXHJcbiAgICAgKi9cclxuICAgIFNFTEVDVCA9IDEsXHJcbiAgICAvKipcclxuICAgICAqIE11bHRpcGxlIHNlbGVjdGlvbiBvZiBsaXN0IGl0ZW1zLlxyXG4gICAgICovXHJcbiAgICBNVUxUSV9TRUxFQ1QgPSAyLFxyXG59Il19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0aG9kLWZvci1zZWxlY3RpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9tZXRob2QtZm9yLXNlbGVjdGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWV0aG9kc0ZvclNlbGVjdGluZyB9IGZyb20gXCIuL21ldGhvZHMtZm9yLXNlbGVjdGluZ1wiO1xyXG5cclxuLyoqXHJcbiAqIE1ldGhvZHMgZm9yIHNlbGVjdGluZyBsaXN0IGl0ZW1zLlxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNS54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL21ldGhvZC1mb3Itc2VsZWN0aW5nLnRzXHJcbiAqIEBhdXRob3IgRXZnZW5paSBHcmViZW5uaWtvdlxyXG4gKiBAZW1haWwgZGpvbm55eEBnbWFpbC5jb21cclxuICovXHJcbmV4cG9ydCB0eXBlIE1ldGhvZEZvclNlbGVjdGluZyA9IE1ldGhvZHNGb3JTZWxlY3RpbmcgfCAnbm9uZScgfCAnc2VsZWN0JyB8ICdtdWx0aS1zZWxlY3QnO1xyXG4iXX0=