ng-virtual-list 18.10.7 → 18.11.0

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 (105) hide show
  1. package/README.md +18 -79
  2. package/esm2022/lib/components/list-item/base/base-virtual-list-item-component.mjs +5 -5
  3. package/esm2022/lib/components/list-item/interfaces/template-context.mjs +1 -1
  4. package/esm2022/lib/components/list-item/ng-virtual-list-item.component.mjs +5 -49
  5. package/esm2022/lib/components/ng-scroll-bar/const/index.mjs +2 -2
  6. package/esm2022/lib/components/ng-scroll-bar/enums/index.mjs +3 -0
  7. package/esm2022/lib/components/ng-scroll-bar/enums/scrollbar-states.mjs +7 -0
  8. package/esm2022/lib/components/ng-scroll-bar/interfaces/index.mjs +1 -1
  9. package/esm2022/lib/components/ng-scroll-bar/interfaces/scroll-bar-template-context.mjs +2 -0
  10. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.mjs +25 -0
  11. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.component.mjs +49 -50
  12. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.module.mjs +4 -5
  13. package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.service.mjs +36 -0
  14. package/esm2022/lib/components/ng-scroll-bar/types/index.mjs +2 -0
  15. package/esm2022/lib/components/ng-scroll-bar/types/scrollbar-state.mjs +2 -0
  16. package/esm2022/lib/components/ng-scroll-view/base/base-scroll-view.component.mjs +24 -46
  17. package/esm2022/lib/components/ng-scroll-view/ng-scroll-view.component.mjs +12 -15
  18. package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.component.mjs +8 -8
  19. package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.mjs +10 -11
  20. package/esm2022/lib/components/prerender-container/core/prerender-track-box.mjs +1 -2
  21. package/esm2022/lib/components/prerender-container/prerender-container.component.mjs +5 -7
  22. package/esm2022/lib/components/scroller/ng-scroller.component.mjs +40 -19
  23. package/esm2022/lib/components/scroller/utils/scroll-box.mjs +4 -4
  24. package/esm2022/lib/const/index.mjs +3 -14
  25. package/esm2022/lib/core/track-box.mjs +37 -9
  26. package/esm2022/lib/interfaces/scroll-to-params.mjs +2 -0
  27. package/esm2022/lib/models/display-object-config.model.mjs +1 -1
  28. package/esm2022/lib/models/display-object-measures.model.mjs +1 -1
  29. package/esm2022/lib/models/render-item-measures.model.mjs +1 -1
  30. package/esm2022/lib/ng-virtual-list-public.service.mjs +121 -0
  31. package/esm2022/lib/ng-virtual-list.component.mjs +191 -195
  32. package/esm2022/lib/ng-virtual-list.service.mjs +106 -29
  33. package/esm2022/lib/types/index.mjs +1 -1
  34. package/esm2022/lib/utils/debounce.mjs +28 -6
  35. package/esm2022/public-api.mjs +6 -1
  36. package/fesm2022/ng-virtual-list.mjs +2771 -2865
  37. package/fesm2022/ng-virtual-list.mjs.map +1 -1
  38. package/lib/components/list-item/base/base-virtual-list-item-component.d.ts +2 -1
  39. package/lib/components/list-item/interfaces/template-context.d.ts +32 -0
  40. package/lib/components/list-item/ng-virtual-list-item.component.d.ts +0 -4
  41. package/lib/components/ng-scroll-bar/const/index.d.ts +1 -2
  42. package/lib/components/ng-scroll-bar/enums/index.d.ts +2 -0
  43. package/lib/components/ng-scroll-bar/enums/scrollbar-states.d.ts +5 -0
  44. package/lib/components/ng-scroll-bar/interfaces/index.d.ts +2 -1
  45. package/lib/components/ng-scroll-bar/interfaces/scroll-bar-template-context.d.ts +26 -0
  46. package/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.d.ts +16 -0
  47. package/lib/components/ng-scroll-bar/ng-scroll-bar.component.d.ts +15 -21
  48. package/lib/components/ng-scroll-bar/ng-scroll-bar.module.d.ts +1 -2
  49. package/lib/components/ng-scroll-bar/ng-scroll-bar.service.d.ts +22 -0
  50. package/lib/components/ng-scroll-bar/types/index.d.ts +2 -0
  51. package/lib/components/ng-scroll-bar/types/scrollbar-state.d.ts +2 -0
  52. package/lib/components/ng-scroll-view/base/base-scroll-view.component.d.ts +3 -7
  53. package/lib/components/prerender-container/components/prerender-list/prerender-list.component.d.ts +4 -6
  54. package/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.d.ts +3 -5
  55. package/lib/components/prerender-container/prerender-container.component.d.ts +2 -5
  56. package/lib/components/scroller/ng-scroller.component.d.ts +16 -6
  57. package/lib/const/index.d.ts +2 -2
  58. package/lib/core/track-box.d.ts +12 -7
  59. package/lib/interfaces/scroll-to-params.d.ts +7 -0
  60. package/lib/models/display-object-config.model.d.ts +1 -15
  61. package/lib/models/display-object-measures.model.d.ts +0 -4
  62. package/lib/models/render-item-measures.model.d.ts +0 -4
  63. package/lib/ng-virtual-list-public.service.d.ts +93 -0
  64. package/lib/ng-virtual-list.component.d.ts +25 -16
  65. package/lib/ng-virtual-list.service.d.ts +39 -7
  66. package/lib/types/index.d.ts +3 -4
  67. package/lib/utils/debounce.d.ts +5 -1
  68. package/package.json +1 -1
  69. package/public-api.d.ts +5 -0
  70. package/esm2022/lib/components/substrate/const/index.mjs +0 -2
  71. package/esm2022/lib/components/substrate/enums/index.mjs +0 -4
  72. package/esm2022/lib/components/substrate/enums/substrate-modes.mjs +0 -16
  73. package/esm2022/lib/components/substrate/enums/substrate-styles.mjs +0 -15
  74. package/esm2022/lib/components/substrate/index.mjs +0 -5
  75. package/esm2022/lib/components/substrate/substrate.component.mjs +0 -253
  76. package/esm2022/lib/components/substrate/substrate.module.mjs +0 -19
  77. package/esm2022/lib/components/substrate/types/index.mjs +0 -2
  78. package/esm2022/lib/components/substrate/types/substrate-mode.mjs +0 -2
  79. package/esm2022/lib/components/substrate/types/substrate-style.mjs +0 -2
  80. package/esm2022/lib/components/substrate/utils/circle-path.mjs +0 -4
  81. package/esm2022/lib/components/substrate/utils/index.mjs +0 -4
  82. package/esm2022/lib/components/substrate/utils/rounded-rect-path.mjs +0 -20
  83. package/esm2022/lib/types/color.mjs +0 -2
  84. package/esm2022/lib/types/gradient-color.mjs +0 -2
  85. package/esm2022/lib/types/rounded-corner.mjs +0 -2
  86. package/esm2022/lib/types/scrollbar-theme.mjs +0 -2
  87. package/esm2022/lib/utils/get-shape-min-size.mjs +0 -13
  88. package/lib/components/substrate/const/index.d.ts +0 -2
  89. package/lib/components/substrate/enums/index.d.ts +0 -3
  90. package/lib/components/substrate/enums/substrate-modes.d.ts +0 -13
  91. package/lib/components/substrate/enums/substrate-styles.d.ts +0 -12
  92. package/lib/components/substrate/index.d.ts +0 -7
  93. package/lib/components/substrate/substrate.component.d.ts +0 -54
  94. package/lib/components/substrate/substrate.module.d.ts +0 -8
  95. package/lib/components/substrate/types/index.d.ts +0 -3
  96. package/lib/components/substrate/types/substrate-mode.d.ts +0 -10
  97. package/lib/components/substrate/types/substrate-style.d.ts +0 -10
  98. package/lib/components/substrate/utils/circle-path.d.ts +0 -1
  99. package/lib/components/substrate/utils/index.d.ts +0 -3
  100. package/lib/components/substrate/utils/rounded-rect-path.d.ts +0 -1
  101. package/lib/types/color.d.ts +0 -7
  102. package/lib/types/gradient-color.d.ts +0 -8
  103. package/lib/types/rounded-corner.d.ts +0 -7
  104. package/lib/types/scrollbar-theme.d.ts +0 -47
  105. package/lib/utils/get-shape-min-size.d.ts +0 -8
package/README.md CHANGED
@@ -511,96 +511,32 @@ export class AppComponent {
511
511
 
512
512
  ## 🖼️ Stylization
513
513
 
514
- - Scrollbar theme
515
- ```ts
516
- import { NgVirtualListComponent, GradientColor, RoundedCorner, ScrollBarTheme } from 'ng-virtual-list';
517
-
518
- const X_LITE_BLUE_PLASMA_GRADIENT: GradientColor = ["rgba(133, 142, 255, 0)", "rgb(0, 133, 160)"],
519
- ROUND_CORNER: RoundedCorner = [3, 3, 3, 3],
520
- SCROLLBAR_GRADIENT: ScrollBarTheme = {
521
- fill: "rgba(51, 0, 97, 1)",
522
- hoverFill: "rgba(73, 6, 133, 1)",
523
- pressedFill: "rgba(73, 6, 150, 1)",
524
- strokeGradientColor: X_LITE_BLUE_PLASMA_GRADIENT,
525
- strokeAnimationDuration: 1000,
526
- thickness: 6,
527
- roundCorner: ROUND_CORNER,
528
- rippleColor: 'rgba(255,255,255,0.5)',
529
- rippleEnabled: true,
530
- };
531
-
532
- @Component({
533
- selector: 'app-root',
534
- imports: [FormsModule, NgVirtualListComponent],
535
- templateUrl: './app.component.html',
536
- styleUrl: './app.component.scss'
537
- })
538
- export class AppComponent {
539
- scrollbarTheme = SCROLLBAR_GRADIENT;
540
-
541
- items = Array.from({ length: 100000 }, (_, i) => ({ id: i, name: `Item #${i}` }));
542
- }
543
-
544
- ```
514
+ ### Scrollbar stylization
545
515
 
546
516
  ```scss
547
-
548
- .list {
549
- &::part(scrollbar-track) {
550
- margin-right: 2px;
551
- overflow: initial;
552
- }
553
-
554
- &::part(scrollbar-thumb) {
555
- border: 1px solid #8738c3;
556
- border-radius: 4px;
557
- }
517
+ .list::part(scrollbar-thumb__shape) {
518
+ background-color: rgba(51, 0, 97, 1);
519
+ border-radius: 3px;
558
520
  }
559
521
  ```
560
522
 
561
523
  ```html
562
- <ng-virtual-list class="list" [scrollbarTheme]="scrollbarTheme" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
524
+ <ng-virtual-list class="list" [scrollbarThickness]="12" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
563
525
 
564
- <ng-template #horizontalItemRenderer let-data="data" let-config="config">
565
- @if (data) {
566
- <div [ngClass]="{'list__h-container': true, 'selected': config.selected}">
567
- <span>{{data.name}}</span>
568
- </div>
569
- }
526
+ <ng-template #itemRenderer let-data="data" let-config="config">
527
+ <span>{{data.name}}</span>
570
528
  </ng-template>
571
529
  ```
572
530
 
531
+ ### Scrollbar castomization
532
+
533
+ [Examples](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/src/app/app.component.html)
534
+ [CustomScrollbarComponent](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/src/app/components/custom-scrollbar/custom-scrollbar.component.ts)
535
+
573
536
  List items are encapsulated in shadowDOM, so to override default styles you need to use ::part access
574
537
 
575
538
  - Customize a scroll area of list
576
539
  ```css
577
- .list::part(scroller) {
578
- scroll-behavior: auto;
579
-
580
- /* custom scrollbar */
581
- &::-webkit-scrollbar {
582
- width: 16px;
583
- height: 16px;
584
- }
585
-
586
- &::-webkit-scrollbar-track {
587
- background-color: #ffffff;
588
- }
589
-
590
- &::-webkit-scrollbar-thumb {
591
- background-color: #d6dee1;
592
- border-radius: 20px;
593
- border: 6px solid transparent;
594
- background-clip: content-box;
595
- min-width: 60px;
596
- min-height: 60px;
597
- }
598
-
599
- &::-webkit-scrollbar-thumb:hover {
600
- background-color: #a8bbbf;
601
- }
602
- }
603
-
604
540
  .list {
605
541
  border-radius: 3px;
606
542
  box-shadow: 1px 2px 8px 4px rgba(0, 0, 0, 0.075);
@@ -684,7 +620,6 @@ Inputs
684
620
  | snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
685
621
  | selectedIds | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/types/id.ts) \| null | Sets the selected items. |
686
622
  | 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. |
687
- | scrollbarTheme | [ScrollBarTheme?](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/types/scrollbar-theme.ts) | Scrollbar theme. |
688
623
  | clickDistance | number? = 40 | The maximum scroll distance at which a click event is triggered. |
689
624
  | waitForPreparation | boolean? = true | If true, it will wait until the list items are fully prepared before displaying them.. The default value is `true`. |
690
625
  | scrollStartOffset | number? = 0 | Sets the scroll start offset value; Default value is "0". |
@@ -693,9 +628,12 @@ Inputs
693
628
  | 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. |
694
629
  | 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. |
695
630
  | snapToEndTransitionInstantOffset | number? = 0 | Sets the offset value; if the scroll area value is exceeded, the scroll animation will be disabled. Default value is "0". |
696
- | scrollbarMinSize | number? = 80 | Minimum scrollbar size. |
697
631
  | scrollbarEnabled | boolean? = true | Determines whether the scrollbar is shown or not. The default value is "true". |
698
632
  | scrollbarInteractive | boolean? = true | Determines whether scrolling using the scrollbar will be possible. The default value is "true". |
633
+ | scrollbarMinSize | number? = 80 | Minimum scrollbar size. |
634
+ | scrollbarThickness | number? = 6 | Scrollbar thickness. |
635
+ | scrollbarThumbRenderer | TemplateRef<any> \| null = null | Scrollbar customization template. |
636
+ | scrollbarThumbParams | {[propName: string]: any;} \| null | Additional options for the scrollbar. |
699
637
  | scrollBehavior | ScrollBehavior? = 'smooth' | Defines the scrolling behavior for any element on the page. The default value is "smooth". |
700
638
  | trackBy | string? = 'id' | The name of the property by which tracking is performed. |
701
639
 
@@ -732,7 +670,7 @@ Methods
732
670
  ### Template API
733
671
 
734
672
  ```html
735
- <ng-template #itemRenderer let-data="data" let-config="config" let-measures="measures">
673
+ <ng-template #itemRenderer let-data="data" let-config="config" let-measures="measures" let-api="api">
736
674
  <!-- content -->
737
675
  </ng-template>
738
676
  ```
@@ -741,6 +679,7 @@ Properties
741
679
 
742
680
  | Property | Type | Description |
743
681
  |--|--|--|
682
+ | api | [NgVirtualListPublicService](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/ng-virtual-list-public.service.ts) | List API Provider. |
744
683
  | data | {\[id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/types/id.ts) \], [otherProps: string]: any;} | Collection item data. |
745
684
  | config | [IDisplayObjectConfig](https://github.com/DjonnyX/ng-virtual-list/blob/18.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. |
746
685
  | measures | [IDisplayObjectMeasures](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/models/display-object-measures.model.ts) \| null | Display object metrics. |
@@ -2,14 +2,15 @@ import { computed, DestroyRef, ElementRef, inject, signal } from '@angular/core'
2
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
3
  import { CLASS_NAME_FOCUS, CLASS_NAME_SNAPPED, CLASS_NAME_SNAPPED_OUT, ID, ITEM_ID, POSITION, POSITION_ZERO, TRANSLATE_3D_HIDDEN, } from '../const';
4
4
  import { TextDirections } from '../../../enums';
5
- const EMPTY_HANDLER = () => { };
5
+ import { NgVirtualListPublicService } from '../../../ng-virtual-list-public.service';
6
6
  /**
7
7
  * BaseVirtualListItemComponent
8
- * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/components/list-item/base//base-virtual-list-item-component.ts
8
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/components/list-item/base/base-virtual-list-item-component.ts
9
9
  * @author Evgenii Alexandrovich Grebennikov
10
10
  * @email djonnyx@gmail.com
11
11
  */
12
12
  export class BaseVirtualListItemComponent {
13
+ _apiService = inject(NgVirtualListPublicService);
13
14
  _id;
14
15
  get id() {
15
16
  return this._id;
@@ -89,7 +90,7 @@ export class BaseVirtualListItemComponent {
89
90
  const data = this.data(), measures = this.measures(), config = this.config();
90
91
  return {
91
92
  data: data?.data, prevData: data?.previouseData, nextData: data?.nextData, measures,
92
- config, reseted: false, index: data?.index ?? -1,
93
+ config, reseted: false, index: data?.index ?? -1, api: this._apiService,
93
94
  };
94
95
  });
95
96
  }
@@ -99,7 +100,6 @@ export class BaseVirtualListItemComponent {
99
100
  updateConfig(v) {
100
101
  this.config.set({
101
102
  ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),
102
- collapse: EMPTY_HANDLER, select: EMPTY_HANDLER, focus: EMPTY_HANDLER,
103
103
  });
104
104
  }
105
105
  update() {
@@ -193,4 +193,4 @@ export class BaseVirtualListItemComponent {
193
193
  }
194
194
  }
195
195
  }
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-virtual-list-item-component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-virtual-list/src/lib/components/list-item/base/base-virtual-list-item-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { 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\n\r\nconst EMPTY_HANDLER = () => { };\r\n\r\n/**\r\n * BaseVirtualListItemComponent\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.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  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\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\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.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,\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      collapse: EMPTY_HANDLER, select: EMPTY_HANDLER, focus: EMPTY_HANDLER,\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()) {\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}"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-virtual-list-item-component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-virtual-list/src/lib/components/list-item/base/base-virtual-list-item-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { 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\n\r\n/**\r\n * BaseVirtualListItemComponent\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.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 _apiService = inject(NgVirtualListPublicService);\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\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\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.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\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}"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbGlzdC1pdGVtL2ludGVyZmFjZXMvdGVtcGxhdGUtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSURpc3BsYXlPYmplY3RDb25maWcsIElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfSBmcm9tIFwiLi4vLi4vLi4vbW9kZWxzXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElUZW1wbGF0ZUNvbnRleHQ8RCA9IGFueT4ge1xyXG4gICAgZGF0YTogRDtcclxuICAgIHByZXZEYXRhOiBEO1xyXG4gICAgbmV4dERhdGE6IEQ7XHJcbiAgICBtZWFzdXJlczogSURpc3BsYXlPYmplY3RNZWFzdXJlcyB8IG51bGw7XHJcbiAgICBjb25maWc6IElEaXNwbGF5T2JqZWN0Q29uZmlnO1xyXG4gICAgcmVzZXRlZDogYm9vbGVhbjtcclxuICAgIGluZGV4OiBudW1iZXI7XHJcbn0iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbGlzdC1pdGVtL2ludGVyZmFjZXMvdGVtcGxhdGUtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSURpc3BsYXlPYmplY3RDb25maWcsIElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfSBmcm9tIFwiLi4vLi4vLi4vbW9kZWxzXCI7XHJcbmltcG9ydCB7IE5nVmlydHVhbExpc3RQdWJsaWNTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uLy4uL25nLXZpcnR1YWwtbGlzdC1wdWJsaWMuc2VydmljZVwiO1xyXG5cclxuLyoqXHJcbiAqIEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnRcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTgueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9pbnRlcmZhY2VzL3RlbXBsYXRlLWNvbnRleHQudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEFsZXhhbmRyb3ZpY2ggR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElUZW1wbGF0ZUNvbnRleHQ8RCA9IGFueT4ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBUEkgcHJvdmlkZXIuXHJcbiAgICAgKi9cclxuICAgIGFwaTogTmdWaXJ0dWFsTGlzdFB1YmxpY1NlcnZpY2U7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBkYXRhLlxyXG4gICAgICovXHJcbiAgICBkYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBEYXRhIG9mIHRoZSBwcmV2aW91cyBsaXN0IGl0ZW0uXHJcbiAgICAgKi9cclxuICAgIHByZXZEYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBEYXRhIG9mIHRoZSBuZXh0IGxpc3QgaXRlbS5cclxuICAgICAqL1xyXG4gICAgbmV4dERhdGE6IEQ7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBtZWFzdXJlbWVudCBkYXRhLlxyXG4gICAgICovXHJcbiAgICBtZWFzdXJlczogSURpc3BsYXlPYmplY3RNZWFzdXJlcyB8IG51bGw7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBjb25maWd1cmF0aW9uLlxyXG4gICAgICovXHJcbiAgICBjb25maWc6IElEaXNwbGF5T2JqZWN0Q29uZmlnO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgYSByZXNldCBzdGF0ZS5cclxuICAgICAqL1xyXG4gICAgcmVzZXRlZDogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogTGlzdCBpdGVtIGluZGV4LlxyXG4gICAgICovXHJcbiAgICBpbmRleDogbnVtYmVyO1xyXG59Il19
@@ -5,8 +5,6 @@ import { DEFAULT_CLICK_DISTANCE, NAVIGATION_BY_KEYBOARD_TIMER, VISIBILITY_HIDDEN
5
5
  import { BaseVirtualListItemComponent } from './base';
6
6
  import { NgVirtualListService } from '../../ng-virtual-list.service';
7
7
  import { MethodsForSelectingTypes } from '../../enums/method-for-selecting-types';
8
- import { validateBoolean } from '../../utils/validation';
9
- import { FocusAlignments } from '../../enums';
10
8
  import { createDisplayId, getListElementByIndex } from './utils';
11
9
  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';
12
10
  import * as i0 from "@angular/core";
@@ -23,39 +21,6 @@ import * as i2 from "../../directives/item-click/item-click.directive";
23
21
  export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
24
22
  _service = inject(NgVirtualListService);
25
23
  maxClickDistance = signal(DEFAULT_CLICK_DISTANCE);
26
- _selectHandler = (data) =>
27
- /**
28
- * Selects a list item
29
- * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.
30
- */
31
- (selected = undefined) => {
32
- const valid = validateBoolean(selected, true);
33
- if (!valid) {
34
- console.error('The "selected" parameter must be of type `boolean` or `undefined`.');
35
- return;
36
- }
37
- this._service.select(data, selected);
38
- };
39
- _collapseHandler = (data) =>
40
- /**
41
- * Collapse list items
42
- * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.
43
- */
44
- (collapsed = undefined) => {
45
- const valid = validateBoolean(collapsed, true);
46
- if (!valid) {
47
- console.error('The "collapsed" parameter must be of type `boolean` or `undefined`.');
48
- return;
49
- }
50
- this._service.collapse(data, collapsed);
51
- };
52
- _focusHandler = () =>
53
- /**
54
- * Focus a list item
55
- */
56
- (align = FocusAlignments.CENTER) => {
57
- this.focus(align);
58
- };
59
24
  _injector = inject(Injector);
60
25
  constructor() {
61
26
  super();
@@ -127,8 +92,10 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
127
92
  case KEY_SPACE: {
128
93
  e.stopImmediatePropagation();
129
94
  e.preventDefault();
130
- this._service.select(this._data);
131
- this._service.collapse(this._data);
95
+ if (!!this._data) {
96
+ this._service.select(this._data.id);
97
+ this._service.collapse(this._data.id);
98
+ }
132
99
  break;
133
100
  }
134
101
  case KEY_ARR_LEFT:
@@ -213,20 +180,9 @@ export class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
213
180
  }
214
181
  return -1;
215
182
  }
216
- focus(align = FocusAlignments.CENTER, index = -1) {
217
- if (this._service.listElement) {
218
- const tabIndex = index > -1 ? index : this._data?.config?.tabIndex ?? 0;
219
- let i = tabIndex;
220
- const element = this._service.listElement.querySelector(getListElementByIndex(i));
221
- if (!!element) {
222
- this._service.focus(element, align);
223
- }
224
- }
225
- }
226
183
  updateConfig(v) {
227
184
  this.config.set({
228
185
  ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),
229
- collapse: this._collapseHandler(v), select: this._selectHandler(v), focus: this._focusHandler(),
230
186
  });
231
187
  }
232
188
  onClickHandler() {
@@ -242,4 +198,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
242
198
  'role': 'listitem',
243
199
  }, 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"] }]
244
200
  }], ctorParameters: () => [] });
245
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-virtual-list/src/lib/components/list-item/ng-virtual-list-item.component.ts","../../../../../../projects/ng-virtual-list/src/lib/components/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, delay, filter, debounceTime } from 'rxjs';\r\nimport { IRenderVirtualListItem } from '../../models/render-item.model';\r\nimport { FocusAlignment, 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 { validateBoolean } from '../../utils/validation';\r\nimport { FocusAlignments } from '../../enums';\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/18.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  \r\n  protected readonly _service = inject(NgVirtualListService);\r\n\r\n  protected readonly maxClickDistance = signal<number>(DEFAULT_CLICK_DISTANCE);\r\n\r\n  private _selectHandler = (data: IRenderVirtualListItem<any> | null) =>\r\n    /**\r\n     * Selects a list item\r\n     * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n     */\r\n    (selected: boolean | undefined = undefined) => {\r\n      const valid = validateBoolean(selected, true);\r\n      if (!valid) {\r\n        console.error('The \"selected\" parameter must be of type `boolean` or `undefined`.');\r\n        return;\r\n      }\r\n      this._service.select(data, selected);\r\n    };\r\n\r\n  private _collapseHandler = (data: IRenderVirtualListItem<any> | null) =>\r\n    /**\r\n    * Collapse list items\r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n    (collapsed: boolean | undefined = undefined) => {\r\n      const valid = validateBoolean(collapsed, true);\r\n      if (!valid) {\r\n        console.error('The \"collapsed\" parameter must be of type `boolean` or `undefined`.');\r\n        return;\r\n      }\r\n      this._service.collapse(data, collapsed);\r\n    };\r\n\r\n  private _focusHandler = () =>\r\n    /**\r\n    * Focus a list item\r\n    */\r\n    (align: FocusAlignment = FocusAlignments.CENTER) => {\r\n      this.focus(align);\r\n    };\r\n\r\n  protected _injector = inject(Injector);\r\n\r\n  constructor() {\r\n    super();\r\n\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\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            this._service.select(this._data);\r\n            this._service.collapse(this._data);\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  private focus(align: FocusAlignment = FocusAlignments.CENTER, index: number = -1) {\r\n    if (this._service.listElement) {\r\n      const tabIndex = index > -1 ? index : this._data?.config?.tabIndex ?? 0;\r\n      let i = tabIndex;\r\n      const element = this._service.listElement.querySelector<HTMLDivElement>(getListElementByIndex(i));\r\n      if (!!element) {\r\n        this._service.focus(element, align);\r\n      }\r\n    }\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      collapse: this._collapseHandler(v), select: this._selectHandler(v), focus: this._focusHandler(),\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>"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-virtual-list/src/lib/components/list-item/ng-virtual-list-item.component.ts","../../../../../../projects/ng-virtual-list/src/lib/components/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 { FocusAlignment, 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 { FocusAlignments } from '../../enums';\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/18.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 _service = inject(NgVirtualListService);\r\n\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    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\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>"]}
@@ -1,2 +1,2 @@
1
- export const DEFAULT_THICKNESS = 6, DEFAULT_SIZE = 6, DEFAULT_ROUNDED_CORNER = [3, 3, 3, 3], DEFAULT_STROKE_ANIMATION_DURATION = 500, DEFAULT_RIPPLE_ENABLED = true, DEFAULT_RIPPLE_COLOR = 'rgba(0,0,0,0.5)', PX = 'px', WIDTH = 'width', HEIGHT = 'height', OPACITY = 'opacity', OPACITY_0 = '0', OPACITY_1 = '1', TRANSITION = 'transition', NONE = 'none', TRANSITION_FADE_IN = `${OPACITY} 500ms ease-out`;
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLXNjcm9sbC1iYXIvY29uc3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxFQUM5QixZQUFZLEdBQUcsQ0FBQyxFQUNoQixzQkFBc0IsR0FBa0IsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsRUFDcEQsaUNBQWlDLEdBQUcsR0FBRyxFQUN2QyxzQkFBc0IsR0FBRyxJQUFJLEVBQzdCLG9CQUFvQixHQUFHLGlCQUFpQixFQUN4QyxFQUFFLEdBQUcsSUFBSSxFQUNULEtBQUssR0FBRyxPQUFPLEVBQ2YsTUFBTSxHQUFHLFFBQVEsRUFDakIsT0FBTyxHQUFHLFNBQVMsRUFDbkIsU0FBUyxHQUFHLEdBQUcsRUFDZixTQUFTLEdBQUcsR0FBRyxFQUNmLFVBQVUsR0FBRyxZQUFZLEVBQ3pCLElBQUksR0FBRyxNQUFNLEVBQ2Isa0JBQWtCLEdBQUcsR0FBRyxPQUFPLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91bmRlZENvcm5lciB9IGZyb20gXCIuLi8uLi8uLi90eXBlc1wiO1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfVEhJQ0tORVNTID0gNixcclxuICAgIERFRkFVTFRfU0laRSA9IDYsXHJcbiAgICBERUZBVUxUX1JPVU5ERURfQ09STkVSOiBSb3VuZGVkQ29ybmVyID0gWzMsIDMsIDMsIDNdLFxyXG4gICAgREVGQVVMVF9TVFJPS0VfQU5JTUFUSU9OX0RVUkFUSU9OID0gNTAwLFxyXG4gICAgREVGQVVMVF9SSVBQTEVfRU5BQkxFRCA9IHRydWUsXHJcbiAgICBERUZBVUxUX1JJUFBMRV9DT0xPUiA9ICdyZ2JhKDAsMCwwLDAuNSknLFxyXG4gICAgUFggPSAncHgnLFxyXG4gICAgV0lEVEggPSAnd2lkdGgnLFxyXG4gICAgSEVJR0hUID0gJ2hlaWdodCcsXHJcbiAgICBPUEFDSVRZID0gJ29wYWNpdHknLFxyXG4gICAgT1BBQ0lUWV8wID0gJzAnLFxyXG4gICAgT1BBQ0lUWV8xID0gJzEnLFxyXG4gICAgVFJBTlNJVElPTiA9ICd0cmFuc2l0aW9uJyxcclxuICAgIE5PTkUgPSAnbm9uZScsXHJcbiAgICBUUkFOU0lUSU9OX0ZBREVfSU4gPSBgJHtPUEFDSVRZfSA1MDBtcyBlYXNlLW91dGA7XHJcbiJdfQ==
1
+ export const DEFAULT_THICKNESS = 6, DEFAULT_SIZE = 6, PX = 'px', WIDTH = 'width', HEIGHT = 'height', OPACITY = 'opacity', OPACITY_0 = '0', OPACITY_1 = '1', TRANSITION = 'transition', NONE = 'none', TRANSITION_FADE_IN = `${OPACITY} 500ms ease-out`;
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLXNjcm9sbC1iYXIvY29uc3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxFQUM5QixZQUFZLEdBQUcsQ0FBQyxFQUNoQixFQUFFLEdBQUcsSUFBSSxFQUNULEtBQUssR0FBRyxPQUFPLEVBQ2YsTUFBTSxHQUFHLFFBQVEsRUFDakIsT0FBTyxHQUFHLFNBQVMsRUFDbkIsU0FBUyxHQUFHLEdBQUcsRUFDZixTQUFTLEdBQUcsR0FBRyxFQUNmLFVBQVUsR0FBRyxZQUFZLEVBQ3pCLElBQUksR0FBRyxNQUFNLEVBQ2Isa0JBQWtCLEdBQUcsR0FBRyxPQUFPLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFRkFVTFRfVEhJQ0tORVNTID0gNixcclxuICAgIERFRkFVTFRfU0laRSA9IDYsXHJcbiAgICBQWCA9ICdweCcsXHJcbiAgICBXSURUSCA9ICd3aWR0aCcsXHJcbiAgICBIRUlHSFQgPSAnaGVpZ2h0JyxcclxuICAgIE9QQUNJVFkgPSAnb3BhY2l0eScsXHJcbiAgICBPUEFDSVRZXzAgPSAnMCcsXHJcbiAgICBPUEFDSVRZXzEgPSAnMScsXHJcbiAgICBUUkFOU0lUSU9OID0gJ3RyYW5zaXRpb24nLFxyXG4gICAgTk9ORSA9ICdub25lJyxcclxuICAgIFRSQU5TSVRJT05fRkFERV9JTiA9IGAke09QQUNJVFl9IDUwMG1zIGVhc2Utb3V0YDtcclxuIl19
@@ -0,0 +1,3 @@
1
+ import { ScrollbarStates } from './scrollbar-states';
2
+ export { ScrollbarStates, };
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLXNjcm9sbC1iYXIvZW51bXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXJELE9BQU8sRUFDSCxlQUFlLEdBQ2xCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY3JvbGxiYXJTdGF0ZXMgfSBmcm9tICcuL3Njcm9sbGJhci1zdGF0ZXMnO1xyXG5cclxuZXhwb3J0IHtcclxuICAgIFNjcm9sbGJhclN0YXRlcyxcclxufVxyXG4iXX0=
@@ -0,0 +1,7 @@
1
+ export var ScrollbarStates;
2
+ (function (ScrollbarStates) {
3
+ ScrollbarStates[ScrollbarStates["NORMAL"] = 0] = "NORMAL";
4
+ ScrollbarStates[ScrollbarStates["PRESSED"] = 1] = "PRESSED";
5
+ ScrollbarStates[ScrollbarStates["HOVER"] = 2] = "HOVER";
6
+ })(ScrollbarStates || (ScrollbarStates = {}));
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsYmFyLXN0YXRlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbmctc2Nyb2xsLWJhci9lbnVtcy9zY3JvbGxiYXItc3RhdGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDdkIseURBQU0sQ0FBQTtJQUNOLDJEQUFPLENBQUE7SUFDUCx1REFBSyxDQUFBO0FBQ1QsQ0FBQyxFQUpXLGVBQWUsS0FBZixlQUFlLFFBSTFCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gU2Nyb2xsYmFyU3RhdGVzIHtcclxuICAgIE5PUk1BTCxcclxuICAgIFBSRVNTRUQsXHJcbiAgICBIT1ZFUixcclxufVxyXG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLXNjcm9sbC1iYXIvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVNjcm9sbEJhckRyYWdFdmVudCB9IGZyb20gJy4vc2Nyb2xsYmFyLWRyYWctZGF0YSc7XHJcblxyXG5leHBvcnQgdHlwZSB7XHJcbiAgICBJU2Nyb2xsQmFyRHJhZ0V2ZW50LFxyXG59Il19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLXNjcm9sbC1iYXIvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVNjcm9sbEJhckRyYWdFdmVudCB9IGZyb20gJy4vc2Nyb2xsYmFyLWRyYWctZGF0YSc7XHJcbmltcG9ydCB7IElTY3JvbGxCYXJUZW1wbGF0ZUNvbnRleHQgfSBmcm9tICcuL3Njcm9sbC1iYXItdGVtcGxhdGUtY29udGV4dCc7XHJcblxyXG5leHBvcnQgdHlwZSB7XHJcbiAgICBJU2Nyb2xsQmFyRHJhZ0V2ZW50LFxyXG4gICAgSVNjcm9sbEJhclRlbXBsYXRlQ29udGV4dCxcclxufSJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLWJhci10ZW1wbGF0ZS1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvY29tcG9uZW50cy9uZy1zY3JvbGwtYmFyL2ludGVyZmFjZXMvc2Nyb2xsLWJhci10ZW1wbGF0ZS1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHcmFkaWVudENvbG9yUG9zaXRpb25zIH0gZnJvbSBcIi4uLy4uLy4uL3R5cGVzXCI7XHJcbmltcG9ydCB7IE5nU2Nyb2xsQmFyUHVibGljU2VydmljZSB9IGZyb20gXCIuLi9uZy1zY3JvbGwtYmFyLXB1YmxpYy5zZXJ2aWNlXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElTY3JvbGxCYXJUZW1wbGF0ZUNvbnRleHQge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBUEkgcHJvdmlkZXJcclxuICAgICAqL1xyXG4gICAgYXBpOiBOZ1Njcm9sbEJhclB1YmxpY1NlcnZpY2U7XHJcbiAgICAvKipcclxuICAgICAqIFNjcm9sbGJhciB0aHVtYiB3aWR0aC5cclxuICAgICAqL1xyXG4gICAgd2lkdGg6IG51bWJlcjtcclxuICAgIC8qKlxyXG4gICAgICogU2Nyb2xsYmFyIHRodW1iIGhlaWdodC5cclxuICAgICAqL1xyXG4gICAgaGVpZ2h0OiBudW1iZXI7XHJcbiAgICAvKipcclxuICAgICAqIEdyYWRpZW50IGZpbGwgcG9zaXRpb24gcGFyYW1ldGVycy5cclxuICAgICAqL1xyXG4gICAgZmlsbFBvc2l0aW9uczogR3JhZGllbnRDb2xvclBvc2l0aW9ucztcclxuICAgIC8qKlxyXG4gICAgICogQWRkaXRpb25hbCBvcHRpb25zIGZvciB0aGUgc2Nyb2xsYmFyLlxyXG4gICAgICovXHJcbiAgICBwYXJhbXM6IHsgW3Byb3BOYW1lOiBzdHJpbmddOiBhbnkgfTtcclxufVxyXG4iXX0=
@@ -0,0 +1,25 @@
1
+ import { inject, Injectable } from '@angular/core';
2
+ import { NgScrollBarService } from './ng-scroll-bar.service';
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * NgScrollBarService
6
+ * Maximum performance for extremely large lists.
7
+ * It is based on algorithms for virtualization of screen objects.
8
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.ts
9
+ * @author Evgenii Alexandrovich Grebennikov
10
+ * @email djonnyx@gmail.com
11
+ */
12
+ export class NgScrollBarPublicService {
13
+ _internalService = inject(NgScrollBarService);
14
+ get $click() { return this._internalService.$click; }
15
+ get $state() { return this._internalService.$state; }
16
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NgScrollBarPublicService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
17
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NgScrollBarPublicService, providedIn: 'root' });
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NgScrollBarPublicService, decorators: [{
20
+ type: Injectable,
21
+ args: [{
22
+ providedIn: 'root'
23
+ }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctc2Nyb2xsLWJhci1wdWJsaWMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbmctc2Nyb2xsLWJhci9uZy1zY3JvbGwtYmFyLXB1YmxpYy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQUU3RDs7Ozs7OztHQU9HO0FBSUgsTUFBTSxPQUFPLHdCQUF3QjtJQUMzQixnQkFBZ0IsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUV0RCxJQUFJLE1BQU0sS0FBSyxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBRXJELElBQUksTUFBTSxLQUFLLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7d0dBTDFDLHdCQUF3Qjs0R0FBeEIsd0JBQXdCLGNBRnZCLE1BQU07OzRGQUVQLHdCQUF3QjtrQkFIcEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTmdTY3JvbGxCYXJTZXJ2aWNlIH0gZnJvbSAnLi9uZy1zY3JvbGwtYmFyLnNlcnZpY2UnO1xyXG5cclxuLyoqXHJcbiAqIE5nU2Nyb2xsQmFyU2VydmljZVxyXG4gKiBNYXhpbXVtIHBlcmZvcm1hbmNlIGZvciBleHRyZW1lbHkgbGFyZ2UgbGlzdHMuXHJcbiAqIEl0IGlzIGJhc2VkIG9uIGFsZ29yaXRobXMgZm9yIHZpcnR1YWxpemF0aW9uIG9mIHNjcmVlbiBvYmplY3RzLlxyXG4gKiBAbGluayBodHRwczovL2dpdGh1Yi5jb20vRGpvbm55WC9uZy12aXJ0dWFsLWxpc3QvYmxvYi8xOC54L3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbmctc2Nyb2xsLWJhci9uZy1zY3JvbGwtYmFyLXB1YmxpYy5zZXJ2aWNlLnRzXHJcbiAqIEBhdXRob3IgRXZnZW5paSBBbGV4YW5kcm92aWNoIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTmdTY3JvbGxCYXJQdWJsaWNTZXJ2aWNlIHtcclxuICBwcml2YXRlIF9pbnRlcm5hbFNlcnZpY2UgPSBpbmplY3QoTmdTY3JvbGxCYXJTZXJ2aWNlKTtcclxuXHJcbiAgZ2V0ICRjbGljaygpIHsgcmV0dXJuIHRoaXMuX2ludGVybmFsU2VydmljZS4kY2xpY2s7IH1cclxuXHJcbiAgZ2V0ICRzdGF0ZSgpIHsgcmV0dXJuIHRoaXMuX2ludGVybmFsU2VydmljZS4kc3RhdGU7IH1cclxufVxyXG4iXX0=