ng-virtual-list 15.0.15 → 16.0.0

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 (82) hide show
  1. package/README.md +75 -72
  2. package/esm2022/lib/components/ng-virtual-list-item.component.mjs +84 -0
  3. package/esm2022/lib/const/index.mjs +34 -0
  4. package/{esm2020 → esm2022}/lib/enums/direction.mjs +2 -2
  5. package/{esm2020 → esm2022}/lib/enums/directions.mjs +18 -18
  6. package/{esm2020 → esm2022}/lib/enums/index.mjs +2 -2
  7. package/{esm2020 → esm2022}/lib/models/collection.model.mjs +3 -3
  8. package/esm2022/lib/models/index.mjs +2 -0
  9. package/{esm2020 → esm2022}/lib/models/item.model.mjs +3 -3
  10. package/{esm2020 → esm2022}/lib/models/render-collection.model.mjs +3 -3
  11. package/{esm2020 → esm2022}/lib/models/render-item-config.model.mjs +2 -2
  12. package/{esm2020 → esm2022}/lib/models/render-item.model.mjs +3 -3
  13. package/{esm2020 → esm2022}/lib/models/sticky-map.model.mjs +2 -2
  14. package/esm2022/lib/ng-virtual-list.component.mjs +516 -0
  15. package/{esm2020 → esm2022}/lib/ng-virtual-list.module.mjs +20 -20
  16. package/{esm2020 → esm2022}/lib/types/id.mjs +2 -2
  17. package/{esm2020 → esm2022}/lib/types/index.mjs +1 -1
  18. package/{esm2020 → esm2022}/lib/types/rect.mjs +2 -2
  19. package/{esm2020 → esm2022}/lib/types/size.mjs +2 -2
  20. package/esm2022/lib/utils/cacheMap.mjs +52 -0
  21. package/{esm2020 → esm2022}/lib/utils/debounce.mjs +31 -31
  22. package/esm2022/lib/utils/eventEmitter.mjs +105 -0
  23. package/esm2022/lib/utils/index.mjs +7 -0
  24. package/{esm2020 → esm2022}/lib/utils/isDirection.mjs +15 -15
  25. package/{esm2020 → esm2022}/lib/utils/toggleClassName.mjs +15 -15
  26. package/esm2022/lib/utils/trackBox.mjs +355 -0
  27. package/esm2022/lib/utils/tracker.mjs +109 -0
  28. package/{esm2020 → esm2022}/ng-virtual-list.mjs +4 -4
  29. package/{esm2020 → esm2022}/public-api.mjs +7 -7
  30. package/fesm2022/ng-virtual-list.mjs +1346 -0
  31. package/fesm2022/ng-virtual-list.mjs.map +1 -0
  32. package/index.d.ts +5 -5
  33. package/lib/components/ng-virtual-list-item.component.d.ts +28 -30
  34. package/lib/const/index.d.ts +32 -33
  35. package/lib/enums/direction.d.ts +8 -8
  36. package/lib/enums/directions.d.ts +16 -16
  37. package/lib/enums/index.d.ts +4 -4
  38. package/lib/models/collection.model.d.ts +9 -9
  39. package/lib/models/index.d.ts +4 -6
  40. package/lib/models/item.model.d.ts +14 -14
  41. package/lib/models/render-collection.model.d.ts +9 -9
  42. package/lib/models/render-item-config.model.d.ts +33 -33
  43. package/lib/models/render-item.model.d.ts +28 -28
  44. package/lib/models/sticky-map.model.d.ts +12 -12
  45. package/lib/ng-virtual-list.component.d.ts +150 -162
  46. package/lib/ng-virtual-list.module.d.ts +9 -9
  47. package/lib/types/id.d.ts +7 -7
  48. package/lib/types/index.d.ts +4 -4
  49. package/lib/types/rect.d.ts +17 -17
  50. package/lib/types/size.d.ts +16 -16
  51. package/lib/utils/cacheMap.d.ts +34 -52
  52. package/lib/utils/debounce.d.ts +16 -16
  53. package/lib/utils/eventEmitter.d.ts +40 -40
  54. package/lib/utils/index.d.ts +6 -7
  55. package/lib/utils/isDirection.d.ts +8 -8
  56. package/lib/utils/toggleClassName.d.ts +7 -7
  57. package/lib/utils/trackBox.d.ts +113 -177
  58. package/lib/utils/tracker.d.ts +38 -44
  59. package/package.json +7 -13
  60. package/public-api.d.ts +4 -4
  61. package/LICENSE +0 -21
  62. package/esm2020/lib/components/ng-virtual-list-item.component.mjs +0 -86
  63. package/esm2020/lib/const/index.mjs +0 -35
  64. package/esm2020/lib/models/index.mjs +0 -2
  65. package/esm2020/lib/models/scroll-direction.model.mjs +0 -2
  66. package/esm2020/lib/models/scroll-event.model.mjs +0 -2
  67. package/esm2020/lib/ng-virtual-list.component.mjs +0 -508
  68. package/esm2020/lib/utils/cacheMap.mjs +0 -133
  69. package/esm2020/lib/utils/disposableComponent.mjs +0 -29
  70. package/esm2020/lib/utils/eventEmitter.mjs +0 -106
  71. package/esm2020/lib/utils/index.mjs +0 -8
  72. package/esm2020/lib/utils/scrollEvent.mjs +0 -42
  73. package/esm2020/lib/utils/trackBox.mjs +0 -627
  74. package/esm2020/lib/utils/tracker.mjs +0 -92
  75. package/fesm2015/ng-virtual-list.mjs +0 -1735
  76. package/fesm2015/ng-virtual-list.mjs.map +0 -1
  77. package/fesm2020/ng-virtual-list.mjs +0 -1744
  78. package/fesm2020/ng-virtual-list.mjs.map +0 -1
  79. package/lib/models/scroll-direction.model.d.ts +0 -5
  80. package/lib/models/scroll-event.model.d.ts +0 -50
  81. package/lib/utils/disposableComponent.d.ts +0 -15
  82. package/lib/utils/scrollEvent.d.ts +0 -39
package/README.md CHANGED
@@ -1,7 +1,7 @@
1
1
  # NgVirtualList
2
2
  Maximum performance for extremely large lists.
3
3
 
4
- Angular version 15.X.X.
4
+ Angular version 16.X.X.
5
5
 
6
6
  ![intro](https://github.com/user-attachments/assets/80fbed6c-9f77-48c3-a7a6-2cedf32aebc2)
7
7
 
@@ -27,9 +27,11 @@ Template:
27
27
  [itemRenderer]="hotizontalItemRenderer" [itemSize]="64"></ng-virtual-list>
28
28
 
29
29
  <ng-template #hotizontalItemRenderer let-data="data">
30
- <div *ngIf="data" class="list__h-container" (click)="onItemClick(data)">
30
+ @if (data) {
31
+ <div class="list__h-container" (click)="onItemClick(data)">
31
32
  <span>{{data.name}}</span>
32
33
  </div>
34
+ }
33
35
  </ng-template>
34
36
  ```
35
37
 
@@ -63,14 +65,20 @@ Template:
63
65
  [itemsOffset]="50" [stickyMap]="horizontalGroupItemsStickyMap" [itemSize]="54" [snap]="true"></ng-virtual-list>
64
66
 
65
67
  <ng-template #horizontalGroupItemRenderer let-data="data">
66
- <ng-container *ngIf="data" [ngSwitch]="data.type">
67
- <div *ngSwitchCase="'group-header'" class="list__h-group-container">
68
- <span>{{data.name}}</span>
69
- </div>
70
- <div *ngSwitchCase="'item'" class="list__h-container" (click)="onItemClick(data)">
71
- <span>{{data.name}}</span>
72
- </div>
73
- </ng-container>
68
+ @if (data) {
69
+ @switch (data.type) {
70
+ @case ("group-header") {
71
+ <div class="list__h-group-container">
72
+ <span>{{data.name}}</span>
73
+ </div>
74
+ }
75
+ @default {
76
+ <div class="list__h-container" (click)="onItemClick(data)">
77
+ <span>{{data.name}}</span>
78
+ </div>
79
+ }
80
+ }
81
+ }
74
82
  </ng-template>
75
83
  ```
76
84
 
@@ -115,9 +123,11 @@ Template:
115
123
  [itemSize]="40"></ng-virtual-list>
116
124
 
117
125
  <ng-template #itemRenderer let-data="data">
118
- <div *ngIf="data" class="list__container">
119
- <span>{{data.name}}</span>
126
+ @if (data) {
127
+ <div class="list__container">
128
+ <p>{{data.name}}</p>
120
129
  </div>
130
+ }
121
131
  </ng-template>
122
132
  ```
123
133
 
@@ -154,14 +164,20 @@ Template:
154
164
  [stickyMap]="groupItemsStickyMap" [itemSize]="40" [snap]="false"></ng-virtual-list>
155
165
 
156
166
  <ng-template #groupItemRenderer let-data="data">
157
- <ng-container *ngIf="data" [ngSwitch]="data.type">
158
- <div *ngSwitchCase="'group-header'" class="list__group-container">
159
- <span>{{data.name}}</span>
160
- </div>
161
- <div *ngSwitchCase="'item'" class="list__container">
162
- <span>{{data.name}}</span>
163
- </div>
164
- </ng-container>
167
+ @if (data) {
168
+ @switch (data.type) {
169
+ @case ("group-header") {
170
+ <div class="list__group-container">
171
+ <p>{{data.name}}</p>
172
+ </div>
173
+ }
174
+ @default {
175
+ <div class="list__container">
176
+ <p>{{data.name}}</p>
177
+ </div>
178
+ }
179
+ }
180
+ }
165
181
  </ng-template>
166
182
  ```
167
183
 
@@ -175,14 +191,20 @@ Template (with snapping):
175
191
  [stickyMap]="groupItemsStickyMap" [itemSize]="40" [snap]="true"></ng-virtual-list>
176
192
 
177
193
  <ng-template #groupItemRenderer let-data="data">
178
- <ng-container *ngIf="data" [ngSwitch]="data.type">
179
- <div *ngSwitchCase="'group-header'" class="list__group-container">
180
- <span>{{data.name}}</span>
181
- </div>
182
- <div *ngSwitchCase="'item'" class="list__container">
183
- <span>{{data.name}}</span>
184
- </div>
185
- </ng-container>
194
+ @if (data) {
195
+ @switch (data.type) {
196
+ @case ("group-header") {
197
+ <div class="list__group-container">
198
+ <p>{{data.name}}</p>
199
+ </div>
200
+ }
201
+ @default {
202
+ <div class="list__container">
203
+ <p>{{data.name}}</p>
204
+ </div>
205
+ }
206
+ }
207
+ }
186
208
  </ng-template>
187
209
  ```
188
210
 
@@ -234,9 +256,11 @@ Template
234
256
  [itemSize]="40"></ng-virtual-list>
235
257
 
236
258
  <ng-template #itemRenderer let-data="data">
237
- <div *ngIf="data" class="list__container">
259
+ @if (data) {
260
+ <div class="list__container">
238
261
  <span>{{data.name}}</span>
239
262
  </div>
263
+ }
240
264
  </ng-template>
241
265
  ```
242
266
 
@@ -286,14 +310,20 @@ Template
286
310
  [stickyMap]="groupDynamicItemsStickyMap" [dynamicSize]="true" [snap]="true"></ng-virtual-list>
287
311
 
288
312
  <ng-template #groupItemRenderer let-data="data">
289
- <ng-container *ngIf="data" [ngSwitch]="data.type">
290
- <div *ngSwitchCase="'group-header'" class="list__group-container">
291
- <span>{{data.name}}</span>
292
- </div>
293
- <div *ngSwitchCase="'item'" class="list__container">
294
- <span>{{data.name}}</span>
295
- </div>
296
- </ng-container>
313
+ @if (data) {
314
+ @switch (data.type) {
315
+ @case ("group-header") {
316
+ <div class="list__group-container">
317
+ <span>{{data.name}}</span>
318
+ </div>
319
+ }
320
+ @default {
321
+ <div class="list__container">
322
+ <span>{{data.name}}</span>
323
+ </div>
324
+ }
325
+ }
326
+ }
297
327
  </ng-template>
298
328
  ```
299
329
 
@@ -405,23 +435,22 @@ List items are encapsulated in shadowDOM, so to override default styles you need
405
435
 
406
436
  ## API
407
437
 
408
- [NgVirtualListComponent](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/ng-virtual-list.component.ts)
438
+ [NgVirtualListComponent](https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/ng-virtual-list.component.ts)
409
439
 
410
440
  Inputs
411
441
 
412
442
  | Property | Type | Description |
413
443
  |---|---|---|
414
444
  | id | number | Readonly. Returns the unique identifier of the component. |
415
- | items | [IVirtualListCollection](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/models/collection.model.ts) | Collection of list items. The collection of elements must be immutable. |
445
+ | items | [IVirtualListCollection](https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/models/collection.model.ts) | Collection of list items. |
416
446
  | itemSize | number? = 24 | If direction = 'vertical', then the height of a typical element. If direction = 'horizontal', then the width of a typical element. Ignored if the dynamicSize property is true. |
417
447
  | itemsOffset | number? = 2 | Number of elements outside the scope of visibility. Default value is 2. |
418
448
  | itemRenderer | TemplateRef | Rendering element template. |
419
- | stickyMap | [IVirtualListStickyMap?](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/models/sticky-map.model.ts) | Dictionary zIndex by id of the list element. If the value is not set or equal to 0, then a simple element is displayed, if the value is greater than 0, then the sticky position mode is enabled for the element. |
449
+ | stickyMap | [IVirtualListStickyMap?](https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/models/sticky-map.model.ts) | Dictionary zIndex by id of the list element. If the value is not set or equal to 0, then a simple element is displayed, if the value is greater than 0, then the sticky position mode is enabled for the element. |
420
450
  | snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
421
- | direction | [Direction? = 'vertical'](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/enums/direction.ts) | Determines the direction in which elements are placed. Default value is "vertical". |
451
+ | snapToItem | boolean? = false | Determines whether scroll positions will be snapped to the element. Default value is "false". |
452
+ | direction | [Direction? = 'vertical'](https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/enums/direction.ts) | Determines the direction in which elements are placed. Default value is "vertical". |
422
453
  | dynamicSize | boolean? = false | If true then the items in the list can have different sizes and the itemSize property is ignored. If false then the items in the list have a fixed size specified by the itemSize property. The default value is false. |
423
- | enabledBufferOptimization | boolean? = true | Experimental! Enables buffer optimization. Can only be used if items in the collection are not added or updated. |
424
- | trackBy | string? = 'id' | The name of the property by which tracking is performed. |
425
454
 
426
455
  <br/>
427
456
 
@@ -429,8 +458,8 @@ Outputs
429
458
 
430
459
  | Event | Type | Description |
431
460
  |---|---|---|
432
- | onScroll | ([IScrollEvent](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/models/scroll-event.model.ts)) => void | Fires when the list has been scrolled. |
433
- | onScrollEnd | ([IScrollEvent](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/models/scroll-event.model.ts)) => void | Fires when the list has completed scrolling. |
461
+ | onScroll | (scrollSize: number) => void | Fires when the list has been scrolled. |
462
+ | onScrollEnd | (scrollSize: number) => void | Fires when the list has completed scrolling. |
434
463
 
435
464
  <br/>
436
465
 
@@ -438,30 +467,4 @@ Methods
438
467
 
439
468
  | Method | Type | Description |
440
469
  |--|--|--|
441
- | scrollTo | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/15.x/projects/ng-virtual-list/src/lib/types/id.ts), behavior: ScrollBehavior = 'auto') => number | The method scrolls the list to the element with the given id and returns the value of the scrolled area. Behavior accepts the values ​​"auto", "instant" and "smooth". |
442
-
443
- <br/>
444
-
445
- ## License
446
-
447
- MIT License
448
-
449
- Copyright (c) 2025 Evgenii Grebennikov
450
-
451
- Permission is hereby granted, free of charge, to any person obtaining a copy
452
- of this software and associated documentation files (the "Software"), to deal
453
- in the Software without restriction, including without limitation the rights
454
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
455
- copies of the Software, and to permit persons to whom the Software is
456
- furnished to do so, subject to the following conditions:
457
-
458
- The above copyright notice and this permission notice shall be included in all
459
- copies or substantial portions of the Software.
460
-
461
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
462
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
463
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
464
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
465
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
466
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
467
- SOFTWARE.
470
+ | scrollTo | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/types/id.ts), behavior: ScrollBehavior = 'auto') => number | The method scrolls the list to the element with the given id and returns the value of the scrolled area. Behavior accepts the values ​​"auto", "instant" and "smooth". |
@@ -0,0 +1,84 @@
1
+ import { ChangeDetectionStrategy, Component, ElementRef, inject } from '@angular/core';
2
+ import { POSITION_ABSOLUTE, POSITION_STICKY, PX, SIZE_100_PERSENT, SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE, ZEROS_TRANSLATE_3D, } from '../const';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ /**
6
+ * Virtual list item component
7
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts
8
+ * @author Evgenii Grebennikov
9
+ * @email djonnyx@gmail.com
10
+ */
11
+ export class NgVirtualListItemComponent {
12
+ _cdr;
13
+ static __nextId = 0;
14
+ _id;
15
+ get id() {
16
+ return this._id;
17
+ }
18
+ data;
19
+ set item(v) {
20
+ if (this.data === v) {
21
+ return;
22
+ }
23
+ const data = this.data = v;
24
+ if (data) {
25
+ const styles = this._elementRef.nativeElement.style;
26
+ styles.zIndex = data.config.sticky;
27
+ if (data.config.snapped) {
28
+ styles.transform = ZEROS_TRANSLATE_3D;
29
+ styles.position = POSITION_STICKY;
30
+ }
31
+ else {
32
+ styles.position = POSITION_ABSOLUTE;
33
+ styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;
34
+ }
35
+ styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : SIZE_100_PERSENT;
36
+ styles.width = data.config.isVertical ? SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
37
+ }
38
+ this._cdr.detectChanges();
39
+ }
40
+ get itemId() {
41
+ return this.data?.id;
42
+ }
43
+ itemRenderer;
44
+ set renderer(v) {
45
+ if (this.itemRenderer === v) {
46
+ return;
47
+ }
48
+ this.itemRenderer = v;
49
+ this._cdr.markForCheck();
50
+ }
51
+ _elementRef = inject((ElementRef));
52
+ constructor(_cdr) {
53
+ this._cdr = _cdr;
54
+ this._id = NgVirtualListItemComponent.__nextId = NgVirtualListItemComponent.__nextId === Number.MAX_SAFE_INTEGER
55
+ ? 0 : NgVirtualListItemComponent.__nextId + 1;
56
+ }
57
+ getBounds() {
58
+ const el = this._elementRef.nativeElement, { width, height, left, top } = el.getBoundingClientRect();
59
+ return { width, height, x: left, y: top };
60
+ }
61
+ showIfNeed() {
62
+ const styles = this._elementRef.nativeElement.style;
63
+ if (styles.visibility === VISIBILITY_VISIBLE) {
64
+ return;
65
+ }
66
+ styles.visibility = VISIBILITY_VISIBLE;
67
+ }
68
+ hide() {
69
+ const styles = this._elementRef.nativeElement.style;
70
+ if (styles.visibility === VISIBILITY_HIDDEN) {
71
+ return;
72
+ }
73
+ styles.visibility = VISIBILITY_HIDDEN;
74
+ }
75
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
76
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { classAttribute: "ngvl__item" }, ngImport: i0, template: "<ng-container *ngIf=\"data\">\r\n <li #listItem part=\"item\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut}\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, config: data.config}\" />\r\n </ng-container>\r\n </li>\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: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
77
+ }
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, decorators: [{
79
+ type: Component,
80
+ args: [{ selector: 'ng-virtual-list-item', standalone: false, host: {
81
+ 'class': 'ngvl__item',
82
+ }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"data\">\r\n <li #listItem part=\"item\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut}\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, config: data.config}\" />\r\n </ng-container>\r\n </li>\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"] }]
83
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; } });
84
+ //# 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, inject, TemplateRef } from '@angular/core';\r\nimport { IRenderVirtualListItem } from '../models/render-item.model';\r\nimport { IRect } from '../types';\r\nimport {\r\n  POSITION_ABSOLUTE, POSITION_STICKY, PX, SIZE_100_PERSENT, SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN,\r\n  VISIBILITY_VISIBLE, ZEROS_TRANSLATE_3D,\r\n} from '../const';\r\n\r\n/**\r\n * Virtual list item component\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/main/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  standalone: false,\r\n  host: {\r\n    'class': 'ngvl__item',\r\n  },\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NgVirtualListItemComponent {\r\n  private static __nextId: number = 0;\r\n\r\n  private _id!: number;\r\n  get id() {\r\n    return this._id;\r\n  }\r\n\r\n  data: IRenderVirtualListItem | undefined;\r\n\r\n  set item(v: IRenderVirtualListItem | undefined) {\r\n    if (this.data === v) {\r\n      return;\r\n    }\r\n\r\n    const data = this.data = v;\r\n\r\n    if (data) {\r\n      const styles = this._elementRef.nativeElement.style;\r\n      styles.zIndex = data.config.sticky;\r\n      if (data.config.snapped) {\r\n        styles.transform = ZEROS_TRANSLATE_3D;\r\n        styles.position = POSITION_STICKY;\r\n      } else {\r\n        styles.position = POSITION_ABSOLUTE;\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      styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : SIZE_100_PERSENT;\r\n      styles.width = data.config.isVertical ? SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;\r\n    }\r\n\r\n    this._cdr.detectChanges();\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  private _elementRef = inject(ElementRef<HTMLElement>);\r\n\r\n  constructor(private _cdr: ChangeDetectorRef) {\r\n    this._id = NgVirtualListItemComponent.__nextId = NgVirtualListItemComponent.__nextId === Number.MAX_SAFE_INTEGER\r\n      ? 0 : NgVirtualListItemComponent.__nextId + 1;\r\n  }\r\n\r\n  getBounds(): IRect {\r\n    const el: HTMLElement = this._elementRef.nativeElement,\r\n      { width, height, left, top } = el.getBoundingClientRect();\r\n    return { width, height, x: left, y: top };\r\n  }\r\n\r\n  showIfNeed() {\r\n    const styles = this._elementRef.nativeElement.style;\r\n    if (styles.visibility === VISIBILITY_VISIBLE) {\r\n      return;\r\n    }\r\n\r\n    styles.visibility = VISIBILITY_VISIBLE;\r\n  }\r\n\r\n  hide() {\r\n    const styles = this._elementRef.nativeElement.style;\r\n    if (styles.visibility === VISIBILITY_HIDDEN) {\r\n      return;\r\n    }\r\n\r\n    styles.visibility = VISIBILITY_HIDDEN;\r\n  }\r\n}\r\n","<ng-container *ngIf=\"data\">\r\n    <li #listItem part=\"item\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n        'snapped-out': data.config.snappedOut}\">\r\n        <ng-container *ngIf=\"itemRenderer\">\r\n            <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n                [ngTemplateOutletContext]=\"{data: data.data || {}, config: data.config}\" />\r\n        </ng-container>\r\n    </li>\r\n</ng-container>"]}
@@ -0,0 +1,34 @@
1
+ import { Directions } from "../enums/directions";
2
+ export const DEFAULT_ITEM_SIZE = 24;
3
+ export const DEFAULT_ITEMS_OFFSET = 2;
4
+ export const DEFAULT_LIST_SIZE = 400;
5
+ export const DEFAULT_SNAP = false;
6
+ export const DEFAULT_SNAP_TO_ITEM = false;
7
+ export const DEFAULT_DYNAMIC_SIZE = false;
8
+ export const TRACK_BY_PROPERTY_NAME = 'id';
9
+ export const DEFAULT_DIRECTION = Directions.VERTICAL;
10
+ export const DISPLAY_OBJECTS_LENGTH_MESUREMENT_ERROR = 1;
11
+ // presets
12
+ export const BEHAVIOR_AUTO = 'auto';
13
+ export const BEHAVIOR_INSTANT = 'instant';
14
+ export const BEHAVIOR_SMOOTH = 'smooth';
15
+ export const VISIBILITY_VISIBLE = 'visible';
16
+ export const VISIBILITY_HIDDEN = 'hidden';
17
+ export const SIZE_100_PERSENT = '100%';
18
+ export const SIZE_AUTO = 'auto';
19
+ export const POSITION_ABSOLUTE = 'absolute';
20
+ export const POSITION_STICKY = 'sticky';
21
+ export const TRANSLATE_3D = 'translate3d';
22
+ export const ZEROS_TRANSLATE_3D = `${TRANSLATE_3D}(0,0,0)`;
23
+ export const TOP_PROP_NAME = 'top';
24
+ export const LEFT_PROP_NAME = 'left';
25
+ export const X_PROP_NAME = 'x';
26
+ export const Y_PROP_NAME = 'y';
27
+ export const WIDTH_PROP_NAME = 'width';
28
+ export const HEIGHT_PROP_NAME = 'height';
29
+ export const PX = 'px';
30
+ export const SCROLL = 'scroll';
31
+ export const SCROLL_END = 'scrollend';
32
+ export const CLASS_LIST_VERTICAL = 'vertical';
33
+ export const CLASS_LIST_HORIZONTAL = 'horizontal';
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb25zdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFakQsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsRUFBRSxDQUFDO0FBRXBDLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsQ0FBQztBQUV0QyxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxHQUFHLENBQUM7QUFFckMsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLEtBQUssQ0FBQztBQUVsQyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxLQUFLLENBQUM7QUFFMUMsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsS0FBSyxDQUFDO0FBRTFDLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLElBQUksQ0FBQztBQUUzQyxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDO0FBRXJELE1BQU0sQ0FBQyxNQUFNLHVDQUF1QyxHQUFHLENBQUMsQ0FBQztBQUV6RCxVQUFVO0FBRVYsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUVwQyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxTQUFTLENBQUM7QUFFMUMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLFFBQVEsQ0FBQztBQUV4QyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxTQUFTLENBQUM7QUFFNUMsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsUUFBUSxDQUFDO0FBRTFDLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQztBQUV2QyxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDO0FBRWhDLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLFVBQVUsQ0FBQztBQUU1QyxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsUUFBUSxDQUFDO0FBRXhDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUM7QUFFMUMsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxZQUFZLFNBQVMsQ0FBQztBQUUzRCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsS0FBSyxDQUFDO0FBRW5DLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUM7QUFFckMsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQztBQUUvQixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsR0FBRyxDQUFDO0FBRS9CLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxPQUFPLENBQUM7QUFFdkMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsUUFBUSxDQUFDO0FBRXpDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUM7QUFFdkIsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQztBQUUvQixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsV0FBVyxDQUFDO0FBRXRDLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLFVBQVUsQ0FBQztBQUU5QyxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3Rpb25zIH0gZnJvbSBcIi4uL2VudW1zL2RpcmVjdGlvbnNcIjtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0lURU1fU0laRSA9IDI0O1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfSVRFTVNfT0ZGU0VUID0gMjtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0xJU1RfU0laRSA9IDQwMDtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX1NOQVAgPSBmYWxzZTtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX1NOQVBfVE9fSVRFTSA9IGZhbHNlO1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfRFlOQU1JQ19TSVpFID0gZmFsc2U7XHJcblxyXG5leHBvcnQgY29uc3QgVFJBQ0tfQllfUFJPUEVSVFlfTkFNRSA9ICdpZCc7XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9ESVJFQ1RJT04gPSBEaXJlY3Rpb25zLlZFUlRJQ0FMO1xyXG5cclxuZXhwb3J0IGNvbnN0IERJU1BMQVlfT0JKRUNUU19MRU5HVEhfTUVTVVJFTUVOVF9FUlJPUiA9IDE7XHJcblxyXG4vLyBwcmVzZXRzXHJcblxyXG5leHBvcnQgY29uc3QgQkVIQVZJT1JfQVVUTyA9ICdhdXRvJztcclxuXHJcbmV4cG9ydCBjb25zdCBCRUhBVklPUl9JTlNUQU5UID0gJ2luc3RhbnQnO1xyXG5cclxuZXhwb3J0IGNvbnN0IEJFSEFWSU9SX1NNT09USCA9ICdzbW9vdGgnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFZJU0lCSUxJVFlfVklTSUJMRSA9ICd2aXNpYmxlJztcclxuXHJcbmV4cG9ydCBjb25zdCBWSVNJQklMSVRZX0hJRERFTiA9ICdoaWRkZW4nO1xyXG5cclxuZXhwb3J0IGNvbnN0IFNJWkVfMTAwX1BFUlNFTlQgPSAnMTAwJSc7XHJcblxyXG5leHBvcnQgY29uc3QgU0laRV9BVVRPID0gJ2F1dG8nO1xyXG5cclxuZXhwb3J0IGNvbnN0IFBPU0lUSU9OX0FCU09MVVRFID0gJ2Fic29sdXRlJztcclxuXHJcbmV4cG9ydCBjb25zdCBQT1NJVElPTl9TVElDS1kgPSAnc3RpY2t5JztcclxuXHJcbmV4cG9ydCBjb25zdCBUUkFOU0xBVEVfM0QgPSAndHJhbnNsYXRlM2QnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFpFUk9TX1RSQU5TTEFURV8zRCA9IGAke1RSQU5TTEFURV8zRH0oMCwwLDApYDtcclxuXHJcbmV4cG9ydCBjb25zdCBUT1BfUFJPUF9OQU1FID0gJ3RvcCc7XHJcblxyXG5leHBvcnQgY29uc3QgTEVGVF9QUk9QX05BTUUgPSAnbGVmdCc7XHJcblxyXG5leHBvcnQgY29uc3QgWF9QUk9QX05BTUUgPSAneCc7XHJcblxyXG5leHBvcnQgY29uc3QgWV9QUk9QX05BTUUgPSAneSc7XHJcblxyXG5leHBvcnQgY29uc3QgV0lEVEhfUFJPUF9OQU1FID0gJ3dpZHRoJztcclxuXHJcbmV4cG9ydCBjb25zdCBIRUlHSFRfUFJPUF9OQU1FID0gJ2hlaWdodCc7XHJcblxyXG5leHBvcnQgY29uc3QgUFggPSAncHgnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFNDUk9MTCA9ICdzY3JvbGwnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFNDUk9MTF9FTkQgPSAnc2Nyb2xsZW5kJztcclxuXHJcbmV4cG9ydCBjb25zdCBDTEFTU19MSVNUX1ZFUlRJQ0FMID0gJ3ZlcnRpY2FsJztcclxuXHJcbmV4cG9ydCBjb25zdCBDTEFTU19MSVNUX0hPUklaT05UQUwgPSAnaG9yaXpvbnRhbCc7XHJcbiJdfQ==
@@ -1,2 +1,2 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvZW51bXMvZGlyZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3Rpb25zIH0gZnJvbSBcIi4vZGlyZWN0aW9uc1wiO1xyXG5cclxuLyoqXHJcbiAqIEF4aXMgb2YgdGhlIGFycmFuZ2VtZW50IG9mIHZpcnR1YWwgbGlzdCBlbGVtZW50cy5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTUueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9kaXJlY3Rpb24udHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IHR5cGUgRGlyZWN0aW9uID0gRGlyZWN0aW9ucyB8ICdob3Rpem9udGFsJyB8ICd2ZXJ0aWNhbCc7XHJcbiJdfQ==
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvZW51bXMvZGlyZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3Rpb25zIH0gZnJvbSBcIi4vZGlyZWN0aW9uc1wiO1xyXG5cclxuLyoqXHJcbiAqIEF4aXMgb2YgdGhlIGFycmFuZ2VtZW50IG9mIHZpcnR1YWwgbGlzdCBlbGVtZW50cy5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvbWFpbi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9kaXJlY3Rpb24udHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IHR5cGUgRGlyZWN0aW9uID0gRGlyZWN0aW9ucyB8ICdob3Rpem9udGFsJyB8ICd2ZXJ0aWNhbCc7XHJcbiJdfQ==
@@ -1,18 +1,18 @@
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
+ /**
2
+ * Axis of the arrangement of virtual list elements.
3
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/main/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL2RpcmVjdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQU4sSUFBWSxVQVNYO0FBVEQsV0FBWSxVQUFVO0lBQ2xCOztPQUVHO0lBQ0gsdUNBQXlCLENBQUE7SUFDekI7O09BRUc7SUFDSCxtQ0FBcUIsQ0FBQTtBQUN6QixDQUFDLEVBVFcsVUFBVSxLQUFWLFVBQVUsUUFTckIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQXhpcyBvZiB0aGUgYXJyYW5nZW1lbnQgb2YgdmlydHVhbCBsaXN0IGVsZW1lbnRzLlxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi9tYWluL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL2RpcmVjdGlvbnMudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IGVudW0gRGlyZWN0aW9ucyB7XHJcbiAgICAvKipcclxuICAgICAqIEhvcml6b250YWwgYXhpcy5cclxuICAgICAqL1xyXG4gICAgSE9SSVpPTlRBTCA9ICdob3Jpem9udGFsJyxcclxuICAgIC8qKlxyXG4gICAgICogVmVydGljYWwgYXhpcy5cclxuICAgICAqL1xyXG4gICAgVkVSVElDQUwgPSAndmVydGljYWwnLFxyXG59Il19
@@ -1,3 +1,3 @@
1
- import { Directions } from "./directions";
2
- export { Directions };
1
+ import { Directions } from "./directions";
2
+ export { Directions };
3
3
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRzFDLE9BQU8sRUFDSCxVQUFVLEVBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGlvbnMgfSBmcm9tIFwiLi9kaXJlY3Rpb25zXCI7XHJcbmltcG9ydCB7IERpcmVjdGlvbiB9IGZyb20gXCIuL2RpcmVjdGlvblwiO1xyXG5cclxuZXhwb3J0IHtcclxuICAgIERpcmVjdGlvbnNcclxufTtcclxuZXhwb3J0IHR5cGUgeyBEaXJlY3Rpb24gfTtcclxuIl19
@@ -1,3 +1,3 @@
1
- ;
2
- export {};
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9jb2xsZWN0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVEyRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVZpcnR1YWxMaXN0SXRlbSB9IGZyb20gXCIuL2l0ZW0ubW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBWaXJ0dWFsIGxpc3QgZWxlbWVudHMgY29sbGVjdGlvbiBpbnRlcmZhY2VcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTUueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvY29sbGVjdGlvbi5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElWaXJ0dWFsTGlzdENvbGxlY3Rpb24gZXh0ZW5kcyBBcnJheTxJVmlydHVhbExpc3RJdGVtPiB7IH07Il19
1
+ ;
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9jb2xsZWN0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVEyRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVZpcnR1YWxMaXN0SXRlbSB9IGZyb20gXCIuL2l0ZW0ubW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBWaXJ0dWFsIGxpc3QgZWxlbWVudHMgY29sbGVjdGlvbiBpbnRlcmZhY2VcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvbWFpbi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvY29sbGVjdGlvbi5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElWaXJ0dWFsTGlzdENvbGxlY3Rpb24gZXh0ZW5kcyBBcnJheTxJVmlydHVhbExpc3RJdGVtPiB7IH07Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElWaXJ0dWFsTGlzdEl0ZW0gfSBmcm9tICcuL2l0ZW0ubW9kZWwnO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RTdGlja3lNYXAgfSBmcm9tICcuL3N0aWNreS1tYXAubW9kZWwnO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RDb2xsZWN0aW9uIH0gZnJvbSAnLi9jb2xsZWN0aW9uLm1vZGVsJztcclxuXHJcbmV4cG9ydCB0eXBlIHtcclxuICAgIElWaXJ0dWFsTGlzdEl0ZW0sXHJcbiAgICBJVmlydHVhbExpc3RTdGlja3lNYXAsXHJcbiAgICBJVmlydHVhbExpc3RDb2xsZWN0aW9uLFxyXG59Il19
@@ -1,3 +1,3 @@
1
- ;
2
- export {};
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJZCB9IGZyb20gXCIuLi90eXBlcy9pZFwiO1xyXG5cclxuLyoqXHJcbiAqIFZpcnR1YWwgbGlzdCBlbGVtZW50IG1vZGVsXHJcbiAqIEBsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9Eam9ubnlYL25nLXZpcnR1YWwtbGlzdC9ibG9iLzE1LngvcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL2l0ZW0ubW9kZWwudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBJVmlydHVhbExpc3RJdGVtIHtcclxuICAgIC8qKlxyXG4gICAgICogVW5pcXVlIGlkZW50aWZpZXIgb2YgdGhlIGVsZW1lbnQuXHJcbiAgICAgKi9cclxuICAgIGlkOiBJZDtcclxuICAgIFt4OiBzdHJpbmddOiBhbnk7XHJcbn07XHJcbiJdfQ==
1
+ ;
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJZCB9IGZyb20gXCIuLi90eXBlcy9pZFwiO1xyXG5cclxuLyoqXHJcbiAqIFZpcnR1YWwgbGlzdCBlbGVtZW50IG1vZGVsXHJcbiAqIEBsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9Eam9ubnlYL25nLXZpcnR1YWwtbGlzdC9ibG9iL21haW4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL2l0ZW0ubW9kZWwudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBJVmlydHVhbExpc3RJdGVtIHtcclxuICAgIC8qKlxyXG4gICAgICogVW5pcXVlIGlkZW50aWZpZXIgb2YgdGhlIGVsZW1lbnQuXHJcbiAgICAgKi9cclxuICAgIGlkOiBJZDtcclxuICAgIFt4OiBzdHJpbmddOiBhbnk7XHJcbn07XHJcbiJdfQ==
@@ -1,3 +1,3 @@
1
- ;
2
- export {};
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWNvbGxlY3Rpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvcmVuZGVyLWNvbGxlY3Rpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUXVGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmVuZGVyVmlydHVhbExpc3RJdGVtIH0gZnJvbSBcIi4vcmVuZGVyLWl0ZW0ubW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBWaXJ0dWFsIGxpc3Qgc2NyZWVuIGVsZW1lbnRzIGNvbGxlY3Rpb24gaW50ZXJmYWNlXHJcbiAqIEBsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9Eam9ubnlYL25nLXZpcnR1YWwtbGlzdC9ibG9iLzE1LngvcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL3JlbmRlci1jb2xsZWN0aW9uLm1vZGVsLnRzXHJcbiAqIEBhdXRob3IgRXZnZW5paSBHcmViZW5uaWtvdlxyXG4gKiBAZW1haWwgZGpvbm55eEBnbWFpbC5jb21cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlbmRlclZpcnR1YWxMaXN0Q29sbGVjdGlvbiBleHRlbmRzIEFycmF5PElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0+IHsgfTsiXX0=
1
+ ;
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWNvbGxlY3Rpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvcmVuZGVyLWNvbGxlY3Rpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUXVGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmVuZGVyVmlydHVhbExpc3RJdGVtIH0gZnJvbSBcIi4vcmVuZGVyLWl0ZW0ubW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBWaXJ0dWFsIGxpc3Qgc2NyZWVuIGVsZW1lbnRzIGNvbGxlY3Rpb24gaW50ZXJmYWNlXHJcbiAqIEBsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9Eam9ubnlYL25nLXZpcnR1YWwtbGlzdC9ibG9iL21haW4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL3JlbmRlci1jb2xsZWN0aW9uLm1vZGVsLnRzXHJcbiAqIEBhdXRob3IgRXZnZW5paSBHcmViZW5uaWtvdlxyXG4gKiBAZW1haWwgZGpvbm55eEBnbWFpbC5jb21cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlbmRlclZpcnR1YWxMaXN0Q29sbGVjdGlvbiBleHRlbmRzIEFycmF5PElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0+IHsgfTsiXX0=
@@ -1,2 +1,2 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWl0ZW0tY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL3JlbmRlci1pdGVtLWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIE9iamVjdCB3aXRoIGNvbmZpZ3VyYXRpb24gcGFyYW1ldGVycyBmb3IgSVJlbmRlclZpcnR1YWxMaXN0SXRlbVxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNS54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9yZW5kZXItaXRlbS1jb25maWcubW9kZWwudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKiBcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlbmRlclZpcnR1YWxMaXN0SXRlbUNvbmZpZyB7XHJcbiAgICAvKipcclxuICAgICAqIElmIGdyZWF0ZXIgdGhhbiAwLCB0aGUgZWxlbWVudCB3aWxsIGhhdmUgYSBzdGlja3kgcG9zaXRpb24gd2l0aCB0aGUgZ2l2ZW4gekluZGV4LlxyXG4gICAgICovXHJcbiAgICBzdGlja3k6IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogU3BlY2lmaWVzIHdoZXRoZXIgdGhlIGVsZW1lbnQgd2lsbCBzbmFwLlxyXG4gICAgICovXHJcbiAgICBzbmFwOiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBzbmFwcGVkLlxyXG4gICAgICovXHJcbiAgICBzbmFwcGVkOiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBiZWluZyBzaGlmdGVkIGJ5IGFub3RoZXIgc25hcCBlbGVtZW50LlxyXG4gICAgICovXHJcbiAgICBzbmFwcGVkT3V0OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBhIHZlcnRpY2FsIGxpc3QgaXRlbS5cclxuICAgICAqL1xyXG4gICAgaXNWZXJ0aWNhbDogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogU3BlY2lmaWVzIHRoYXQgdGhlIGVsZW1lbnQgYWRhcHRzIHRvIHRoZSBzaXplIG9mIGl0cyBjb250ZW50LlxyXG4gICAgICovXHJcbiAgICBkeW5hbWljOiBib29sZWFuO1xyXG59Il19
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWl0ZW0tY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL3JlbmRlci1pdGVtLWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIE9iamVjdCB3aXRoIGNvbmZpZ3VyYXRpb24gcGFyYW1ldGVycyBmb3IgSVJlbmRlclZpcnR1YWxMaXN0SXRlbVxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi9tYWluL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9yZW5kZXItaXRlbS1jb25maWcubW9kZWwudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKiBcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlbmRlclZpcnR1YWxMaXN0SXRlbUNvbmZpZyB7XHJcbiAgICAvKipcclxuICAgICAqIElmIGdyZWF0ZXIgdGhhbiAwLCB0aGUgZWxlbWVudCB3aWxsIGhhdmUgYSBzdGlja3kgcG9zaXRpb24gd2l0aCB0aGUgZ2l2ZW4gekluZGV4LlxyXG4gICAgICovXHJcbiAgICBzdGlja3k6IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogU3BlY2lmaWVzIHdoZXRoZXIgdGhlIGVsZW1lbnQgd2lsbCBzbmFwLlxyXG4gICAgICovXHJcbiAgICBzbmFwOiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBzbmFwcGVkLlxyXG4gICAgICovXHJcbiAgICBzbmFwcGVkOiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBiZWluZyBzaGlmdGVkIGJ5IGFub3RoZXIgc25hcCBlbGVtZW50LlxyXG4gICAgICovXHJcbiAgICBzbmFwcGVkT3V0OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBhIHZlcnRpY2FsIGxpc3QgaXRlbS5cclxuICAgICAqL1xyXG4gICAgaXNWZXJ0aWNhbDogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogU3BlY2lmaWVzIHRoYXQgdGhlIGVsZW1lbnQgYWRhcHRzIHRvIHRoZSBzaXplIG9mIGl0cyBjb250ZW50LlxyXG4gICAgICovXHJcbiAgICBkeW5hbWljOiBib29sZWFuO1xyXG59Il19
@@ -1,3 +1,3 @@
1
- ;
2
- export {};
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvcmVuZGVyLWl0ZW0ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmVjdCB9IGZyb20gXCIuLi90eXBlc1wiO1xyXG5pbXBvcnQgeyBJZCB9IGZyb20gXCIuLi90eXBlcy9pZFwiO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RJdGVtIH0gZnJvbSBcIi4vaXRlbS5tb2RlbFwiO1xyXG5pbXBvcnQgeyBJUmVuZGVyVmlydHVhbExpc3RJdGVtQ29uZmlnIH0gZnJvbSBcIi4vcmVuZGVyLWl0ZW0tY29uZmlnLm1vZGVsXCI7XHJcblxyXG4vKipcclxuICogTGlzdCBzY3JlZW4gZWxlbWVudCBtb2RlbFxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNS54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9yZW5kZXItaXRlbS5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBVbmlxdWUgaWRlbnRpZmllciBvZiB0aGUgZWxlbWVudC5cclxuICAgICAqL1xyXG4gICAgaWQ6IElkO1xyXG4gICAgLyoqXHJcbiAgICAgKiBFbGVtZW50IG1ldHJpY3MuXHJcbiAgICAgKi9cclxuICAgIG1lYXN1cmVzOiBJUmVjdDtcclxuICAgIC8qKlxyXG4gICAgICogRWxlbWVudCBkYXRhLlxyXG4gICAgICovXHJcbiAgICBkYXRhOiBJVmlydHVhbExpc3RJdGVtO1xyXG4gICAgLyoqXHJcbiAgICAgKiBPYmplY3Qgd2l0aCBjb25maWd1cmF0aW9uIHBhcmFtZXRlcnMgZm9yIElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0uXHJcbiAgICAgKi9cclxuICAgIGNvbmZpZzogSVJlbmRlclZpcnR1YWxMaXN0SXRlbUNvbmZpZztcclxufTtcclxuIl19
1
+ ;
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvcmVuZGVyLWl0ZW0ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmVjdCB9IGZyb20gXCIuLi90eXBlc1wiO1xyXG5pbXBvcnQgeyBJZCB9IGZyb20gXCIuLi90eXBlcy9pZFwiO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RJdGVtIH0gZnJvbSBcIi4vaXRlbS5tb2RlbFwiO1xyXG5pbXBvcnQgeyBJUmVuZGVyVmlydHVhbExpc3RJdGVtQ29uZmlnIH0gZnJvbSBcIi4vcmVuZGVyLWl0ZW0tY29uZmlnLm1vZGVsXCI7XHJcblxyXG4vKipcclxuICogTGlzdCBzY3JlZW4gZWxlbWVudCBtb2RlbFxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi9tYWluL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9yZW5kZXItaXRlbS5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBVbmlxdWUgaWRlbnRpZmllciBvZiB0aGUgZWxlbWVudC5cclxuICAgICAqL1xyXG4gICAgaWQ6IElkO1xyXG4gICAgLyoqXHJcbiAgICAgKiBFbGVtZW50IG1ldHJpY3MuXHJcbiAgICAgKi9cclxuICAgIG1lYXN1cmVzOiBJUmVjdDtcclxuICAgIC8qKlxyXG4gICAgICogRWxlbWVudCBkYXRhLlxyXG4gICAgICovXHJcbiAgICBkYXRhOiBJVmlydHVhbExpc3RJdGVtO1xyXG4gICAgLyoqXHJcbiAgICAgKiBPYmplY3Qgd2l0aCBjb25maWd1cmF0aW9uIHBhcmFtZXRlcnMgZm9yIElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0uXHJcbiAgICAgKi9cclxuICAgIGNvbmZpZzogSVJlbmRlclZpcnR1YWxMaXN0SXRlbUNvbmZpZztcclxufTtcclxuIl19
@@ -1,2 +1,2 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LW1hcC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9zdGlja3ktbWFwLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogRGljdGlvbmFyeSB6SW5kZXggYnkgaWQgb2YgdGhlIGxpc3QgZWxlbWVudC4gSWYgdGhlIHZhbHVlIGlzIG5vdCBzZXQgb3IgZXF1YWwgdG8gMCwgdGhlbiBhIHNpbXBsZSBlbGVtZW50IGlzIGRpc3BsYXllZCwgaWYgdGhlIHZhbHVlIGlzIGdyZWF0ZXIgdGhhbiAwLCB0aGVuIHRoZSBzdGlja3kgcG9zaXRpb24gbW9kZSBpcyBlbmFibGVkIGZvciB0aGUgZWxlbWVudC5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTUueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvc3RpY2t5LW1hcC5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElWaXJ0dWFsTGlzdFN0aWNreU1hcCB7XHJcbiAgICAvKipcclxuICAgICAqIFNldHMgekluZGV4IGZvciB0aGUgZWxlbWVudCBJRC4gSWYgekluZGV4IGlzIGdyZWF0ZXIgdGhhbiAwLCB0aGVuIHN0aWNreSBwb3NpdGlvbiBpcyBhcHBsaWVkLlxyXG4gICAgICovXHJcbiAgICBbaWQ6IHN0cmluZ106IG51bWJlcjtcclxufSJdfQ==
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LW1hcC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9zdGlja3ktbWFwLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogRGljdGlvbmFyeSB6SW5kZXggYnkgaWQgb2YgdGhlIGxpc3QgZWxlbWVudC4gSWYgdGhlIHZhbHVlIGlzIG5vdCBzZXQgb3IgZXF1YWwgdG8gMCwgdGhlbiBhIHNpbXBsZSBlbGVtZW50IGlzIGRpc3BsYXllZCwgaWYgdGhlIHZhbHVlIGlzIGdyZWF0ZXIgdGhhbiAwLCB0aGVuIHRoZSBzdGlja3kgcG9zaXRpb24gbW9kZSBpcyBlbmFibGVkIGZvciB0aGUgZWxlbWVudC5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvbWFpbi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvc3RpY2t5LW1hcC5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElWaXJ0dWFsTGlzdFN0aWNreU1hcCB7XHJcbiAgICAvKipcclxuICAgICAqIFNldHMgekluZGV4IGZvciB0aGUgZWxlbWVudCBJRC4gSWYgekluZGV4IGlzIGdyZWF0ZXIgdGhhbiAwLCB0aGVuIHN0aWNreSBwb3NpdGlvbiBpcyBhcHBsaWVkLlxyXG4gICAgICovXHJcbiAgICBbaWQ6IHN0cmluZ106IG51bWJlcjtcclxufSJdfQ==