@djangocfg/ui-tools 2.1.416 → 2.1.418
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/dist/audio-player/index.cjs +2098 -0
- package/dist/audio-player/index.cjs.map +1 -0
- package/dist/audio-player/index.css +65 -0
- package/dist/audio-player/index.css.map +1 -0
- package/dist/audio-player/index.d.cts +166 -0
- package/dist/audio-player/index.d.ts +166 -0
- package/dist/audio-player/index.mjs +2075 -0
- package/dist/audio-player/index.mjs.map +1 -0
- package/dist/composer-registry/index.cjs +45 -0
- package/dist/composer-registry/index.cjs.map +1 -0
- package/dist/composer-registry/index.d.cts +73 -0
- package/dist/composer-registry/index.d.ts +73 -0
- package/dist/composer-registry/index.mjs +39 -0
- package/dist/composer-registry/index.mjs.map +1 -0
- package/dist/tree/index.cjs +82 -63
- package/dist/tree/index.cjs.map +1 -1
- package/dist/tree/index.d.cts +15 -1
- package/dist/tree/index.d.ts +15 -1
- package/dist/tree/index.mjs +83 -64
- package/dist/tree/index.mjs.map +1 -1
- package/package.json +38 -17
- package/src/tools/chat/composer/Composer.tsx +8 -8
- package/src/tools/chat/context/ChatProvider.tsx +13 -78
- package/src/tools/chat/hooks/useAutoFocusOnStreamEnd.ts +12 -15
- package/src/tools/chat/hooks/useFocusOnEmptyClick.ts +4 -5
- package/src/tools/chat/launcher/header/ChatHeader.tsx +14 -19
- package/src/tools/chat/launcher/header/ChatHeaderActionButton.tsx +8 -12
- package/src/tools/data/Tree/TreeRoot.tsx +33 -109
- package/src/tools/data/Tree/context/TreeContext.tsx +22 -3
- package/src/tools/data/Tree/context/menu/index.ts +1 -0
- package/src/tools/data/Tree/context/menu/render.tsx +75 -0
- package/src/tools/data/Tree/context/menu/use-resolved-menu.ts +16 -2
- package/src/tools/data/Tree/index.tsx +1 -0
- package/src/tools/data/Tree/types/index.ts +1 -1
- package/src/tools/data/Tree/types/root-props.ts +16 -0
- package/src/tools/dev/OpenapiViewer/components/DocsLayout/EndpointDoc/Header/MetaActions.tsx +6 -9
- package/src/tools/dev/OpenapiViewer/components/DocsLayout/index.tsx +2 -4
- package/src/tools/forms/CodeEditor/components/Editor.tsx +19 -0
- package/src/tools/forms/CodeEditor/types/index.ts +7 -0
- package/src/tools/forms/MarkdownEditor/MarkdownEditor.tsx +40 -0
- package/src/tools/forms/MarkdownEditor/styles.css +174 -21
- package/src/tools/forms/NotionEditor/CustomKeymap.ts +48 -0
- package/src/tools/forms/NotionEditor/LinkDialog.tsx +133 -0
- package/src/tools/forms/NotionEditor/NotionEditor.tsx +304 -0
- package/src/tools/forms/NotionEditor/SlashExtension.ts +32 -0
- package/src/tools/forms/NotionEditor/SlashList.tsx +136 -0
- package/src/tools/forms/NotionEditor/TaskItemView.tsx +41 -0
- package/src/tools/forms/NotionEditor/createSlashSuggestion.ts +121 -0
- package/src/tools/forms/NotionEditor/extensions.ts +105 -0
- package/src/tools/forms/NotionEditor/index.ts +1 -0
- package/src/tools/forms/NotionEditor/lazy.tsx +44 -0
- package/src/tools/forms/NotionEditor/slashItems.ts +159 -0
- package/src/tools/forms/NotionEditor/styles.css +478 -0
- package/src/tools/forms/NotionEditor/types.ts +28 -0
- package/src/tools/input/SpeechRecognition/widgets/VoiceComposerSlot.tsx +11 -12
- package/src/tools/integration/ComposerRegistry/index.ts +105 -0
- package/src/tools/media/AudioPlayer/Player.tsx +2 -0
- package/src/tools/media/AudioPlayer/PlayerShell.tsx +29 -22
- package/src/tools/media/AudioPlayer/lazy.tsx +30 -42
- package/src/tools/media/AudioPlayer/parts/Controls/IconButton.tsx +10 -11
- package/src/tools/media/AudioPlayer/parts/Controls/VolumeControl.tsx +52 -115
- package/src/tools/media/AudioPlayer/types.ts +8 -0
- package/src/tools/media/ImageViewer/components/ImageViewer.tsx +8 -0
- package/src/tools/media/ImageViewer/types.ts +4 -0
- package/src/tools/media/VideoPlayer/VideoPlayer.tsx +20 -1
- package/src/tools/media/VideoPlayer/types.ts +4 -0
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
|
+
|
|
5
|
+
type WaveformMode = 'peaks' | 'live' | 'bars' | 'progress' | 'none';
|
|
6
|
+
type WaveformConfig = {
|
|
7
|
+
mode?: WaveformMode;
|
|
8
|
+
peaks?: Float32Array;
|
|
9
|
+
height?: number;
|
|
10
|
+
barWidth?: number;
|
|
11
|
+
barGap?: number;
|
|
12
|
+
bgColor?: string;
|
|
13
|
+
fgColor?: string;
|
|
14
|
+
decodeOnMount?: boolean;
|
|
15
|
+
};
|
|
16
|
+
type ReactiveCoverMode = false | 'subtle';
|
|
17
|
+
type PlayerVariant = 'default' | 'compact' | 'auto';
|
|
18
|
+
type PlayerErrorReason = 'network' | 'decode' | 'unsupported' | 'unknown';
|
|
19
|
+
type PlayerProps = {
|
|
20
|
+
src: string;
|
|
21
|
+
peaks?: Float32Array;
|
|
22
|
+
title?: string;
|
|
23
|
+
artist?: string;
|
|
24
|
+
album?: string;
|
|
25
|
+
cover?: string;
|
|
26
|
+
variant?: PlayerVariant;
|
|
27
|
+
className?: string;
|
|
28
|
+
waveform?: WaveformConfig;
|
|
29
|
+
reactiveCover?: ReactiveCoverMode;
|
|
30
|
+
autoplay?: boolean;
|
|
31
|
+
loop?: boolean;
|
|
32
|
+
initialVolume?: number;
|
|
33
|
+
muted?: boolean;
|
|
34
|
+
preload?: 'none' | 'metadata' | 'auto';
|
|
35
|
+
exclusive?: boolean;
|
|
36
|
+
onPrev?: () => void;
|
|
37
|
+
onNext?: () => void;
|
|
38
|
+
onPlay?: () => void;
|
|
39
|
+
onPause?: () => void;
|
|
40
|
+
onEnded?: () => void;
|
|
41
|
+
onError?: (reason: PlayerErrorReason, e: unknown) => void;
|
|
42
|
+
onTimeUpdate?: (currentTime: number, duration: number) => void;
|
|
43
|
+
ariaLabel?: string;
|
|
44
|
+
enableKeyboardShortcuts?: boolean;
|
|
45
|
+
/** Focus the player container on mount so its keyboard scope is active
|
|
46
|
+
* immediately. Pair with `key={src}` upstream when the parent wants a
|
|
47
|
+
* fresh focus on every source change (file-browser inspector pattern). */
|
|
48
|
+
autoFocus?: boolean;
|
|
49
|
+
seekStartsPlayback?: boolean;
|
|
50
|
+
};
|
|
51
|
+
type PlayerStateKind = 'idle' | 'loading' | 'decoding' | 'ready' | 'playing' | 'paused' | 'ended' | 'error';
|
|
52
|
+
type PlayerState = {
|
|
53
|
+
kind: 'idle' | 'loading';
|
|
54
|
+
} | {
|
|
55
|
+
kind: 'decoding';
|
|
56
|
+
duration: number;
|
|
57
|
+
} | {
|
|
58
|
+
kind: 'ready' | 'playing' | 'paused' | 'ended';
|
|
59
|
+
duration: number;
|
|
60
|
+
peaks?: Float32Array;
|
|
61
|
+
} | {
|
|
62
|
+
kind: 'error';
|
|
63
|
+
reason: PlayerErrorReason;
|
|
64
|
+
duration: number;
|
|
65
|
+
};
|
|
66
|
+
type PlayerControls = {
|
|
67
|
+
play: () => Promise<void>;
|
|
68
|
+
pause: () => void;
|
|
69
|
+
toggle: () => Promise<void>;
|
|
70
|
+
seek: (seconds: number) => void;
|
|
71
|
+
seekTo: (ratio: number) => void;
|
|
72
|
+
setVolume: (v: number) => void;
|
|
73
|
+
toggleMute: () => void;
|
|
74
|
+
toggleLoop: () => void;
|
|
75
|
+
};
|
|
76
|
+
type PlayerHandle = {
|
|
77
|
+
audio: HTMLAudioElement;
|
|
78
|
+
play: () => Promise<void>;
|
|
79
|
+
pause: () => void;
|
|
80
|
+
seek: (seconds: number) => void;
|
|
81
|
+
getCurrentTime: () => number;
|
|
82
|
+
getDuration: () => number;
|
|
83
|
+
/** Move keyboard focus to the player container so its hotkey scope
|
|
84
|
+
* (Space=play/pause, ←→=seek, ↑↓=volume, M=mute) becomes active. */
|
|
85
|
+
focus: () => void;
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
declare const Player: react.ForwardRefExoticComponent<PlayerProps & react.RefAttributes<PlayerHandle>>;
|
|
89
|
+
|
|
90
|
+
type LevelsStore = {
|
|
91
|
+
subscribe: (cb: () => void) => () => void;
|
|
92
|
+
getCurrent: () => Float32Array;
|
|
93
|
+
set: (next: Float32Array) => void;
|
|
94
|
+
setActive: (active: boolean) => void;
|
|
95
|
+
isActive: () => boolean;
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
type Listener$1 = (activeId: string | null) => void;
|
|
99
|
+
declare function setActivePlayer(id: string | null): void;
|
|
100
|
+
declare function getActivePlayer(): string | null;
|
|
101
|
+
declare function getLastActivePlayer(): string | null;
|
|
102
|
+
declare function subscribeActivePlayer(cb: Listener$1): () => void;
|
|
103
|
+
|
|
104
|
+
type PlayerPreferences = {
|
|
105
|
+
volume: number;
|
|
106
|
+
muted: boolean;
|
|
107
|
+
};
|
|
108
|
+
type Listener = (prefs: PlayerPreferences) => void;
|
|
109
|
+
declare function getPreferences(): PlayerPreferences;
|
|
110
|
+
declare function setStoredVolume(volume: number): void;
|
|
111
|
+
declare function setStoredMuted(muted: boolean): void;
|
|
112
|
+
declare function subscribePreferences(cb: Listener): () => void;
|
|
113
|
+
|
|
114
|
+
type PlayerMeta = {
|
|
115
|
+
src: string;
|
|
116
|
+
title?: string;
|
|
117
|
+
artist?: string;
|
|
118
|
+
album?: string;
|
|
119
|
+
cover?: string;
|
|
120
|
+
hasPrev: boolean;
|
|
121
|
+
hasNext: boolean;
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
type PlayerProviderProps = {
|
|
125
|
+
src: string;
|
|
126
|
+
peaks?: Float32Array;
|
|
127
|
+
title?: string;
|
|
128
|
+
artist?: string;
|
|
129
|
+
album?: string;
|
|
130
|
+
cover?: string;
|
|
131
|
+
autoplay?: boolean;
|
|
132
|
+
loop?: boolean;
|
|
133
|
+
initialVolume?: number;
|
|
134
|
+
muted?: boolean;
|
|
135
|
+
preload?: 'none' | 'metadata' | 'auto';
|
|
136
|
+
exclusive?: boolean;
|
|
137
|
+
onPrev?: () => void;
|
|
138
|
+
onNext?: () => void;
|
|
139
|
+
onPlay?: () => void;
|
|
140
|
+
onPause?: () => void;
|
|
141
|
+
onEnded?: () => void;
|
|
142
|
+
onError?: (reason: PlayerErrorReason, e: unknown) => void;
|
|
143
|
+
children: ReactNode;
|
|
144
|
+
};
|
|
145
|
+
declare function PlayerProvider(props: PlayerProviderProps): react_jsx_runtime.JSX.Element;
|
|
146
|
+
|
|
147
|
+
declare const usePlayerState: () => PlayerState;
|
|
148
|
+
declare const usePlayerControls: () => PlayerControls;
|
|
149
|
+
declare const usePlayerLevels: () => LevelsStore;
|
|
150
|
+
declare const usePlayerMeta: () => PlayerMeta;
|
|
151
|
+
declare const usePlayerAudio: () => HTMLAudioElement;
|
|
152
|
+
declare const usePlayerPaused: () => boolean;
|
|
153
|
+
declare const usePlayerDuration: () => number;
|
|
154
|
+
|
|
155
|
+
/** Currently active player id. `null` when nothing plays. */
|
|
156
|
+
declare function useActivePlayer(): string | null;
|
|
157
|
+
/** Most recently active player id. Stays set after pause; useful for "last
|
|
158
|
+
* played" UIs where you want to keep showing a track even when paused. */
|
|
159
|
+
declare function useLastActivePlayer(): string | null;
|
|
160
|
+
/** True when the given id is currently active. Convenience for conditional
|
|
161
|
+
* styling without comparing strings inline. */
|
|
162
|
+
declare function useIsActivePlayer(id: string | null | undefined): boolean;
|
|
163
|
+
|
|
164
|
+
declare function usePlayerPreferences(): PlayerPreferences;
|
|
165
|
+
|
|
166
|
+
export { Player as LazyPlayer, Player, type PlayerControls, type PlayerErrorReason, type PlayerHandle, type PlayerPreferences, type PlayerProps, PlayerProvider, type PlayerState, type PlayerStateKind, type PlayerVariant, type ReactiveCoverMode, type WaveformConfig, type WaveformMode, getActivePlayer, getLastActivePlayer, getPreferences, setActivePlayer, setStoredMuted, setStoredVolume, subscribeActivePlayer, subscribePreferences, useActivePlayer, useIsActivePlayer, useLastActivePlayer, usePlayerAudio, usePlayerControls, usePlayerDuration, usePlayerLevels, usePlayerMeta, usePlayerPaused, usePlayerPreferences, usePlayerState };
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
|
+
|
|
5
|
+
type WaveformMode = 'peaks' | 'live' | 'bars' | 'progress' | 'none';
|
|
6
|
+
type WaveformConfig = {
|
|
7
|
+
mode?: WaveformMode;
|
|
8
|
+
peaks?: Float32Array;
|
|
9
|
+
height?: number;
|
|
10
|
+
barWidth?: number;
|
|
11
|
+
barGap?: number;
|
|
12
|
+
bgColor?: string;
|
|
13
|
+
fgColor?: string;
|
|
14
|
+
decodeOnMount?: boolean;
|
|
15
|
+
};
|
|
16
|
+
type ReactiveCoverMode = false | 'subtle';
|
|
17
|
+
type PlayerVariant = 'default' | 'compact' | 'auto';
|
|
18
|
+
type PlayerErrorReason = 'network' | 'decode' | 'unsupported' | 'unknown';
|
|
19
|
+
type PlayerProps = {
|
|
20
|
+
src: string;
|
|
21
|
+
peaks?: Float32Array;
|
|
22
|
+
title?: string;
|
|
23
|
+
artist?: string;
|
|
24
|
+
album?: string;
|
|
25
|
+
cover?: string;
|
|
26
|
+
variant?: PlayerVariant;
|
|
27
|
+
className?: string;
|
|
28
|
+
waveform?: WaveformConfig;
|
|
29
|
+
reactiveCover?: ReactiveCoverMode;
|
|
30
|
+
autoplay?: boolean;
|
|
31
|
+
loop?: boolean;
|
|
32
|
+
initialVolume?: number;
|
|
33
|
+
muted?: boolean;
|
|
34
|
+
preload?: 'none' | 'metadata' | 'auto';
|
|
35
|
+
exclusive?: boolean;
|
|
36
|
+
onPrev?: () => void;
|
|
37
|
+
onNext?: () => void;
|
|
38
|
+
onPlay?: () => void;
|
|
39
|
+
onPause?: () => void;
|
|
40
|
+
onEnded?: () => void;
|
|
41
|
+
onError?: (reason: PlayerErrorReason, e: unknown) => void;
|
|
42
|
+
onTimeUpdate?: (currentTime: number, duration: number) => void;
|
|
43
|
+
ariaLabel?: string;
|
|
44
|
+
enableKeyboardShortcuts?: boolean;
|
|
45
|
+
/** Focus the player container on mount so its keyboard scope is active
|
|
46
|
+
* immediately. Pair with `key={src}` upstream when the parent wants a
|
|
47
|
+
* fresh focus on every source change (file-browser inspector pattern). */
|
|
48
|
+
autoFocus?: boolean;
|
|
49
|
+
seekStartsPlayback?: boolean;
|
|
50
|
+
};
|
|
51
|
+
type PlayerStateKind = 'idle' | 'loading' | 'decoding' | 'ready' | 'playing' | 'paused' | 'ended' | 'error';
|
|
52
|
+
type PlayerState = {
|
|
53
|
+
kind: 'idle' | 'loading';
|
|
54
|
+
} | {
|
|
55
|
+
kind: 'decoding';
|
|
56
|
+
duration: number;
|
|
57
|
+
} | {
|
|
58
|
+
kind: 'ready' | 'playing' | 'paused' | 'ended';
|
|
59
|
+
duration: number;
|
|
60
|
+
peaks?: Float32Array;
|
|
61
|
+
} | {
|
|
62
|
+
kind: 'error';
|
|
63
|
+
reason: PlayerErrorReason;
|
|
64
|
+
duration: number;
|
|
65
|
+
};
|
|
66
|
+
type PlayerControls = {
|
|
67
|
+
play: () => Promise<void>;
|
|
68
|
+
pause: () => void;
|
|
69
|
+
toggle: () => Promise<void>;
|
|
70
|
+
seek: (seconds: number) => void;
|
|
71
|
+
seekTo: (ratio: number) => void;
|
|
72
|
+
setVolume: (v: number) => void;
|
|
73
|
+
toggleMute: () => void;
|
|
74
|
+
toggleLoop: () => void;
|
|
75
|
+
};
|
|
76
|
+
type PlayerHandle = {
|
|
77
|
+
audio: HTMLAudioElement;
|
|
78
|
+
play: () => Promise<void>;
|
|
79
|
+
pause: () => void;
|
|
80
|
+
seek: (seconds: number) => void;
|
|
81
|
+
getCurrentTime: () => number;
|
|
82
|
+
getDuration: () => number;
|
|
83
|
+
/** Move keyboard focus to the player container so its hotkey scope
|
|
84
|
+
* (Space=play/pause, ←→=seek, ↑↓=volume, M=mute) becomes active. */
|
|
85
|
+
focus: () => void;
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
declare const Player: react.ForwardRefExoticComponent<PlayerProps & react.RefAttributes<PlayerHandle>>;
|
|
89
|
+
|
|
90
|
+
type LevelsStore = {
|
|
91
|
+
subscribe: (cb: () => void) => () => void;
|
|
92
|
+
getCurrent: () => Float32Array;
|
|
93
|
+
set: (next: Float32Array) => void;
|
|
94
|
+
setActive: (active: boolean) => void;
|
|
95
|
+
isActive: () => boolean;
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
type Listener$1 = (activeId: string | null) => void;
|
|
99
|
+
declare function setActivePlayer(id: string | null): void;
|
|
100
|
+
declare function getActivePlayer(): string | null;
|
|
101
|
+
declare function getLastActivePlayer(): string | null;
|
|
102
|
+
declare function subscribeActivePlayer(cb: Listener$1): () => void;
|
|
103
|
+
|
|
104
|
+
type PlayerPreferences = {
|
|
105
|
+
volume: number;
|
|
106
|
+
muted: boolean;
|
|
107
|
+
};
|
|
108
|
+
type Listener = (prefs: PlayerPreferences) => void;
|
|
109
|
+
declare function getPreferences(): PlayerPreferences;
|
|
110
|
+
declare function setStoredVolume(volume: number): void;
|
|
111
|
+
declare function setStoredMuted(muted: boolean): void;
|
|
112
|
+
declare function subscribePreferences(cb: Listener): () => void;
|
|
113
|
+
|
|
114
|
+
type PlayerMeta = {
|
|
115
|
+
src: string;
|
|
116
|
+
title?: string;
|
|
117
|
+
artist?: string;
|
|
118
|
+
album?: string;
|
|
119
|
+
cover?: string;
|
|
120
|
+
hasPrev: boolean;
|
|
121
|
+
hasNext: boolean;
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
type PlayerProviderProps = {
|
|
125
|
+
src: string;
|
|
126
|
+
peaks?: Float32Array;
|
|
127
|
+
title?: string;
|
|
128
|
+
artist?: string;
|
|
129
|
+
album?: string;
|
|
130
|
+
cover?: string;
|
|
131
|
+
autoplay?: boolean;
|
|
132
|
+
loop?: boolean;
|
|
133
|
+
initialVolume?: number;
|
|
134
|
+
muted?: boolean;
|
|
135
|
+
preload?: 'none' | 'metadata' | 'auto';
|
|
136
|
+
exclusive?: boolean;
|
|
137
|
+
onPrev?: () => void;
|
|
138
|
+
onNext?: () => void;
|
|
139
|
+
onPlay?: () => void;
|
|
140
|
+
onPause?: () => void;
|
|
141
|
+
onEnded?: () => void;
|
|
142
|
+
onError?: (reason: PlayerErrorReason, e: unknown) => void;
|
|
143
|
+
children: ReactNode;
|
|
144
|
+
};
|
|
145
|
+
declare function PlayerProvider(props: PlayerProviderProps): react_jsx_runtime.JSX.Element;
|
|
146
|
+
|
|
147
|
+
declare const usePlayerState: () => PlayerState;
|
|
148
|
+
declare const usePlayerControls: () => PlayerControls;
|
|
149
|
+
declare const usePlayerLevels: () => LevelsStore;
|
|
150
|
+
declare const usePlayerMeta: () => PlayerMeta;
|
|
151
|
+
declare const usePlayerAudio: () => HTMLAudioElement;
|
|
152
|
+
declare const usePlayerPaused: () => boolean;
|
|
153
|
+
declare const usePlayerDuration: () => number;
|
|
154
|
+
|
|
155
|
+
/** Currently active player id. `null` when nothing plays. */
|
|
156
|
+
declare function useActivePlayer(): string | null;
|
|
157
|
+
/** Most recently active player id. Stays set after pause; useful for "last
|
|
158
|
+
* played" UIs where you want to keep showing a track even when paused. */
|
|
159
|
+
declare function useLastActivePlayer(): string | null;
|
|
160
|
+
/** True when the given id is currently active. Convenience for conditional
|
|
161
|
+
* styling without comparing strings inline. */
|
|
162
|
+
declare function useIsActivePlayer(id: string | null | undefined): boolean;
|
|
163
|
+
|
|
164
|
+
declare function usePlayerPreferences(): PlayerPreferences;
|
|
165
|
+
|
|
166
|
+
export { Player as LazyPlayer, Player, type PlayerControls, type PlayerErrorReason, type PlayerHandle, type PlayerPreferences, type PlayerProps, PlayerProvider, type PlayerState, type PlayerStateKind, type PlayerVariant, type ReactiveCoverMode, type WaveformConfig, type WaveformMode, getActivePlayer, getLastActivePlayer, getPreferences, setActivePlayer, setStoredMuted, setStoredVolume, subscribeActivePlayer, subscribePreferences, useActivePlayer, useIsActivePlayer, useLastActivePlayer, usePlayerAudio, usePlayerControls, usePlayerDuration, usePlayerLevels, usePlayerMeta, usePlayerPaused, usePlayerPreferences, usePlayerState };
|