ng-virtual-list 16.10.8 → 16.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (206) hide show
  1. package/README.md +24 -79
  2. package/esm2022/lib/components/ng-list-item/base/base-virtual-list-item-component.mjs +207 -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 +30 -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 +212 -0
  8. package/esm2022/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.module.mjs +1 -1
  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 +269 -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 +140 -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 +92 -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/const/index.mjs +9 -2
  28. package/esm2022/lib/components/ng-scroll-bar/enums/index.mjs +3 -0
  29. package/esm2022/lib/components/ng-scroll-bar/enums/scrollbar-states.mjs +7 -0
  30. package/esm2022/lib/components/ng-scroll-bar/interfaces/index.mjs +1 -1
  31. package/esm2022/lib/components/ng-scroll-bar/interfaces/scroll-bar-template-context.mjs +2 -0
  32. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.mjs +25 -0
  33. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.component.mjs +97 -84
  34. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.module.mjs +4 -5
  35. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.service.mjs +36 -0
  36. package/esm2022/lib/components/ng-scroll-bar/types/index.mjs +2 -0
  37. package/esm2022/lib/components/ng-scroll-bar/types/scrollbar-state.mjs +2 -0
  38. package/esm2022/lib/components/ng-scroll-view/base/base-scroll-view.component.mjs +44 -56
  39. package/esm2022/lib/components/ng-scroll-view/ng-scroll-view.component.mjs +26 -30
  40. package/esm2022/lib/components/ng-scroller/const/index.mjs +2 -0
  41. package/esm2022/lib/components/ng-scroller/enums/index.mjs +3 -0
  42. package/esm2022/lib/components/ng-scroller/enums/scroller-direction.mjs +6 -0
  43. package/esm2022/lib/components/ng-scroller/enums/scroller-directions.mjs +2 -0
  44. package/esm2022/lib/components/ng-scroller/ng-scroller.component.mjs +449 -0
  45. package/esm2022/lib/components/ng-scroller/ng-scroller.module.mjs +22 -0
  46. package/esm2022/lib/components/ng-scroller/utils/index.mjs +3 -0
  47. package/esm2022/lib/components/ng-scroller/utils/scroll-box.mjs +52 -0
  48. package/esm2022/lib/const/index.mjs +3 -14
  49. package/esm2022/lib/core/track-box.mjs +46 -16
  50. package/esm2022/lib/core/tracker.mjs +1 -1
  51. package/esm2022/lib/directives/locale-sensitive/locale-sensitive.directive.mjs +2 -2
  52. package/esm2022/lib/interfaces/scroll-params.mjs +1 -1
  53. package/esm2022/lib/interfaces/scroll-to-params.mjs +2 -0
  54. package/esm2022/lib/models/display-object-config.model.mjs +1 -1
  55. package/esm2022/lib/models/display-object-measures.model.mjs +1 -1
  56. package/esm2022/lib/models/render-item-measures.model.mjs +1 -1
  57. package/esm2022/lib/ng-virtual-list-public.service.mjs +121 -0
  58. package/esm2022/lib/ng-virtual-list.component.mjs +367 -333
  59. package/esm2022/lib/ng-virtual-list.module.mjs +7 -7
  60. package/esm2022/lib/ng-virtual-list.service.mjs +116 -33
  61. package/esm2022/lib/types/index.mjs +1 -1
  62. package/esm2022/lib/utils/debounce.mjs +28 -6
  63. package/esm2022/lib/utils/disposable-component.mjs +27 -0
  64. package/esm2022/lib/utils/list-validators.mjs +1 -1
  65. package/esm2022/public-api.mjs +8 -3
  66. package/fesm2022/ng-virtual-list.mjs +2268 -2358
  67. package/fesm2022/ng-virtual-list.mjs.map +1 -1
  68. package/lib/components/{list-item → ng-list-item}/base/base-virtual-list-item-component.d.ts +7 -6
  69. package/lib/components/ng-list-item/interfaces/template-context.d.ts +42 -0
  70. package/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.component.d.ts +1 -4
  71. 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} +9 -14
  72. package/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.module.d.ts +10 -0
  73. package/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.component.d.ts +17 -0
  74. package/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.module.d.ts +9 -0
  75. 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} +9 -14
  76. package/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.module.d.ts +9 -0
  77. package/lib/components/{prerender-container → ng-prerender-container}/core/prerender-track-box.d.ts +2 -2
  78. package/lib/components/{prerender-container → ng-prerender-container}/interfaces/refresh-params.d.ts +1 -1
  79. package/lib/components/ng-prerender-container/ng-prerender-container.component.d.ts +39 -0
  80. package/lib/components/ng-prerender-container/ng-prerender-container.module.d.ts +9 -0
  81. package/lib/components/{prerender-container → ng-prerender-container}/types/cache.d.ts +1 -1
  82. package/lib/components/ng-scroll-bar/const/index.d.ts +3 -2
  83. package/lib/components/ng-scroll-bar/enums/index.d.ts +2 -0
  84. package/lib/components/ng-scroll-bar/enums/scrollbar-states.d.ts +5 -0
  85. package/lib/components/ng-scroll-bar/interfaces/index.d.ts +2 -1
  86. package/lib/components/ng-scroll-bar/interfaces/scroll-bar-template-context.d.ts +26 -0
  87. package/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.d.ts +16 -0
  88. package/lib/components/ng-scroll-bar/ng-scroll-bar.component.d.ts +31 -36
  89. package/lib/components/ng-scroll-bar/ng-scroll-bar.module.d.ts +1 -2
  90. package/lib/components/ng-scroll-bar/ng-scroll-bar.service.d.ts +22 -0
  91. package/lib/components/ng-scroll-bar/types/index.d.ts +2 -0
  92. package/lib/components/ng-scroll-bar/types/scrollbar-state.d.ts +2 -0
  93. package/lib/components/ng-scroll-view/base/base-scroll-view.component.d.ts +9 -10
  94. package/lib/components/{scroller → ng-scroller}/ng-scroller.component.d.ts +31 -10
  95. package/lib/components/{scroller → ng-scroller}/utils/scroll-box.d.ts +1 -1
  96. package/lib/const/index.d.ts +2 -2
  97. package/lib/core/track-box.d.ts +17 -11
  98. package/lib/core/tracker.d.ts +1 -1
  99. package/lib/directives/locale-sensitive/locale-sensitive.directive.d.ts +1 -1
  100. package/lib/interfaces/scroll-params.d.ts +1 -1
  101. package/lib/interfaces/scroll-to-params.d.ts +7 -0
  102. package/lib/models/display-object-config.model.d.ts +1 -15
  103. package/lib/models/display-object-measures.model.d.ts +0 -4
  104. package/lib/models/render-item-measures.model.d.ts +0 -4
  105. package/lib/ng-virtual-list-public.service.d.ts +93 -0
  106. package/lib/ng-virtual-list.component.d.ts +41 -23
  107. package/lib/ng-virtual-list.module.d.ts +4 -4
  108. package/lib/ng-virtual-list.service.d.ts +42 -7
  109. package/lib/types/index.d.ts +3 -4
  110. package/lib/utils/debounce.d.ts +5 -1
  111. package/lib/utils/disposable-component.d.ts +15 -0
  112. package/lib/utils/list-validators.d.ts +1 -1
  113. package/package.json +1 -1
  114. package/public-api.d.ts +7 -2
  115. package/esm2022/lib/components/list-item/base/base-virtual-list-item-component.mjs +0 -207
  116. package/esm2022/lib/components/list-item/base/index.mjs +0 -3
  117. package/esm2022/lib/components/list-item/const/index.mjs +0 -32
  118. package/esm2022/lib/components/list-item/interfaces/index.mjs +0 -2
  119. package/esm2022/lib/components/list-item/interfaces/template-context.mjs +0 -2
  120. package/esm2022/lib/components/list-item/ng-virtual-list-item.component.mjs +0 -246
  121. package/esm2022/lib/components/list-item/utils/create-display-id.mjs +0 -4
  122. package/esm2022/lib/components/list-item/utils/get-element-by-index.mjs +0 -6
  123. package/esm2022/lib/components/list-item/utils/index.mjs +0 -4
  124. package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.component.mjs +0 -280
  125. package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.module.mjs +0 -21
  126. package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.mjs +0 -78
  127. package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.mjs +0 -20
  128. package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.mjs +0 -151
  129. package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.mjs +0 -20
  130. package/esm2022/lib/components/prerender-container/core/index.mjs +0 -3
  131. package/esm2022/lib/components/prerender-container/core/prerender-track-box.mjs +0 -169
  132. package/esm2022/lib/components/prerender-container/events/index.mjs +0 -6
  133. package/esm2022/lib/components/prerender-container/interfaces/index.mjs +0 -2
  134. package/esm2022/lib/components/prerender-container/interfaces/refresh-params.mjs +0 -2
  135. package/esm2022/lib/components/prerender-container/prerender-container.component.mjs +0 -97
  136. package/esm2022/lib/components/prerender-container/prerender-container.module.mjs +0 -20
  137. package/esm2022/lib/components/prerender-container/types/cache.mjs +0 -2
  138. package/esm2022/lib/components/prerender-container/types/index.mjs +0 -2
  139. package/esm2022/lib/components/scroller/const/index.mjs +0 -2
  140. package/esm2022/lib/components/scroller/enums/index.mjs +0 -3
  141. package/esm2022/lib/components/scroller/enums/scroller-direction.mjs +0 -6
  142. package/esm2022/lib/components/scroller/enums/scroller-directions.mjs +0 -2
  143. package/esm2022/lib/components/scroller/ng-scroller.component.mjs +0 -410
  144. package/esm2022/lib/components/scroller/ng-scroller.module.mjs +0 -22
  145. package/esm2022/lib/components/scroller/utils/index.mjs +0 -3
  146. package/esm2022/lib/components/scroller/utils/scroll-box.mjs +0 -52
  147. package/esm2022/lib/components/substrate/const/index.mjs +0 -2
  148. package/esm2022/lib/components/substrate/enums/index.mjs +0 -4
  149. package/esm2022/lib/components/substrate/enums/substrate-modes.mjs +0 -16
  150. package/esm2022/lib/components/substrate/enums/substrate-styles.mjs +0 -15
  151. package/esm2022/lib/components/substrate/index.mjs +0 -5
  152. package/esm2022/lib/components/substrate/substrate.component.mjs +0 -354
  153. package/esm2022/lib/components/substrate/substrate.module.mjs +0 -19
  154. package/esm2022/lib/components/substrate/types/index.mjs +0 -2
  155. package/esm2022/lib/components/substrate/types/substrate-mode.mjs +0 -2
  156. package/esm2022/lib/components/substrate/types/substrate-style.mjs +0 -2
  157. package/esm2022/lib/components/substrate/utils/circle-path.mjs +0 -4
  158. package/esm2022/lib/components/substrate/utils/index.mjs +0 -4
  159. package/esm2022/lib/components/substrate/utils/rounded-rect-path.mjs +0 -20
  160. package/esm2022/lib/types/color.mjs +0 -2
  161. package/esm2022/lib/types/gradient-color.mjs +0 -2
  162. package/esm2022/lib/types/rounded-corner.mjs +0 -2
  163. package/esm2022/lib/types/scrollbar-theme.mjs +0 -2
  164. package/esm2022/lib/utils/get-shape-min-size.mjs +0 -13
  165. package/lib/components/list-item/interfaces/template-context.d.ts +0 -10
  166. package/lib/components/prerender-container/components/prerender-list/prerender-list.module.d.ts +0 -10
  167. package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.d.ts +0 -17
  168. package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.d.ts +0 -9
  169. package/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.d.ts +0 -9
  170. package/lib/components/prerender-container/prerender-container.component.d.ts +0 -42
  171. package/lib/components/prerender-container/prerender-container.module.d.ts +0 -9
  172. package/lib/components/substrate/const/index.d.ts +0 -2
  173. package/lib/components/substrate/enums/index.d.ts +0 -3
  174. package/lib/components/substrate/enums/substrate-modes.d.ts +0 -13
  175. package/lib/components/substrate/enums/substrate-styles.d.ts +0 -12
  176. package/lib/components/substrate/index.d.ts +0 -7
  177. package/lib/components/substrate/substrate.component.d.ts +0 -91
  178. package/lib/components/substrate/substrate.module.d.ts +0 -8
  179. package/lib/components/substrate/types/index.d.ts +0 -3
  180. package/lib/components/substrate/types/substrate-mode.d.ts +0 -10
  181. package/lib/components/substrate/types/substrate-style.d.ts +0 -10
  182. package/lib/components/substrate/utils/circle-path.d.ts +0 -1
  183. package/lib/components/substrate/utils/index.d.ts +0 -3
  184. package/lib/components/substrate/utils/rounded-rect-path.d.ts +0 -1
  185. package/lib/types/color.d.ts +0 -7
  186. package/lib/types/gradient-color.d.ts +0 -8
  187. package/lib/types/rounded-corner.d.ts +0 -7
  188. package/lib/types/scrollbar-theme.d.ts +0 -47
  189. package/lib/utils/get-shape-min-size.d.ts +0 -8
  190. /package/lib/components/{list-item → ng-list-item}/base/index.d.ts +0 -0
  191. /package/lib/components/{list-item → ng-list-item}/const/index.d.ts +0 -0
  192. /package/lib/components/{list-item → ng-list-item}/interfaces/index.d.ts +0 -0
  193. /package/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.module.d.ts +0 -0
  194. /package/lib/components/{list-item → ng-list-item}/utils/create-display-id.d.ts +0 -0
  195. /package/lib/components/{list-item → ng-list-item}/utils/get-element-by-index.d.ts +0 -0
  196. /package/lib/components/{list-item → ng-list-item}/utils/index.d.ts +0 -0
  197. /package/lib/components/{prerender-container → ng-prerender-container}/core/index.d.ts +0 -0
  198. /package/lib/components/{prerender-container → ng-prerender-container}/events/index.d.ts +0 -0
  199. /package/lib/components/{prerender-container → ng-prerender-container}/interfaces/index.d.ts +0 -0
  200. /package/lib/components/{prerender-container → ng-prerender-container}/types/index.d.ts +0 -0
  201. /package/lib/components/{scroller → ng-scroller}/const/index.d.ts +0 -0
  202. /package/lib/components/{scroller → ng-scroller}/enums/index.d.ts +0 -0
  203. /package/lib/components/{scroller → ng-scroller}/enums/scroller-direction.d.ts +0 -0
  204. /package/lib/components/{scroller → ng-scroller}/enums/scroller-directions.d.ts +0 -0
  205. /package/lib/components/{scroller → ng-scroller}/ng-scroller.module.d.ts +0 -0
  206. /package/lib/components/{scroller → ng-scroller}/utils/index.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/)
@@ -288,6 +291,7 @@ Template:
288
291
  <span>{{data.name}}</span>
289
292
  </div>
290
293
  </ng-container>
294
+ </ng-template>
291
295
  ```
292
296
 
293
297
  #### With snapping
@@ -478,94 +482,32 @@ export class AppComponent {
478
482
 
479
483
  ## 🖼️ Stylization
480
484
 
481
- - Scrollbar theme
482
- ```ts
483
- import { NgVirtualListComponent, GradientColor, RoundedCorner, ScrollBarTheme } from 'ng-virtual-list';
484
-
485
- const X_LITE_BLUE_PLASMA_GRADIENT: GradientColor = ["rgba(133, 142, 255, 0)", "rgb(0, 133, 160)"],
486
- ROUND_CORNER: RoundedCorner = [3, 3, 3, 3],
487
- SCROLLBAR_GRADIENT: ScrollBarTheme = {
488
- fill: "rgba(51, 0, 97, 1)",
489
- hoverFill: "rgba(73, 6, 133, 1)",
490
- pressedFill: "rgba(73, 6, 150, 1)",
491
- strokeGradientColor: X_LITE_BLUE_PLASMA_GRADIENT,
492
- strokeAnimationDuration: 1000,
493
- thickness: 6,
494
- roundCorner: ROUND_CORNER,
495
- rippleColor: 'rgba(255,255,255,0.5)',
496
- rippleEnabled: true,
497
- };
498
-
499
- @Component({
500
- selector: 'app-root',
501
- imports: [FormsModule, NgVirtualListComponent],
502
- templateUrl: './app.component.html',
503
- styleUrl: './app.component.scss'
504
- })
505
- export class AppComponent {
506
- scrollbarTheme = SCROLLBAR_GRADIENT;
507
-
508
- items = Array.from({ length: 100000 }, (_, i) => ({ id: i, name: `Item #${i}` }));
509
- }
510
-
511
- ```
485
+ ### Scrollbar stylization
512
486
 
513
487
  ```scss
514
-
515
- .list {
516
- &::part(scrollbar-track) {
517
- margin-right: 2px;
518
- overflow: initial;
519
- }
520
-
521
- &::part(scrollbar-thumb) {
522
- border: 1px solid #8738c3;
523
- border-radius: 4px;
524
- }
488
+ .list::part(scrollbar-thumb__shape) {
489
+ background-color: rgba(51, 0, 97, 1);
490
+ border-radius: 3px;
525
491
  }
526
492
  ```
527
493
 
528
494
  ```html
529
- <ng-virtual-list class="list" [scrollbarTheme]="scrollbarTheme" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
495
+ <ng-virtual-list class="list" [scrollbarThickness]="12" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
530
496
 
531
- <ng-template #horizontalItemRenderer let-data="data" let-config="config">
532
- <div *ngIf="data" [ngClass]="{'list__h-container': true, 'selected': config.selected}">
533
- <span>{{data.name}}</span>
534
- </div>
497
+ <ng-template #itemRenderer let-data="data" let-config="config">
498
+ <span>{{data.name}}</span>
535
499
  </ng-template>
536
500
  ```
537
501
 
502
+ ### Scrollbar castomization
503
+
504
+ [Examples](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/src/app/app.component.html)
505
+ [CustomScrollbarComponent](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/src/app/components/custom-scrollbar/custom-scrollbar.component.ts)
506
+
538
507
  List items are encapsulated in shadowDOM, so to override default styles you need to use ::part access
539
508
 
540
509
  - Customize a scroll area of list
541
510
  ```css
542
- .list::part(scroller) {
543
- scroll-behavior: auto;
544
-
545
- /* custom scrollbar */
546
- &::-webkit-scrollbar {
547
- width: 16px;
548
- height: 16px;
549
- }
550
-
551
- &::-webkit-scrollbar-track {
552
- background-color: #ffffff;
553
- }
554
-
555
- &::-webkit-scrollbar-thumb {
556
- background-color: #d6dee1;
557
- border-radius: 20px;
558
- border: 6px solid transparent;
559
- background-clip: content-box;
560
- min-width: 60px;
561
- min-height: 60px;
562
- }
563
-
564
- &::-webkit-scrollbar-thumb:hover {
565
- background-color: #a8bbbf;
566
- }
567
- }
568
-
569
511
  .list {
570
512
  border-radius: 3px;
571
513
  box-shadow: 1px 2px 8px 4px rgba(0, 0, 0, 0.075);
@@ -597,7 +539,7 @@ List items are encapsulated in shadowDOM, so to override default styles you need
597
539
  Selecting even elements:
598
540
 
599
541
  ```html
600
- <ng-virtual-list class="list" direction="horizontal" [items]="horizontalItems" [bufferSize]="1"
542
+ <ng-virtual-list class="list" direction="horizontal" [items]="horizontalItems" [bufferSize]="1" [maxBufferSize]="5"
601
543
  [itemRenderer]="horizontalItemRenderer" [itemSize]="54"></ng-virtual-list>
602
544
 
603
545
  <ng-template #horizontalItemRenderer let-data="data" let-config="config">
@@ -647,7 +589,6 @@ Inputs
647
589
  | snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
648
590
  | selectedIds | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/types/id.ts) \| null | Sets the selected items. |
649
591
  | screenReaderMessage | string? = "Showing items $1 to $2" | Message for screen reader. The message format is: "some text `$1` some text `$2`", where `$1` is the number of the first element of the screen collection, `$2` is the number of the last element of the screen collection. |
650
- | scrollbarTheme | [ScrollBarTheme?](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/types/scrollbar-theme.ts) | Scrollbar theme. |
651
592
  | clickDistance | number? = 40 | The maximum scroll distance at which a click event is triggered. |
652
593
  | waitForPreparation | boolean? = true | If true, it will wait until the list items are fully prepared before displaying them.. The default value is `true`. |
653
594
  | scrollStartOffset | number? = 0 | Sets the scroll start offset value; Default value is "0". |
@@ -656,9 +597,12 @@ Inputs
656
597
  | snapScrollToStart | boolean? = true | Determines whether the scroll will be anchored to the start of the list. Default value is "true". This property takes precedence over the snapScrollToEnd property. That is, if snapScrollToStart and snapScrollToEnd are enabled, the list will initially snap to the beginning; if you move the scroll bar to the end, the list will snap to the end. If snapScrollToStart is disabled and snapScrollToEnd is enabled, the list will snap to the end; if you move the scroll bar to the beginning, the list will snap to the beginning. If both snapScrollToStart and snapScrollToEnd are disabled, the list will never snap to the beginning or end. |
657
598
  | snapScrollToEnd | boolean? = true | Determines whether the scroll will be anchored to the утв of the list. Default value is "true". That is, if snapScrollToStart and snapScrollToEnd are enabled, the list will initially snap to the beginning; if you move the scroll bar to the end, the list will snap to the end. If snapScrollToStart is disabled and snapScrollToEnd is enabled, the list will snap to the end; if you move the scroll bar to the beginning, the list will snap to the beginning. If both snapScrollToStart and snapScrollToEnd are disabled, the list will never snap to the beginning or end. |
658
599
  | snapToEndTransitionInstantOffset | number? = 0 | Sets the offset value; if the scroll area value is exceeded, the scroll animation will be disabled. Default value is "0". |
659
- | scrollbarMinSize | number? = 80 | Minimum scrollbar size. |
660
600
  | scrollbarEnabled | boolean? = true | Determines whether the scrollbar is shown or not. The default value is "true". |
661
601
  | scrollbarInteractive | boolean? = true | Determines whether scrolling using the scrollbar will be possible. The default value is "true". |
602
+ | scrollbarMinSize | number? = 80 | Minimum scrollbar size. |
603
+ | scrollbarThickness | number? = 6 | Scrollbar thickness. |
604
+ | scrollbarThumbRenderer | TemplateRef<any> \| null = null | Scrollbar customization template. |
605
+ | scrollbarThumbParams | {[propName: string]: any;} \| null | Additional options for the scrollbar. |
662
606
  | scrollBehavior | ScrollBehavior? = 'smooth' | Defines the scrolling behavior for any element on the page. The default value is "smooth". |
663
607
  | trackBy | string? = 'id' | The name of the property by which tracking is performed. |
664
608
 
@@ -695,7 +639,7 @@ Methods
695
639
  ### Template API
696
640
 
697
641
  ```html
698
- <ng-template #itemRenderer let-data="data" let-config="config" let-measures="measures">
642
+ <ng-template #itemRenderer let-data="data" let-config="config" let-measures="measures" let-api="api">
699
643
  <!-- content -->
700
644
  </ng-template>
701
645
  ```
@@ -704,6 +648,7 @@ Properties
704
648
 
705
649
  | Property | Type | Description |
706
650
  |--|--|--|
651
+ | api | [NgVirtualListPublicService](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/ng-virtual-list-public.service.ts) | List API Provider. |
707
652
  | data | {\[id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/types/id.ts) \], [otherProps: string]: any;} | Collection item data. |
708
653
  | config | [IDisplayObjectConfig](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/models/display-object-config.model.ts) | Display object configuration. A set of `select`, `collapse`, and `focus` methods are also provided. |
709
654
  | measures | [IDisplayObjectMeasures](https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/models/display-object-measures.model.ts) \| null | Display object metrics. |
@@ -0,0 +1,207 @@
1
+ import { ChangeDetectorRef, ElementRef, inject } 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, DEFAULT_TEMPLATE_CONTEXT, 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 { BehaviorSubject, combineLatest, takeUntil, tap } from 'rxjs';
7
+ import { DisposableComponent } from '../../../utils/disposable-component';
8
+ /**
9
+ * BaseVirtualListItemComponent
10
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.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 extends DisposableComponent {
15
+ _apiService = inject(NgVirtualListPublicService);
16
+ _cdr = inject(ChangeDetectorRef);
17
+ _id;
18
+ get id() {
19
+ return this._id;
20
+ }
21
+ _listId;
22
+ get listId() {
23
+ return this._listId;
24
+ }
25
+ _displayId;
26
+ get displayId() {
27
+ return this._displayId;
28
+ }
29
+ _isSelected = false;
30
+ _isCollapsed = false;
31
+ _$config = new BehaviorSubject({});
32
+ $config = this._$config.asObservable();
33
+ _$measures = new BehaviorSubject(null);
34
+ $measures = this._$measures.asObservable();
35
+ _$focused = new BehaviorSubject(false);
36
+ $focused = this._$focused.asObservable();
37
+ _$part = new BehaviorSubject(PART_DEFAULT_ITEM);
38
+ $part = this._$part.asObservable();
39
+ _data = null;
40
+ get data() { return this._data; }
41
+ _$data = new BehaviorSubject(this._data);
42
+ $data = this._$data.asObservable();
43
+ set item(v) {
44
+ if (this._data === v || this._data?.id === -1 || !v) {
45
+ return;
46
+ }
47
+ this._data = v;
48
+ this.updatePartStr(v, this._isSelected, this._isCollapsed);
49
+ this.updateConfig(v);
50
+ this.updateMeasures(v);
51
+ this.update();
52
+ this._$data.next(v);
53
+ }
54
+ _$classes = new BehaviorSubject({});
55
+ $classes = this._$classes.asObservable();
56
+ _$index = new BehaviorSubject(-1);
57
+ $index = this._$index.asObservable();
58
+ _$templateContext = new BehaviorSubject(DEFAULT_TEMPLATE_CONTEXT);
59
+ $templateContext = this._$templateContext.asObservable();
60
+ regular = false;
61
+ _scrollBarSize = 0;
62
+ _langTextDir = TextDirections.LTR;
63
+ _regularLength = SIZE_100_PERSENT;
64
+ set regularLength(v) {
65
+ if (this._regularLength === v) {
66
+ return;
67
+ }
68
+ this._regularLength = v;
69
+ this.update();
70
+ }
71
+ get item() {
72
+ return this._data;
73
+ }
74
+ get itemId() {
75
+ return this._data?.id;
76
+ }
77
+ itemRenderer;
78
+ set renderer(v) {
79
+ if (this.itemRenderer === v) {
80
+ return;
81
+ }
82
+ this.itemRenderer = v;
83
+ this._cdr.markForCheck();
84
+ }
85
+ _elementRef = inject(ElementRef);
86
+ get element() {
87
+ return this._elementRef.nativeElement;
88
+ }
89
+ constructor() {
90
+ super();
91
+ const $data = this.$data, $config = this.$config, $measures = this.$measures, $focused = this.$focused;
92
+ combineLatest([$data, $focused]).pipe(takeUntil(this._$unsubscribe), tap(([data, focused]) => {
93
+ this._$classes.next({
94
+ [CLASS_NAME_SNAPPED]: data?.config?.snapped ?? false, [CLASS_NAME_SNAPPED_OUT]: data?.config?.snappedOut ?? false,
95
+ [CLASS_NAME_FOCUS]: focused,
96
+ });
97
+ })).subscribe();
98
+ $config.pipe(takeUntil(this._$unsubscribe), tap(config => {
99
+ this._$index.next(config?.tabIndex ?? -1);
100
+ })).subscribe();
101
+ combineLatest([$data, $config, $measures]).pipe(takeUntil(this._$unsubscribe), tap(([data, config, measures]) => {
102
+ this._$templateContext.next({
103
+ data: data?.data, prevData: data?.previouseData, nextData: data?.nextData, measures,
104
+ config, reseted: false, index: data?.index ?? -1, api: this._apiService,
105
+ });
106
+ })).subscribe();
107
+ }
108
+ updateMeasures(v) {
109
+ this._$measures.next(v?.measures ? { ...v.measures } : null);
110
+ }
111
+ updateConfig(v) {
112
+ this._$config.next({
113
+ ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this._$focused.getValue(),
114
+ });
115
+ }
116
+ update() {
117
+ const data = this._data, regular = this.regular, length = this._regularLength, el = this._elementRef.nativeElement;
118
+ if (data) {
119
+ el.setAttribute(ITEM_ID, `${data.id}`);
120
+ const styles = el.style;
121
+ styles.zIndex = data.config.zIndex;
122
+ styles.position = POSITION_ABSOLUTE;
123
+ if (data.config.isStub === true) {
124
+ el.style.visibility = VISIBILITY_HIDDEN;
125
+ }
126
+ if (regular) {
127
+ el.setAttribute(POSITION, POSITION_ZERO);
128
+ 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})`;
129
+ }
130
+ else {
131
+ el.setAttribute(POSITION, `${data.config.isVertical ? data.measures.y : data.measures.x}`);
132
+ styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX}, ${POSITION_ZERO})`;
133
+ }
134
+ styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;
135
+ styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
136
+ }
137
+ else {
138
+ el.removeAttribute(ID);
139
+ }
140
+ }
141
+ updatePartStr(v, isSelected, isCollapsed) {
142
+ let odd = false;
143
+ if (v?.index !== undefined) {
144
+ odd = v.index % 2 === 0;
145
+ }
146
+ let part = PART_DEFAULT_ITEM;
147
+ part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;
148
+ if (v ? v.config.snapped : false) {
149
+ part += PART_ITEM_SNAPPED;
150
+ }
151
+ if (isSelected) {
152
+ part += PART_ITEM_SELECTED;
153
+ }
154
+ if (isCollapsed) {
155
+ part += PART_ITEM_COLLAPSED;
156
+ }
157
+ if (v ? v.config.new : false) {
158
+ part += PART_ITEM_NEW;
159
+ }
160
+ if (this._$focused.getValue()) {
161
+ part += PART_ITEM_FOCUSED;
162
+ }
163
+ this._$part.next(part);
164
+ }
165
+ getBounds() {
166
+ const el = this._elementRef.nativeElement, { width, height } = el.getBoundingClientRect();
167
+ return { width: width > 0 ? width : 1, height: height > 0 ? height : 1, };
168
+ }
169
+ show() {
170
+ const el = this._elementRef.nativeElement, styles = el.style;
171
+ styles.zIndex = this._data?.config?.zIndex ?? DEFAULT_ZINDEX;
172
+ if (this.regular) {
173
+ if (styles.display === DISPLAY_BLOCK) {
174
+ return;
175
+ }
176
+ styles.display = DISPLAY_BLOCK;
177
+ }
178
+ else {
179
+ const isStub = this._data?.config?.isStub ?? false;
180
+ if (!isStub) {
181
+ if (styles.visibility === VISIBILITY_VISIBLE) {
182
+ return;
183
+ }
184
+ styles.visibility = VISIBILITY_VISIBLE;
185
+ }
186
+ }
187
+ }
188
+ hide() {
189
+ const el = this._elementRef.nativeElement, styles = el.style;
190
+ styles.position = POSITION_ABSOLUTE;
191
+ styles.transform = TRANSLATE_3D_HIDDEN;
192
+ styles.zIndex = HIDDEN_ZINDEX;
193
+ if (this.regular) {
194
+ if (styles.display === DISPLAY_NONE) {
195
+ return;
196
+ }
197
+ styles.display = DISPLAY_NONE;
198
+ }
199
+ else {
200
+ if (styles.visibility === VISIBILITY_HIDDEN) {
201
+ return;
202
+ }
203
+ styles.visibility = VISIBILITY_HIDDEN;
204
+ }
205
+ }
206
+ }
207
+ //# 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":"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","sourcesContent":["import { ChangeDetectorRef, ElementRef, inject, 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, DEFAULT_TEMPLATE_CONTEXT, 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 { BehaviorSubject, combineLatest, takeUntil, tap } from 'rxjs';\r\nimport { DisposableComponent } from '../../../utils/disposable-component';\r\n\r\n/**\r\n * BaseVirtualListItemComponent\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.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 extends DisposableComponent {\r\n  private _apiService = inject(NgVirtualListPublicService);\r\n\r\n  protected _cdr = inject(ChangeDetectorRef);\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 _$config = new BehaviorSubject<IDisplayObjectConfig>({} as IDisplayObjectConfig);\r\n  $config = this._$config.asObservable();\r\n\r\n  protected _$measures = new BehaviorSubject<IDisplayObjectMeasures | null>(null);\r\n  $measures = this._$measures.asObservable();\r\n\r\n  protected _$focused = new BehaviorSubject<boolean>(false);\r\n  $focused = this._$focused.asObservable();\r\n\r\n  protected _$part = new BehaviorSubject<string>(PART_DEFAULT_ITEM);\r\n  $part = this._$part.asObservable();\r\n\r\n  protected _data: IRenderVirtualListItem | null = null;\r\n  get data() { return this._data; }\r\n  protected readonly _$data = new BehaviorSubject<IRenderVirtualListItem | null>(this._data);\r\n  protected readonly $data = this._$data.asObservable();\r\n\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.next(v);\r\n  }\r\n\r\n  private _$classes = new BehaviorSubject<{ [cName: string]: boolean; }>({});\r\n  $classes = this._$classes.asObservable();\r\n\r\n  private _$index = new BehaviorSubject<number>(-1);\r\n  $index = this._$index.asObservable();\r\n\r\n  private _$templateContext = new BehaviorSubject<ITemplateContext>(DEFAULT_TEMPLATE_CONTEXT);\r\n  $templateContext = this._$templateContext.asObservable();\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\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 itemRenderer: TemplateRef<any> | undefined;\r\n\r\n  set renderer(v: TemplateRef<any> | undefined) {\r\n    if (this.itemRenderer === v) {\r\n      return;\r\n    }\r\n\r\n    this.itemRenderer = v;\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  protected _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\r\n  get element() {\r\n    return this._elementRef.nativeElement;\r\n  }\r\n\r\n  constructor() {\r\n    super();\r\n\r\n    const $data = this.$data,\r\n      $config = this.$config,\r\n      $measures = this.$measures,\r\n      $focused = this.$focused;\r\n\r\n    combineLatest([$data, $focused]).pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      tap(([data, focused]) => {\r\n        this._$classes.next({\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    ).subscribe();\r\n\r\n    $config.pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      tap(config => {\r\n        this._$index.next(config?.tabIndex ?? -1);\r\n      }),\r\n    ).subscribe();\r\n\r\n    combineLatest([$data, $config, $measures]).pipe(\r\n      takeUntil(this._$unsubscribe),\r\n      tap(([data, config, measures]) => {\r\n        this._$templateContext.next({\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    ).subscribe();\r\n  }\r\n\r\n  protected updateMeasures(v: IRenderVirtualListItem<any> | null) {\r\n    this._$measures.next(v?.measures ? { ...v.measures } : null)\r\n  }\r\n\r\n  protected updateConfig(v: IRenderVirtualListItem<any> | null) {\r\n    this._$config.next({\r\n      ...v?.config || {} as IDisplayObjectConfig, selected: this._isSelected, collapsed: this._isCollapsed, focused: this._$focused.getValue(),\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\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.getValue()) {\r\n      part += PART_ITEM_FOCUSED;\r\n    }\r\n    this._$part.next(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}\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,30 @@
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
+ export const DEFAULT_TEMPLATE_CONTEXT = {
3
+ data: undefined,
4
+ prevData: undefined,
5
+ nextData: undefined,
6
+ measures: null,
7
+ config: {
8
+ focused: false,
9
+ selected: false,
10
+ collapsed: false,
11
+ new: false,
12
+ odd: false,
13
+ even: false,
14
+ collapsable: false,
15
+ sticky: 0,
16
+ selectable: false,
17
+ snap: false,
18
+ snapped: false,
19
+ snappedOut: false,
20
+ isVertical: false,
21
+ dynamic: false,
22
+ isSnappingMethodAdvanced: false,
23
+ tabIndex: 0,
24
+ zIndex: '0',
25
+ },
26
+ reseted: false,
27
+ index: -1,
28
+ api: null,
29
+ };
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9jb25zdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxFQUNsQixtQkFBbUIsR0FBRyxnQ0FBZ0MsRUFDdEQsa0JBQWtCLEdBQUcsZUFBZSxFQUNwQyxRQUFRLEdBQUcsVUFBVSxFQUNyQixhQUFhLEdBQUcsR0FBRyxFQUNuQixPQUFPLEdBQUcsU0FBUyxFQUNuQixTQUFTLEdBQUcsR0FBRyxFQUNmLFlBQVksR0FBRyxXQUFXLEVBQzFCLFVBQVUsR0FBRyxTQUFTLEVBQ3RCLGFBQWEsR0FBRyxZQUFZLEVBQzVCLFlBQVksR0FBRyxXQUFXLEVBQzFCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGVBQWUsR0FBRyxVQUFVLEVBQzVCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGtCQUFrQixHQUFHLFNBQVMsRUFDOUIsc0JBQXNCLEdBQUcsYUFBYSxFQUN0QyxnQkFBZ0IsR0FBRyxPQUFPLENBQUM7QUFHM0IsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQXFCO0lBQ3RELElBQUksRUFBRSxTQUFTO0lBQ2YsUUFBUSxFQUFFLFNBQVM7SUFDbkIsUUFBUSxFQUFFLFNBQVM7SUFDbkIsUUFBUSxFQUFFLElBQUk7SUFDZCxNQUFNLEVBQUU7UUFDSixPQUFPLEVBQUUsS0FBSztRQUNkLFFBQVEsRUFBRSxLQUFLO1FBQ2YsU0FBUyxFQUFFLEtBQUs7UUFDaEIsR0FBRyxFQUFFLEtBQUs7UUFDVixHQUFHLEVBQUUsS0FBSztRQUNWLElBQUksRUFBRSxLQUFLO1FBQ1gsV0FBVyxFQUFFLEtBQUs7UUFDbEIsTUFBTSxFQUFFLENBQUM7UUFDVCxVQUFVLEVBQUUsS0FBSztRQUNqQixJQUFJLEVBQUUsS0FBSztRQUNYLE9BQU8sRUFBRSxLQUFLO1FBQ2QsVUFBVSxFQUFFLEtBQUs7UUFDakIsVUFBVSxFQUFFLEtBQUs7UUFDakIsT0FBTyxFQUFFLEtBQUs7UUFDZCx3QkFBd0IsRUFBRSxLQUFLO1FBQy9CLFFBQVEsRUFBRSxDQUFDO1FBQ1gsTUFBTSxFQUFFLEdBQUc7S0FDZDtJQUNELE9BQU8sRUFBRSxLQUFLO0lBQ2QsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNULEdBQUcsRUFBRSxJQUFJO0NBQ1osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElUZW1wbGF0ZUNvbnRleHQgfSBmcm9tIFwiLi4vaW50ZXJmYWNlc1wiO1xyXG5cclxuZXhwb3J0IGNvbnN0IElEID0gJ2lkJyxcclxuICAgIFRSQU5TTEFURV8zRF9ISURERU4gPSAndHJhbnNsYXRlM2QoLTEwMDBweCwtMTAwMHB4LDApJyxcclxuICAgIEFUVFJfQVJFQV9TRUxFQ1RFRCA9ICdhcmVhLXNlbGVjdGVkJyxcclxuICAgIFBPU0lUSU9OID0gJ3Bvc2l0aW9uJyxcclxuICAgIFBPU0lUSU9OX1pFUk8gPSAnMCcsXHJcbiAgICBJVEVNX0lEID0gJ2l0ZW0taWQnLFxyXG4gICAgS0VZX1NQQUNFID0gJyAnLFxyXG4gICAgS0VZX0FSUl9MRUZUID0gJ0Fycm93TGVmdCcsXHJcbiAgICBLRVlfQVJSX1VQID0gJ0Fycm93VXAnLFxyXG4gICAgS0VZX0FSUl9SSUdIVCA9ICdBcnJvd1JpZ2h0JyxcclxuICAgIEtFWV9BUlJfRE9XTiA9ICdBcnJvd0Rvd24nLFxyXG4gICAgRVZFTlRfRk9DVVNfSU4gPSAnZm9jdXNpbicsXHJcbiAgICBFVkVOVF9GT0NVU19PVVQgPSAnZm9jdXNvdXQnLFxyXG4gICAgRVZFTlRfS0VZX0RPV04gPSAna2V5ZG93bicsXHJcbiAgICBDTEFTU19OQU1FX1NOQVBQRUQgPSAnc25hcHBlZCcsXHJcbiAgICBDTEFTU19OQU1FX1NOQVBQRURfT1VUID0gJ3NuYXBwZWQtb3V0JyxcclxuICAgIENMQVNTX05BTUVfRk9DVVMgPSAnZm9jdXMnO1xyXG5cclxuXHJcbiAgICBleHBvcnQgY29uc3QgREVGQVVMVF9URU1QTEFURV9DT05URVhUOiBJVGVtcGxhdGVDb250ZXh0ID0ge1xyXG4gICAgICAgIGRhdGE6IHVuZGVmaW5lZCxcclxuICAgICAgICBwcmV2RGF0YTogdW5kZWZpbmVkLFxyXG4gICAgICAgIG5leHREYXRhOiB1bmRlZmluZWQsXHJcbiAgICAgICAgbWVhc3VyZXM6IG51bGwsXHJcbiAgICAgICAgY29uZmlnOiB7XHJcbiAgICAgICAgICAgIGZvY3VzZWQ6IGZhbHNlLFxyXG4gICAgICAgICAgICBzZWxlY3RlZDogZmFsc2UsXHJcbiAgICAgICAgICAgIGNvbGxhcHNlZDogZmFsc2UsXHJcbiAgICAgICAgICAgIG5ldzogZmFsc2UsXHJcbiAgICAgICAgICAgIG9kZDogZmFsc2UsXHJcbiAgICAgICAgICAgIGV2ZW46IGZhbHNlLFxyXG4gICAgICAgICAgICBjb2xsYXBzYWJsZTogZmFsc2UsXHJcbiAgICAgICAgICAgIHN0aWNreTogMCxcclxuICAgICAgICAgICAgc2VsZWN0YWJsZTogZmFsc2UsXHJcbiAgICAgICAgICAgIHNuYXA6IGZhbHNlLFxyXG4gICAgICAgICAgICBzbmFwcGVkOiBmYWxzZSxcclxuICAgICAgICAgICAgc25hcHBlZE91dDogZmFsc2UsXHJcbiAgICAgICAgICAgIGlzVmVydGljYWw6IGZhbHNlLFxyXG4gICAgICAgICAgICBkeW5hbWljOiBmYWxzZSxcclxuICAgICAgICAgICAgaXNTbmFwcGluZ01ldGhvZEFkdmFuY2VkOiBmYWxzZSxcclxuICAgICAgICAgICAgdGFiSW5kZXg6IDAsXHJcbiAgICAgICAgICAgIHpJbmRleDogJzAnLFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAgcmVzZXRlZDogZmFsc2UsXHJcbiAgICAgICAgaW5kZXg6IC0xLFxyXG4gICAgICAgIGFwaTogbnVsbCxcclxuICAgIH07XHJcbiAgICAiXX0=
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbmctbGlzdC1pdGVtL2ludGVyZmFjZXMvdGVtcGxhdGUtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSURpc3BsYXlPYmplY3RDb25maWcsIElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfSBmcm9tIFwiLi4vLi4vLi4vbW9kZWxzXCI7XHJcbmltcG9ydCB7IE5nVmlydHVhbExpc3RQdWJsaWNTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uLy4uL25nLXZpcnR1YWwtbGlzdC1wdWJsaWMuc2VydmljZVwiO1xyXG5cclxuLyoqXHJcbiAqIEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnRcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTYueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9pbnRlcmZhY2VzL3RlbXBsYXRlLWNvbnRleHQudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEFsZXhhbmRyb3ZpY2ggR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElUZW1wbGF0ZUNvbnRleHQ8RCA9IGFueT4ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBUEkgcHJvdmlkZXIuXHJcbiAgICAgKi9cclxuICAgIGFwaTogTmdWaXJ0dWFsTGlzdFB1YmxpY1NlcnZpY2UgfCBudWxsO1xyXG4gICAgLyoqXHJcbiAgICAgKiBMaXN0IGl0ZW0gZGF0YS5cclxuICAgICAqL1xyXG4gICAgZGF0YTogRDtcclxuICAgIC8qKlxyXG4gICAgICogRGF0YSBvZiB0aGUgcHJldmlvdXMgbGlzdCBpdGVtLlxyXG4gICAgICovXHJcbiAgICBwcmV2RGF0YTogRDtcclxuICAgIC8qKlxyXG4gICAgICogRGF0YSBvZiB0aGUgbmV4dCBsaXN0IGl0ZW0uXHJcbiAgICAgKi9cclxuICAgIG5leHREYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBMaXN0IGl0ZW0gbWVhc3VyZW1lbnQgZGF0YS5cclxuICAgICAqL1xyXG4gICAgbWVhc3VyZXM6IElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfCBudWxsO1xyXG4gICAgLyoqXHJcbiAgICAgKiBMaXN0IGl0ZW0gY29uZmlndXJhdGlvbi5cclxuICAgICAqL1xyXG4gICAgY29uZmlnOiBJRGlzcGxheU9iamVjdENvbmZpZztcclxuICAgIC8qKlxyXG4gICAgICogSW5kaWNhdGVzIGEgcmVzZXQgc3RhdGUuXHJcbiAgICAgKi9cclxuICAgIHJlc2V0ZWQ6IGJvb2xlYW47XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBpbmRleC5cclxuICAgICAqL1xyXG4gICAgaW5kZXg6IG51bWJlcjtcclxufSJdfQ==