-
-
Notifications
You must be signed in to change notification settings - Fork 426
Expand file tree
/
Copy pathindex.ts
More file actions
98 lines (88 loc) · 2.57 KB
/
index.ts
File metadata and controls
98 lines (88 loc) · 2.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
import {
Virtualizer,
elementScroll,
observeElementOffset,
observeElementRect,
observeWindowOffset,
observeWindowRect,
windowScroll,
} from '@tanstack/virtual-core'
import type { ReactiveController, ReactiveControllerHost } from 'lit'
import type { PartialKeys, VirtualizerOptions } from '@tanstack/virtual-core'
class VirtualizerControllerBase<
TScrollElement extends Element | Window,
TItemElement extends Element,
> implements ReactiveController {
host: ReactiveControllerHost
private readonly virtualizer: Virtualizer<TScrollElement, TItemElement>
private cleanup: () => void = () => {}
constructor(
host: ReactiveControllerHost,
options: VirtualizerOptions<TScrollElement, TItemElement>,
) {
const resolvedOptions: VirtualizerOptions<TScrollElement, TItemElement> = {
...options,
onChange: (instance, sync) => {
this.host.updateComplete.then(() => this.host.requestUpdate())
options.onChange?.(instance, sync)
},
}
this.virtualizer = new Virtualizer(resolvedOptions)
;(this.host = host).addController(this)
}
public getVirtualizer() {
return this.virtualizer
}
hostConnected() {
this.cleanup = this.virtualizer._didMount()
}
hostUpdated() {
this.virtualizer._willUpdate()
}
hostDisconnected() {
this.cleanup()
}
}
export class VirtualizerController<
TScrollElement extends Element,
TItemElement extends Element,
> extends VirtualizerControllerBase<TScrollElement, TItemElement> {
constructor(
host: ReactiveControllerHost,
options: PartialKeys<
VirtualizerOptions<TScrollElement, TItemElement>,
'observeElementRect' | 'observeElementOffset' | 'scrollToFn'
>,
) {
super(host, {
observeElementRect: observeElementRect,
observeElementOffset: observeElementOffset,
scrollToFn: elementScroll,
...options,
})
}
}
export class WindowVirtualizerController<
TItemElement extends Element,
> extends VirtualizerControllerBase<Window, TItemElement> {
constructor(
host: ReactiveControllerHost,
options: PartialKeys<
VirtualizerOptions<Window, TItemElement>,
| 'getScrollElement'
| 'observeElementRect'
| 'observeElementOffset'
| 'scrollToFn'
>,
) {
super(host, {
getScrollElement: () => (typeof document !== 'undefined' ? window : null),
observeElementRect: observeWindowRect,
observeElementOffset: observeWindowOffset,
scrollToFn: windowScroll,
initialOffset: () =>
typeof document !== 'undefined' ? window.scrollY : 0,
...options,
})
}
}