@hanifhan1f/vidstack 1.12.13 → 1.12.18

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 (952) hide show
  1. package/cdn/chunks/vidstack-2f5gzOW6.js +1 -0
  2. package/cdn/chunks/vidstack-BYgY9wmd.js +1 -0
  3. package/cdn/chunks/vidstack-BfBBPhXV.js +1 -0
  4. package/cdn/chunks/vidstack-Bjo5esRp.js +1 -0
  5. package/cdn/chunks/vidstack-BuL67v3q.js +1 -0
  6. package/cdn/chunks/vidstack-C0msPRTd.js +3 -0
  7. package/cdn/chunks/vidstack-CIjxJCz3.js +1 -0
  8. package/cdn/chunks/vidstack-C_AxqLKV.js +1 -0
  9. package/cdn/chunks/vidstack-CioT3Yw2.js +1 -0
  10. package/cdn/chunks/vidstack-CmpbA3Yd.js +16 -0
  11. package/cdn/chunks/vidstack-CrqkytHl.js +1 -0
  12. package/cdn/chunks/vidstack-D0M8R0ZU.js +1 -0
  13. package/cdn/chunks/vidstack-D40FSa5B.js +3 -0
  14. package/cdn/chunks/vidstack-DD2JwFVU.js +1 -0
  15. package/cdn/chunks/vidstack-DRH_1tFW.js +1 -0
  16. package/cdn/chunks/vidstack-DfDZuHNP.js +1 -0
  17. package/cdn/chunks/vidstack-DiNS2Vx5.js +1 -0
  18. package/cdn/chunks/vidstack-xjJ-ui_l.js +1 -0
  19. package/cdn/providers/vidstack-audio-2Dt_Ivbp.js +1 -0
  20. package/cdn/providers/vidstack-dash-CUtD4e6q.js +1 -0
  21. package/cdn/providers/vidstack-google-cast-BdORATUX.js +1 -0
  22. package/cdn/providers/vidstack-hls-R25Kb6DP.js +1 -0
  23. package/cdn/providers/vidstack-html-DaAUJYsD.js +1 -0
  24. package/cdn/providers/vidstack-video-Csvox7SO.js +1 -0
  25. package/cdn/providers/vidstack-vimeo-D4Z96kg2.js +1 -0
  26. package/cdn/providers/vidstack-youtube-DiND6h3s.js +1 -0
  27. package/cdn/vidstack.js +1 -0
  28. package/cdn/with-layouts/chunks/vidstack-2f5gzOW6.js +1 -0
  29. package/cdn/with-layouts/chunks/vidstack-BGhRKayG.js +914 -0
  30. package/cdn/with-layouts/chunks/vidstack-BL_lNyW_.js +1 -0
  31. package/cdn/with-layouts/chunks/vidstack-BMhNagfl.js +1 -0
  32. package/cdn/with-layouts/chunks/vidstack-BfBBPhXV.js +1 -0
  33. package/cdn/with-layouts/chunks/vidstack-BjOOdDcQ.js +1 -0
  34. package/cdn/with-layouts/chunks/vidstack-Bxv1Qnxe.js +1 -0
  35. package/cdn/with-layouts/chunks/vidstack-C5AP9wid.js +1 -0
  36. package/cdn/with-layouts/chunks/vidstack-CS2aNc61.js +1 -0
  37. package/cdn/with-layouts/chunks/vidstack-C_AxqLKV.js +1 -0
  38. package/cdn/with-layouts/chunks/vidstack-D-3_fAsK.js +1 -0
  39. package/cdn/with-layouts/chunks/vidstack-DKqYI_HJ.js +1 -0
  40. package/cdn/with-layouts/chunks/vidstack-DLVdcWrK.js +3 -0
  41. package/cdn/with-layouts/chunks/vidstack-DPO7J4-v.js +3 -0
  42. package/cdn/with-layouts/chunks/vidstack-DRH_1tFW.js +1 -0
  43. package/cdn/with-layouts/chunks/vidstack-DWjB11vV.js +1 -0
  44. package/cdn/with-layouts/chunks/vidstack-Dge3KT8k.js +1 -0
  45. package/cdn/with-layouts/chunks/vidstack-Dh2GOjra.js +1 -0
  46. package/cdn/with-layouts/chunks/vidstack-DiNS2Vx5.js +1 -0
  47. package/cdn/with-layouts/chunks/vidstack-QW5tTAS4.js +897 -0
  48. package/cdn/with-layouts/chunks/vidstack-Xe_d7ovA.js +1 -0
  49. package/cdn/with-layouts/chunks/vidstack-wt2OT4N7.js +1 -0
  50. package/cdn/with-layouts/providers/vidstack-audio-Bw1csc6N.js +1 -0
  51. package/cdn/with-layouts/providers/vidstack-dash-DHRMFG4Y.js +1 -0
  52. package/cdn/with-layouts/providers/vidstack-google-cast-BSYJYn-o.js +1 -0
  53. package/cdn/with-layouts/providers/vidstack-hls-DG1rTEqu.js +1 -0
  54. package/cdn/with-layouts/providers/vidstack-html-CoKFAYW5.js +1 -0
  55. package/cdn/with-layouts/providers/vidstack-video-CIxFJ9Z1.js +1 -0
  56. package/cdn/with-layouts/providers/vidstack-vimeo-CNLKOGMa.js +1 -0
  57. package/cdn/with-layouts/providers/vidstack-youtube-D1e-LE-8.js +1 -0
  58. package/cdn/with-layouts/vidstack.js +1 -0
  59. package/dev/chunks/vidstack-03oQOdB7.js +58 -0
  60. package/dev/chunks/vidstack-0Of4tJ8D.js +224 -0
  61. package/dev/chunks/vidstack-BJsZjPkB.js +204 -0
  62. package/dev/chunks/vidstack-BQSA-Rux.js +56 -0
  63. package/{src/core/quality/utils.ts → dev/chunks/vidstack-BTM4ERc7.js} +5 -7
  64. package/dev/chunks/vidstack-BXSB7eI9.js +58 -0
  65. package/dev/chunks/vidstack-BaGbgcvz.js +107 -0
  66. package/{src/core/time-ranges.ts → dev/chunks/vidstack-Becy7l6h.js} +22 -61
  67. package/dev/chunks/vidstack-Bf6x4gWe.js +29 -0
  68. package/dev/chunks/vidstack-BjxlZzGu.js +11 -0
  69. package/dev/chunks/vidstack-Blfm1k-4.js +1520 -0
  70. package/dev/chunks/vidstack-Bpr4fI4n.js +7 -0
  71. package/dev/chunks/vidstack-Bs54kFSz.js +66 -0
  72. package/dev/chunks/vidstack-Bur7I7Vy.js +57 -0
  73. package/dev/chunks/vidstack-C0SWkbs7.js +254 -0
  74. package/dev/chunks/vidstack-C1PwJD_4.js +1635 -0
  75. package/dev/chunks/vidstack-C4aPQ7hZ.js +1482 -0
  76. package/dev/chunks/vidstack-C6OqdJO7.js +114 -0
  77. package/dev/chunks/vidstack-C_rvOKWp.js +33 -0
  78. package/dev/chunks/vidstack-CaudO1jl.js +109 -0
  79. package/dev/chunks/vidstack-Cax7aAP-.js +66 -0
  80. package/dev/chunks/vidstack-CcQdBWil.js +58 -0
  81. package/dev/chunks/vidstack-CwTj4H1w.js +18 -0
  82. package/dev/chunks/vidstack-DAOcbKGP.js +254 -0
  83. package/dev/chunks/vidstack-DKaohJzR.js +5181 -0
  84. package/dev/chunks/vidstack-DXxIKXmd.js +50 -0
  85. package/dev/chunks/vidstack-DXzRuMtJ.js +107 -0
  86. package/dev/chunks/vidstack-Db1-Hg_U.js +297 -0
  87. package/dev/chunks/vidstack-DbBJlz7I.js +10 -0
  88. package/dev/chunks/vidstack-Dihypf8P.js +11 -0
  89. package/dev/chunks/vidstack-Dm1xEU9Q.js +34 -0
  90. package/dev/chunks/vidstack-Dv_LIPFu.js +14 -0
  91. package/{src/foundation/observers/raf-loop.ts → dev/chunks/vidstack-DwyWIZjv.js} +8 -11
  92. package/dev/chunks/vidstack-EoLRQZbs.js +2986 -0
  93. package/dev/chunks/vidstack-FKkY62Dr.js +104 -0
  94. package/dev/chunks/vidstack-krOAtKMi.js +32 -0
  95. package/dev/define/plyr-layout.js +52 -0
  96. package/dev/define/templates/plyr-layout.js +571 -0
  97. package/dev/define/templates/vidstack-audio-layout.js +168 -0
  98. package/dev/define/templates/vidstack-video-layout.js +486 -0
  99. package/dev/define/vidstack-icons.js +1 -0
  100. package/dev/define/vidstack-player-default-layout.js +22 -0
  101. package/dev/define/vidstack-player-layouts.js +26 -0
  102. package/dev/define/vidstack-player-ui.js +71 -0
  103. package/dev/define/vidstack-player.js +19 -0
  104. package/dev/global/plyr.js +502 -0
  105. package/dev/global/vidstack-player.js +129 -0
  106. package/dev/providers/vidstack-audio.js +35 -0
  107. package/dev/providers/vidstack-dash.js +516 -0
  108. package/dev/providers/vidstack-google-cast.js +474 -0
  109. package/dev/providers/vidstack-hls.js +408 -0
  110. package/dev/providers/vidstack-html.js +567 -0
  111. package/dev/providers/vidstack-video.js +207 -0
  112. package/dev/providers/vidstack-vimeo.js +554 -0
  113. package/dev/providers/vidstack-youtube.js +286 -0
  114. package/dev/vidstack-elements.js +37 -0
  115. package/dev/vidstack.js +92 -0
  116. package/elements.d.ts +1433 -0
  117. package/global/player.d.ts +52 -0
  118. package/{types/global → global}/plyr.d.ts +32 -33
  119. package/icons.d.ts +1 -0
  120. package/index.d.ts +402 -0
  121. package/package.json +3 -87
  122. package/{styles/player → player/styles}/default/layouts/video.css +69 -0
  123. package/plugins.d.ts +19 -0
  124. package/plugins.js +13 -0
  125. package/prod/chunks/vidstack-9_r3lWNO.js +45 -0
  126. package/prod/chunks/vidstack-B01xzxC4.js +7 -0
  127. package/prod/chunks/vidstack-BDIzK77F.js +107 -0
  128. package/prod/chunks/vidstack-BHqGlnGz.js +1482 -0
  129. package/prod/chunks/vidstack-BNpgCJJ1.js +1588 -0
  130. package/prod/chunks/vidstack-BP49Gz0m.js +58 -0
  131. package/prod/chunks/vidstack-BRZe2BNi.js +107 -0
  132. package/prod/chunks/vidstack-BTM4ERc7.js +11 -0
  133. package/prod/chunks/vidstack-BaaRY-9x.js +201 -0
  134. package/prod/chunks/vidstack-BdFYWy6h.js +26 -0
  135. package/prod/chunks/vidstack-BpLd9ASW.js +246 -0
  136. package/prod/chunks/vidstack-C05ipjAK.js +1520 -0
  137. package/prod/chunks/vidstack-C9vIqaYT.js +10 -0
  138. package/prod/chunks/vidstack-CA4tDJdF.js +33 -0
  139. package/prod/chunks/vidstack-COLU-zPZ.js +57 -0
  140. package/prod/chunks/vidstack-CwTj4H1w.js +18 -0
  141. package/prod/chunks/vidstack-D5EzK014.js +14 -0
  142. package/prod/chunks/vidstack-D7hJcnN-.js +297 -0
  143. package/prod/chunks/vidstack-DB9WDRL5.js +248 -0
  144. package/prod/chunks/vidstack-DESBVLFp.js +104 -0
  145. package/prod/chunks/vidstack-DXxIKXmd.js +50 -0
  146. package/prod/chunks/vidstack-DcMkaIHJ.js +2976 -0
  147. package/prod/chunks/vidstack-Dihypf8P.js +11 -0
  148. package/prod/chunks/vidstack-Dm1xEU9Q.js +34 -0
  149. package/prod/chunks/vidstack-DwenML7x.js +4771 -0
  150. package/prod/chunks/vidstack-Fem0yF3c.js +77 -0
  151. package/prod/chunks/vidstack-IDWYvfna.js +58 -0
  152. package/prod/chunks/vidstack-MbEMbVfP.js +109 -0
  153. package/prod/chunks/vidstack-Oq65llxr.js +29 -0
  154. package/prod/chunks/vidstack-SnIdjCkV.js +58 -0
  155. package/prod/chunks/vidstack-V1jwkH0s.js +66 -0
  156. package/prod/chunks/vidstack-bdt7uOlN.js +114 -0
  157. package/prod/chunks/vidstack-krOAtKMi.js +32 -0
  158. package/prod/chunks/vidstack-mxJIo4Sg.js +56 -0
  159. package/prod/chunks/vidstack-tt3O1zL6.js +11 -0
  160. package/prod/chunks/vidstack-zfCm-GM5.js +205 -0
  161. package/prod/define/plyr-layout.js +52 -0
  162. package/prod/define/templates/plyr-layout.js +571 -0
  163. package/prod/define/templates/vidstack-audio-layout.js +168 -0
  164. package/prod/define/templates/vidstack-video-layout.js +486 -0
  165. package/prod/define/vidstack-icons.js +1 -0
  166. package/prod/define/vidstack-player-default-layout.js +22 -0
  167. package/prod/define/vidstack-player-layouts.js +26 -0
  168. package/prod/define/vidstack-player-ui.js +71 -0
  169. package/prod/define/vidstack-player.js +19 -0
  170. package/prod/global/plyr.js +494 -0
  171. package/prod/global/vidstack-player.js +129 -0
  172. package/prod/providers/vidstack-audio.js +35 -0
  173. package/prod/providers/vidstack-dash.js +501 -0
  174. package/prod/providers/vidstack-google-cast.js +468 -0
  175. package/prod/providers/vidstack-hls.js +393 -0
  176. package/prod/providers/vidstack-html.js +555 -0
  177. package/prod/providers/vidstack-video.js +204 -0
  178. package/prod/providers/vidstack-vimeo.js +548 -0
  179. package/prod/providers/vidstack-youtube.js +286 -0
  180. package/prod/vidstack-elements.js +37 -0
  181. package/prod/vidstack.js +159 -0
  182. package/server/chunks/vidstack-B4CWj0Hp.js +381 -0
  183. package/server/chunks/vidstack-B8LynzY5.js +1564 -0
  184. package/server/chunks/vidstack-BGgfNYAH.js +141 -0
  185. package/server/chunks/vidstack-BGmwlunt.js +3035 -0
  186. package/server/chunks/vidstack-BOTZD4tC.js +18 -0
  187. package/server/chunks/vidstack-C19bj3Wq.js +307 -0
  188. package/server/chunks/vidstack-CFTkUXGK.js +295 -0
  189. package/server/chunks/vidstack-CQMB7Msg.js +1502 -0
  190. package/server/chunks/vidstack-CdBfecZT.js +205 -0
  191. package/server/chunks/vidstack-Cv_Art04.js +4635 -0
  192. package/server/chunks/vidstack-CwTj4H1w.js +18 -0
  193. package/server/chunks/vidstack-DE4b5Bgx.js +2002 -0
  194. package/server/chunks/vidstack-DXxIKXmd.js +50 -0
  195. package/server/chunks/vidstack-DbvCOsqU.js +107 -0
  196. package/server/chunks/vidstack-DgHfFDiw.js +1962 -0
  197. package/server/chunks/vidstack-Dm1xEU9Q.js +34 -0
  198. package/server/chunks/vidstack-DnkB7eGO.js +207 -0
  199. package/server/chunks/vidstack-DsnTqzpL.js +29 -0
  200. package/{src/elements/define/layouts/plyr/ui.ts → server/chunks/vidstack-FHGkN5xj.js} +144 -235
  201. package/server/chunks/vidstack-P_QDjYIl.js +56 -0
  202. package/server/chunks/vidstack-f5-aflD2.js +104 -0
  203. package/server/chunks/vidstack-krOAtKMi.js +32 -0
  204. package/server/define/plyr-layout.js +16 -0
  205. package/server/define/vidstack-icons.js +1 -0
  206. package/server/define/vidstack-player-default-layout.js +13 -0
  207. package/server/define/vidstack-player-layouts.js +16 -0
  208. package/server/define/vidstack-player-ui.js +11 -0
  209. package/server/define/vidstack-player.js +6 -0
  210. package/server/global/plyr.js +322 -0
  211. package/server/global/vidstack-player.js +58 -0
  212. package/server/vidstack-elements.js +46 -0
  213. package/server/vidstack.js +148 -0
  214. package/types/vidstack-BOvzfZjK.d.ts +1269 -0
  215. package/types/vidstack-DYLKXUvI.d.ts +7479 -0
  216. package/.templates/sandbox/favicon-32x32.png +0 -0
  217. package/.templates/sandbox/index.html +0 -42
  218. package/.templates/sandbox/main.ts +0 -137
  219. package/.templates/sandbox/styles.css +0 -68
  220. package/analyze.config.ts +0 -133
  221. package/build/build-styles.js +0 -33
  222. package/build/rollup-decorators.ts +0 -102
  223. package/build/rollup-minify.js +0 -20
  224. package/build/rollup-ts.js +0 -57
  225. package/rollup.config.ts +0 -442
  226. package/src/components/aria/announcer.ts +0 -181
  227. package/src/components/layouts/default/audio-layout.ts +0 -20
  228. package/src/components/layouts/default/context.ts +0 -15
  229. package/src/components/layouts/default/default-layout.ts +0 -67
  230. package/src/components/layouts/default/props.ts +0 -143
  231. package/src/components/layouts/default/translations.ts +0 -70
  232. package/src/components/layouts/default/video-layout.ts +0 -20
  233. package/src/components/layouts/plyr/context.ts +0 -13
  234. package/src/components/layouts/plyr/plyr-layout.ts +0 -90
  235. package/src/components/layouts/plyr/props.ts +0 -114
  236. package/src/components/layouts/plyr/translations.ts +0 -53
  237. package/src/components/player.ts +0 -758
  238. package/src/components/provider/provider.ts +0 -184
  239. package/src/components/provider/source-select.ts +0 -378
  240. package/src/components/provider/tracks.ts +0 -37
  241. package/src/components/ui/buttons/airplay-button.ts +0 -74
  242. package/src/components/ui/buttons/caption-button.ts +0 -68
  243. package/src/components/ui/buttons/fullscreen-button.ts +0 -90
  244. package/src/components/ui/buttons/google-cast-button.ts +0 -75
  245. package/src/components/ui/buttons/live-button.ts +0 -76
  246. package/src/components/ui/buttons/mute-button.ts +0 -69
  247. package/src/components/ui/buttons/pip-button.ts +0 -71
  248. package/src/components/ui/buttons/play-button.ts +0 -62
  249. package/src/components/ui/buttons/seek-button.ts +0 -92
  250. package/src/components/ui/buttons/toggle-button-controller.ts +0 -92
  251. package/src/components/ui/buttons/toggle-button.ts +0 -49
  252. package/src/components/ui/captions/captions-renderer.ts +0 -63
  253. package/src/components/ui/captions/captions.ts +0 -227
  254. package/src/components/ui/controls-group.ts +0 -13
  255. package/src/components/ui/controls.ts +0 -101
  256. package/src/components/ui/gesture.ts +0 -252
  257. package/src/components/ui/menu/menu-button.ts +0 -95
  258. package/src/components/ui/menu/menu-context.ts +0 -27
  259. package/src/components/ui/menu/menu-focus-controller.ts +0 -205
  260. package/src/components/ui/menu/menu-item.ts +0 -9
  261. package/src/components/ui/menu/menu-items.ts +0 -129
  262. package/src/components/ui/menu/menu-portal.ts +0 -105
  263. package/src/components/ui/menu/menu.ts +0 -612
  264. package/src/components/ui/menu/radio/radio-controller.ts +0 -18
  265. package/src/components/ui/menu/radio/radio-group-controller.ts +0 -81
  266. package/src/components/ui/menu/radio/radio-group.ts +0 -78
  267. package/src/components/ui/menu/radio/radio.ts +0 -151
  268. package/src/components/ui/menu/radio-groups/audio-gain-radio-group.ts +0 -116
  269. package/src/components/ui/menu/radio-groups/audio-radio-group.ts +0 -121
  270. package/src/components/ui/menu/radio-groups/captions-radio-group.ts +0 -153
  271. package/src/components/ui/menu/radio-groups/chapters-radio-group.ts +0 -211
  272. package/src/components/ui/menu/radio-groups/quality-radio-group.ts +0 -181
  273. package/src/components/ui/menu/radio-groups/speed-radio-group.ts +0 -112
  274. package/src/components/ui/popper/popper.ts +0 -103
  275. package/src/components/ui/poster.ts +0 -187
  276. package/src/components/ui/sliders/audio-gain-slider.ts +0 -150
  277. package/src/components/ui/sliders/quality-slider.ts +0 -148
  278. package/src/components/ui/sliders/slider/api/cssvars.ts +0 -10
  279. package/src/components/ui/sliders/slider/api/events.ts +0 -65
  280. package/src/components/ui/sliders/slider/api/state.ts +0 -101
  281. package/src/components/ui/sliders/slider/events-controller.ts +0 -383
  282. package/src/components/ui/sliders/slider/format.ts +0 -12
  283. package/src/components/ui/sliders/slider/slider-context.ts +0 -18
  284. package/src/components/ui/sliders/slider/slider-controller.ts +0 -211
  285. package/src/components/ui/sliders/slider/slider.ts +0 -94
  286. package/src/components/ui/sliders/slider/types.ts +0 -1
  287. package/src/components/ui/sliders/slider/utils.ts +0 -14
  288. package/src/components/ui/sliders/slider-preview.ts +0 -131
  289. package/src/components/ui/sliders/slider-thumbnail.ts +0 -28
  290. package/src/components/ui/sliders/slider-value.ts +0 -122
  291. package/src/components/ui/sliders/slider-video.ts +0 -198
  292. package/src/components/ui/sliders/speed-slider.ts +0 -147
  293. package/src/components/ui/sliders/time-slider/slider-chapters.ts +0 -444
  294. package/src/components/ui/sliders/time-slider/time-slider.ts +0 -319
  295. package/src/components/ui/sliders/volume-slider.ts +0 -145
  296. package/src/components/ui/thumbnails/thumbnail-loader.ts +0 -324
  297. package/src/components/ui/thumbnails/thumbnail.ts +0 -244
  298. package/src/components/ui/time.ts +0 -191
  299. package/src/components/ui/tooltip/tooltip-content.ts +0 -105
  300. package/src/components/ui/tooltip/tooltip-context.ts +0 -13
  301. package/src/components/ui/tooltip/tooltip-trigger.ts +0 -49
  302. package/src/components/ui/tooltip/tooltip.ts +0 -127
  303. package/src/core/api/media-attrs.ts +0 -35
  304. package/src/core/api/media-context.ts +0 -52
  305. package/src/core/api/media-events.ts +0 -601
  306. package/src/core/api/media-request-events.ts +0 -323
  307. package/src/core/api/player-controller.ts +0 -10
  308. package/src/core/api/player-events.ts +0 -49
  309. package/src/core/api/player-props.ts +0 -233
  310. package/src/core/api/player-state.ts +0 -940
  311. package/src/core/api/src-types.ts +0 -97
  312. package/src/core/api/types.ts +0 -69
  313. package/src/core/controls.ts +0 -251
  314. package/src/core/font/font-options.ts +0 -106
  315. package/src/core/font/font-vars.ts +0 -107
  316. package/src/core/keyboard/aria-shortcuts.ts +0 -42
  317. package/src/core/keyboard/controller.ts +0 -302
  318. package/src/core/keyboard/types.ts +0 -40
  319. package/src/core/quality/events.ts +0 -48
  320. package/src/core/quality/symbols.ts +0 -8
  321. package/src/core/quality/video-quality.ts +0 -86
  322. package/src/core/state/media-events-logger.ts +0 -67
  323. package/src/core/state/media-load-controller.ts +0 -40
  324. package/src/core/state/media-player-delegate.ts +0 -170
  325. package/src/core/state/media-request-manager.ts +0 -952
  326. package/src/core/state/media-state-manager.ts +0 -1077
  327. package/src/core/state/media-state-sync.ts +0 -162
  328. package/src/core/state/media-storage.ts +0 -196
  329. package/src/core/state/navigator-media-session.ts +0 -62
  330. package/src/core/state/remote-control.ts +0 -584
  331. package/src/core/state/tracked-media-events.ts +0 -22
  332. package/src/core/tracks/audio/audio-tracks.ts +0 -33
  333. package/src/core/tracks/audio/events.ts +0 -41
  334. package/src/core/tracks/text/events.ts +0 -52
  335. package/src/core/tracks/text/render/libass-text-renderer.ts +0 -246
  336. package/src/core/tracks/text/render/native-text-renderer.ts +0 -106
  337. package/src/core/tracks/text/render/text-renderer.ts +0 -134
  338. package/src/core/tracks/text/symbols.ts +0 -17
  339. package/src/core/tracks/text/text-track.test.ts +0 -407
  340. package/src/core/tracks/text/text-track.ts +0 -413
  341. package/src/core/tracks/text/text-tracks.ts +0 -210
  342. package/src/core/tracks/text/utils.ts +0 -85
  343. package/src/elements/bundles/cdn/player.core.ts +0 -6
  344. package/src/elements/bundles/cdn/player.ts +0 -8
  345. package/src/elements/bundles/cdn/plyr.ts +0 -6
  346. package/src/elements/bundles/cdn-legacy/player-with-default.ts +0 -4
  347. package/src/elements/bundles/cdn-legacy/player-with-layouts.ts +0 -4
  348. package/src/elements/bundles/cdn-legacy/player-with-plyr.ts +0 -3
  349. package/src/elements/bundles/cdn-legacy/player.ts +0 -3
  350. package/src/elements/bundles/icons.ts +0 -3
  351. package/src/elements/bundles/player-layouts/default.ts +0 -7
  352. package/src/elements/bundles/player-layouts/index.ts +0 -9
  353. package/src/elements/bundles/player-layouts/plyr.ts +0 -65
  354. package/src/elements/bundles/player-ui.ts +0 -108
  355. package/src/elements/bundles/player.ts +0 -7
  356. package/src/elements/define/announcer-element.ts +0 -20
  357. package/src/elements/define/buttons/airplay-button-element.ts +0 -21
  358. package/src/elements/define/buttons/caption-button-element.ts +0 -22
  359. package/src/elements/define/buttons/fullscreen-button-element.ts +0 -22
  360. package/src/elements/define/buttons/google-cast-button-element.ts +0 -21
  361. package/src/elements/define/buttons/live-button-element.ts +0 -22
  362. package/src/elements/define/buttons/mute-button-element.ts +0 -23
  363. package/src/elements/define/buttons/pip-button-element.ts +0 -22
  364. package/src/elements/define/buttons/play-button-element.ts +0 -23
  365. package/src/elements/define/buttons/seek-button-element.ts +0 -26
  366. package/src/elements/define/buttons/toggle-button-element.ts +0 -21
  367. package/src/elements/define/captions-element.ts +0 -20
  368. package/src/elements/define/chapter-title-element.ts +0 -54
  369. package/src/elements/define/controls-element.ts +0 -26
  370. package/src/elements/define/controls-group-element.ts +0 -26
  371. package/src/elements/define/gesture-element.ts +0 -24
  372. package/src/elements/define/layouts/default/audio-layout-element.ts +0 -137
  373. package/src/elements/define/layouts/default/audio-layout.ts +0 -113
  374. package/src/elements/define/layouts/default/icons-loader.ts +0 -17
  375. package/src/elements/define/layouts/default/icons.ts +0 -86
  376. package/src/elements/define/layouts/default/slots.ts +0 -12
  377. package/src/elements/define/layouts/default/ui/announcer.ts +0 -14
  378. package/src/elements/define/layouts/default/ui/buttons.ts +0 -291
  379. package/src/elements/define/layouts/default/ui/captions.ts +0 -14
  380. package/src/elements/define/layouts/default/ui/controls.ts +0 -5
  381. package/src/elements/define/layouts/default/ui/keyboard-display.ts +0 -114
  382. package/src/elements/define/layouts/default/ui/menu/accessibility-menu.ts +0 -79
  383. package/src/elements/define/layouts/default/ui/menu/audio-menu.ts +0 -135
  384. package/src/elements/define/layouts/default/ui/menu/captions-menu.ts +0 -114
  385. package/src/elements/define/layouts/default/ui/menu/chapters-menu.ts +0 -117
  386. package/src/elements/define/layouts/default/ui/menu/episodes-menu.ts +0 -133
  387. package/src/elements/define/layouts/default/ui/menu/font-menu.ts +0 -253
  388. package/src/elements/define/layouts/default/ui/menu/items/menu-checkbox.ts +0 -67
  389. package/src/elements/define/layouts/default/ui/menu/items/menu-items.ts +0 -108
  390. package/src/elements/define/layouts/default/ui/menu/items/menu-slider.ts +0 -59
  391. package/src/elements/define/layouts/default/ui/menu/menu-portal.ts +0 -56
  392. package/src/elements/define/layouts/default/ui/menu/playback-menu.ts +0 -183
  393. package/src/elements/define/layouts/default/ui/menu/settings-menu.ts +0 -98
  394. package/src/elements/define/layouts/default/ui/slider.ts +0 -112
  395. package/src/elements/define/layouts/default/ui/time.ts +0 -41
  396. package/src/elements/define/layouts/default/ui/title.ts +0 -25
  397. package/src/elements/define/layouts/default/ui/utils.ts +0 -10
  398. package/src/elements/define/layouts/default/video-layout-element.ts +0 -125
  399. package/src/elements/define/layouts/default/video-layout.ts +0 -353
  400. package/src/elements/define/layouts/icons/icons-loader.ts +0 -47
  401. package/src/elements/define/layouts/icons/layout-icons-loader.ts +0 -24
  402. package/src/elements/define/layouts/layout-element.ts +0 -78
  403. package/src/elements/define/layouts/layout-name.ts +0 -15
  404. package/src/elements/define/layouts/plyr/icons/plyr-airplay.js +0 -1
  405. package/src/elements/define/layouts/plyr/icons/plyr-captions-off.js +0 -1
  406. package/src/elements/define/layouts/plyr/icons/plyr-captions-on.js +0 -1
  407. package/src/elements/define/layouts/plyr/icons/plyr-download.js +0 -1
  408. package/src/elements/define/layouts/plyr/icons/plyr-enter-fullscreen.js +0 -1
  409. package/src/elements/define/layouts/plyr/icons/plyr-exit-fullscreen.js +0 -1
  410. package/src/elements/define/layouts/plyr/icons/plyr-fast-forward.js +0 -1
  411. package/src/elements/define/layouts/plyr/icons/plyr-muted.js +0 -1
  412. package/src/elements/define/layouts/plyr/icons/plyr-pause.js +0 -1
  413. package/src/elements/define/layouts/plyr/icons/plyr-pip.js +0 -1
  414. package/src/elements/define/layouts/plyr/icons/plyr-play.js +0 -1
  415. package/src/elements/define/layouts/plyr/icons/plyr-restart.js +0 -1
  416. package/src/elements/define/layouts/plyr/icons/plyr-rewind.js +0 -1
  417. package/src/elements/define/layouts/plyr/icons/plyr-settings.js +0 -1
  418. package/src/elements/define/layouts/plyr/icons/plyr-volume.js +0 -1
  419. package/src/elements/define/layouts/plyr/icons-loader.ts +0 -21
  420. package/src/elements/define/layouts/plyr/icons.ts +0 -34
  421. package/src/elements/define/layouts/plyr/plyr-layout-element.ts +0 -67
  422. package/src/elements/define/layouts/slot-manager.ts +0 -61
  423. package/src/elements/define/layouts/slot-observer.ts +0 -70
  424. package/src/elements/define/menus/_template.ts +0 -47
  425. package/src/elements/define/menus/audio-gain-group-element.ts +0 -37
  426. package/src/elements/define/menus/audio-radio-group-element.ts +0 -37
  427. package/src/elements/define/menus/captions-radio-group-element.ts +0 -37
  428. package/src/elements/define/menus/chapters-radio-group-element.ts +0 -68
  429. package/src/elements/define/menus/menu-button-element.ts +0 -27
  430. package/src/elements/define/menus/menu-element.ts +0 -28
  431. package/src/elements/define/menus/menu-item-element.ts +0 -24
  432. package/src/elements/define/menus/menu-items-element.ts +0 -27
  433. package/src/elements/define/menus/menu-portal-element.ts +0 -35
  434. package/src/elements/define/menus/quality-radio-group-element.ts +0 -51
  435. package/src/elements/define/menus/radio-element.ts +0 -24
  436. package/src/elements/define/menus/radio-group-element.ts +0 -24
  437. package/src/elements/define/menus/speed-radio-group-element.ts +0 -37
  438. package/src/elements/define/player-element.ts +0 -33
  439. package/src/elements/define/poster-element.ts +0 -53
  440. package/src/elements/define/provider-cast-display.ts +0 -36
  441. package/src/elements/define/provider-element.ts +0 -158
  442. package/src/elements/define/sliders/audio-gain-slider-element.ts +0 -34
  443. package/src/elements/define/sliders/quality-slider-element.ts +0 -34
  444. package/src/elements/define/sliders/slider-chapters-element.ts +0 -53
  445. package/src/elements/define/sliders/slider-element.ts +0 -25
  446. package/src/elements/define/sliders/slider-preview-element.ts +0 -16
  447. package/src/elements/define/sliders/slider-steps-element.ts +0 -50
  448. package/src/elements/define/sliders/slider-thumbnail-element.ts +0 -48
  449. package/src/elements/define/sliders/slider-value-element.ts +0 -49
  450. package/src/elements/define/sliders/slider-video-element.ts +0 -59
  451. package/src/elements/define/sliders/speed-slider-element.ts +0 -34
  452. package/src/elements/define/sliders/time-slider-element.ts +0 -34
  453. package/src/elements/define/sliders/volume-slider-element.ts +0 -34
  454. package/src/elements/define/spinner-element.ts +0 -96
  455. package/src/elements/define/thumbnail-element.ts +0 -63
  456. package/src/elements/define/time-element.ts +0 -32
  457. package/src/elements/define/title-element.ts +0 -38
  458. package/src/elements/define/tooltips/tooltip-content-element.ts +0 -28
  459. package/src/elements/define/tooltips/tooltip-element.ts +0 -28
  460. package/src/elements/define/tooltips/tooltip-trigger-element.ts +0 -32
  461. package/src/elements/icon.ts +0 -30
  462. package/src/elements/index.ts +0 -71
  463. package/src/elements/lit/directives/signal.ts +0 -80
  464. package/src/elements/lit/html.ts +0 -11
  465. package/src/elements/lit/lit-element.ts +0 -23
  466. package/src/elements/state-controller.ts +0 -48
  467. package/src/exports/components.ts +0 -79
  468. package/src/exports/core.ts +0 -41
  469. package/src/exports/events.ts +0 -46
  470. package/src/exports/font.ts +0 -3
  471. package/src/exports/foundation.ts +0 -8
  472. package/src/exports/maverick.ts +0 -9
  473. package/src/exports/providers.ts +0 -42
  474. package/src/exports/utils.ts +0 -18
  475. package/src/foundation/fullscreen/controller.ts +0 -128
  476. package/src/foundation/fullscreen/events.ts +0 -26
  477. package/src/foundation/list/list.ts +0 -127
  478. package/src/foundation/list/select-list.ts +0 -86
  479. package/src/foundation/list/symbols.ts +0 -22
  480. package/src/foundation/logger/colors.ts +0 -33
  481. package/src/foundation/logger/controller.ts +0 -71
  482. package/src/foundation/logger/events.ts +0 -29
  483. package/src/foundation/logger/grouped-log.ts +0 -44
  484. package/src/foundation/logger/log-level.ts +0 -17
  485. package/src/foundation/logger/log-printer.ts +0 -119
  486. package/src/foundation/logger/ms.ts +0 -31
  487. package/src/foundation/observers/focus-visible.ts +0 -74
  488. package/src/foundation/observers/intersection-observer.ts +0 -60
  489. package/src/foundation/observers/page-visibility.ts +0 -105
  490. package/src/foundation/orientation/controller.ts +0 -139
  491. package/src/foundation/orientation/events.ts +0 -20
  492. package/src/foundation/orientation/types.ts +0 -96
  493. package/src/foundation/queue/queue.ts +0 -41
  494. package/src/foundation/queue/request-queue.test.ts +0 -139
  495. package/src/foundation/queue/request-queue.ts +0 -94
  496. package/src/global/layouts/default.ts +0 -28
  497. package/src/global/layouts/loader.ts +0 -5
  498. package/src/global/layouts/plyr.ts +0 -24
  499. package/src/global/player.ts +0 -144
  500. package/src/global/plyr.ts +0 -917
  501. package/src/globals.d.ts +0 -11
  502. package/src/index.ts +0 -10
  503. package/src/plugins.ts +0 -369
  504. package/src/providers/audio/loader.ts +0 -45
  505. package/src/providers/audio/provider.ts +0 -50
  506. package/src/providers/dash/dash.ts +0 -417
  507. package/src/providers/dash/events.ts +0 -585
  508. package/src/providers/dash/lib-loader.ts +0 -202
  509. package/src/providers/dash/loader.ts +0 -33
  510. package/src/providers/dash/provider.ts +0 -135
  511. package/src/providers/dash/types.ts +0 -21
  512. package/src/providers/embed/EmbedProvider.ts +0 -84
  513. package/src/providers/google-cast/events.ts +0 -53
  514. package/src/providers/google-cast/loader.ts +0 -174
  515. package/src/providers/google-cast/media-info.ts +0 -49
  516. package/src/providers/google-cast/provider.ts +0 -483
  517. package/src/providers/google-cast/tracks.ts +0 -170
  518. package/src/providers/google-cast/types.ts +0 -3
  519. package/src/providers/google-cast/utils.ts +0 -112
  520. package/src/providers/hls/events.ts +0 -472
  521. package/src/providers/hls/hls.ts +0 -290
  522. package/src/providers/hls/lib-loader.ts +0 -178
  523. package/src/providers/hls/loader.ts +0 -33
  524. package/src/providers/hls/provider.ts +0 -137
  525. package/src/providers/hls/types.ts +0 -10
  526. package/src/providers/html/audio/audio-context.ts +0 -60
  527. package/src/providers/html/audio/audio-gain.ts +0 -100
  528. package/src/providers/html/html/342/200/223media-events.ts +0 -338
  529. package/src/providers/html/native-audio-tracks.ts +0 -91
  530. package/src/providers/html/provider.ts +0 -141
  531. package/src/providers/html/remote-playback.ts +0 -94
  532. package/src/providers/type-check.ts +0 -61
  533. package/src/providers/types.ts +0 -95
  534. package/src/providers/video/loader.ts +0 -45
  535. package/src/providers/video/native-hls-text-tracks.ts +0 -69
  536. package/src/providers/video/picture-in-picture.ts +0 -54
  537. package/src/providers/video/presentation/events.ts +0 -12
  538. package/src/providers/video/presentation/video-presentation.ts +0 -110
  539. package/src/providers/video/provider.ts +0 -91
  540. package/src/providers/vimeo/embed/command.ts +0 -118
  541. package/src/providers/vimeo/embed/event.ts +0 -124
  542. package/src/providers/vimeo/embed/message.ts +0 -9
  543. package/src/providers/vimeo/embed/misc.ts +0 -57
  544. package/src/providers/vimeo/embed/params.ts +0 -168
  545. package/src/providers/vimeo/loader.ts +0 -61
  546. package/src/providers/vimeo/provider.ts +0 -730
  547. package/src/providers/vimeo/utils.ts +0 -53
  548. package/src/providers/youtube/embed/command.ts +0 -21
  549. package/src/providers/youtube/embed/event.ts +0 -1
  550. package/src/providers/youtube/embed/message.ts +0 -54
  551. package/src/providers/youtube/embed/params.ts +0 -238
  552. package/src/providers/youtube/embed/quality.ts +0 -35
  553. package/src/providers/youtube/embed/state.ts +0 -13
  554. package/src/providers/youtube/loader.ts +0 -61
  555. package/src/providers/youtube/provider.ts +0 -403
  556. package/src/providers/youtube/utils.ts +0 -45
  557. package/src/tailwind.test.ts +0 -413
  558. package/src/test-utils/index.ts +0 -22
  559. package/src/test-utils/setup.ts +0 -3
  560. package/src/utils/aria.ts +0 -14
  561. package/src/utils/array.ts +0 -3
  562. package/src/utils/color.ts +0 -5
  563. package/src/utils/dom.ts +0 -458
  564. package/src/utils/error.ts +0 -11
  565. package/src/utils/language.ts +0 -16
  566. package/src/utils/manifest.ts +0 -61
  567. package/src/utils/mime.ts +0 -101
  568. package/src/utils/network.ts +0 -118
  569. package/src/utils/number.ts +0 -25
  570. package/src/utils/promise.ts +0 -12
  571. package/src/utils/scroll.ts +0 -19
  572. package/src/utils/support.ts +0 -163
  573. package/src/utils/time.test.ts +0 -111
  574. package/src/utils/time.ts +0 -123
  575. package/tsconfig.build.json +0 -9
  576. package/tsconfig.json +0 -11
  577. package/types/components/aria/announcer.d.ts +0 -27
  578. package/types/components/layouts/default/audio-layout.d.ts +0 -15
  579. package/types/components/layouts/default/context.d.ts +0 -9
  580. package/types/components/layouts/default/default-layout.d.ts +0 -10
  581. package/types/components/layouts/default/props.d.ts +0 -125
  582. package/types/components/layouts/default/translations.d.ts +0 -6
  583. package/types/components/layouts/default/video-layout.d.ts +0 -15
  584. package/types/components/layouts/plyr/context.d.ts +0 -7
  585. package/types/components/layouts/plyr/plyr-layout.d.ts +0 -9
  586. package/types/components/layouts/plyr/props.d.ts +0 -68
  587. package/types/components/layouts/plyr/translations.d.ts +0 -6
  588. package/types/components/player.d.ts +0 -214
  589. package/types/components/provider/provider.d.ts +0 -24
  590. package/types/components/provider/source-select.d.ts +0 -10
  591. package/types/components/provider/tracks.d.ts +0 -7
  592. package/types/components/ui/buttons/airplay-button.d.ts +0 -23
  593. package/types/components/ui/buttons/caption-button.d.ts +0 -21
  594. package/types/components/ui/buttons/fullscreen-button.d.ts +0 -28
  595. package/types/components/ui/buttons/google-cast-button.d.ts +0 -23
  596. package/types/components/ui/buttons/live-button.d.ts +0 -30
  597. package/types/components/ui/buttons/mute-button.d.ts +0 -21
  598. package/types/components/ui/buttons/pip-button.d.ts +0 -22
  599. package/types/components/ui/buttons/play-button.d.ts +0 -21
  600. package/types/components/ui/buttons/seek-button.d.ts +0 -32
  601. package/types/components/ui/buttons/toggle-button-controller.d.ts +0 -20
  602. package/types/components/ui/buttons/toggle-button.d.ts +0 -29
  603. package/types/components/ui/captions/captions-renderer.d.ts +0 -12
  604. package/types/components/ui/captions/captions.d.ts +0 -22
  605. package/types/components/ui/controls-group.d.ts +0 -9
  606. package/types/components/ui/controls.d.ts +0 -38
  607. package/types/components/ui/gesture.d.ts +0 -64
  608. package/types/components/ui/menu/menu-button.d.ts +0 -37
  609. package/types/components/ui/menu/menu-context.d.ts +0 -23
  610. package/types/components/ui/menu/menu-focus-controller.d.ts +0 -14
  611. package/types/components/ui/menu/menu-item.d.ts +0 -9
  612. package/types/components/ui/menu/menu-items.d.ts +0 -44
  613. package/types/components/ui/menu/menu-portal.d.ts +0 -31
  614. package/types/components/ui/menu/menu.d.ts +0 -66
  615. package/types/components/ui/menu/radio/radio-controller.d.ts +0 -14
  616. package/types/components/ui/menu/radio/radio-group-controller.d.ts +0 -11
  617. package/types/components/ui/menu/radio/radio-group.d.ts +0 -40
  618. package/types/components/ui/menu/radio/radio.d.ts +0 -50
  619. package/types/components/ui/menu/radio-groups/audio-gain-radio-group.d.ts +0 -36
  620. package/types/components/ui/menu/radio-groups/audio-radio-group.d.ts +0 -37
  621. package/types/components/ui/menu/radio-groups/captions-radio-group.d.ts +0 -38
  622. package/types/components/ui/menu/radio-groups/chapters-radio-group.d.ts +0 -46
  623. package/types/components/ui/menu/radio-groups/quality-radio-group.d.ts +0 -48
  624. package/types/components/ui/menu/radio-groups/speed-radio-group.d.ts +0 -36
  625. package/types/components/ui/popper/popper.d.ts +0 -15
  626. package/types/components/ui/poster.d.ts +0 -47
  627. package/types/components/ui/sliders/audio-gain-slider.d.ts +0 -43
  628. package/types/components/ui/sliders/quality-slider.d.ts +0 -34
  629. package/types/components/ui/sliders/slider/api/cssvars.d.ts +0 -10
  630. package/types/components/ui/sliders/slider/api/events.d.ts +0 -57
  631. package/types/components/ui/sliders/slider/api/state.d.ts +0 -68
  632. package/types/components/ui/sliders/slider/events-controller.d.ts +0 -23
  633. package/types/components/ui/sliders/slider/format.d.ts +0 -8
  634. package/types/components/ui/sliders/slider/slider-context.d.ts +0 -13
  635. package/types/components/ui/sliders/slider/slider-controller.d.ts +0 -59
  636. package/types/components/ui/sliders/slider/slider.d.ts +0 -39
  637. package/types/components/ui/sliders/slider/types.d.ts +0 -1
  638. package/types/components/ui/sliders/slider/utils.d.ts +0 -2
  639. package/types/components/ui/sliders/slider-preview.d.ts +0 -34
  640. package/types/components/ui/sliders/slider-thumbnail.d.ts +0 -16
  641. package/types/components/ui/sliders/slider-value.d.ts +0 -59
  642. package/types/components/ui/sliders/slider-video.d.ts +0 -73
  643. package/types/components/ui/sliders/speed-slider.d.ts +0 -42
  644. package/types/components/ui/sliders/time-slider/slider-chapters.d.ts +0 -36
  645. package/types/components/ui/sliders/time-slider/time-slider.d.ts +0 -56
  646. package/types/components/ui/sliders/volume-slider.d.ts +0 -35
  647. package/types/components/ui/thumbnails/thumbnail-loader.d.ts +0 -47
  648. package/types/components/ui/thumbnails/thumbnail.d.ts +0 -50
  649. package/types/components/ui/time.d.ts +0 -62
  650. package/types/components/ui/tooltip/tooltip-content.d.ts +0 -39
  651. package/types/components/ui/tooltip/tooltip-context.d.ts +0 -11
  652. package/types/components/ui/tooltip/tooltip-trigger.d.ts +0 -14
  653. package/types/components/ui/tooltip/tooltip.d.ts +0 -23
  654. package/types/core/api/media-attrs.d.ts +0 -3
  655. package/types/core/api/media-context.d.ts +0 -37
  656. package/types/core/api/media-events.d.ts +0 -581
  657. package/types/core/api/media-request-events.d.ts +0 -319
  658. package/types/core/api/player-controller.d.ts +0 -6
  659. package/types/core/api/player-events.d.ts +0 -38
  660. package/types/core/api/player-props.d.ts +0 -163
  661. package/types/core/api/player-state.d.ts +0 -656
  662. package/types/core/api/src-types.d.ts +0 -50
  663. package/types/core/api/types.d.ts +0 -54
  664. package/types/core/controls.d.ts +0 -43
  665. package/types/core/font/font-options.d.ts +0 -42
  666. package/types/core/font/font-vars.d.ts +0 -1
  667. package/types/core/keyboard/aria-shortcuts.d.ts +0 -6
  668. package/types/core/keyboard/controller.d.ts +0 -9
  669. package/types/core/keyboard/types.d.ts +0 -33
  670. package/types/core/quality/events.d.ts +0 -43
  671. package/types/core/quality/symbols.d.ts +0 -6
  672. package/types/core/quality/utils.d.ts +0 -2
  673. package/types/core/quality/video-quality.d.ts +0 -52
  674. package/types/core/state/media-events-logger.d.ts +0 -7
  675. package/types/core/state/media-load-controller.d.ts +0 -6
  676. package/types/core/state/media-player-delegate.d.ts +0 -13
  677. package/types/core/state/media-request-manager.d.ts +0 -71
  678. package/types/core/state/media-state-manager.d.ts +0 -59
  679. package/types/core/state/media-state-sync.d.ts +0 -8
  680. package/types/core/state/media-storage.d.ts +0 -74
  681. package/types/core/state/navigator-media-session.d.ts +0 -5
  682. package/types/core/state/remote-control.d.ts +0 -288
  683. package/types/core/state/tracked-media-events.d.ts +0 -2
  684. package/types/core/time-ranges.d.ts +0 -12
  685. package/types/core/tracks/audio/audio-tracks.d.ts +0 -32
  686. package/types/core/tracks/audio/events.d.ts +0 -37
  687. package/types/core/tracks/text/events.d.ts +0 -49
  688. package/types/core/tracks/text/render/libass-text-renderer.d.ts +0 -181
  689. package/types/core/tracks/text/render/native-text-renderer.d.ts +0 -13
  690. package/types/core/tracks/text/render/text-renderer.d.ts +0 -17
  691. package/types/core/tracks/text/symbols.d.ts +0 -11
  692. package/types/core/tracks/text/text-track.d.ts +0 -137
  693. package/types/core/tracks/text/text-tracks.d.ts +0 -55
  694. package/types/core/tracks/text/utils.d.ts +0 -8
  695. package/types/elements/bundles/cdn/player.core.d.ts +0 -5
  696. package/types/elements/bundles/cdn/player.d.ts +0 -7
  697. package/types/elements/bundles/cdn/plyr.d.ts +0 -5
  698. package/types/elements/bundles/cdn-legacy/player-with-default.d.ts +0 -4
  699. package/types/elements/bundles/cdn-legacy/player-with-layouts.d.ts +0 -4
  700. package/types/elements/bundles/cdn-legacy/player-with-plyr.d.ts +0 -3
  701. package/types/elements/bundles/cdn-legacy/player.d.ts +0 -3
  702. package/types/elements/bundles/icons.d.ts +0 -2
  703. package/types/elements/bundles/player-layouts/default.d.ts +0 -1
  704. package/types/elements/bundles/player-layouts/index.d.ts +0 -1
  705. package/types/elements/bundles/player-layouts/plyr.d.ts +0 -1
  706. package/types/elements/bundles/player-ui.d.ts +0 -1
  707. package/types/elements/bundles/player.d.ts +0 -1
  708. package/types/elements/define/announcer-element.d.ts +0 -18
  709. package/types/elements/define/buttons/airplay-button-element.d.ts +0 -19
  710. package/types/elements/define/buttons/caption-button-element.d.ts +0 -20
  711. package/types/elements/define/buttons/fullscreen-button-element.d.ts +0 -20
  712. package/types/elements/define/buttons/google-cast-button-element.d.ts +0 -19
  713. package/types/elements/define/buttons/live-button-element.d.ts +0 -20
  714. package/types/elements/define/buttons/mute-button-element.d.ts +0 -21
  715. package/types/elements/define/buttons/pip-button-element.d.ts +0 -20
  716. package/types/elements/define/buttons/play-button-element.d.ts +0 -21
  717. package/types/elements/define/buttons/seek-button-element.d.ts +0 -24
  718. package/types/elements/define/buttons/toggle-button-element.d.ts +0 -19
  719. package/types/elements/define/captions-element.d.ts +0 -18
  720. package/types/elements/define/chapter-title-element.d.ts +0 -30
  721. package/types/elements/define/controls-element.d.ts +0 -24
  722. package/types/elements/define/controls-group-element.d.ts +0 -24
  723. package/types/elements/define/gesture-element.d.ts +0 -22
  724. package/types/elements/define/layouts/default/audio-layout-element.d.ts +0 -29
  725. package/types/elements/define/layouts/default/audio-layout.d.ts +0 -1
  726. package/types/elements/define/layouts/default/icons-loader.d.ts +0 -5
  727. package/types/elements/define/layouts/default/icons.d.ts +0 -52
  728. package/types/elements/define/layouts/default/slots.d.ts +0 -2
  729. package/types/elements/define/layouts/default/ui/announcer.d.ts +0 -1
  730. package/types/elements/define/layouts/default/ui/buttons.d.ts +0 -31
  731. package/types/elements/define/layouts/default/ui/captions.d.ts +0 -1
  732. package/types/elements/define/layouts/default/ui/controls.d.ts +0 -1
  733. package/types/elements/define/layouts/default/ui/keyboard-display.d.ts +0 -1
  734. package/types/elements/define/layouts/default/ui/menu/accessibility-menu.d.ts +0 -1
  735. package/types/elements/define/layouts/default/ui/menu/audio-menu.d.ts +0 -1
  736. package/types/elements/define/layouts/default/ui/menu/captions-menu.d.ts +0 -1
  737. package/types/elements/define/layouts/default/ui/menu/chapters-menu.d.ts +0 -8
  738. package/types/elements/define/layouts/default/ui/menu/episodes-menu.d.ts +0 -8
  739. package/types/elements/define/layouts/default/ui/menu/font-menu.d.ts +0 -1
  740. package/types/elements/define/layouts/default/ui/menu/items/menu-checkbox.d.ts +0 -8
  741. package/types/elements/define/layouts/default/ui/menu/items/menu-items.d.ts +0 -26
  742. package/types/elements/define/layouts/default/ui/menu/items/menu-slider.d.ts +0 -3
  743. package/types/elements/define/layouts/default/ui/menu/menu-portal.d.ts +0 -4
  744. package/types/elements/define/layouts/default/ui/menu/playback-menu.d.ts +0 -1
  745. package/types/elements/define/layouts/default/ui/menu/settings-menu.d.ts +0 -8
  746. package/types/elements/define/layouts/default/ui/slider.d.ts +0 -10
  747. package/types/elements/define/layouts/default/ui/time.d.ts +0 -3
  748. package/types/elements/define/layouts/default/ui/title.d.ts +0 -2
  749. package/types/elements/define/layouts/default/ui/utils.d.ts +0 -3
  750. package/types/elements/define/layouts/default/video-layout-element.d.ts +0 -29
  751. package/types/elements/define/layouts/default/video-layout.d.ts +0 -5
  752. package/types/elements/define/layouts/icons/icons-loader.d.ts +0 -11
  753. package/types/elements/define/layouts/icons/layout-icons-loader.d.ts +0 -4
  754. package/types/elements/define/layouts/layout-element.d.ts +0 -38
  755. package/types/elements/define/layouts/layout-name.d.ts +0 -2
  756. package/types/elements/define/layouts/plyr/icons/plyr-airplay.d.ts +0 -2
  757. package/types/elements/define/layouts/plyr/icons/plyr-captions-off.d.ts +0 -2
  758. package/types/elements/define/layouts/plyr/icons/plyr-captions-on.d.ts +0 -2
  759. package/types/elements/define/layouts/plyr/icons/plyr-download.d.ts +0 -2
  760. package/types/elements/define/layouts/plyr/icons/plyr-enter-fullscreen.d.ts +0 -2
  761. package/types/elements/define/layouts/plyr/icons/plyr-exit-fullscreen.d.ts +0 -2
  762. package/types/elements/define/layouts/plyr/icons/plyr-fast-forward.d.ts +0 -2
  763. package/types/elements/define/layouts/plyr/icons/plyr-muted.d.ts +0 -2
  764. package/types/elements/define/layouts/plyr/icons/plyr-pause.d.ts +0 -2
  765. package/types/elements/define/layouts/plyr/icons/plyr-pip.d.ts +0 -2
  766. package/types/elements/define/layouts/plyr/icons/plyr-play.d.ts +0 -2
  767. package/types/elements/define/layouts/plyr/icons/plyr-restart.d.ts +0 -2
  768. package/types/elements/define/layouts/plyr/icons/plyr-rewind.d.ts +0 -2
  769. package/types/elements/define/layouts/plyr/icons/plyr-settings.d.ts +0 -2
  770. package/types/elements/define/layouts/plyr/icons/plyr-volume.d.ts +0 -2
  771. package/types/elements/define/layouts/plyr/icons-loader.d.ts +0 -5
  772. package/types/elements/define/layouts/plyr/icons.d.ts +0 -18
  773. package/types/elements/define/layouts/plyr/plyr-layout-element.d.ts +0 -26
  774. package/types/elements/define/layouts/plyr/ui.d.ts +0 -3
  775. package/types/elements/define/layouts/slot-manager.d.ts +0 -7
  776. package/types/elements/define/layouts/slot-observer.d.ts +0 -12
  777. package/types/elements/define/menus/_template.d.ts +0 -7
  778. package/types/elements/define/menus/audio-gain-group-element.d.ts +0 -31
  779. package/types/elements/define/menus/audio-radio-group-element.d.ts +0 -31
  780. package/types/elements/define/menus/captions-radio-group-element.d.ts +0 -31
  781. package/types/elements/define/menus/chapters-radio-group-element.d.ts +0 -36
  782. package/types/elements/define/menus/menu-button-element.d.ts +0 -25
  783. package/types/elements/define/menus/menu-element.d.ts +0 -26
  784. package/types/elements/define/menus/menu-item-element.d.ts +0 -22
  785. package/types/elements/define/menus/menu-items-element.d.ts +0 -25
  786. package/types/elements/define/menus/menu-portal-element.d.ts +0 -25
  787. package/types/elements/define/menus/quality-radio-group-element.d.ts +0 -33
  788. package/types/elements/define/menus/radio-element.d.ts +0 -22
  789. package/types/elements/define/menus/radio-group-element.d.ts +0 -22
  790. package/types/elements/define/menus/speed-radio-group-element.d.ts +0 -31
  791. package/types/elements/define/player-element.d.ts +0 -24
  792. package/types/elements/define/poster-element.d.ts +0 -25
  793. package/types/elements/define/provider-cast-display.d.ts +0 -2
  794. package/types/elements/define/provider-element.d.ts +0 -25
  795. package/types/elements/define/sliders/audio-gain-slider-element.d.ts +0 -32
  796. package/types/elements/define/sliders/quality-slider-element.d.ts +0 -32
  797. package/types/elements/define/sliders/slider-chapters-element.d.ts +0 -31
  798. package/types/elements/define/sliders/slider-element.d.ts +0 -23
  799. package/types/elements/define/sliders/slider-preview-element.d.ts +0 -14
  800. package/types/elements/define/sliders/slider-steps-element.d.ts +0 -28
  801. package/types/elements/define/sliders/slider-thumbnail-element.d.ts +0 -26
  802. package/types/elements/define/sliders/slider-value-element.d.ts +0 -37
  803. package/types/elements/define/sliders/slider-video-element.d.ts +0 -25
  804. package/types/elements/define/sliders/speed-slider-element.d.ts +0 -32
  805. package/types/elements/define/sliders/time-slider-element.d.ts +0 -32
  806. package/types/elements/define/sliders/volume-slider-element.d.ts +0 -32
  807. package/types/elements/define/spinner-element.d.ts +0 -50
  808. package/types/elements/define/thumbnail-element.d.ts +0 -29
  809. package/types/elements/define/time-element.d.ts +0 -24
  810. package/types/elements/define/title-element.d.ts +0 -23
  811. package/types/elements/define/tooltips/tooltip-content-element.d.ts +0 -26
  812. package/types/elements/define/tooltips/tooltip-element.d.ts +0 -26
  813. package/types/elements/define/tooltips/tooltip-trigger-element.d.ts +0 -27
  814. package/types/elements/icon.d.ts +0 -10
  815. package/types/elements/index.d.ts +0 -56
  816. package/types/elements/lit/directives/signal.d.ts +0 -1
  817. package/types/elements/lit/html.d.ts +0 -4
  818. package/types/elements/lit/lit-element.d.ts +0 -8
  819. package/types/elements/state-controller.d.ts +0 -5
  820. package/types/exports/components.d.ts +0 -59
  821. package/types/exports/core.d.ts +0 -26
  822. package/types/exports/events.d.ts +0 -32
  823. package/types/exports/font.d.ts +0 -2
  824. package/types/exports/foundation.d.ts +0 -8
  825. package/types/exports/maverick.d.ts +0 -1
  826. package/types/exports/providers.d.ts +0 -22
  827. package/types/exports/utils.d.ts +0 -4
  828. package/types/foundation/fullscreen/controller.d.ts +0 -39
  829. package/types/foundation/fullscreen/events.d.ts +0 -25
  830. package/types/foundation/list/list.d.ts +0 -64
  831. package/types/foundation/list/select-list.d.ts +0 -30
  832. package/types/foundation/list/symbols.d.ts +0 -14
  833. package/types/foundation/logger/colors.d.ts +0 -5
  834. package/types/foundation/logger/controller.d.ts +0 -20
  835. package/types/foundation/logger/events.d.ts +0 -26
  836. package/types/foundation/logger/grouped-log.d.ts +0 -22
  837. package/types/foundation/logger/log-level.d.ts +0 -15
  838. package/types/foundation/logger/log-printer.d.ts +0 -11
  839. package/types/foundation/logger/ms.d.ts +0 -4
  840. package/types/foundation/observers/focus-visible.d.ts +0 -7
  841. package/types/foundation/observers/intersection-observer.d.ts +0 -36
  842. package/types/foundation/observers/page-visibility.d.ts +0 -37
  843. package/types/foundation/observers/raf-loop.d.ts +0 -6
  844. package/types/foundation/orientation/controller.d.ts +0 -62
  845. package/types/foundation/orientation/events.d.ts +0 -16
  846. package/types/foundation/orientation/types.d.ts +0 -85
  847. package/types/foundation/queue/queue.d.ts +0 -24
  848. package/types/foundation/queue/request-queue.d.ts +0 -42
  849. package/types/global/layouts/default.d.ts +0 -9
  850. package/types/global/layouts/loader.d.ts +0 -5
  851. package/types/global/layouts/plyr.d.ts +0 -9
  852. package/types/global/player.d.ts +0 -26
  853. package/types/index.d.ts +0 -6
  854. package/types/plugins.d.ts +0 -11
  855. package/types/providers/audio/loader.d.ts +0 -12
  856. package/types/providers/audio/provider.d.ts +0 -29
  857. package/types/providers/dash/dash.d.ts +0 -15
  858. package/types/providers/dash/events.d.ts +0 -570
  859. package/types/providers/dash/lib-loader.d.ts +0 -6
  860. package/types/providers/dash/loader.d.ts +0 -10
  861. package/types/providers/dash/provider.d.ts +0 -62
  862. package/types/providers/dash/types.d.ts +0 -13
  863. package/types/providers/embed/EmbedProvider.d.ts +0 -18
  864. package/types/providers/google-cast/events.d.ts +0 -36
  865. package/types/providers/google-cast/loader.d.ts +0 -18
  866. package/types/providers/google-cast/media-info.d.ts +0 -11
  867. package/types/providers/google-cast/provider.d.ts +0 -48
  868. package/types/providers/google-cast/tracks.d.ts +0 -10
  869. package/types/providers/google-cast/types.d.ts +0 -3
  870. package/types/providers/google-cast/utils.d.ts +0 -34
  871. package/types/providers/hls/events.d.ts +0 -463
  872. package/types/providers/hls/hls.d.ts +0 -14
  873. package/types/providers/hls/lib-loader.d.ts +0 -6
  874. package/types/providers/hls/loader.d.ts +0 -10
  875. package/types/providers/hls/provider.d.ts +0 -64
  876. package/types/providers/hls/types.d.ts +0 -9
  877. package/types/providers/html/audio/audio-context.d.ts +0 -6
  878. package/types/providers/html/audio/audio-gain.d.ts +0 -10
  879. package/types/providers/html/html/342/200/223media-events.d.ts +0 -6
  880. package/types/providers/html/native-audio-tracks.d.ts +0 -6
  881. package/types/providers/html/provider.d.ts +0 -34
  882. package/types/providers/html/remote-playback.d.ts +0 -18
  883. package/types/providers/type-check.d.ts +0 -28
  884. package/types/providers/types.d.ts +0 -95
  885. package/types/providers/video/loader.d.ts +0 -12
  886. package/types/providers/video/native-hls-text-tracks.d.ts +0 -9
  887. package/types/providers/video/picture-in-picture.d.ts +0 -16
  888. package/types/providers/video/presentation/events.d.ts +0 -11
  889. package/types/providers/video/presentation/video-presentation.d.ts +0 -30
  890. package/types/providers/video/provider.d.ts +0 -34
  891. package/types/providers/vimeo/embed/command.d.ts +0 -81
  892. package/types/providers/vimeo/embed/event.d.ts +0 -58
  893. package/types/providers/vimeo/embed/message.d.ts +0 -8
  894. package/types/providers/vimeo/embed/misc.d.ts +0 -52
  895. package/types/providers/vimeo/embed/params.d.ts +0 -148
  896. package/types/providers/vimeo/loader.d.ts +0 -14
  897. package/types/providers/vimeo/provider.d.ts +0 -61
  898. package/types/providers/vimeo/utils.d.ts +0 -6
  899. package/types/providers/youtube/embed/command.d.ts +0 -13
  900. package/types/providers/youtube/embed/event.d.ts +0 -1
  901. package/types/providers/youtube/embed/message.d.ts +0 -50
  902. package/types/providers/youtube/embed/params.d.ts +0 -218
  903. package/types/providers/youtube/embed/quality.d.ts +0 -2
  904. package/types/providers/youtube/embed/state.d.ts +0 -12
  905. package/types/providers/youtube/loader.d.ts +0 -14
  906. package/types/providers/youtube/provider.d.ts +0 -61
  907. package/types/providers/youtube/utils.d.ts +0 -2
  908. package/types/utils/aria.d.ts +0 -4
  909. package/types/utils/array.d.ts +0 -1
  910. package/types/utils/color.d.ts +0 -1
  911. package/types/utils/dom.d.ts +0 -41
  912. package/types/utils/error.d.ts +0 -2
  913. package/types/utils/language.d.ts +0 -8
  914. package/types/utils/manifest.d.ts +0 -3
  915. package/types/utils/mime.d.ts +0 -15
  916. package/types/utils/network.d.ts +0 -17
  917. package/types/utils/number.d.ts +0 -17
  918. package/types/utils/promise.d.ts +0 -1
  919. package/types/utils/scroll.d.ts +0 -5
  920. package/types/utils/support.d.ts +0 -72
  921. package/types/utils/time.d.ts +0 -57
  922. package/vite.config.ts +0 -61
  923. /package/{npm/analyze.json.d.ts → analyze.json.d.ts} +0 -0
  924. /package/{npm/bundle.d.ts → bundle.d.ts} +0 -0
  925. /package/{npm/dom.d.ts → dom.d.ts} +0 -0
  926. /package/{npm/empty.vtt → empty.vtt} +0 -0
  927. /package/{npm/google-cast.d.ts → google-cast.d.ts} +0 -0
  928. /package/{npm/player → player}/index.d.ts +0 -0
  929. /package/{npm/player → player}/layouts/default.d.ts +0 -0
  930. /package/{npm/player → player}/layouts/index.d.ts +0 -0
  931. /package/{npm/player → player}/layouts/plyr.d.ts +0 -0
  932. /package/{styles/player → player/styles}/base.css +0 -0
  933. /package/{styles/player → player/styles}/default/buffering.css +0 -0
  934. /package/{styles/player → player/styles}/default/buttons.css +0 -0
  935. /package/{styles/player → player/styles}/default/captions.css +0 -0
  936. /package/{styles/player → player/styles}/default/chapter-title.css +0 -0
  937. /package/{styles/player → player/styles}/default/controls.css +0 -0
  938. /package/{styles/player → player/styles}/default/gestures.css +0 -0
  939. /package/{styles/player → player/styles}/default/icons.css +0 -0
  940. /package/{styles/player → player/styles}/default/keyboard.css +0 -0
  941. /package/{styles/player → player/styles}/default/layouts/audio.css +0 -0
  942. /package/{styles/player → player/styles}/default/menus.css +0 -0
  943. /package/{styles/player → player/styles}/default/poster.css +0 -0
  944. /package/{styles/player → player/styles}/default/sliders.css +0 -0
  945. /package/{styles/player → player/styles}/default/theme.css +0 -0
  946. /package/{styles/player → player/styles}/default/thumbnail.css +0 -0
  947. /package/{styles/player → player/styles}/default/time.css +0 -0
  948. /package/{styles/player → player/styles}/default/tooltips.css +0 -0
  949. /package/{styles/player → player/styles}/plyr/theme.css +0 -0
  950. /package/{npm/player → player}/ui.d.ts +0 -0
  951. /package/{npm/tailwind.cjs → tailwind.cjs} +0 -0
  952. /package/{npm/tailwind.d.cts → tailwind.d.cts} +0 -0
@@ -0,0 +1,1502 @@
1
+ import { Component, State, effect, tick, peek, setAttribute, isString, setStyle, createContext, signal, EventsController, provideContext, onDispose, useContext, prop, useState, isNull, functionThrottle, computed, method, scoped, createScope, animationFrameThrottle, functionDebounce, hasProvidedContext, isNumber, listenEvent, isPointerEvent, isTouchEvent, isMouseEvent, DOMEvent, kebabToCamelCase } from './vidstack-B8LynzY5.js';
2
+ import { useMediaContext, setAttributeIfEmpty, requestScopedAnimationFrame, autoPlacement, setARIALabel, watchActiveTextTrack, isCueActive, isTouchPinchEvent } from './vidstack-B4CWj0Hp.js';
3
+ import { formatSpokenTime, Popper, ToggleButtonController, Slider, SliderController, sliderState, sliderValueFormatContext, TimeSlider, RadioGroupController, menuContext, formatTime } from './vidstack-BGmwlunt.js';
4
+ import { FocusVisibleController, $keyboard, round, isTrackCaptionKind } from './vidstack-C19bj3Wq.js';
5
+ import { $ariaBool, sortVideoQualities } from './vidstack-BOTZD4tC.js';
6
+
7
+ class MediaAnnouncer extends Component {
8
+ static props = {
9
+ translations: null
10
+ };
11
+ static state = new State({
12
+ label: null,
13
+ busy: false
14
+ });
15
+ #media;
16
+ #initializing = false;
17
+ onSetup() {
18
+ this.#media = useMediaContext();
19
+ }
20
+ onAttach(el) {
21
+ el.style.display = "contents";
22
+ }
23
+ onConnect(el) {
24
+ el.setAttribute("data-media-announcer", "");
25
+ setAttributeIfEmpty(el, "role", "status");
26
+ setAttributeIfEmpty(el, "aria-live", "polite");
27
+ const { busy } = this.$state;
28
+ this.setAttributes({
29
+ "aria-busy": () => busy() ? "true" : null
30
+ });
31
+ this.#initializing = true;
32
+ effect(this.#watchPaused.bind(this));
33
+ effect(this.#watchVolume.bind(this));
34
+ effect(this.#watchCaptions.bind(this));
35
+ effect(this.#watchFullscreen.bind(this));
36
+ effect(this.#watchPiP.bind(this));
37
+ effect(this.#watchSeeking.bind(this));
38
+ effect(this.#watchLabel.bind(this));
39
+ tick();
40
+ this.#initializing = false;
41
+ }
42
+ #watchPaused() {
43
+ const { paused } = this.#media.$state;
44
+ this.#setLabel(!paused() ? "Play" : "Pause");
45
+ }
46
+ #watchFullscreen() {
47
+ const { fullscreen } = this.#media.$state;
48
+ this.#setLabel(fullscreen() ? "Enter Fullscreen" : "Exit Fullscreen");
49
+ }
50
+ #watchPiP() {
51
+ const { pictureInPicture } = this.#media.$state;
52
+ this.#setLabel(pictureInPicture() ? "Enter PiP" : "Exit PiP");
53
+ }
54
+ #watchCaptions() {
55
+ const { textTrack } = this.#media.$state;
56
+ this.#setLabel(textTrack() ? "Closed-Captions On" : "Closed-Captions Off");
57
+ }
58
+ #watchVolume() {
59
+ const { muted, volume, audioGain } = this.#media.$state;
60
+ this.#setLabel(
61
+ muted() || volume() === 0 ? "Mute" : `${Math.round(volume() * (audioGain() ?? 1) * 100)}% ${this.#translate("Volume")}`
62
+ );
63
+ }
64
+ #startedSeekingAt = -1;
65
+ #seekTimer = -1;
66
+ #watchSeeking() {
67
+ const { seeking, currentTime } = this.#media.$state, isSeeking = seeking();
68
+ if (this.#startedSeekingAt > 0) {
69
+ window.clearTimeout(this.#seekTimer);
70
+ this.#seekTimer = window.setTimeout(() => {
71
+ if (!this.scope) return;
72
+ const newTime = peek(currentTime), seconds = Math.abs(newTime - this.#startedSeekingAt);
73
+ if (seconds >= 1) {
74
+ const isForward = newTime >= this.#startedSeekingAt, spokenTime = formatSpokenTime(seconds);
75
+ this.#setLabel(
76
+ `${this.#translate(isForward ? "Seek Forward" : "Seek Backward")} ${spokenTime}`
77
+ );
78
+ }
79
+ this.#startedSeekingAt = -1;
80
+ this.#seekTimer = -1;
81
+ }, 300);
82
+ } else if (isSeeking) {
83
+ this.#startedSeekingAt = peek(currentTime);
84
+ }
85
+ }
86
+ #translate(word) {
87
+ const { translations } = this.$props;
88
+ return translations?.()?.[word || ""] ?? word;
89
+ }
90
+ #watchLabel() {
91
+ const { label, busy } = this.$state, $label = this.#translate(label());
92
+ if (this.#initializing) return;
93
+ busy.set(true);
94
+ const id = window.setTimeout(() => void busy.set(false), 150);
95
+ this.el && setAttribute(this.el, "aria-label", $label);
96
+ if (isString($label)) {
97
+ this.dispatch("change", { detail: $label });
98
+ }
99
+ return () => window.clearTimeout(id);
100
+ }
101
+ #setLabel(word) {
102
+ const { label } = this.$state;
103
+ label.set(word);
104
+ }
105
+ }
106
+
107
+ class Controls extends Component {
108
+ static props = {
109
+ hideDelay: 2e3,
110
+ hideOnMouseLeave: false
111
+ };
112
+ #media;
113
+ onSetup() {
114
+ this.#media = useMediaContext();
115
+ effect(this.#watchProps.bind(this));
116
+ }
117
+ onAttach(el) {
118
+ const { pictureInPicture, fullscreen } = this.#media.$state;
119
+ setStyle(el, "pointer-events", "none");
120
+ setAttributeIfEmpty(el, "role", "group");
121
+ this.setAttributes({
122
+ "data-visible": this.#isShowing.bind(this),
123
+ "data-fullscreen": fullscreen,
124
+ "data-pip": pictureInPicture
125
+ });
126
+ effect(() => {
127
+ this.dispatch("change", { detail: this.#isShowing() });
128
+ });
129
+ effect(this.#hideControls.bind(this));
130
+ effect(() => {
131
+ const isFullscreen = fullscreen();
132
+ for (const side of ["top", "right", "bottom", "left"]) {
133
+ setStyle(el, `padding-${side}`, isFullscreen && `env(safe-area-inset-${side})`);
134
+ }
135
+ });
136
+ }
137
+ #hideControls() {
138
+ if (!this.el) return;
139
+ const { nativeControls } = this.#media.$state, isHidden = nativeControls();
140
+ setAttribute(this.el, "aria-hidden", isHidden ? "true" : null);
141
+ setStyle(this.el, "display", isHidden ? "none" : null);
142
+ }
143
+ #watchProps() {
144
+ const { controls } = this.#media.player, { hideDelay, hideOnMouseLeave } = this.$props;
145
+ controls.defaultDelay = hideDelay() === 2e3 ? this.#media.$props.controlsDelay() : hideDelay();
146
+ controls.hideOnMouseLeave = hideOnMouseLeave();
147
+ }
148
+ #isShowing() {
149
+ const { controlsVisible } = this.#media.$state;
150
+ return controlsVisible();
151
+ }
152
+ }
153
+
154
+ class ControlsGroup extends Component {
155
+ onAttach(el) {
156
+ if (!el.style.pointerEvents) setStyle(el, "pointer-events", "auto");
157
+ }
158
+ }
159
+
160
+ const tooltipContext = createContext();
161
+
162
+ let id = 0;
163
+ class Tooltip extends Component {
164
+ static props = {
165
+ showDelay: 700
166
+ };
167
+ #id = `media-tooltip-${++id}`;
168
+ #trigger = signal(null);
169
+ #content = signal(null);
170
+ #showing = signal(false);
171
+ constructor() {
172
+ super();
173
+ new FocusVisibleController();
174
+ const { showDelay } = this.$props;
175
+ new Popper({
176
+ trigger: this.#trigger,
177
+ content: this.#content,
178
+ showDelay,
179
+ listen(trigger, show, hide) {
180
+ effect(() => {
181
+ if ($keyboard()) ;
182
+ });
183
+ new EventsController(trigger).add("touchstart", (e) => e.preventDefault(), { passive: false }).add("mouseenter", show).add("mouseleave", hide);
184
+ },
185
+ onChange: this.#onShowingChange.bind(this)
186
+ });
187
+ }
188
+ onAttach(el) {
189
+ el.style.setProperty("display", "contents");
190
+ }
191
+ onSetup() {
192
+ provideContext(tooltipContext, {
193
+ trigger: this.#trigger,
194
+ content: this.#content,
195
+ showing: this.#showing,
196
+ attachTrigger: this.#attachTrigger.bind(this),
197
+ detachTrigger: this.#detachTrigger.bind(this),
198
+ attachContent: this.#attachContent.bind(this),
199
+ detachContent: this.#detachContent.bind(this)
200
+ });
201
+ }
202
+ #attachTrigger(el) {
203
+ this.#trigger.set(el);
204
+ let tooltipName = el.getAttribute("data-media-tooltip");
205
+ if (tooltipName) {
206
+ this.el?.setAttribute(`data-media-${tooltipName}-tooltip`, "");
207
+ }
208
+ setAttribute(el, "data-describedby", this.#id);
209
+ }
210
+ #detachTrigger(el) {
211
+ el.removeAttribute("data-describedby");
212
+ el.removeAttribute("aria-describedby");
213
+ this.#trigger.set(null);
214
+ }
215
+ #attachContent(el) {
216
+ el.setAttribute("id", this.#id);
217
+ el.style.display = "none";
218
+ setAttributeIfEmpty(el, "role", "tooltip");
219
+ this.#content.set(el);
220
+ }
221
+ #detachContent(el) {
222
+ el.removeAttribute("id");
223
+ el.removeAttribute("role");
224
+ this.#content.set(null);
225
+ }
226
+ #onShowingChange(isShowing) {
227
+ const trigger = this.#trigger(), content = this.#content();
228
+ if (trigger) {
229
+ setAttribute(trigger, "aria-describedby", isShowing ? this.#id : null);
230
+ }
231
+ for (const el of [this.el, trigger, content]) {
232
+ el && setAttribute(el, "data-visible", isShowing);
233
+ }
234
+ this.#showing.set(isShowing);
235
+ }
236
+ }
237
+
238
+ class TooltipTrigger extends Component {
239
+ constructor() {
240
+ super();
241
+ new FocusVisibleController();
242
+ }
243
+ onConnect(el) {
244
+ onDispose(
245
+ requestScopedAnimationFrame(() => {
246
+ if (!this.connectScope) return;
247
+ this.#attach();
248
+ const tooltip = useContext(tooltipContext);
249
+ onDispose(() => {
250
+ const button = this.#getButton();
251
+ button && tooltip.detachTrigger(button);
252
+ });
253
+ })
254
+ );
255
+ }
256
+ #attach() {
257
+ const button = this.#getButton(), tooltip = useContext(tooltipContext);
258
+ button && tooltip.attachTrigger(button);
259
+ }
260
+ #getButton() {
261
+ const candidate = this.el.firstElementChild;
262
+ return candidate?.localName === "button" || candidate?.getAttribute("role") === "button" ? candidate : this.el;
263
+ }
264
+ }
265
+
266
+ class TooltipContent extends Component {
267
+ static props = {
268
+ placement: "top center",
269
+ offset: 0,
270
+ alignOffset: 0
271
+ };
272
+ constructor() {
273
+ super();
274
+ new FocusVisibleController();
275
+ const { placement } = this.$props;
276
+ this.setAttributes({
277
+ "data-placement": placement
278
+ });
279
+ }
280
+ onAttach(el) {
281
+ this.#attach(el);
282
+ Object.assign(el.style, {
283
+ position: "absolute",
284
+ top: 0,
285
+ left: 0,
286
+ width: "max-content"
287
+ });
288
+ }
289
+ onConnect(el) {
290
+ this.#attach(el);
291
+ const tooltip = useContext(tooltipContext);
292
+ onDispose(() => tooltip.detachContent(el));
293
+ onDispose(
294
+ requestScopedAnimationFrame(() => {
295
+ if (!this.connectScope) return;
296
+ effect(this.#watchPlacement.bind(this));
297
+ })
298
+ );
299
+ }
300
+ #attach(el) {
301
+ const tooltip = useContext(tooltipContext);
302
+ tooltip.attachContent(el);
303
+ }
304
+ #watchPlacement() {
305
+ const { showing } = useContext(tooltipContext);
306
+ if (!showing()) return;
307
+ const { placement, offset: mainOffset, alignOffset } = this.$props;
308
+ return autoPlacement(this.el, this.#getTrigger(), placement(), {
309
+ offsetVarName: "media-tooltip",
310
+ xOffset: alignOffset(),
311
+ yOffset: mainOffset()
312
+ });
313
+ }
314
+ #getTrigger() {
315
+ return useContext(tooltipContext).trigger();
316
+ }
317
+ }
318
+
319
+ class ToggleButton extends Component {
320
+ static props = {
321
+ disabled: false,
322
+ defaultPressed: false
323
+ };
324
+ #pressed = signal(false);
325
+ /**
326
+ * Whether the toggle is currently in a `pressed` state.
327
+ */
328
+ get pressed() {
329
+ return this.#pressed();
330
+ }
331
+ constructor() {
332
+ super();
333
+ new ToggleButtonController({
334
+ isPresssed: this.#pressed
335
+ });
336
+ }
337
+ }
338
+ const togglebutton__proto = ToggleButton.prototype;
339
+ prop(togglebutton__proto, "pressed");
340
+
341
+ class GoogleCastButton extends Component {
342
+ static props = ToggleButtonController.props;
343
+ #media;
344
+ constructor() {
345
+ super();
346
+ new ToggleButtonController({
347
+ isPresssed: this.#isPressed.bind(this),
348
+ onPress: this.#onPress.bind(this)
349
+ });
350
+ }
351
+ onSetup() {
352
+ this.#media = useMediaContext();
353
+ const { canGoogleCast, isGoogleCastConnected } = this.#media.$state;
354
+ this.setAttributes({
355
+ "data-active": isGoogleCastConnected,
356
+ "data-supported": canGoogleCast,
357
+ "data-state": this.#getState.bind(this),
358
+ "aria-hidden": $ariaBool(() => !canGoogleCast())
359
+ });
360
+ }
361
+ onAttach(el) {
362
+ el.setAttribute("data-media-tooltip", "google-cast");
363
+ setARIALabel(el, this.#getDefaultLabel.bind(this));
364
+ }
365
+ #onPress(event) {
366
+ const remote = this.#media.remote;
367
+ remote.requestGoogleCast(event);
368
+ }
369
+ #isPressed() {
370
+ const { remotePlaybackType, remotePlaybackState } = this.#media.$state;
371
+ return remotePlaybackType() === "google-cast" && remotePlaybackState() !== "disconnected";
372
+ }
373
+ #getState() {
374
+ const { remotePlaybackType, remotePlaybackState } = this.#media.$state;
375
+ return remotePlaybackType() === "google-cast" && remotePlaybackState();
376
+ }
377
+ #getDefaultLabel() {
378
+ const { remotePlaybackState } = this.#media.$state;
379
+ return `Google Cast ${remotePlaybackState()}`;
380
+ }
381
+ }
382
+
383
+ class SliderVideo extends Component {
384
+ static props = {
385
+ src: null,
386
+ crossOrigin: null
387
+ };
388
+ static state = new State({
389
+ video: null,
390
+ src: null,
391
+ crossOrigin: null,
392
+ canPlay: false,
393
+ error: null,
394
+ hidden: false
395
+ });
396
+ #media;
397
+ #slider;
398
+ get video() {
399
+ return this.$state.video();
400
+ }
401
+ onSetup() {
402
+ this.#media = useMediaContext();
403
+ this.#slider = useState(Slider.state);
404
+ this.#watchCrossOrigin();
405
+ this.setAttributes({
406
+ "data-loading": this.#isLoading.bind(this),
407
+ "data-hidden": this.$state.hidden,
408
+ "data-error": this.#hasError.bind(this),
409
+ "aria-hidden": $ariaBool(this.$state.hidden)
410
+ });
411
+ }
412
+ onAttach(el) {
413
+ effect(this.#watchVideo.bind(this));
414
+ effect(this.#watchSrc.bind(this));
415
+ effect(this.#watchCrossOrigin.bind(this));
416
+ effect(this.#watchHidden.bind(this));
417
+ effect(this.#onSrcChange.bind(this));
418
+ effect(this.#onUpdateTime.bind(this));
419
+ }
420
+ #watchVideo() {
421
+ const video = this.$state.video();
422
+ if (!video) return;
423
+ if (video.readyState >= 2) this.#onCanPlay();
424
+ new EventsController(video).add("canplay", this.#onCanPlay.bind(this)).add("error", this.#onError.bind(this));
425
+ }
426
+ #watchSrc() {
427
+ const { src } = this.$state, { canLoad } = this.#media.$state;
428
+ src.set(canLoad() ? this.$props.src() : null);
429
+ }
430
+ #watchCrossOrigin() {
431
+ const { crossOrigin: crossOriginProp } = this.$props, { crossOrigin: crossOriginState } = this.$state, { crossOrigin: mediaCrossOrigin } = this.#media.$state, crossOrigin = crossOriginProp() !== null ? crossOriginProp() : mediaCrossOrigin();
432
+ crossOriginState.set(crossOrigin === true ? "anonymous" : crossOrigin);
433
+ }
434
+ #isLoading() {
435
+ const { canPlay, hidden } = this.$state;
436
+ return !canPlay() && !hidden();
437
+ }
438
+ #hasError() {
439
+ const { error } = this.$state;
440
+ return !isNull(error);
441
+ }
442
+ #watchHidden() {
443
+ const { src, hidden } = this.$state, { canLoad, duration } = this.#media.$state;
444
+ hidden.set(canLoad() && (!src() || this.#hasError() || !Number.isFinite(duration())));
445
+ }
446
+ #onSrcChange() {
447
+ const { src, canPlay, error } = this.$state;
448
+ src();
449
+ canPlay.set(false);
450
+ error.set(null);
451
+ }
452
+ #onCanPlay(event) {
453
+ const { canPlay, error } = this.$state;
454
+ canPlay.set(true);
455
+ error.set(null);
456
+ this.dispatch("can-play", { trigger: event });
457
+ }
458
+ #onError(event) {
459
+ const { canPlay, error } = this.$state;
460
+ canPlay.set(false);
461
+ error.set(event);
462
+ this.dispatch("error", { trigger: event });
463
+ }
464
+ #onUpdateTime() {
465
+ const { video, canPlay } = this.$state, { duration } = this.#media.$state, { pointerRate } = this.#slider, media = video(), canUpdate = canPlay() && media && Number.isFinite(duration()) && Number.isFinite(pointerRate());
466
+ if (canUpdate) {
467
+ media.currentTime = pointerRate() * duration();
468
+ }
469
+ }
470
+ }
471
+ const slidervideo__proto = SliderVideo.prototype;
472
+ prop(slidervideo__proto, "video");
473
+
474
+ class AudioGainSlider extends Component {
475
+ static props = {
476
+ ...SliderController.props,
477
+ step: 25,
478
+ keyStep: 25,
479
+ shiftKeyMultiplier: 2,
480
+ min: 0,
481
+ max: 300
482
+ };
483
+ static state = sliderState;
484
+ #media;
485
+ onSetup() {
486
+ this.#media = useMediaContext();
487
+ provideContext(sliderValueFormatContext, {
488
+ default: "percent",
489
+ percent: (_, decimalPlaces) => {
490
+ return round(this.$state.value(), decimalPlaces) + "%";
491
+ }
492
+ });
493
+ new SliderController({
494
+ getStep: this.$props.step,
495
+ getKeyStep: this.$props.keyStep,
496
+ roundValue: Math.round,
497
+ isDisabled: this.#isDisabled.bind(this),
498
+ aria: {
499
+ valueNow: this.#getARIAValueNow.bind(this),
500
+ valueText: this.#getARIAValueText.bind(this)
501
+ },
502
+ onDragValueChange: this.#onDragValueChange.bind(this),
503
+ onValueChange: this.#onValueChange.bind(this)
504
+ }).attach(this);
505
+ effect(this.#watchMinMax.bind(this));
506
+ effect(this.#watchAudioGain.bind(this));
507
+ }
508
+ onAttach(el) {
509
+ el.setAttribute("data-media-audio-gain-slider", "");
510
+ setAttributeIfEmpty(el, "aria-label", "Audio Boost");
511
+ const { canSetAudioGain } = this.#media.$state;
512
+ this.setAttributes({
513
+ "data-supported": canSetAudioGain,
514
+ "aria-hidden": $ariaBool(() => !canSetAudioGain())
515
+ });
516
+ }
517
+ #getARIAValueNow() {
518
+ const { value } = this.$state;
519
+ return Math.round(value());
520
+ }
521
+ #getARIAValueText() {
522
+ const { value } = this.$state;
523
+ return value() + "%";
524
+ }
525
+ #watchMinMax() {
526
+ const { min, max } = this.$props;
527
+ this.$state.min.set(min());
528
+ this.$state.max.set(max());
529
+ }
530
+ #watchAudioGain() {
531
+ const { audioGain } = this.#media.$state, value = ((audioGain() ?? 1) - 1) * 100;
532
+ this.$state.value.set(value);
533
+ this.dispatch("value-change", { detail: value });
534
+ }
535
+ #isDisabled() {
536
+ const { disabled } = this.$props, { canSetAudioGain } = this.#media.$state;
537
+ return disabled() || !canSetAudioGain();
538
+ }
539
+ #onAudioGainChange(event) {
540
+ if (!event.trigger) return;
541
+ const gain = round(1 + event.detail / 100, 2);
542
+ this.#media.remote.changeAudioGain(gain, event);
543
+ }
544
+ #onValueChange(event) {
545
+ this.#onAudioGainChange(event);
546
+ }
547
+ #onDragValueChange(event) {
548
+ this.#onAudioGainChange(event);
549
+ }
550
+ }
551
+
552
+ class SpeedSlider extends Component {
553
+ static props = {
554
+ ...SliderController.props,
555
+ step: 0.25,
556
+ keyStep: 0.25,
557
+ shiftKeyMultiplier: 2,
558
+ min: 0,
559
+ max: 2
560
+ };
561
+ static state = sliderState;
562
+ #media;
563
+ onSetup() {
564
+ this.#media = useMediaContext();
565
+ new SliderController({
566
+ getStep: this.$props.step,
567
+ getKeyStep: this.$props.keyStep,
568
+ roundValue: this.#roundValue,
569
+ isDisabled: this.#isDisabled.bind(this),
570
+ aria: {
571
+ valueNow: this.#getARIAValueNow.bind(this),
572
+ valueText: this.#getARIAValueText.bind(this)
573
+ },
574
+ onDragValueChange: this.#onDragValueChange.bind(this),
575
+ onValueChange: this.#onValueChange.bind(this)
576
+ }).attach(this);
577
+ effect(this.#watchMinMax.bind(this));
578
+ effect(this.#watchPlaybackRate.bind(this));
579
+ }
580
+ onAttach(el) {
581
+ el.setAttribute("data-media-speed-slider", "");
582
+ setAttributeIfEmpty(el, "aria-label", "Speed");
583
+ const { canSetPlaybackRate } = this.#media.$state;
584
+ this.setAttributes({
585
+ "data-supported": canSetPlaybackRate,
586
+ "aria-hidden": $ariaBool(() => !canSetPlaybackRate())
587
+ });
588
+ }
589
+ #getARIAValueNow() {
590
+ const { value } = this.$state;
591
+ return value();
592
+ }
593
+ #getARIAValueText() {
594
+ const { value } = this.$state;
595
+ return value() + "x";
596
+ }
597
+ #watchMinMax() {
598
+ const { min, max } = this.$props;
599
+ this.$state.min.set(min());
600
+ this.$state.max.set(max());
601
+ }
602
+ #watchPlaybackRate() {
603
+ const { playbackRate } = this.#media.$state;
604
+ const newValue = playbackRate();
605
+ this.$state.value.set(newValue);
606
+ this.dispatch("value-change", { detail: newValue });
607
+ }
608
+ #roundValue(value) {
609
+ return round(value, 2);
610
+ }
611
+ #isDisabled() {
612
+ const { disabled } = this.$props, { canSetPlaybackRate } = this.#media.$state;
613
+ return disabled() || !canSetPlaybackRate();
614
+ }
615
+ #throttledSpeedChange = functionThrottle(this.#onPlaybackRateChange.bind(this), 25);
616
+ #onPlaybackRateChange(event) {
617
+ if (!event.trigger) return;
618
+ const rate = event.detail;
619
+ this.#media.remote.changePlaybackRate(rate, event);
620
+ }
621
+ #onValueChange(event) {
622
+ this.#throttledSpeedChange(event);
623
+ }
624
+ #onDragValueChange(event) {
625
+ this.#throttledSpeedChange(event);
626
+ }
627
+ }
628
+
629
+ class QualitySlider extends Component {
630
+ static props = {
631
+ ...SliderController.props,
632
+ step: 1,
633
+ keyStep: 1,
634
+ shiftKeyMultiplier: 1
635
+ };
636
+ static state = sliderState;
637
+ #media;
638
+ #sortedQualities = computed(() => {
639
+ const { qualities } = this.#media.$state;
640
+ return sortVideoQualities(qualities());
641
+ });
642
+ onSetup() {
643
+ this.#media = useMediaContext();
644
+ new SliderController({
645
+ getStep: this.$props.step,
646
+ getKeyStep: this.$props.keyStep,
647
+ roundValue: Math.round,
648
+ isDisabled: this.#isDisabled.bind(this),
649
+ aria: {
650
+ valueNow: this.#getARIAValueNow.bind(this),
651
+ valueText: this.#getARIAValueText.bind(this)
652
+ },
653
+ onDragValueChange: this.#onDragValueChange.bind(this),
654
+ onValueChange: this.#onValueChange.bind(this)
655
+ }).attach(this);
656
+ effect(this.#watchMax.bind(this));
657
+ effect(this.#watchQuality.bind(this));
658
+ }
659
+ onAttach(el) {
660
+ el.setAttribute("data-media-quality-slider", "");
661
+ setAttributeIfEmpty(el, "aria-label", "Video Quality");
662
+ const { qualities, canSetQuality } = this.#media.$state, $supported = computed(() => canSetQuality() && qualities().length > 0);
663
+ this.setAttributes({
664
+ "data-supported": $supported,
665
+ "aria-hidden": $ariaBool(() => !$supported())
666
+ });
667
+ }
668
+ #getARIAValueNow() {
669
+ const { value } = this.$state;
670
+ return value();
671
+ }
672
+ #getARIAValueText() {
673
+ const { quality } = this.#media.$state;
674
+ if (!quality()) return "";
675
+ const { height, bitrate } = quality(), bitrateText = bitrate && bitrate > 0 ? `${(bitrate / 1e6).toFixed(2)} Mbps` : null;
676
+ return height ? `${height}p${bitrateText ? ` (${bitrateText})` : ""}` : "Auto";
677
+ }
678
+ #watchMax() {
679
+ const $qualities = this.#sortedQualities();
680
+ this.$state.max.set(Math.max(0, $qualities.length - 1));
681
+ }
682
+ #watchQuality() {
683
+ let { quality } = this.#media.$state, $qualities = this.#sortedQualities(), value = Math.max(0, $qualities.indexOf(quality()));
684
+ this.$state.value.set(value);
685
+ this.dispatch("value-change", { detail: value });
686
+ }
687
+ #isDisabled() {
688
+ const { disabled } = this.$props, { canSetQuality, qualities } = this.#media.$state;
689
+ return disabled() || qualities().length <= 1 || !canSetQuality();
690
+ }
691
+ #throttledQualityChange = functionThrottle(this.#onQualityChange.bind(this), 25);
692
+ #onQualityChange(event) {
693
+ if (!event.trigger) return;
694
+ const { qualities } = this.#media, quality = peek(this.#sortedQualities)[event.detail];
695
+ this.#media.remote.changeQuality(qualities.indexOf(quality), event);
696
+ }
697
+ #onValueChange(event) {
698
+ this.#throttledQualityChange(event);
699
+ }
700
+ #onDragValueChange(event) {
701
+ this.#throttledQualityChange(event);
702
+ }
703
+ }
704
+
705
+ class SliderChapters extends Component {
706
+ static props = {
707
+ disabled: false
708
+ };
709
+ #media;
710
+ #sliderState;
711
+ #updateScope;
712
+ #titleRef = null;
713
+ #refs = [];
714
+ #$track = signal(null);
715
+ #$cues = signal([]);
716
+ #activeIndex = signal(-1);
717
+ #activePointerIndex = signal(-1);
718
+ #bufferedIndex = 0;
719
+ get cues() {
720
+ return this.#$cues();
721
+ }
722
+ get activeCue() {
723
+ return this.#$cues()[this.#activeIndex()] || null;
724
+ }
725
+ get activePointerCue() {
726
+ return this.#$cues()[this.#activePointerIndex()] || null;
727
+ }
728
+ onSetup() {
729
+ this.#media = useMediaContext();
730
+ this.#sliderState = useState(TimeSlider.state);
731
+ }
732
+ onAttach(el) {
733
+ watchActiveTextTrack(this.#media.textTracks, "chapters", this.#setTrack.bind(this));
734
+ effect(this.#watchSource.bind(this));
735
+ }
736
+ onConnect() {
737
+ onDispose(() => this.#reset.bind(this));
738
+ }
739
+ onDestroy() {
740
+ this.#setTrack(null);
741
+ }
742
+ setRefs(refs) {
743
+ this.#refs = refs;
744
+ this.#updateScope?.dispose();
745
+ if (this.#refs.length === 1) {
746
+ const el = this.#refs[0];
747
+ el.style.width = "100%";
748
+ el.style.setProperty("--chapter-fill", "var(--slider-fill)");
749
+ el.style.setProperty("--chapter-progress", "var(--slider-progress)");
750
+ } else if (this.#refs.length > 0) {
751
+ scoped(() => this.#watch(), this.#updateScope = createScope());
752
+ }
753
+ }
754
+ #setTrack(track) {
755
+ if (peek(this.#$track) === track) return;
756
+ this.#reset();
757
+ this.#$track.set(track);
758
+ }
759
+ #reset() {
760
+ this.#refs = [];
761
+ this.#$cues.set([]);
762
+ this.#activeIndex.set(-1);
763
+ this.#activePointerIndex.set(-1);
764
+ this.#bufferedIndex = 0;
765
+ this.#updateScope?.dispose();
766
+ }
767
+ #watch() {
768
+ if (!this.#refs.length) return;
769
+ effect(this.#watchUpdates.bind(this));
770
+ }
771
+ #watchUpdates() {
772
+ const { hidden } = this.#sliderState;
773
+ if (hidden()) return;
774
+ effect(this.#watchContainerWidths.bind(this));
775
+ effect(this.#watchFillPercent.bind(this));
776
+ effect(this.#watchPointerPercent.bind(this));
777
+ effect(this.#watchBufferedPercent.bind(this));
778
+ }
779
+ #watchContainerWidths() {
780
+ const cues = this.#$cues();
781
+ if (!cues.length) return;
782
+ let cue, { seekableStart, seekableEnd } = this.#media.$state, startTime = seekableStart(), endTime = seekableEnd() || cues[cues.length - 1].endTime, duration = endTime - startTime, remainingWidth = 100;
783
+ for (let i = 0; i < cues.length; i++) {
784
+ cue = cues[i];
785
+ if (this.#refs[i]) {
786
+ const width = i === cues.length - 1 ? remainingWidth : round((cue.endTime - Math.max(startTime, cue.startTime)) / duration * 100, 3);
787
+ this.#refs[i].style.width = width + "%";
788
+ remainingWidth -= width;
789
+ }
790
+ }
791
+ }
792
+ #watchFillPercent() {
793
+ let { liveEdge, seekableStart, seekableEnd } = this.#media.$state, { fillPercent, value } = this.#sliderState, cues = this.#$cues(), isLiveEdge = liveEdge(), prevActiveIndex = peek(this.#activeIndex), currentChapter = cues[prevActiveIndex];
794
+ let currentActiveIndex = isLiveEdge ? this.#$cues.length - 1 : this.#findActiveChapterIndex(
795
+ currentChapter ? currentChapter.startTime / seekableEnd() * 100 <= peek(value) ? prevActiveIndex : 0 : 0,
796
+ fillPercent()
797
+ );
798
+ if (isLiveEdge || !currentChapter) {
799
+ this.#updateFillPercents(0, cues.length, 100);
800
+ } else if (currentActiveIndex > prevActiveIndex) {
801
+ this.#updateFillPercents(prevActiveIndex, currentActiveIndex, 100);
802
+ } else if (currentActiveIndex < prevActiveIndex) {
803
+ this.#updateFillPercents(currentActiveIndex + 1, prevActiveIndex + 1, 0);
804
+ }
805
+ const percent = isLiveEdge ? 100 : this.#calcPercent(
806
+ cues[currentActiveIndex],
807
+ fillPercent(),
808
+ seekableStart(),
809
+ this.#getEndTime(cues)
810
+ );
811
+ this.#updateFillPercent(this.#refs[currentActiveIndex], percent);
812
+ this.#activeIndex.set(currentActiveIndex);
813
+ }
814
+ #watchPointerPercent() {
815
+ let { hidden, pointerPercent } = this.#sliderState;
816
+ if (hidden()) {
817
+ this.#activePointerIndex.set(-1);
818
+ return;
819
+ }
820
+ const activeIndex = this.#findActiveChapterIndex(0, pointerPercent());
821
+ this.#activePointerIndex.set(activeIndex);
822
+ }
823
+ #updateFillPercents(start, end, percent) {
824
+ for (let i = start; i < end; i++) this.#updateFillPercent(this.#refs[i], percent);
825
+ }
826
+ #updateFillPercent(ref, percent) {
827
+ if (!ref) return;
828
+ ref.style.setProperty("--chapter-fill", percent + "%");
829
+ setAttribute(ref, "data-active", percent > 0 && percent < 100);
830
+ setAttribute(ref, "data-ended", percent === 100);
831
+ }
832
+ #findActiveChapterIndex(startIndex, percent) {
833
+ let chapterPercent = 0, cues = this.#$cues();
834
+ if (percent === 0) return 0;
835
+ else if (percent === 100) return cues.length - 1;
836
+ let { seekableStart } = this.#media.$state, startTime = seekableStart(), endTime = this.#getEndTime(cues);
837
+ for (let i = startIndex; i < cues.length; i++) {
838
+ chapterPercent = this.#calcPercent(cues[i], percent, startTime, endTime);
839
+ if (chapterPercent >= 0 && chapterPercent < 100) return i;
840
+ }
841
+ return 0;
842
+ }
843
+ #watchBufferedPercent() {
844
+ this.#updateBufferedPercent(this.#bufferedPercent());
845
+ }
846
+ #updateBufferedPercent = animationFrameThrottle();
847
+ #bufferedPercent = computed(this.#calcMediaBufferedPercent.bind(this));
848
+ #calcMediaBufferedPercent() {
849
+ const { bufferedEnd, duration } = this.#media.$state;
850
+ return round(Math.min(bufferedEnd() / Math.max(duration(), 1), 1), 3) * 100;
851
+ }
852
+ #getEndTime(cues) {
853
+ const { seekableEnd } = this.#media.$state, endTime = seekableEnd();
854
+ return Number.isFinite(endTime) ? endTime : cues[cues.length - 1]?.endTime || 0;
855
+ }
856
+ #calcPercent(cue, percent, startTime, endTime) {
857
+ if (!cue) return 0;
858
+ const cues = this.#$cues();
859
+ if (cues.length === 0) return 0;
860
+ const duration = endTime - startTime, cueStartTime = Math.max(0, cue.startTime - startTime), cueEndTime = Math.min(endTime, cue.endTime) - startTime;
861
+ const startRatio = cueStartTime / duration, startPercent = startRatio * 100, endPercent = Math.min(1, startRatio + (cueEndTime - cueStartTime) / duration) * 100;
862
+ return Math.max(
863
+ 0,
864
+ round(
865
+ percent >= endPercent ? 100 : (percent - startPercent) / (endPercent - startPercent) * 100,
866
+ 3
867
+ )
868
+ );
869
+ }
870
+ #fillGaps(cues) {
871
+ let chapters = [], { seekableStart, seekableEnd, duration } = this.#media.$state, startTime = seekableStart(), endTime = seekableEnd();
872
+ cues = cues.filter((cue) => cue.startTime <= endTime && cue.endTime >= startTime);
873
+ const firstCue = cues[0];
874
+ if (firstCue && firstCue.startTime > startTime) {
875
+ chapters.push(new window.VTTCue(startTime, firstCue.startTime, ""));
876
+ }
877
+ for (let i = 0; i < cues.length - 1; i++) {
878
+ const currentCue = cues[i], nextCue = cues[i + 1];
879
+ chapters.push(currentCue);
880
+ if (nextCue) {
881
+ const timeDiff = nextCue.startTime - currentCue.endTime;
882
+ if (timeDiff > 0) {
883
+ chapters.push(new window.VTTCue(currentCue.endTime, currentCue.endTime + timeDiff, ""));
884
+ }
885
+ }
886
+ }
887
+ const lastCue = cues[cues.length - 1];
888
+ if (lastCue) {
889
+ chapters.push(lastCue);
890
+ const endTime2 = duration();
891
+ if (endTime2 >= 0 && endTime2 - lastCue.endTime > 1) {
892
+ chapters.push(new window.VTTCue(lastCue.endTime, duration(), ""));
893
+ }
894
+ }
895
+ return chapters;
896
+ }
897
+ #watchSource() {
898
+ const { source } = this.#media.$state;
899
+ source();
900
+ this.#onTrackChange();
901
+ }
902
+ #onTrackChange() {
903
+ if (!this.scope) return;
904
+ const { disabled } = this.$props;
905
+ if (disabled()) {
906
+ this.#$cues.set([]);
907
+ this.#activeIndex.set(0);
908
+ this.#bufferedIndex = 0;
909
+ return;
910
+ }
911
+ const track = this.#$track();
912
+ if (track) {
913
+ const onCuesChange = this.#onCuesChange.bind(this);
914
+ onCuesChange();
915
+ new EventsController(track).add("add-cue", onCuesChange).add("remove-cue", onCuesChange);
916
+ effect(this.#watchMediaDuration.bind(this));
917
+ }
918
+ this.#titleRef = this.#findChapterTitleRef();
919
+ if (this.#titleRef) effect(this.#onChapterTitleChange.bind(this));
920
+ return () => {
921
+ if (this.#titleRef) {
922
+ this.#titleRef.textContent = "";
923
+ this.#titleRef = null;
924
+ }
925
+ };
926
+ }
927
+ #watchMediaDuration() {
928
+ this.#media.$state.duration();
929
+ this.#onCuesChange();
930
+ }
931
+ #onCuesChange = functionDebounce(
932
+ () => {
933
+ const track = peek(this.#$track);
934
+ if (!this.scope || !track || !track.cues.length) return;
935
+ this.#$cues.set(this.#fillGaps(track.cues));
936
+ this.#activeIndex.set(0);
937
+ this.#bufferedIndex = 0;
938
+ },
939
+ 150,
940
+ true
941
+ );
942
+ #onChapterTitleChange() {
943
+ const cue = this.activePointerCue || this.activeCue;
944
+ if (this.#titleRef) this.#titleRef.textContent = cue?.text || "";
945
+ }
946
+ #findParentSlider() {
947
+ let node = this.el;
948
+ while (node && node.getAttribute("role") !== "slider") {
949
+ node = node.parentElement;
950
+ }
951
+ return node;
952
+ }
953
+ #findChapterTitleRef() {
954
+ const slider = this.#findParentSlider();
955
+ return slider ? slider.querySelector('[data-part="chapter-title"]') : null;
956
+ }
957
+ }
958
+ const sliderchapters__proto = SliderChapters.prototype;
959
+ prop(sliderchapters__proto, "cues");
960
+ prop(sliderchapters__proto, "activeCue");
961
+ prop(sliderchapters__proto, "activePointerCue");
962
+ method(sliderchapters__proto, "setRefs");
963
+
964
+ class RadioGroup extends Component {
965
+ static props = {
966
+ value: ""
967
+ };
968
+ #controller;
969
+ /**
970
+ * A list of radio values that belong this group.
971
+ */
972
+ get values() {
973
+ return this.#controller.values;
974
+ }
975
+ /**
976
+ * The radio value that is checked in this group.
977
+ */
978
+ get value() {
979
+ return this.#controller.value;
980
+ }
981
+ set value(newValue) {
982
+ this.#controller.value = newValue;
983
+ }
984
+ constructor() {
985
+ super();
986
+ this.#controller = new RadioGroupController();
987
+ this.#controller.onValueChange = this.#onValueChange.bind(this);
988
+ }
989
+ onSetup() {
990
+ this.#watchValue();
991
+ }
992
+ #watchValue() {
993
+ this.#controller.value = this.$props.value();
994
+ }
995
+ #onValueChange(value, trigger) {
996
+ const event = this.createEvent("change", { detail: value, trigger });
997
+ this.dispatch(event);
998
+ }
999
+ }
1000
+ const radiogroup__proto = RadioGroup.prototype;
1001
+ prop(radiogroup__proto, "values");
1002
+ prop(radiogroup__proto, "value");
1003
+
1004
+ var __defProp = Object.defineProperty;
1005
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
1006
+ var __decorateClass = (decorators, target, key, kind) => {
1007
+ var result = __getOwnPropDesc(target, key) ;
1008
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
1009
+ if (decorator = decorators[i])
1010
+ result = (decorator(target, key, result) ) || result;
1011
+ if (result) __defProp(target, key, result);
1012
+ return result;
1013
+ };
1014
+ class ChaptersRadioGroup extends Component {
1015
+ static props = {
1016
+ thumbnails: null
1017
+ };
1018
+ #media;
1019
+ #menu;
1020
+ #controller;
1021
+ #track = signal(null);
1022
+ #cues = signal([]);
1023
+ get value() {
1024
+ return this.#controller.value;
1025
+ }
1026
+ get disabled() {
1027
+ return !this.#cues()?.length;
1028
+ }
1029
+ constructor() {
1030
+ super();
1031
+ this.#controller = new RadioGroupController();
1032
+ this.#controller.onValueChange = this.#onValueChange.bind(this);
1033
+ }
1034
+ onSetup() {
1035
+ this.#media = useMediaContext();
1036
+ if (hasProvidedContext(menuContext)) {
1037
+ this.#menu = useContext(menuContext);
1038
+ }
1039
+ const { thumbnails } = this.$props;
1040
+ this.setAttributes({
1041
+ "data-thumbnails": () => !!thumbnails()
1042
+ });
1043
+ }
1044
+ onAttach(el) {
1045
+ this.#menu?.attachObserver({
1046
+ onOpen: this.#onOpen.bind(this)
1047
+ });
1048
+ }
1049
+ getOptions() {
1050
+ const { seekableStart, seekableEnd } = this.#media.$state, startTime = seekableStart(), endTime = seekableEnd();
1051
+ return this.#cues().map((cue, i) => ({
1052
+ cue,
1053
+ value: i.toString(),
1054
+ label: cue.text,
1055
+ startTime: formatTime(Math.max(0, cue.startTime - startTime)),
1056
+ duration: formatSpokenTime(
1057
+ Math.min(endTime, cue.endTime) - Math.max(startTime, cue.startTime)
1058
+ )
1059
+ }));
1060
+ }
1061
+ #onOpen() {
1062
+ peek(() => this.#watchCurrentTime());
1063
+ }
1064
+ onConnect(el) {
1065
+ effect(this.#watchCurrentTime.bind(this));
1066
+ effect(this.#watchControllerDisabled.bind(this));
1067
+ effect(this.#watchTrack.bind(this));
1068
+ watchActiveTextTrack(this.#media.textTracks, "chapters", this.#track.set);
1069
+ }
1070
+ #watchTrack() {
1071
+ const track = this.#track();
1072
+ if (!track) return;
1073
+ const onCuesChange = this.#onCuesChange.bind(this, track);
1074
+ onCuesChange();
1075
+ new EventsController(track).add("add-cue", onCuesChange).add("remove-cue", onCuesChange);
1076
+ return () => {
1077
+ this.#cues.set([]);
1078
+ };
1079
+ }
1080
+ #onCuesChange(track) {
1081
+ const { seekableStart, seekableEnd } = this.#media.$state, startTime = seekableStart(), endTime = seekableEnd();
1082
+ this.#cues.set(
1083
+ [...track.cues].filter((cue) => cue.startTime <= endTime && cue.endTime >= startTime)
1084
+ );
1085
+ }
1086
+ #watchCurrentTime() {
1087
+ if (!this.#menu?.expanded()) return;
1088
+ const track = this.#track();
1089
+ if (!track) {
1090
+ this.#controller.value = "-1";
1091
+ return;
1092
+ }
1093
+ const { realCurrentTime, seekableStart, seekableEnd } = this.#media.$state, startTime = seekableStart(), endTime = seekableEnd(), time = realCurrentTime(), activeCueIndex = this.#cues().findIndex((cue) => isCueActive(cue, time));
1094
+ this.#controller.value = activeCueIndex.toString();
1095
+ if (activeCueIndex >= 0) {
1096
+ requestScopedAnimationFrame(() => {
1097
+ if (!this.connectScope) return;
1098
+ const cue = this.#cues()[activeCueIndex], radio = this.el.querySelector(`[aria-checked='true']`), cueStartTime = Math.max(startTime, cue.startTime), duration = Math.min(endTime, cue.endTime) - cueStartTime, playedPercent = Math.max(0, time - cueStartTime) / duration * 100;
1099
+ radio && setStyle(radio, "--progress", round(playedPercent, 3) + "%");
1100
+ });
1101
+ }
1102
+ }
1103
+ #watchControllerDisabled() {
1104
+ this.#menu?.disable(this.disabled);
1105
+ }
1106
+ #onValueChange(value, trigger) {
1107
+ if (this.disabled || !trigger) return;
1108
+ const index = +value, cues = this.#cues(), { clipStartTime } = this.#media.$state;
1109
+ if (isNumber(index) && cues?.[index]) {
1110
+ this.#controller.value = index.toString();
1111
+ this.#media.remote.seek(cues[index].startTime - clipStartTime(), trigger);
1112
+ this.dispatch("change", { detail: cues[index], trigger });
1113
+ }
1114
+ }
1115
+ }
1116
+ __decorateClass([
1117
+ prop
1118
+ ], ChaptersRadioGroup.prototype, "value");
1119
+ __decorateClass([
1120
+ prop
1121
+ ], ChaptersRadioGroup.prototype, "disabled");
1122
+ __decorateClass([
1123
+ method
1124
+ ], ChaptersRadioGroup.prototype, "getOptions");
1125
+
1126
+ const DEFAULT_AUDIO_GAINS = [1, 1.25, 1.5, 1.75, 2, 2.5, 3, 4];
1127
+ class AudioGainRadioGroup extends Component {
1128
+ static props = {
1129
+ normalLabel: "Disabled",
1130
+ gains: DEFAULT_AUDIO_GAINS
1131
+ };
1132
+ #media;
1133
+ #menu;
1134
+ #controller;
1135
+ get value() {
1136
+ return this.#controller.value;
1137
+ }
1138
+ get disabled() {
1139
+ const { gains } = this.$props, { canSetAudioGain } = this.#media.$state;
1140
+ return !canSetAudioGain() || gains().length === 0;
1141
+ }
1142
+ constructor() {
1143
+ super();
1144
+ this.#controller = new RadioGroupController();
1145
+ this.#controller.onValueChange = this.#onValueChange.bind(this);
1146
+ }
1147
+ onSetup() {
1148
+ this.#media = useMediaContext();
1149
+ if (hasProvidedContext(menuContext)) {
1150
+ this.#menu = useContext(menuContext);
1151
+ }
1152
+ }
1153
+ onConnect(el) {
1154
+ effect(this.#watchValue.bind(this));
1155
+ effect(this.#watchHintText.bind(this));
1156
+ effect(this.#watchControllerDisabled.bind(this));
1157
+ }
1158
+ getOptions() {
1159
+ const { gains, normalLabel } = this.$props;
1160
+ return gains().map((gain) => ({
1161
+ label: gain === 1 || gain === null ? normalLabel : String(gain * 100) + "%",
1162
+ value: gain.toString()
1163
+ }));
1164
+ }
1165
+ #watchValue() {
1166
+ this.#controller.value = this.#getValue();
1167
+ }
1168
+ #watchHintText() {
1169
+ const { normalLabel } = this.$props, { audioGain } = this.#media.$state, gain = audioGain();
1170
+ this.#menu?.hint.set(gain === 1 || gain == null ? normalLabel() : String(gain * 100) + "%");
1171
+ }
1172
+ #watchControllerDisabled() {
1173
+ this.#menu?.disable(this.disabled);
1174
+ }
1175
+ #getValue() {
1176
+ const { audioGain } = this.#media.$state;
1177
+ return audioGain()?.toString() ?? "1";
1178
+ }
1179
+ #onValueChange(value, trigger) {
1180
+ if (this.disabled) return;
1181
+ const gain = +value;
1182
+ this.#media.remote.changeAudioGain(gain, trigger);
1183
+ this.dispatch("change", { detail: gain, trigger });
1184
+ }
1185
+ }
1186
+ const audiogainradiogroup__proto = AudioGainRadioGroup.prototype;
1187
+ prop(audiogainradiogroup__proto, "value");
1188
+ prop(audiogainradiogroup__proto, "disabled");
1189
+ method(audiogainradiogroup__proto, "getOptions");
1190
+
1191
+ class Gesture extends Component {
1192
+ static props = {
1193
+ disabled: false,
1194
+ event: void 0,
1195
+ action: void 0
1196
+ };
1197
+ #media;
1198
+ #provider = null;
1199
+ onSetup() {
1200
+ this.#media = useMediaContext();
1201
+ const { event, action } = this.$props;
1202
+ this.setAttributes({
1203
+ event,
1204
+ action
1205
+ });
1206
+ }
1207
+ onAttach(el) {
1208
+ el.setAttribute("data-media-gesture", "");
1209
+ el.style.setProperty("pointer-events", "none");
1210
+ }
1211
+ onConnect(el) {
1212
+ this.#provider = this.#media.player.el?.querySelector(
1213
+ "[data-media-provider]"
1214
+ );
1215
+ effect(this.#attachListener.bind(this));
1216
+ }
1217
+ #attachListener() {
1218
+ let eventType = this.$props.event(), disabled = this.$props.disabled();
1219
+ if (!this.#provider || !eventType || disabled) return;
1220
+ if (/^dbl/.test(eventType)) {
1221
+ eventType = eventType.split(/^dbl/)[1];
1222
+ }
1223
+ if (eventType === "pointerup" || eventType === "pointerdown") {
1224
+ const pointer = this.#media.$state.pointer();
1225
+ if (pointer === "coarse") {
1226
+ eventType = eventType === "pointerup" ? "touchend" : "touchstart";
1227
+ }
1228
+ }
1229
+ listenEvent(
1230
+ this.#provider,
1231
+ eventType,
1232
+ this.#acceptEvent.bind(this));
1233
+ }
1234
+ #presses = 0;
1235
+ #pressTimerId = -1;
1236
+ #acceptEvent(event) {
1237
+ if (this.$props.disabled() || isPointerEvent(event) && (event.button !== 0 || this.#media.activeMenu) || isTouchEvent(event) && this.#media.activeMenu || isTouchPinchEvent(event) || !this.#inBounds(event)) {
1238
+ return;
1239
+ }
1240
+ event.MEDIA_GESTURE = true;
1241
+ event.preventDefault();
1242
+ const eventType = peek(this.$props.event), isDblEvent = eventType?.startsWith("dbl");
1243
+ if (!isDblEvent) {
1244
+ if (this.#presses === 0) {
1245
+ setTimeout(() => {
1246
+ if (this.#presses === 1) this.#handleEvent(event);
1247
+ }, 250);
1248
+ }
1249
+ } else if (this.#presses === 1) {
1250
+ queueMicrotask(() => this.#handleEvent(event));
1251
+ clearTimeout(this.#pressTimerId);
1252
+ this.#presses = 0;
1253
+ return;
1254
+ }
1255
+ if (this.#presses === 0) {
1256
+ this.#pressTimerId = window.setTimeout(() => {
1257
+ this.#presses = 0;
1258
+ }, 275);
1259
+ }
1260
+ this.#presses++;
1261
+ }
1262
+ #handleEvent(event) {
1263
+ this.el.setAttribute("data-triggered", "");
1264
+ requestAnimationFrame(() => {
1265
+ if (this.#isTopLayer()) {
1266
+ this.#performAction(peek(this.$props.action), event);
1267
+ }
1268
+ requestAnimationFrame(() => {
1269
+ this.el.removeAttribute("data-triggered");
1270
+ });
1271
+ });
1272
+ }
1273
+ /** Validate event occurred in gesture bounds. */
1274
+ #inBounds(event) {
1275
+ if (!this.el) return false;
1276
+ if (isPointerEvent(event) || isMouseEvent(event) || isTouchEvent(event)) {
1277
+ const touch = isTouchEvent(event) ? event.changedTouches[0] ?? event.touches[0] : void 0;
1278
+ const clientX = touch?.clientX ?? event.clientX;
1279
+ const clientY = touch?.clientY ?? event.clientY;
1280
+ const rect = this.el.getBoundingClientRect();
1281
+ const inBounds = clientY >= rect.top && clientY <= rect.bottom && clientX >= rect.left && clientX <= rect.right;
1282
+ return event.type.includes("leave") ? !inBounds : inBounds;
1283
+ }
1284
+ return true;
1285
+ }
1286
+ /** Validate gesture has the highest z-index in this triggered group. */
1287
+ #isTopLayer() {
1288
+ const gestures = this.#media.player.el.querySelectorAll(
1289
+ "[data-media-gesture][data-triggered]"
1290
+ );
1291
+ return Array.from(gestures).sort(
1292
+ (a, b) => +getComputedStyle(b).zIndex - +getComputedStyle(a).zIndex
1293
+ )[0] === this.el;
1294
+ }
1295
+ #performAction(action, trigger) {
1296
+ if (!action) return;
1297
+ const willTriggerEvent = new DOMEvent("will-trigger", {
1298
+ detail: action,
1299
+ cancelable: true,
1300
+ trigger
1301
+ });
1302
+ this.dispatchEvent(willTriggerEvent);
1303
+ if (willTriggerEvent.defaultPrevented) return;
1304
+ const [method, value] = action.replace(/:([a-z])/, "-$1").split(":");
1305
+ if (action.includes(":fullscreen")) {
1306
+ this.#media.remote.toggleFullscreen("prefer-media", trigger);
1307
+ } else if (action.includes("seek:")) {
1308
+ this.#media.remote.seek(peek(this.#media.$state.currentTime) + (+value || 0), trigger);
1309
+ } else {
1310
+ this.#media.remote[kebabToCamelCase(method)](trigger);
1311
+ }
1312
+ this.dispatch("trigger", {
1313
+ detail: action,
1314
+ trigger
1315
+ });
1316
+ }
1317
+ }
1318
+
1319
+ class CaptionsTextRenderer {
1320
+ priority = 10;
1321
+ #track = null;
1322
+ #renderer;
1323
+ #events;
1324
+ constructor(renderer) {
1325
+ this.#renderer = renderer;
1326
+ }
1327
+ attach() {
1328
+ }
1329
+ canRender() {
1330
+ return true;
1331
+ }
1332
+ detach() {
1333
+ this.#events?.abort();
1334
+ this.#events = void 0;
1335
+ this.#renderer.reset();
1336
+ this.#track = null;
1337
+ }
1338
+ changeTrack(track) {
1339
+ if (!track || this.#track === track) return;
1340
+ this.#events?.abort();
1341
+ this.#events = new EventsController(track);
1342
+ if (track.readyState < 2) {
1343
+ this.#renderer.reset();
1344
+ this.#events.add("load", () => this.#changeTrack(track), { once: true });
1345
+ } else {
1346
+ this.#changeTrack(track);
1347
+ }
1348
+ this.#events.add("add-cue", (event) => {
1349
+ this.#renderer.addCue(event.detail);
1350
+ }).add("remove-cue", (event) => {
1351
+ this.#renderer.removeCue(event.detail);
1352
+ });
1353
+ this.#track = track;
1354
+ }
1355
+ #changeTrack(track) {
1356
+ this.#renderer.changeTrack({
1357
+ cues: [...track.cues],
1358
+ regions: [...track.regions]
1359
+ });
1360
+ }
1361
+ }
1362
+
1363
+ class Captions extends Component {
1364
+ static props = {
1365
+ textDir: "ltr",
1366
+ exampleText: "Captions look like this."
1367
+ };
1368
+ #media;
1369
+ static lib = signal(null);
1370
+ onSetup() {
1371
+ this.#media = useMediaContext();
1372
+ this.setAttributes({
1373
+ "aria-hidden": $ariaBool(this.#isHidden.bind(this))
1374
+ });
1375
+ }
1376
+ onAttach(el) {
1377
+ el.style.setProperty("pointer-events", "none");
1378
+ }
1379
+ onConnect(el) {
1380
+ if (!Captions.lib()) {
1381
+ import('media-captions').then((lib) => Captions.lib.set(lib));
1382
+ }
1383
+ effect(this.#watchViewType.bind(this));
1384
+ }
1385
+ #isHidden() {
1386
+ const { textTrack, remotePlaybackState, iOSControls } = this.#media.$state, track = textTrack();
1387
+ return iOSControls() || remotePlaybackState() === "connected" || !track || !isTrackCaptionKind(track);
1388
+ }
1389
+ #watchViewType() {
1390
+ if (!Captions.lib()) return;
1391
+ const { viewType } = this.#media.$state;
1392
+ if (viewType() === "audio") {
1393
+ return this.#setupAudioView();
1394
+ } else {
1395
+ return this.#setupVideoView();
1396
+ }
1397
+ }
1398
+ #setupAudioView() {
1399
+ effect(this.#onTrackChange.bind(this));
1400
+ this.#listenToFontStyleChanges(null);
1401
+ return () => {
1402
+ this.el.textContent = "";
1403
+ };
1404
+ }
1405
+ #onTrackChange() {
1406
+ if (this.#isHidden()) return;
1407
+ this.#onCueChange();
1408
+ const { textTrack } = this.#media.$state;
1409
+ listenEvent(textTrack(), "cue-change", this.#onCueChange.bind(this));
1410
+ effect(this.#onUpdateTimedNodes.bind(this));
1411
+ }
1412
+ #onCueChange() {
1413
+ this.el.textContent = "";
1414
+ if (this.#hideExampleTimer >= 0) {
1415
+ this.#removeExample();
1416
+ }
1417
+ const { realCurrentTime, textTrack } = this.#media.$state, { renderVTTCueString } = Captions.lib(), time = peek(realCurrentTime), activeCues = peek(textTrack).activeCues;
1418
+ for (const cue of activeCues) {
1419
+ const displayEl = this.#createCueDisplayElement(), cueEl = this.#createCueElement();
1420
+ cueEl.innerHTML = renderVTTCueString(cue, time);
1421
+ displayEl.append(cueEl);
1422
+ this.el.append(cueEl);
1423
+ }
1424
+ }
1425
+ #onUpdateTimedNodes() {
1426
+ const { realCurrentTime } = this.#media.$state, { updateTimedVTTCueNodes } = Captions.lib();
1427
+ updateTimedVTTCueNodes(this.el, realCurrentTime());
1428
+ }
1429
+ #setupVideoView() {
1430
+ const { CaptionsRenderer } = Captions.lib(), renderer = new CaptionsRenderer(this.el), textRenderer = new CaptionsTextRenderer(renderer);
1431
+ this.#media.textRenderers.add(textRenderer);
1432
+ effect(this.#watchTextDirection.bind(this, renderer));
1433
+ effect(this.#watchMediaTime.bind(this, renderer));
1434
+ this.#listenToFontStyleChanges(renderer);
1435
+ return () => {
1436
+ this.el.textContent = "";
1437
+ this.#media.textRenderers.remove(textRenderer);
1438
+ renderer.destroy();
1439
+ };
1440
+ }
1441
+ #watchTextDirection(renderer) {
1442
+ renderer.dir = this.$props.textDir();
1443
+ }
1444
+ #watchMediaTime(renderer) {
1445
+ if (this.#isHidden()) return;
1446
+ const { realCurrentTime, textTrack } = this.#media.$state;
1447
+ renderer.currentTime = realCurrentTime();
1448
+ if (this.#hideExampleTimer >= 0 && textTrack()?.activeCues[0]) {
1449
+ this.#removeExample();
1450
+ }
1451
+ }
1452
+ #listenToFontStyleChanges(renderer) {
1453
+ const player = this.#media.player;
1454
+ if (!player) return;
1455
+ this.#onFontStyleChange.bind(this, renderer);
1456
+ }
1457
+ #onFontStyleChange(renderer) {
1458
+ if (this.#hideExampleTimer >= 0) {
1459
+ this.#hideExample();
1460
+ return;
1461
+ }
1462
+ const { textTrack } = this.#media.$state;
1463
+ if (!textTrack()?.activeCues[0]) {
1464
+ this.#showExample();
1465
+ } else {
1466
+ renderer?.update(true);
1467
+ }
1468
+ }
1469
+ #showExample() {
1470
+ const display = this.#createCueDisplayElement();
1471
+ setAttribute(display, "data-example", "");
1472
+ const cue = this.#createCueElement();
1473
+ setAttribute(cue, "data-example", "");
1474
+ cue.textContent = this.$props.exampleText();
1475
+ display?.append(cue);
1476
+ this.el?.append(display);
1477
+ this.el?.setAttribute("data-example", "");
1478
+ this.#hideExample();
1479
+ }
1480
+ #hideExampleTimer = -1;
1481
+ #hideExample() {
1482
+ window.clearTimeout(this.#hideExampleTimer);
1483
+ this.#hideExampleTimer = window.setTimeout(this.#removeExample.bind(this), 2500);
1484
+ }
1485
+ #removeExample() {
1486
+ this.el?.removeAttribute("data-example");
1487
+ if (this.el?.querySelector("[data-example]")) this.el.textContent = "";
1488
+ this.#hideExampleTimer = -1;
1489
+ }
1490
+ #createCueDisplayElement() {
1491
+ const el = document.createElement("div");
1492
+ setAttribute(el, "data-part", "cue-display");
1493
+ return el;
1494
+ }
1495
+ #createCueElement() {
1496
+ const el = document.createElement("div");
1497
+ setAttribute(el, "data-part", "cue");
1498
+ return el;
1499
+ }
1500
+ }
1501
+
1502
+ export { AudioGainRadioGroup, AudioGainSlider, Captions, ChaptersRadioGroup, Controls, ControlsGroup, DEFAULT_AUDIO_GAINS, Gesture, GoogleCastButton, MediaAnnouncer, QualitySlider, RadioGroup, SliderChapters, SliderVideo, SpeedSlider, ToggleButton, Tooltip, TooltipContent, TooltipTrigger };