ng-virtual-list 17.11.0 → 17.11.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (134) hide show
  1. package/README.md +5 -1
  2. package/esm2022/lib/components/ng-list-item/base/base-virtual-list-item-component.mjs +206 -0
  3. package/esm2022/lib/components/ng-list-item/base/index.mjs +3 -0
  4. package/esm2022/lib/components/ng-list-item/const/index.mjs +2 -0
  5. package/esm2022/lib/components/ng-list-item/interfaces/index.mjs +2 -0
  6. package/esm2022/lib/components/ng-list-item/interfaces/template-context.mjs +2 -0
  7. package/esm2022/lib/components/ng-list-item/ng-virtual-list-item.component.mjs +196 -0
  8. package/esm2022/lib/components/ng-list-item/ng-virtual-list-item.module.mjs +20 -0
  9. package/esm2022/lib/components/ng-list-item/utils/create-display-id.mjs +4 -0
  10. package/esm2022/lib/components/ng-list-item/utils/get-element-by-index.mjs +6 -0
  11. package/esm2022/lib/components/ng-list-item/utils/index.mjs +4 -0
  12. package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.component.mjs +154 -0
  13. package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.module.mjs +21 -0
  14. package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.component.mjs +78 -0
  15. package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.module.mjs +20 -0
  16. package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.component.mjs +118 -0
  17. package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.module.mjs +20 -0
  18. package/esm2022/lib/components/ng-prerender-container/core/index.mjs +3 -0
  19. package/esm2022/lib/components/ng-prerender-container/core/prerender-track-box.mjs +168 -0
  20. package/esm2022/lib/components/ng-prerender-container/events/index.mjs +6 -0
  21. package/esm2022/lib/components/ng-prerender-container/interfaces/index.mjs +2 -0
  22. package/esm2022/lib/components/ng-prerender-container/interfaces/refresh-params.mjs +2 -0
  23. package/esm2022/lib/components/ng-prerender-container/ng-prerender-container.component.mjs +63 -0
  24. package/esm2022/lib/components/ng-prerender-container/ng-prerender-container.module.mjs +20 -0
  25. package/esm2022/lib/components/ng-prerender-container/types/cache.mjs +2 -0
  26. package/esm2022/lib/components/ng-prerender-container/types/index.mjs +2 -0
  27. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.component.mjs +1 -1
  28. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.module.mjs +3 -3
  29. package/esm2022/lib/components/ng-scroll-view/ng-scroll-view.component.mjs +10 -8
  30. package/esm2022/lib/components/ng-scroller/const/index.mjs +2 -0
  31. package/esm2022/lib/components/ng-scroller/enums/index.mjs +3 -0
  32. package/esm2022/lib/components/ng-scroller/enums/scroller-direction.mjs +6 -0
  33. package/esm2022/lib/components/ng-scroller/enums/scroller-directions.mjs +2 -0
  34. package/esm2022/lib/components/ng-scroller/ng-scroller.component.mjs +343 -0
  35. package/esm2022/lib/components/ng-scroller/ng-scroller.module.mjs +22 -0
  36. package/esm2022/lib/components/ng-scroller/utils/index.mjs +3 -0
  37. package/esm2022/lib/components/ng-scroller/utils/scroll-box.mjs +52 -0
  38. package/esm2022/lib/const/index.mjs +9 -1
  39. package/esm2022/lib/core/track-box.mjs +9 -7
  40. package/esm2022/lib/core/tracker.mjs +1 -1
  41. package/esm2022/lib/directives/item-click/item-click.directive.mjs +2 -2
  42. package/esm2022/lib/directives/locale-sensitive/locale-sensitive.directive.mjs +3 -3
  43. package/esm2022/lib/interfaces/index.mjs +1 -1
  44. package/esm2022/lib/interfaces/scrolling-settings.mjs +2 -0
  45. package/esm2022/lib/ng-virtual-list-public.service.mjs +1 -1
  46. package/esm2022/lib/ng-virtual-list.component.mjs +120 -50
  47. package/esm2022/lib/ng-virtual-list.module.mjs +7 -7
  48. package/esm2022/lib/ng-virtual-list.service.mjs +2 -2
  49. package/esm2022/public-api.mjs +2 -2
  50. package/fesm2022/ng-virtual-list.mjs +212 -130
  51. package/fesm2022/ng-virtual-list.mjs.map +1 -1
  52. package/lib/components/{list-item → ng-list-item}/base/base-virtual-list-item-component.d.ts +2 -0
  53. package/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.component.d.ts +0 -2
  54. package/lib/components/{prerender-container/components/prerender-list/prerender-list.component.d.ts → ng-prerender-container/components/ng-prerender-list/ng-prerender-list.component.d.ts} +4 -4
  55. package/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.module.d.ts +10 -0
  56. package/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.component.d.ts +17 -0
  57. package/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.module.d.ts +9 -0
  58. package/lib/components/{prerender-container/components/prerender-scroller/prerender-scroller.component.d.ts → ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.component.d.ts} +3 -3
  59. package/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.module.d.ts +9 -0
  60. package/lib/components/{prerender-container → ng-prerender-container}/core/prerender-track-box.d.ts +1 -1
  61. package/lib/components/{prerender-container/prerender-container.component.d.ts → ng-prerender-container/ng-prerender-container.component.d.ts} +4 -4
  62. package/lib/components/ng-prerender-container/ng-prerender-container.module.d.ts +9 -0
  63. package/lib/components/ng-scroll-view/ng-scroll-view.component.d.ts +3 -1
  64. package/lib/const/index.d.ts +2 -1
  65. package/lib/core/track-box.d.ts +4 -3
  66. package/lib/core/tracker.d.ts +1 -1
  67. package/lib/directives/item-click/item-click.directive.d.ts +1 -1
  68. package/lib/directives/locale-sensitive/locale-sensitive.directive.d.ts +2 -2
  69. package/lib/interfaces/index.d.ts +2 -1
  70. package/lib/interfaces/scrolling-settings.d.ts +38 -0
  71. package/lib/ng-virtual-list.component.d.ts +14 -3
  72. package/lib/ng-virtual-list.module.d.ts +4 -4
  73. package/package.json +1 -1
  74. package/public-api.d.ts +1 -1
  75. package/esm2022/lib/components/list-item/base/base-virtual-list-item-component.mjs +0 -200
  76. package/esm2022/lib/components/list-item/base/index.mjs +0 -3
  77. package/esm2022/lib/components/list-item/const/index.mjs +0 -2
  78. package/esm2022/lib/components/list-item/interfaces/index.mjs +0 -2
  79. package/esm2022/lib/components/list-item/interfaces/template-context.mjs +0 -2
  80. package/esm2022/lib/components/list-item/ng-virtual-list-item.component.mjs +0 -201
  81. package/esm2022/lib/components/list-item/ng-virtual-list-item.module.mjs +0 -20
  82. package/esm2022/lib/components/list-item/utils/create-display-id.mjs +0 -4
  83. package/esm2022/lib/components/list-item/utils/get-element-by-index.mjs +0 -6
  84. package/esm2022/lib/components/list-item/utils/index.mjs +0 -4
  85. package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.component.mjs +0 -154
  86. package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.module.mjs +0 -21
  87. package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.mjs +0 -78
  88. package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.mjs +0 -20
  89. package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.mjs +0 -118
  90. package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.mjs +0 -20
  91. package/esm2022/lib/components/prerender-container/core/index.mjs +0 -3
  92. package/esm2022/lib/components/prerender-container/core/prerender-track-box.mjs +0 -168
  93. package/esm2022/lib/components/prerender-container/events/index.mjs +0 -6
  94. package/esm2022/lib/components/prerender-container/interfaces/index.mjs +0 -2
  95. package/esm2022/lib/components/prerender-container/interfaces/refresh-params.mjs +0 -2
  96. package/esm2022/lib/components/prerender-container/prerender-container.component.mjs +0 -63
  97. package/esm2022/lib/components/prerender-container/prerender-container.module.mjs +0 -20
  98. package/esm2022/lib/components/prerender-container/types/cache.mjs +0 -2
  99. package/esm2022/lib/components/prerender-container/types/index.mjs +0 -2
  100. package/esm2022/lib/components/scroller/const/index.mjs +0 -2
  101. package/esm2022/lib/components/scroller/enums/index.mjs +0 -3
  102. package/esm2022/lib/components/scroller/enums/scroller-direction.mjs +0 -6
  103. package/esm2022/lib/components/scroller/enums/scroller-directions.mjs +0 -2
  104. package/esm2022/lib/components/scroller/ng-scroller.component.mjs +0 -343
  105. package/esm2022/lib/components/scroller/ng-scroller.module.mjs +0 -22
  106. package/esm2022/lib/components/scroller/utils/index.mjs +0 -3
  107. package/esm2022/lib/components/scroller/utils/scroll-box.mjs +0 -52
  108. package/lib/components/prerender-container/components/prerender-list/prerender-list.module.d.ts +0 -10
  109. package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.d.ts +0 -17
  110. package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.d.ts +0 -9
  111. package/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.d.ts +0 -9
  112. package/lib/components/prerender-container/prerender-container.module.d.ts +0 -9
  113. /package/lib/components/{list-item → ng-list-item}/base/index.d.ts +0 -0
  114. /package/lib/components/{list-item → ng-list-item}/const/index.d.ts +0 -0
  115. /package/lib/components/{list-item → ng-list-item}/interfaces/index.d.ts +0 -0
  116. /package/lib/components/{list-item → ng-list-item}/interfaces/template-context.d.ts +0 -0
  117. /package/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.module.d.ts +0 -0
  118. /package/lib/components/{list-item → ng-list-item}/utils/create-display-id.d.ts +0 -0
  119. /package/lib/components/{list-item → ng-list-item}/utils/get-element-by-index.d.ts +0 -0
  120. /package/lib/components/{list-item → ng-list-item}/utils/index.d.ts +0 -0
  121. /package/lib/components/{prerender-container → ng-prerender-container}/core/index.d.ts +0 -0
  122. /package/lib/components/{prerender-container → ng-prerender-container}/events/index.d.ts +0 -0
  123. /package/lib/components/{prerender-container → ng-prerender-container}/interfaces/index.d.ts +0 -0
  124. /package/lib/components/{prerender-container → ng-prerender-container}/interfaces/refresh-params.d.ts +0 -0
  125. /package/lib/components/{prerender-container → ng-prerender-container}/types/cache.d.ts +0 -0
  126. /package/lib/components/{prerender-container → ng-prerender-container}/types/index.d.ts +0 -0
  127. /package/lib/components/{scroller → ng-scroller}/const/index.d.ts +0 -0
  128. /package/lib/components/{scroller → ng-scroller}/enums/index.d.ts +0 -0
  129. /package/lib/components/{scroller → ng-scroller}/enums/scroller-direction.d.ts +0 -0
  130. /package/lib/components/{scroller → ng-scroller}/enums/scroller-directions.d.ts +0 -0
  131. /package/lib/components/{scroller → ng-scroller}/ng-scroller.component.d.ts +0 -0
  132. /package/lib/components/{scroller → ng-scroller}/ng-scroller.module.d.ts +0 -0
  133. /package/lib/components/{scroller → ng-scroller}/utils/index.d.ts +0 -0
  134. /package/lib/components/{scroller → ng-scroller}/utils/scroll-box.d.ts +0 -0
package/README.md CHANGED
@@ -16,9 +16,12 @@ Works correctly in all browsers and platforms.
16
16
  ![npm downloads](https://img.shields.io/npm/dm/ng-virtual-list)
17
17
  ![npm total downloads](https://img.shields.io/npm/dt/ng-virtual-list)
18
18
 
19
- [Live Demo](https://chat-demo.eugene-grebennikov.pro/)
19
+ [Chat Demo](https://chat-demo.eugene-grebennikov.pro/)
20
20
  [(Code)](https://github.com/DjonnyX/ng-virtual-list-chat-demo)
21
21
 
22
+ [News Feed Demo](https://news-feed-demo.eugene-grebennikov.pro/)
23
+ [(Code)](https://github.com/DjonnyX/ng-virtual-list-news-feed-demo)
24
+
22
25
  [Live Examples (Storybook)](https://ng-virtual-list-examples.eugene-grebennikov.pro/)
23
26
 
24
27
  [Examples](https://ng-virtual-list.eugene-grebennikov.pro/)
@@ -635,6 +638,7 @@ Inputs
635
638
  | scrollbarThumbRenderer | TemplateRef<any> \| null = null | Scrollbar customization template. |
636
639
  | scrollbarThumbParams | {[propName: string]: any;} \| null | Additional options for the scrollbar. |
637
640
  | scrollBehavior | ScrollBehavior? = 'smooth' | Defines the scrolling behavior for any element on the page. The default value is "smooth". |
641
+ | scrollingSettings | [IScrollingSettings](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/scrolling-settings.ts) = {frictionalForce: 0.035, mass: 0.005, maxDistance: 12500, maxDuration: 4000, speedScale: 15, optimization: true} | Scrolling settings. |
638
642
  | trackBy | string? = 'id' | The name of the property by which tracking is performed. |
639
643
 
640
644
  <br/>
@@ -0,0 +1,206 @@
1
+ import { ChangeDetectorRef, computed, DestroyRef, ElementRef, inject, signal } from '@angular/core';
2
+ import { DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN, PART_ITEM_FOCUSED, PART_ITEM_NEW, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, PX, SIZE_100_PERSENT, SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE, } from '../../../const';
3
+ import { CLASS_NAME_FOCUS, CLASS_NAME_SNAPPED, CLASS_NAME_SNAPPED_OUT, ID, ITEM_ID, POSITION, POSITION_ZERO, TRANSLATE_3D_HIDDEN, } from '../const';
4
+ import { TextDirections } from '../../../enums';
5
+ import { NgVirtualListPublicService } from '../../../ng-virtual-list-public.service';
6
+ import { NgVirtualListService } from '../../../ng-virtual-list.service';
7
+ import { createDisplayId } from '../utils';
8
+ /**
9
+ * BaseVirtualListItemComponent
10
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/components/list-item/base/base-virtual-list-item-component.ts
11
+ * @author Evgenii Alexandrovich Grebennikov
12
+ * @email djonnyx@gmail.com
13
+ */
14
+ export class BaseVirtualListItemComponent {
15
+ _cdr = inject(ChangeDetectorRef);
16
+ _apiService = inject(NgVirtualListPublicService);
17
+ _service = inject(NgVirtualListService);
18
+ _id;
19
+ get id() {
20
+ return this._id;
21
+ }
22
+ _listId;
23
+ get listId() {
24
+ return this._listId;
25
+ }
26
+ _displayId;
27
+ get displayId() {
28
+ return this._displayId;
29
+ }
30
+ _isSelected = false;
31
+ _isCollapsed = false;
32
+ config = signal({});
33
+ measures = signal(null);
34
+ focused = signal(false);
35
+ part = signal(PART_DEFAULT_ITEM);
36
+ data = signal(null);
37
+ _data = null;
38
+ set item(v) {
39
+ if (this._data === v || this._data?.id === -1 || !v) {
40
+ return;
41
+ }
42
+ this._data = v;
43
+ this.updatePartStr(v, this._isSelected, this._isCollapsed);
44
+ this.updateConfig(v);
45
+ this.updateMeasures(v);
46
+ this.update();
47
+ this.data.set(v);
48
+ this._cdr.markForCheck();
49
+ }
50
+ classes;
51
+ index;
52
+ templateContext;
53
+ regular = false;
54
+ _scrollBarSize = 0;
55
+ _langTextDir = TextDirections.LTR;
56
+ _regularLength = SIZE_100_PERSENT;
57
+ set regularLength(v) {
58
+ if (this._regularLength === v) {
59
+ return;
60
+ }
61
+ this._regularLength = v;
62
+ this.update();
63
+ this._cdr.markForCheck();
64
+ }
65
+ get item() {
66
+ return this._data;
67
+ }
68
+ get itemId() {
69
+ return this._data?.id;
70
+ }
71
+ itemRenderer = signal(undefined);
72
+ _renderer;
73
+ set renderer(v) {
74
+ if (this._renderer !== v) {
75
+ this._renderer = v;
76
+ this.itemRenderer.set(v);
77
+ }
78
+ }
79
+ _elementRef = inject(ElementRef);
80
+ get element() {
81
+ return this._elementRef.nativeElement;
82
+ }
83
+ _destroyRef = inject(DestroyRef);
84
+ constructor() {
85
+ this._id = this._service.generateComponentId();
86
+ this._listId = this._service.id;
87
+ this._displayId = createDisplayId(this._listId, this._id);
88
+ this.classes = computed(() => {
89
+ const data = this.data(), focused = this.focused();
90
+ return {
91
+ [CLASS_NAME_SNAPPED]: data?.config?.snapped ?? false, [CLASS_NAME_SNAPPED_OUT]: data?.config?.snappedOut ?? false,
92
+ [CLASS_NAME_FOCUS]: focused,
93
+ };
94
+ });
95
+ this.index = computed(() => {
96
+ return this.config()?.tabIndex ?? -1;
97
+ });
98
+ this.templateContext = computed(() => {
99
+ const data = this.data(), measures = this.measures(), config = this.config();
100
+ return {
101
+ data: data?.data, prevData: data?.previouseData, nextData: data?.nextData, measures,
102
+ config, reseted: false, index: data?.index ?? -1, api: this._apiService,
103
+ };
104
+ });
105
+ }
106
+ updateMeasures(v) {
107
+ this.measures.set(v?.measures ? { ...v.measures } : null);
108
+ }
109
+ updateConfig(v) {
110
+ this.config.set({
111
+ ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),
112
+ });
113
+ }
114
+ update() {
115
+ const data = this._data, regular = this.regular, length = this._regularLength, el = this._elementRef.nativeElement;
116
+ if (data) {
117
+ el.setAttribute(ITEM_ID, `${data.id}`);
118
+ const styles = el.style;
119
+ styles.zIndex = data.config.zIndex;
120
+ styles.position = POSITION_ABSOLUTE;
121
+ if (data.config.isStub === true) {
122
+ el.style.visibility = VISIBILITY_HIDDEN;
123
+ }
124
+ if (regular) {
125
+ el.setAttribute(POSITION, POSITION_ZERO);
126
+ styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? (this._langTextDir === TextDirections.RTL ? this._scrollBarSize : 0) : data.measures.delta}${PX}, ${data.config.isVertical ? data.measures.delta : 0}${PX}, ${POSITION_ZERO})`;
127
+ }
128
+ else {
129
+ el.setAttribute(POSITION, `${data.config.isVertical ? data.measures.y : data.measures.x}`);
130
+ styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX}, ${POSITION_ZERO})`;
131
+ }
132
+ styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;
133
+ styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
134
+ }
135
+ else {
136
+ el.removeAttribute(ID);
137
+ }
138
+ this._cdr.markForCheck();
139
+ }
140
+ updatePartStr(v, isSelected, isCollapsed) {
141
+ let odd = false;
142
+ if (v?.index !== undefined) {
143
+ odd = v.index % 2 === 0;
144
+ }
145
+ let part = PART_DEFAULT_ITEM;
146
+ part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;
147
+ if (v ? v.config.snapped : false) {
148
+ part += PART_ITEM_SNAPPED;
149
+ }
150
+ if (isSelected) {
151
+ part += PART_ITEM_SELECTED;
152
+ }
153
+ if (isCollapsed) {
154
+ part += PART_ITEM_COLLAPSED;
155
+ }
156
+ if (v ? v.config.new : false) {
157
+ part += PART_ITEM_NEW;
158
+ }
159
+ if (this.focused()) {
160
+ part += PART_ITEM_FOCUSED;
161
+ }
162
+ this.part.set(part);
163
+ }
164
+ getBounds() {
165
+ const el = this._elementRef.nativeElement, { width, height } = el.getBoundingClientRect();
166
+ return { width: width > 0 ? width : 1, height: height > 0 ? height : 1, };
167
+ }
168
+ show() {
169
+ const el = this._elementRef.nativeElement, styles = el.style;
170
+ styles.zIndex = this._data?.config?.zIndex ?? DEFAULT_ZINDEX;
171
+ if (this.regular) {
172
+ if (styles.display === DISPLAY_BLOCK) {
173
+ return;
174
+ }
175
+ styles.display = DISPLAY_BLOCK;
176
+ }
177
+ else {
178
+ const isStub = this._data?.config?.isStub ?? false;
179
+ if (!isStub) {
180
+ if (styles.visibility === VISIBILITY_VISIBLE) {
181
+ return;
182
+ }
183
+ styles.visibility = VISIBILITY_VISIBLE;
184
+ }
185
+ }
186
+ }
187
+ hide() {
188
+ const el = this._elementRef.nativeElement, styles = el.style;
189
+ styles.position = POSITION_ABSOLUTE;
190
+ styles.transform = TRANSLATE_3D_HIDDEN;
191
+ styles.zIndex = HIDDEN_ZINDEX;
192
+ if (this.regular) {
193
+ if (styles.display === DISPLAY_NONE) {
194
+ return;
195
+ }
196
+ styles.display = DISPLAY_NONE;
197
+ }
198
+ else {
199
+ if (styles.visibility === VISIBILITY_HIDDEN) {
200
+ return;
201
+ }
202
+ styles.visibility = VISIBILITY_HIDDEN;
203
+ }
204
+ }
205
+ }
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-virtual-list-item-component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-virtual-list/src/lib/components/ng-list-item/base/base-virtual-list-item-component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAU,MAAM,EAAe,MAAM,eAAe,CAAC;AAIzH,OAAO,EACL,cAAc,EAAE,aAAa,EAAE,YAAY,EAAE,aAAa,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,cAAc,EAClH,iBAAiB,EAAE,aAAa,EAAE,aAAa,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,EAAE,EAAE,gBAAgB,EAC/H,SAAS,EAAE,YAAY,EAAE,iBAAiB,EAAE,kBAAkB,GAC/D,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,gBAAgB,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,mBAAmB,GACxH,MAAM,UAAU,CAAC;AAClB,OAAO,EAAiB,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAE,0BAA0B,EAAE,MAAM,yCAAyC,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C;;;;;GAKG;AACH,MAAM,OAAO,4BAA4B;IAC/B,IAAI,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAEjC,WAAW,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;IAEtC,QAAQ,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAEjD,GAAG,CAAU;IACvB,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAES,OAAO,CAAU;IAC3B,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAES,UAAU,CAAU;IAC9B,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAES,WAAW,GAAY,KAAK,CAAC;IAE7B,YAAY,GAAY,KAAK,CAAC;IAErB,MAAM,GAAG,MAAM,CAAuB,EAA0B,CAAC,CAAC;IAElE,QAAQ,GAAG,MAAM,CAAgC,IAAI,CAAC,CAAC;IAEvD,OAAO,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;IAEjC,IAAI,GAAG,MAAM,CAAS,iBAAiB,CAAC,CAAC;IAEzC,IAAI,GAAG,MAAM,CAAgC,IAAI,CAAC,CAAC;IAC5D,KAAK,GAAkC,IAAI,CAAC;IACtD,IAAI,IAAI,CAAC,CAAgC;QACvC,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACpD,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QAEf,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAE3D,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAErB,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QAEvB,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEjB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAEkB,OAAO,CAAyC;IAEhD,KAAK,CAAkB;IAEvB,eAAe,CAA4B;IAEvD,OAAO,GAAY,KAAK,CAAC;IAEtB,cAAc,GAAW,CAAC,CAAC;IAE3B,YAAY,GAAkB,cAAc,CAAC,GAAG,CAAC;IAEjD,cAAc,GAAW,gBAAgB,CAAC;IACpD,IAAI,aAAa,CAAC,CAAS;QACzB,IAAI,IAAI,CAAC,cAAc,KAAK,CAAC,EAAE,CAAC;YAC9B,OAAO;QACT,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QAExB,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;IACxB,CAAC;IAEkB,YAAY,GAAG,MAAM,CAA+B,SAAS,CAAC,CAAC;IAExE,SAAS,CAA+B;IAClD,IAAI,QAAQ,CAAC,CAA+B;QAC1C,IAAI,IAAI,CAAC,SAAS,KAAK,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;YACnB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAES,WAAW,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;IACpE,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;IACxC,CAAC;IAES,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAE3C;QACE,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC;QAC/C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QAChC,IAAI,CAAC,UAAU,GAAG,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAE1D,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YACnD,OAAO;gBACL,CAAC,kBAAkB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,IAAI,KAAK,EAAE,CAAC,sBAAsB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,IAAI,KAAK;gBACjH,CAAC,gBAAgB,CAAC,EAAE,OAAO;aAC5B,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzB,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE,QAAQ,IAAI,CAAC,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,GAAG,EAAE;YACnC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7E,OAAO;gBACL,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ;gBACnF,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,IAAI,CAAE,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,WAAW;aACzE,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAES,cAAc,CAAC,CAAqC;QAC5D,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IAC3D,CAAC;IAES,YAAY,CAAC,CAAqC;QAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;YACd,GAAG,CAAC,EAAE,MAAM,IAAI,EAA0B,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;SAC9H,CAAC,CAAC;IACL,CAAC;IAES,MAAM;QACd,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC,cAAc,EAAE,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QACnH,IAAI,IAAI,EAAE,CAAC;YACT,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;YACvC,MAAM,MAAM,GAAG,EAAE,CAAC,KAAK,CAAC;YACxB,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YACnC,MAAM,CAAC,QAAQ,GAAG,iBAAiB,CAAC;YACpC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;gBAChC,EAAE,CAAC,KAAK,CAAC,UAAU,GAAG,iBAAiB,CAAC;YAC1C,CAAC;YACD,IAAI,OAAO,EAAE,CAAC;gBACZ,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;gBACzC,MAAM,CAAC,SAAS,GAAG,GAAG,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,KAAK,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,aAAa,GAAG,CAAC;YAChP,CAAC;iBAAM,CAAC;gBACN,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC;gBAC3F,MAAM,CAAC,SAAS,GAAG,GAAG,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,aAAa,GAAG,CAAC;YACrK,CAAC;YACD,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,gBAAgB,CAAC;YAChJ,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,EAAE,EAAE,CAAC;QAChJ,CAAC;aAAM,CAAC;YACN,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAES,aAAa,CAAC,CAAgC,EAAE,UAAmB,EAAE,WAAoB;QACjG,IAAI,GAAG,GAAG,KAAK,CAAC;QAChB,IAAI,CAAC,EAAE,KAAK,KAAK,SAAS,EAAE,CAAC;YAC3B,GAAG,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;QAED,IAAI,IAAI,GAAG,iBAAiB,CAAC;QAC7B,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,cAAc,CAAC;QAC7C,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YACjC,IAAI,IAAI,iBAAiB,CAAC;QAC5B,CAAC;QACD,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,IAAI,kBAAkB,CAAC;QAC7B,CAAC;QACD,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,IAAI,mBAAmB,CAAC;QAC9B,CAAC;QACD,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAC7B,IAAI,IAAI,aAAa,CAAC;QACxB,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YACnB,IAAI,IAAI,iBAAiB,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;IAED,SAAS;QACP,MAAM,EAAE,GAAgB,IAAI,CAAC,WAAW,CAAC,aAAa,EACpD,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,qBAAqB,EAAE,CAAC;QACjD,OAAO,EAAE,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAC5E,CAAC;IAED,IAAI;QACF,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,aAA4B,EACtD,MAAM,GAAG,EAAE,CAAC,KAAK,CAAC;QACpB,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,IAAI,cAAc,CAAC;QAC7D,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,MAAM,CAAC,OAAO,KAAK,aAAa,EAAE,CAAC;gBACrC,OAAO;YACT,CAAC;YAED,MAAM,CAAC,OAAO,GAAG,aAAa,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,IAAI,KAAK,CAAC;YACnD,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,IAAI,MAAM,CAAC,UAAU,KAAK,kBAAkB,EAAE,CAAC;oBAC7C,OAAO;gBACT,CAAC;gBACD,MAAM,CAAC,UAAU,GAAG,kBAAkB,CAAC;YACzC,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI;QACF,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,EACvC,MAAM,GAAG,EAAE,CAAC,KAAK,CAAC;QACpB,MAAM,CAAC,QAAQ,GAAG,iBAAiB,CAAC;QACpC,MAAM,CAAC,SAAS,GAAG,mBAAmB,CAAC;QACvC,MAAM,CAAC,MAAM,GAAG,aAAa,CAAC;QAC9B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,MAAM,CAAC,OAAO,KAAK,YAAY,EAAE,CAAC;gBACpC,OAAO;YACT,CAAC;YAED,MAAM,CAAC,OAAO,GAAG,YAAY,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,IAAI,MAAM,CAAC,UAAU,KAAK,iBAAiB,EAAE,CAAC;gBAC5C,OAAO;YACT,CAAC;YAED,MAAM,CAAC,UAAU,GAAG,iBAAiB,CAAC;QACxC,CAAC;IACH,CAAC;CACF","sourcesContent":["import { ChangeDetectorRef, computed, DestroyRef, ElementRef, inject, Signal, signal, TemplateRef } from '@angular/core';\r\nimport { ISize } from '../../../interfaces';\r\nimport { IRenderVirtualListItem } from '../../../models/render-item.model';\r\nimport { IDisplayObjectConfig, IDisplayObjectMeasures } from '../../../models';\r\nimport {\r\n  DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN,\r\n  PART_ITEM_FOCUSED, PART_ITEM_NEW, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, PX, SIZE_100_PERSENT,\r\n  SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE,\r\n} from '../../../const';\r\nimport { ITemplateContext } from '../interfaces';\r\nimport {\r\n  CLASS_NAME_FOCUS, CLASS_NAME_SNAPPED, CLASS_NAME_SNAPPED_OUT, ID, ITEM_ID, POSITION, POSITION_ZERO, TRANSLATE_3D_HIDDEN,\r\n} from '../const';\r\nimport { TextDirection, TextDirections } from '../../../enums';\r\nimport { NgVirtualListPublicService } from '../../../ng-virtual-list-public.service';\r\nimport { NgVirtualListService } from '../../../ng-virtual-list.service';\r\nimport { createDisplayId } from '../utils';\r\n\r\n/**\r\n * BaseVirtualListItemComponent\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/components/list-item/base/base-virtual-list-item-component.ts\r\n * @author Evgenii Alexandrovich Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\nexport class BaseVirtualListItemComponent {\r\n  private _cdr = inject(ChangeDetectorRef);\r\n\r\n  private _apiService = inject(NgVirtualListPublicService);\r\n\r\n  protected readonly _service = inject(NgVirtualListService);\r\n\r\n  protected _id!: number;\r\n  get id() {\r\n    return this._id;\r\n  }\r\n\r\n  protected _listId!: number;\r\n  get listId() {\r\n    return this._listId;\r\n  }\r\n\r\n  protected _displayId!: string;\r\n  get displayId() {\r\n    return this._displayId;\r\n  }\r\n\r\n  protected _isSelected: boolean = false;\r\n\r\n  protected _isCollapsed: boolean = false;\r\n\r\n  protected readonly config = signal<IDisplayObjectConfig>({} as IDisplayObjectConfig);\r\n\r\n  protected readonly measures = signal<IDisplayObjectMeasures | null>(null);\r\n\r\n  protected readonly focused = signal<boolean>(false);\r\n\r\n  protected readonly part = signal<string>(PART_DEFAULT_ITEM);\r\n\r\n  protected readonly data = signal<IRenderVirtualListItem | null>(null);\r\n  protected _data: IRenderVirtualListItem | null = null;\r\n  set item(v: IRenderVirtualListItem | null) {\r\n    if (this._data === v || this._data?.id === -1 || !v) {\r\n      return;\r\n    }\r\n\r\n    this._data = v;\r\n\r\n    this.updatePartStr(v, this._isSelected, this._isCollapsed);\r\n\r\n    this.updateConfig(v);\r\n\r\n    this.updateMeasures(v);\r\n\r\n    this.update();\r\n\r\n    this.data.set(v);\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  protected readonly classes!: Signal<{ [cName: string]: boolean; }>;\r\n\r\n  protected readonly index!: Signal<number>;\r\n\r\n  protected readonly templateContext!: Signal<ITemplateContext>;\r\n\r\n  public regular: boolean = false;\r\n\r\n  protected _scrollBarSize: number = 0;\r\n\r\n  protected _langTextDir: TextDirection = TextDirections.LTR;\r\n\r\n  protected _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.markForCheck();\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  protected readonly itemRenderer = signal<TemplateRef<any> | undefined>(undefined);\r\n\r\n  protected _renderer: TemplateRef<any> | undefined;\r\n  set renderer(v: TemplateRef<any> | undefined) {\r\n    if (this._renderer !== v) {\r\n      this._renderer = v;\r\n      this.itemRenderer.set(v);\r\n    }\r\n  }\r\n\r\n  protected _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\r\n  get element() {\r\n    return this._elementRef.nativeElement;\r\n  }\r\n\r\n  protected _destroyRef = inject(DestroyRef);\r\n\r\n  constructor() {\r\n    this._id = this._service.generateComponentId();\r\n    this._listId = this._service.id;\r\n    this._displayId = createDisplayId(this._listId, this._id);\r\n\r\n    this.classes = computed(() => {\r\n      const data = this.data(), focused = this.focused();\r\n      return {\r\n        [CLASS_NAME_SNAPPED]: data?.config?.snapped ?? false, [CLASS_NAME_SNAPPED_OUT]: data?.config?.snappedOut ?? false,\r\n        [CLASS_NAME_FOCUS]: focused,\r\n      };\r\n    });\r\n\r\n    this.index = computed(() => {\r\n      return this.config()?.tabIndex ?? -1;\r\n    });\r\n\r\n    this.templateContext = computed(() => {\r\n      const data = this.data(), measures = this.measures(), config = this.config();\r\n      return {\r\n        data: data?.data, prevData: data?.previouseData, nextData: data?.nextData, measures,\r\n        config, reseted: false, index: data?.index ?? - 1, api: this._apiService,\r\n      };\r\n    });\r\n  }\r\n\r\n  protected updateMeasures(v: IRenderVirtualListItem<any> | null) {\r\n    this.measures.set(v?.measures ? { ...v.measures } : null)\r\n  }\r\n\r\n  protected updateConfig(v: IRenderVirtualListItem<any> | null) {\r\n    this.config.set({\r\n      ...v?.config || {} as IDisplayObjectConfig, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),\r\n    });\r\n  }\r\n\r\n  protected update() {\r\n    const data = this._data, regular = this.regular, length = this._regularLength, el = this._elementRef.nativeElement;\r\n    if (data) {\r\n      el.setAttribute(ITEM_ID, `${data.id}`);\r\n      const styles = el.style;\r\n      styles.zIndex = data.config.zIndex;\r\n      styles.position = POSITION_ABSOLUTE;\r\n      if (data.config.isStub === true) {\r\n        el.style.visibility = VISIBILITY_HIDDEN;\r\n      }\r\n      if (regular) {\r\n        el.setAttribute(POSITION, POSITION_ZERO);\r\n        styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? (this._langTextDir === TextDirections.RTL ? this._scrollBarSize : 0) : data.measures.delta}${PX}, ${data.config.isVertical ? data.measures.delta : 0}${PX}, ${POSITION_ZERO})`;\r\n      } else {\r\n        el.setAttribute(POSITION, `${data.config.isVertical ? data.measures.y : data.measures.x}`);\r\n        styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX}, ${POSITION_ZERO})`;\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    } else {\r\n      el.removeAttribute(ID);\r\n    }\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  protected updatePartStr(v: IRenderVirtualListItem | null, isSelected: boolean, isCollapsed: 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    if (isCollapsed) {\r\n      part += PART_ITEM_COLLAPSED;\r\n    }\r\n    if (v ? v.config.new : false) {\r\n      part += PART_ITEM_NEW;\r\n    }\r\n    if (this.focused()) {\r\n      part += PART_ITEM_FOCUSED;\r\n    }\r\n    this.part.set(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: width > 0 ? width : 1, height: height > 0 ? height : 1, };\r\n  }\r\n\r\n  show() {\r\n    const el = this._elementRef.nativeElement as HTMLElement,\r\n      styles = el.style;\r\n    styles.zIndex = this._data?.config?.zIndex ?? DEFAULT_ZINDEX;\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      const isStub = this._data?.config?.isStub ?? false;\r\n      if (!isStub) {\r\n        if (styles.visibility === VISIBILITY_VISIBLE) {\r\n          return;\r\n        }\r\n        styles.visibility = VISIBILITY_VISIBLE;\r\n      }\r\n    }\r\n  }\r\n\r\n  hide() {\r\n    const el = this._elementRef.nativeElement,\r\n      styles = el.style;\r\n    styles.position = POSITION_ABSOLUTE;\r\n    styles.transform = TRANSLATE_3D_HIDDEN;\r\n    styles.zIndex = HIDDEN_ZINDEX;\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  }\r\n}"]}
@@ -0,0 +1,3 @@
1
+ import { BaseVirtualListItemComponent } from './base-virtual-list-item-component';
2
+ export { BaseVirtualListItemComponent, };
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9iYXNlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRWxGLE9BQU8sRUFDSCw0QkFBNEIsR0FDL0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2Jhc2UtdmlydHVhbC1saXN0LWl0ZW0tY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBCYXNlVmlydHVhbExpc3RJdGVtQ29tcG9uZW50LFxyXG59XHJcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export const ID = 'id', TRANSLATE_3D_HIDDEN = 'translate3d(-1000px,-1000px,0)', ATTR_AREA_SELECTED = 'area-selected', POSITION = 'position', POSITION_ZERO = '0', ITEM_ID = 'item-id', KEY_SPACE = ' ', KEY_ARR_LEFT = 'ArrowLeft', KEY_ARR_UP = 'ArrowUp', KEY_ARR_RIGHT = 'ArrowRight', KEY_ARR_DOWN = 'ArrowDown', EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown', CLASS_NAME_SNAPPED = 'snapped', CLASS_NAME_SNAPPED_OUT = 'snapped-out', CLASS_NAME_FOCUS = 'focus';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9jb25zdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxFQUNsQixtQkFBbUIsR0FBRyxnQ0FBZ0MsRUFDdEQsa0JBQWtCLEdBQUcsZUFBZSxFQUNwQyxRQUFRLEdBQUcsVUFBVSxFQUNyQixhQUFhLEdBQUcsR0FBRyxFQUNuQixPQUFPLEdBQUcsU0FBUyxFQUNuQixTQUFTLEdBQUcsR0FBRyxFQUNmLFlBQVksR0FBRyxXQUFXLEVBQzFCLFVBQVUsR0FBRyxTQUFTLEVBQ3RCLGFBQWEsR0FBRyxZQUFZLEVBQzVCLFlBQVksR0FBRyxXQUFXLEVBQzFCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGVBQWUsR0FBRyxVQUFVLEVBQzVCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGtCQUFrQixHQUFHLFNBQVMsRUFDOUIsc0JBQXNCLEdBQUcsYUFBYSxFQUN0QyxnQkFBZ0IsR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgSUQgPSAnaWQnLFxyXG4gICAgVFJBTlNMQVRFXzNEX0hJRERFTiA9ICd0cmFuc2xhdGUzZCgtMTAwMHB4LC0xMDAwcHgsMCknLFxyXG4gICAgQVRUUl9BUkVBX1NFTEVDVEVEID0gJ2FyZWEtc2VsZWN0ZWQnLFxyXG4gICAgUE9TSVRJT04gPSAncG9zaXRpb24nLFxyXG4gICAgUE9TSVRJT05fWkVSTyA9ICcwJyxcclxuICAgIElURU1fSUQgPSAnaXRlbS1pZCcsXHJcbiAgICBLRVlfU1BBQ0UgPSAnICcsXHJcbiAgICBLRVlfQVJSX0xFRlQgPSAnQXJyb3dMZWZ0JyxcclxuICAgIEtFWV9BUlJfVVAgPSAnQXJyb3dVcCcsXHJcbiAgICBLRVlfQVJSX1JJR0hUID0gJ0Fycm93UmlnaHQnLFxyXG4gICAgS0VZX0FSUl9ET1dOID0gJ0Fycm93RG93bicsXHJcbiAgICBFVkVOVF9GT0NVU19JTiA9ICdmb2N1c2luJyxcclxuICAgIEVWRU5UX0ZPQ1VTX09VVCA9ICdmb2N1c291dCcsXHJcbiAgICBFVkVOVF9LRVlfRE9XTiA9ICdrZXlkb3duJyxcclxuICAgIENMQVNTX05BTUVfU05BUFBFRCA9ICdzbmFwcGVkJyxcclxuICAgIENMQVNTX05BTUVfU05BUFBFRF9PVVQgPSAnc25hcHBlZC1vdXQnLFxyXG4gICAgQ0xBU1NfTkFNRV9GT0NVUyA9ICdmb2N1cyc7XHJcblxyXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJVGVtcGxhdGVDb250ZXh0IH0gZnJvbSAnLi90ZW1wbGF0ZS1jb250ZXh0JztcclxuXHJcbmV4cG9ydCB0eXBlIHtcclxuICAgIElUZW1wbGF0ZUNvbnRleHQsXHJcbn1cclxuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbmctbGlzdC1pdGVtL2ludGVyZmFjZXMvdGVtcGxhdGUtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSURpc3BsYXlPYmplY3RDb25maWcsIElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfSBmcm9tIFwiLi4vLi4vLi4vbW9kZWxzXCI7XHJcbmltcG9ydCB7IE5nVmlydHVhbExpc3RQdWJsaWNTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uLy4uL25nLXZpcnR1YWwtbGlzdC1wdWJsaWMuc2VydmljZVwiO1xyXG5cclxuLyoqXHJcbiAqIEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnRcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTcueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9pbnRlcmZhY2VzL3RlbXBsYXRlLWNvbnRleHQudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEFsZXhhbmRyb3ZpY2ggR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElUZW1wbGF0ZUNvbnRleHQ8RCA9IGFueT4ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBUEkgcHJvdmlkZXIuXHJcbiAgICAgKi9cclxuICAgIGFwaTogTmdWaXJ0dWFsTGlzdFB1YmxpY1NlcnZpY2U7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBkYXRhLlxyXG4gICAgICovXHJcbiAgICBkYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBEYXRhIG9mIHRoZSBwcmV2aW91cyBsaXN0IGl0ZW0uXHJcbiAgICAgKi9cclxuICAgIHByZXZEYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBEYXRhIG9mIHRoZSBuZXh0IGxpc3QgaXRlbS5cclxuICAgICAqL1xyXG4gICAgbmV4dERhdGE6IEQ7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBtZWFzdXJlbWVudCBkYXRhLlxyXG4gICAgICovXHJcbiAgICBtZWFzdXJlczogSURpc3BsYXlPYmplY3RNZWFzdXJlcyB8IG51bGw7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBjb25maWd1cmF0aW9uLlxyXG4gICAgICovXHJcbiAgICBjb25maWc6IElEaXNwbGF5T2JqZWN0Q29uZmlnO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgYSByZXNldCBzdGF0ZS5cclxuICAgICAqL1xyXG4gICAgcmVzZXRlZDogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogTGlzdCBpdGVtIGluZGV4LlxyXG4gICAgICovXHJcbiAgICBpbmRleDogbnVtYmVyO1xyXG59Il19
@@ -0,0 +1,196 @@
1
+ import { ChangeDetectionStrategy, Component, inject, Injector, signal } from '@angular/core';
2
+ import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
3
+ import { map, tap, combineLatest, fromEvent, switchMap, of, filter, debounceTime } from 'rxjs';
4
+ import { DEFAULT_CLICK_DISTANCE, NAVIGATION_BY_KEYBOARD_TIMER, VISIBILITY_HIDDEN, } from '../../const';
5
+ import { BaseVirtualListItemComponent } from './base';
6
+ import { MethodsForSelectingTypes } from '../../enums/method-for-selecting-types';
7
+ import { getListElementByIndex } from './utils';
8
+ import { ATTR_AREA_SELECTED, EVENT_FOCUS_IN, EVENT_FOCUS_OUT, EVENT_KEY_DOWN, KEY_ARR_DOWN, KEY_ARR_LEFT, KEY_ARR_RIGHT, KEY_ARR_UP, KEY_SPACE, } from './const';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common";
11
+ import * as i2 from "../../directives/item-click/item-click.directive";
12
+ /**
13
+ * Virtual list component.
14
+ * Maximum performance for extremely large lists.
15
+ * It is based on algorithms for virtualization of screen objects.
16
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/components/list-item/ng-virtual-list-item.component.ts
17
+ * @author Evgenii Alexandrovich Grebennikov
18
+ * @email djonnyx@gmail.com
19
+ */
20
+ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
21
+ maxClickDistance = signal(DEFAULT_CLICK_DISTANCE);
22
+ _injector = inject(Injector);
23
+ constructor() {
24
+ super();
25
+ }
26
+ ngOnInit() {
27
+ this._service.$clickDistance.pipe(takeUntilDestroyed(this._destroyRef), tap(v => {
28
+ this.maxClickDistance.set(v);
29
+ })).subscribe();
30
+ this._service.$langTextDir.pipe(takeUntilDestroyed(this._destroyRef), tap(v => {
31
+ this._langTextDir = v;
32
+ })).subscribe();
33
+ this._service.$scrollBarSize.pipe(takeUntilDestroyed(this._destroyRef), tap(v => {
34
+ this._scrollBarSize = v;
35
+ })).subscribe();
36
+ const $data = toObservable(this.data, { injector: this._injector }), $focused = toObservable(this.focused, { injector: this._injector });
37
+ $focused.pipe(takeUntilDestroyed(this._destroyRef), tap(v => {
38
+ this._service.areaFocus(v ? this._id : this._service.focusedId === this._id ? null : this._service.focusedId);
39
+ })).subscribe();
40
+ fromEvent(this.element, EVENT_FOCUS_IN).pipe(takeUntilDestroyed(this._destroyRef), tap(e => {
41
+ this.focused.set(true);
42
+ this.updateConfig(this._data);
43
+ this.updatePartStr(this._data, this._isSelected, this._isCollapsed);
44
+ })).subscribe(),
45
+ fromEvent(this.element, EVENT_FOCUS_OUT).pipe(takeUntilDestroyed(this._destroyRef), tap(e => {
46
+ this.focused.set(false);
47
+ this.updateConfig(this._data);
48
+ this.updatePartStr(this._data, this._isSelected, this._isCollapsed);
49
+ })).subscribe();
50
+ $focused.pipe(takeUntilDestroyed(this._destroyRef), debounceTime(this._service.animationParams.navigateByKeyboard ?? NAVIGATION_BY_KEYBOARD_TIMER), switchMap(v => {
51
+ if (v) {
52
+ return this.keyKode();
53
+ }
54
+ return of(false);
55
+ })).subscribe();
56
+ combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(takeUntilDestroyed(this._destroyRef), map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })), tap(({ method, selectedIds, collapsedIds }) => {
57
+ switch (method) {
58
+ case MethodsForSelectingTypes.SELECT: {
59
+ const id = selectedIds, isSelected = id === this.itemId;
60
+ this.element.setAttribute(ATTR_AREA_SELECTED, String(isSelected));
61
+ this._isSelected = isSelected;
62
+ break;
63
+ }
64
+ case MethodsForSelectingTypes.MULTI_SELECT: {
65
+ const actualIds = selectedIds, isSelected = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);
66
+ this.element.setAttribute(ATTR_AREA_SELECTED, String(isSelected));
67
+ this._isSelected = isSelected;
68
+ break;
69
+ }
70
+ case MethodsForSelectingTypes.NONE:
71
+ default: {
72
+ this.element.removeAttribute(ATTR_AREA_SELECTED);
73
+ this._isSelected = false;
74
+ break;
75
+ }
76
+ }
77
+ const actualIds = collapsedIds, isCollapsed = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);
78
+ this._isCollapsed = isCollapsed;
79
+ this.updatePartStr(this._data, this._isSelected, isCollapsed);
80
+ this.updateConfig(this._data);
81
+ this.updateMeasures(this._data);
82
+ })).subscribe();
83
+ }
84
+ keyKode() {
85
+ return fromEvent(this.element, EVENT_KEY_DOWN).pipe(takeUntilDestroyed(this._destroyRef), switchMap(e => {
86
+ switch (e.key) {
87
+ case KEY_SPACE: {
88
+ e.stopImmediatePropagation();
89
+ e.preventDefault();
90
+ if (!!this._data) {
91
+ this._service.select(this._data.id);
92
+ this._service.collapse(this._data.id);
93
+ }
94
+ break;
95
+ }
96
+ case KEY_ARR_LEFT:
97
+ if (!this.config().isVertical) {
98
+ return this.toPrevItem(e);
99
+ }
100
+ break;
101
+ case KEY_ARR_UP:
102
+ if (this.config().isVertical) {
103
+ return this.toPrevItem(e);
104
+ }
105
+ break;
106
+ case KEY_ARR_RIGHT:
107
+ if (!this.config().isVertical) {
108
+ return this.toNextItem(e);
109
+ }
110
+ break;
111
+ case KEY_ARR_DOWN:
112
+ if (this.config().isVertical) {
113
+ return this.toNextItem(e);
114
+ }
115
+ break;
116
+ }
117
+ return of(null);
118
+ }));
119
+ }
120
+ toNextItem(e) {
121
+ if (!!e && e.cancelable) {
122
+ e.stopImmediatePropagation();
123
+ e.preventDefault();
124
+ }
125
+ const index = this.focusNext();
126
+ if (index > -1) {
127
+ this._service.lastFocusedItemId = index;
128
+ }
129
+ return of(e).pipe(takeUntilDestroyed(this._destroyRef), filter(v => !!v), debounceTime(this._service.animationParams.navigateByKeyboard ?? NAVIGATION_BY_KEYBOARD_TIMER), switchMap(() => {
130
+ return this.keyKode();
131
+ }));
132
+ }
133
+ toPrevItem(e) {
134
+ if (!!e && e.cancelable) {
135
+ e.stopImmediatePropagation();
136
+ e.preventDefault();
137
+ }
138
+ const index = this.focusPrev();
139
+ if (index > -1) {
140
+ this._service.lastFocusedItemId = index;
141
+ }
142
+ return of(e).pipe(takeUntilDestroyed(this._destroyRef), filter(v => !!v), debounceTime(this._service.animationParams.navigateByKeyboard ?? NAVIGATION_BY_KEYBOARD_TIMER), switchMap(() => {
143
+ return this.keyKode();
144
+ }));
145
+ }
146
+ focusNext() {
147
+ if (this._service.listElement) {
148
+ const tabIndex = this._data?.config?.tabIndex ?? 0, length = this._service.collection?.length ?? 0;
149
+ let index = tabIndex;
150
+ while (index <= length) {
151
+ index++;
152
+ const element = this._service.listElement.querySelector(getListElementByIndex(index));
153
+ if (!!element && element.style.visibility !== VISIBILITY_HIDDEN) {
154
+ const focused = this._service.focus(element);
155
+ if (focused) {
156
+ return index;
157
+ }
158
+ }
159
+ }
160
+ }
161
+ return -1;
162
+ }
163
+ focusPrev() {
164
+ if (this._service.listElement) {
165
+ const tabIndex = this._data?.config?.tabIndex ?? 0;
166
+ let index = tabIndex;
167
+ while (index >= 0) {
168
+ index--;
169
+ const element = this._service.listElement.querySelector(getListElementByIndex(index));
170
+ if (!!element) {
171
+ this._service.focus(element);
172
+ return index;
173
+ }
174
+ }
175
+ }
176
+ return -1;
177
+ }
178
+ updateConfig(v) {
179
+ this.config.set({
180
+ ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),
181
+ });
182
+ }
183
+ onClickHandler() {
184
+ this._service.itemClick(this._data);
185
+ }
186
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgVirtualListItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
187
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { attributes: { "role": "listitem" }, classAttribute: "ngvl__item" }, usesInheritance: true, ngImport: i0, template: "<div itemClick [maxClickDistance]=\"maxClickDistance()\" [part]=\"part()\" [attr.ngvl-index]=\"index()\" tabindex=\"-1\"\r\n class=\"ngvl-item__container\" [ngClass]=\"classes()\" (onClick)=\"onClickHandler()\">\r\n @if (itemRenderer(); as renderer) {\r\n <ng-container [ngTemplateOutlet]=\"renderer\" [ngTemplateOutletContext]=\"templateContext()\" />\r\n }\r\n</div>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden;-webkit-tap-highlight-color:transparent;-webkit-user-drag:none;-moz-user-drag:none;text-rendering:optimizeSpeed;image-rendering:auto}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.ItemClickDirective, selector: "[itemClick]", inputs: ["maxClickDistance"], outputs: ["onClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
188
+ }
189
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgVirtualListItemComponent, decorators: [{
190
+ type: Component,
191
+ args: [{ selector: 'ng-virtual-list-item', host: {
192
+ 'class': 'ngvl__item',
193
+ 'role': 'listitem',
194
+ }, standalone: false, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div itemClick [maxClickDistance]=\"maxClickDistance()\" [part]=\"part()\" [attr.ngvl-index]=\"index()\" tabindex=\"-1\"\r\n class=\"ngvl-item__container\" [ngClass]=\"classes()\" (onClick)=\"onClickHandler()\">\r\n @if (itemRenderer(); as renderer) {\r\n <ng-container [ngTemplateOutlet]=\"renderer\" [ngTemplateOutletContext]=\"templateContext()\" />\r\n }\r\n</div>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden;-webkit-tap-highlight-color:transparent;-webkit-user-drag:none;-moz-user-drag:none;text-rendering:optimizeSpeed;image-rendering:auto}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"] }]
195
+ }], ctorParameters: () => [] });
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-virtual-list/src/lib/components/ng-list-item/ng-virtual-list-item.component.ts","../../../../../../projects/ng-virtual-list/src/lib/components/ng-list-item/ng-virtual-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, Injector, OnInit, signal } from '@angular/core';\r\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\r\nimport { map, tap, combineLatest, fromEvent, switchMap, of, Observable, filter, debounceTime } from 'rxjs';\r\nimport { IRenderVirtualListItem } from '../../models/render-item.model';\r\nimport { Id } from '../../types';\r\nimport {\r\n  DEFAULT_CLICK_DISTANCE, NAVIGATION_BY_KEYBOARD_TIMER, VISIBILITY_HIDDEN,\r\n} from '../../const';\r\nimport { BaseVirtualListItemComponent } from './base';\r\nimport { NgVirtualListService } from '../../ng-virtual-list.service';\r\nimport { MethodsForSelectingTypes } from '../../enums/method-for-selecting-types';\r\nimport { IDisplayObjectConfig } from '../../models';\r\nimport { createDisplayId, getListElementByIndex } from './utils';\r\nimport {\r\n  ATTR_AREA_SELECTED, EVENT_FOCUS_IN, EVENT_FOCUS_OUT, EVENT_KEY_DOWN, KEY_ARR_DOWN, KEY_ARR_LEFT,\r\n  KEY_ARR_RIGHT, KEY_ARR_UP, KEY_SPACE,\r\n} from './const';\r\n\r\n/**\r\n * Virtual list component.\r\n * Maximum performance for extremely large lists.\r\n * It is based on algorithms for virtualization of screen objects.\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/components/list-item/ng-virtual-list-item.component.ts\r\n * @author Evgenii Alexandrovich 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  styleUrl: './ng-virtual-list-item.component.scss',\r\n  host: {\r\n    'class': 'ngvl__item',\r\n    'role': 'listitem',\r\n  },\r\n  standalone: false,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NgVirtualListItemComponent extends BaseVirtualListItemComponent implements OnInit {\r\n  protected readonly maxClickDistance = signal<number>(DEFAULT_CLICK_DISTANCE);\r\n\r\n  protected _injector = inject(Injector);\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._service.$clickDistance.pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      tap(v => {\r\n        this.maxClickDistance.set(v);\r\n      }),\r\n    ).subscribe();\r\n\r\n    this._service.$langTextDir.pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      tap(v => {\r\n        this._langTextDir = v;\r\n      }),\r\n    ).subscribe();\r\n\r\n    this._service.$scrollBarSize.pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      tap(v => {\r\n        this._scrollBarSize = v;\r\n      }),\r\n    ).subscribe();\r\n\r\n    const $data = toObservable(this.data, { injector: this._injector }),\r\n      $focused = toObservable(this.focused, { injector: this._injector });\r\n\r\n    $focused.pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      tap(v => {\r\n        this._service.areaFocus(v ? this._id : this._service.focusedId === this._id ? null : this._service.focusedId);\r\n      }),\r\n    ).subscribe();\r\n\r\n    fromEvent(this.element, EVENT_FOCUS_IN).pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      tap(e => {\r\n        this.focused.set(true);\r\n\r\n        this.updateConfig(this._data);\r\n\r\n        this.updatePartStr(this._data, this._isSelected, this._isCollapsed);\r\n      }),\r\n    ).subscribe(),\r\n\r\n      fromEvent(this.element, EVENT_FOCUS_OUT).pipe(\r\n        takeUntilDestroyed(this._destroyRef),\r\n        tap(e => {\r\n          this.focused.set(false);\r\n\r\n          this.updateConfig(this._data);\r\n\r\n          this.updatePartStr(this._data, this._isSelected, this._isCollapsed);\r\n        }),\r\n      ).subscribe();\r\n\r\n    $focused.pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      debounceTime(this._service.animationParams.navigateByKeyboard ?? NAVIGATION_BY_KEYBOARD_TIMER),\r\n      switchMap(v => {\r\n        if (v) {\r\n          return this.keyKode();\r\n        }\r\n        return of(false);\r\n      }),\r\n    ).subscribe();\r\n\r\n    combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })),\r\n      tap(({ method, selectedIds, collapsedIds }) => {\r\n        switch (method) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const id = selectedIds as Id | undefined, isSelected = id === this.itemId;\r\n            this.element.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 = selectedIds as Array<Id>, isSelected = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n            this.element.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.element.removeAttribute(ATTR_AREA_SELECTED);\r\n            this._isSelected = false;\r\n            break;\r\n          }\r\n        }\r\n\r\n        const actualIds = collapsedIds, isCollapsed = this.itemId !== undefined && actualIds && actualIds.includes(this.itemId);\r\n        this._isCollapsed = isCollapsed;\r\n\r\n        this.updatePartStr(this._data, this._isSelected, isCollapsed);\r\n\r\n        this.updateConfig(this._data);\r\n\r\n        this.updateMeasures(this._data);\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  private keyKode() {\r\n    return fromEvent<KeyboardEvent>(this.element, EVENT_KEY_DOWN).pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      switchMap(e => {\r\n        switch (e.key) {\r\n          case KEY_SPACE: {\r\n            e.stopImmediatePropagation();\r\n            e.preventDefault();\r\n            if (!!this._data) {\r\n              this._service.select(this._data!.id!);\r\n              this._service.collapse(this._data!.id!);\r\n            }\r\n            break;\r\n          }\r\n          case KEY_ARR_LEFT:\r\n            if (!this.config().isVertical) {\r\n              return this.toPrevItem(e);\r\n            }\r\n            break;\r\n          case KEY_ARR_UP:\r\n            if (this.config().isVertical) {\r\n              return this.toPrevItem(e);\r\n            }\r\n            break;\r\n          case KEY_ARR_RIGHT:\r\n            if (!this.config().isVertical) {\r\n              return this.toNextItem(e);\r\n            }\r\n            break;\r\n          case KEY_ARR_DOWN:\r\n            if (this.config().isVertical) {\r\n              return this.toNextItem(e);\r\n            }\r\n            break;\r\n        }\r\n        return of(null);\r\n      }),\r\n    );\r\n  }\r\n\r\n  private toNextItem(e: Event): Observable<any> {\r\n    if (!!e && e.cancelable) {\r\n      e.stopImmediatePropagation();\r\n      e.preventDefault();\r\n    }\r\n\r\n    const index = this.focusNext();\r\n    if (index > -1) {\r\n      this._service.lastFocusedItemId = index;\r\n    }\r\n    return of(e).pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      filter(v => !!v),\r\n      debounceTime(this._service.animationParams.navigateByKeyboard ?? NAVIGATION_BY_KEYBOARD_TIMER),\r\n      switchMap(() => {\r\n        return this.keyKode();\r\n      }),\r\n    );\r\n  }\r\n\r\n  private toPrevItem(e: Event): Observable<any> {\r\n    if (!!e && e.cancelable) {\r\n      e.stopImmediatePropagation();\r\n      e.preventDefault();\r\n    }\r\n\r\n    const index = this.focusPrev();\r\n    if (index > -1) {\r\n      this._service.lastFocusedItemId = index;\r\n    }\r\n    return of(e).pipe(\r\n      takeUntilDestroyed(this._destroyRef),\r\n      filter(v => !!v),\r\n      debounceTime(this._service.animationParams.navigateByKeyboard ?? NAVIGATION_BY_KEYBOARD_TIMER),\r\n      switchMap(() => {\r\n        return this.keyKode();\r\n      }),\r\n    );\r\n  }\r\n\r\n  private focusNext(): number {\r\n    if (this._service.listElement) {\r\n      const tabIndex = this._data?.config?.tabIndex ?? 0, length = this._service.collection?.length ?? 0;\r\n      let index = tabIndex;\r\n      while (index <= length) {\r\n        index++;\r\n        const element = this._service.listElement.querySelector<HTMLDivElement>(getListElementByIndex(index));\r\n        if (!!element && element.style.visibility !== VISIBILITY_HIDDEN) {\r\n          const focused = this._service.focus(element);\r\n          if (focused) {\r\n            return index;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return -1;\r\n  }\r\n\r\n  private focusPrev(): number {\r\n    if (this._service.listElement) {\r\n      const tabIndex = this._data?.config?.tabIndex ?? 0;\r\n      let index = tabIndex;\r\n      while (index >= 0) {\r\n        index--;\r\n        const element = this._service.listElement.querySelector<HTMLDivElement>(getListElementByIndex(index));\r\n        if (!!element) {\r\n          this._service.focus(element);\r\n          return index;\r\n        }\r\n      }\r\n    }\r\n    return -1;\r\n  }\r\n\r\n  protected override updateConfig(v: IRenderVirtualListItem<any> | null) {\r\n    this.config.set({\r\n      ...v?.config || {} as IDisplayObjectConfig, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),\r\n    });\r\n  }\r\n\r\n  onClickHandler() {\r\n    this._service.itemClick(this._data);\r\n  }\r\n}\r\n","<div itemClick [maxClickDistance]=\"maxClickDistance()\" [part]=\"part()\" [attr.ngvl-index]=\"index()\" tabindex=\"-1\"\r\n    class=\"ngvl-item__container\" [ngClass]=\"classes()\" (onClick)=\"onClickHandler()\">\r\n    @if (itemRenderer(); as renderer) {\r\n        <ng-container [ngTemplateOutlet]=\"renderer\" [ngTemplateOutletContext]=\"templateContext()\" />\r\n    }\r\n</div>"]}
@@ -0,0 +1,20 @@
1
+ import { NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NgVirtualListItemComponent } from './ng-virtual-list-item.component';
4
+ import { ItemClickModule } from '../../directives';
5
+ import * as i0 from "@angular/core";
6
+ export class NgVirtualListItemModule {
7
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgVirtualListItemModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: NgVirtualListItemModule, declarations: [NgVirtualListItemComponent], imports: [CommonModule, ItemClickModule], exports: [NgVirtualListItemComponent] });
9
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgVirtualListItemModule, imports: [CommonModule, ItemClickModule] });
10
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgVirtualListItemModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [NgVirtualListItemComponent],
15
+ exports: [NgVirtualListItemComponent],
16
+ imports: [CommonModule, ItemClickModule],
17
+ schemas: [NO_ERRORS_SCHEMA],
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctdmlydHVhbC1saXN0LWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvY29tcG9uZW50cy9uZy1saXN0LWl0ZW0vbmctdmlydHVhbC1saXN0LWl0ZW0ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFRbkQsTUFBTSxPQUFPLHVCQUF1Qjt3R0FBdkIsdUJBQXVCO3lHQUF2Qix1QkFBdUIsaUJBTG5CLDBCQUEwQixhQUUvQixZQUFZLEVBQUUsZUFBZSxhQUQ3QiwwQkFBMEI7eUdBSXpCLHVCQUF1QixZQUh4QixZQUFZLEVBQUUsZUFBZTs7NEZBRzVCLHVCQUF1QjtrQkFObkMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQywwQkFBMEIsQ0FBQztvQkFDMUMsT0FBTyxFQUFFLENBQUMsMEJBQTBCLENBQUM7b0JBQ3JDLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxlQUFlLENBQUM7b0JBQ3hDLE9BQU8sRUFBRSxDQUFDLGdCQUFnQixDQUFDO2lCQUM1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBOT19FUlJPUlNfU0NIRU1BIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nVmlydHVhbExpc3RJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9uZy12aXJ0dWFsLWxpc3QtaXRlbS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBJdGVtQ2xpY2tNb2R1bGUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbTmdWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnRdLFxyXG4gIGV4cG9ydHM6IFtOZ1ZpcnR1YWxMaXN0SXRlbUNvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgSXRlbUNsaWNrTW9kdWxlXSxcclxuICBzY2hlbWFzOiBbTk9fRVJST1JTX1NDSEVNQV0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOZ1ZpcnR1YWxMaXN0SXRlbU1vZHVsZSB7IH1cclxuIl19
@@ -0,0 +1,4 @@
1
+ export const createDisplayId = (listId, id) => {
2
+ return `${listId}-${id}`;
3
+ };
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWRpc3BsYXktaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS91dGlscy9jcmVhdGUtZGlzcGxheS1pZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxNQUFjLEVBQUUsRUFBVSxFQUFFLEVBQUU7SUFDMUQsT0FBTyxHQUFHLE1BQU0sSUFBSSxFQUFFLEVBQUUsQ0FBQztBQUM3QixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgY3JlYXRlRGlzcGxheUlkID0gKGxpc3RJZDogbnVtYmVyLCBpZDogbnVtYmVyKSA9PiB7XHJcbiAgICByZXR1cm4gYCR7bGlzdElkfS0ke2lkfWA7XHJcbn07XHJcbiJdfQ==
@@ -0,0 +1,6 @@
1
+ export const NGVL_INDEX = 'ngvl-index', getListElementByIndex = (index) => {
2
+ return `[${NGVL_INDEX}="${index}"]`;
3
+ }, getListElements = () => {
4
+ return `[${NGVL_INDEX}]`;
5
+ };
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWVsZW1lbnQtYnktaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS91dGlscy9nZXQtZWxlbWVudC1ieS1pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsWUFBWSxFQUNsQyxxQkFBcUIsR0FBRyxDQUFDLEtBQWEsRUFBRSxFQUFFO0lBQ3RDLE9BQU8sSUFBSSxVQUFVLEtBQUssS0FBSyxJQUFJLENBQUM7QUFDeEMsQ0FBQyxFQUNELGVBQWUsR0FBRyxHQUFHLEVBQUU7SUFDbkIsT0FBTyxJQUFJLFVBQVUsR0FBRyxDQUFDO0FBQzdCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBOR1ZMX0lOREVYID0gJ25ndmwtaW5kZXgnLFxyXG4gICAgZ2V0TGlzdEVsZW1lbnRCeUluZGV4ID0gKGluZGV4OiBudW1iZXIpID0+IHtcclxuICAgICAgICByZXR1cm4gYFske05HVkxfSU5ERVh9PVwiJHtpbmRleH1cIl1gO1xyXG4gICAgfSxcclxuICAgIGdldExpc3RFbGVtZW50cyA9ICgpID0+IHtcclxuICAgICAgICByZXR1cm4gYFske05HVkxfSU5ERVh9XWA7XHJcbiAgICB9O1xyXG4iXX0=
@@ -0,0 +1,4 @@
1
+ import { getListElementByIndex, getListElements, NGVL_INDEX } from './get-element-by-index';
2
+ import { createDisplayId } from './create-display-id';
3
+ export { createDisplayId, getListElementByIndex, getListElements, NGVL_INDEX, };
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsZUFBZSxFQUFFLFVBQVUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV0RCxPQUFPLEVBQ0gsZUFBZSxFQUNmLHFCQUFxQixFQUNyQixlQUFlLEVBQ2YsVUFBVSxHQUNiLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRMaXN0RWxlbWVudEJ5SW5kZXgsIGdldExpc3RFbGVtZW50cywgTkdWTF9JTkRFWCB9IGZyb20gJy4vZ2V0LWVsZW1lbnQtYnktaW5kZXgnO1xyXG5pbXBvcnQgeyBjcmVhdGVEaXNwbGF5SWQgfSBmcm9tICcuL2NyZWF0ZS1kaXNwbGF5LWlkJztcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBjcmVhdGVEaXNwbGF5SWQsXHJcbiAgICBnZXRMaXN0RWxlbWVudEJ5SW5kZXgsXHJcbiAgICBnZXRMaXN0RWxlbWVudHMsXHJcbiAgICBOR1ZMX0lOREVYLFxyXG59Il19