ng-virtual-list 18.10.7 → 18.11.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +22 -80
- package/esm2022/lib/components/ng-list-item/base/base-virtual-list-item-component.mjs +200 -0
- package/esm2022/lib/components/ng-list-item/base/index.mjs +3 -0
- package/esm2022/lib/components/ng-list-item/const/index.mjs +2 -0
- package/esm2022/lib/components/ng-list-item/interfaces/index.mjs +2 -0
- package/esm2022/lib/components/ng-list-item/interfaces/template-context.mjs +2 -0
- package/esm2022/lib/components/ng-list-item/ng-virtual-list-item.component.mjs +201 -0
- package/esm2022/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.module.mjs +1 -1
- package/esm2022/lib/components/ng-list-item/utils/create-display-id.mjs +4 -0
- package/esm2022/lib/components/ng-list-item/utils/get-element-by-index.mjs +6 -0
- package/esm2022/lib/components/ng-list-item/utils/index.mjs +4 -0
- package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.component.mjs +154 -0
- package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.module.mjs +21 -0
- package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.component.mjs +78 -0
- package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.module.mjs +20 -0
- package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.component.mjs +118 -0
- package/esm2022/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.module.mjs +20 -0
- package/esm2022/lib/components/ng-prerender-container/core/index.mjs +3 -0
- package/esm2022/lib/components/ng-prerender-container/core/prerender-track-box.mjs +168 -0
- package/esm2022/lib/components/ng-prerender-container/events/index.mjs +6 -0
- package/esm2022/lib/components/ng-prerender-container/interfaces/index.mjs +2 -0
- package/esm2022/lib/components/ng-prerender-container/interfaces/refresh-params.mjs +2 -0
- package/esm2022/lib/components/ng-prerender-container/ng-prerender-container.component.mjs +63 -0
- package/esm2022/lib/components/ng-prerender-container/ng-prerender-container.module.mjs +20 -0
- package/esm2022/lib/components/ng-prerender-container/types/cache.mjs +2 -0
- package/esm2022/lib/components/ng-prerender-container/types/index.mjs +2 -0
- package/esm2022/lib/components/ng-scroll-bar/const/index.mjs +2 -2
- package/esm2022/lib/components/ng-scroll-bar/enums/index.mjs +3 -0
- package/esm2022/lib/components/ng-scroll-bar/enums/scrollbar-states.mjs +7 -0
- package/esm2022/lib/components/ng-scroll-bar/interfaces/index.mjs +1 -1
- package/esm2022/lib/components/ng-scroll-bar/interfaces/scroll-bar-template-context.mjs +2 -0
- package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.mjs +25 -0
- package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.component.mjs +49 -50
- package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.module.mjs +4 -5
- package/esm2022/lib/components/ng-scroll-bar/ng-scroll-bar.service.mjs +36 -0
- package/esm2022/lib/components/ng-scroll-bar/types/index.mjs +2 -0
- package/esm2022/lib/components/ng-scroll-bar/types/scrollbar-state.mjs +2 -0
- package/esm2022/lib/components/ng-scroll-view/base/base-scroll-view.component.mjs +24 -46
- package/esm2022/lib/components/ng-scroll-view/ng-scroll-view.component.mjs +12 -15
- package/esm2022/lib/components/ng-scroller/const/index.mjs +2 -0
- package/esm2022/lib/components/ng-scroller/enums/index.mjs +3 -0
- package/esm2022/lib/components/ng-scroller/enums/scroller-direction.mjs +6 -0
- package/esm2022/lib/components/ng-scroller/enums/scroller-directions.mjs +2 -0
- package/esm2022/lib/components/ng-scroller/ng-scroller.component.mjs +343 -0
- package/esm2022/lib/components/ng-scroller/ng-scroller.module.mjs +22 -0
- package/esm2022/lib/components/ng-scroller/utils/index.mjs +3 -0
- package/esm2022/lib/components/ng-scroller/utils/scroll-box.mjs +52 -0
- package/esm2022/lib/const/index.mjs +3 -14
- package/esm2022/lib/core/track-box.mjs +45 -15
- package/esm2022/lib/core/tracker.mjs +1 -1
- package/esm2022/lib/directives/locale-sensitive/locale-sensitive.directive.mjs +2 -2
- package/esm2022/lib/interfaces/scroll-to-params.mjs +2 -0
- package/esm2022/lib/models/display-object-config.model.mjs +1 -1
- package/esm2022/lib/models/display-object-measures.model.mjs +1 -1
- package/esm2022/lib/models/render-item-measures.model.mjs +1 -1
- package/esm2022/lib/ng-virtual-list-public.service.mjs +121 -0
- package/esm2022/lib/ng-virtual-list.component.mjs +232 -219
- package/esm2022/lib/ng-virtual-list.module.mjs +7 -7
- package/esm2022/lib/ng-virtual-list.service.mjs +107 -30
- package/esm2022/lib/types/index.mjs +1 -1
- package/esm2022/lib/utils/debounce.mjs +28 -6
- package/esm2022/public-api.mjs +7 -2
- package/fesm2022/ng-virtual-list.mjs +2875 -2946
- package/fesm2022/ng-virtual-list.mjs.map +1 -1
- package/lib/components/{list-item → ng-list-item}/base/base-virtual-list-item-component.d.ts +3 -1
- package/lib/components/ng-list-item/interfaces/template-context.d.ts +42 -0
- package/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.component.d.ts +0 -4
- package/lib/components/{prerender-container/components/prerender-list/prerender-list.component.d.ts → ng-prerender-container/components/ng-prerender-list/ng-prerender-list.component.d.ts} +7 -9
- package/lib/components/ng-prerender-container/components/ng-prerender-list/ng-prerender-list.module.d.ts +10 -0
- package/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.component.d.ts +17 -0
- package/lib/components/ng-prerender-container/components/ng-prerender-list-item/ng-prerender-list-item.module.d.ts +9 -0
- package/lib/components/{prerender-container/components/prerender-scroller/prerender-scroller.component.d.ts → ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.component.d.ts} +5 -7
- package/lib/components/ng-prerender-container/components/ng-prerender-scroller/ng-prerender-scroller.module.d.ts +9 -0
- package/lib/components/{prerender-container → ng-prerender-container}/core/prerender-track-box.d.ts +1 -1
- package/lib/components/ng-prerender-container/ng-prerender-container.component.d.ts +37 -0
- package/lib/components/ng-prerender-container/ng-prerender-container.module.d.ts +9 -0
- package/lib/components/ng-scroll-bar/const/index.d.ts +1 -2
- package/lib/components/ng-scroll-bar/enums/index.d.ts +2 -0
- package/lib/components/ng-scroll-bar/enums/scrollbar-states.d.ts +5 -0
- package/lib/components/ng-scroll-bar/interfaces/index.d.ts +2 -1
- package/lib/components/ng-scroll-bar/interfaces/scroll-bar-template-context.d.ts +26 -0
- package/lib/components/ng-scroll-bar/ng-scroll-bar-public.service.d.ts +16 -0
- package/lib/components/ng-scroll-bar/ng-scroll-bar.component.d.ts +15 -21
- package/lib/components/ng-scroll-bar/ng-scroll-bar.module.d.ts +1 -2
- package/lib/components/ng-scroll-bar/ng-scroll-bar.service.d.ts +22 -0
- package/lib/components/ng-scroll-bar/types/index.d.ts +2 -0
- package/lib/components/ng-scroll-bar/types/scrollbar-state.d.ts +2 -0
- package/lib/components/ng-scroll-view/base/base-scroll-view.component.d.ts +3 -7
- package/lib/components/{scroller → ng-scroller}/ng-scroller.component.d.ts +16 -6
- package/lib/const/index.d.ts +2 -2
- package/lib/core/track-box.d.ts +16 -10
- package/lib/core/tracker.d.ts +1 -1
- package/lib/directives/locale-sensitive/locale-sensitive.directive.d.ts +1 -1
- package/lib/interfaces/scroll-to-params.d.ts +7 -0
- package/lib/models/display-object-config.model.d.ts +1 -15
- package/lib/models/display-object-measures.model.d.ts +0 -4
- package/lib/models/render-item-measures.model.d.ts +0 -4
- package/lib/ng-virtual-list-public.service.d.ts +93 -0
- package/lib/ng-virtual-list.component.d.ts +26 -17
- package/lib/ng-virtual-list.module.d.ts +4 -4
- package/lib/ng-virtual-list.service.d.ts +39 -7
- package/lib/types/index.d.ts +3 -4
- package/lib/utils/debounce.d.ts +5 -1
- package/package.json +1 -1
- package/public-api.d.ts +6 -1
- package/esm2022/lib/components/list-item/base/base-virtual-list-item-component.mjs +0 -196
- package/esm2022/lib/components/list-item/base/index.mjs +0 -3
- package/esm2022/lib/components/list-item/const/index.mjs +0 -2
- package/esm2022/lib/components/list-item/interfaces/index.mjs +0 -2
- package/esm2022/lib/components/list-item/interfaces/template-context.mjs +0 -2
- package/esm2022/lib/components/list-item/ng-virtual-list-item.component.mjs +0 -245
- package/esm2022/lib/components/list-item/utils/create-display-id.mjs +0 -4
- package/esm2022/lib/components/list-item/utils/get-element-by-index.mjs +0 -6
- package/esm2022/lib/components/list-item/utils/index.mjs +0 -4
- package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.component.mjs +0 -154
- package/esm2022/lib/components/prerender-container/components/prerender-list/prerender-list.module.mjs +0 -21
- package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.mjs +0 -78
- package/esm2022/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.mjs +0 -20
- package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.component.mjs +0 -119
- package/esm2022/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.mjs +0 -20
- package/esm2022/lib/components/prerender-container/core/index.mjs +0 -3
- package/esm2022/lib/components/prerender-container/core/prerender-track-box.mjs +0 -169
- package/esm2022/lib/components/prerender-container/events/index.mjs +0 -6
- package/esm2022/lib/components/prerender-container/interfaces/index.mjs +0 -2
- package/esm2022/lib/components/prerender-container/interfaces/refresh-params.mjs +0 -2
- package/esm2022/lib/components/prerender-container/prerender-container.component.mjs +0 -65
- package/esm2022/lib/components/prerender-container/prerender-container.module.mjs +0 -20
- package/esm2022/lib/components/prerender-container/types/cache.mjs +0 -2
- package/esm2022/lib/components/prerender-container/types/index.mjs +0 -2
- package/esm2022/lib/components/scroller/const/index.mjs +0 -2
- package/esm2022/lib/components/scroller/enums/index.mjs +0 -3
- package/esm2022/lib/components/scroller/enums/scroller-direction.mjs +0 -6
- package/esm2022/lib/components/scroller/enums/scroller-directions.mjs +0 -2
- package/esm2022/lib/components/scroller/ng-scroller.component.mjs +0 -322
- package/esm2022/lib/components/scroller/ng-scroller.module.mjs +0 -22
- package/esm2022/lib/components/scroller/utils/index.mjs +0 -3
- package/esm2022/lib/components/scroller/utils/scroll-box.mjs +0 -52
- package/esm2022/lib/components/substrate/const/index.mjs +0 -2
- package/esm2022/lib/components/substrate/enums/index.mjs +0 -4
- package/esm2022/lib/components/substrate/enums/substrate-modes.mjs +0 -16
- package/esm2022/lib/components/substrate/enums/substrate-styles.mjs +0 -15
- package/esm2022/lib/components/substrate/index.mjs +0 -5
- package/esm2022/lib/components/substrate/substrate.component.mjs +0 -253
- package/esm2022/lib/components/substrate/substrate.module.mjs +0 -19
- package/esm2022/lib/components/substrate/types/index.mjs +0 -2
- package/esm2022/lib/components/substrate/types/substrate-mode.mjs +0 -2
- package/esm2022/lib/components/substrate/types/substrate-style.mjs +0 -2
- package/esm2022/lib/components/substrate/utils/circle-path.mjs +0 -4
- package/esm2022/lib/components/substrate/utils/index.mjs +0 -4
- package/esm2022/lib/components/substrate/utils/rounded-rect-path.mjs +0 -20
- package/esm2022/lib/types/color.mjs +0 -2
- package/esm2022/lib/types/gradient-color.mjs +0 -2
- package/esm2022/lib/types/rounded-corner.mjs +0 -2
- package/esm2022/lib/types/scrollbar-theme.mjs +0 -2
- package/esm2022/lib/utils/get-shape-min-size.mjs +0 -13
- package/lib/components/list-item/interfaces/template-context.d.ts +0 -10
- package/lib/components/prerender-container/components/prerender-list/prerender-list.module.d.ts +0 -10
- package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.component.d.ts +0 -17
- package/lib/components/prerender-container/components/prerender-list-item/prerender-list-item.module.d.ts +0 -9
- package/lib/components/prerender-container/components/prerender-scroller/prerender-scroller.module.d.ts +0 -9
- package/lib/components/prerender-container/prerender-container.component.d.ts +0 -40
- package/lib/components/prerender-container/prerender-container.module.d.ts +0 -9
- package/lib/components/substrate/const/index.d.ts +0 -2
- package/lib/components/substrate/enums/index.d.ts +0 -3
- package/lib/components/substrate/enums/substrate-modes.d.ts +0 -13
- package/lib/components/substrate/enums/substrate-styles.d.ts +0 -12
- package/lib/components/substrate/index.d.ts +0 -7
- package/lib/components/substrate/substrate.component.d.ts +0 -54
- package/lib/components/substrate/substrate.module.d.ts +0 -8
- package/lib/components/substrate/types/index.d.ts +0 -3
- package/lib/components/substrate/types/substrate-mode.d.ts +0 -10
- package/lib/components/substrate/types/substrate-style.d.ts +0 -10
- package/lib/components/substrate/utils/circle-path.d.ts +0 -1
- package/lib/components/substrate/utils/index.d.ts +0 -3
- package/lib/components/substrate/utils/rounded-rect-path.d.ts +0 -1
- package/lib/types/color.d.ts +0 -7
- package/lib/types/gradient-color.d.ts +0 -8
- package/lib/types/rounded-corner.d.ts +0 -7
- package/lib/types/scrollbar-theme.d.ts +0 -47
- package/lib/utils/get-shape-min-size.d.ts +0 -8
- /package/lib/components/{list-item → ng-list-item}/base/index.d.ts +0 -0
- /package/lib/components/{list-item → ng-list-item}/const/index.d.ts +0 -0
- /package/lib/components/{list-item → ng-list-item}/interfaces/index.d.ts +0 -0
- /package/lib/components/{list-item → ng-list-item}/ng-virtual-list-item.module.d.ts +0 -0
- /package/lib/components/{list-item → ng-list-item}/utils/create-display-id.d.ts +0 -0
- /package/lib/components/{list-item → ng-list-item}/utils/get-element-by-index.d.ts +0 -0
- /package/lib/components/{list-item → ng-list-item}/utils/index.d.ts +0 -0
- /package/lib/components/{prerender-container → ng-prerender-container}/core/index.d.ts +0 -0
- /package/lib/components/{prerender-container → ng-prerender-container}/events/index.d.ts +0 -0
- /package/lib/components/{prerender-container → ng-prerender-container}/interfaces/index.d.ts +0 -0
- /package/lib/components/{prerender-container → ng-prerender-container}/interfaces/refresh-params.d.ts +0 -0
- /package/lib/components/{prerender-container → ng-prerender-container}/types/cache.d.ts +0 -0
- /package/lib/components/{prerender-container → ng-prerender-container}/types/index.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/const/index.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/enums/index.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/enums/scroller-direction.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/enums/scroller-directions.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/ng-scroller.module.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/utils/index.d.ts +0 -0
- /package/lib/components/{scroller → ng-scroller}/utils/scroll-box.d.ts +0 -0
package/README.md
CHANGED
|
@@ -16,9 +16,12 @@ Works correctly in all browsers and platforms.
|
|
|
16
16
|

|
|
17
17
|

|
|
18
18
|
|
|
19
|
-
[
|
|
19
|
+
[Chat Demo](https://chat-demo.eugene-grebennikov.pro/)
|
|
20
20
|
[(Code)](https://github.com/DjonnyX/ng-virtual-list-chat-demo)
|
|
21
21
|
|
|
22
|
+
[News Feed Demo](https://news-feed-demo.eugene-grebennikov.pro/)
|
|
23
|
+
[(Code)](https://github.com/DjonnyX/ng-virtual-list-news-feed-demo)
|
|
24
|
+
|
|
22
25
|
[Live Examples (Storybook)](https://ng-virtual-list-examples.eugene-grebennikov.pro/)
|
|
23
26
|
|
|
24
27
|
[Examples](https://ng-virtual-list.eugene-grebennikov.pro/)
|
|
@@ -511,96 +514,32 @@ export class AppComponent {
|
|
|
511
514
|
|
|
512
515
|
## 🖼️ Stylization
|
|
513
516
|
|
|
514
|
-
|
|
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
|
-
```
|
|
517
|
+
### Scrollbar stylization
|
|
545
518
|
|
|
546
519
|
```scss
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
margin-right: 2px;
|
|
551
|
-
overflow: initial;
|
|
552
|
-
}
|
|
553
|
-
|
|
554
|
-
&::part(scrollbar-thumb) {
|
|
555
|
-
border: 1px solid #8738c3;
|
|
556
|
-
border-radius: 4px;
|
|
557
|
-
}
|
|
520
|
+
.list::part(scrollbar-thumb__shape) {
|
|
521
|
+
background-color: rgba(51, 0, 97, 1);
|
|
522
|
+
border-radius: 3px;
|
|
558
523
|
}
|
|
559
524
|
```
|
|
560
525
|
|
|
561
526
|
```html
|
|
562
|
-
<ng-virtual-list class="list" [
|
|
527
|
+
<ng-virtual-list class="list" [scrollbarThickness]="12" [items]="items" [itemRenderer]="itemRenderer"></ng-virtual-list>
|
|
563
528
|
|
|
564
|
-
<ng-template #
|
|
565
|
-
|
|
566
|
-
<div [ngClass]="{'list__h-container': true, 'selected': config.selected}">
|
|
567
|
-
<span>{{data.name}}</span>
|
|
568
|
-
</div>
|
|
569
|
-
}
|
|
529
|
+
<ng-template #itemRenderer let-data="data" let-config="config">
|
|
530
|
+
<span>{{data.name}}</span>
|
|
570
531
|
</ng-template>
|
|
571
532
|
```
|
|
572
533
|
|
|
534
|
+
### Scrollbar castomization
|
|
535
|
+
|
|
536
|
+
[Examples](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/src/app/app.component.html)
|
|
537
|
+
[CustomScrollbarComponent](https://github.com/DjonnyX/ng-virtual-list/blob/18.x/src/app/components/custom-scrollbar/custom-scrollbar.component.ts)
|
|
538
|
+
|
|
573
539
|
List items are encapsulated in shadowDOM, so to override default styles you need to use ::part access
|
|
574
540
|
|
|
575
541
|
- Customize a scroll area of list
|
|
576
542
|
```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
543
|
.list {
|
|
605
544
|
border-radius: 3px;
|
|
606
545
|
box-shadow: 1px 2px 8px 4px rgba(0, 0, 0, 0.075);
|
|
@@ -684,7 +623,6 @@ Inputs
|
|
|
684
623
|
| snap | boolean? = false | Determines whether elements will snap. Default value is "false". |
|
|
685
624
|
| 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
625
|
| 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
626
|
| clickDistance | number? = 40 | The maximum scroll distance at which a click event is triggered. |
|
|
689
627
|
| waitForPreparation | boolean? = true | If true, it will wait until the list items are fully prepared before displaying them.. The default value is `true`. |
|
|
690
628
|
| scrollStartOffset | number? = 0 | Sets the scroll start offset value; Default value is "0". |
|
|
@@ -693,9 +631,12 @@ Inputs
|
|
|
693
631
|
| 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
632
|
| 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
633
|
| 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
634
|
| scrollbarEnabled | boolean? = true | Determines whether the scrollbar is shown or not. The default value is "true". |
|
|
698
635
|
| scrollbarInteractive | boolean? = true | Determines whether scrolling using the scrollbar will be possible. The default value is "true". |
|
|
636
|
+
| scrollbarMinSize | number? = 80 | Minimum scrollbar size. |
|
|
637
|
+
| scrollbarThickness | number? = 6 | Scrollbar thickness. |
|
|
638
|
+
| scrollbarThumbRenderer | TemplateRef<any> \| null = null | Scrollbar customization template. |
|
|
639
|
+
| scrollbarThumbParams | {[propName: string]: any;} \| null | Additional options for the scrollbar. |
|
|
699
640
|
| scrollBehavior | ScrollBehavior? = 'smooth' | Defines the scrolling behavior for any element on the page. The default value is "smooth". |
|
|
700
641
|
| trackBy | string? = 'id' | The name of the property by which tracking is performed. |
|
|
701
642
|
|
|
@@ -732,7 +673,7 @@ Methods
|
|
|
732
673
|
### Template API
|
|
733
674
|
|
|
734
675
|
```html
|
|
735
|
-
<ng-template #itemRenderer let-data="data" let-config="config" let-measures="measures">
|
|
676
|
+
<ng-template #itemRenderer let-data="data" let-config="config" let-measures="measures" let-api="api">
|
|
736
677
|
<!-- content -->
|
|
737
678
|
</ng-template>
|
|
738
679
|
```
|
|
@@ -741,6 +682,7 @@ Properties
|
|
|
741
682
|
|
|
742
683
|
| Property | Type | Description |
|
|
743
684
|
|--|--|--|
|
|
685
|
+
| 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
686
|
| 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
687
|
| 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
688
|
| 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. |
|
|
@@ -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
|
+
import { NgVirtualListPublicService } from '../../../ng-virtual-list-public.service';
|
|
6
|
+
/**
|
|
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
|
|
9
|
+
* @author Evgenii Alexandrovich Grebennikov
|
|
10
|
+
* @email djonnyx@gmail.com
|
|
11
|
+
*/
|
|
12
|
+
export class BaseVirtualListItemComponent {
|
|
13
|
+
_cdr = inject(ChangeDetectorRef);
|
|
14
|
+
_apiService = inject(NgVirtualListPublicService);
|
|
15
|
+
_id;
|
|
16
|
+
get id() {
|
|
17
|
+
return this._id;
|
|
18
|
+
}
|
|
19
|
+
_listId;
|
|
20
|
+
get listId() {
|
|
21
|
+
return this._listId;
|
|
22
|
+
}
|
|
23
|
+
_displayId;
|
|
24
|
+
get displayId() {
|
|
25
|
+
return this._displayId;
|
|
26
|
+
}
|
|
27
|
+
_isSelected = false;
|
|
28
|
+
_isCollapsed = false;
|
|
29
|
+
config = signal({});
|
|
30
|
+
measures = signal(null);
|
|
31
|
+
focused = signal(false);
|
|
32
|
+
part = signal(PART_DEFAULT_ITEM);
|
|
33
|
+
data = signal(null);
|
|
34
|
+
_data = null;
|
|
35
|
+
set item(v) {
|
|
36
|
+
if (this._data === v || this._data?.id === -1 || !v) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
this._data = v;
|
|
40
|
+
this.updatePartStr(v, this._isSelected, this._isCollapsed);
|
|
41
|
+
this.updateConfig(v);
|
|
42
|
+
this.updateMeasures(v);
|
|
43
|
+
this.update();
|
|
44
|
+
this.data.set(v);
|
|
45
|
+
this._cdr.markForCheck();
|
|
46
|
+
}
|
|
47
|
+
classes;
|
|
48
|
+
index;
|
|
49
|
+
templateContext;
|
|
50
|
+
regular = false;
|
|
51
|
+
_scrollBarSize = 0;
|
|
52
|
+
_langTextDir = TextDirections.LTR;
|
|
53
|
+
_regularLength = SIZE_100_PERSENT;
|
|
54
|
+
set regularLength(v) {
|
|
55
|
+
if (this._regularLength === v) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
this._regularLength = v;
|
|
59
|
+
this.update();
|
|
60
|
+
this._cdr.markForCheck();
|
|
61
|
+
}
|
|
62
|
+
get item() {
|
|
63
|
+
return this._data;
|
|
64
|
+
}
|
|
65
|
+
get itemId() {
|
|
66
|
+
return this._data?.id;
|
|
67
|
+
}
|
|
68
|
+
itemRenderer = signal(undefined);
|
|
69
|
+
_renderer;
|
|
70
|
+
set renderer(v) {
|
|
71
|
+
if (this._renderer !== v) {
|
|
72
|
+
this._renderer = v;
|
|
73
|
+
this.itemRenderer.set(v);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
_elementRef = inject(ElementRef);
|
|
77
|
+
get element() {
|
|
78
|
+
return this._elementRef.nativeElement;
|
|
79
|
+
}
|
|
80
|
+
_destroyRef = inject(DestroyRef);
|
|
81
|
+
constructor() {
|
|
82
|
+
this.classes = computed(() => {
|
|
83
|
+
const data = this.data(), focused = this.focused();
|
|
84
|
+
return {
|
|
85
|
+
[CLASS_NAME_SNAPPED]: data?.config?.snapped ?? false, [CLASS_NAME_SNAPPED_OUT]: data?.config?.snappedOut ?? false,
|
|
86
|
+
[CLASS_NAME_FOCUS]: focused,
|
|
87
|
+
};
|
|
88
|
+
});
|
|
89
|
+
this.index = computed(() => {
|
|
90
|
+
return this.config()?.tabIndex ?? -1;
|
|
91
|
+
});
|
|
92
|
+
this.templateContext = computed(() => {
|
|
93
|
+
const data = this.data(), measures = this.measures(), config = this.config();
|
|
94
|
+
return {
|
|
95
|
+
data: data?.data, prevData: data?.previouseData, nextData: data?.nextData, measures,
|
|
96
|
+
config, reseted: false, index: data?.index ?? -1, api: this._apiService,
|
|
97
|
+
};
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
updateMeasures(v) {
|
|
101
|
+
this.measures.set(v?.measures ? { ...v.measures } : null);
|
|
102
|
+
}
|
|
103
|
+
updateConfig(v) {
|
|
104
|
+
this.config.set({
|
|
105
|
+
...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),
|
|
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/ng-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\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 _cdr = inject(ChangeDetectorRef);\r\n\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    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, api: this._apiService,\r\n      };\r\n    });\r\n  }\r\n\r\n  protected updateMeasures(v: IRenderVirtualListItem<any> | null) {\r\n    this.measures.set(v?.measures ? { ...v.measures } : null)\r\n  }\r\n\r\n  protected updateConfig(v: IRenderVirtualListItem<any> | null) {\r\n    this.config.set({\r\n      ...v?.config || {} as IDisplayObjectConfig, selected: this._isSelected, collapsed: this._isCollapsed, focused: this.focused(),\r\n    });\r\n  }\r\n\r\n  protected update() {\r\n    const data = this._data, regular = this.regular, length = this._regularLength, el = this._elementRef.nativeElement;\r\n    if (data) {\r\n      el.setAttribute(ITEM_ID, `${data.id}`);\r\n      const styles = el.style;\r\n      styles.zIndex = data.config.zIndex;\r\n      styles.position = POSITION_ABSOLUTE;\r\n      if (data.config.isStub === true) {\r\n        el.style.visibility = VISIBILITY_HIDDEN;\r\n      }\r\n      if (regular) {\r\n        el.setAttribute(POSITION, POSITION_ZERO);\r\n        styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? (this._langTextDir === TextDirections.RTL ? this._scrollBarSize : 0) : data.measures.delta}${PX}, ${data.config.isVertical ? data.measures.delta : 0}${PX}, ${POSITION_ZERO})`;\r\n      } else {\r\n        el.setAttribute(POSITION, `${data.config.isVertical ? data.measures.y : data.measures.x}`);\r\n        styles.transform = `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX}, ${POSITION_ZERO})`;\r\n      }\r\n      styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;\r\n      styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;\r\n    } else {\r\n      el.removeAttribute(ID);\r\n    }\r\n\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  protected updatePartStr(v: IRenderVirtualListItem | null, isSelected: boolean, isCollapsed: boolean) {\r\n    let odd = false;\r\n    if (v?.index !== undefined) {\r\n      odd = v.index % 2 === 0;\r\n    }\r\n\r\n    let part = PART_DEFAULT_ITEM;\r\n    part += odd ? PART_ITEM_ODD : PART_ITEM_EVEN;\r\n    if (v ? v.config.snapped : false) {\r\n      part += PART_ITEM_SNAPPED;\r\n    }\r\n    if (isSelected) {\r\n      part += PART_ITEM_SELECTED;\r\n    }\r\n    if (isCollapsed) {\r\n      part += PART_ITEM_COLLAPSED;\r\n    }\r\n    if (v ? v.config.new : false) {\r\n      part += PART_ITEM_NEW;\r\n    }\r\n    if (this.focused()) {\r\n      part += PART_ITEM_FOCUSED;\r\n    }\r\n    this.part.set(part);\r\n  }\r\n\r\n  getBounds(): ISize {\r\n    const el: HTMLElement = this._elementRef.nativeElement,\r\n      { width, height } = el.getBoundingClientRect();\r\n    return { width: width > 0 ? width : 1, height: height > 0 ? height : 1, };\r\n  }\r\n\r\n  show() {\r\n    const el = this._elementRef.nativeElement as HTMLElement,\r\n      styles = el.style;\r\n    styles.zIndex = this._data?.config?.zIndex ?? DEFAULT_ZINDEX;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_BLOCK) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_BLOCK;\r\n    } else {\r\n      const isStub = this._data?.config?.isStub ?? false;\r\n      if (!isStub) {\r\n        if (styles.visibility === VISIBILITY_VISIBLE) {\r\n          return;\r\n        }\r\n        styles.visibility = VISIBILITY_VISIBLE;\r\n      }\r\n    }\r\n  }\r\n\r\n  hide() {\r\n    const el = this._elementRef.nativeElement,\r\n      styles = el.style;\r\n    styles.position = POSITION_ABSOLUTE;\r\n    styles.transform = TRANSLATE_3D_HIDDEN;\r\n    styles.zIndex = HIDDEN_ZINDEX;\r\n    if (this.regular) {\r\n      if (styles.display === DISPLAY_NONE) {\r\n        return;\r\n      }\r\n\r\n      styles.display = DISPLAY_NONE;\r\n    } else {\r\n      if (styles.visibility === VISIBILITY_HIDDEN) {\r\n        return;\r\n      }\r\n\r\n      styles.visibility = VISIBILITY_HIDDEN;\r\n    }\r\n  }\r\n}"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { BaseVirtualListItemComponent } from './base-virtual-list-item-component';
|
|
2
|
+
export { BaseVirtualListItemComponent, };
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9iYXNlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRWxGLE9BQU8sRUFDSCw0QkFBNEIsR0FDL0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2Jhc2UtdmlydHVhbC1saXN0LWl0ZW0tY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBCYXNlVmlydHVhbExpc3RJdGVtQ29tcG9uZW50LFxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const ID = 'id', TRANSLATE_3D_HIDDEN = 'translate3d(-1000px,-1000px,0)', ATTR_AREA_SELECTED = 'area-selected', POSITION = 'position', POSITION_ZERO = '0', ITEM_ID = 'item-id', KEY_SPACE = ' ', KEY_ARR_LEFT = 'ArrowLeft', KEY_ARR_UP = 'ArrowUp', KEY_ARR_RIGHT = 'ArrowRight', KEY_ARR_DOWN = 'ArrowDown', EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown', CLASS_NAME_SNAPPED = 'snapped', CLASS_NAME_SNAPPED_OUT = 'snapped-out', CLASS_NAME_FOCUS = 'focus';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9jb25zdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxFQUNsQixtQkFBbUIsR0FBRyxnQ0FBZ0MsRUFDdEQsa0JBQWtCLEdBQUcsZUFBZSxFQUNwQyxRQUFRLEdBQUcsVUFBVSxFQUNyQixhQUFhLEdBQUcsR0FBRyxFQUNuQixPQUFPLEdBQUcsU0FBUyxFQUNuQixTQUFTLEdBQUcsR0FBRyxFQUNmLFlBQVksR0FBRyxXQUFXLEVBQzFCLFVBQVUsR0FBRyxTQUFTLEVBQ3RCLGFBQWEsR0FBRyxZQUFZLEVBQzVCLFlBQVksR0FBRyxXQUFXLEVBQzFCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGVBQWUsR0FBRyxVQUFVLEVBQzVCLGNBQWMsR0FBRyxTQUFTLEVBQzFCLGtCQUFrQixHQUFHLFNBQVMsRUFDOUIsc0JBQXNCLEdBQUcsYUFBYSxFQUN0QyxnQkFBZ0IsR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgSUQgPSAnaWQnLFxyXG4gICAgVFJBTlNMQVRFXzNEX0hJRERFTiA9ICd0cmFuc2xhdGUzZCgtMTAwMHB4LC0xMDAwcHgsMCknLFxyXG4gICAgQVRUUl9BUkVBX1NFTEVDVEVEID0gJ2FyZWEtc2VsZWN0ZWQnLFxyXG4gICAgUE9TSVRJT04gPSAncG9zaXRpb24nLFxyXG4gICAgUE9TSVRJT05fWkVSTyA9ICcwJyxcclxuICAgIElURU1fSUQgPSAnaXRlbS1pZCcsXHJcbiAgICBLRVlfU1BBQ0UgPSAnICcsXHJcbiAgICBLRVlfQVJSX0xFRlQgPSAnQXJyb3dMZWZ0JyxcclxuICAgIEtFWV9BUlJfVVAgPSAnQXJyb3dVcCcsXHJcbiAgICBLRVlfQVJSX1JJR0hUID0gJ0Fycm93UmlnaHQnLFxyXG4gICAgS0VZX0FSUl9ET1dOID0gJ0Fycm93RG93bicsXHJcbiAgICBFVkVOVF9GT0NVU19JTiA9ICdmb2N1c2luJyxcclxuICAgIEVWRU5UX0ZPQ1VTX09VVCA9ICdmb2N1c291dCcsXHJcbiAgICBFVkVOVF9LRVlfRE9XTiA9ICdrZXlkb3duJyxcclxuICAgIENMQVNTX05BTUVfU05BUFBFRCA9ICdzbmFwcGVkJyxcclxuICAgIENMQVNTX05BTUVfU05BUFBFRF9PVVQgPSAnc25hcHBlZC1vdXQnLFxyXG4gICAgQ0xBU1NfTkFNRV9GT0NVUyA9ICdmb2N1cyc7XHJcblxyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL25nLWxpc3QtaXRlbS9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJVGVtcGxhdGVDb250ZXh0IH0gZnJvbSAnLi90ZW1wbGF0ZS1jb250ZXh0JztcclxuXHJcbmV4cG9ydCB0eXBlIHtcclxuICAgIElUZW1wbGF0ZUNvbnRleHQsXHJcbn1cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvbGliL2NvbXBvbmVudHMvbmctbGlzdC1pdGVtL2ludGVyZmFjZXMvdGVtcGxhdGUtY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSURpc3BsYXlPYmplY3RDb25maWcsIElEaXNwbGF5T2JqZWN0TWVhc3VyZXMgfSBmcm9tIFwiLi4vLi4vLi4vbW9kZWxzXCI7XHJcbmltcG9ydCB7IE5nVmlydHVhbExpc3RQdWJsaWNTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uLy4uL25nLXZpcnR1YWwtbGlzdC1wdWJsaWMuc2VydmljZVwiO1xyXG5cclxuLyoqXHJcbiAqIEJhc2VWaXJ0dWFsTGlzdEl0ZW1Db21wb25lbnRcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTgueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi9jb21wb25lbnRzL2xpc3QtaXRlbS9pbnRlcmZhY2VzL3RlbXBsYXRlLWNvbnRleHQudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEFsZXhhbmRyb3ZpY2ggR3JlYmVubmlrb3ZcclxuICogQGVtYWlsIGRqb25ueXhAZ21haWwuY29tXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElUZW1wbGF0ZUNvbnRleHQ8RCA9IGFueT4ge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBUEkgcHJvdmlkZXIuXHJcbiAgICAgKi9cclxuICAgIGFwaTogTmdWaXJ0dWFsTGlzdFB1YmxpY1NlcnZpY2U7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBkYXRhLlxyXG4gICAgICovXHJcbiAgICBkYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBEYXRhIG9mIHRoZSBwcmV2aW91cyBsaXN0IGl0ZW0uXHJcbiAgICAgKi9cclxuICAgIHByZXZEYXRhOiBEO1xyXG4gICAgLyoqXHJcbiAgICAgKiBEYXRhIG9mIHRoZSBuZXh0IGxpc3QgaXRlbS5cclxuICAgICAqL1xyXG4gICAgbmV4dERhdGE6IEQ7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBtZWFzdXJlbWVudCBkYXRhLlxyXG4gICAgICovXHJcbiAgICBtZWFzdXJlczogSURpc3BsYXlPYmplY3RNZWFzdXJlcyB8IG51bGw7XHJcbiAgICAvKipcclxuICAgICAqIExpc3QgaXRlbSBjb25maWd1cmF0aW9uLlxyXG4gICAgICovXHJcbiAgICBjb25maWc6IElEaXNwbGF5T2JqZWN0Q29uZmlnO1xyXG4gICAgLyoqXHJcbiAgICAgKiBJbmRpY2F0ZXMgYSByZXNldCBzdGF0ZS5cclxuICAgICAqL1xyXG4gICAgcmVzZXRlZDogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogTGlzdCBpdGVtIGluZGV4LlxyXG4gICAgICovXHJcbiAgICBpbmRleDogbnVtYmVyO1xyXG59Il19
|