@livepeer-frameworks/player-svelte 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/dist/DevModePanel.svelte +650 -0
  2. package/dist/DevModePanel.svelte.d.ts +31 -0
  3. package/dist/DvdLogo.svelte +213 -0
  4. package/dist/DvdLogo.svelte.d.ts +7 -0
  5. package/dist/Icons.svelte +27 -0
  6. package/dist/Icons.svelte.d.ts +25 -0
  7. package/dist/IdleScreen.svelte +752 -0
  8. package/dist/IdleScreen.svelte.d.ts +11 -0
  9. package/dist/LoadingScreen.svelte +689 -0
  10. package/dist/LoadingScreen.svelte.d.ts +7 -0
  11. package/dist/Player.svelte +482 -0
  12. package/dist/Player.svelte.d.ts +26 -0
  13. package/dist/PlayerControls.svelte +739 -0
  14. package/dist/PlayerControls.svelte.d.ts +20 -0
  15. package/dist/SeekBar.svelte +274 -0
  16. package/dist/SeekBar.svelte.d.ts +25 -0
  17. package/dist/SkipIndicator.svelte +95 -0
  18. package/dist/SkipIndicator.svelte.d.ts +14 -0
  19. package/dist/SpeedIndicator.svelte +38 -0
  20. package/dist/SpeedIndicator.svelte.d.ts +8 -0
  21. package/dist/StatsPanel.svelte +155 -0
  22. package/dist/StatsPanel.svelte.d.ts +27 -0
  23. package/dist/StreamStateOverlay.svelte +266 -0
  24. package/dist/StreamStateOverlay.svelte.d.ts +18 -0
  25. package/dist/SubtitleRenderer.svelte +234 -0
  26. package/dist/SubtitleRenderer.svelte.d.ts +41 -0
  27. package/dist/ThumbnailOverlay.svelte +96 -0
  28. package/dist/ThumbnailOverlay.svelte.d.ts +11 -0
  29. package/dist/TitleOverlay.svelte +47 -0
  30. package/dist/TitleOverlay.svelte.d.ts +9 -0
  31. package/dist/assets/logomark.svg +56 -0
  32. package/dist/components/VolumeIcons.svelte +53 -0
  33. package/dist/components/VolumeIcons.svelte.d.ts +10 -0
  34. package/dist/global.d.ts +15 -0
  35. package/dist/icons/FullscreenExitIcon.svelte +33 -0
  36. package/dist/icons/FullscreenExitIcon.svelte.d.ts +8 -0
  37. package/dist/icons/FullscreenIcon.svelte +33 -0
  38. package/dist/icons/FullscreenIcon.svelte.d.ts +8 -0
  39. package/dist/icons/PauseIcon.svelte +28 -0
  40. package/dist/icons/PauseIcon.svelte.d.ts +8 -0
  41. package/dist/icons/PictureInPictureIcon.svelte +28 -0
  42. package/dist/icons/PictureInPictureIcon.svelte.d.ts +8 -0
  43. package/dist/icons/PlayIcon.svelte +27 -0
  44. package/dist/icons/PlayIcon.svelte.d.ts +8 -0
  45. package/dist/icons/SeekToLiveIcon.svelte +30 -0
  46. package/dist/icons/SeekToLiveIcon.svelte.d.ts +8 -0
  47. package/dist/icons/SettingsIcon.svelte +40 -0
  48. package/dist/icons/SettingsIcon.svelte.d.ts +8 -0
  49. package/dist/icons/SkipBackIcon.svelte +32 -0
  50. package/dist/icons/SkipBackIcon.svelte.d.ts +8 -0
  51. package/dist/icons/SkipForwardIcon.svelte +32 -0
  52. package/dist/icons/SkipForwardIcon.svelte.d.ts +8 -0
  53. package/dist/icons/StatsIcon.svelte +29 -0
  54. package/dist/icons/StatsIcon.svelte.d.ts +8 -0
  55. package/dist/icons/VolumeOffIcon.svelte +29 -0
  56. package/dist/icons/VolumeOffIcon.svelte.d.ts +8 -0
  57. package/dist/icons/VolumeUpIcon.svelte +34 -0
  58. package/dist/icons/VolumeUpIcon.svelte.d.ts +8 -0
  59. package/dist/icons/index.d.ts +17 -0
  60. package/dist/icons/index.js +17 -0
  61. package/dist/index.d.ts +50 -0
  62. package/dist/index.js +54 -0
  63. package/dist/player.css +2 -0
  64. package/dist/stores/index.d.ts +15 -0
  65. package/dist/stores/index.js +21 -0
  66. package/dist/stores/playbackQuality.d.ts +43 -0
  67. package/dist/stores/playbackQuality.js +107 -0
  68. package/dist/stores/playerContext.d.ts +73 -0
  69. package/dist/stores/playerContext.js +166 -0
  70. package/dist/stores/playerController.d.ts +178 -0
  71. package/dist/stores/playerController.js +358 -0
  72. package/dist/stores/playerSelection.d.ts +84 -0
  73. package/dist/stores/playerSelection.js +159 -0
  74. package/dist/stores/streamState.d.ts +44 -0
  75. package/dist/stores/streamState.js +314 -0
  76. package/dist/stores/viewerEndpoints.d.ts +48 -0
  77. package/dist/stores/viewerEndpoints.js +178 -0
  78. package/dist/types.d.ts +4 -0
  79. package/dist/types.js +4 -0
  80. package/dist/ui/Badge.svelte +21 -0
  81. package/dist/ui/Badge.svelte.d.ts +32 -0
  82. package/dist/ui/Button.svelte +42 -0
  83. package/dist/ui/Button.svelte.d.ts +35 -0
  84. package/dist/ui/Slider.svelte +100 -0
  85. package/dist/ui/Slider.svelte.d.ts +17 -0
  86. package/dist/ui/badge.d.ts +6 -0
  87. package/dist/ui/badge.js +10 -0
  88. package/dist/ui/button.d.ts +8 -0
  89. package/dist/ui/button.js +21 -0
  90. package/dist/ui/context-menu/ContextMenuCheckboxItem.svelte +34 -0
  91. package/dist/ui/context-menu/ContextMenuCheckboxItem.svelte.d.ts +31 -0
  92. package/dist/ui/context-menu/ContextMenuContent.svelte +17 -0
  93. package/dist/ui/context-menu/ContextMenuContent.svelte.d.ts +7 -0
  94. package/dist/ui/context-menu/ContextMenuItem.svelte +22 -0
  95. package/dist/ui/context-menu/ContextMenuItem.svelte.d.ts +8 -0
  96. package/dist/ui/context-menu/ContextMenuLabel.svelte +22 -0
  97. package/dist/ui/context-menu/ContextMenuLabel.svelte.d.ts +8 -0
  98. package/dist/ui/context-menu/ContextMenuPortal.svelte +11 -0
  99. package/dist/ui/context-menu/ContextMenuPortal.svelte.d.ts +6 -0
  100. package/dist/ui/context-menu/ContextMenuRadioItem.svelte +21 -0
  101. package/dist/ui/context-menu/ContextMenuRadioItem.svelte.d.ts +31 -0
  102. package/dist/ui/context-menu/ContextMenuSeparator.svelte +14 -0
  103. package/dist/ui/context-menu/ContextMenuSeparator.svelte.d.ts +6 -0
  104. package/dist/ui/context-menu/ContextMenuShortcut.svelte +19 -0
  105. package/dist/ui/context-menu/ContextMenuShortcut.svelte.d.ts +7 -0
  106. package/dist/ui/context-menu/ContextMenuSubContent.svelte +20 -0
  107. package/dist/ui/context-menu/ContextMenuSubContent.svelte.d.ts +7 -0
  108. package/dist/ui/context-menu/ContextMenuSubTrigger.svelte +34 -0
  109. package/dist/ui/context-menu/ContextMenuSubTrigger.svelte.d.ts +8 -0
  110. package/dist/ui/context-menu/index.d.ts +17 -0
  111. package/dist/ui/context-menu/index.js +17 -0
  112. package/package.json +51 -0
  113. package/src/DevModePanel.svelte +650 -0
  114. package/src/DvdLogo.svelte +213 -0
  115. package/src/Icons.svelte +27 -0
  116. package/src/IdleScreen.svelte +739 -0
  117. package/src/LoadingScreen.svelte +674 -0
  118. package/src/Player.svelte +483 -0
  119. package/src/PlayerControls.svelte +752 -0
  120. package/src/SeekBar.svelte +274 -0
  121. package/src/SkipIndicator.svelte +95 -0
  122. package/src/SpeedIndicator.svelte +37 -0
  123. package/src/StatsPanel.svelte +155 -0
  124. package/src/StreamStateOverlay.svelte +266 -0
  125. package/src/SubtitleRenderer.svelte +234 -0
  126. package/src/ThumbnailOverlay.svelte +96 -0
  127. package/src/TitleOverlay.svelte +47 -0
  128. package/src/assets/logomark.svg +56 -0
  129. package/src/components/VolumeIcons.svelte +53 -0
  130. package/src/global.d.ts +15 -0
  131. package/src/icons/FullscreenExitIcon.svelte +33 -0
  132. package/src/icons/FullscreenIcon.svelte +33 -0
  133. package/src/icons/PauseIcon.svelte +28 -0
  134. package/src/icons/PictureInPictureIcon.svelte +28 -0
  135. package/src/icons/PlayIcon.svelte +27 -0
  136. package/src/icons/SeekToLiveIcon.svelte +30 -0
  137. package/src/icons/SettingsIcon.svelte +40 -0
  138. package/src/icons/SkipBackIcon.svelte +32 -0
  139. package/src/icons/SkipForwardIcon.svelte +32 -0
  140. package/src/icons/StatsIcon.svelte +29 -0
  141. package/src/icons/VolumeOffIcon.svelte +29 -0
  142. package/src/icons/VolumeUpIcon.svelte +34 -0
  143. package/src/icons/index.ts +18 -0
  144. package/src/index.ts +84 -0
  145. package/src/player.css +2 -0
  146. package/src/stores/index.ts +88 -0
  147. package/src/stores/playbackQuality.ts +137 -0
  148. package/src/stores/playerContext.ts +221 -0
  149. package/src/stores/playerController.ts +568 -0
  150. package/src/stores/playerSelection.ts +216 -0
  151. package/src/stores/streamState.ts +367 -0
  152. package/src/stores/viewerEndpoints.ts +224 -0
  153. package/src/types.ts +6 -0
  154. package/src/ui/Badge.svelte +21 -0
  155. package/src/ui/Button.svelte +42 -0
  156. package/src/ui/Slider.svelte +100 -0
  157. package/src/ui/badge.ts +20 -0
  158. package/src/ui/button.ts +35 -0
  159. package/src/ui/context-menu/ContextMenuCheckboxItem.svelte +34 -0
  160. package/src/ui/context-menu/ContextMenuContent.svelte +17 -0
  161. package/src/ui/context-menu/ContextMenuItem.svelte +22 -0
  162. package/src/ui/context-menu/ContextMenuLabel.svelte +22 -0
  163. package/src/ui/context-menu/ContextMenuPortal.svelte +11 -0
  164. package/src/ui/context-menu/ContextMenuRadioItem.svelte +21 -0
  165. package/src/ui/context-menu/ContextMenuSeparator.svelte +14 -0
  166. package/src/ui/context-menu/ContextMenuShortcut.svelte +19 -0
  167. package/src/ui/context-menu/ContextMenuSubContent.svelte +20 -0
  168. package/src/ui/context-menu/ContextMenuSubTrigger.svelte +34 -0
  169. package/src/ui/context-menu/index.ts +36 -0
@@ -0,0 +1,21 @@
1
+ <script lang="ts">
2
+ import { ContextMenu } from "bits-ui";
3
+ import { cn } from "@livepeer-frameworks/player-core";
4
+
5
+ let {
6
+ class: className,
7
+ value,
8
+ ...rest
9
+ }: { class?: string; value: string } & Record<string, any> = $props();
10
+ </script>
11
+
12
+ <ContextMenu.RadioItem
13
+ class={cn("fw-context-menu-checkbox", className)}
14
+ {value}
15
+ {...rest}
16
+ >
17
+ <div class="fw-context-menu-indicator">
18
+ <!-- Indicator state is managed by the underlying ContextMenu.RadioGroup. -->
19
+ </div>
20
+ <slot />
21
+ </ContextMenu.RadioItem>
@@ -0,0 +1,31 @@
1
+ type $$ComponentProps = {
2
+ class?: string;
3
+ value: string;
4
+ } & Record<string, any>;
5
+ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
6
+ new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
7
+ $$bindings?: Bindings;
8
+ } & Exports;
9
+ (internal: unknown, props: Props & {
10
+ $$events?: Events;
11
+ $$slots?: Slots;
12
+ }): Exports & {
13
+ $set?: any;
14
+ $on?: any;
15
+ };
16
+ z_$$bindings?: Bindings;
17
+ }
18
+ type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
19
+ default: any;
20
+ } ? Props extends Record<string, never> ? any : {
21
+ children?: any;
22
+ } : {});
23
+ declare const ContextMenuRadioItem: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<$$ComponentProps, {
24
+ default: {};
25
+ }>, {
26
+ [evt: string]: CustomEvent<any>;
27
+ }, {
28
+ default: {};
29
+ }, {}, "">;
30
+ type ContextMenuRadioItem = InstanceType<typeof ContextMenuRadioItem>;
31
+ export default ContextMenuRadioItem;
@@ -0,0 +1,14 @@
1
+ <script lang="ts">
2
+ import { ContextMenu } from "bits-ui";
3
+ import { cn } from "@livepeer-frameworks/player-core";
4
+
5
+ let {
6
+ class: className,
7
+ ...rest
8
+ }: { class?: string } = $props();
9
+ </script>
10
+
11
+ <ContextMenu.Separator
12
+ class={cn("fw-context-menu-separator", className)}
13
+ {...rest}
14
+ />
@@ -0,0 +1,6 @@
1
+ type $$ComponentProps = {
2
+ class?: string;
3
+ };
4
+ declare const ContextMenuSeparator: import("svelte").Component<$$ComponentProps, {}, "">;
5
+ type ContextMenuSeparator = ReturnType<typeof ContextMenuSeparator>;
6
+ export default ContextMenuSeparator;
@@ -0,0 +1,19 @@
1
+ <script lang="ts">
2
+ import { cn } from "@livepeer-frameworks/player-core";
3
+
4
+ let {
5
+ children,
6
+ class: className,
7
+ ...rest
8
+ }: { children?: any; class?: string } = $props();
9
+ </script>
10
+
11
+ <span
12
+ class={cn(
13
+ "ml-auto text-xs tracking-widest text-muted-foreground",
14
+ className
15
+ )}
16
+ {...rest}
17
+ >
18
+ {@render children?.()}
19
+ </span>
@@ -0,0 +1,7 @@
1
+ type $$ComponentProps = {
2
+ children?: any;
3
+ class?: string;
4
+ };
5
+ declare const ContextMenuShortcut: import("svelte").Component<$$ComponentProps, {}, "">;
6
+ type ContextMenuShortcut = ReturnType<typeof ContextMenuShortcut>;
7
+ export default ContextMenuShortcut;
@@ -0,0 +1,20 @@
1
+ <script lang="ts">
2
+ import { ContextMenu } from "bits-ui";
3
+ import { cn } from "@livepeer-frameworks/player-core";
4
+
5
+ let {
6
+ children,
7
+ class: className,
8
+ ...rest
9
+ }: { children?: any; class?: string } = $props();
10
+ </script>
11
+
12
+ <ContextMenu.SubContent
13
+ class={cn(
14
+ "z-50 min-w-[8rem] overflow-hidden rounded border border-[#5a607f]/30 bg-[#1a1b26] p-0 text-[#a9b1d6] shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
15
+ className
16
+ )}
17
+ {...rest}
18
+ >
19
+ {@render children?.()}
20
+ </ContextMenu.SubContent>
@@ -0,0 +1,7 @@
1
+ type $$ComponentProps = {
2
+ children?: any;
3
+ class?: string;
4
+ };
5
+ declare const ContextMenuSubContent: import("svelte").Component<$$ComponentProps, {}, "">;
6
+ type ContextMenuSubContent = ReturnType<typeof ContextMenuSubContent>;
7
+ export default ContextMenuSubContent;
@@ -0,0 +1,34 @@
1
+ <script lang="ts">
2
+ import { ContextMenu } from "bits-ui";
3
+ import { cn } from "@livepeer-frameworks/player-core";
4
+
5
+ let {
6
+ children,
7
+ class: className,
8
+ inset = false,
9
+ ...rest
10
+ }: { children?: any; class?: string; inset?: boolean } = $props();
11
+ </script>
12
+
13
+ <ContextMenu.SubTrigger
14
+ class={cn(
15
+ "flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-[#292e42] focus:text-[#c0caf5] data-[state=open]:bg-[#292e42] data-[state=open]:text-[#c0caf5] data-[highlighted]:bg-[#292e42] data-[highlighted]:text-[#c0caf5]",
16
+ inset && "pl-8",
17
+ className
18
+ )}
19
+ {...rest}
20
+ >
21
+ {@render children?.()}
22
+ <svg
23
+ xmlns="http://www.w3.org/2000/svg"
24
+ viewBox="0 0 24 24"
25
+ fill="none"
26
+ stroke="currentColor"
27
+ stroke-width="2"
28
+ stroke-linecap="round"
29
+ stroke-linejoin="round"
30
+ class="ml-auto h-4 w-4"
31
+ >
32
+ <polyline points="9 18 15 12 9 6" />
33
+ </svg>
34
+ </ContextMenu.SubTrigger>
@@ -0,0 +1,8 @@
1
+ type $$ComponentProps = {
2
+ children?: any;
3
+ class?: string;
4
+ inset?: boolean;
5
+ };
6
+ declare const ContextMenuSubTrigger: import("svelte").Component<$$ComponentProps, {}, "">;
7
+ type ContextMenuSubTrigger = ReturnType<typeof ContextMenuSubTrigger>;
8
+ export default ContextMenuSubTrigger;
@@ -0,0 +1,17 @@
1
+ import { ContextMenu as ContextMenuPrimitive } from "bits-ui";
2
+ import ContextMenuContent from "./ContextMenuContent.svelte";
3
+ import ContextMenuItem from "./ContextMenuItem.svelte";
4
+ import ContextMenuSeparator from "./ContextMenuSeparator.svelte";
5
+ import ContextMenuLabel from "./ContextMenuLabel.svelte";
6
+ import ContextMenuCheckboxItem from "./ContextMenuCheckboxItem.svelte";
7
+ import ContextMenuRadioItem from "./ContextMenuRadioItem.svelte";
8
+ import ContextMenuSubContent from "./ContextMenuSubContent.svelte";
9
+ import ContextMenuSubTrigger from "./ContextMenuSubTrigger.svelte";
10
+ import ContextMenuShortcut from "./ContextMenuShortcut.svelte";
11
+ import ContextMenuPortal from "./ContextMenuPortal.svelte";
12
+ declare const ContextMenu: import("svelte").Component<import("bits-ui").ContextMenuRootPropsWithoutHTML, {}, "open">;
13
+ declare const ContextMenuTrigger: import("svelte").Component<ContextMenuPrimitive.TriggerProps, {}, "ref">;
14
+ declare const ContextMenuGroup: import("svelte").Component<ContextMenuPrimitive.GroupProps, {}, "ref">;
15
+ declare const ContextMenuSub: import("svelte").Component<import("bits-ui").ContextMenuSubPropsWithoutHTML, {}, "open">;
16
+ declare const ContextMenuRadioGroup: import("svelte").Component<ContextMenuPrimitive.RadioGroupProps, {}, "value" | "ref">;
17
+ export { ContextMenu, ContextMenuTrigger, ContextMenuContent, ContextMenuItem, ContextMenuCheckboxItem, ContextMenuRadioItem, ContextMenuLabel, ContextMenuSeparator, ContextMenuShortcut, ContextMenuGroup, ContextMenuPortal, ContextMenuSub, ContextMenuSubContent, ContextMenuSubTrigger, ContextMenuRadioGroup, };
@@ -0,0 +1,17 @@
1
+ import { ContextMenu as ContextMenuPrimitive } from "bits-ui";
2
+ import ContextMenuContent from "./ContextMenuContent.svelte";
3
+ import ContextMenuItem from "./ContextMenuItem.svelte";
4
+ import ContextMenuSeparator from "./ContextMenuSeparator.svelte";
5
+ import ContextMenuLabel from "./ContextMenuLabel.svelte";
6
+ import ContextMenuCheckboxItem from "./ContextMenuCheckboxItem.svelte";
7
+ import ContextMenuRadioItem from "./ContextMenuRadioItem.svelte";
8
+ import ContextMenuSubContent from "./ContextMenuSubContent.svelte";
9
+ import ContextMenuSubTrigger from "./ContextMenuSubTrigger.svelte";
10
+ import ContextMenuShortcut from "./ContextMenuShortcut.svelte";
11
+ import ContextMenuPortal from "./ContextMenuPortal.svelte";
12
+ const ContextMenu = ContextMenuPrimitive.Root;
13
+ const ContextMenuTrigger = ContextMenuPrimitive.Trigger;
14
+ const ContextMenuGroup = ContextMenuPrimitive.Group;
15
+ const ContextMenuSub = ContextMenuPrimitive.Sub;
16
+ const ContextMenuRadioGroup = ContextMenuPrimitive.RadioGroup;
17
+ export { ContextMenu, ContextMenuTrigger, ContextMenuContent, ContextMenuItem, ContextMenuCheckboxItem, ContextMenuRadioItem, ContextMenuLabel, ContextMenuSeparator, ContextMenuShortcut, ContextMenuGroup, ContextMenuPortal, ContextMenuSub, ContextMenuSubContent, ContextMenuSubTrigger, ContextMenuRadioGroup, };
package/package.json ADDED
@@ -0,0 +1,51 @@
1
+ {
2
+ "name": "@livepeer-frameworks/player-svelte",
3
+ "version": "0.0.3",
4
+ "type": "module",
5
+ "description": "Svelte 5 components for FrameWorks streaming player",
6
+ "svelte": "./dist/index.js",
7
+ "main": "./dist/index.js",
8
+ "module": "./dist/index.js",
9
+ "types": "./dist/index.d.ts",
10
+ "files": [
11
+ "dist",
12
+ "src"
13
+ ],
14
+ "exports": {
15
+ ".": {
16
+ "svelte": "./dist/index.js",
17
+ "import": "./dist/index.js",
18
+ "types": "./dist/index.d.ts"
19
+ },
20
+ "./player.css": "./src/player.css"
21
+ },
22
+ "scripts": {
23
+ "build": "svelte-package -i src -o dist",
24
+ "build:watch": "svelte-package -i src -o dist --watch",
25
+ "type-check": "svelte-check"
26
+ },
27
+ "dependencies": {
28
+ "@livepeer-frameworks/player-core": "workspace:*",
29
+ "bits-ui": "^2.14.4"
30
+ },
31
+ "peerDependencies": {
32
+ "svelte": "^5.0.0"
33
+ },
34
+ "devDependencies": {
35
+ "@sveltejs/package": "^2.3.7",
36
+ "@sveltejs/vite-plugin-svelte": "^4.0.0",
37
+ "svelte": "^5.33.5",
38
+ "svelte-check": "^4.0.0",
39
+ "typescript": "^5.9.2",
40
+ "vite": "^5.4.0"
41
+ },
42
+ "keywords": [
43
+ "svelte",
44
+ "svelte5",
45
+ "streaming",
46
+ "player",
47
+ "video"
48
+ ],
49
+ "author": "Livepeer FrameWorks",
50
+ "license": "Unlicense"
51
+ }