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.
- package/README.md +18 -16
- package/esm2022/lib/components/ng-virtual-list-item.component.mjs +18 -5
- package/esm2022/lib/const/index.mjs +2 -1
- package/esm2022/lib/models/index.mjs +1 -1
- package/esm2022/lib/models/item-config-map.model.mjs +2 -0
- package/esm2022/lib/models/render-item-config.model.mjs +1 -1
- package/esm2022/lib/ng-virtual-list.component.mjs +45 -19
- package/esm2022/lib/ng-virtual-list.service.mjs +46 -8
- package/esm2022/lib/utils/trackBox.mjs +22 -19
- package/fesm2022/ng-virtual-list.mjs +126 -46
- package/fesm2022/ng-virtual-list.mjs.map +1 -1
- package/lib/components/ng-virtual-list-item.component.d.ts +22 -4
- package/lib/const/index.d.ts +1 -0
- package/lib/models/index.d.ts +2 -2
- package/lib/models/item-config-map.model.d.ts +23 -0
- package/lib/models/render-item-config.model.d.ts +5 -1
- package/lib/ng-virtual-list.component.d.ts +20 -6
- package/lib/ng-virtual-list.service.d.ts +7 -0
- package/lib/utils/trackBox.d.ts +4 -4
- package/package.json +1 -1
- package/esm2020/lib/components/ng-virtual-list-item.component.mjs +0 -198
- package/esm2020/lib/const/index.mjs +0 -51
- package/esm2020/lib/enums/direction.mjs +0 -2
- package/esm2020/lib/enums/directions.mjs +0 -18
- package/esm2020/lib/enums/index.mjs +0 -5
- package/esm2020/lib/enums/method-for-selecting-types.mjs +0 -22
- package/esm2020/lib/enums/method-for-selecting.mjs +0 -2
- package/esm2020/lib/enums/methods-for-selecting.mjs +0 -22
- package/esm2020/lib/enums/snapping-method.mjs +0 -2
- package/esm2020/lib/enums/snapping-methods.mjs +0 -18
- package/esm2020/lib/models/base-virtual-list-item-component.mjs +0 -9
- package/esm2020/lib/models/collection.model.mjs +0 -3
- package/esm2020/lib/models/component.model.mjs +0 -2
- package/esm2020/lib/models/index.mjs +0 -2
- package/esm2020/lib/models/item.model.mjs +0 -2
- package/esm2020/lib/models/render-collection.model.mjs +0 -3
- package/esm2020/lib/models/render-item-config.model.mjs +0 -2
- package/esm2020/lib/models/render-item.model.mjs +0 -3
- package/esm2020/lib/models/scroll-direction.model.mjs +0 -2
- package/esm2020/lib/models/scroll-event.model.mjs +0 -2
- package/esm2020/lib/models/sticky-map.model.mjs +0 -2
- package/esm2020/lib/ng-virtual-list.component.mjs +0 -800
- package/esm2020/lib/ng-virtual-list.module.mjs +0 -20
- package/esm2020/lib/ng-virtual-list.service.mjs +0 -94
- package/esm2020/lib/types/id.mjs +0 -2
- package/esm2020/lib/types/index.mjs +0 -2
- package/esm2020/lib/types/rect.mjs +0 -2
- package/esm2020/lib/types/size.mjs +0 -2
- package/esm2020/lib/utils/browser.mjs +0 -3
- package/esm2020/lib/utils/buffer-interpolation.mjs +0 -27
- package/esm2020/lib/utils/cacheMap.mjs +0 -167
- package/esm2020/lib/utils/debounce.mjs +0 -31
- package/esm2020/lib/utils/disposableComponent.mjs +0 -29
- package/esm2020/lib/utils/eventEmitter.mjs +0 -106
- package/esm2020/lib/utils/index.mjs +0 -5
- package/esm2020/lib/utils/isDirection.mjs +0 -15
- package/esm2020/lib/utils/isMethodForSelecting.mjs +0 -18
- package/esm2020/lib/utils/scrollEvent.mjs +0 -42
- package/esm2020/lib/utils/snapping-method.mjs +0 -9
- package/esm2020/lib/utils/toggleClassName.mjs +0 -15
- package/esm2020/lib/utils/trackBox.mjs +0 -762
- package/esm2020/lib/utils/tracker.mjs +0 -143
- package/esm2020/ng-virtual-list.mjs +0 -5
- package/esm2020/public-api.mjs +0 -10
- package/esm2022/lib/models/sticky-map.model.mjs +0 -2
- package/fesm2015/ng-virtual-list.mjs +0 -2582
- package/fesm2015/ng-virtual-list.mjs.map +0 -1
- package/fesm2020/ng-virtual-list.mjs +0 -2586
- package/fesm2020/ng-virtual-list.mjs.map +0 -1
- package/lib/models/sticky-map.model.d.ts +0 -14
- 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<
|
|
21
|
-
|
|
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 {};
|
package/lib/const/index.d.ts
CHANGED
|
@@ -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";
|
package/lib/models/index.d.ts
CHANGED
|
@@ -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 {
|
|
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,
|
|
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:
|
|
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,
|
|
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
|
-
*
|
|
75
|
-
*
|
|
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
|
-
|
|
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>;
|
package/lib/utils/trackBox.d.ts
CHANGED
|
@@ -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 {
|
|
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,
|
|
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,
|
|
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,
|
|
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,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":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, TemplateRef } from '@angular/core';\r\nimport { IRenderVirtualListItem } from '../models/render-item.model';\r\nimport { Id, 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=
|