ng-virtual-list 17.10.6 → 17.10.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +53 -38
- package/esm2022/lib/components/list-item/base/base-virtual-list-item-component.mjs +200 -0
- package/esm2022/lib/components/list-item/base/index.mjs +3 -0
- package/esm2022/lib/components/list-item/const/index.mjs +2 -0
- package/esm2022/lib/components/list-item/interfaces/index.mjs +2 -0
- package/esm2022/lib/components/list-item/interfaces/template-context.mjs +2 -0
- package/esm2022/lib/components/list-item/ng-virtual-list-item.component.mjs +84 -234
- package/esm2022/lib/components/list-item/utils/create-display-id.mjs +4 -0
- package/esm2022/lib/components/list-item/utils/index.mjs +3 -2
- package/esm2022/lib/components/ng-scroll-bar/const/index.mjs +2 -0
- package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.component.mjs +51 -42
- package/esm2022/lib/components/ng-scroll-view/base/base-scroll-view.component.mjs +158 -0
- package/esm2022/lib/components/ng-scroll-view/const/index.mjs +5 -1
- package/esm2022/lib/components/ng-scroll-view/ng-scroll-view.component.mjs +22 -139
- package/esm2022/lib/components/ng-scroll-view/utils/calculate-direction.mjs +11 -0
- package/esm2022/lib/components/ng-scroll-view/utils/index.mjs +4 -0
- package/esm2022/lib/components/ng-scroll-view/utils/scroll-box.mjs +45 -0
- package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.component.mjs +154 -0
- package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.module.mjs +21 -0
- package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.mjs +78 -0
- package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.mjs +20 -0
- package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.mjs +119 -0
- package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.mjs +20 -0
- package/esm2022/lib/components/prerender-container/core/index.mjs +3 -0
- package/esm2022/lib/components/prerender-container/core/prerender-track-box.mjs +169 -0
- package/esm2022/lib/components/prerender-container/events/index.mjs +6 -0
- package/esm2022/lib/components/prerender-container/interfaces/index.mjs +2 -0
- package/esm2022/lib/components/prerender-container/interfaces/refresh-params.mjs +2 -0
- package/esm2022/lib/components/prerender-container/prerender-container.component.mjs +65 -0
- package/esm2022/lib/components/prerender-container/prerender-container.module.mjs +20 -0
- package/esm2022/lib/components/prerender-container/types/cache.mjs +2 -0
- package/esm2022/lib/components/prerender-container/types/index.mjs +2 -0
- package/esm2022/lib/components/scroller/const/index.mjs +2 -0
- package/esm2022/lib/components/scroller/ng-scroller.component.mjs +143 -51
- package/esm2022/lib/components/substrate/const/index.mjs +2 -0
- package/esm2022/lib/components/substrate/substrate.component.mjs +16 -42
- package/esm2022/lib/components/substrate/utils/circle-path.mjs +4 -0
- package/esm2022/lib/components/substrate/utils/index.mjs +4 -0
- package/esm2022/lib/components/substrate/utils/rounded-rect-path.mjs +20 -0
- package/esm2022/lib/const/index.mjs +24 -5
- package/esm2022/lib/core/cache-map.mjs +154 -0
- package/esm2022/lib/core/track-box.mjs +913 -0
- package/esm2022/lib/core/tracker.mjs +201 -0
- package/esm2022/lib/directives/item-click/item-click.directive.mjs +3 -2
- package/esm2022/lib/directives/locale-sensitive/locale-sensitive.directive.mjs +3 -2
- package/esm2022/lib/enums/snapping-method.mjs +1 -1
- package/esm2022/lib/enums/snapping-methods.mjs +4 -8
- package/esm2022/lib/interfaces/animation-params.mjs +2 -0
- package/esm2022/lib/interfaces/base-virtual-list-item-component.mjs +9 -0
- package/esm2022/lib/interfaces/index.mjs +2 -0
- package/esm2022/lib/interfaces/rect.mjs +2 -0
- package/esm2022/lib/interfaces/render-stabilizer-options.mjs +2 -0
- package/esm2022/lib/interfaces/scroll-event.mjs +2 -0
- package/esm2022/lib/interfaces/scroll-options.mjs +2 -0
- package/esm2022/lib/interfaces/scroll-params.mjs +2 -0
- package/esm2022/lib/interfaces/size.mjs +2 -0
- package/esm2022/lib/models/display-object-measures.model.mjs +1 -1
- package/esm2022/lib/models/index.mjs +1 -1
- package/esm2022/lib/models/render-item-config.model.mjs +1 -1
- package/esm2022/lib/models/render-item-measures.model.mjs +1 -1
- package/esm2022/lib/ng-virtual-list.component.mjs +762 -593
- package/esm2022/lib/ng-virtual-list.module.mjs +5 -4
- package/esm2022/lib/ng-virtual-list.service.mjs +35 -17
- package/esm2022/lib/types/focus-item-params.mjs +2 -0
- package/esm2022/lib/types/index.mjs +1 -1
- package/esm2022/lib/types/scroll-direction.mjs +2 -0
- package/esm2022/lib/types/scrollbar-theme.mjs +1 -1
- package/esm2022/lib/utils/animator/animator.mjs +1 -7
- package/esm2022/lib/utils/debounce.mjs +11 -3
- package/esm2022/lib/utils/get-selector-by-item-id.mjs +5 -0
- package/esm2022/lib/utils/get-shape-min-size.mjs +1 -1
- package/esm2022/lib/utils/index.mjs +1 -1
- package/esm2022/lib/utils/list-validators.mjs +27 -0
- package/esm2022/lib/utils/screen-reader-formatter.mjs +43 -0
- package/esm2022/lib/utils/scroll-event.mjs +8 -5
- package/esm2022/lib/utils/snapping-method.mjs +2 -2
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ng-virtual-list.mjs +2279 -1151
- package/fesm2022/ng-virtual-list.mjs.map +1 -1
- package/lib/components/list-item/base/base-virtual-list-item-component.d.ts +56 -0
- package/lib/components/list-item/base/index.d.ts +2 -0
- package/lib/components/list-item/const/index.d.ts +1 -0
- package/lib/components/list-item/interfaces/index.d.ts +2 -0
- package/lib/components/list-item/interfaces/template-context.d.ts +10 -0
- package/lib/components/list-item/ng-virtual-list-item.component.d.ts +9 -51
- package/lib/components/list-item/utils/create-display-id.d.ts +1 -0
- package/lib/components/list-item/utils/index.d.ts +2 -1
- package/lib/components/ng-scroll-bar/const/index.d.ts +2 -0
- package/lib/components/ng-scroll-bar/ng-scroll-bar.component.d.ts +29 -30
- package/lib/components/ng-scroll-view/base/base-scroll-view.component.d.ts +60 -0
- package/lib/components/ng-scroll-view/const/index.d.ts +3 -0
- package/lib/components/ng-scroll-view/ng-scroll-view.component.d.ts +10 -48
- package/lib/components/ng-scroll-view/utils/calculate-direction.d.ts +4 -0
- package/lib/components/ng-scroll-view/utils/index.d.ts +3 -0
- package/lib/components/ng-scroll-view/utils/scroll-box.d.ts +39 -0
- package/lib/components/prerender-container/components/prerender-list/prerender-list.component.d.ts +63 -0
- package/lib/components/prerender-container/components/prerender-list/prerender-list.module.d.ts +10 -0
- package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.d.ts +17 -0
- package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.d.ts +9 -0
- package/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.d.ts +43 -0
- package/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.d.ts +9 -0
- package/lib/components/prerender-container/core/index.d.ts +2 -0
- package/lib/components/prerender-container/core/prerender-track-box.d.ts +35 -0
- package/lib/components/prerender-container/events/index.d.ts +6 -0
- package/lib/components/prerender-container/interfaces/index.d.ts +2 -0
- package/lib/components/prerender-container/interfaces/refresh-params.d.ts +16 -0
- package/lib/components/prerender-container/prerender-container.component.d.ts +40 -0
- package/lib/components/prerender-container/prerender-container.module.d.ts +9 -0
- package/lib/components/prerender-container/types/cache.d.ts +13 -0
- package/lib/components/prerender-container/types/index.d.ts +2 -0
- package/lib/components/scroller/const/index.d.ts +1 -0
- package/lib/components/scroller/ng-scroller.component.d.ts +43 -22
- package/lib/components/substrate/const/index.d.ts +2 -0
- package/lib/components/substrate/substrate.component.d.ts +27 -27
- package/lib/components/substrate/utils/circle-path.d.ts +1 -0
- package/lib/components/substrate/utils/index.d.ts +3 -0
- package/lib/components/substrate/utils/rounded-rect-path.d.ts +1 -0
- package/lib/const/index.d.ts +24 -5
- package/lib/{utils → core}/cache-map.d.ts +4 -4
- package/lib/{utils → core}/track-box.d.ts +17 -15
- package/lib/{utils → core}/tracker.d.ts +8 -6
- package/lib/directives/item-click/item-click.directive.d.ts +1 -1
- package/lib/directives/locale-sensitive/locale-sensitive.directive.d.ts +1 -1
- package/lib/enums/snapping-method.d.ts +3 -3
- package/lib/enums/snapping-methods.d.ts +4 -8
- package/lib/{types → interfaces}/animation-params.d.ts +4 -1
- package/lib/{models → interfaces}/base-virtual-list-item-component.d.ts +4 -3
- package/lib/interfaces/index.d.ts +9 -0
- package/lib/{types → interfaces}/rect.d.ts +1 -1
- package/lib/interfaces/render-stabilizer-options.d.ts +12 -0
- package/lib/{models/scroll-event.model.d.ts → interfaces/scroll-event.d.ts} +8 -4
- package/lib/{models/scroll-options.model.d.ts → interfaces/scroll-options.d.ts} +5 -1
- package/lib/interfaces/scroll-params.d.ts +16 -0
- package/lib/{types → interfaces}/size.d.ts +1 -1
- package/lib/models/display-object-measures.model.d.ts +1 -1
- package/lib/models/index.d.ts +1 -4
- package/lib/models/render-item-config.model.d.ts +4 -0
- package/lib/models/render-item-measures.model.d.ts +1 -1
- package/lib/ng-virtual-list.component.d.ts +76 -49
- package/lib/ng-virtual-list.module.d.ts +3 -2
- package/lib/ng-virtual-list.service.d.ts +24 -13
- package/lib/types/focus-item-params.d.ts +7 -0
- package/lib/types/index.d.ts +2 -4
- package/lib/{models/scroll-direction.model.d.ts → types/scroll-direction.d.ts} +1 -0
- package/lib/types/scrollbar-theme.d.ts +31 -4
- package/lib/utils/animator/animator.d.ts +0 -6
- package/lib/utils/debounce.d.ts +13 -8
- package/lib/utils/get-selector-by-item-id.d.ts +2 -0
- package/lib/utils/get-shape-min-size.d.ts +1 -1
- package/lib/utils/index.d.ts +2 -2
- package/lib/utils/list-validators.d.ts +2 -0
- package/lib/utils/screen-reader-formatter.d.ts +7 -0
- package/lib/utils/scroll-event.d.ts +8 -4
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/esm2022/lib/models/base-virtual-list-item-component.mjs +0 -9
- package/esm2022/lib/models/scroll-direction.model.mjs +0 -2
- package/esm2022/lib/models/scroll-event.model.mjs +0 -2
- package/esm2022/lib/models/scroll-options.model.mjs +0 -2
- package/esm2022/lib/types/animation-params.mjs +0 -2
- package/esm2022/lib/types/rect.mjs +0 -2
- package/esm2022/lib/types/size.mjs +0 -2
- package/esm2022/lib/utils/cache-map.mjs +0 -154
- package/esm2022/lib/utils/track-box.mjs +0 -924
- package/esm2022/lib/utils/tracker.mjs +0 -178
package/README.md
CHANGED
|
@@ -155,13 +155,13 @@ const HORIZONTAL_ITEMS: IVirtualListCollection<ICollectionItem> = Array.from({ l
|
|
|
155
155
|
export class AppComponent {
|
|
156
156
|
horizontalItems = HORIZONTAL_ITEMS;
|
|
157
157
|
|
|
158
|
-
onItemClick(item: IRenderVirtualListItem<ICollectionItem> |
|
|
158
|
+
onItemClick(item: IRenderVirtualListItem<ICollectionItem> | null) {
|
|
159
159
|
if (item) {
|
|
160
160
|
console.info(`Click: (ID: ${item.id}) Item ${item.data.name}`);
|
|
161
161
|
}
|
|
162
162
|
}
|
|
163
163
|
|
|
164
|
-
onSelect(data: Array<Id> | Id |
|
|
164
|
+
onSelect(data: Array<Id> | Id | null) {
|
|
165
165
|
console.info(`Select: ${JSON.stringify(data)}`);
|
|
166
166
|
}
|
|
167
167
|
}
|
|
@@ -229,13 +229,13 @@ export class AppComponent {
|
|
|
229
229
|
horizontalGroupItems = HORIZONTAL_GROUP_ITEMS;
|
|
230
230
|
horizontalGroupItemConfigMap = HORIZONTAL_GROUP_ITEM_CONFIG_MAP;
|
|
231
231
|
|
|
232
|
-
onItemClick(item: IRenderVirtualListItem<ICollectionItem> |
|
|
232
|
+
onItemClick(item: IRenderVirtualListItem<ICollectionItem> | null) {
|
|
233
233
|
if (item) {
|
|
234
234
|
console.info(`Click: (ID: ${item.id}) Item ${item.data.name}`);
|
|
235
235
|
}
|
|
236
236
|
}
|
|
237
237
|
|
|
238
|
-
onSelect(data: Array<Id> | Id |
|
|
238
|
+
onSelect(data: Array<Id> | Id | null) {
|
|
239
239
|
console.info(`Select: ${JSON.stringify(data)}`);
|
|
240
240
|
}
|
|
241
241
|
}
|
|
@@ -518,9 +518,9 @@ import { NgVirtualListComponent, GradientColor, RoundedCorner, ScrollBarTheme }
|
|
|
518
518
|
const X_LITE_BLUE_PLASMA_GRADIENT: GradientColor = ["rgba(133, 142, 255, 0)", "rgb(0, 133, 160)"],
|
|
519
519
|
ROUND_CORNER: RoundedCorner = [3, 3, 3, 3],
|
|
520
520
|
SCROLLBAR_GRADIENT: ScrollBarTheme = {
|
|
521
|
-
fill:
|
|
522
|
-
hoverFill:
|
|
523
|
-
pressedFill:
|
|
521
|
+
fill: "rgba(51, 0, 97, 1)",
|
|
522
|
+
hoverFill: "rgba(73, 6, 133, 1)",
|
|
523
|
+
pressedFill: "rgba(73, 6, 150, 1)",
|
|
524
524
|
strokeGradientColor: X_LITE_BLUE_PLASMA_GRADIENT,
|
|
525
525
|
strokeAnimationDuration: 1000,
|
|
526
526
|
thickness: 6,
|
|
@@ -543,8 +543,23 @@ export class AppComponent {
|
|
|
543
543
|
|
|
544
544
|
```
|
|
545
545
|
|
|
546
|
+
```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
|
+
}
|
|
558
|
+
}
|
|
559
|
+
```
|
|
560
|
+
|
|
546
561
|
```html
|
|
547
|
-
<ng-virtual-list [scrollbarTheme]="scrollbarTheme" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
|
|
562
|
+
<ng-virtual-list class="list" [scrollbarTheme]="scrollbarTheme" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
|
|
548
563
|
|
|
549
564
|
<ng-template #horizontalItemRenderer let-data="data" let-config="config">
|
|
550
565
|
@if (data) {
|
|
@@ -647,41 +662,42 @@ Inputs
|
|
|
647
662
|
|
|
648
663
|
| Property | Type | Description |
|
|
649
664
|
|---|---|---|
|
|
650
|
-
|
|
|
651
|
-
| items | [IVirtualListCollection](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/collection.model.ts) | Collection of list items. The collection of elements must be immutable. |
|
|
652
|
-
| itemSize | number? = 24 | If direction = 'vertical', then the height of a typical element. If direction = 'horizontal', then the width of a typical element. If the dynamicSize property is true, the items in the list can have different sizes, and you must specify the itemSize property to adjust the sizes of the items in the unallocated area. |
|
|
665
|
+
| animationParams | [IAnimationParams](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/animation-params.ts)? = { scrollToItem: 50, navigateToItem: 150, navigateByKeyboard: 50 } | Animation parameters. The default value is "{ scrollToItem: 50, navigateToItem: 150, , navigateByKeyboard: 50 }". |
|
|
653
666
|
| bufferSize | number? = 2 | Number of elements outside the scope of visibility. Default value is 2. |
|
|
654
667
|
| maxBufferSize | number? = 10 | Maximum number of elements outside the scope of visibility. Default value is 10. If maxBufferSize is set to be greater than bufferSize, then adaptive buffer mode is enabled. The greater the scroll size, the more elements are allocated for rendering. |
|
|
655
|
-
|
|
|
656
|
-
| methodForSelecting | [MethodForSelecting](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/method-for-selecting.ts) | Method for selecting list items. Default value is 'none'. 'select' - List items are selected one by one. 'multi-select' - Multiple selection of list items. 'none' - List items are not selectable. |
|
|
657
|
-
| itemConfigMap | [IVirtualListItemConfigMap?](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/item-config-map.model.ts) | Sets `sticky` position and `selectable` for the list item element. If `sticky` position is greater than `0`, then `sticky` position is applied. If the `sticky` value is greater than `0`, then the `sticky` position mode is enabled for the element. `1` - position start, `2` - position end. Default value is `0`. `selectable` determines whether an element can be selected or not. Default value is `true`. |
|
|
668
|
+
| collapsedIds | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)> | Sets the collapsed items. |
|
|
658
669
|
| collapseByClick | boolean? = true | If `false`, the element is collapsed using the config.collapse method passed to the template; if `true`, the element is collapsed by clicking on it. The default value is `true`. |
|
|
659
670
|
| collectionMode | [CollectionMode? = 'normal'](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/collection-mode.ts) | Determines the action modes for collection elements. Default value is `normal`. |
|
|
660
|
-
| selectByClick | boolean? = true | If `false`, the element is selected using the config.select method passed to the template; if `true`, the element is selected by clicking on it. The default value is `true`. |
|
|
661
|
-
| snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
|
|
662
|
-
| snappingMethod | [SnappingMethod? = 'normal'](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/snapping-method.ts) | Snapping method. 'normal' - Normal group rendering. 'advanced' - The group is rendered on a transparent background. 'chat' - The group is rendered on a background. List items below the group are not rendered. |
|
|
663
671
|
| direction | [Direction? = 'vertical'](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/direction.ts) | Determines the direction in which elements are placed. Default value is "vertical". |
|
|
664
672
|
| dynamicSize | boolean? = true | If true, items in the list may have different sizes, and the itemSize property must be specified to adjust the sizes of items in the unallocated area. If false then the items in the list have a fixed size specified by the itemSize property. The default value is true. |
|
|
665
673
|
| enabledBufferOptimization | boolean? = true | Experimental! Enables buffer optimization. Can only be used if items in the collection are not added or updated. |
|
|
666
|
-
|
|
|
667
|
-
|
|
|
668
|
-
|
|
|
669
|
-
|
|
|
674
|
+
| id | number | Readonly. Returns the unique identifier of the component. |
|
|
675
|
+
| items | [IVirtualListCollection](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/collection.model.ts) | Collection of list items. The collection of elements must be immutable. |
|
|
676
|
+
| itemSize | number? = 24 | If direction = 'vertical', then the height of a typical element. If direction = 'horizontal', then the width of a typical element. If the dynamicSize property is true, the items in the list can have different sizes, and you must specify the itemSize property to adjust the sizes of the items in the unallocated area. |
|
|
677
|
+
| itemRenderer | TemplateRef | Rendering element template. |
|
|
678
|
+
| itemConfigMap | [IVirtualListItemConfigMap?](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/item-config-map.model.ts) | Sets `sticky` position and `selectable` for the list item element. If `sticky` position is greater than `0`, then `sticky` position is applied. If the `sticky` value is greater than `0`, then the `sticky` position mode is enabled for the element. `1` - position start, `2` - position end. Default value is `0`. `selectable` determines whether an element can be selected or not. Default value is `true`. |
|
|
679
|
+
| methodForSelecting | [MethodForSelecting](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/method-for-selecting.ts) | Method for selecting list items. Default value is 'none'. 'select' - List items are selected one by one. 'multi-select' - Multiple selection of list items. 'none' - List items are not selectable. |
|
|
670
680
|
| langTextDir | [TextDirection? = 'ltr'](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/text-direction.ts) | A string indicating the direction of text for the locale. Can be either "ltr" (left-to-right) or "rtl" (right-to-left). |
|
|
671
681
|
| loading | boolean? = false | If `true`, the scrollBar goes into loading state. The default value is `false`. |
|
|
672
|
-
|
|
|
682
|
+
| overscrollEnabled | boolean? = true | Determines whether the overscroll (re-scroll) feature will work. The default value is "true". |
|
|
683
|
+
| selectByClick | boolean? = true | If `false`, the element is selected using the config.select method passed to the template; if `true`, the element is selected by clicking on it. The default value is `true`. |
|
|
684
|
+
| snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
|
|
685
|
+
| selectedIds | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts) \| null | Sets the selected items. |
|
|
686
|
+
| 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/17.x/projects/ng-virtual-list/src/lib/types/scrollbar-theme.ts) | Scrollbar theme. |
|
|
673
688
|
| clickDistance | number? = 40 | The maximum scroll distance at which a click event is triggered. |
|
|
674
689
|
| waitForPreparation | boolean? = true | If true, it will wait until the list items are fully prepared before displaying them.. The default value is `true`. |
|
|
675
690
|
| scrollStartOffset | number? = 0 | Sets the scroll start offset value; Default value is "0". |
|
|
676
691
|
| scrollEndOffset | number? = 0 | Sets the scroll end offset value; Default value is "0". |
|
|
677
|
-
|
|
|
692
|
+
| snappingMethod | [SnappingMethod](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/snapping-method.ts) | Snapping method. Default value is [SnappingMethods.STANDART](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/snapping-method.ts). [SnappingMethods.STANDART](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/snapping-method.ts) - Classic group visualization. [SnappingMethods.ADVANCED](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/snapping-method.ts) - A mask is applied to the viewport area so that the background is displayed underneath the attached group. |
|
|
693
|
+
| 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
|
+
| 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. |
|
|
678
695
|
| snapToEndTransitionInstantOffset | number? = 0 | Sets the offset value; if the scroll area value is exceeded, the scroll animation will be disabled. Default value is "0". |
|
|
679
696
|
| scrollbarMinSize | number? = 80 | Minimum scrollbar size. |
|
|
680
697
|
| scrollbarEnabled | boolean? = true | Determines whether the scrollbar is shown or not. The default value is "true". |
|
|
681
698
|
| scrollbarInteractive | boolean? = true | Determines whether scrolling using the scrollbar will be possible. The default value is "true". |
|
|
682
|
-
| overscrollEnabled | boolean? = true | Determines whether the overscroll (re-scroll) feature will work. The default value is "true". |
|
|
683
|
-
| animationParams | [IAnimationParams](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/animation-params.ts)? = { scrollToItem: 50, navigateToItem: 150 } | Animation parameters. The default value is "{ scrollToItem: 50, navigateToItem: 150 }". |
|
|
684
699
|
| scrollBehavior | ScrollBehavior? = 'smooth' | Defines the scrolling behavior for any element on the page. The default value is "smooth". |
|
|
700
|
+
| trackBy | string? = 'id' | The name of the property by which tracking is performed. |
|
|
685
701
|
|
|
686
702
|
<br/>
|
|
687
703
|
|
|
@@ -689,12 +705,12 @@ Outputs
|
|
|
689
705
|
|
|
690
706
|
| Event | Type | Description |
|
|
691
707
|
|---|---|---|
|
|
692
|
-
| onItemClick | [IRenderVirtualListItem](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/render-item.model.ts) \|
|
|
693
|
-
| onScroll | ([IScrollEvent](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/
|
|
694
|
-
| onScrollEnd | ([IScrollEvent](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/
|
|
695
|
-
| onSelect | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts) \|
|
|
696
|
-
| onCollapse | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts) \|
|
|
697
|
-
| onViewportChange | [ISize](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/
|
|
708
|
+
| onItemClick | [IRenderVirtualListItem](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/render-item.model.ts) \| null | Fires when an element is clicked. |
|
|
709
|
+
| onScroll | ([IScrollEvent](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/scroll-event.ts)) => void | Fires when the list has been scrolled. |
|
|
710
|
+
| onScrollEnd | ([IScrollEvent](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/scroll-event.ts)) => void | Fires when the list has completed scrolling. |
|
|
711
|
+
| onSelect | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts) \| null | Fires when an elements are selected. |
|
|
712
|
+
| onCollapse | Array<[Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)> \| [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts) \| null | Fires when elements are collapsed. |
|
|
713
|
+
| onViewportChange | [ISize](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/size.ts) | Fires when the viewport size is changed. |
|
|
698
714
|
| onScrollReachStart | void | Fires when the scroll reaches the start. |
|
|
699
715
|
| onScrollReachEnd | void | Fires when the scroll reaches the end. |
|
|
700
716
|
|
|
@@ -704,13 +720,12 @@ Methods
|
|
|
704
720
|
|
|
705
721
|
| Method | Type | Description |
|
|
706
722
|
|--|--|--|
|
|
707
|
-
| scrollTo | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts), cb
|
|
708
|
-
| scrollToStart | (cb
|
|
709
|
-
|
|
|
710
|
-
|
|
|
711
|
-
| getItemBounds | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts), behavior?: ScrollBehavior) => void | Returns the bounds of an element with a given id |
|
|
723
|
+
| scrollTo | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts), (cb: () => void) \| null = null, options: [IScrollOptions](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/scroll-options.ts) \| null = null) | The method scrolls the list to the element with the given `id` and returns the value of the scrolled area. |
|
|
724
|
+
| scrollToStart | (cb: (() => void) \| null = null, options: [IScrollOptions](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/scroll-options.ts) \| null = null) | Scrolls the scroll area to the first item in the collection. |
|
|
725
|
+
| scrollToEnd | (cb: (() => void) \| null = null, options: [IScrollOptions](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/scroll-options.ts) \| null = null) | Scrolls the list to the end of the content height. |
|
|
726
|
+
| getItemBounds | (id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts)) => [ISize \| null](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/interfaces/size.ts) | Returns the bounds of an element with a given id |
|
|
712
727
|
| focus | [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts), align: [FocusAlignment](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/focus-alignment.ts) = [FocusAlignments.NONE](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/enums/focus-alignments.ts) | Focus an list item by a given id. |
|
|
713
|
-
|
|
|
728
|
+
| preventSnapping | | Prevents the list from snapping to its start or end edge. |
|
|
714
729
|
|
|
715
730
|
<br/>
|
|
716
731
|
|
|
@@ -728,7 +743,7 @@ Properties
|
|
|
728
743
|
|--|--|--|
|
|
729
744
|
| data | {\[id: [Id](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/types/id.ts) \], [otherProps: string]: any;} | Collection item data. |
|
|
730
745
|
| config | [IDisplayObjectConfig](https://github.com/DjonnyX/ng-virtual-list/blob/17.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. |
|
|
731
|
-
| measures | [IDisplayObjectMeasures](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/display-object-measures.model.ts) \|
|
|
746
|
+
| measures | [IDisplayObjectMeasures](https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/models/display-object-measures.model.ts) \| null | Display object metrics. |
|
|
732
747
|
|
|
733
748
|
<br/>
|
|
734
749
|
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
import { ChangeDetectorRef, computed, DestroyRef, ElementRef, inject, signal } from '@angular/core';
|
|
2
|
+
import { DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN, PART_ITEM_FOCUSED, PART_ITEM_NEW, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, PX, SIZE_100_PERSENT, SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE, } from '../../../const';
|
|
3
|
+
import { CLASS_NAME_FOCUS, CLASS_NAME_SNAPPED, CLASS_NAME_SNAPPED_OUT, ID, ITEM_ID, POSITION, POSITION_ZERO, TRANSLATE_3D_HIDDEN, } from '../const';
|
|
4
|
+
import { TextDirections } from '../../../enums';
|
|
5
|
+
const EMPTY_HANDLER = () => { };
|
|
6
|
+
/**
|
|
7
|
+
* BaseVirtualListItemComponent
|
|
8
|
+
* @link https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/components/list-item/base//base-virtual-list-item-component.ts
|
|
9
|
+
* @author Evgenii Alexandrovich Grebennikov
|
|
10
|
+
* @email djonnyx@gmail.com
|
|
11
|
+
*/
|
|
12
|
+
export class BaseVirtualListItemComponent {
|
|
13
|
+
_cdr = inject(ChangeDetectorRef);
|
|
14
|
+
_id;
|
|
15
|
+
get id() {
|
|
16
|
+
return this._id;
|
|
17
|
+
}
|
|
18
|
+
_listId;
|
|
19
|
+
get listId() {
|
|
20
|
+
return this._listId;
|
|
21
|
+
}
|
|
22
|
+
_displayId;
|
|
23
|
+
get displayId() {
|
|
24
|
+
return this._displayId;
|
|
25
|
+
}
|
|
26
|
+
_isSelected = false;
|
|
27
|
+
_isCollapsed = false;
|
|
28
|
+
config = signal({});
|
|
29
|
+
measures = signal(null);
|
|
30
|
+
focused = signal(false);
|
|
31
|
+
part = signal(PART_DEFAULT_ITEM);
|
|
32
|
+
data = signal(null);
|
|
33
|
+
_data = null;
|
|
34
|
+
set item(v) {
|
|
35
|
+
if (this._data === v || this._data?.id === -1 || !v) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
this._data = v;
|
|
39
|
+
this.updatePartStr(v, this._isSelected, this._isCollapsed);
|
|
40
|
+
this.updateConfig(v);
|
|
41
|
+
this.updateMeasures(v);
|
|
42
|
+
this.update();
|
|
43
|
+
this.data.set(v);
|
|
44
|
+
this._cdr.markForCheck();
|
|
45
|
+
}
|
|
46
|
+
classes;
|
|
47
|
+
index;
|
|
48
|
+
templateContext;
|
|
49
|
+
regular = false;
|
|
50
|
+
_scrollBarSize = 0;
|
|
51
|
+
_langTextDir = TextDirections.LTR;
|
|
52
|
+
_regularLength = SIZE_100_PERSENT;
|
|
53
|
+
set regularLength(v) {
|
|
54
|
+
if (this._regularLength === v) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
this._regularLength = v;
|
|
58
|
+
this.update();
|
|
59
|
+
this._cdr.markForCheck();
|
|
60
|
+
}
|
|
61
|
+
get item() {
|
|
62
|
+
return this._data;
|
|
63
|
+
}
|
|
64
|
+
get itemId() {
|
|
65
|
+
return this._data?.id;
|
|
66
|
+
}
|
|
67
|
+
itemRenderer = signal(undefined);
|
|
68
|
+
_renderer;
|
|
69
|
+
set renderer(v) {
|
|
70
|
+
if (this._renderer !== v) {
|
|
71
|
+
this._renderer = v;
|
|
72
|
+
this.itemRenderer.set(v);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
_elementRef = inject(ElementRef);
|
|
76
|
+
get element() {
|
|
77
|
+
return this._elementRef.nativeElement;
|
|
78
|
+
}
|
|
79
|
+
_destroyRef = inject(DestroyRef);
|
|
80
|
+
constructor() {
|
|
81
|
+
this.classes = computed(() => {
|
|
82
|
+
const data = this.data(), focused = this.focused();
|
|
83
|
+
return {
|
|
84
|
+
[CLASS_NAME_SNAPPED]: data?.config?.snapped ?? false, [CLASS_NAME_SNAPPED_OUT]: data?.config?.snappedOut ?? false,
|
|
85
|
+
[CLASS_NAME_FOCUS]: focused,
|
|
86
|
+
};
|
|
87
|
+
});
|
|
88
|
+
this.index = computed(() => {
|
|
89
|
+
return this.config()?.tabIndex ?? -1;
|
|
90
|
+
});
|
|
91
|
+
this.templateContext = computed(() => {
|
|
92
|
+
const data = this.data(), measures = this.measures(), config = this.config();
|
|
93
|
+
return {
|
|
94
|
+
data: data?.data, prevData: data?.previouseData, nextData: data?.nextData, measures,
|
|
95
|
+
config, reseted: false, index: data?.index ?? -1,
|
|
96
|
+
};
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
updateMeasures(v) {
|
|
100
|
+
this.measures.set(v?.measures ? { ...v.measures } : null);
|
|
101
|
+
}
|
|
102
|
+
updateConfig(v) {
|
|
103
|
+
this.config.set({
|
|
104
|
+
...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),
|
|
105
|
+
collapse: EMPTY_HANDLER, select: EMPTY_HANDLER, focus: EMPTY_HANDLER,
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
update() {
|
|
109
|
+
const data = this._data, regular = this.regular, length = this._regularLength, el = this._elementRef.nativeElement;
|
|
110
|
+
if (data) {
|
|
111
|
+
el.setAttribute(ITEM_ID, `${data.id}`);
|
|
112
|
+
const styles = el.style;
|
|
113
|
+
styles.zIndex = data.config.zIndex;
|
|
114
|
+
styles.position = POSITION_ABSOLUTE;
|
|
115
|
+
if (data.config.isStub === true) {
|
|
116
|
+
el.style.visibility = VISIBILITY_HIDDEN;
|
|
117
|
+
}
|
|
118
|
+
if (regular) {
|
|
119
|
+
el.setAttribute(POSITION, POSITION_ZERO);
|
|
120
|
+
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})`;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
el.setAttribute(POSITION, `${data.config.isVertical ? data.measures.y : data.measures.x}`);
|
|
124
|
+
styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX}, ${POSITION_ZERO})`;
|
|
125
|
+
}
|
|
126
|
+
styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;
|
|
127
|
+
styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
el.removeAttribute(ID);
|
|
131
|
+
}
|
|
132
|
+
this._cdr.markForCheck();
|
|
133
|
+
}
|
|
134
|
+
updatePartStr(v, isSelected, isCollapsed) {
|
|
135
|
+
let odd = false;
|
|
136
|
+
if (v?.index !== undefined) {
|
|
137
|
+
odd = v.index % 2 === 0;
|
|
138
|
+
}
|
|
139
|
+
let part = PART_DEFAULT_ITEM;
|
|
140
|
+
part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;
|
|
141
|
+
if (v ? v.config.snapped : false) {
|
|
142
|
+
part += PART_ITEM_SNAPPED;
|
|
143
|
+
}
|
|
144
|
+
if (isSelected) {
|
|
145
|
+
part += PART_ITEM_SELECTED;
|
|
146
|
+
}
|
|
147
|
+
if (isCollapsed) {
|
|
148
|
+
part += PART_ITEM_COLLAPSED;
|
|
149
|
+
}
|
|
150
|
+
if (v ? v.config.new : false) {
|
|
151
|
+
part += PART_ITEM_NEW;
|
|
152
|
+
}
|
|
153
|
+
if (this.focused()) {
|
|
154
|
+
part += PART_ITEM_FOCUSED;
|
|
155
|
+
}
|
|
156
|
+
this.part.set(part);
|
|
157
|
+
}
|
|
158
|
+
getBounds() {
|
|
159
|
+
const el = this._elementRef.nativeElement, { width, height } = el.getBoundingClientRect();
|
|
160
|
+
return { width: width > 0 ? width : 1, height: height > 0 ? height : 1, };
|
|
161
|
+
}
|
|
162
|
+
show() {
|
|
163
|
+
const el = this._elementRef.nativeElement, styles = el.style;
|
|
164
|
+
styles.zIndex = this._data?.config?.zIndex ?? DEFAULT_ZINDEX;
|
|
165
|
+
if (this.regular) {
|
|
166
|
+
if (styles.display === DISPLAY_BLOCK) {
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
styles.display = DISPLAY_BLOCK;
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
const isStub = this._data?.config?.isStub ?? false;
|
|
173
|
+
if (!isStub) {
|
|
174
|
+
if (styles.visibility === VISIBILITY_VISIBLE) {
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
styles.visibility = VISIBILITY_VISIBLE;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
hide() {
|
|
182
|
+
const el = this._elementRef.nativeElement, styles = el.style;
|
|
183
|
+
styles.position = POSITION_ABSOLUTE;
|
|
184
|
+
styles.transform = TRANSLATE_3D_HIDDEN;
|
|
185
|
+
styles.zIndex = HIDDEN_ZINDEX;
|
|
186
|
+
if (this.regular) {
|
|
187
|
+
if (styles.display === DISPLAY_NONE) {
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
190
|
+
styles.display = DISPLAY_NONE;
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
if (styles.visibility === VISIBILITY_HIDDEN) {
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
styles.visibility = VISIBILITY_HIDDEN;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
//# 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 { ChangeDetectorRef, computed, DestroyRef, ElementRef, inject, Signal, signal, TemplateRef } from '@angular/core';\r\nimport { ISize } from '../../../interfaces';\r\nimport { IRenderVirtualListItem } from '../../../models/render-item.model';\r\nimport { IDisplayObjectConfig, IDisplayObjectMeasures } from '../../../models';\r\nimport {\r\n  DEFAULT_ZINDEX, DISPLAY_BLOCK, DISPLAY_NONE, HIDDEN_ZINDEX, PART_DEFAULT_ITEM, PART_ITEM_COLLAPSED, PART_ITEM_EVEN,\r\n  PART_ITEM_FOCUSED, PART_ITEM_NEW, PART_ITEM_ODD, PART_ITEM_SELECTED, PART_ITEM_SNAPPED, POSITION_ABSOLUTE, PX, SIZE_100_PERSENT,\r\n  SIZE_AUTO, TRANSLATE_3D, VISIBILITY_HIDDEN, VISIBILITY_VISIBLE,\r\n} from '../../../const';\r\nimport { ITemplateContext } from '../interfaces';\r\nimport {\r\n  CLASS_NAME_FOCUS, CLASS_NAME_SNAPPED, CLASS_NAME_SNAPPED_OUT, ID, ITEM_ID, POSITION, POSITION_ZERO, TRANSLATE_3D_HIDDEN,\r\n} from '../const';\r\nimport { TextDirection, TextDirections } from '../../../enums';\r\n\r\nconst EMPTY_HANDLER = () => { };\r\n\r\n/**\r\n * BaseVirtualListItemComponent\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/17.x/projects/ng-virtual-list/src/lib/components/list-item/base//base-virtual-list-item-component.ts\r\n * @author Evgenii Alexandrovich Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\nexport class BaseVirtualListItemComponent {\r\n  private _cdr = inject(ChangeDetectorRef);\r\n\r\n  protected _id!: number;\r\n  get id() {\r\n    return this._id;\r\n  }\r\n\r\n  protected _listId!: number;\r\n  get listId() {\r\n    return this._listId;\r\n  }\r\n\r\n  protected _displayId!: string;\r\n  get displayId() {\r\n    return this._displayId;\r\n  }\r\n\r\n  protected _isSelected: boolean = false;\r\n\r\n  protected _isCollapsed: boolean = false;\r\n\r\n  protected readonly config = signal<IDisplayObjectConfig>({} as IDisplayObjectConfig);\r\n\r\n  protected readonly measures = signal<IDisplayObjectMeasures | null>(null);\r\n\r\n  protected readonly focused = signal<boolean>(false);\r\n\r\n  protected readonly part = signal<string>(PART_DEFAULT_ITEM);\r\n\r\n  protected readonly data = signal<IRenderVirtualListItem | null>(null);\r\n  protected _data: IRenderVirtualListItem | null = null;\r\n  set item(v: IRenderVirtualListItem | null) {\r\n    if (this._data === v || this._data?.id === -1 || !v) {\r\n      return;\r\n    }\r\n\r\n    this._data = v;\r\n\r\n    this.updatePartStr(v, this._isSelected, this._isCollapsed);\r\n\r\n    this.updateConfig(v);\r\n\r\n    this.updateMeasures(v);\r\n\r\n    this.update();\r\n\r\n    this.data.set(v);\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  protected readonly classes!: Signal<{ [cName: string]: boolean; }>;\r\n\r\n  protected readonly index!: Signal<number>;\r\n\r\n  protected readonly templateContext!: Signal<ITemplateContext>;\r\n\r\n  public regular: boolean = false;\r\n\r\n  protected _scrollBarSize: number = 0;\r\n\r\n  protected _langTextDir: TextDirection = TextDirections.LTR;\r\n\r\n  protected _regularLength: string = SIZE_100_PERSENT;\r\n  set regularLength(v: string) {\r\n    if (this._regularLength === v) {\r\n      return;\r\n    }\r\n\r\n    this._regularLength = v;\r\n\r\n    this.update();\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  get item() {\r\n    return this._data;\r\n  }\r\n\r\n  get itemId() {\r\n    return this._data?.id;\r\n  }\r\n\r\n  protected readonly itemRenderer = signal<TemplateRef<any> | undefined>(undefined);\r\n\r\n  protected _renderer: TemplateRef<any> | undefined;\r\n  set renderer(v: TemplateRef<any> | undefined) {\r\n    if (this._renderer !== v) {\r\n      this._renderer = v;\r\n      this.itemRenderer.set(v);\r\n    }\r\n  }\r\n\r\n  protected _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\r\n  get element() {\r\n    return this._elementRef.nativeElement;\r\n  }\r\n\r\n  protected _destroyRef = inject(DestroyRef);\r\n\r\n  constructor() {\r\n    this.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    this._cdr.markForCheck();\r\n  }\r\n\r\n  protected updatePartStr(v: IRenderVirtualListItem | null, isSelected: boolean, isCollapsed: boolean) {\r\n    let odd = false;\r\n    if (v?.index !== undefined) {\r\n      odd = v.index % 2 === 0;\r\n    }\r\n\r\n    let part = PART_DEFAULT_ITEM;\r\n    part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;\r\n    if (v ? v.config.snapped : false) {\r\n      part += PART_ITEM_SNAPPED;\r\n    }\r\n    if (isSelected) {\r\n      part += PART_ITEM_SELECTED;\r\n    }\r\n    if (isCollapsed) {\r\n      part += PART_ITEM_COLLAPSED;\r\n    }\r\n    if (v ? v.config.new : false) {\r\n      part += PART_ITEM_NEW;\r\n    }\r\n    if (this.focused()) {\r\n      part += PART_ITEM_FOCUSED;\r\n    }\r\n    this.part.set(part);\r\n  }\r\n\r\n  getBounds(): ISize {\r\n    const el: HTMLElement = this._elementRef.nativeElement,\r\n      { width, height } = el.getBoundingClientRect();\r\n    return { width: width > 0 ? width : 1, height: height > 0 ? height : 1, };\r\n  }\r\n\r\n  show() {\r\n    const el = this._elementRef.nativeElement as HTMLElement,\r\n      styles = el.style;\r\n    styles.zIndex = this._data?.config?.zIndex ?? DEFAULT_ZINDEX;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_BLOCK) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_BLOCK;\r\n    } else {\r\n      const isStub = this._data?.config?.isStub ?? false;\r\n      if (!isStub) {\r\n        if (styles.visibility === VISIBILITY_VISIBLE) {\r\n          return;\r\n        }\r\n        styles.visibility = VISIBILITY_VISIBLE;\r\n      }\r\n    }\r\n  }\r\n\r\n  hide() {\r\n    const el = this._elementRef.nativeElement,\r\n      styles = el.style;\r\n    styles.position = POSITION_ABSOLUTE;\r\n    styles.transform = TRANSLATE_3D_HIDDEN;\r\n    styles.zIndex = HIDDEN_ZINDEX;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_NONE) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_NONE;\r\n    } else {\r\n      if (styles.visibility === VISIBILITY_HIDDEN) {\r\n        return;\r\n      }\r\n\r\n      styles.visibility = VISIBILITY_HIDDEN;\r\n    }\r\n  }\r\n}"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { BaseVirtualListItemComponent } from './base-virtual-list-item-component';
|
|
2
|
+
export { BaseVirtualListItemComponent, };
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9iYXNlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRWxGLE9BQU8sRUFDSCw0QkFBNEIsR0FDL0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2Jhc2UtdmlydHVhbC1saXN0LWl0ZW0tY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBCYXNlVmlydHVhbExpc3RJdGVtQ29tcG9uZW50LFxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const ID = 'id', TRANSLATE_3D_HIDDEN = 'translate3d(-1000px,-1000px,0)', ATTR_AREA_SELECTED = 'area-selected', POSITION = 'position', POSITION_ZERO = '0', ITEM_ID = 'item-id', KEY_SPACE = ' ', KEY_ARR_LEFT = 'ArrowLeft', KEY_ARR_UP = 'ArrowUp', KEY_ARR_RIGHT = 'ArrowRight', KEY_ARR_DOWN = 'ArrowDown', EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown', CLASS_NAME_SNAPPED = 'snapped', CLASS_NAME_SNAPPED_OUT = 'snapped-out', CLASS_NAME_FOCUS = 'focus';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9jb25zdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxFQUNsQixtQkFBbUIsR0FBRyxnQ0FBZ0MsRUFDdEQsa0JBQWtCLEdBQUcsZUFBZSxFQUNwQyxRQUFRLEdBQUcsVUFBVSxFQUNyQixhQUFhLEdBQUcsR0FBRyxFQUNuQixPQUFPLEdBQUcsU0FBUyxFQUNuQixTQUFTLEdBQUcsR0FBRyxFQUNmLFlBQVksR0FBRyxXQUFXLEVBQzFCLFVBQVUsR0FBRyxTQUFTLEVBQ3RCLGFBQWEsR0FBRyxZQUFZLEVBQzVCLFlBQVksR0FBRyxXQUFXLEVBQzFCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGVBQWUsR0FBRyxVQUFVLEVBQzVCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGtCQUFrQixHQUFHLFNBQVMsRUFDOUIsc0JBQXNCLEdBQUcsYUFBYSxFQUN0QyxnQkFBZ0IsR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgSUQgPSAnaWQnLFxyXG4gICAgVFJBTlNMQVRFXzNEX0hJRERFTiA9ICd0cmFuc2xhdGUzZCgtMTAwMHB4LC0xMDAwcHgsMCknLFxyXG4gICAgQVRUUl9BUkVBX1NFTEVDVEVEID0gJ2FyZWEtc2VsZWN0ZWQnLFxyXG4gICAgUE9TSVRJT04gPSAncG9zaXRpb24nLFxyXG4gICAgUE9TSVRJT05fWkVSTyA9ICcwJyxcclxuICAgIElURU1fSUQgPSAnaXRlbS1pZCcsXHJcbiAgICBLRVlfU1BBQ0UgPSAnICcsXHJcbiAgICBLRVlfQVJSX0xFRlQgPSAnQXJyb3dMZWZ0JyxcclxuICAgIEtFWV9BUlJfVVAgPSAnQXJyb3dVcCcsXHJcbiAgICBLRVlfQVJSX1JJR0hUID0gJ0Fycm93UmlnaHQnLFxyXG4gICAgS0VZX0FSUl9ET1dOID0gJ0Fycm93RG93bicsXHJcbiAgICBFVkVOVF9GT0NVU19JTiA9ICdmb2N1c2luJyxcclxuICAgIEVWRU5UX0ZPQ1VTX09VVCA9ICdmb2N1c291dCcsXHJcbiAgICBFVkVOVF9LRVlfRE9XTiA9ICdrZXlkb3duJyxcclxuICAgIENMQVNTX05BTUVfU05BUFBFRCA9ICdzbmFwcGVkJyxcclxuICAgIENMQVNTX05BTUVfU05BUFBFRF9PVVQgPSAnc25hcHBlZC1vdXQnLFxyXG4gICAgQ0xBU1NfTkFNRV9GT0NVUyA9ICdmb2N1cyc7XHJcblxyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJVGVtcGxhdGVDb250ZXh0IH0gZnJvbSAnLi90ZW1wbGF0ZS1jb250ZXh0JztcclxuXHJcbmV4cG9ydCB0eXBlIHtcclxuICAgIElUZW1wbGF0ZUNvbnRleHQsXHJcbn1cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbGlzdC1pdGVtL2ludGVyZmFjZXMvdGVtcGxhdGUtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSURpc3BsYXlPYmplY3RDb25maWcsIElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfSBmcm9tIFwiLi4vLi4vLi4vbW9kZWxzXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElUZW1wbGF0ZUNvbnRleHQ8RCA9IGFueT4ge1xyXG4gICAgZGF0YTogRDtcclxuICAgIHByZXZEYXRhOiBEO1xyXG4gICAgbmV4dERhdGE6IEQ7XHJcbiAgICBtZWFzdXJlczogSURpc3BsYXlPYmplY3RNZWFzdXJlcyB8IG51bGw7XHJcbiAgICBjb25maWc6IElEaXNwbGF5T2JqZWN0Q29uZmlnO1xyXG4gICAgcmVzZXRlZDogYm9vbGVhbjtcclxuICAgIGluZGV4OiBudW1iZXI7XHJcbn0iXX0=
|