@hanifhan1f/vidstack-react 1.12.13 → 1.12.15

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 (392) hide show
  1. package/dev/chunks/vidstack-B-FM4-oZ.js +668 -0
  2. package/dev/chunks/vidstack-B92UncBI.js +61 -0
  3. package/dev/chunks/vidstack-BDiAEW1N.js +11691 -0
  4. package/dev/chunks/vidstack-BZIhWvGa.js +1371 -0
  5. package/dev/chunks/vidstack-Bfi_jCvb.js +476 -0
  6. package/dev/chunks/vidstack-CBF7iUqu.js +22 -0
  7. package/dev/chunks/vidstack-CFZ0rYJz.js +34 -0
  8. package/dev/chunks/vidstack-CM82l-7o.js +551 -0
  9. package/dev/chunks/vidstack-CvWDiSTs.js +84 -0
  10. package/dev/chunks/vidstack-CzU-uC5f.js +189 -0
  11. package/dev/chunks/vidstack-D-hQD1eE.js +9 -0
  12. package/dev/chunks/vidstack-D6_9yy0x.js +643 -0
  13. package/dev/chunks/vidstack-DJQOTrl6.js +180 -0
  14. package/dev/chunks/vidstack-DNbKNc4R.js +288 -0
  15. package/dev/chunks/vidstack-D_bWd66h.js +2023 -0
  16. package/dev/chunks/vidstack-Dm1xEU9Q.js +36 -0
  17. package/dev/chunks/vidstack-f6WXkmfP.js +375 -0
  18. package/dev/chunks/vidstack-krOAtKMi.js +34 -0
  19. package/dev/chunks/vidstack-lYFZKRUc.js +401 -0
  20. package/dev/chunks/vidstack-vz-aZSfo.js +1497 -0
  21. package/dev/player/vidstack-default-components.js +14 -0
  22. package/dev/player/vidstack-default-icons.js +88 -0
  23. package/dev/player/vidstack-default-layout.js +14 -0
  24. package/dev/player/vidstack-plyr-icons.js +62 -0
  25. package/dev/player/vidstack-plyr-layout.js +636 -0
  26. package/dev/player/vidstack-remotion.js +345 -0
  27. package/dev/vidstack.js +587 -0
  28. package/dom.d.ts +91 -0
  29. package/google-cast.d.ts +1422 -0
  30. package/icons.d.ts +5 -0
  31. package/index.d.ts +8 -0
  32. package/package.json +9 -60
  33. package/player/layouts/default.d.ts +11392 -0
  34. package/player/layouts/plyr.d.ts +5 -0
  35. package/player/remotion.d.ts +5 -0
  36. package/player/styles/base.css +153 -0
  37. package/player/styles/default/buffering.css +55 -0
  38. package/player/styles/default/buttons.css +175 -0
  39. package/player/styles/default/captions.css +181 -0
  40. package/player/styles/default/chapter-title.css +26 -0
  41. package/player/styles/default/controls.css +56 -0
  42. package/player/styles/default/gestures.css +19 -0
  43. package/player/styles/default/icons.css +6 -0
  44. package/player/styles/default/keyboard.css +148 -0
  45. package/player/styles/default/layouts/audio.css +417 -0
  46. package/player/styles/default/layouts/video.css +1082 -0
  47. package/player/styles/default/menus.css +959 -0
  48. package/player/styles/default/poster.css +52 -0
  49. package/player/styles/default/sliders.css +391 -0
  50. package/player/styles/default/theme.css +2461 -0
  51. package/player/styles/default/thumbnail.css +40 -0
  52. package/player/styles/default/time.css +45 -0
  53. package/player/styles/default/tooltips.css +141 -0
  54. package/player/styles/plyr/theme.css +1237 -0
  55. package/prod/chunks/vidstack-0Foyib2F.js +34 -0
  56. package/prod/chunks/vidstack-BbPEqH3g.js +11196 -0
  57. package/prod/chunks/vidstack-Bh7M8kL6.js +663 -0
  58. package/prod/chunks/vidstack-BlPINAXN.js +189 -0
  59. package/prod/chunks/vidstack-C5Rzkyfp.js +375 -0
  60. package/prod/chunks/vidstack-CBF7iUqu.js +22 -0
  61. package/prod/chunks/vidstack-CZNlvfmV.js +288 -0
  62. package/prod/chunks/vidstack-CZgUA94N.js +1979 -0
  63. package/prod/chunks/vidstack-Ce0Qn3e1.js +1497 -0
  64. package/prod/chunks/vidstack-D0XCUWbp.js +159 -0
  65. package/prod/chunks/vidstack-DTyDOhwS.js +504 -0
  66. package/prod/chunks/vidstack-DhC5F6c8.js +470 -0
  67. package/prod/chunks/vidstack-Dm1xEU9Q.js +36 -0
  68. package/prod/chunks/vidstack-Ma9rwtR0.js +386 -0
  69. package/prod/chunks/vidstack-WsodkLQg.js +1371 -0
  70. package/prod/chunks/vidstack-jIPoNqhj.js +545 -0
  71. package/prod/chunks/vidstack-krOAtKMi.js +34 -0
  72. package/prod/chunks/vidstack-vqp2QaHR.js +9 -0
  73. package/prod/chunks/vidstack-xo_SmgiV.js +84 -0
  74. package/prod/chunks/vidstack-xvxeRtaN.js +61 -0
  75. package/prod/player/vidstack-default-components.js +14 -0
  76. package/prod/player/vidstack-default-icons.js +88 -0
  77. package/prod/player/vidstack-default-layout.js +14 -0
  78. package/prod/player/vidstack-plyr-icons.js +62 -0
  79. package/prod/player/vidstack-plyr-layout.js +636 -0
  80. package/prod/player/vidstack-remotion.js +335 -0
  81. package/prod/vidstack-icons.js +435 -0
  82. package/prod/vidstack.js +648 -0
  83. package/server/chunks/vidstack-2zMSe4ym.js +1371 -0
  84. package/server/chunks/vidstack-BtqWstSj.js +375 -0
  85. package/server/chunks/vidstack-C-HdFsZi.js +84 -0
  86. package/server/chunks/vidstack-C4iWXMC-.js +545 -0
  87. package/server/chunks/vidstack-C5zFBMwg.js +386 -0
  88. package/server/chunks/vidstack-CBF7iUqu.js +22 -0
  89. package/server/chunks/vidstack-CEh38XpD.js +288 -0
  90. package/server/chunks/vidstack-CWR0J8Qz.js +1497 -0
  91. package/server/chunks/vidstack-CkMAeO-e.js +34 -0
  92. package/server/chunks/vidstack-Cm0qnRvu.js +11196 -0
  93. package/server/chunks/vidstack-CoGzBr_V.js +663 -0
  94. package/server/chunks/vidstack-CyFwkPiu.js +470 -0
  95. package/server/chunks/vidstack-D-hQD1eE.js +9 -0
  96. package/server/chunks/vidstack-D_bWd66h.js +2023 -0
  97. package/server/chunks/vidstack-Dm1xEU9Q.js +36 -0
  98. package/server/chunks/vidstack-DtQSvsQr.js +189 -0
  99. package/server/chunks/vidstack-jlaBqZq5.js +61 -0
  100. package/server/chunks/vidstack-krOAtKMi.js +34 -0
  101. package/server/chunks/vidstack-rWs25cS9.js +159 -0
  102. package/server/chunks/vidstack-uyCXITen.js +504 -0
  103. package/server/player/vidstack-default-components.js +14 -0
  104. package/server/player/vidstack-default-icons.js +88 -0
  105. package/server/player/vidstack-default-layout.js +14 -0
  106. package/server/player/vidstack-plyr-icons.js +62 -0
  107. package/server/player/vidstack-plyr-layout.js +636 -0
  108. package/server/player/vidstack-remotion.js +335 -0
  109. package/server/vidstack.js +648 -0
  110. package/tailwind.cjs +101 -0
  111. package/tailwind.d.cts +15 -0
  112. package/.templates/sandbox/document.css +0 -27
  113. package/.templates/sandbox/favicon-32x32.png +0 -0
  114. package/.templates/sandbox/index.html +0 -21
  115. package/.templates/sandbox/main.tsx +0 -12
  116. package/.templates/sandbox/player.css +0 -39
  117. package/.templates/sandbox/player.tsx +0 -121
  118. package/.templates/sandbox/tracks.ts +0 -23
  119. package/analyze.config.ts +0 -7
  120. package/build/build-icons.js +0 -62
  121. package/rollup.config.ts +0 -256
  122. package/src/components/announcer.tsx +0 -47
  123. package/src/components/layouts/default/audio-layout.tsx +0 -231
  124. package/src/components/layouts/default/context.ts +0 -28
  125. package/src/components/layouts/default/hooks.ts +0 -13
  126. package/src/components/layouts/default/icons.tsx +0 -225
  127. package/src/components/layouts/default/index.ts +0 -11
  128. package/src/components/layouts/default/media-layout.tsx +0 -259
  129. package/src/components/layouts/default/slots.tsx +0 -98
  130. package/src/components/layouts/default/ui/announcer.tsx +0 -22
  131. package/src/components/layouts/default/ui/buttons.tsx +0 -301
  132. package/src/components/layouts/default/ui/captions.tsx +0 -16
  133. package/src/components/layouts/default/ui/controls.tsx +0 -12
  134. package/src/components/layouts/default/ui/keyboard-display.tsx +0 -132
  135. package/src/components/layouts/default/ui/menus/accessibility-menu.tsx +0 -100
  136. package/src/components/layouts/default/ui/menus/audio-menu.tsx +0 -167
  137. package/src/components/layouts/default/ui/menus/captions-menu.tsx +0 -61
  138. package/src/components/layouts/default/ui/menus/chapters-menu.tsx +0 -132
  139. package/src/components/layouts/default/ui/menus/font-menu.tsx +0 -331
  140. package/src/components/layouts/default/ui/menus/items/menu-checkbox.tsx +0 -72
  141. package/src/components/layouts/default/ui/menus/items/menu-items.tsx +0 -135
  142. package/src/components/layouts/default/ui/menus/items/menu-slider.tsx +0 -92
  143. package/src/components/layouts/default/ui/menus/playback-menu.tsx +0 -232
  144. package/src/components/layouts/default/ui/menus/settings-menu.tsx +0 -114
  145. package/src/components/layouts/default/ui/menus/utils.ts +0 -12
  146. package/src/components/layouts/default/ui/sliders.tsx +0 -136
  147. package/src/components/layouts/default/ui/time.tsx +0 -73
  148. package/src/components/layouts/default/ui/title.tsx +0 -24
  149. package/src/components/layouts/default/ui/tooltip.tsx +0 -27
  150. package/src/components/layouts/default/ui.ts +0 -8
  151. package/src/components/layouts/default/video-layout.tsx +0 -344
  152. package/src/components/layouts/plyr/context.ts +0 -26
  153. package/src/components/layouts/plyr/icons/plyr-airplay.js +0 -1
  154. package/src/components/layouts/plyr/icons/plyr-captions-off.js +0 -1
  155. package/src/components/layouts/plyr/icons/plyr-captions-on.js +0 -1
  156. package/src/components/layouts/plyr/icons/plyr-download.js +0 -1
  157. package/src/components/layouts/plyr/icons/plyr-enter-fullscreen.js +0 -1
  158. package/src/components/layouts/plyr/icons/plyr-exit-fullscreen.js +0 -1
  159. package/src/components/layouts/plyr/icons/plyr-fast-forward.js +0 -1
  160. package/src/components/layouts/plyr/icons/plyr-muted.js +0 -1
  161. package/src/components/layouts/plyr/icons/plyr-pause.js +0 -1
  162. package/src/components/layouts/plyr/icons/plyr-pip.js +0 -1
  163. package/src/components/layouts/plyr/icons/plyr-play.js +0 -1
  164. package/src/components/layouts/plyr/icons/plyr-restart.js +0 -1
  165. package/src/components/layouts/plyr/icons/plyr-rewind.js +0 -1
  166. package/src/components/layouts/plyr/icons/plyr-settings.js +0 -1
  167. package/src/components/layouts/plyr/icons/plyr-volume.js +0 -1
  168. package/src/components/layouts/plyr/icons.tsx +0 -71
  169. package/src/components/layouts/plyr/index.ts +0 -11
  170. package/src/components/layouts/plyr/layout.tsx +0 -1024
  171. package/src/components/layouts/plyr/props.ts +0 -104
  172. package/src/components/layouts/plyr/slots.tsx +0 -52
  173. package/src/components/layouts/remotion-ui.ts +0 -13
  174. package/src/components/layouts/utils.ts +0 -17
  175. package/src/components/player-callbacks.ts +0 -67
  176. package/src/components/player.tsx +0 -67
  177. package/src/components/primitives/instances.ts +0 -92
  178. package/src/components/primitives/nodes.tsx +0 -58
  179. package/src/components/primitives/slot.tsx +0 -132
  180. package/src/components/provider.tsx +0 -187
  181. package/src/components/text-track.tsx +0 -106
  182. package/src/components/ui/buttons/airplay-button.tsx +0 -53
  183. package/src/components/ui/buttons/caption-button.tsx +0 -55
  184. package/src/components/ui/buttons/fullscreen-button.tsx +0 -55
  185. package/src/components/ui/buttons/google-cast-button.tsx +0 -53
  186. package/src/components/ui/buttons/live-button.tsx +0 -56
  187. package/src/components/ui/buttons/mute-button.tsx +0 -60
  188. package/src/components/ui/buttons/pip-button.tsx +0 -54
  189. package/src/components/ui/buttons/play-button.tsx +0 -53
  190. package/src/components/ui/buttons/seek-button.tsx +0 -55
  191. package/src/components/ui/buttons/toggle-button.tsx +0 -51
  192. package/src/components/ui/caption.tsx +0 -70
  193. package/src/components/ui/captions.tsx +0 -41
  194. package/src/components/ui/chapter-title.tsx +0 -40
  195. package/src/components/ui/controls.tsx +0 -90
  196. package/src/components/ui/gesture.tsx +0 -43
  197. package/src/components/ui/menu.tsx +0 -251
  198. package/src/components/ui/poster.tsx +0 -101
  199. package/src/components/ui/radio-group.tsx +0 -88
  200. package/src/components/ui/sliders/audio-gain-slider.tsx +0 -55
  201. package/src/components/ui/sliders/quality-slider.tsx +0 -54
  202. package/src/components/ui/sliders/slider-callbacks.ts +0 -14
  203. package/src/components/ui/sliders/slider-value.tsx +0 -13
  204. package/src/components/ui/sliders/slider.tsx +0 -254
  205. package/src/components/ui/sliders/speed-slider.tsx +0 -54
  206. package/src/components/ui/sliders/time-slider.tsx +0 -379
  207. package/src/components/ui/sliders/volume-slider.tsx +0 -55
  208. package/src/components/ui/spinner.tsx +0 -105
  209. package/src/components/ui/thumbnail.tsx +0 -82
  210. package/src/components/ui/time.tsx +0 -77
  211. package/src/components/ui/title.tsx +0 -32
  212. package/src/components/ui/tooltip.tsx +0 -135
  213. package/src/globals.d.ts +0 -3
  214. package/src/hooks/create-text-track.ts +0 -22
  215. package/src/hooks/options/use-audio-gain-options.ts +0 -75
  216. package/src/hooks/options/use-audio-options.ts +0 -71
  217. package/src/hooks/options/use-caption-options.ts +0 -95
  218. package/src/hooks/options/use-chapter-options.ts +0 -97
  219. package/src/hooks/options/use-playback-rate-options.ts +0 -75
  220. package/src/hooks/options/use-video-quality-options.ts +0 -123
  221. package/src/hooks/use-active-text-cues.ts +0 -28
  222. package/src/hooks/use-active-text-track.ts +0 -19
  223. package/src/hooks/use-chapter-title.ts +0 -12
  224. package/src/hooks/use-dom.ts +0 -121
  225. package/src/hooks/use-media-context.ts +0 -6
  226. package/src/hooks/use-media-player.ts +0 -19
  227. package/src/hooks/use-media-provider.ts +0 -31
  228. package/src/hooks/use-media-remote.ts +0 -37
  229. package/src/hooks/use-media-state.ts +0 -58
  230. package/src/hooks/use-signals.ts +0 -24
  231. package/src/hooks/use-slider-preview.ts +0 -126
  232. package/src/hooks/use-slider-state.ts +0 -63
  233. package/src/hooks/use-state.ts +0 -47
  234. package/src/hooks/use-text-cues.ts +0 -33
  235. package/src/hooks/use-thumbnails.ts +0 -69
  236. package/src/icon.ts +0 -37
  237. package/src/icons.ts +0 -754
  238. package/src/index.ts +0 -181
  239. package/src/providers/remotion/index.ts +0 -10
  240. package/src/providers/remotion/layout-engine.ts +0 -123
  241. package/src/providers/remotion/loader.ts +0 -35
  242. package/src/providers/remotion/playback-engine.ts +0 -142
  243. package/src/providers/remotion/provider.tsx +0 -514
  244. package/src/providers/remotion/type-check.ts +0 -13
  245. package/src/providers/remotion/types.ts +0 -94
  246. package/src/providers/remotion/ui/context.tsx +0 -120
  247. package/src/providers/remotion/ui/error-boundary.tsx +0 -57
  248. package/src/providers/remotion/ui/poster.tsx +0 -33
  249. package/src/providers/remotion/ui/slider-thumbnail.tsx +0 -41
  250. package/src/providers/remotion/ui/thumbnail.tsx +0 -166
  251. package/src/providers/remotion/validate.ts +0 -220
  252. package/src/source.ts +0 -5
  253. package/src/utils.ts +0 -27
  254. package/tsconfig.build.json +0 -10
  255. package/tsconfig.json +0 -11
  256. package/types/react/src/components/announcer.d.ts +0 -16
  257. package/types/react/src/components/layouts/default/audio-layout.d.ts +0 -27
  258. package/types/react/src/components/layouts/default/context.d.ts +0 -14
  259. package/types/react/src/components/layouts/default/hooks.d.ts +0 -2
  260. package/types/react/src/components/layouts/default/icons.d.ts +0 -95
  261. package/types/react/src/components/layouts/default/index.d.ts +0 -5
  262. package/types/react/src/components/layouts/default/media-layout.d.ts +0 -133
  263. package/types/react/src/components/layouts/default/slots.d.ts +0 -22
  264. package/types/react/src/components/layouts/default/ui/announcer.d.ts +0 -6
  265. package/types/react/src/components/layouts/default/ui/buttons.d.ts +0 -54
  266. package/types/react/src/components/layouts/default/ui/captions.d.ts +0 -6
  267. package/types/react/src/components/layouts/default/ui/controls.d.ts +0 -6
  268. package/types/react/src/components/layouts/default/ui/keyboard-display.d.ts +0 -8
  269. package/types/react/src/components/layouts/default/ui/menus/accessibility-menu.d.ts +0 -10
  270. package/types/react/src/components/layouts/default/ui/menus/audio-menu.d.ts +0 -10
  271. package/types/react/src/components/layouts/default/ui/menus/captions-menu.d.ts +0 -10
  272. package/types/react/src/components/layouts/default/ui/menus/chapters-menu.d.ts +0 -7
  273. package/types/react/src/components/layouts/default/ui/menus/font-menu.d.ts +0 -6
  274. package/types/react/src/components/layouts/default/ui/menus/items/menu-checkbox.d.ts +0 -13
  275. package/types/react/src/components/layouts/default/ui/menus/items/menu-items.d.ts +0 -49
  276. package/types/react/src/components/layouts/default/ui/menus/items/menu-slider.d.ts +0 -26
  277. package/types/react/src/components/layouts/default/ui/menus/playback-menu.d.ts +0 -10
  278. package/types/react/src/components/layouts/default/ui/menus/settings-menu.d.ts +0 -15
  279. package/types/react/src/components/layouts/default/ui/menus/utils.d.ts +0 -1
  280. package/types/react/src/components/layouts/default/ui/sliders.d.ts +0 -24
  281. package/types/react/src/components/layouts/default/ui/time.d.ts +0 -30
  282. package/types/react/src/components/layouts/default/ui/title.d.ts +0 -6
  283. package/types/react/src/components/layouts/default/ui/tooltip.d.ts +0 -12
  284. package/types/react/src/components/layouts/default/ui.d.ts +0 -8
  285. package/types/react/src/components/layouts/default/video-layout.d.ts +0 -47
  286. package/types/react/src/components/layouts/plyr/context.d.ts +0 -12
  287. package/types/react/src/components/layouts/plyr/icons/plyr-airplay.d.ts +0 -2
  288. package/types/react/src/components/layouts/plyr/icons/plyr-captions-off.d.ts +0 -2
  289. package/types/react/src/components/layouts/plyr/icons/plyr-captions-on.d.ts +0 -2
  290. package/types/react/src/components/layouts/plyr/icons/plyr-download.d.ts +0 -2
  291. package/types/react/src/components/layouts/plyr/icons/plyr-enter-fullscreen.d.ts +0 -2
  292. package/types/react/src/components/layouts/plyr/icons/plyr-exit-fullscreen.d.ts +0 -2
  293. package/types/react/src/components/layouts/plyr/icons/plyr-fast-forward.d.ts +0 -2
  294. package/types/react/src/components/layouts/plyr/icons/plyr-muted.d.ts +0 -2
  295. package/types/react/src/components/layouts/plyr/icons/plyr-pause.d.ts +0 -2
  296. package/types/react/src/components/layouts/plyr/icons/plyr-pip.d.ts +0 -2
  297. package/types/react/src/components/layouts/plyr/icons/plyr-play.d.ts +0 -2
  298. package/types/react/src/components/layouts/plyr/icons/plyr-restart.d.ts +0 -2
  299. package/types/react/src/components/layouts/plyr/icons/plyr-rewind.d.ts +0 -2
  300. package/types/react/src/components/layouts/plyr/icons/plyr-settings.d.ts +0 -2
  301. package/types/react/src/components/layouts/plyr/icons/plyr-volume.d.ts +0 -2
  302. package/types/react/src/components/layouts/plyr/icons.d.ts +0 -25
  303. package/types/react/src/components/layouts/plyr/index.d.ts +0 -6
  304. package/types/react/src/components/layouts/plyr/layout.d.ts +0 -17
  305. package/types/react/src/components/layouts/plyr/props.d.ts +0 -71
  306. package/types/react/src/components/layouts/plyr/slots.d.ts +0 -9
  307. package/types/react/src/components/layouts/remotion-ui.d.ts +0 -3
  308. package/types/react/src/components/layouts/utils.d.ts +0 -1
  309. package/types/react/src/components/player-callbacks.d.ts +0 -6
  310. package/types/react/src/components/player.d.ts +0 -32
  311. package/types/react/src/components/primitives/instances.d.ts +0 -83
  312. package/types/react/src/components/primitives/nodes.d.ts +0 -15
  313. package/types/react/src/components/primitives/slot.d.ts +0 -11
  314. package/types/react/src/components/provider.d.ts +0 -26
  315. package/types/react/src/components/text-track.d.ts +0 -100
  316. package/types/react/src/components/ui/buttons/airplay-button.d.ts +0 -22
  317. package/types/react/src/components/ui/buttons/caption-button.d.ts +0 -24
  318. package/types/react/src/components/ui/buttons/fullscreen-button.d.ts +0 -24
  319. package/types/react/src/components/ui/buttons/google-cast-button.d.ts +0 -22
  320. package/types/react/src/components/ui/buttons/live-button.d.ts +0 -26
  321. package/types/react/src/components/ui/buttons/mute-button.d.ts +0 -30
  322. package/types/react/src/components/ui/buttons/pip-button.d.ts +0 -24
  323. package/types/react/src/components/ui/buttons/play-button.d.ts +0 -23
  324. package/types/react/src/components/ui/buttons/seek-button.d.ts +0 -25
  325. package/types/react/src/components/ui/buttons/toggle-button.d.ts +0 -22
  326. package/types/react/src/components/ui/caption.d.ts +0 -11
  327. package/types/react/src/components/ui/captions.d.ts +0 -20
  328. package/types/react/src/components/ui/chapter-title.d.ts +0 -20
  329. package/types/react/src/components/ui/controls.d.ts +0 -40
  330. package/types/react/src/components/ui/gesture.d.ts +0 -20
  331. package/types/react/src/components/ui/menu.d.ts +0 -102
  332. package/types/react/src/components/ui/poster.d.ts +0 -25
  333. package/types/react/src/components/ui/radio-group.d.ts +0 -39
  334. package/types/react/src/components/ui/sliders/audio-gain-slider.d.ts +0 -29
  335. package/types/react/src/components/ui/sliders/quality-slider.d.ts +0 -28
  336. package/types/react/src/components/ui/sliders/slider-callbacks.d.ts +0 -6
  337. package/types/react/src/components/ui/sliders/slider-value.d.ts +0 -9
  338. package/types/react/src/components/ui/sliders/slider.d.ts +0 -134
  339. package/types/react/src/components/ui/sliders/speed-slider.d.ts +0 -28
  340. package/types/react/src/components/ui/sliders/time-slider.d.ts +0 -124
  341. package/types/react/src/components/ui/sliders/volume-slider.d.ts +0 -29
  342. package/types/react/src/components/ui/spinner.d.ts +0 -31
  343. package/types/react/src/components/ui/thumbnail.d.ts +0 -26
  344. package/types/react/src/components/ui/time.d.ts +0 -20
  345. package/types/react/src/components/ui/title.d.ts +0 -15
  346. package/types/react/src/components/ui/tooltip.d.ts +0 -63
  347. package/types/react/src/hooks/create-text-track.d.ts +0 -7
  348. package/types/react/src/hooks/options/use-audio-gain-options.d.ts +0 -22
  349. package/types/react/src/hooks/options/use-audio-options.d.ts +0 -17
  350. package/types/react/src/hooks/options/use-caption-options.d.ts +0 -24
  351. package/types/react/src/hooks/options/use-chapter-options.d.ts +0 -18
  352. package/types/react/src/hooks/options/use-playback-rate-options.d.ts +0 -22
  353. package/types/react/src/hooks/options/use-video-quality-options.d.ts +0 -35
  354. package/types/react/src/hooks/use-active-text-cues.d.ts +0 -6
  355. package/types/react/src/hooks/use-active-text-track.d.ts +0 -5
  356. package/types/react/src/hooks/use-chapter-title.d.ts +0 -4
  357. package/types/react/src/hooks/use-dom.d.ts +0 -9
  358. package/types/react/src/hooks/use-media-context.d.ts +0 -1
  359. package/types/react/src/hooks/use-media-player.d.ts +0 -7
  360. package/types/react/src/hooks/use-media-provider.d.ts +0 -7
  361. package/types/react/src/hooks/use-media-remote.d.ts +0 -12
  362. package/types/react/src/hooks/use-media-state.d.ts +0 -15
  363. package/types/react/src/hooks/use-signals.d.ts +0 -5
  364. package/types/react/src/hooks/use-slider-preview.d.ts +0 -27
  365. package/types/react/src/hooks/use-slider-state.d.ts +0 -16
  366. package/types/react/src/hooks/use-state.d.ts +0 -18
  367. package/types/react/src/hooks/use-text-cues.d.ts +0 -6
  368. package/types/react/src/hooks/use-thumbnails.d.ts +0 -16
  369. package/types/react/src/icon.d.ts +0 -17
  370. package/types/react/src/icons.d.ts +0 -215
  371. package/types/react/src/index.d.ts +0 -78
  372. package/types/react/src/providers/remotion/index.d.ts +0 -7
  373. package/types/react/src/providers/remotion/layout-engine.d.ts +0 -8
  374. package/types/react/src/providers/remotion/loader.d.ts +0 -9
  375. package/types/react/src/providers/remotion/playback-engine.d.ts +0 -11
  376. package/types/react/src/providers/remotion/provider.d.ts +0 -26
  377. package/types/react/src/providers/remotion/type-check.d.ts +0 -6
  378. package/types/react/src/providers/remotion/types.d.ts +0 -91
  379. package/types/react/src/providers/remotion/ui/context.d.ts +0 -17
  380. package/types/react/src/providers/remotion/ui/error-boundary.d.ts +0 -21
  381. package/types/react/src/providers/remotion/ui/poster.d.ts +0 -18
  382. package/types/react/src/providers/remotion/ui/slider-thumbnail.d.ts +0 -17
  383. package/types/react/src/providers/remotion/ui/thumbnail.d.ts +0 -32
  384. package/types/react/src/providers/remotion/validate.d.ts +0 -12
  385. package/types/react/src/source.d.ts +0 -3
  386. package/types/react/src/utils.d.ts +0 -3
  387. package/types/vidstack/src/core/api/src-types.d.ts +0 -50
  388. package/types/vidstack/src/utils/mime.d.ts +0 -15
  389. package/types/vidstack/src/utils/network.d.ts +0 -17
  390. package/types/vidstack/src/utils/support.d.ts +0 -72
  391. package/vite.config.ts +0 -23
  392. /package/{npm/analyze.json.d.ts → analyze.json.d.ts} +0 -0
@@ -0,0 +1,401 @@
1
+ "use client"
2
+
3
+ import { peek, listenEvent, effect, DOMEvent, isString, camelToKebabCase, isUndefined, isFunction } from './vidstack-D_bWd66h.js';
4
+ import { QualitySymbol, RAFLoop, TextTrack, TextTrackSymbol, ListSymbol, IS_CHROME, coerceToError, loadScript, VideoProvider, isHLSSupported, preconnect } from './vidstack-BDiAEW1N.js';
5
+ import 'react';
6
+ import '@floating-ui/dom';
7
+
8
+ const toDOMEventType = (type) => camelToKebabCase(type);
9
+ class HLSController {
10
+ #video;
11
+ #ctx;
12
+ #instance = null;
13
+ #stopLiveSync = null;
14
+ config = {};
15
+ #callbacks = /* @__PURE__ */ new Set();
16
+ get instance() {
17
+ return this.#instance;
18
+ }
19
+ constructor(video, ctx) {
20
+ this.#video = video;
21
+ this.#ctx = ctx;
22
+ }
23
+ setup(ctor) {
24
+ const { streamType } = this.#ctx.$state;
25
+ const isLive = peek(streamType).includes("live"), isLiveLowLatency = peek(streamType).includes("ll-");
26
+ this.#instance = new ctor({
27
+ lowLatencyMode: isLiveLowLatency,
28
+ backBufferLength: isLiveLowLatency ? 4 : isLive ? 8 : void 0,
29
+ renderTextTracksNatively: false,
30
+ ...this.config
31
+ });
32
+ const dispatcher = this.#dispatchHLSEvent.bind(this);
33
+ for (const event of Object.values(ctor.Events)) this.#instance.on(event, dispatcher);
34
+ this.#instance.on(ctor.Events.ERROR, this.#onError.bind(this));
35
+ for (const callback of this.#callbacks) callback(this.#instance);
36
+ this.#ctx.player.dispatch("hls-instance", {
37
+ detail: this.#instance
38
+ });
39
+ this.#instance.attachMedia(this.#video);
40
+ this.#instance.on(ctor.Events.AUDIO_TRACK_SWITCHED, this.#onAudioSwitch.bind(this));
41
+ this.#instance.on(ctor.Events.LEVEL_SWITCHED, this.#onLevelSwitched.bind(this));
42
+ this.#instance.on(ctor.Events.LEVEL_LOADED, this.#onLevelLoaded.bind(this));
43
+ this.#instance.on(ctor.Events.LEVEL_UPDATED, this.#onLevelUpdated.bind(this));
44
+ this.#instance.on(ctor.Events.NON_NATIVE_TEXT_TRACKS_FOUND, this.#onTracksFound.bind(this));
45
+ this.#instance.on(ctor.Events.CUES_PARSED, this.#onCuesParsed.bind(this));
46
+ this.#ctx.qualities[QualitySymbol.enableAuto] = this.#enableAutoQuality.bind(this);
47
+ listenEvent(this.#ctx.qualities, "change", this.#onUserQualityChange.bind(this));
48
+ listenEvent(this.#ctx.audioTracks, "change", this.#onUserAudioChange.bind(this));
49
+ this.#stopLiveSync = effect(this.#liveSync.bind(this));
50
+ }
51
+ #createDOMEvent(type, data) {
52
+ return new DOMEvent(toDOMEventType(type), { detail: data });
53
+ }
54
+ #liveSync() {
55
+ if (!this.#ctx.$state.live()) return;
56
+ const raf = new RAFLoop(this.#liveSyncPosition.bind(this));
57
+ raf.start();
58
+ return raf.stop.bind(raf);
59
+ }
60
+ #liveSyncPosition() {
61
+ this.#ctx.$state.liveSyncPosition.set(this.#instance?.liveSyncPosition ?? Infinity);
62
+ }
63
+ #dispatchHLSEvent(type, data) {
64
+ this.#ctx.player?.dispatch(this.#createDOMEvent(type, data));
65
+ }
66
+ #onTracksFound(eventType, data) {
67
+ const event = this.#createDOMEvent(eventType, data);
68
+ let currentTrack = -1;
69
+ for (let i = 0; i < data.tracks.length; i++) {
70
+ const nonNativeTrack = data.tracks[i], init = nonNativeTrack.subtitleTrack ?? nonNativeTrack.closedCaptions, track = new TextTrack({
71
+ id: `hls-${nonNativeTrack.kind}-${i}`,
72
+ src: init?.url,
73
+ label: nonNativeTrack.label,
74
+ language: init?.lang,
75
+ kind: nonNativeTrack.kind,
76
+ default: nonNativeTrack.default
77
+ });
78
+ track[TextTrackSymbol.readyState] = 2;
79
+ track[TextTrackSymbol.onModeChange] = () => {
80
+ if (track.mode === "showing") {
81
+ this.#instance.subtitleTrack = i;
82
+ currentTrack = i;
83
+ } else if (currentTrack === i) {
84
+ this.#instance.subtitleTrack = -1;
85
+ currentTrack = -1;
86
+ }
87
+ };
88
+ this.#ctx.textTracks.add(track, event);
89
+ }
90
+ }
91
+ #onCuesParsed(eventType, data) {
92
+ const index = this.#instance?.subtitleTrack, track = this.#ctx.textTracks.getById(`hls-${data.type}-${index}`);
93
+ if (!track) return;
94
+ const event = this.#createDOMEvent(eventType, data);
95
+ for (const cue of data.cues) {
96
+ cue.positionAlign = "auto";
97
+ track.addCue(cue, event);
98
+ }
99
+ }
100
+ #onAudioSwitch(eventType, data) {
101
+ const track = this.#ctx.audioTracks[data.id];
102
+ if (track) {
103
+ const trigger = this.#createDOMEvent(eventType, data);
104
+ this.#ctx.audioTracks[ListSymbol.select](track, true, trigger);
105
+ }
106
+ }
107
+ #onLevelSwitched(eventType, data) {
108
+ const quality = this.#ctx.qualities[data.level];
109
+ if (quality) {
110
+ const trigger = this.#createDOMEvent(eventType, data);
111
+ this.#ctx.qualities[ListSymbol.select](quality, true, trigger);
112
+ }
113
+ }
114
+ #onLevelUpdated(eventType, data) {
115
+ if (data.details.totalduration > 0) {
116
+ this.#ctx.$state.inferredLiveDVRWindow.set(data.details.totalduration);
117
+ }
118
+ }
119
+ #onLevelLoaded(eventType, data) {
120
+ if (this.#ctx.$state.canPlay()) return;
121
+ const { type, live, totalduration: duration, targetduration } = data.details, trigger = this.#createDOMEvent(eventType, data);
122
+ this.#ctx.notify(
123
+ "stream-type-change",
124
+ live ? type === "EVENT" && Number.isFinite(duration) && targetduration >= 10 ? "live:dvr" : "live" : "on-demand",
125
+ trigger
126
+ );
127
+ this.#ctx.notify("duration-change", duration, trigger);
128
+ const media = this.#instance.media;
129
+ if (this.#instance.currentLevel === -1) {
130
+ this.#ctx.qualities[QualitySymbol.setAuto](true, trigger);
131
+ }
132
+ for (const remoteTrack of this.#instance.audioTracks) {
133
+ const localTrack = {
134
+ id: remoteTrack.id.toString(),
135
+ label: remoteTrack.name,
136
+ language: remoteTrack.lang || "",
137
+ kind: "main"
138
+ };
139
+ this.#ctx.audioTracks[ListSymbol.add](localTrack, trigger);
140
+ }
141
+ for (const level of this.#instance.levels) {
142
+ const videoQuality = {
143
+ id: level.id?.toString() ?? level.height + "p",
144
+ width: level.width,
145
+ height: level.height,
146
+ codec: level.codecSet,
147
+ bitrate: level.bitrate
148
+ };
149
+ this.#ctx.qualities[ListSymbol.add](videoQuality, trigger);
150
+ }
151
+ media.dispatchEvent(new DOMEvent("canplay", { trigger }));
152
+ }
153
+ #onError(eventType, data) {
154
+ {
155
+ this.#ctx.logger?.errorGroup(`[vidstack] HLS error \`${eventType}\``).labelledLog("Media Element", this.#instance?.media).labelledLog("HLS Instance", this.#instance).labelledLog("Event Type", eventType).labelledLog("Data", data).labelledLog("Src", peek(this.#ctx.$state.source)).labelledLog("Media Store", { ...this.#ctx.$state }).dispatch();
156
+ }
157
+ if (data.fatal) {
158
+ switch (data.type) {
159
+ case "mediaError":
160
+ this.#instance?.recoverMediaError();
161
+ break;
162
+ default:
163
+ this.#onFatalError(data.error);
164
+ break;
165
+ }
166
+ }
167
+ }
168
+ #onFatalError(error) {
169
+ this.#ctx.notify("error", {
170
+ message: error.message,
171
+ code: 1,
172
+ error
173
+ });
174
+ }
175
+ #enableAutoQuality() {
176
+ if (this.#instance) this.#instance.currentLevel = -1;
177
+ }
178
+ #onUserQualityChange() {
179
+ const { qualities } = this.#ctx;
180
+ if (!this.#instance || qualities.auto) return;
181
+ this.#instance[qualities.switch + "Level"] = qualities.selectedIndex;
182
+ if (IS_CHROME) {
183
+ this.#video.currentTime = this.#video.currentTime;
184
+ }
185
+ }
186
+ #onUserAudioChange() {
187
+ const { audioTracks } = this.#ctx;
188
+ if (this.#instance && this.#instance.audioTrack !== audioTracks.selectedIndex) {
189
+ this.#instance.audioTrack = audioTracks.selectedIndex;
190
+ }
191
+ }
192
+ onInstance(callback) {
193
+ this.#callbacks.add(callback);
194
+ return () => this.#callbacks.delete(callback);
195
+ }
196
+ loadSource(src) {
197
+ if (!isString(src.src)) return;
198
+ this.#instance?.loadSource(src.src);
199
+ }
200
+ destroy() {
201
+ this.#instance?.destroy();
202
+ this.#instance = null;
203
+ this.#stopLiveSync?.();
204
+ this.#stopLiveSync = null;
205
+ this.#ctx?.logger?.info("\u{1F3D7}\uFE0F Destroyed HLS instance");
206
+ }
207
+ }
208
+
209
+ class HLSLibLoader {
210
+ #lib;
211
+ #ctx;
212
+ #callback;
213
+ constructor(lib, ctx, callback) {
214
+ this.#lib = lib;
215
+ this.#ctx = ctx;
216
+ this.#callback = callback;
217
+ this.#startLoading();
218
+ }
219
+ async #startLoading() {
220
+ this.#ctx.logger?.info("\u{1F3D7}\uFE0F Loading HLS Library");
221
+ const callbacks = {
222
+ onLoadStart: this.#onLoadStart.bind(this),
223
+ onLoaded: this.#onLoaded.bind(this),
224
+ onLoadError: this.#onLoadError.bind(this)
225
+ };
226
+ let ctor = await loadHLSScript(this.#lib, callbacks);
227
+ if (isUndefined(ctor) && !isString(this.#lib)) ctor = await importHLS(this.#lib, callbacks);
228
+ if (!ctor) return null;
229
+ if (!ctor.isSupported()) {
230
+ const message = "[vidstack] `hls.js` is not supported in this environment";
231
+ this.#ctx.logger?.error(message);
232
+ this.#ctx.player.dispatch(new DOMEvent("hls-unsupported"));
233
+ this.#ctx.notify("error", { message, code: 4 });
234
+ return null;
235
+ }
236
+ return ctor;
237
+ }
238
+ #onLoadStart() {
239
+ {
240
+ this.#ctx.logger?.infoGroup("Starting to load `hls.js`").labelledLog("URL", this.#lib).dispatch();
241
+ }
242
+ this.#ctx.player.dispatch(new DOMEvent("hls-lib-load-start"));
243
+ }
244
+ #onLoaded(ctor) {
245
+ {
246
+ this.#ctx.logger?.infoGroup("Loaded `hls.js`").labelledLog("Library", this.#lib).labelledLog("Constructor", ctor).dispatch();
247
+ }
248
+ this.#ctx.player.dispatch(
249
+ new DOMEvent("hls-lib-loaded", {
250
+ detail: ctor
251
+ })
252
+ );
253
+ this.#callback(ctor);
254
+ }
255
+ #onLoadError(e) {
256
+ const error = coerceToError(e);
257
+ {
258
+ this.#ctx.logger?.errorGroup("[vidstack] Failed to load `hls.js`").labelledLog("Library", this.#lib).labelledLog("Error", e).dispatch();
259
+ }
260
+ this.#ctx.player.dispatch(
261
+ new DOMEvent("hls-lib-load-error", {
262
+ detail: error
263
+ })
264
+ );
265
+ this.#ctx.notify("error", {
266
+ message: error.message,
267
+ code: 4,
268
+ error
269
+ });
270
+ }
271
+ }
272
+ async function importHLS(loader, callbacks = {}) {
273
+ if (isUndefined(loader)) return void 0;
274
+ callbacks.onLoadStart?.();
275
+ if (loader.prototype && loader.prototype !== Function) {
276
+ callbacks.onLoaded?.(loader);
277
+ return loader;
278
+ }
279
+ try {
280
+ const ctor = (await loader())?.default;
281
+ if (ctor && !!ctor.isSupported) {
282
+ callbacks.onLoaded?.(ctor);
283
+ } else {
284
+ throw Error(
285
+ true ? "[vidstack] failed importing `hls.js`. Dynamic import returned invalid constructor." : ""
286
+ );
287
+ }
288
+ return ctor;
289
+ } catch (err) {
290
+ callbacks.onLoadError?.(err);
291
+ }
292
+ return void 0;
293
+ }
294
+ async function loadHLSScript(src, callbacks = {}) {
295
+ if (!isString(src)) return void 0;
296
+ callbacks.onLoadStart?.();
297
+ try {
298
+ await loadScript(src);
299
+ if (!isFunction(window.Hls)) {
300
+ throw Error(
301
+ true ? "[vidstack] failed loading `hls.js`. Could not find a valid `Hls` constructor on window" : ""
302
+ );
303
+ }
304
+ const ctor = window.Hls;
305
+ callbacks.onLoaded?.(ctor);
306
+ return ctor;
307
+ } catch (err) {
308
+ callbacks.onLoadError?.(err);
309
+ }
310
+ return void 0;
311
+ }
312
+
313
+ const JS_DELIVR_CDN = "https://cdn.jsdelivr.net";
314
+ class HLSProvider extends VideoProvider {
315
+ $$PROVIDER_TYPE = "HLS";
316
+ #ctor = null;
317
+ #controller = new HLSController(this.video, this.ctx);
318
+ /**
319
+ * The `hls.js` constructor.
320
+ */
321
+ get ctor() {
322
+ return this.#ctor;
323
+ }
324
+ /**
325
+ * The current `hls.js` instance.
326
+ */
327
+ get instance() {
328
+ return this.#controller.instance;
329
+ }
330
+ /**
331
+ * Whether `hls.js` is supported in this environment.
332
+ */
333
+ static supported = isHLSSupported();
334
+ get type() {
335
+ return "hls";
336
+ }
337
+ get canLiveSync() {
338
+ return true;
339
+ }
340
+ #library = `${JS_DELIVR_CDN}/npm/hls.js@^1.5.0/dist/hls${".js" }`;
341
+ /**
342
+ * The `hls.js` configuration object.
343
+ *
344
+ * @see {@link https://github.com/video-dev/hls.js/blob/master/docs/API.md#fine-tuning}
345
+ */
346
+ get config() {
347
+ return this.#controller.config;
348
+ }
349
+ set config(config) {
350
+ this.#controller.config = config;
351
+ }
352
+ /**
353
+ * The `hls.js` constructor (supports dynamic imports) or a URL of where it can be found.
354
+ *
355
+ * @defaultValue `https://cdn.jsdelivr.net/npm/hls.js@^1.0.0/dist/hls.min.js`
356
+ */
357
+ get library() {
358
+ return this.#library;
359
+ }
360
+ set library(library) {
361
+ this.#library = library;
362
+ }
363
+ preconnect() {
364
+ if (!isString(this.#library)) return;
365
+ preconnect(this.#library);
366
+ }
367
+ setup() {
368
+ super.setup();
369
+ new HLSLibLoader(this.#library, this.ctx, (ctor) => {
370
+ this.#ctor = ctor;
371
+ this.#controller.setup(ctor);
372
+ this.ctx.notify("provider-setup", this);
373
+ const src = peek(this.ctx.$state.source);
374
+ if (src) this.loadSource(src);
375
+ });
376
+ }
377
+ async loadSource(src, preload) {
378
+ if (!isString(src.src)) {
379
+ this.removeSource();
380
+ return;
381
+ }
382
+ this.media.preload = preload || "";
383
+ this.appendSource(src, "application/x-mpegurl");
384
+ this.#controller.loadSource(src);
385
+ this.currentSrc = src;
386
+ }
387
+ /**
388
+ * The given callback is invoked when a new `hls.js` instance is created and right before it's
389
+ * attached to media.
390
+ */
391
+ onInstance(callback) {
392
+ const instance = this.#controller.instance;
393
+ if (instance) callback(instance);
394
+ return this.#controller.onInstance(callback);
395
+ }
396
+ destroy() {
397
+ this.#controller.destroy();
398
+ }
399
+ }
400
+
401
+ export { HLSProvider };