ng-virtual-list 0.7.3 → 14.0.1
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.
- package/README.md +49 -76
- package/esm2020/lib/components/ng-virtual-list-item.component.mjs +80 -0
- package/esm2020/lib/const/index.mjs +34 -0
- package/esm2020/lib/enums/direction.mjs +2 -0
- package/esm2020/lib/enums/directions.mjs +18 -0
- package/esm2020/lib/enums/index.mjs +3 -0
- package/esm2020/lib/models/collection.model.mjs +3 -0
- package/esm2020/lib/models/index.mjs +2 -0
- package/esm2020/lib/models/item.model.mjs +3 -0
- package/esm2020/lib/models/render-collection.model.mjs +3 -0
- package/esm2020/lib/models/render-item-config.model.mjs +2 -0
- package/esm2020/lib/models/render-item.model.mjs +3 -0
- package/esm2020/lib/models/sticky-map.model.mjs +2 -0
- package/esm2020/lib/ng-virtual-list.component.mjs +510 -0
- package/esm2020/lib/ng-virtual-list.module.mjs +20 -0
- package/esm2020/lib/types/id.mjs +2 -0
- package/esm2020/lib/types/index.mjs +2 -0
- package/esm2020/lib/types/rect.mjs +2 -0
- package/esm2020/lib/types/size.mjs +2 -0
- package/esm2020/lib/utils/cacheMap.mjs +52 -0
- package/esm2020/lib/utils/debounce.mjs +31 -0
- package/esm2020/lib/utils/disposableComponent.mjs +29 -0
- package/esm2020/lib/utils/eventEmitter.mjs +106 -0
- package/esm2020/lib/utils/index.mjs +8 -0
- package/esm2020/lib/utils/isDirection.mjs +15 -0
- package/esm2020/lib/utils/toggleClassName.mjs +15 -0
- package/esm2020/lib/utils/trackBox.mjs +356 -0
- package/esm2020/lib/utils/tracker.mjs +108 -0
- package/esm2020/ng-virtual-list.mjs +5 -0
- package/esm2020/public-api.mjs +8 -0
- package/fesm2015/ng-virtual-list.mjs +1364 -0
- package/fesm2015/ng-virtual-list.mjs.map +1 -0
- package/fesm2020/ng-virtual-list.mjs +1363 -0
- package/fesm2020/ng-virtual-list.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/components/ng-virtual-list-item.component.d.ts +28 -28
- package/lib/const/index.d.ts +32 -31
- package/lib/enums/direction.d.ts +8 -2
- package/lib/enums/directions.d.ts +16 -4
- package/lib/enums/index.d.ts +4 -4
- package/lib/models/collection.model.d.ts +9 -3
- package/lib/models/index.d.ts +4 -4
- package/lib/models/item.model.d.ts +14 -5
- package/lib/models/render-collection.model.d.ts +9 -3
- package/lib/models/render-item-config.model.d.ts +33 -7
- package/lib/models/render-item.model.d.ts +28 -10
- package/lib/models/sticky-map.model.d.ts +12 -6
- package/lib/ng-virtual-list.component.d.ts +151 -110
- package/lib/ng-virtual-list.module.d.ts +9 -0
- package/lib/types/id.d.ts +7 -1
- package/lib/types/index.d.ts +4 -4
- package/lib/types/rect.d.ts +17 -5
- package/lib/types/size.d.ts +16 -4
- package/lib/utils/cacheMap.d.ts +34 -31
- package/lib/utils/debounce.d.ts +16 -10
- package/lib/utils/disposableComponent.d.ts +15 -0
- package/lib/utils/eventEmitter.d.ts +40 -37
- package/lib/utils/index.d.ts +7 -6
- package/lib/utils/isDirection.d.ts +8 -2
- package/lib/utils/toggleClassName.d.ts +7 -1
- package/lib/utils/trackBox.d.ts +113 -73
- package/lib/utils/tracker.d.ts +38 -38
- package/package.json +18 -6
- package/public-api.d.ts +4 -3
- package/fesm2022/ng-virtual-list.mjs +0 -939
- package/fesm2022/ng-virtual-list.mjs.map +0 -1
package/README.md
CHANGED
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
# NgVirtualList
|
|
2
2
|
Maximum performance for extremely large lists.
|
|
3
|
-
It is based on algorithms for virtualization of screen objects.
|
|
4
3
|
|
|
5
|
-
Angular version
|
|
4
|
+
Angular version 14.X.X.
|
|
6
5
|
|
|
7
|
-
[
|
|
6
|
+

|
|
7
|
+
|
|
8
|
+
[Live Demo](https://ng-virtual-list-chat-demo.eugene-grebennikov.pro/)
|
|
9
|
+
|
|
10
|
+
[Live Examples](https://ng-virtual-list.eugene-grebennikov.pro/)
|
|
8
11
|
|
|
9
12
|
## Installation
|
|
10
13
|
|
|
@@ -24,11 +27,9 @@ Template:
|
|
|
24
27
|
[itemRenderer]="hotizontalItemRenderer" [itemSize]="64"></ng-virtual-list>
|
|
25
28
|
|
|
26
29
|
<ng-template #hotizontalItemRenderer let-data="data">
|
|
27
|
-
|
|
28
|
-
<div class="list__h-container" (click)="onItemClick(data)">
|
|
30
|
+
<div *ngIf="data" class="list__h-container" (click)="onItemClick(data)">
|
|
29
31
|
<span>{{data.name}}</span>
|
|
30
32
|
</div>
|
|
31
|
-
}
|
|
32
33
|
</ng-template>
|
|
33
34
|
```
|
|
34
35
|
|
|
@@ -62,20 +63,14 @@ Template:
|
|
|
62
63
|
[itemsOffset]="50" [stickyMap]="horizontalGroupItemsStickyMap" [itemSize]="54" [snap]="true"></ng-virtual-list>
|
|
63
64
|
|
|
64
65
|
<ng-template #horizontalGroupItemRenderer let-data="data">
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
</
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
<div class="list__h-container" (click)="onItemClick(data)">
|
|
74
|
-
<span>{{data.name}}</span>
|
|
75
|
-
</div>
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
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>
|
|
79
74
|
</ng-template>
|
|
80
75
|
```
|
|
81
76
|
|
|
@@ -120,11 +115,9 @@ Template:
|
|
|
120
115
|
[itemSize]="40"></ng-virtual-list>
|
|
121
116
|
|
|
122
117
|
<ng-template #itemRenderer let-data="data">
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
<p>{{data.name}}</p>
|
|
118
|
+
<div *ngIf="data" class="list__container">
|
|
119
|
+
<span>{{data.name}}</span>
|
|
126
120
|
</div>
|
|
127
|
-
}
|
|
128
121
|
</ng-template>
|
|
129
122
|
```
|
|
130
123
|
|
|
@@ -161,20 +154,14 @@ Template:
|
|
|
161
154
|
[stickyMap]="groupItemsStickyMap" [itemSize]="40" [snap]="false"></ng-virtual-list>
|
|
162
155
|
|
|
163
156
|
<ng-template #groupItemRenderer let-data="data">
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
</
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
<div class="list__container">
|
|
173
|
-
<p>{{data.name}}</p>
|
|
174
|
-
</div>
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
}
|
|
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>
|
|
178
165
|
</ng-template>
|
|
179
166
|
```
|
|
180
167
|
|
|
@@ -188,20 +175,14 @@ Template (with snapping):
|
|
|
188
175
|
[stickyMap]="groupItemsStickyMap" [itemSize]="40" [snap]="true"></ng-virtual-list>
|
|
189
176
|
|
|
190
177
|
<ng-template #groupItemRenderer let-data="data">
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
</
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
<div class="list__container">
|
|
200
|
-
<p>{{data.name}}</p>
|
|
201
|
-
</div>
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
}
|
|
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>
|
|
205
186
|
</ng-template>
|
|
206
187
|
```
|
|
207
188
|
|
|
@@ -253,11 +234,9 @@ Template
|
|
|
253
234
|
[itemSize]="40"></ng-virtual-list>
|
|
254
235
|
|
|
255
236
|
<ng-template #itemRenderer let-data="data">
|
|
256
|
-
|
|
257
|
-
<div class="list__container">
|
|
237
|
+
<div *ngIf="data" class="list__container">
|
|
258
238
|
<span>{{data.name}}</span>
|
|
259
239
|
</div>
|
|
260
|
-
}
|
|
261
240
|
</ng-template>
|
|
262
241
|
```
|
|
263
242
|
|
|
@@ -307,20 +286,14 @@ Template
|
|
|
307
286
|
[stickyMap]="groupDynamicItemsStickyMap" [dynamicSize]="true" [snap]="true"></ng-virtual-list>
|
|
308
287
|
|
|
309
288
|
<ng-template #groupItemRenderer let-data="data">
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
<div class="list__container">
|
|
319
|
-
<span>{{data.name}}</span>
|
|
320
|
-
</div>
|
|
321
|
-
}
|
|
322
|
-
}
|
|
323
|
-
}
|
|
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>
|
|
324
297
|
</ng-template>
|
|
325
298
|
```
|
|
326
299
|
|
|
@@ -432,21 +405,21 @@ List items are encapsulated in shadowDOM, so to override default styles you need
|
|
|
432
405
|
|
|
433
406
|
## API
|
|
434
407
|
|
|
435
|
-
[NgVirtualListComponent](https://github.com/DjonnyX/ng-virtual-list/blob/
|
|
408
|
+
[NgVirtualListComponent](https://github.com/DjonnyX/ng-virtual-list/blob/14.x/projects/ng-virtual-list/src/lib/ng-virtual-list.component.ts)
|
|
436
409
|
|
|
437
410
|
Inputs
|
|
438
411
|
|
|
439
412
|
| Property | Type | Description |
|
|
440
413
|
|---|---|---|
|
|
441
414
|
| id | number | Readonly. Returns the unique identifier of the component. |
|
|
442
|
-
| items | [IVirtualListCollection](https://github.com/DjonnyX/ng-virtual-list/blob/
|
|
415
|
+
| items | [IVirtualListCollection](https://github.com/DjonnyX/ng-virtual-list/blob/14.x/projects/ng-virtual-list/src/lib/models/collection.model.ts) | Collection of list items. |
|
|
443
416
|
| 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. |
|
|
444
417
|
| itemsOffset | number? = 2 | Number of elements outside the scope of visibility. Default value is 2. |
|
|
445
418
|
| itemRenderer | TemplateRef | Rendering element template. |
|
|
446
|
-
| stickyMap | [IVirtualListStickyMap?](https://github.com/DjonnyX/ng-virtual-list/blob/
|
|
419
|
+
| stickyMap | [IVirtualListStickyMap?](https://github.com/DjonnyX/ng-virtual-list/blob/14.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. |
|
|
447
420
|
| snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
|
|
448
421
|
| snapToItem | boolean? = false | Determines whether scroll positions will be snapped to the element. Default value is "false". |
|
|
449
|
-
| direction | [Direction? = 'vertical'](https://github.com/DjonnyX/ng-virtual-list/blob/
|
|
422
|
+
| direction | [Direction? = 'vertical'](https://github.com/DjonnyX/ng-virtual-list/blob/14.x/projects/ng-virtual-list/src/lib/enums/direction.ts) | Determines the direction in which elements are placed. Default value is "vertical". |
|
|
450
423
|
| 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. |
|
|
451
424
|
|
|
452
425
|
<br/>
|
|
@@ -455,8 +428,8 @@ Outputs
|
|
|
455
428
|
|
|
456
429
|
| Event | Type | Description |
|
|
457
430
|
|---|---|---|
|
|
458
|
-
| onScroll | (
|
|
459
|
-
| onScrollEnd | (
|
|
431
|
+
| onScroll | (scrollSize: number) => void | Fires when the list has been scrolled. |
|
|
432
|
+
| onScrollEnd | (scrollSize: number) => void | Fires when the list has completed scrolling. |
|
|
460
433
|
|
|
461
434
|
<br/>
|
|
462
435
|
|
|
@@ -464,4 +437,4 @@ Methods
|
|
|
464
437
|
|
|
465
438
|
| Method | Type | Description |
|
|
466
439
|
|--|--|--|
|
|
467
|
-
| scrollTo | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/
|
|
440
|
+
| scrollTo | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/14.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". |
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } 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/14.x/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
|
+
constructor(_cdr, _elementRef) {
|
|
13
|
+
this._cdr = _cdr;
|
|
14
|
+
this._elementRef = _elementRef;
|
|
15
|
+
this._id = NgVirtualListItemComponent.__nextId = NgVirtualListItemComponent.__nextId === Number.MAX_SAFE_INTEGER
|
|
16
|
+
? 0 : NgVirtualListItemComponent.__nextId + 1;
|
|
17
|
+
}
|
|
18
|
+
get id() {
|
|
19
|
+
return this._id;
|
|
20
|
+
}
|
|
21
|
+
set item(v) {
|
|
22
|
+
if (this.data === v) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const data = this.data = v;
|
|
26
|
+
if (data) {
|
|
27
|
+
const styles = this._elementRef.nativeElement.style;
|
|
28
|
+
styles.zIndex = String(data.config.sticky);
|
|
29
|
+
if (data.config.snapped) {
|
|
30
|
+
styles.transform = ZEROS_TRANSLATE_3D;
|
|
31
|
+
styles.position = POSITION_STICKY;
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
styles.position = POSITION_ABSOLUTE;
|
|
35
|
+
styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;
|
|
36
|
+
}
|
|
37
|
+
styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : SIZE_100_PERSENT;
|
|
38
|
+
styles.width = data.config.isVertical ? SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
|
|
39
|
+
}
|
|
40
|
+
this._cdr.detectChanges();
|
|
41
|
+
}
|
|
42
|
+
get itemId() {
|
|
43
|
+
return this.data?.id;
|
|
44
|
+
}
|
|
45
|
+
set renderer(v) {
|
|
46
|
+
if (this.itemRenderer === v) {
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
this.itemRenderer = v;
|
|
50
|
+
this._cdr.markForCheck();
|
|
51
|
+
}
|
|
52
|
+
getBounds() {
|
|
53
|
+
const el = this._elementRef.nativeElement, { width, height, left, top } = el.getBoundingClientRect();
|
|
54
|
+
return { width, height, x: left, y: top };
|
|
55
|
+
}
|
|
56
|
+
showIfNeed() {
|
|
57
|
+
const styles = this._elementRef.nativeElement.style;
|
|
58
|
+
if (styles.visibility === VISIBILITY_VISIBLE) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
styles.visibility = VISIBILITY_VISIBLE;
|
|
62
|
+
}
|
|
63
|
+
hide() {
|
|
64
|
+
const styles = this._elementRef.nativeElement.style;
|
|
65
|
+
if (styles.visibility === VISIBILITY_HIDDEN) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
styles.visibility = VISIBILITY_HIDDEN;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
NgVirtualListItemComponent.__nextId = 0;
|
|
72
|
+
NgVirtualListItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NgVirtualListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
+
NgVirtualListItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", 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}\"></ng-container>\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 });
|
|
74
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NgVirtualListItemComponent, decorators: [{
|
|
75
|
+
type: Component,
|
|
76
|
+
args: [{ selector: 'ng-virtual-list-item', host: {
|
|
77
|
+
'class': 'ngvl__item',
|
|
78
|
+
}, 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}\"></ng-container>\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"] }]
|
|
79
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; } });
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list-item.component.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.ts","../../../../../projects/ng-virtual-list/src/lib/components/ng-virtual-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, TemplateRef } from '@angular/core';\r\nimport { IRenderVirtualListItem } from '../models/render-item.model';\r\nimport { 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/14.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  },\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 = String(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  constructor(private _cdr: ChangeDetectorRef, private _elementRef: ElementRef<HTMLElement>) {\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}\"></ng-container>\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==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvZW51bXMvZGlyZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3Rpb25zIH0gZnJvbSBcIi4vZGlyZWN0aW9uc1wiO1xyXG5cclxuLyoqXHJcbiAqIEF4aXMgb2YgdGhlIGFycmFuZ2VtZW50IG9mIHZpcnR1YWwgbGlzdCBlbGVtZW50cy5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTQueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9kaXJlY3Rpb24udHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IHR5cGUgRGlyZWN0aW9uID0gRGlyZWN0aW9ucyB8ICdob3Rpem9udGFsJyB8ICd2ZXJ0aWNhbCc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Axis of the arrangement of virtual list elements.
|
|
3
|
+
* @link https://github.com/DjonnyX/ng-virtual-list/blob/14.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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL2RpcmVjdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQU4sSUFBWSxVQVNYO0FBVEQsV0FBWSxVQUFVO0lBQ2xCOztPQUVHO0lBQ0gsdUNBQXlCLENBQUE7SUFDekI7O09BRUc7SUFDSCxtQ0FBcUIsQ0FBQTtBQUN6QixDQUFDLEVBVFcsVUFBVSxLQUFWLFVBQVUsUUFTckIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQXhpcyBvZiB0aGUgYXJyYW5nZW1lbnQgb2YgdmlydHVhbCBsaXN0IGVsZW1lbnRzLlxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNC54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2VudW1zL2RpcmVjdGlvbnMudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IGVudW0gRGlyZWN0aW9ucyB7XHJcbiAgICAvKipcclxuICAgICAqIEhvcml6b250YWwgYXhpcy5cclxuICAgICAqL1xyXG4gICAgSE9SSVpPTlRBTCA9ICdob3Jpem9udGFsJyxcclxuICAgIC8qKlxyXG4gICAgICogVmVydGljYWwgYXhpcy5cclxuICAgICAqL1xyXG4gICAgVkVSVElDQUwgPSAndmVydGljYWwnLFxyXG59Il19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { Directions } from "./directions";
|
|
2
|
+
export { Directions };
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9lbnVtcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRzFDLE9BQU8sRUFDSCxVQUFVLEVBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGlvbnMgfSBmcm9tIFwiLi9kaXJlY3Rpb25zXCI7XHJcbmltcG9ydCB7IERpcmVjdGlvbiB9IGZyb20gXCIuL2RpcmVjdGlvblwiO1xyXG5cclxuZXhwb3J0IHtcclxuICAgIERpcmVjdGlvbnNcclxufTtcclxuZXhwb3J0IHR5cGUgeyBEaXJlY3Rpb24gfTtcclxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
;
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9jb2xsZWN0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVEyRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVZpcnR1YWxMaXN0SXRlbSB9IGZyb20gXCIuL2l0ZW0ubW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBWaXJ0dWFsIGxpc3QgZWxlbWVudHMgY29sbGVjdGlvbiBpbnRlcmZhY2VcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTQueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvY29sbGVjdGlvbi5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElWaXJ0dWFsTGlzdENvbGxlY3Rpb24gZXh0ZW5kcyBBcnJheTxJVmlydHVhbExpc3RJdGVtPiB7IH07Il19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElWaXJ0dWFsTGlzdEl0ZW0gfSBmcm9tICcuL2l0ZW0ubW9kZWwnO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RTdGlja3lNYXAgfSBmcm9tICcuL3N0aWNreS1tYXAubW9kZWwnO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RDb2xsZWN0aW9uIH0gZnJvbSAnLi9jb2xsZWN0aW9uLm1vZGVsJztcclxuXHJcbmV4cG9ydCB0eXBlIHtcclxuICAgIElWaXJ0dWFsTGlzdEl0ZW0sXHJcbiAgICBJVmlydHVhbExpc3RTdGlja3lNYXAsXHJcbiAgICBJVmlydHVhbExpc3RDb2xsZWN0aW9uLFxyXG59Il19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
;
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJZCB9IGZyb20gXCIuLi90eXBlcy9pZFwiO1xyXG5cclxuLyoqXHJcbiAqIFZpcnR1YWwgbGlzdCBlbGVtZW50IG1vZGVsXHJcbiAqIEBsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9Eam9ubnlYL25nLXZpcnR1YWwtbGlzdC9ibG9iLzE0LngvcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL2l0ZW0ubW9kZWwudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBJVmlydHVhbExpc3RJdGVtIHtcclxuICAgIC8qKlxyXG4gICAgICogVW5pcXVlIGlkZW50aWZpZXIgb2YgdGhlIGVsZW1lbnQuXHJcbiAgICAgKi9cclxuICAgIGlkOiBJZDtcclxuICAgIFt4OiBzdHJpbmddOiBhbnk7XHJcbn07XHJcbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
;
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWNvbGxlY3Rpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvcmVuZGVyLWNvbGxlY3Rpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUXVGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmVuZGVyVmlydHVhbExpc3RJdGVtIH0gZnJvbSBcIi4vcmVuZGVyLWl0ZW0ubW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBWaXJ0dWFsIGxpc3Qgc2NyZWVuIGVsZW1lbnRzIGNvbGxlY3Rpb24gaW50ZXJmYWNlXHJcbiAqIEBsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9Eam9ubnlYL25nLXZpcnR1YWwtbGlzdC9ibG9iLzE0LngvcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL3JlbmRlci1jb2xsZWN0aW9uLm1vZGVsLnRzXHJcbiAqIEBhdXRob3IgRXZnZW5paSBHcmViZW5uaWtvdlxyXG4gKiBAZW1haWwgZGpvbm55eEBnbWFpbC5jb21cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlbmRlclZpcnR1YWxMaXN0Q29sbGVjdGlvbiBleHRlbmRzIEFycmF5PElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0+IHsgfTsiXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWl0ZW0tY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvbW9kZWxzL3JlbmRlci1pdGVtLWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIE9iamVjdCB3aXRoIGNvbmZpZ3VyYXRpb24gcGFyYW1ldGVycyBmb3IgSVJlbmRlclZpcnR1YWxMaXN0SXRlbVxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNC54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9yZW5kZXItaXRlbS1jb25maWcubW9kZWwudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKiBcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlbmRlclZpcnR1YWxMaXN0SXRlbUNvbmZpZyB7XHJcbiAgICAvKipcclxuICAgICAqIElmIGdyZWF0ZXIgdGhhbiAwLCB0aGUgZWxlbWVudCB3aWxsIGhhdmUgYSBzdGlja3kgcG9zaXRpb24gd2l0aCB0aGUgZ2l2ZW4gekluZGV4LlxyXG4gICAgICovXHJcbiAgICBzdGlja3k6IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogU3BlY2lmaWVzIHdoZXRoZXIgdGhlIGVsZW1lbnQgd2lsbCBzbmFwLlxyXG4gICAgICovXHJcbiAgICBzbmFwOiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBzbmFwcGVkLlxyXG4gICAgICovXHJcbiAgICBzbmFwcGVkOiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBiZWluZyBzaGlmdGVkIGJ5IGFub3RoZXIgc25hcCBlbGVtZW50LlxyXG4gICAgICovXHJcbiAgICBzbmFwcGVkT3V0OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZWxlbWVudCBpcyBhIHZlcnRpY2FsIGxpc3QgaXRlbS5cclxuICAgICAqL1xyXG4gICAgaXNWZXJ0aWNhbDogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogU3BlY2lmaWVzIHRoYXQgdGhlIGVsZW1lbnQgYWRhcHRzIHRvIHRoZSBzaXplIG9mIGl0cyBjb250ZW50LlxyXG4gICAgICovXHJcbiAgICBkeW5hbWljOiBib29sZWFuO1xyXG59Il19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
;
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvcmVuZGVyLWl0ZW0ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmVjdCB9IGZyb20gXCIuLi90eXBlc1wiO1xyXG5pbXBvcnQgeyBJZCB9IGZyb20gXCIuLi90eXBlcy9pZFwiO1xyXG5pbXBvcnQgeyBJVmlydHVhbExpc3RJdGVtIH0gZnJvbSBcIi4vaXRlbS5tb2RlbFwiO1xyXG5pbXBvcnQgeyBJUmVuZGVyVmlydHVhbExpc3RJdGVtQ29uZmlnIH0gZnJvbSBcIi4vcmVuZGVyLWl0ZW0tY29uZmlnLm1vZGVsXCI7XHJcblxyXG4vKipcclxuICogTGlzdCBzY3JlZW4gZWxlbWVudCBtb2RlbFxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xNC54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9yZW5kZXItaXRlbS5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBVbmlxdWUgaWRlbnRpZmllciBvZiB0aGUgZWxlbWVudC5cclxuICAgICAqL1xyXG4gICAgaWQ6IElkO1xyXG4gICAgLyoqXHJcbiAgICAgKiBFbGVtZW50IG1ldHJpY3MuXHJcbiAgICAgKi9cclxuICAgIG1lYXN1cmVzOiBJUmVjdDtcclxuICAgIC8qKlxyXG4gICAgICogRWxlbWVudCBkYXRhLlxyXG4gICAgICovXHJcbiAgICBkYXRhOiBJVmlydHVhbExpc3RJdGVtO1xyXG4gICAgLyoqXHJcbiAgICAgKiBPYmplY3Qgd2l0aCBjb25maWd1cmF0aW9uIHBhcmFtZXRlcnMgZm9yIElSZW5kZXJWaXJ0dWFsTGlzdEl0ZW0uXHJcbiAgICAgKi9cclxuICAgIGNvbmZpZzogSVJlbmRlclZpcnR1YWxMaXN0SXRlbUNvbmZpZztcclxufTtcclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RpY2t5LW1hcC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL21vZGVscy9zdGlja3ktbWFwLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogRGljdGlvbmFyeSB6SW5kZXggYnkgaWQgb2YgdGhlIGxpc3QgZWxlbWVudC4gSWYgdGhlIHZhbHVlIGlzIG5vdCBzZXQgb3IgZXF1YWwgdG8gMCwgdGhlbiBhIHNpbXBsZSBlbGVtZW50IGlzIGRpc3BsYXllZCwgaWYgdGhlIHZhbHVlIGlzIGdyZWF0ZXIgdGhhbiAwLCB0aGVuIHRoZSBzdGlja3kgcG9zaXRpb24gbW9kZSBpcyBlbmFibGVkIGZvciB0aGUgZWxlbWVudC5cclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTQueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9tb2RlbHMvc3RpY2t5LW1hcC5tb2RlbC50c1xyXG4gKiBAYXV0aG9yIEV2Z2VuaWkgR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElWaXJ0dWFsTGlzdFN0aWNreU1hcCB7XHJcbiAgICAvKipcclxuICAgICAqIFNldHMgekluZGV4IGZvciB0aGUgZWxlbWVudCBJRC4gSWYgekluZGV4IGlzIGdyZWF0ZXIgdGhhbiAwLCB0aGVuIHN0aWNreSBwb3NpdGlvbiBpcyBhcHBsaWVkLlxyXG4gICAgICovXHJcbiAgICBbaWQ6IHN0cmluZ106IG51bWJlcjtcclxufSJdfQ==
|