ng-virtual-list 16.7.1 → 16.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 +1 -0
- package/esm2022/lib/components/ng-virtual-list-item.component.mjs +18 -4
- package/esm2022/lib/const/index.mjs +2 -1
- package/esm2022/lib/ng-virtual-list.component.mjs +36 -10
- package/esm2022/lib/ng-virtual-list.service.mjs +45 -8
- package/fesm2022/ng-virtual-list.mjs +95 -18
- package/fesm2022/ng-virtual-list.mjs.map +1 -1
- package/lib/components/ng-virtual-list-item.component.d.ts +17 -1
- package/lib/const/index.d.ts +1 -0
- package/lib/ng-virtual-list.component.d.ts +9 -1
- package/lib/ng-virtual-list.service.d.ts +7 -0
- package/package.json +1 -1
|
@@ -3,6 +3,7 @@ import { Subject, tap } from 'rxjs';
|
|
|
3
3
|
import { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';
|
|
4
4
|
import { MethodsForSelectingTypes } from './enums/method-for-selecting-types';
|
|
5
5
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { DEFAULT_SELECT_BY_CLICK } from './const';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export class NgVirtualListService {
|
|
8
9
|
_nextComponentId = 0;
|
|
@@ -15,6 +16,7 @@ export class NgVirtualListService {
|
|
|
15
16
|
set methodOfSelecting(v) {
|
|
16
17
|
this._$methodOfSelecting.next(v);
|
|
17
18
|
}
|
|
19
|
+
selectByClick = DEFAULT_SELECT_BY_CLICK;
|
|
18
20
|
_trackBox;
|
|
19
21
|
constructor() {
|
|
20
22
|
this._$methodOfSelecting.pipe(takeUntilDestroyed(), tap(v => {
|
|
@@ -41,25 +43,60 @@ export class NgVirtualListService {
|
|
|
41
43
|
})).subscribe();
|
|
42
44
|
}
|
|
43
45
|
setSelectedIds(ids) {
|
|
44
|
-
this._$selectedIds.
|
|
46
|
+
if (JSON.stringify(this._$selectedIds.getValue()) !== JSON.stringify(ids)) {
|
|
47
|
+
this._$selectedIds.next(ids);
|
|
48
|
+
}
|
|
45
49
|
}
|
|
46
50
|
itemClick(data) {
|
|
47
|
-
this.
|
|
51
|
+
if (this.selectByClick) {
|
|
52
|
+
this.select(data);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Selects a list item
|
|
57
|
+
* @param data
|
|
58
|
+
* @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
|
|
59
|
+
*/
|
|
60
|
+
select(data, selected = undefined) {
|
|
48
61
|
if (data && data.config.selectable) {
|
|
49
62
|
switch (this._$methodOfSelecting.getValue()) {
|
|
50
63
|
case MethodsForSelectingTypes.SELECT: {
|
|
51
64
|
const curr = this._$selectedIds.getValue();
|
|
52
|
-
|
|
65
|
+
if (selected === undefined) {
|
|
66
|
+
this._$selectedIds.next(curr !== data?.id ? data?.id : undefined);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
this._$selectedIds.next(selected ? data?.id : undefined);
|
|
70
|
+
}
|
|
53
71
|
break;
|
|
54
72
|
}
|
|
55
73
|
case MethodsForSelectingTypes.MULTI_SELECT: {
|
|
56
74
|
const curr = [...(this._$selectedIds.getValue() || [])], index = curr.indexOf(data.id);
|
|
57
|
-
if (
|
|
58
|
-
|
|
59
|
-
|
|
75
|
+
if (selected === undefined) {
|
|
76
|
+
if (index > -1) {
|
|
77
|
+
curr.splice(index, 1);
|
|
78
|
+
this._$selectedIds.next(curr);
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
this._$selectedIds.next([...curr, data.id]);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
else if (selected) {
|
|
85
|
+
if (index > -1) {
|
|
86
|
+
this._$selectedIds.next(curr);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
this._$selectedIds.next([...curr, data.id]);
|
|
90
|
+
}
|
|
60
91
|
}
|
|
61
92
|
else {
|
|
62
|
-
|
|
93
|
+
if (index > -1) {
|
|
94
|
+
curr.splice(index, 1);
|
|
95
|
+
this._$selectedIds.next(curr);
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this._$selectedIds.next(curr);
|
|
99
|
+
}
|
|
63
100
|
}
|
|
64
101
|
break;
|
|
65
102
|
}
|
|
@@ -86,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
86
123
|
providedIn: 'root'
|
|
87
124
|
}]
|
|
88
125
|
}], ctorParameters: function () { return []; } });
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list.service.js","sourceRoot":"","sources":["../../../../projects/ng-virtual-list/src/lib/ng-virtual-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Subject, tap } from 'rxjs';\r\nimport { TrackBox } from './utils/trackBox';\r\nimport { IRenderVirtualListItem } from './models';\r\nimport { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';\r\nimport { Id } from './types';\r\nimport { MethodsForSelectingTypes } from './enums/method-for-selecting-types';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class NgVirtualListService {\r\n  private _nextComponentId: number = 0;\r\n\r\n  private _$itemClick = new Subject<IRenderVirtualListItem<any> | undefined>();\r\n  $itemClick = this._$itemClick.asObservable();\r\n\r\n  private _$selectedIds = new BehaviorSubject<Array<Id> | Id | undefined>(undefined);\r\n  $selectedIds = this._$selectedIds.asObservable();\r\n\r\n  private _$methodOfSelecting = new BehaviorSubject<MethodsForSelectingTypes>(0);\r\n  $methodOfSelecting = this._$methodOfSelecting.asObservable();\r\n\r\n  set methodOfSelecting(v: MethodsForSelectingTypes) {\r\n    this._$methodOfSelecting.next(v);\r\n  }\r\n\r\n  private _trackBox: TrackBox | undefined;\r\n\r\n  constructor() {\r\n    this._$methodOfSelecting.pipe(\r\n      takeUntilDestroyed(),\r\n      tap(v => {\r\n        switch (v) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const curr = this._$selectedIds.getValue();\r\n            if (typeof curr !== 'number' && typeof curr !== 'string') {\r\n              this._$selectedIds.next(undefined);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.MULTI_SELECT: {\r\n            if (!Array.isArray(this._$selectedIds.getValue())) {\r\n              this._$selectedIds.next([]);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.NONE:\r\n          default: {\r\n            this._$selectedIds.next(undefined);\r\n            break;\r\n          }\r\n        }\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  setSelectedIds(ids: Array<Id> | Id | undefined) {\r\n    this._$selectedIds.next(ids);\r\n  }\r\n\r\n  itemClick(data: IRenderVirtualListItem | undefined) {\r\n    this._$itemClick.next(data);\r\n    if (data && data.config.selectable) {\r\n      switch (this._$methodOfSelecting.getValue()) {\r\n        case MethodsForSelectingTypes.SELECT: {\r\n          const curr = this._$selectedIds.getValue() as (Id | undefined);\r\n          this._$selectedIds.next(curr !== data?.id ? data?.id : undefined);\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.MULTI_SELECT: {\r\n          const curr = [...(this._$selectedIds.getValue() || []) as Array<Id>], index = curr.indexOf(data.id);\r\n          if (index > -1) {\r\n            curr.splice(index, 1);\r\n            this._$selectedIds.next(curr);\r\n          } else {\r\n            this._$selectedIds.next([...curr, data.id]);\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.NONE:\r\n        default: {\r\n          this._$selectedIds.next(undefined);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  initialize(trackBox: TrackBox) {\r\n    this._trackBox = trackBox;\r\n  }\r\n\r\n  generateComponentId() {\r\n    return this._nextComponentId = this._nextComponentId === Number.MAX_SAFE_INTEGER\r\n      ? 0 : this._nextComponentId + 1;\r\n  }\r\n}\r\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list.service.js","sourceRoot":"","sources":["../../../../projects/ng-virtual-list/src/lib/ng-virtual-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Subject, tap } from 'rxjs';\r\nimport { TrackBox } from './utils/trackBox';\r\nimport { IRenderVirtualListItem } from './models';\r\nimport { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';\r\nimport { Id } from './types';\r\nimport { MethodsForSelectingTypes } from './enums/method-for-selecting-types';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { DEFAULT_SELECT_BY_CLICK } from './const';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class NgVirtualListService {\r\n  private _nextComponentId: number = 0;\r\n\r\n  private _$itemClick = new Subject<IRenderVirtualListItem<any> | undefined>();\r\n  $itemClick = this._$itemClick.asObservable();\r\n\r\n  private _$selectedIds = new BehaviorSubject<Array<Id> | Id | undefined>(undefined);\r\n  $selectedIds = this._$selectedIds.asObservable();\r\n\r\n  private _$methodOfSelecting = new BehaviorSubject<MethodsForSelectingTypes>(0);\r\n  $methodOfSelecting = this._$methodOfSelecting.asObservable();\r\n\r\n  set methodOfSelecting(v: MethodsForSelectingTypes) {\r\n    this._$methodOfSelecting.next(v);\r\n  }\r\n\r\n  selectByClick: boolean = DEFAULT_SELECT_BY_CLICK;\r\n\r\n  private _trackBox: TrackBox | undefined;\r\n\r\n  constructor() {\r\n    this._$methodOfSelecting.pipe(\r\n      takeUntilDestroyed(),\r\n      tap(v => {\r\n        switch (v) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const curr = this._$selectedIds.getValue();\r\n            if (typeof curr !== 'number' && typeof curr !== 'string') {\r\n              this._$selectedIds.next(undefined);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.MULTI_SELECT: {\r\n            if (!Array.isArray(this._$selectedIds.getValue())) {\r\n              this._$selectedIds.next([]);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.NONE:\r\n          default: {\r\n            this._$selectedIds.next(undefined);\r\n            break;\r\n          }\r\n        }\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  setSelectedIds(ids: Array<Id> | Id | undefined) {\r\n    if (JSON.stringify(this._$selectedIds.getValue()) !== JSON.stringify(ids)) {\r\n      this._$selectedIds.next(ids);\r\n    }\r\n  }\r\n\r\n  itemClick(data: IRenderVirtualListItem | undefined) {\r\n    if (this.selectByClick) {\r\n      this.select(data);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Selects a list item\r\n   * @param data \r\n   * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n   */\r\n  select(data: IRenderVirtualListItem | undefined, selected: boolean | undefined = undefined) {\r\n    if (data && data.config.selectable) {\r\n      switch (this._$methodOfSelecting.getValue()) {\r\n        case MethodsForSelectingTypes.SELECT: {\r\n          const curr = this._$selectedIds.getValue() as (Id | undefined);\r\n          if (selected === undefined) {\r\n            this._$selectedIds.next(curr !== data?.id ? data?.id : undefined);\r\n          } else {\r\n            this._$selectedIds.next(selected ? data?.id : undefined);\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.MULTI_SELECT: {\r\n          const curr = [...(this._$selectedIds.getValue() || []) as Array<Id>], index = curr.indexOf(data.id);\r\n          if (selected === undefined) {\r\n            if (index > -1) {\r\n              curr.splice(index, 1);\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next([...curr, data.id]);\r\n            }\r\n          } else if (selected) {\r\n            if (index > -1) {\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next([...curr, data.id]);\r\n            }\r\n          } else {\r\n            if (index > -1) {\r\n              curr.splice(index, 1);\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next(curr);\r\n            }\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.NONE:\r\n        default: {\r\n          this._$selectedIds.next(undefined);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  initialize(trackBox: TrackBox) {\r\n    this._trackBox = trackBox;\r\n  }\r\n\r\n  generateComponentId() {\r\n    return this._nextComponentId = this._nextComponentId === Number.MAX_SAFE_INTEGER\r\n      ? 0 : this._nextComponentId + 1;\r\n  }\r\n}\r\n"]}
|
|
@@ -70,6 +70,7 @@ const DEFAULT_BUFFER_SIZE = 2;
|
|
|
70
70
|
const DEFAULT_MAX_BUFFER_SIZE = 100;
|
|
71
71
|
const DEFAULT_LIST_SIZE = 400;
|
|
72
72
|
const DEFAULT_SNAP = false;
|
|
73
|
+
const DEFAULT_SELECT_BY_CLICK = true;
|
|
73
74
|
const DEFAULT_ENABLED_BUFFER_OPTIMIZATION = false;
|
|
74
75
|
const DEFAULT_DYNAMIC_SIZE = false;
|
|
75
76
|
const TRACK_BY_PROPERTY_NAME = 'id';
|
|
@@ -156,6 +157,7 @@ class NgVirtualListService {
|
|
|
156
157
|
set methodOfSelecting(v) {
|
|
157
158
|
this._$methodOfSelecting.next(v);
|
|
158
159
|
}
|
|
160
|
+
selectByClick = DEFAULT_SELECT_BY_CLICK;
|
|
159
161
|
_trackBox;
|
|
160
162
|
constructor() {
|
|
161
163
|
this._$methodOfSelecting.pipe(takeUntilDestroyed(), tap(v => {
|
|
@@ -182,25 +184,60 @@ class NgVirtualListService {
|
|
|
182
184
|
})).subscribe();
|
|
183
185
|
}
|
|
184
186
|
setSelectedIds(ids) {
|
|
185
|
-
this._$selectedIds.
|
|
187
|
+
if (JSON.stringify(this._$selectedIds.getValue()) !== JSON.stringify(ids)) {
|
|
188
|
+
this._$selectedIds.next(ids);
|
|
189
|
+
}
|
|
186
190
|
}
|
|
187
191
|
itemClick(data) {
|
|
188
|
-
this.
|
|
192
|
+
if (this.selectByClick) {
|
|
193
|
+
this.select(data);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Selects a list item
|
|
198
|
+
* @param data
|
|
199
|
+
* @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
|
|
200
|
+
*/
|
|
201
|
+
select(data, selected = undefined) {
|
|
189
202
|
if (data && data.config.selectable) {
|
|
190
203
|
switch (this._$methodOfSelecting.getValue()) {
|
|
191
204
|
case MethodsForSelectingTypes.SELECT: {
|
|
192
205
|
const curr = this._$selectedIds.getValue();
|
|
193
|
-
|
|
206
|
+
if (selected === undefined) {
|
|
207
|
+
this._$selectedIds.next(curr !== data?.id ? data?.id : undefined);
|
|
208
|
+
}
|
|
209
|
+
else {
|
|
210
|
+
this._$selectedIds.next(selected ? data?.id : undefined);
|
|
211
|
+
}
|
|
194
212
|
break;
|
|
195
213
|
}
|
|
196
214
|
case MethodsForSelectingTypes.MULTI_SELECT: {
|
|
197
215
|
const curr = [...(this._$selectedIds.getValue() || [])], index = curr.indexOf(data.id);
|
|
198
|
-
if (
|
|
199
|
-
|
|
200
|
-
|
|
216
|
+
if (selected === undefined) {
|
|
217
|
+
if (index > -1) {
|
|
218
|
+
curr.splice(index, 1);
|
|
219
|
+
this._$selectedIds.next(curr);
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
this._$selectedIds.next([...curr, data.id]);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
else if (selected) {
|
|
226
|
+
if (index > -1) {
|
|
227
|
+
this._$selectedIds.next(curr);
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
this._$selectedIds.next([...curr, data.id]);
|
|
231
|
+
}
|
|
201
232
|
}
|
|
202
233
|
else {
|
|
203
|
-
|
|
234
|
+
if (index > -1) {
|
|
235
|
+
curr.splice(index, 1);
|
|
236
|
+
this._$selectedIds.next(curr);
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
this._$selectedIds.next(curr);
|
|
240
|
+
}
|
|
204
241
|
}
|
|
205
242
|
break;
|
|
206
243
|
}
|
|
@@ -248,6 +285,7 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
|
|
|
248
285
|
get part() { return this._part; }
|
|
249
286
|
_isSelected = false;
|
|
250
287
|
config = new BehaviorSubject$1({});
|
|
288
|
+
measures = new BehaviorSubject$1(undefined);
|
|
251
289
|
regular = false;
|
|
252
290
|
data;
|
|
253
291
|
_$data = new BehaviorSubject$1(this.data);
|
|
@@ -259,6 +297,7 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
|
|
|
259
297
|
this.data = v;
|
|
260
298
|
this.updatePartStr(v, this._isSelected);
|
|
261
299
|
this.updateConfig(v);
|
|
300
|
+
this.updateMeasures(v);
|
|
262
301
|
this.update();
|
|
263
302
|
this._$data.next(v);
|
|
264
303
|
this._cdr.detectChanges();
|
|
@@ -289,6 +328,14 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
|
|
|
289
328
|
get element() {
|
|
290
329
|
return this._elementRef.nativeElement;
|
|
291
330
|
}
|
|
331
|
+
_selectHandler = (data) =>
|
|
332
|
+
/**
|
|
333
|
+
* Selects a list item
|
|
334
|
+
* @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
|
|
335
|
+
*/
|
|
336
|
+
(selected = undefined) => {
|
|
337
|
+
this._service.select(data, selected);
|
|
338
|
+
};
|
|
292
339
|
constructor(_cdr, _elementRef, _service) {
|
|
293
340
|
super();
|
|
294
341
|
this._cdr = _cdr;
|
|
@@ -319,10 +366,14 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
|
|
|
319
366
|
}
|
|
320
367
|
this.updatePartStr(this.data, this._isSelected);
|
|
321
368
|
this.updateConfig(this.data);
|
|
369
|
+
this.updateMeasures(this.data);
|
|
322
370
|
})).subscribe();
|
|
323
371
|
}
|
|
372
|
+
updateMeasures(v) {
|
|
373
|
+
this.measures.next(v?.measures ? { ...v.measures } : undefined);
|
|
374
|
+
}
|
|
324
375
|
updateConfig(v) {
|
|
325
|
-
this.config.next({ ...v?.config || {}, selected: this._isSelected });
|
|
376
|
+
this.config.next({ ...v?.config || {}, selected: this._isSelected, select: this._selectHandler(v) });
|
|
326
377
|
}
|
|
327
378
|
update() {
|
|
328
379
|
const data = this.data, regular = this.regular, length = this._regularLength;
|
|
@@ -413,14 +464,14 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
|
|
|
413
464
|
}
|
|
414
465
|
}
|
|
415
466
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: NgVirtualListService }], target: i0.ɵɵFactoryTarget.Component });
|
|
416
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { attributes: { "role": "listitem" }, classAttribute: "ngvl__item" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"part\" 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 });
|
|
467
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { attributes: { "role": "listitem" }, classAttribute: "ngvl__item" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"part\" 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 || {}, measures: measures | async, config: config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit}\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 });
|
|
417
468
|
}
|
|
418
469
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, decorators: [{
|
|
419
470
|
type: Component,
|
|
420
471
|
args: [{ selector: 'ng-virtual-list-item', host: {
|
|
421
472
|
'class': 'ngvl__item',
|
|
422
473
|
'role': 'listitem',
|
|
423
|
-
}, 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"] }]
|
|
474
|
+
}, 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 || {}, measures: measures | async, config: config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit}\n"] }]
|
|
424
475
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: NgVirtualListService }]; } });
|
|
425
476
|
|
|
426
477
|
/**
|
|
@@ -1838,6 +1889,21 @@ class NgVirtualListComponent {
|
|
|
1838
1889
|
}
|
|
1839
1890
|
;
|
|
1840
1891
|
get selectedIds() { return this._$selectedIds.getValue(); }
|
|
1892
|
+
_$selectByClick = new BehaviorSubject$1(DEFAULT_SELECT_BY_CLICK);
|
|
1893
|
+
$selectByClick = this._$selectByClick.asObservable();
|
|
1894
|
+
/**
|
|
1895
|
+
* If false, the element is selected using the config.select method passed to the template;
|
|
1896
|
+
* if true, the element is selected by clicking on it. The default value is true.
|
|
1897
|
+
*/
|
|
1898
|
+
set selectByClick(v) {
|
|
1899
|
+
if (this._$selectByClick.getValue() === v) {
|
|
1900
|
+
return;
|
|
1901
|
+
}
|
|
1902
|
+
this._$selectByClick.next(v);
|
|
1903
|
+
this._cdr.markForCheck();
|
|
1904
|
+
}
|
|
1905
|
+
;
|
|
1906
|
+
get selectByClick() { return this._$selectByClick.getValue(); }
|
|
1841
1907
|
_$snap = new BehaviorSubject$1(DEFAULT_SNAP);
|
|
1842
1908
|
$snap = this._$snap.asObservable();
|
|
1843
1909
|
/**
|
|
@@ -2146,7 +2212,10 @@ class NgVirtualListComponent {
|
|
|
2146
2212
|
this._$initialized = new BehaviorSubject$1(false);
|
|
2147
2213
|
this.$initialized = this._$initialized.asObservable();
|
|
2148
2214
|
this._trackBox.displayComponents = this._displayComponents;
|
|
2149
|
-
const $trackBy = this.$trackBy;
|
|
2215
|
+
const $trackBy = this.$trackBy, $selectByClick = this.$selectByClick;
|
|
2216
|
+
$selectByClick.pipe(takeUntilDestroyed(), tap(v => {
|
|
2217
|
+
this._service.selectByClick = v;
|
|
2218
|
+
})).subscribe();
|
|
2150
2219
|
$trackBy.pipe(takeUntilDestroyed(), tap(v => {
|
|
2151
2220
|
this._trackBox.trackingPropertyName = v;
|
|
2152
2221
|
})).subscribe();
|
|
@@ -2165,7 +2234,6 @@ class NgVirtualListComponent {
|
|
|
2165
2234
|
this._isMultiSelecting = true;
|
|
2166
2235
|
this._isNotSelecting = this._isSingleSelecting = false;
|
|
2167
2236
|
if (el) {
|
|
2168
|
-
console.log('set role', ROLE_LIST_BOX);
|
|
2169
2237
|
el.setAttribute('role', ROLE_LIST_BOX);
|
|
2170
2238
|
}
|
|
2171
2239
|
this._service.methodOfSelecting = MethodsForSelectingTypes.MULTI_SELECT;
|
|
@@ -2174,7 +2242,6 @@ class NgVirtualListComponent {
|
|
|
2174
2242
|
this._isSingleSelecting = true;
|
|
2175
2243
|
this._isNotSelecting = this._isMultiSelecting = false;
|
|
2176
2244
|
if (el) {
|
|
2177
|
-
console.log('set role', ROLE_LIST_BOX);
|
|
2178
2245
|
el.setAttribute('role', ROLE_LIST_BOX);
|
|
2179
2246
|
}
|
|
2180
2247
|
this._service.methodOfSelecting = MethodsForSelectingTypes.SELECT;
|
|
@@ -2183,7 +2250,6 @@ class NgVirtualListComponent {
|
|
|
2183
2250
|
this._isNotSelecting = true;
|
|
2184
2251
|
this._isSingleSelecting = this._isMultiSelecting = false;
|
|
2185
2252
|
if (el) {
|
|
2186
|
-
console.log('set role', ROLE_LIST);
|
|
2187
2253
|
el.setAttribute('role', ROLE_LIST);
|
|
2188
2254
|
}
|
|
2189
2255
|
this._service.methodOfSelecting = MethodsForSelectingTypes.NONE;
|
|
@@ -2231,10 +2297,19 @@ class NgVirtualListComponent {
|
|
|
2231
2297
|
this._service.$itemClick.pipe(takeUntilDestroyed(), tap(v => {
|
|
2232
2298
|
this.onItemClick.emit(v ?? undefined);
|
|
2233
2299
|
})).subscribe();
|
|
2234
|
-
|
|
2235
|
-
|
|
2300
|
+
let isSelectedIdsFirstEmit = 0;
|
|
2301
|
+
this._service.$selectedIds.pipe(takeUntilDestroyed(), distinctUntilChanged(), tap(v => {
|
|
2302
|
+
if (this.isSingleSelecting || (this.isMultiSelecting && isSelectedIdsFirstEmit >= 2)) {
|
|
2303
|
+
const curr = this._$selectedIds.getValue();
|
|
2304
|
+
if ((this.isSingleSelecting && JSON.stringify(v) !== JSON.stringify(curr)) || (isSelectedIdsFirstEmit === 2 && JSON.stringify(v) !== JSON.stringify(curr)) || isSelectedIdsFirstEmit > 2) {
|
|
2305
|
+
this.onSelect.emit(v);
|
|
2306
|
+
}
|
|
2307
|
+
}
|
|
2308
|
+
if (isSelectedIdsFirstEmit < 3) {
|
|
2309
|
+
isSelectedIdsFirstEmit++;
|
|
2310
|
+
}
|
|
2236
2311
|
})).subscribe();
|
|
2237
|
-
$selectedIds.pipe(takeUntilDestroyed(), tap(v => {
|
|
2312
|
+
$selectedIds.pipe(takeUntilDestroyed(), distinctUntilChanged(), tap(v => {
|
|
2238
2313
|
this._service.setSelectedIds(v);
|
|
2239
2314
|
})).subscribe();
|
|
2240
2315
|
}
|
|
@@ -2497,7 +2572,7 @@ class NgVirtualListComponent {
|
|
|
2497
2572
|
}
|
|
2498
2573
|
}
|
|
2499
2574
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: NgVirtualListService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2500
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListComponent, selector: "ng-virtual-list", inputs: { items: "items", selectedIds: "selectedIds", snap: "snap", enabledBufferOptimization: "enabledBufferOptimization", itemRenderer: "itemRenderer", stickyMap: "stickyMap", itemConfigMap: "itemConfigMap", itemSize: "itemSize", dynamicSize: "dynamicSize", direction: "direction", itemsOffset: "itemsOffset", bufferSize: "bufferSize", maxBufferSize: "maxBufferSize", trackBy: "trackBy", snappingMethod: "snappingMethod", methodForSelecting: "methodForSelecting" }, outputs: { onScroll: "onScroll", onScrollEnd: "onScrollEnd", onViewportChange: "onViewportChange", onItemClick: "onItemClick", onSelect: "onSelect" }, providers: [NgVirtualListService], viewQueries: [{ propertyName: "_listContainerRef", first: true, predicate: ["renderersContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_container", first: true, predicate: ["container"], descendants: true, read: (ElementRef) }, { propertyName: "_list", first: true, predicate: ["list"], descendants: true, read: (ElementRef) }, { propertyName: "_snapContainerRef", first: true, predicate: ["snapRendererContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_snappedContainer", first: true, predicate: ["snapped"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <div [attr.aria-orientation]=\"orientation\" #list part=\"list\" class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </div>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
|
|
2575
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListComponent, selector: "ng-virtual-list", inputs: { items: "items", selectedIds: "selectedIds", selectByClick: "selectByClick", snap: "snap", enabledBufferOptimization: "enabledBufferOptimization", itemRenderer: "itemRenderer", stickyMap: "stickyMap", itemConfigMap: "itemConfigMap", itemSize: "itemSize", dynamicSize: "dynamicSize", direction: "direction", itemsOffset: "itemsOffset", bufferSize: "bufferSize", maxBufferSize: "maxBufferSize", trackBy: "trackBy", snappingMethod: "snappingMethod", methodForSelecting: "methodForSelecting" }, outputs: { onScroll: "onScroll", onScrollEnd: "onScrollEnd", onViewportChange: "onViewportChange", onItemClick: "onItemClick", onSelect: "onSelect" }, providers: [NgVirtualListService], viewQueries: [{ propertyName: "_listContainerRef", first: true, predicate: ["renderersContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_container", first: true, predicate: ["container"], descendants: true, read: (ElementRef) }, { propertyName: "_list", first: true, predicate: ["list"], descendants: true, read: (ElementRef) }, { propertyName: "_snapContainerRef", first: true, predicate: ["snapRendererContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_snappedContainer", first: true, predicate: ["snapped"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <div [attr.aria-orientation]=\"orientation\" #list part=\"list\" class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </div>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
|
|
2501
2576
|
}
|
|
2502
2577
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListComponent, decorators: [{
|
|
2503
2578
|
type: Component,
|
|
@@ -2531,6 +2606,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
2531
2606
|
type: Input
|
|
2532
2607
|
}], selectedIds: [{
|
|
2533
2608
|
type: Input
|
|
2609
|
+
}], selectByClick: [{
|
|
2610
|
+
type: Input
|
|
2534
2611
|
}], snap: [{
|
|
2535
2612
|
type: Input
|
|
2536
2613
|
}], enabledBufferOptimization: [{
|