@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,36 @@
1
+ "use client"
2
+
3
+ const videoIdRE = /(?:youtu\.be|youtube|youtube\.com|youtube-nocookie\.com)(?:\/shorts)?\/(?:embed\/|v\/|watch\?v=|watch\?.+&v=|)((?:\w|-){11})/;
4
+ const posterCache = /* @__PURE__ */ new Map();
5
+ const pendingFetch = /* @__PURE__ */ new Map();
6
+ function resolveYouTubeVideoId(src) {
7
+ return src.match(videoIdRE)?.[1];
8
+ }
9
+ async function findYouTubePoster(videoId, abort) {
10
+ if (posterCache.has(videoId)) return posterCache.get(videoId);
11
+ if (pendingFetch.has(videoId)) return pendingFetch.get(videoId);
12
+ const pending = new Promise(async (resolve) => {
13
+ const sizes = ["maxresdefault", "sddefault", "hqdefault"];
14
+ for (const size of sizes) {
15
+ for (const webp of [true, false]) {
16
+ const url = resolveYouTubePosterURL(videoId, size, webp), response = await fetch(url, {
17
+ mode: "no-cors",
18
+ signal: abort.signal
19
+ });
20
+ if (response.status < 400) {
21
+ posterCache.set(videoId, url);
22
+ resolve(url);
23
+ return;
24
+ }
25
+ }
26
+ }
27
+ }).catch(() => "").finally(() => pendingFetch.delete(videoId));
28
+ pendingFetch.set(videoId, pending);
29
+ return pending;
30
+ }
31
+ function resolveYouTubePosterURL(videoId, size, webp) {
32
+ const type = webp ? "webp" : "jpg";
33
+ return `https://i.ytimg.com/${webp ? "vi_webp" : "vi"}/${videoId}/${size}.${type}`;
34
+ }
35
+
36
+ export { findYouTubePoster, resolveYouTubeVideoId };
@@ -0,0 +1,375 @@
1
+ "use client"
2
+
3
+ import * as React from 'react';
4
+ import { createReactComponent, composeRefs, listenEvent, useReactScope, scoped, computed, signal, effect, EventsController, useSignal } from './vidstack-D_bWd66h.js';
5
+ import { MediaAnnouncerInstance, Primitive, ControlsInstance, ControlsGroupInstance, TooltipInstance, TooltipTriggerInstance, TooltipContentInstance, GoogleCastButtonInstance, QualitySliderInstance, AudioGainSliderInstance, SpeedSliderInstance, useMediaState, watchActiveTextTrack, CaptionsInstance, formatSpokenTime, formatTime } from './vidstack-BDiAEW1N.js';
6
+ import { sliderCallbacks, Preview, Steps, Thumb, Track as Track$1, TrackFill as TrackFill$1, Value, useMediaContext } from './vidstack-B-FM4-oZ.js';
7
+
8
+ const MediaAnnouncerBridge = createReactComponent(MediaAnnouncerInstance, {
9
+ events: ["onChange"]
10
+ });
11
+ const MediaAnnouncer = React.forwardRef(
12
+ ({ style, children, ...props }, forwardRef) => {
13
+ return /* @__PURE__ */ React.createElement(MediaAnnouncerBridge, { ...props }, (props2) => /* @__PURE__ */ React.createElement(
14
+ Primitive.div,
15
+ {
16
+ ...props2,
17
+ style: { display: "contents", ...style },
18
+ ref: composeRefs(props2.ref, forwardRef)
19
+ },
20
+ children
21
+ ));
22
+ }
23
+ );
24
+ MediaAnnouncer.displayName = "MediaAnnouncer";
25
+
26
+ const ControlsBridge = createReactComponent(ControlsInstance);
27
+ const Root$5 = React.forwardRef(({ children, ...props }, forwardRef) => {
28
+ return /* @__PURE__ */ React.createElement(ControlsBridge, { ...props }, (props2) => /* @__PURE__ */ React.createElement(
29
+ Primitive.div,
30
+ {
31
+ ...props2,
32
+ ref: composeRefs(props2.ref, forwardRef)
33
+ },
34
+ children
35
+ ));
36
+ });
37
+ Root$5.displayName = "Controls";
38
+ const ControlsGroupBridge = createReactComponent(ControlsGroupInstance);
39
+ const Group = React.forwardRef(({ children, ...props }, forwardRef) => {
40
+ return /* @__PURE__ */ React.createElement(ControlsGroupBridge, { ...props }, (props2) => /* @__PURE__ */ React.createElement(
41
+ Primitive.div,
42
+ {
43
+ ...props2,
44
+ ref: composeRefs(props2.ref, forwardRef)
45
+ },
46
+ children
47
+ ));
48
+ });
49
+ Group.displayName = "ControlsGroup";
50
+
51
+ var controls = /*#__PURE__*/Object.freeze({
52
+ __proto__: null,
53
+ Group: Group,
54
+ Root: Root$5
55
+ });
56
+
57
+ const TooltipBridge = createReactComponent(TooltipInstance);
58
+ function Root$4({ children, ...props }) {
59
+ return /* @__PURE__ */ React.createElement(TooltipBridge, { ...props }, children);
60
+ }
61
+ Root$4.displayName = "Tooltip";
62
+ const TriggerBridge = createReactComponent(TooltipTriggerInstance);
63
+ const Trigger = React.forwardRef(
64
+ ({ children, ...props }, forwardRef) => {
65
+ return /* @__PURE__ */ React.createElement(TriggerBridge, { ...props }, (props2) => /* @__PURE__ */ React.createElement(
66
+ Primitive.button,
67
+ {
68
+ ...props2,
69
+ ref: composeRefs(props2.ref, forwardRef)
70
+ },
71
+ children
72
+ ));
73
+ }
74
+ );
75
+ Trigger.displayName = "TooltipTrigger";
76
+ const ContentBridge = createReactComponent(TooltipContentInstance);
77
+ const Content = React.forwardRef(
78
+ ({ children, ...props }, forwardRef) => {
79
+ return /* @__PURE__ */ React.createElement(ContentBridge, { ...props }, (props2) => /* @__PURE__ */ React.createElement(
80
+ Primitive.div,
81
+ {
82
+ ...props2,
83
+ ref: composeRefs(props2.ref, forwardRef)
84
+ },
85
+ children
86
+ ));
87
+ }
88
+ );
89
+ Content.displayName = "TooltipContent";
90
+
91
+ var tooltip = /*#__PURE__*/Object.freeze({
92
+ __proto__: null,
93
+ Content: Content,
94
+ Root: Root$4,
95
+ Trigger: Trigger
96
+ });
97
+
98
+ const GoogleCastButtonBridge = createReactComponent(GoogleCastButtonInstance, {
99
+ domEventsRegex: /^onMedia/
100
+ });
101
+ const GoogleCastButton = React.forwardRef(
102
+ ({ children, ...props }, forwardRef) => {
103
+ return /* @__PURE__ */ React.createElement(GoogleCastButtonBridge, { ...props }, (props2) => /* @__PURE__ */ React.createElement(
104
+ Primitive.button,
105
+ {
106
+ ...props2,
107
+ ref: composeRefs(props2.ref, forwardRef)
108
+ },
109
+ children
110
+ ));
111
+ }
112
+ );
113
+ GoogleCastButton.displayName = "GoogleCastButton";
114
+
115
+ const QualitySliderBridge = createReactComponent(QualitySliderInstance, {
116
+ events: sliderCallbacks,
117
+ domEventsRegex: /^onMedia/
118
+ });
119
+ const Root$3 = React.forwardRef(
120
+ ({ children, ...props }, forwardRef) => {
121
+ return /* @__PURE__ */ React.createElement(QualitySliderBridge, { ...props, ref: forwardRef }, (props2) => /* @__PURE__ */ React.createElement(Primitive.div, { ...props2 }, children));
122
+ }
123
+ );
124
+ Root$3.displayName = "QualitySlider";
125
+
126
+ var qualitySlider = /*#__PURE__*/Object.freeze({
127
+ __proto__: null,
128
+ Preview: Preview,
129
+ Root: Root$3,
130
+ Steps: Steps,
131
+ Thumb: Thumb,
132
+ Track: Track$1,
133
+ TrackFill: TrackFill$1,
134
+ Value: Value
135
+ });
136
+
137
+ const AudioGainSliderBridge = createReactComponent(AudioGainSliderInstance, {
138
+ events: sliderCallbacks,
139
+ domEventsRegex: /^onMedia/
140
+ });
141
+ const Root$2 = React.forwardRef(
142
+ ({ children, ...props }, forwardRef) => {
143
+ return /* @__PURE__ */ React.createElement(AudioGainSliderBridge, { ...props, ref: forwardRef }, (props2) => /* @__PURE__ */ React.createElement(Primitive.div, { ...props2 }, children));
144
+ }
145
+ );
146
+ Root$2.displayName = "AudioGainSlider";
147
+
148
+ var audioGainSlider = /*#__PURE__*/Object.freeze({
149
+ __proto__: null,
150
+ Preview: Preview,
151
+ Root: Root$2,
152
+ Steps: Steps,
153
+ Thumb: Thumb,
154
+ Track: Track$1,
155
+ TrackFill: TrackFill$1,
156
+ Value: Value
157
+ });
158
+
159
+ const SpeedSliderBridge = createReactComponent(SpeedSliderInstance, {
160
+ events: sliderCallbacks,
161
+ domEventsRegex: /^onMedia/
162
+ });
163
+ const Root$1 = React.forwardRef(
164
+ ({ children, ...props }, forwardRef) => {
165
+ return /* @__PURE__ */ React.createElement(SpeedSliderBridge, { ...props, ref: forwardRef }, (props2) => /* @__PURE__ */ React.createElement(Primitive.div, { ...props2 }, children));
166
+ }
167
+ );
168
+ Root$1.displayName = "SpeedSlider";
169
+
170
+ var speedSlider = /*#__PURE__*/Object.freeze({
171
+ __proto__: null,
172
+ Preview: Preview,
173
+ Root: Root$1,
174
+ Steps: Steps,
175
+ Thumb: Thumb,
176
+ Track: Track$1,
177
+ TrackFill: TrackFill$1,
178
+ Value: Value
179
+ });
180
+
181
+ const Title = React.forwardRef(({ children, ...props }, forwardRef) => {
182
+ const $title = useMediaState("title");
183
+ return /* @__PURE__ */ React.createElement(Primitive.span, { ...props, ref: forwardRef }, $title, children);
184
+ });
185
+ Title.displayName = "Title";
186
+
187
+ function useActiveTextCues(track) {
188
+ const [activeCues, setActiveCues] = React.useState([]);
189
+ React.useEffect(() => {
190
+ if (!track) {
191
+ setActiveCues([]);
192
+ return;
193
+ }
194
+ function onCuesChange() {
195
+ if (track) setActiveCues(track.activeCues);
196
+ }
197
+ onCuesChange();
198
+ return listenEvent(track, "cue-change", onCuesChange);
199
+ }, [track]);
200
+ return activeCues;
201
+ }
202
+
203
+ function useActiveTextTrack(kind) {
204
+ const media = useMediaContext(), [track, setTrack] = React.useState(null);
205
+ React.useEffect(() => {
206
+ return watchActiveTextTrack(media.textTracks, kind, setTrack);
207
+ }, [kind]);
208
+ return track;
209
+ }
210
+
211
+ function useChapterTitle() {
212
+ const $track = useActiveTextTrack("chapters"), $cues = useActiveTextCues($track);
213
+ return $cues[0]?.text || "";
214
+ }
215
+
216
+ const ChapterTitle = React.forwardRef(
217
+ ({ defaultText = "", children, ...props }, forwardRef) => {
218
+ const $chapterTitle = useChapterTitle();
219
+ return /* @__PURE__ */ React.createElement(Primitive.span, { ...props, ref: forwardRef }, $chapterTitle || defaultText, children);
220
+ }
221
+ );
222
+ ChapterTitle.displayName = "ChapterTitle";
223
+
224
+ const CaptionsBridge = createReactComponent(CaptionsInstance);
225
+ const Captions = React.forwardRef(
226
+ ({ children, ...props }, forwardRef) => {
227
+ return /* @__PURE__ */ React.createElement(CaptionsBridge, { ...props, ref: forwardRef }, (props2) => /* @__PURE__ */ React.createElement(Primitive.div, { ...props2 }, children));
228
+ }
229
+ );
230
+ Captions.displayName = "Captions";
231
+
232
+ const Root = React.forwardRef(
233
+ ({ size = 96, children, ...props }, forwardRef) => {
234
+ return /* @__PURE__ */ React.createElement(
235
+ "svg",
236
+ {
237
+ width: size,
238
+ height: size,
239
+ fill: "none",
240
+ viewBox: "0 0 120 120",
241
+ "aria-hidden": "true",
242
+ "data-part": "root",
243
+ ...props,
244
+ ref: forwardRef
245
+ },
246
+ children
247
+ );
248
+ }
249
+ );
250
+ const Track = React.forwardRef(
251
+ ({ width = 8, children, ...props }, ref) => /* @__PURE__ */ React.createElement(
252
+ "circle",
253
+ {
254
+ cx: "60",
255
+ cy: "60",
256
+ r: "54",
257
+ stroke: "currentColor",
258
+ strokeWidth: width,
259
+ "data-part": "track",
260
+ ...props,
261
+ ref
262
+ },
263
+ children
264
+ )
265
+ );
266
+ const TrackFill = React.forwardRef(
267
+ ({ width = 8, fillPercent = 50, children, ...props }, ref) => /* @__PURE__ */ React.createElement(
268
+ "circle",
269
+ {
270
+ cx: "60",
271
+ cy: "60",
272
+ r: "54",
273
+ stroke: "currentColor",
274
+ pathLength: "100",
275
+ strokeWidth: width,
276
+ strokeDasharray: 100,
277
+ strokeDashoffset: 100 - fillPercent,
278
+ "data-part": "track-fill",
279
+ ...props,
280
+ ref
281
+ },
282
+ children
283
+ )
284
+ );
285
+
286
+ var spinner = /*#__PURE__*/Object.freeze({
287
+ __proto__: null,
288
+ Root: Root,
289
+ Track: Track,
290
+ TrackFill: TrackFill
291
+ });
292
+
293
+ function createSignal(initialValue, deps = []) {
294
+ const scope = useReactScope();
295
+ return React.useMemo(() => scoped(() => signal(initialValue), scope), [scope, ...deps]);
296
+ }
297
+ function createComputed(compute, deps = []) {
298
+ const scope = useReactScope();
299
+ return React.useMemo(() => scoped(() => computed(compute), scope), [scope, ...deps]);
300
+ }
301
+ function createEffect(compute, deps = []) {
302
+ const scope = useReactScope();
303
+ React.useEffect(() => scoped(() => effect(compute), scope), [scope, ...deps]);
304
+ }
305
+ function useScoped(compute) {
306
+ const scope = useReactScope();
307
+ return React.useMemo(() => scoped(compute, scope), [scope]);
308
+ }
309
+
310
+ function useTextCues(track) {
311
+ const [cues, setCues] = React.useState([]);
312
+ React.useEffect(() => {
313
+ if (!track) return;
314
+ function onCuesChange() {
315
+ if (track) setCues([...track.cues]);
316
+ }
317
+ const events = new EventsController(track).add("add-cue", onCuesChange).add("remove-cue", onCuesChange);
318
+ onCuesChange();
319
+ return () => {
320
+ setCues([]);
321
+ events.abort();
322
+ };
323
+ }, [track]);
324
+ return cues;
325
+ }
326
+
327
+ function useChapterOptions() {
328
+ const media = useMediaContext(), track = useActiveTextTrack("chapters"), cues = useTextCues(track), $startTime = useSignal(media.$state.seekableStart), $endTime = useSignal(media.$state.seekableEnd);
329
+ useActiveTextCues(track);
330
+ return React.useMemo(() => {
331
+ const options = track ? cues.filter((cue) => cue.startTime <= $endTime && cue.endTime >= $startTime).map((cue, i) => {
332
+ let currentRef = null, stopProgressEffect;
333
+ return {
334
+ cue,
335
+ label: cue.text,
336
+ value: i.toString(),
337
+ startTimeText: formatTime(Math.max(0, cue.startTime - $startTime)),
338
+ durationText: formatSpokenTime(
339
+ Math.min($endTime, cue.endTime) - Math.max($startTime, cue.startTime)
340
+ ),
341
+ get selected() {
342
+ return cue === track.activeCues[0];
343
+ },
344
+ setProgressVar(ref) {
345
+ if (!ref || cue !== track.activeCues[0]) {
346
+ stopProgressEffect?.();
347
+ stopProgressEffect = void 0;
348
+ ref?.style.setProperty("--progress", "0%");
349
+ currentRef = null;
350
+ return;
351
+ }
352
+ if (currentRef === ref) return;
353
+ currentRef = ref;
354
+ stopProgressEffect?.();
355
+ stopProgressEffect = effect(() => {
356
+ const { realCurrentTime } = media.$state, time = realCurrentTime(), cueStartTime = Math.max($startTime, cue.startTime), duration = Math.min($endTime, cue.endTime) - cueStartTime, progress = Math.max(0, time - cueStartTime) / duration * 100;
357
+ ref.style.setProperty("--progress", progress.toFixed(3) + "%");
358
+ });
359
+ },
360
+ select(trigger) {
361
+ media.remote.seek(cue.startTime - $startTime, trigger);
362
+ }
363
+ };
364
+ }) : [];
365
+ Object.defineProperty(options, "selectedValue", {
366
+ get() {
367
+ const index = options.findIndex((option) => option.selected);
368
+ return (index >= 0 ? index : 0).toString();
369
+ }
370
+ });
371
+ return options;
372
+ }, [cues, $startTime, $endTime]);
373
+ }
374
+
375
+ export { Captions, ChapterTitle, Content, GoogleCastButton, Group, MediaAnnouncer, Root$4 as Root, Root$2 as Root$1, Root$1 as Root$2, Root$3, Root$5 as Root$4, Root as Root$5, Title, Track, TrackFill, Trigger, audioGainSlider, controls, createComputed, createEffect, createSignal, qualitySlider, speedSlider, spinner, tooltip, useActiveTextCues, useActiveTextTrack, useChapterOptions, useChapterTitle, useScoped, useTextCues };
@@ -0,0 +1,34 @@
1
+ "use client"
2
+
3
+ const videoIdRE = /(?:https:\/\/)?(?:player\.)?vimeo(?:\.com)?\/(?:video\/)?(\d+)(?:(?:\?hash=|\?h=|\/)(.*))?/;
4
+ const infoCache = /* @__PURE__ */ new Map();
5
+ const pendingFetch = /* @__PURE__ */ new Map();
6
+ function resolveVimeoVideoId(src) {
7
+ const matches = src.match(videoIdRE);
8
+ return { videoId: matches?.[1], hash: matches?.[2] };
9
+ }
10
+ async function getVimeoVideoInfo(videoId, abort, videoHash) {
11
+ if (infoCache.has(videoId)) return infoCache.get(videoId);
12
+ if (pendingFetch.has(videoId)) return pendingFetch.get(videoId);
13
+ let oembedSrc = `https://vimeo.com/api/oembed.json?url=https://player.vimeo.com/video/${videoId}`;
14
+ if (videoHash) {
15
+ oembedSrc = oembedSrc.concat(`?h=${videoHash}`);
16
+ }
17
+ const promise = window.fetch(oembedSrc, {
18
+ mode: "cors",
19
+ signal: abort.signal
20
+ }).then((response) => response.json()).then((data) => {
21
+ const thumnailRegex = /vimeocdn.com\/video\/(.*)?_/, thumbnailId = data?.thumbnail_url?.match(thumnailRegex)?.[1], poster = thumbnailId ? `https://i.vimeocdn.com/video/${thumbnailId}_1920x1080.webp` : "", info = {
22
+ title: data?.title ?? "",
23
+ duration: data?.duration ?? 0,
24
+ poster,
25
+ pro: data.account_type !== "basic"
26
+ };
27
+ infoCache.set(videoId, info);
28
+ return info;
29
+ }).finally(() => pendingFetch.delete(videoId));
30
+ pendingFetch.set(videoId, promise);
31
+ return promise;
32
+ }
33
+
34
+ export { getVimeoVideoInfo, resolveVimeoVideoId };