@videojs/html 10.0.0-alpha.7 → 10.0.0-beta.1

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 (439) hide show
  1. package/README.md +2 -2
  2. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js +6 -0
  3. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -0
  4. package/dist/default/_virtual/inline-css_src/define/audio/skin.js +6 -0
  5. package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -0
  6. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +6 -0
  7. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -0
  8. package/dist/default/_virtual/inline-css_src/define/video/skin.js +6 -0
  9. package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -0
  10. package/dist/default/define/audio/minimal-skin.css +630 -5
  11. package/dist/default/define/audio/minimal-skin.js +97 -9
  12. package/dist/default/define/audio/minimal-skin.js.map +1 -1
  13. package/dist/default/define/audio/minimal-skin.tailwind.js +121 -0
  14. package/dist/default/define/audio/minimal-skin.tailwind.js.map +1 -0
  15. package/dist/default/define/audio/skin.css +655 -6
  16. package/dist/default/define/audio/skin.js +88 -9
  17. package/dist/default/define/audio/skin.js.map +1 -1
  18. package/dist/default/define/audio/skin.tailwind.js +111 -0
  19. package/dist/default/define/audio/skin.tailwind.js.map +1 -0
  20. package/dist/default/define/media/simple-hls-video.js +13 -0
  21. package/dist/default/define/media/simple-hls-video.js.map +1 -0
  22. package/dist/default/define/skin-mixin.js +53 -19
  23. package/dist/default/define/skin-mixin.js.map +1 -1
  24. package/dist/default/define/ui/alert-dialog-close.js +8 -0
  25. package/dist/default/define/ui/alert-dialog-close.js.map +1 -0
  26. package/dist/default/define/ui/alert-dialog-description.js +8 -0
  27. package/dist/default/define/ui/alert-dialog-description.js.map +1 -0
  28. package/dist/default/define/ui/alert-dialog-title.js +8 -0
  29. package/dist/default/define/ui/alert-dialog-title.js.map +1 -0
  30. package/dist/default/define/ui/alert-dialog.js +14 -0
  31. package/dist/default/define/ui/alert-dialog.js.map +1 -0
  32. package/dist/default/define/ui/captions-button.js +7 -0
  33. package/dist/default/define/ui/captions-button.js.map +1 -0
  34. package/dist/default/define/ui/slider-thumbnail.js +8 -0
  35. package/dist/default/define/ui/slider-thumbnail.js.map +1 -0
  36. package/dist/default/define/ui/slider.js +2 -0
  37. package/dist/default/define/ui/slider.js.map +1 -1
  38. package/dist/default/define/ui/time-slider.js +4 -0
  39. package/dist/default/define/ui/time-slider.js.map +1 -1
  40. package/dist/default/define/ui/tooltip-group.js +8 -0
  41. package/dist/default/define/ui/tooltip-group.js.map +1 -0
  42. package/dist/default/define/ui/tooltip.js +8 -0
  43. package/dist/default/define/ui/tooltip.js.map +1 -0
  44. package/dist/default/define/ui/volume-slider.js +2 -0
  45. package/dist/default/define/ui/volume-slider.js.map +1 -1
  46. package/dist/default/define/video/minimal-skin.css +367 -256
  47. package/dist/default/define/video/minimal-skin.js +46 -17
  48. package/dist/default/define/video/minimal-skin.js.map +1 -1
  49. package/dist/default/define/video/minimal-skin.tailwind.js +77 -31
  50. package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
  51. package/dist/default/define/video/skin.css +395 -280
  52. package/dist/default/define/video/skin.js +46 -15
  53. package/dist/default/define/video/skin.js.map +1 -1
  54. package/dist/default/define/video/skin.tailwind.js +71 -28
  55. package/dist/default/define/video/skin.tailwind.js.map +1 -1
  56. package/dist/default/icons/dist/render/default/index.js +13 -13
  57. package/dist/default/icons/dist/render/default/index.js.map +1 -1
  58. package/dist/default/icons/dist/render/minimal/index.js +13 -13
  59. package/dist/default/icons/dist/render/minimal/index.js.map +1 -1
  60. package/dist/default/index.js +13 -3
  61. package/dist/default/media/hls-video/index.js +5 -1
  62. package/dist/default/media/hls-video/index.js.map +1 -1
  63. package/dist/default/media/simple-hls-video/index.js +21 -0
  64. package/dist/default/media/simple-hls-video/index.js.map +1 -0
  65. package/dist/default/player/create-player.js.map +1 -1
  66. package/dist/default/presets/audio.js +3 -1
  67. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js +58 -0
  68. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -0
  69. package/dist/default/skins/dist/default/default/tailwind/components/buffering.js +9 -0
  70. package/dist/default/skins/dist/default/default/tailwind/components/buffering.js.map +1 -0
  71. package/dist/default/skins/dist/default/default/tailwind/components/button.js +12 -0
  72. package/dist/default/skins/dist/default/default/tailwind/components/button.js.map +1 -0
  73. package/dist/default/skins/dist/default/default/tailwind/components/controls.js +8 -0
  74. package/dist/default/skins/dist/default/default/tailwind/components/controls.js.map +1 -0
  75. package/dist/default/skins/dist/default/default/tailwind/components/error.js +15 -0
  76. package/dist/default/skins/dist/default/default/tailwind/components/error.js.map +1 -0
  77. package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js +29 -0
  78. package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js.map +1 -0
  79. package/dist/default/skins/dist/default/default/tailwind/components/icon.js +10 -0
  80. package/dist/default/skins/dist/default/default/tailwind/components/icon.js.map +1 -0
  81. package/dist/default/skins/dist/default/default/tailwind/components/overlay.js +8 -0
  82. package/dist/default/skins/dist/default/default/tailwind/components/overlay.js.map +1 -0
  83. package/dist/default/skins/dist/default/default/tailwind/components/playback-rate.js +6 -0
  84. package/dist/default/skins/dist/default/default/tailwind/components/playback-rate.js.map +1 -0
  85. package/dist/default/skins/dist/default/default/tailwind/components/popup.js +13 -0
  86. package/dist/default/skins/dist/default/default/tailwind/components/popup.js.map +1 -0
  87. package/dist/default/skins/dist/default/default/tailwind/components/root.js +8 -0
  88. package/dist/default/skins/dist/default/default/tailwind/components/root.js.map +1 -0
  89. package/dist/default/skins/dist/default/default/tailwind/components/seek.js +11 -0
  90. package/dist/default/skins/dist/default/default/tailwind/components/seek.js.map +1 -0
  91. package/dist/default/skins/dist/default/default/tailwind/components/slider.js +21 -0
  92. package/dist/default/skins/dist/default/default/tailwind/components/slider.js.map +1 -0
  93. package/dist/default/skins/dist/default/default/tailwind/components/surface.js +8 -0
  94. package/dist/default/skins/dist/default/default/tailwind/components/surface.js.map +1 -0
  95. package/dist/default/skins/dist/default/default/tailwind/components/time.js +10 -0
  96. package/dist/default/skins/dist/default/default/tailwind/components/time.js.map +1 -0
  97. package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js +28 -0
  98. package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js.map +1 -0
  99. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +55 -0
  100. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -0
  101. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +44 -0
  102. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -0
  103. package/dist/default/skins/dist/default/minimal/tailwind/components/buffering.js +6 -0
  104. package/dist/default/skins/dist/default/minimal/tailwind/components/buffering.js.map +1 -0
  105. package/dist/default/skins/dist/default/minimal/tailwind/components/button-group.js +8 -0
  106. package/dist/default/skins/dist/default/minimal/tailwind/components/button-group.js.map +1 -0
  107. package/dist/default/skins/dist/default/minimal/tailwind/components/button.js +12 -0
  108. package/dist/default/skins/dist/default/minimal/tailwind/components/button.js.map +1 -0
  109. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js +8 -0
  110. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -0
  111. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js +15 -0
  112. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js.map +1 -0
  113. package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js +29 -0
  114. package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js.map +1 -0
  115. package/dist/default/skins/dist/default/minimal/tailwind/components/icon.js +10 -0
  116. package/dist/default/skins/dist/default/minimal/tailwind/components/icon.js.map +1 -0
  117. package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js +8 -0
  118. package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -0
  119. package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js +12 -0
  120. package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -0
  121. package/dist/default/skins/dist/default/minimal/tailwind/components/root.js +8 -0
  122. package/dist/default/skins/dist/default/minimal/tailwind/components/root.js.map +1 -0
  123. package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js +11 -0
  124. package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -0
  125. package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js +20 -0
  126. package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -0
  127. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js +14 -0
  128. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js.map +1 -0
  129. package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js +28 -0
  130. package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +1 -0
  131. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +44 -0
  132. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -0
  133. package/dist/default/store/container-mixin.js +17 -3
  134. package/dist/default/store/container-mixin.js.map +1 -1
  135. package/dist/default/store/provider-mixin.js +2 -2
  136. package/dist/default/store/provider-mixin.js.map +1 -1
  137. package/dist/default/ui/alert-dialog/alert-dialog-close-element.js +46 -0
  138. package/dist/default/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
  139. package/dist/default/ui/alert-dialog/alert-dialog-description-element.js +26 -0
  140. package/dist/default/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
  141. package/dist/default/ui/alert-dialog/alert-dialog-element.js +73 -0
  142. package/dist/default/ui/alert-dialog/alert-dialog-element.js.map +1 -0
  143. package/dist/default/ui/alert-dialog/alert-dialog-title-element.js +26 -0
  144. package/dist/default/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
  145. package/dist/default/ui/alert-dialog/context.js +9 -0
  146. package/dist/default/ui/alert-dialog/context.js.map +1 -0
  147. package/dist/default/ui/captions-button/captions-button-element.js +25 -0
  148. package/dist/default/ui/captions-button/captions-button-element.js.map +1 -0
  149. package/dist/default/ui/controls/controls-group-element.js +1 -1
  150. package/dist/default/ui/media-element.js +3 -2
  151. package/dist/default/ui/media-element.js.map +1 -1
  152. package/dist/default/ui/popover/popover-element.js +9 -4
  153. package/dist/default/ui/popover/popover-element.js.map +1 -1
  154. package/dist/default/ui/slider/slider-element.js +12 -7
  155. package/dist/default/ui/slider/slider-element.js.map +1 -1
  156. package/dist/default/ui/slider/slider-preview-element.js +51 -0
  157. package/dist/default/ui/slider/slider-preview-element.js.map +1 -0
  158. package/dist/default/ui/slider/slider-thumbnail-element.js +23 -0
  159. package/dist/default/ui/slider/slider-thumbnail-element.js.map +1 -0
  160. package/dist/default/ui/thumbnail/thumbnail-element.js +4 -1
  161. package/dist/default/ui/thumbnail/thumbnail-element.js.map +1 -1
  162. package/dist/default/ui/time-slider/time-slider-element.js +12 -7
  163. package/dist/default/ui/time-slider/time-slider-element.js.map +1 -1
  164. package/dist/default/ui/tooltip/context.js +9 -0
  165. package/dist/default/ui/tooltip/context.js.map +1 -0
  166. package/dist/default/ui/tooltip/tooltip-element.js +154 -0
  167. package/dist/default/ui/tooltip/tooltip-element.js.map +1 -0
  168. package/dist/default/ui/tooltip/tooltip-group-element.js +38 -0
  169. package/dist/default/ui/tooltip/tooltip-group-element.js.map +1 -0
  170. package/dist/default/ui/volume-slider/volume-slider-element.js +13 -8
  171. package/dist/default/ui/volume-slider/volume-slider-element.js.map +1 -1
  172. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js +6 -0
  173. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -0
  174. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +6 -0
  175. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -0
  176. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +6 -0
  177. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -0
  178. package/dist/dev/_virtual/inline-css_src/define/video/skin.js +6 -0
  179. package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -0
  180. package/dist/dev/define/audio/minimal-skin.css +630 -5
  181. package/dist/dev/define/audio/minimal-skin.d.ts +6 -2
  182. package/dist/dev/define/audio/minimal-skin.d.ts.map +1 -1
  183. package/dist/dev/define/audio/minimal-skin.js +97 -9
  184. package/dist/dev/define/audio/minimal-skin.js.map +1 -1
  185. package/dist/dev/define/audio/minimal-skin.tailwind.d.ts +20 -0
  186. package/dist/dev/define/audio/minimal-skin.tailwind.d.ts.map +1 -0
  187. package/dist/dev/define/audio/minimal-skin.tailwind.js +121 -0
  188. package/dist/dev/define/audio/minimal-skin.tailwind.js.map +1 -0
  189. package/dist/dev/define/audio/player.d.ts +0 -1
  190. package/dist/dev/define/audio/player.d.ts.map +1 -1
  191. package/dist/dev/define/audio/skin.css +655 -6
  192. package/dist/dev/define/audio/skin.d.ts +6 -2
  193. package/dist/dev/define/audio/skin.d.ts.map +1 -1
  194. package/dist/dev/define/audio/skin.js +88 -9
  195. package/dist/dev/define/audio/skin.js.map +1 -1
  196. package/dist/dev/define/audio/skin.tailwind.d.ts +20 -0
  197. package/dist/dev/define/audio/skin.tailwind.d.ts.map +1 -0
  198. package/dist/dev/define/audio/skin.tailwind.js +111 -0
  199. package/dist/dev/define/audio/skin.tailwind.js.map +1 -0
  200. package/dist/dev/define/background/player.d.ts +0 -1
  201. package/dist/dev/define/background/player.d.ts.map +1 -1
  202. package/dist/dev/define/media/simple-hls-video.d.ts +14 -0
  203. package/dist/dev/define/media/simple-hls-video.d.ts.map +1 -0
  204. package/dist/dev/define/media/simple-hls-video.js +13 -0
  205. package/dist/dev/define/media/simple-hls-video.js.map +1 -0
  206. package/dist/dev/define/skin-mixin.d.ts +12 -4
  207. package/dist/dev/define/skin-mixin.d.ts.map +1 -1
  208. package/dist/dev/define/skin-mixin.js +53 -19
  209. package/dist/dev/define/skin-mixin.js.map +1 -1
  210. package/dist/dev/define/ui/alert-dialog-close.d.ts +9 -0
  211. package/dist/dev/define/ui/alert-dialog-close.d.ts.map +1 -0
  212. package/dist/dev/define/ui/alert-dialog-close.js +8 -0
  213. package/dist/dev/define/ui/alert-dialog-close.js.map +1 -0
  214. package/dist/dev/define/ui/alert-dialog-description.d.ts +9 -0
  215. package/dist/dev/define/ui/alert-dialog-description.d.ts.map +1 -0
  216. package/dist/dev/define/ui/alert-dialog-description.js +8 -0
  217. package/dist/dev/define/ui/alert-dialog-description.js.map +1 -0
  218. package/dist/dev/define/ui/alert-dialog-title.d.ts +9 -0
  219. package/dist/dev/define/ui/alert-dialog-title.d.ts.map +1 -0
  220. package/dist/dev/define/ui/alert-dialog-title.js +8 -0
  221. package/dist/dev/define/ui/alert-dialog-title.js.map +1 -0
  222. package/dist/dev/define/ui/alert-dialog.d.ts +15 -0
  223. package/dist/dev/define/ui/alert-dialog.d.ts.map +1 -0
  224. package/dist/dev/define/ui/alert-dialog.js +14 -0
  225. package/dist/dev/define/ui/alert-dialog.js.map +1 -0
  226. package/dist/dev/define/ui/captions-button.d.ts +9 -0
  227. package/dist/dev/define/ui/captions-button.d.ts.map +1 -0
  228. package/dist/dev/define/ui/captions-button.js +7 -0
  229. package/dist/dev/define/ui/captions-button.js.map +1 -0
  230. package/dist/dev/define/ui/slider-thumbnail.d.ts +9 -0
  231. package/dist/dev/define/ui/slider-thumbnail.d.ts.map +1 -0
  232. package/dist/dev/define/ui/slider-thumbnail.js +8 -0
  233. package/dist/dev/define/ui/slider-thumbnail.js.map +1 -0
  234. package/dist/dev/define/ui/slider.d.ts.map +1 -1
  235. package/dist/dev/define/ui/slider.js +2 -0
  236. package/dist/dev/define/ui/slider.js.map +1 -1
  237. package/dist/dev/define/ui/time-slider.d.ts.map +1 -1
  238. package/dist/dev/define/ui/time-slider.js +4 -0
  239. package/dist/dev/define/ui/time-slider.js.map +1 -1
  240. package/dist/dev/define/ui/tooltip-group.d.ts +9 -0
  241. package/dist/dev/define/ui/tooltip-group.d.ts.map +1 -0
  242. package/dist/dev/define/ui/tooltip-group.js +8 -0
  243. package/dist/dev/define/ui/tooltip-group.js.map +1 -0
  244. package/dist/dev/define/ui/tooltip.d.ts +9 -0
  245. package/dist/dev/define/ui/tooltip.d.ts.map +1 -0
  246. package/dist/dev/define/ui/tooltip.js +8 -0
  247. package/dist/dev/define/ui/tooltip.js.map +1 -0
  248. package/dist/dev/define/ui/volume-slider.d.ts.map +1 -1
  249. package/dist/dev/define/ui/volume-slider.js +2 -0
  250. package/dist/dev/define/ui/volume-slider.js.map +1 -1
  251. package/dist/dev/define/video/minimal-skin.css +367 -256
  252. package/dist/dev/define/video/minimal-skin.d.ts +5 -14
  253. package/dist/dev/define/video/minimal-skin.d.ts.map +1 -1
  254. package/dist/dev/define/video/minimal-skin.js +46 -17
  255. package/dist/dev/define/video/minimal-skin.js.map +1 -1
  256. package/dist/dev/define/video/minimal-skin.tailwind.d.ts +4 -14
  257. package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -1
  258. package/dist/dev/define/video/minimal-skin.tailwind.js +77 -31
  259. package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -1
  260. package/dist/dev/define/video/player.d.ts +0 -1
  261. package/dist/dev/define/video/player.d.ts.map +1 -1
  262. package/dist/dev/define/video/skin.css +395 -280
  263. package/dist/dev/define/video/skin.d.ts +5 -14
  264. package/dist/dev/define/video/skin.d.ts.map +1 -1
  265. package/dist/dev/define/video/skin.js +46 -15
  266. package/dist/dev/define/video/skin.js.map +1 -1
  267. package/dist/dev/define/video/skin.tailwind.d.ts +4 -14
  268. package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -1
  269. package/dist/dev/define/video/skin.tailwind.js +71 -28
  270. package/dist/dev/define/video/skin.tailwind.js.map +1 -1
  271. package/dist/dev/icons/dist/render/default/index.js +13 -13
  272. package/dist/dev/icons/dist/render/default/index.js.map +1 -1
  273. package/dist/dev/icons/dist/render/minimal/index.js +13 -13
  274. package/dist/dev/icons/dist/render/minimal/index.js.map +1 -1
  275. package/dist/dev/index.d.ts +15 -5
  276. package/dist/dev/index.js +13 -3
  277. package/dist/dev/media/container-element.d.ts +0 -1
  278. package/dist/dev/media/container-element.d.ts.map +1 -1
  279. package/dist/dev/media/hls-video/index.d.ts +1 -0
  280. package/dist/dev/media/hls-video/index.d.ts.map +1 -1
  281. package/dist/dev/media/hls-video/index.js +5 -1
  282. package/dist/dev/media/hls-video/index.js.map +1 -1
  283. package/dist/dev/media/simple-hls-video/index.d.ts +11 -0
  284. package/dist/dev/media/simple-hls-video/index.d.ts.map +1 -0
  285. package/dist/dev/media/simple-hls-video/index.js +21 -0
  286. package/dist/dev/media/simple-hls-video/index.js.map +1 -0
  287. package/dist/dev/player/create-player.d.ts +1 -1
  288. package/dist/dev/player/create-player.js.map +1 -1
  289. package/dist/dev/presets/audio.d.ts +3 -1
  290. package/dist/dev/presets/audio.js +3 -1
  291. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js +58 -0
  292. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -0
  293. package/dist/dev/skins/dist/default/default/tailwind/components/buffering.js +9 -0
  294. package/dist/dev/skins/dist/default/default/tailwind/components/buffering.js.map +1 -0
  295. package/dist/dev/skins/dist/default/default/tailwind/components/button.js +12 -0
  296. package/dist/dev/skins/dist/default/default/tailwind/components/button.js.map +1 -0
  297. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js +8 -0
  298. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js.map +1 -0
  299. package/dist/dev/skins/dist/default/default/tailwind/components/error.js +15 -0
  300. package/dist/dev/skins/dist/default/default/tailwind/components/error.js.map +1 -0
  301. package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js +29 -0
  302. package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js.map +1 -0
  303. package/dist/dev/skins/dist/default/default/tailwind/components/icon.js +10 -0
  304. package/dist/dev/skins/dist/default/default/tailwind/components/icon.js.map +1 -0
  305. package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js +8 -0
  306. package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js.map +1 -0
  307. package/dist/dev/skins/dist/default/default/tailwind/components/playback-rate.js +6 -0
  308. package/dist/dev/skins/dist/default/default/tailwind/components/playback-rate.js.map +1 -0
  309. package/dist/dev/skins/dist/default/default/tailwind/components/popup.js +13 -0
  310. package/dist/dev/skins/dist/default/default/tailwind/components/popup.js.map +1 -0
  311. package/dist/dev/skins/dist/default/default/tailwind/components/root.js +8 -0
  312. package/dist/dev/skins/dist/default/default/tailwind/components/root.js.map +1 -0
  313. package/dist/dev/skins/dist/default/default/tailwind/components/seek.js +11 -0
  314. package/dist/dev/skins/dist/default/default/tailwind/components/seek.js.map +1 -0
  315. package/dist/dev/skins/dist/default/default/tailwind/components/slider.js +21 -0
  316. package/dist/dev/skins/dist/default/default/tailwind/components/slider.js.map +1 -0
  317. package/dist/dev/skins/dist/default/default/tailwind/components/surface.js +8 -0
  318. package/dist/dev/skins/dist/default/default/tailwind/components/surface.js.map +1 -0
  319. package/dist/dev/skins/dist/default/default/tailwind/components/time.js +10 -0
  320. package/dist/dev/skins/dist/default/default/tailwind/components/time.js.map +1 -0
  321. package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js +28 -0
  322. package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js.map +1 -0
  323. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +55 -0
  324. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -0
  325. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +44 -0
  326. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -0
  327. package/dist/dev/skins/dist/default/minimal/tailwind/components/buffering.js +6 -0
  328. package/dist/dev/skins/dist/default/minimal/tailwind/components/buffering.js.map +1 -0
  329. package/dist/dev/skins/dist/default/minimal/tailwind/components/button-group.js +8 -0
  330. package/dist/dev/skins/dist/default/minimal/tailwind/components/button-group.js.map +1 -0
  331. package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js +12 -0
  332. package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js.map +1 -0
  333. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js +8 -0
  334. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -0
  335. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js +15 -0
  336. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js.map +1 -0
  337. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js +29 -0
  338. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js.map +1 -0
  339. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon.js +10 -0
  340. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon.js.map +1 -0
  341. package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js +8 -0
  342. package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -0
  343. package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js +12 -0
  344. package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -0
  345. package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js +8 -0
  346. package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js.map +1 -0
  347. package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js +11 -0
  348. package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -0
  349. package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js +20 -0
  350. package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -0
  351. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js +14 -0
  352. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js.map +1 -0
  353. package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js +28 -0
  354. package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +1 -0
  355. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +44 -0
  356. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -0
  357. package/dist/dev/store/container-mixin.d.ts +1 -1
  358. package/dist/dev/store/container-mixin.js +17 -3
  359. package/dist/dev/store/container-mixin.js.map +1 -1
  360. package/dist/dev/store/provider-mixin.d.ts +1 -1
  361. package/dist/dev/store/provider-mixin.js +2 -2
  362. package/dist/dev/store/provider-mixin.js.map +1 -1
  363. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts +20 -0
  364. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts.map +1 -0
  365. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js +46 -0
  366. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
  367. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts +17 -0
  368. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts.map +1 -0
  369. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js +26 -0
  370. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
  371. package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts +22 -0
  372. package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts.map +1 -0
  373. package/dist/dev/ui/alert-dialog/alert-dialog-element.js +73 -0
  374. package/dist/dev/ui/alert-dialog/alert-dialog-element.js.map +1 -0
  375. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts +17 -0
  376. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts.map +1 -0
  377. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js +26 -0
  378. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
  379. package/dist/dev/ui/alert-dialog/context.d.ts +14 -0
  380. package/dist/dev/ui/alert-dialog/context.d.ts.map +1 -0
  381. package/dist/dev/ui/alert-dialog/context.js +9 -0
  382. package/dist/dev/ui/alert-dialog/context.js.map +1 -0
  383. package/dist/dev/ui/captions-button/captions-button-element.d.ts +19 -0
  384. package/dist/dev/ui/captions-button/captions-button-element.d.ts.map +1 -0
  385. package/dist/dev/ui/captions-button/captions-button-element.js +25 -0
  386. package/dist/dev/ui/captions-button/captions-button-element.js.map +1 -0
  387. package/dist/dev/ui/controls/controls-group-element.d.ts +1 -1
  388. package/dist/dev/ui/controls/controls-group-element.js +1 -1
  389. package/dist/dev/ui/media-element.d.ts +4 -1
  390. package/dist/dev/ui/media-element.d.ts.map +1 -1
  391. package/dist/dev/ui/media-element.js +3 -2
  392. package/dist/dev/ui/media-element.js.map +1 -1
  393. package/dist/dev/ui/popover/popover-element.d.ts +1 -0
  394. package/dist/dev/ui/popover/popover-element.d.ts.map +1 -1
  395. package/dist/dev/ui/popover/popover-element.js +9 -4
  396. package/dist/dev/ui/popover/popover-element.js.map +1 -1
  397. package/dist/dev/ui/slider/slider-element.d.ts +1 -0
  398. package/dist/dev/ui/slider/slider-element.d.ts.map +1 -1
  399. package/dist/dev/ui/slider/slider-element.js +12 -7
  400. package/dist/dev/ui/slider/slider-element.js.map +1 -1
  401. package/dist/dev/ui/slider/slider-preview-element.js +51 -0
  402. package/dist/dev/ui/slider/slider-preview-element.js.map +1 -0
  403. package/dist/dev/ui/slider/slider-thumbnail-element.d.ts +12 -0
  404. package/dist/dev/ui/slider/slider-thumbnail-element.d.ts.map +1 -0
  405. package/dist/dev/ui/slider/slider-thumbnail-element.js +23 -0
  406. package/dist/dev/ui/slider/slider-thumbnail-element.js.map +1 -0
  407. package/dist/dev/ui/thumbnail/thumbnail-element.d.ts +1 -0
  408. package/dist/dev/ui/thumbnail/thumbnail-element.d.ts.map +1 -1
  409. package/dist/dev/ui/thumbnail/thumbnail-element.js +4 -1
  410. package/dist/dev/ui/thumbnail/thumbnail-element.js.map +1 -1
  411. package/dist/dev/ui/time-slider/time-slider-element.d.ts +1 -0
  412. package/dist/dev/ui/time-slider/time-slider-element.d.ts.map +1 -1
  413. package/dist/dev/ui/time-slider/time-slider-element.js +12 -7
  414. package/dist/dev/ui/time-slider/time-slider-element.js.map +1 -1
  415. package/dist/dev/ui/tooltip/context.d.ts +9 -0
  416. package/dist/dev/ui/tooltip/context.d.ts.map +1 -0
  417. package/dist/dev/ui/tooltip/context.js +9 -0
  418. package/dist/dev/ui/tooltip/context.js.map +1 -0
  419. package/dist/dev/ui/tooltip/tooltip-element.d.ts +54 -0
  420. package/dist/dev/ui/tooltip/tooltip-element.d.ts.map +1 -0
  421. package/dist/dev/ui/tooltip/tooltip-element.js +154 -0
  422. package/dist/dev/ui/tooltip/tooltip-element.js.map +1 -0
  423. package/dist/dev/ui/tooltip/tooltip-group-element.d.ts +27 -0
  424. package/dist/dev/ui/tooltip/tooltip-group-element.d.ts.map +1 -0
  425. package/dist/dev/ui/tooltip/tooltip-group-element.js +38 -0
  426. package/dist/dev/ui/tooltip/tooltip-group-element.js.map +1 -0
  427. package/dist/dev/ui/volume-slider/volume-slider-element.d.ts +1 -0
  428. package/dist/dev/ui/volume-slider/volume-slider-element.d.ts.map +1 -1
  429. package/dist/dev/ui/volume-slider/volume-slider-element.js +13 -8
  430. package/dist/dev/ui/volume-slider/volume-slider-element.js.map +1 -1
  431. package/package.json +8 -7
  432. package/dist/default/skins/dist/default/video/default.tailwind.js +0 -90
  433. package/dist/default/skins/dist/default/video/default.tailwind.js.map +0 -1
  434. package/dist/default/skins/dist/default/video/minimal.tailwind.js +0 -86
  435. package/dist/default/skins/dist/default/video/minimal.tailwind.js.map +0 -1
  436. package/dist/dev/skins/dist/default/video/default.tailwind.js +0 -90
  437. package/dist/dev/skins/dist/default/video/default.tailwind.js.map +0 -1
  438. package/dist/dev/skins/dist/default/video/minimal.tailwind.js +0 -86
  439. package/dist/dev/skins/dist/default/video/minimal.tailwind.js.map +0 -1
@@ -34,20 +34,33 @@ function createContainerMixin(context) {
34
34
  });
35
35
  this.#observer.observe(this, {
36
36
  childList: true,
37
- subtree: true
37
+ subtree: true,
38
+ attributes: true,
39
+ attributeFilter: ["data-media-element"]
38
40
  });
41
+ this.addEventListener("slotchange", this.#onSlotChange);
39
42
  this.#attachMedia();
40
43
  }
41
44
  disconnectedCallback() {
42
45
  super.disconnectedCallback();
43
46
  this.#observer?.disconnect();
44
47
  this.#observer = null;
48
+ this.removeEventListener("slotchange", this.#onSlotChange);
45
49
  this.#detach();
46
50
  }
51
+ #onSlotChange = () => {
52
+ this.#attachMedia();
53
+ };
54
+ #getSlottedMedia() {
55
+ const slot = this.querySelector("slot[name=\"media\"]");
56
+ if (!slot) return null;
57
+ for (const el of slot.assignedElements({ flatten: true })) if (el instanceof HTMLMediaElement) return el;
58
+ return null;
59
+ }
47
60
  #attachMedia() {
48
61
  const store = this.#contextStore ?? this.store;
49
62
  if (!store) return;
50
- const media = this.querySelector("video, audio");
63
+ const media = this.querySelector("video, audio, [data-media-element]") ?? this.#getSlottedMedia();
51
64
  if (!media) {
52
65
  this.#detach();
53
66
  this.#detach = noop;
@@ -68,9 +81,10 @@ function createContainerMixin(context) {
68
81
  };
69
82
  }
70
83
  function isMediaNode(node) {
71
- return node instanceof HTMLMediaElement;
84
+ return node instanceof HTMLMediaElement || node instanceof Element && node.hasAttribute("data-media-element");
72
85
  }
73
86
  function hasMediaNode(record) {
87
+ if (record.type === "attributes" && record.target instanceof Element) return record.target.hasAttribute("data-media-element");
74
88
  for (const node of record.addedNodes) if (isMediaNode(node)) return true;
75
89
  for (const node of record.removedNodes) if (isMediaNode(node)) return true;
76
90
  return false;
@@ -1 +1 @@
1
- {"version":3,"file":"container-mixin.js","names":["#contextStore","#attachMedia","#observer","#detach"],"sources":["../../../src/store/container-mixin.ts"],"sourcesContent":["import type { MediaContainer, PlayerStore, PlayerTarget } from '@videojs/core/dom';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { noop } from '@videojs/utils/function';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerConsumer, PlayerConsumerConstructor } from './types';\n\nexport type ContainerMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerConsumerConstructor<Store>;\n\n/**\n * Create a mixin that consumes player context and auto-attaches media elements.\n *\n * @param context - Player context to consume from an ancestor provider.\n */\nexport function createContainerMixin<Store extends PlayerStore>(context: PlayerContext<Store>): ContainerMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerContainerElement extends BaseClass implements PlayerConsumer<Store>, MediaContainer {\n #detach = noop;\n #observer: MutationObserver | null = null;\n #contextStore: Store | null = null;\n\n constructor(...args: any[]) {\n super(...args);\n\n // Created in the constructor body (after all field initializers) so\n // that #contextStore's private slot exists if the callback fires\n // synchronously — which happens when the element is already connected.\n // The host's controller list keeps the consumer alive; no field needed.\n new ContextConsumer(this, {\n context,\n callback: (value) => {\n this.#contextStore = value ?? null;\n this.#attachMedia();\n },\n subscribe: true,\n });\n }\n\n get store(): Store | null {\n return this.#contextStore;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n\n this.#observer = new MutationObserver((records) => {\n if (records.some(hasMediaNode)) this.#attachMedia();\n });\n\n this.#observer.observe(this, { childList: true, subtree: true });\n\n this.#attachMedia();\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#observer?.disconnect();\n this.#observer = null;\n this.#detach();\n }\n\n #attachMedia() {\n // Prefer the cached context value; fall back to `this.store` which\n // ProviderMixin overrides when both mixins are applied to one element.\n const store = this.#contextStore ?? this.store;\n if (!store) return;\n\n const media = this.querySelector<HTMLMediaElement>('video, audio');\n\n if (!media) {\n this.#detach();\n this.#detach = noop;\n return;\n }\n\n const target: PlayerTarget = {\n media,\n container: this,\n };\n\n const hasMediaChanged = store.target?.media !== target.media,\n hasContainerChanged = store.target?.container !== target.container;\n\n if (hasMediaChanged || hasContainerChanged) {\n this.#detach();\n this.#detach = store.attach(target);\n }\n }\n }\n\n return PlayerContainerElement;\n };\n}\n\nfunction isMediaNode(node: Node): boolean {\n return node instanceof HTMLMediaElement;\n}\n\nfunction hasMediaNode(record: MutationRecord): boolean {\n for (const node of record.addedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n for (const node of record.removedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n return false;\n}\n"],"mappings":";;;;;;;;;AAgBA,SAAgB,qBAAgD,SAAsD;AACpH,SAA+C,cAAqB;EAClE,MAAM,+BAA+B,UAA2D;GAC9F,UAAU;GACV,YAAqC;GACrC,gBAA8B;GAE9B,YAAY,GAAG,MAAa;AAC1B,UAAM,GAAG,KAAK;AAMd,QAAI,gBAAgB,MAAM;KACxB;KACA,WAAW,UAAU;AACnB,YAAKA,eAAgB,SAAS;AAC9B,YAAKC,aAAc;;KAErB,WAAW;KACZ,CAAC;;GAGJ,IAAI,QAAsB;AACxB,WAAO,MAAKD;;GAGd,AAAS,oBAAoB;AAC3B,UAAM,mBAAmB;AAEzB,UAAKE,WAAY,IAAI,kBAAkB,YAAY;AACjD,SAAI,QAAQ,KAAK,aAAa,CAAE,OAAKD,aAAc;MACnD;AAEF,UAAKC,SAAU,QAAQ,MAAM;KAAE,WAAW;KAAM,SAAS;KAAM,CAAC;AAEhE,UAAKD,aAAc;;GAGrB,AAAS,uBAAuB;AAC9B,UAAM,sBAAsB;AAC5B,UAAKC,UAAW,YAAY;AAC5B,UAAKA,WAAY;AACjB,UAAKC,QAAS;;GAGhB,eAAe;IAGb,MAAM,QAAQ,MAAKH,gBAAiB,KAAK;AACzC,QAAI,CAAC,MAAO;IAEZ,MAAM,QAAQ,KAAK,cAAgC,eAAe;AAElE,QAAI,CAAC,OAAO;AACV,WAAKG,QAAS;AACd,WAAKA,SAAU;AACf;;IAGF,MAAM,SAAuB;KAC3B;KACA,WAAW;KACZ;IAED,MAAM,kBAAkB,MAAM,QAAQ,UAAU,OAAO,OACrD,sBAAsB,MAAM,QAAQ,cAAc,OAAO;AAE3D,QAAI,mBAAmB,qBAAqB;AAC1C,WAAKA,QAAS;AACd,WAAKA,SAAU,MAAM,OAAO,OAAO;;;;AAKzC,SAAO;;;AAIX,SAAS,YAAY,MAAqB;AACxC,QAAO,gBAAgB;;AAGzB,SAAS,aAAa,QAAiC;AACrD,MAAK,MAAM,QAAQ,OAAO,WACxB,KAAI,YAAY,KAAK,CAAE,QAAO;AAGhC,MAAK,MAAM,QAAQ,OAAO,aACxB,KAAI,YAAY,KAAK,CAAE,QAAO;AAGhC,QAAO"}
1
+ {"version":3,"file":"container-mixin.js","names":["#contextStore","#attachMedia","#observer","#onSlotChange","#detach","#getSlottedMedia"],"sources":["../../../src/store/container-mixin.ts"],"sourcesContent":["import type { MediaContainer, PlayerStore, PlayerTarget } from '@videojs/core/dom';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { noop } from '@videojs/utils/function';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerConsumer, PlayerConsumerConstructor } from './types';\n\nexport type ContainerMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerConsumerConstructor<Store>;\n\n/**\n * Create a mixin that consumes player context and auto-attaches media elements.\n *\n * @param context - Player context to consume from an ancestor provider.\n */\nexport function createContainerMixin<Store extends PlayerStore>(context: PlayerContext<Store>): ContainerMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerContainerElement extends BaseClass implements PlayerConsumer<Store>, MediaContainer {\n #detach = noop;\n #observer: MutationObserver | null = null;\n #contextStore: Store | null = null;\n\n constructor(...args: any[]) {\n super(...args);\n\n // Created in the constructor body (after all field initializers) so\n // that #contextStore's private slot exists if the callback fires\n // synchronously — which happens when the element is already connected.\n // The host's controller list keeps the consumer alive; no field needed.\n new ContextConsumer(this, {\n context,\n callback: (value) => {\n this.#contextStore = value ?? null;\n this.#attachMedia();\n },\n subscribe: true,\n });\n }\n\n get store(): Store | null {\n return this.#contextStore;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n\n this.#observer = new MutationObserver((records) => {\n if (records.some(hasMediaNode)) this.#attachMedia();\n });\n\n this.#observer.observe(this, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['data-media-element'],\n });\n\n // Slotted media elements don't appear in the container's subtree,\n // so listen for slot reassignments to pick them up.\n this.addEventListener('slotchange', this.#onSlotChange);\n\n this.#attachMedia();\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#observer?.disconnect();\n this.#observer = null;\n this.removeEventListener('slotchange', this.#onSlotChange);\n this.#detach();\n }\n\n #onSlotChange = () => {\n this.#attachMedia();\n };\n\n #getSlottedMedia(): HTMLMediaElement | null {\n const slot = this.querySelector<HTMLSlotElement>('slot[name=\"media\"]');\n if (!slot) return null;\n\n for (const el of slot.assignedElements({ flatten: true })) {\n if (el instanceof HTMLMediaElement) return el;\n }\n\n return null;\n }\n\n #attachMedia() {\n // Prefer the cached context value; fall back to `this.store` which\n // ProviderMixin overrides when both mixins are applied to one element.\n const store = this.#contextStore ?? this.store;\n if (!store) return;\n\n const media =\n this.querySelector<HTMLMediaElement>('video, audio, [data-media-element]') ?? this.#getSlottedMedia();\n\n if (!media) {\n this.#detach();\n this.#detach = noop;\n return;\n }\n\n const target: PlayerTarget = {\n media,\n container: this,\n };\n\n const hasMediaChanged = store.target?.media !== target.media,\n hasContainerChanged = store.target?.container !== target.container;\n\n if (hasMediaChanged || hasContainerChanged) {\n this.#detach();\n this.#detach = store.attach(target);\n }\n }\n }\n\n return PlayerContainerElement;\n };\n}\n\nfunction isMediaNode(node: Node): boolean {\n return node instanceof HTMLMediaElement || (node instanceof Element && node.hasAttribute('data-media-element'));\n}\n\nfunction hasMediaNode(record: MutationRecord): boolean {\n // Attribute mutation: data-media-element was added to a descendant\n if (record.type === 'attributes' && record.target instanceof Element) {\n return record.target.hasAttribute('data-media-element');\n }\n\n for (const node of record.addedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n for (const node of record.removedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n return false;\n}\n"],"mappings":";;;;;;;;;AAgBA,SAAgB,qBAAgD,SAAsD;AACpH,SAA+C,cAAqB;EAClE,MAAM,+BAA+B,UAA2D;GAC9F,UAAU;GACV,YAAqC;GACrC,gBAA8B;GAE9B,YAAY,GAAG,MAAa;AAC1B,UAAM,GAAG,KAAK;AAMd,QAAI,gBAAgB,MAAM;KACxB;KACA,WAAW,UAAU;AACnB,YAAKA,eAAgB,SAAS;AAC9B,YAAKC,aAAc;;KAErB,WAAW;KACZ,CAAC;;GAGJ,IAAI,QAAsB;AACxB,WAAO,MAAKD;;GAGd,AAAS,oBAAoB;AAC3B,UAAM,mBAAmB;AAEzB,UAAKE,WAAY,IAAI,kBAAkB,YAAY;AACjD,SAAI,QAAQ,KAAK,aAAa,CAAE,OAAKD,aAAc;MACnD;AAEF,UAAKC,SAAU,QAAQ,MAAM;KAC3B,WAAW;KACX,SAAS;KACT,YAAY;KACZ,iBAAiB,CAAC,qBAAqB;KACxC,CAAC;AAIF,SAAK,iBAAiB,cAAc,MAAKC,aAAc;AAEvD,UAAKF,aAAc;;GAGrB,AAAS,uBAAuB;AAC9B,UAAM,sBAAsB;AAC5B,UAAKC,UAAW,YAAY;AAC5B,UAAKA,WAAY;AACjB,SAAK,oBAAoB,cAAc,MAAKC,aAAc;AAC1D,UAAKC,QAAS;;GAGhB,sBAAsB;AACpB,UAAKH,aAAc;;GAGrB,mBAA4C;IAC1C,MAAM,OAAO,KAAK,cAA+B,uBAAqB;AACtE,QAAI,CAAC,KAAM,QAAO;AAElB,SAAK,MAAM,MAAM,KAAK,iBAAiB,EAAE,SAAS,MAAM,CAAC,CACvD,KAAI,cAAc,iBAAkB,QAAO;AAG7C,WAAO;;GAGT,eAAe;IAGb,MAAM,QAAQ,MAAKD,gBAAiB,KAAK;AACzC,QAAI,CAAC,MAAO;IAEZ,MAAM,QACJ,KAAK,cAAgC,qCAAqC,IAAI,MAAKK,iBAAkB;AAEvG,QAAI,CAAC,OAAO;AACV,WAAKD,QAAS;AACd,WAAKA,SAAU;AACf;;IAGF,MAAM,SAAuB;KAC3B;KACA,WAAW;KACZ;IAED,MAAM,kBAAkB,MAAM,QAAQ,UAAU,OAAO,OACrD,sBAAsB,MAAM,QAAQ,cAAc,OAAO;AAE3D,QAAI,mBAAmB,qBAAqB;AAC1C,WAAKA,QAAS;AACd,WAAKA,SAAU,MAAM,OAAO,OAAO;;;;AAKzC,SAAO;;;AAIX,SAAS,YAAY,MAAqB;AACxC,QAAO,gBAAgB,oBAAqB,gBAAgB,WAAW,KAAK,aAAa,qBAAqB;;AAGhH,SAAS,aAAa,QAAiC;AAErD,KAAI,OAAO,SAAS,gBAAgB,OAAO,kBAAkB,QAC3D,QAAO,OAAO,OAAO,aAAa,qBAAqB;AAGzD,MAAK,MAAM,QAAQ,OAAO,WACxB,KAAI,YAAY,KAAK,CAAE,QAAO;AAGhC,MAAK,MAAM,QAAQ,OAAO,aACxB,KAAI,YAAY,KAAK,CAAE,QAAO;AAGhC,QAAO"}
@@ -24,10 +24,10 @@ function createProviderMixin(context, factory) {
24
24
  super.connectedCallback();
25
25
  this.#provider.setValue(this.store);
26
26
  }
27
- disconnectedCallback() {
28
- super.disconnectedCallback();
27
+ destroyCallback() {
29
28
  this.#store?.destroy();
30
29
  this.#store = null;
30
+ super.destroyCallback();
31
31
  }
32
32
  }
33
33
  return PlayerProviderElement;
@@ -1 +1 @@
1
- {"version":3,"file":"provider-mixin.js","names":["#store","#provider"],"sources":["../../../src/store/provider-mixin.ts"],"sourcesContent":["import type { PlayerStore } from '@videojs/core/dom';\nimport { ContextProvider } from '@videojs/element/context';\nimport { isNull } from '@videojs/utils/predicate';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerProvider, PlayerProviderConstructor } from './types';\n\nexport type ProviderMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerProviderConstructor<Store>;\n\n/**\n * Create a mixin that provides player context to descendant elements.\n *\n * @param context - Player context to provide to descendants.\n * @param factory - Factory function that creates a store instance.\n */\nexport function createProviderMixin<Store extends PlayerStore>(\n context: PlayerContext<Store>,\n factory: () => Store\n): ProviderMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerProviderElement extends BaseClass implements PlayerProvider<Store> {\n #store: Store | null = factory();\n\n #provider = new ContextProvider(this, {\n context,\n initialValue: this.store,\n });\n\n get store(): Store {\n if (isNull(this.#store)) {\n this.#store = factory();\n }\n\n return this.#store;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#provider.setValue(this.store);\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#store?.destroy();\n this.#store = null;\n }\n }\n\n return PlayerProviderElement;\n };\n}\n"],"mappings":";;;;;;;;;;AAiBA,SAAgB,oBACd,SACA,SACsB;AACtB,SAA+C,cAAqB;EAClE,MAAM,8BAA8B,UAA2C;GAC7E,SAAuB,SAAS;GAEhC,YAAY,IAAI,gBAAgB,MAAM;IACpC;IACA,cAAc,KAAK;IACpB,CAAC;GAEF,IAAI,QAAe;AACjB,QAAI,OAAO,MAAKA,MAAO,CACrB,OAAKA,QAAS,SAAS;AAGzB,WAAO,MAAKA;;GAGd,AAAS,oBAAoB;AAC3B,UAAM,mBAAmB;AACzB,UAAKC,SAAU,SAAS,KAAK,MAAM;;GAGrC,AAAS,uBAAuB;AAC9B,UAAM,sBAAsB;AAC5B,UAAKD,OAAQ,SAAS;AACtB,UAAKA,QAAS;;;AAIlB,SAAO"}
1
+ {"version":3,"file":"provider-mixin.js","names":["#store","#provider"],"sources":["../../../src/store/provider-mixin.ts"],"sourcesContent":["import type { PlayerStore } from '@videojs/core/dom';\nimport { ContextProvider } from '@videojs/element/context';\nimport { isNull } from '@videojs/utils/predicate';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerProvider, PlayerProviderConstructor } from './types';\n\nexport type ProviderMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerProviderConstructor<Store>;\n\n/**\n * Create a mixin that provides player context to descendant elements.\n *\n * @param context - Player context to provide to descendants.\n * @param factory - Factory function that creates a store instance.\n */\nexport function createProviderMixin<Store extends PlayerStore>(\n context: PlayerContext<Store>,\n factory: () => Store\n): ProviderMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerProviderElement extends BaseClass implements PlayerProvider<Store> {\n #store: Store | null = factory();\n\n #provider = new ContextProvider(this, {\n context,\n initialValue: this.store,\n });\n\n get store(): Store {\n if (isNull(this.#store)) {\n this.#store = factory();\n }\n\n return this.#store;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#provider.setValue(this.store);\n }\n\n override destroyCallback() {\n this.#store?.destroy();\n this.#store = null;\n super.destroyCallback();\n }\n }\n\n return PlayerProviderElement;\n };\n}\n"],"mappings":";;;;;;;;;;AAiBA,SAAgB,oBACd,SACA,SACsB;AACtB,SAA+C,cAAqB;EAClE,MAAM,8BAA8B,UAA2C;GAC7E,SAAuB,SAAS;GAEhC,YAAY,IAAI,gBAAgB,MAAM;IACpC;IACA,cAAc,KAAK;IACpB,CAAC;GAEF,IAAI,QAAe;AACjB,QAAI,OAAO,MAAKA,MAAO,CACrB,OAAKA,QAAS,SAAS;AAGzB,WAAO,MAAKA;;GAGd,AAAS,oBAAoB;AAC3B,UAAM,mBAAmB;AACzB,UAAKC,SAAU,SAAS,KAAK,MAAM;;GAGrC,AAAS,kBAAkB;AACzB,UAAKD,OAAQ,SAAS;AACtB,UAAKA,QAAS;AACd,UAAM,iBAAiB;;;AAI3B,SAAO"}
@@ -0,0 +1,46 @@
1
+ import { MediaElement } from "../media-element.js";
2
+ import { alertDialogContext } from "./context.js";
3
+ import { applyElementProps, applyStateDataAttrs, createButton } from "@videojs/core/dom";
4
+ import { ContextConsumer } from "@videojs/element/context";
5
+
6
+ //#region src/ui/alert-dialog/alert-dialog-close-element.ts
7
+ var AlertDialogCloseElement = class extends MediaElement {
8
+ constructor(..._args) {
9
+ super(..._args);
10
+ this.disabled = false;
11
+ }
12
+ static {
13
+ this.tagName = "media-alert-dialog-close";
14
+ }
15
+ static {
16
+ this.properties = { disabled: { type: Boolean } };
17
+ }
18
+ #ctx = new ContextConsumer(this, {
19
+ context: alertDialogContext,
20
+ subscribe: true
21
+ });
22
+ #disconnect = null;
23
+ connectedCallback() {
24
+ super.connectedCallback();
25
+ this.#disconnect = new AbortController();
26
+ const buttonProps = createButton({
27
+ onActivate: () => this.#ctx.value?.close(),
28
+ isDisabled: () => this.disabled
29
+ });
30
+ applyElementProps(this, buttonProps, { signal: this.#disconnect.signal });
31
+ }
32
+ disconnectedCallback() {
33
+ super.disconnectedCallback();
34
+ this.#disconnect?.abort();
35
+ this.#disconnect = null;
36
+ }
37
+ update(_changed) {
38
+ super.update(_changed);
39
+ const ctx = this.#ctx.value;
40
+ if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);
41
+ }
42
+ };
43
+
44
+ //#endregion
45
+ export { AlertDialogCloseElement };
46
+ //# sourceMappingURL=alert-dialog-close-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-dialog-close-element.js","names":["#ctx","#disconnect"],"sources":["../../../../src/ui/alert-dialog/alert-dialog-close-element.ts"],"sourcesContent":["import { applyElementProps, applyStateDataAttrs, createButton } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { MediaElement } from '../media-element';\nimport { alertDialogContext } from './context';\n\nexport class AlertDialogCloseElement extends MediaElement {\n static readonly tagName = 'media-alert-dialog-close';\n\n static override properties = {\n disabled: { type: Boolean },\n } satisfies PropertyDeclarationMap<'disabled'>;\n\n disabled = false;\n\n readonly #ctx = new ContextConsumer(this, { context: alertDialogContext, subscribe: true });\n\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.#disconnect = new AbortController();\n\n const buttonProps = createButton({\n onActivate: () => this.#ctx.value?.close(),\n isDisabled: () => this.disabled,\n });\n\n applyElementProps(this, buttonProps, { signal: this.#disconnect.signal });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n const ctx = this.#ctx.value;\n if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);\n }\n}\n"],"mappings":";;;;;;AAOA,IAAa,0BAAb,cAA6C,aAAa;;;kBAO7C;;;iBANe;;;oBAEG,EAC3B,UAAU,EAAE,MAAM,SAAS,EAC5B;;CAID,CAASA,MAAO,IAAI,gBAAgB,MAAM;EAAE,SAAS;EAAoB,WAAW;EAAM,CAAC;CAE3F,cAAsC;CAEtC,AAAS,oBAA0B;AACjC,QAAM,mBAAmB;AACzB,QAAKC,aAAc,IAAI,iBAAiB;EAExC,MAAM,cAAc,aAAa;GAC/B,kBAAkB,MAAKD,IAAK,OAAO,OAAO;GAC1C,kBAAkB,KAAK;GACxB,CAAC;AAEF,oBAAkB,MAAM,aAAa,EAAE,QAAQ,MAAKC,WAAY,QAAQ,CAAC;;CAG3E,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKA,YAAa,OAAO;AACzB,QAAKA,aAAc;;CAGrB,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;EACtB,MAAM,MAAM,MAAKD,IAAK;AACtB,MAAI,IAAK,qBAAoB,MAAM,IAAI,OAAO,IAAI,aAAa"}
@@ -0,0 +1,26 @@
1
+ import { alertDialogContext } from "./context.js";
2
+ import { ContextPartElement } from "../context-part-element.js";
3
+ import { ContextConsumer } from "@videojs/element/context";
4
+
5
+ //#region src/ui/alert-dialog/alert-dialog-description-element.ts
6
+ var AlertDialogDescriptionElement = class extends ContextPartElement {
7
+ constructor(..._args) {
8
+ super(..._args);
9
+ this.consumer = new ContextConsumer(this, {
10
+ context: alertDialogContext,
11
+ subscribe: true
12
+ });
13
+ }
14
+ static {
15
+ this.tagName = "media-alert-dialog-description";
16
+ }
17
+ update(changed) {
18
+ super.update(changed);
19
+ const descriptionId = this.consumer.value?.state.descriptionId;
20
+ if (descriptionId) this.id = descriptionId;
21
+ }
22
+ };
23
+
24
+ //#endregion
25
+ export { AlertDialogDescriptionElement };
26
+ //# sourceMappingURL=alert-dialog-description-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-dialog-description-element.js","names":[],"sources":["../../../../src/ui/alert-dialog/alert-dialog-description-element.ts"],"sourcesContent":["import type { AlertDialogState } from '@videojs/core';\nimport type { PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { ContextPartElement } from '../context-part-element';\nimport { alertDialogContext } from './context';\n\nexport class AlertDialogDescriptionElement extends ContextPartElement<AlertDialogState> {\n static readonly tagName = 'media-alert-dialog-description';\n\n protected readonly consumer = new ContextConsumer(this, { context: alertDialogContext, subscribe: true });\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n const descriptionId = this.consumer.value?.state.descriptionId;\n if (descriptionId) this.id = descriptionId;\n }\n}\n"],"mappings":";;;;;AAOA,IAAa,gCAAb,cAAmD,mBAAqC;;;kBAGxD,IAAI,gBAAgB,MAAM;GAAE,SAAS;GAAoB,WAAW;GAAM,CAAC;;;iBAF/E;;CAI1B,AAAmB,OAAO,SAA+B;AACvD,QAAM,OAAO,QAAQ;EACrB,MAAM,gBAAgB,KAAK,SAAS,OAAO,MAAM;AACjD,MAAI,cAAe,MAAK,KAAK"}
@@ -0,0 +1,73 @@
1
+ import { MediaElement } from "../media-element.js";
2
+ import { alertDialogContext } from "./context.js";
3
+ import { applyElementProps, applyStateDataAttrs, createAlertDialog, createTransition } from "@videojs/core/dom";
4
+ import { ContextProvider } from "@videojs/element/context";
5
+ import { SnapshotController } from "@videojs/store/html";
6
+ import { AlertDialogCore, AlertDialogDataAttrs } from "@videojs/core";
7
+
8
+ //#region src/ui/alert-dialog/alert-dialog-element.ts
9
+ let idCounter = 0;
10
+ var AlertDialogElement = class extends MediaElement {
11
+ static {
12
+ this.tagName = "media-alert-dialog";
13
+ }
14
+ static {
15
+ this.properties = { open: { type: Boolean } };
16
+ }
17
+ #core = new AlertDialogCore();
18
+ #provider = new ContextProvider(this, { context: alertDialogContext });
19
+ #titleId = `vjs-alert-dialog-title-${idCounter++}`;
20
+ #descriptionId = `vjs-alert-dialog-desc-${idCounter++}`;
21
+ #dialog = null;
22
+ #snapshot = null;
23
+ constructor() {
24
+ super();
25
+ this.open = false;
26
+ this.#core.setTitleId(this.#titleId);
27
+ this.#core.setDescriptionId(this.#descriptionId);
28
+ }
29
+ connectedCallback() {
30
+ super.connectedCallback();
31
+ this.#dialog = createAlertDialog({
32
+ transition: createTransition(),
33
+ onOpenChange: (nextOpen) => {
34
+ this.open = nextOpen;
35
+ this.dispatchEvent(new CustomEvent("open-change", { detail: { open: nextOpen } }));
36
+ }
37
+ });
38
+ this.#dialog.setElement(this);
39
+ if (this.#snapshot) this.#snapshot.track(this.#dialog.input);
40
+ else this.#snapshot = new SnapshotController(this, this.#dialog.input);
41
+ }
42
+ disconnectedCallback() {
43
+ super.disconnectedCallback();
44
+ this.#dialog?.destroy();
45
+ this.#dialog = null;
46
+ }
47
+ willUpdate(changed) {
48
+ super.willUpdate(changed);
49
+ if (this.#dialog && changed.has("open")) {
50
+ const { active: inputOpen } = this.#dialog.input.current;
51
+ if (this.open !== inputOpen) if (this.open) this.#dialog.open();
52
+ else this.#dialog.close();
53
+ }
54
+ }
55
+ update(_changed) {
56
+ super.update(_changed);
57
+ if (!this.#dialog) return;
58
+ const input = this.#dialog.input.current;
59
+ this.#core.setInput(input);
60
+ const state = this.#core.getState();
61
+ applyElementProps(this, this.#core.getAttrs(state));
62
+ applyStateDataAttrs(this, state, AlertDialogDataAttrs);
63
+ this.#provider.setValue({
64
+ state,
65
+ stateAttrMap: AlertDialogDataAttrs,
66
+ close: () => this.#dialog?.close()
67
+ });
68
+ }
69
+ };
70
+
71
+ //#endregion
72
+ export { AlertDialogElement };
73
+ //# sourceMappingURL=alert-dialog-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-dialog-element.js","names":["#core","#provider","#titleId","#descriptionId","#dialog","#snapshot"],"sources":["../../../../src/ui/alert-dialog/alert-dialog-element.ts"],"sourcesContent":["import { AlertDialogCore, AlertDialogDataAttrs, type AlertDialogInput } from '@videojs/core';\nimport {\n type AlertDialogApi,\n applyElementProps,\n applyStateDataAttrs,\n createAlertDialog,\n createTransition,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { SnapshotController } from '@videojs/store/html';\n\nimport { MediaElement } from '../media-element';\nimport { alertDialogContext } from './context';\n\nlet idCounter = 0;\n\nexport class AlertDialogElement extends MediaElement {\n static readonly tagName = 'media-alert-dialog';\n\n static override properties = {\n open: { type: Boolean },\n } satisfies PropertyDeclarationMap<'open'>;\n\n open = false;\n\n readonly #core = new AlertDialogCore();\n readonly #provider = new ContextProvider(this, { context: alertDialogContext });\n readonly #titleId = `vjs-alert-dialog-title-${idCounter++}`;\n readonly #descriptionId = `vjs-alert-dialog-desc-${idCounter++}`;\n\n #dialog: AlertDialogApi | null = null;\n #snapshot: SnapshotController<AlertDialogInput> | null = null;\n\n constructor() {\n super();\n this.#core.setTitleId(this.#titleId);\n this.#core.setDescriptionId(this.#descriptionId);\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#dialog = createAlertDialog({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen } }));\n },\n });\n\n // Register self as the dialog element.\n this.#dialog.setElement(this);\n\n if (this.#snapshot) {\n this.#snapshot.track(this.#dialog.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#dialog.input);\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#dialog?.destroy();\n this.#dialog = null;\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n\n // Sync controlled open state.\n if (this.#dialog && changed.has('open')) {\n const { active: inputOpen } = this.#dialog.input.current;\n if (this.open !== inputOpen) {\n if (this.open) {\n this.#dialog.open();\n } else {\n this.#dialog.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#dialog) return;\n\n const input = this.#dialog.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, AlertDialogDataAttrs);\n\n this.#provider.setValue({\n state,\n stateAttrMap: AlertDialogDataAttrs,\n close: () => this.#dialog?.close(),\n });\n }\n}\n"],"mappings":";;;;;;;;AAeA,IAAI,YAAY;AAEhB,IAAa,qBAAb,cAAwC,aAAa;;iBACzB;;;oBAEG,EAC3B,MAAM,EAAE,MAAM,SAAS,EACxB;;CAID,CAASA,OAAQ,IAAI,iBAAiB;CACtC,CAASC,WAAY,IAAI,gBAAgB,MAAM,EAAE,SAAS,oBAAoB,CAAC;CAC/E,CAASC,UAAW,0BAA0B;CAC9C,CAASC,gBAAiB,yBAAyB;CAEnD,UAAiC;CACjC,YAAyD;CAEzD,cAAc;AACZ,SAAO;cAXF;AAYL,QAAKH,KAAM,WAAW,MAAKE,QAAS;AACpC,QAAKF,KAAM,iBAAiB,MAAKG,cAAe;;CAGlD,AAAS,oBAA0B;AACjC,QAAM,mBAAmB;AAEzB,QAAKC,SAAU,kBAAkB;GAC/B,YAAY,kBAAkB;GAC9B,eAAe,aAAsB;AACnC,SAAK,OAAO;AACZ,SAAK,cAAc,IAAI,YAAY,eAAe,EAAE,QAAQ,EAAE,MAAM,UAAU,EAAE,CAAC,CAAC;;GAErF,CAAC;AAGF,QAAKA,OAAQ,WAAW,KAAK;AAE7B,MAAI,MAAKC,SACP,OAAKA,SAAU,MAAM,MAAKD,OAAQ,MAAM;MAExC,OAAKC,WAAY,IAAI,mBAAmB,MAAM,MAAKD,OAAQ,MAAM;;CAIrE,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKA,QAAS,SAAS;AACvB,QAAKA,SAAU;;CAGjB,AAAmB,WAAW,SAA+B;AAC3D,QAAM,WAAW,QAAQ;AAGzB,MAAI,MAAKA,UAAW,QAAQ,IAAI,OAAO,EAAE;GACvC,MAAM,EAAE,QAAQ,cAAc,MAAKA,OAAQ,MAAM;AACjD,OAAI,KAAK,SAAS,UAChB,KAAI,KAAK,KACP,OAAKA,OAAQ,MAAM;OAEnB,OAAKA,OAAQ,OAAO;;;CAM5B,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;AACtB,MAAI,CAAC,MAAKA,OAAS;EAEnB,MAAM,QAAQ,MAAKA,OAAQ,MAAM;AACjC,QAAKJ,KAAM,SAAS,MAAM;EAC1B,MAAM,QAAQ,MAAKA,KAAM,UAAU;AAEnC,oBAAkB,MAAM,MAAKA,KAAM,SAAS,MAAM,CAAC;AACnD,sBAAoB,MAAM,OAAO,qBAAqB;AAEtD,QAAKC,SAAU,SAAS;GACtB;GACA,cAAc;GACd,aAAa,MAAKG,QAAS,OAAO;GACnC,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { alertDialogContext } from "./context.js";
2
+ import { ContextPartElement } from "../context-part-element.js";
3
+ import { ContextConsumer } from "@videojs/element/context";
4
+
5
+ //#region src/ui/alert-dialog/alert-dialog-title-element.ts
6
+ var AlertDialogTitleElement = class extends ContextPartElement {
7
+ constructor(..._args) {
8
+ super(..._args);
9
+ this.consumer = new ContextConsumer(this, {
10
+ context: alertDialogContext,
11
+ subscribe: true
12
+ });
13
+ }
14
+ static {
15
+ this.tagName = "media-alert-dialog-title";
16
+ }
17
+ update(changed) {
18
+ super.update(changed);
19
+ const titleId = this.consumer.value?.state.titleId;
20
+ if (titleId) this.id = titleId;
21
+ }
22
+ };
23
+
24
+ //#endregion
25
+ export { AlertDialogTitleElement };
26
+ //# sourceMappingURL=alert-dialog-title-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-dialog-title-element.js","names":[],"sources":["../../../../src/ui/alert-dialog/alert-dialog-title-element.ts"],"sourcesContent":["import type { AlertDialogState } from '@videojs/core';\nimport type { PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { ContextPartElement } from '../context-part-element';\nimport { alertDialogContext } from './context';\n\nexport class AlertDialogTitleElement extends ContextPartElement<AlertDialogState> {\n static readonly tagName = 'media-alert-dialog-title';\n\n protected readonly consumer = new ContextConsumer(this, { context: alertDialogContext, subscribe: true });\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n const titleId = this.consumer.value?.state.titleId;\n if (titleId) this.id = titleId;\n }\n}\n"],"mappings":";;;;;AAOA,IAAa,0BAAb,cAA6C,mBAAqC;;;kBAGlD,IAAI,gBAAgB,MAAM;GAAE,SAAS;GAAoB,WAAW;GAAM,CAAC;;;iBAF/E;;CAI1B,AAAmB,OAAO,SAA+B;AACvD,QAAM,OAAO,QAAQ;EACrB,MAAM,UAAU,KAAK,SAAS,OAAO,MAAM;AAC3C,MAAI,QAAS,MAAK,KAAK"}
@@ -0,0 +1,9 @@
1
+ import { createContext } from "@videojs/element/context";
2
+
3
+ //#region src/ui/alert-dialog/context.ts
4
+ const ALERT_DIALOG_CONTEXT_KEY = Symbol("@videojs/alert-dialog");
5
+ const alertDialogContext = createContext(ALERT_DIALOG_CONTEXT_KEY);
6
+
7
+ //#endregion
8
+ export { alertDialogContext };
9
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","names":[],"sources":["../../../../src/ui/alert-dialog/context.ts"],"sourcesContent":["import type { AlertDialogState, StateAttrMap } from '@videojs/core';\nimport { createContext } from '@videojs/element/context';\n\nexport interface AlertDialogContextValue {\n state: AlertDialogState;\n stateAttrMap: StateAttrMap<AlertDialogState>;\n close: () => void;\n}\n\nconst ALERT_DIALOG_CONTEXT_KEY = Symbol('@videojs/alert-dialog');\n\nexport const alertDialogContext = createContext<AlertDialogContextValue>(ALERT_DIALOG_CONTEXT_KEY);\n"],"mappings":";;;AASA,MAAM,2BAA2B,OAAO,wBAAwB;AAEhE,MAAa,qBAAqB,cAAuC,yBAAyB"}
@@ -0,0 +1,25 @@
1
+ import { playerContext } from "../../player/context.js";
2
+ import { PlayerController } from "../../player/player-controller.js";
3
+ import { MediaButtonElement } from "../media-button-element.js";
4
+ import { selectTextTrack } from "@videojs/core/dom";
5
+ import { CaptionsButtonCore, CaptionsButtonDataAttrs } from "@videojs/core";
6
+
7
+ //#region src/ui/captions-button/captions-button-element.ts
8
+ var CaptionsButtonElement = class extends MediaButtonElement {
9
+ constructor(..._args) {
10
+ super(..._args);
11
+ this.core = new CaptionsButtonCore();
12
+ this.stateAttrMap = CaptionsButtonDataAttrs;
13
+ this.mediaState = new PlayerController(this, playerContext, selectTextTrack);
14
+ }
15
+ static {
16
+ this.tagName = "media-captions-button";
17
+ }
18
+ activate(state) {
19
+ this.core.toggle(state);
20
+ }
21
+ };
22
+
23
+ //#endregion
24
+ export { CaptionsButtonElement };
25
+ //# sourceMappingURL=captions-button-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"captions-button-element.js","names":[],"sources":["../../../../src/ui/captions-button/captions-button-element.ts"],"sourcesContent":["import { CaptionsButtonCore, CaptionsButtonDataAttrs, type MediaTextTrackState } from '@videojs/core';\nimport { selectTextTrack } from '@videojs/core/dom';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaButtonElement } from '../media-button-element';\n\nexport class CaptionsButtonElement extends MediaButtonElement<CaptionsButtonCore> {\n static readonly tagName = 'media-captions-button';\n\n protected readonly core = new CaptionsButtonCore();\n protected readonly stateAttrMap = CaptionsButtonDataAttrs;\n protected readonly mediaState = new PlayerController(this, playerContext, selectTextTrack);\n\n protected activate(state: MediaTextTrackState): void {\n this.core.toggle(state);\n }\n}\n"],"mappings":";;;;;;;AAOA,IAAa,wBAAb,cAA2C,mBAAuC;;;cAGtD,IAAI,oBAAoB;sBAChB;oBACF,IAAI,iBAAiB,MAAM,eAAe,gBAAgB;;;iBAJhE;;CAM1B,AAAU,SAAS,OAAkC;AACnD,OAAK,KAAK,OAAO,MAAM"}
@@ -1,5 +1,5 @@
1
- import { controlsContext } from "./context.js";
2
1
  import { ContextPartElement } from "../context-part-element.js";
2
+ import { controlsContext } from "./context.js";
3
3
  import { ContextConsumer } from "@videojs/element/context";
4
4
 
5
5
  //#region src/ui/controls/controls-group-element.ts
@@ -1,7 +1,8 @@
1
- import { ReactiveElement } from "@videojs/element";
1
+ import { DestroyMixin, ReactiveElement } from "@videojs/element";
2
2
 
3
3
  //#region src/ui/media-element.ts
4
- var MediaElement = class extends ReactiveElement {};
4
+ /** Base class for interactive media UI elements. */
5
+ var MediaElement = class extends DestroyMixin(ReactiveElement) {};
5
6
 
6
7
  //#endregion
7
8
  export { MediaElement };
@@ -1 +1 @@
1
- {"version":3,"file":"media-element.js","names":[],"sources":["../../../src/ui/media-element.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\nexport class MediaElement extends ReactiveElement {}\n\nexport interface MediaElementConstructor extends Constructor<MediaElement> {}\n"],"mappings":";;;AAGA,IAAa,eAAb,cAAkC,gBAAgB"}
1
+ {"version":3,"file":"media-element.js","names":[],"sources":["../../../src/ui/media-element.ts"],"sourcesContent":["import { DestroyMixin, ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\n/** Base class for interactive media UI elements. */\nexport class MediaElement extends DestroyMixin(ReactiveElement) {}\n\nexport interface MediaElementConstructor extends Constructor<MediaElement> {}\n"],"mappings":";;;;AAIA,IAAa,eAAb,cAAkC,aAAa,gBAAgB,CAAC"}
@@ -2,7 +2,7 @@ import { MediaElement } from "../media-element.js";
2
2
  import { applyElementProps, applyStateDataAttrs, createPopover, createTransition, getAnchorNameStyle, getAnchorPositionStyle, resolveOffsets } from "@videojs/core/dom";
3
3
  import { SnapshotController } from "@videojs/store/html";
4
4
  import { PopoverCore, PopoverDataAttrs } from "@videojs/core";
5
- import { applyStyles, supportsAnchorPositioning } from "@videojs/utils/dom";
5
+ import { applyStyles, supportsAnchorPositioning, tryHidePopover, tryShowPopover } from "@videojs/utils/dom";
6
6
 
7
7
  //#region src/ui/popover/popover-element.ts
8
8
  var PopoverElement = class extends MediaElement {
@@ -59,6 +59,7 @@ var PopoverElement = class extends MediaElement {
59
59
  #currentTrigger = null;
60
60
  connectedCallback() {
61
61
  super.connectedCallback();
62
+ if (this.destroyed) return;
62
63
  this.#disconnect = new AbortController();
63
64
  this.#popover = createPopover({
64
65
  transition: createTransition(),
@@ -86,12 +87,14 @@ var PopoverElement = class extends MediaElement {
86
87
  }
87
88
  disconnectedCallback() {
88
89
  super.disconnectedCallback();
89
- this.#cleanupTrigger();
90
- this.#popover?.destroy();
91
- this.#popover = null;
92
90
  this.#disconnect?.abort();
93
91
  this.#disconnect = null;
94
92
  }
93
+ destroyCallback() {
94
+ this.#cleanupTrigger();
95
+ this.#popover?.destroy();
96
+ super.destroyCallback();
97
+ }
95
98
  willUpdate(changed) {
96
99
  super.willUpdate(changed);
97
100
  this.#core.setProps(this);
@@ -111,6 +114,8 @@ var PopoverElement = class extends MediaElement {
111
114
  const state = this.#core.getState();
112
115
  applyElementProps(this, this.#core.getPopupAttrs(state));
113
116
  applyStateDataAttrs(this, state, PopoverDataAttrs);
117
+ if (state.open) tryShowPopover(this);
118
+ else tryHidePopover(this);
114
119
  if (this.#currentTrigger) {
115
120
  applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));
116
121
  applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));
@@ -1 +1 @@
1
- {"version":3,"file":"popover-element.js","names":["#core","#disconnect","#popover","#snapshot","#cleanupTrigger","#findTrigger","#syncTrigger","#currentTrigger","#triggerAbort"],"sources":["../../../../src/ui/popover/popover-element.ts"],"sourcesContent":["import { PopoverCore, PopoverDataAttrs, type PopoverInput, type PopoverProps } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createPopover,\n createTransition,\n getAnchorNameStyle,\n getAnchorPositionStyle,\n type PopoverApi,\n type PopoverChangeDetails,\n resolveOffsets,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { SnapshotController } from '@videojs/store/html';\nimport { applyStyles, supportsAnchorPositioning } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\n\nexport class PopoverElement extends MediaElement {\n static readonly tagName = 'media-popover';\n\n static override properties = {\n open: { type: Boolean },\n defaultOpen: { type: Boolean, attribute: 'default-open' },\n side: { type: String },\n align: { type: String },\n modal: { type: Boolean },\n closeOnEscape: { type: Boolean, attribute: 'close-on-escape' },\n closeOnOutsideClick: { type: Boolean, attribute: 'close-on-outside-click' },\n openOnHover: { type: Boolean, attribute: 'open-on-hover' },\n delay: { type: Number },\n closeDelay: { type: Number, attribute: 'close-delay' },\n } satisfies PropertyDeclarationMap<keyof PopoverCore.Props>;\n\n open = PopoverCore.defaultProps.open;\n defaultOpen = PopoverCore.defaultProps.defaultOpen;\n side = PopoverCore.defaultProps.side;\n align = PopoverCore.defaultProps.align;\n modal: PopoverProps['modal'] = PopoverCore.defaultProps.modal;\n closeOnEscape = PopoverCore.defaultProps.closeOnEscape;\n closeOnOutsideClick = PopoverCore.defaultProps.closeOnOutsideClick;\n openOnHover = PopoverCore.defaultProps.openOnHover;\n delay = PopoverCore.defaultProps.delay;\n closeDelay = PopoverCore.defaultProps.closeDelay;\n\n readonly #core = new PopoverCore();\n #popover: PopoverApi | null = null;\n #snapshot: SnapshotController<PopoverInput> | null = null;\n\n // Cleanup controllers\n #disconnect: AbortController | null = null;\n #triggerAbort: AbortController | null = null;\n #currentTrigger: HTMLElement | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.#disconnect = new AbortController();\n\n this.#popover = createPopover({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean, details: PopoverChangeDetails) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen, ...details } }));\n },\n closeOnEscape: () => this.closeOnEscape,\n closeOnOutsideClick: () => this.closeOnOutsideClick,\n openOnHover: () => this.openOnHover,\n delay: () => this.delay,\n closeDelay: () => this.closeDelay,\n });\n\n // Register self as the popup element — the element IS the popup.\n this.#popover.setPopupElement(this);\n\n // Apply popup event handlers (pointerenter/leave, focusout) to self.\n applyElementProps(this, this.#popover.popupProps, { signal: this.#disconnect.signal });\n\n // Subscribe to interaction state for reactive updates.\n // Reuse the controller across connect/disconnect cycles to avoid\n // leaking stale controllers in the host's controller set.\n if (this.#snapshot) {\n this.#snapshot.track(this.#popover.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#popover.input);\n }\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n\n // Uncontrolled mode: open if `defaultOpen` is set. Controlled `open`\n // is already synced by `willUpdate` on the first render cycle.\n if (this.defaultOpen && !this.open) {\n this.#popover?.open();\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#cleanupTrigger();\n this.#popover?.destroy();\n this.#popover = null;\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n this.#core.setProps(this);\n\n // Sync controlled open state\n if (this.#popover && changed.has('open')) {\n const { active: interactionOpen } = this.#popover.input.current;\n if (this.open !== interactionOpen) {\n if (this.open) {\n this.#popover.open();\n } else {\n this.#popover.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#popover) return;\n\n // Discover trigger via commandfor linkage.\n const triggerEl = this.#findTrigger();\n this.#syncTrigger(triggerEl);\n\n // Derive state from core + input.\n const input = this.#popover.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n // Apply popup ARIA and data attributes to self.\n applyElementProps(this, this.#core.getPopupAttrs(state));\n applyStateDataAttrs(this, state, PopoverDataAttrs);\n\n // Apply trigger ARIA and anchor-name to the discovered trigger.\n if (this.#currentTrigger) {\n applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));\n applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));\n }\n\n // Skip positioning when closed — no rects to measure.\n if (!state.open) return;\n\n // Apply positioning styles to self.\n const posOpts = { side: state.side, align: state.align };\n\n if (supportsAnchorPositioning()) {\n // Native CSS Anchor Positioning — no JS rect measurements needed.\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts));\n } else {\n // JS fallback: measure rects and resolve CSS var offsets.\n const triggerRect = this.#currentTrigger?.getBoundingClientRect();\n const selfRect = this.getBoundingClientRect();\n const boundaryRect = document.documentElement.getBoundingClientRect();\n const offsets = resolveOffsets(this);\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts, triggerRect, selfRect, boundaryRect, offsets));\n }\n }\n\n // --- Trigger discovery ---\n\n #findTrigger(): HTMLElement | null {\n if (!this.id) return null;\n const root = this.getRootNode() as Document | ShadowRoot;\n return root.querySelector<HTMLElement>(`[commandfor=\"${this.id}\"]`);\n }\n\n #syncTrigger(triggerEl: HTMLElement | null): void {\n if (triggerEl === this.#currentTrigger) return;\n\n this.#cleanupTrigger();\n this.#currentTrigger = triggerEl;\n this.#popover?.setTriggerElement(triggerEl);\n\n if (triggerEl && this.#popover) {\n this.#triggerAbort = new AbortController();\n applyElementProps(triggerEl, this.#popover.triggerProps, { signal: this.#triggerAbort.signal });\n }\n }\n\n #cleanupTrigger(): void {\n if (this.#currentTrigger) {\n // Remove ARIA attributes and anchor-name style from the old trigger.\n applyElementProps(this.#currentTrigger, {\n 'aria-expanded': undefined,\n 'aria-haspopup': undefined,\n 'aria-controls': undefined,\n });\n this.#currentTrigger.style.removeProperty('anchor-name');\n }\n\n this.#triggerAbort?.abort();\n this.#triggerAbort = null;\n this.#currentTrigger = null;\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"popover-element.js","names":["#core","#disconnect","#popover","#snapshot","#cleanupTrigger","#findTrigger","#syncTrigger","#currentTrigger","#triggerAbort"],"sources":["../../../../src/ui/popover/popover-element.ts"],"sourcesContent":["import { PopoverCore, PopoverDataAttrs, type PopoverInput, type PopoverProps } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createPopover,\n createTransition,\n getAnchorNameStyle,\n getAnchorPositionStyle,\n type PopoverApi,\n type PopoverChangeDetails,\n resolveOffsets,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { SnapshotController } from '@videojs/store/html';\nimport { applyStyles, supportsAnchorPositioning, tryHidePopover, tryShowPopover } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\n\nexport class PopoverElement extends MediaElement {\n static readonly tagName = 'media-popover';\n\n static override properties = {\n open: { type: Boolean },\n defaultOpen: { type: Boolean, attribute: 'default-open' },\n side: { type: String },\n align: { type: String },\n modal: { type: Boolean },\n closeOnEscape: { type: Boolean, attribute: 'close-on-escape' },\n closeOnOutsideClick: { type: Boolean, attribute: 'close-on-outside-click' },\n openOnHover: { type: Boolean, attribute: 'open-on-hover' },\n delay: { type: Number },\n closeDelay: { type: Number, attribute: 'close-delay' },\n } satisfies PropertyDeclarationMap<keyof PopoverCore.Props>;\n\n open = PopoverCore.defaultProps.open;\n defaultOpen = PopoverCore.defaultProps.defaultOpen;\n side = PopoverCore.defaultProps.side;\n align = PopoverCore.defaultProps.align;\n modal: PopoverProps['modal'] = PopoverCore.defaultProps.modal;\n closeOnEscape = PopoverCore.defaultProps.closeOnEscape;\n closeOnOutsideClick = PopoverCore.defaultProps.closeOnOutsideClick;\n openOnHover = PopoverCore.defaultProps.openOnHover;\n delay = PopoverCore.defaultProps.delay;\n closeDelay = PopoverCore.defaultProps.closeDelay;\n\n readonly #core = new PopoverCore();\n #popover: PopoverApi | null = null;\n #snapshot: SnapshotController<PopoverInput> | null = null;\n\n // Cleanup controllers\n #disconnect: AbortController | null = null;\n #triggerAbort: AbortController | null = null;\n #currentTrigger: HTMLElement | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#disconnect = new AbortController();\n\n this.#popover = createPopover({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean, details: PopoverChangeDetails) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen, ...details } }));\n },\n closeOnEscape: () => this.closeOnEscape,\n closeOnOutsideClick: () => this.closeOnOutsideClick,\n openOnHover: () => this.openOnHover,\n delay: () => this.delay,\n closeDelay: () => this.closeDelay,\n });\n\n // Register self as the popup element — the element IS the popup.\n this.#popover.setPopupElement(this);\n\n // Apply popup event handlers (pointerenter/leave, focusout) to self.\n applyElementProps(this, this.#popover.popupProps, { signal: this.#disconnect.signal });\n\n // Subscribe to interaction state for reactive updates.\n // Reuse the controller across connect/disconnect cycles to avoid\n // leaking stale controllers in the host's controller set.\n if (this.#snapshot) {\n this.#snapshot.track(this.#popover.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#popover.input);\n }\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n\n // Uncontrolled mode: open if `defaultOpen` is set. Controlled `open`\n // is already synced by `willUpdate` on the first render cycle.\n if (this.defaultOpen && !this.open) {\n this.#popover?.open();\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n override destroyCallback(): void {\n this.#cleanupTrigger();\n this.#popover?.destroy();\n super.destroyCallback();\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n this.#core.setProps(this);\n\n // Sync controlled open state\n if (this.#popover && changed.has('open')) {\n const { active: interactionOpen } = this.#popover.input.current;\n if (this.open !== interactionOpen) {\n if (this.open) {\n this.#popover.open();\n } else {\n this.#popover.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#popover) return;\n\n // Discover trigger via commandfor linkage.\n const triggerEl = this.#findTrigger();\n this.#syncTrigger(triggerEl);\n\n // Derive state from core + input.\n const input = this.#popover.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n // Apply popup ARIA and data attributes to self.\n applyElementProps(this, this.#core.getPopupAttrs(state));\n applyStateDataAttrs(this, state, PopoverDataAttrs);\n\n // Show/hide via Popover API AFTER data attributes are applied so\n // `data-starting-style` is present before the first visible frame.\n if (state.open) {\n tryShowPopover(this);\n } else {\n tryHidePopover(this);\n }\n\n // Apply trigger ARIA and anchor-name to the discovered trigger.\n if (this.#currentTrigger) {\n applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));\n applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));\n }\n\n // Skip positioning when closed — no rects to measure.\n if (!state.open) return;\n\n // Apply positioning styles to self.\n const posOpts = { side: state.side, align: state.align };\n\n if (supportsAnchorPositioning()) {\n // Native CSS Anchor Positioning — no JS rect measurements needed.\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts));\n } else {\n // JS fallback: measure rects and resolve CSS var offsets.\n const triggerRect = this.#currentTrigger?.getBoundingClientRect();\n const selfRect = this.getBoundingClientRect();\n const boundaryRect = document.documentElement.getBoundingClientRect();\n const offsets = resolveOffsets(this);\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts, triggerRect, selfRect, boundaryRect, offsets));\n }\n }\n\n // --- Trigger discovery ---\n\n #findTrigger(): HTMLElement | null {\n if (!this.id) return null;\n const root = this.getRootNode() as Document | ShadowRoot;\n return root.querySelector<HTMLElement>(`[commandfor=\"${this.id}\"]`);\n }\n\n #syncTrigger(triggerEl: HTMLElement | null): void {\n if (triggerEl === this.#currentTrigger) return;\n\n this.#cleanupTrigger();\n this.#currentTrigger = triggerEl;\n this.#popover?.setTriggerElement(triggerEl);\n\n if (triggerEl && this.#popover) {\n this.#triggerAbort = new AbortController();\n applyElementProps(triggerEl, this.#popover.triggerProps, { signal: this.#triggerAbort.signal });\n }\n }\n\n #cleanupTrigger(): void {\n if (this.#currentTrigger) {\n // Remove ARIA attributes and anchor-name style from the old trigger.\n applyElementProps(this.#currentTrigger, {\n 'aria-expanded': undefined,\n 'aria-haspopup': undefined,\n 'aria-controls': undefined,\n });\n this.#currentTrigger.style.removeProperty('anchor-name');\n }\n\n this.#triggerAbort?.abort();\n this.#triggerAbort = null;\n this.#currentTrigger = null;\n }\n}\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { MediaElement } from "../media-element.js";
2
2
  import { sliderContext } from "./context.js";
3
- import { applyStateDataAttrs, createSlider, getSliderCSSVars } from "@videojs/core/dom";
3
+ import { applyElementProps, applyStateDataAttrs, createSlider, getSliderCSSVars } from "@videojs/core/dom";
4
4
  import { ContextProvider } from "@videojs/element/context";
5
5
  import { SliderCore, SliderDataAttrs } from "@videojs/core";
6
6
  import { applyStyles, isRTL } from "@videojs/utils/dom";
@@ -47,6 +47,7 @@ var SliderElement = class extends MediaElement {
47
47
  #disconnect = null;
48
48
  connectedCallback() {
49
49
  super.connectedCallback();
50
+ if (this.destroyed) return;
50
51
  this.#disconnect = new AbortController();
51
52
  const signal = this.#disconnect.signal;
52
53
  this.#slider = createSlider({
@@ -77,19 +78,23 @@ var SliderElement = class extends MediaElement {
77
78
  },
78
79
  onDragEnd: () => {
79
80
  this.dispatchEvent(new CustomEvent("drag-end", { bubbles: true }));
80
- }
81
+ },
82
+ adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),
83
+ onResize: () => this.requestUpdate()
81
84
  });
85
+ applyElementProps(this, this.#slider.rootProps, { signal });
86
+ applyStyles(this, this.#slider.rootStyle);
82
87
  this.#slider.input.subscribe(() => this.requestUpdate(), { signal });
83
- this.style.touchAction = "none";
84
- this.style.userSelect = "none";
85
88
  }
86
89
  disconnectedCallback() {
87
90
  super.disconnectedCallback();
88
- this.#slider?.destroy();
89
- this.#slider = null;
90
91
  this.#disconnect?.abort();
91
92
  this.#disconnect = null;
92
93
  }
94
+ destroyCallback() {
95
+ this.#slider?.destroy();
96
+ super.destroyCallback();
97
+ }
93
98
  willUpdate(_changed) {
94
99
  super.willUpdate(_changed);
95
100
  this.#core.setProps(this);
@@ -99,7 +104,7 @@ var SliderElement = class extends MediaElement {
99
104
  if (!this.#slider) return;
100
105
  this.#core.setInput(this.#slider.input.current);
101
106
  const state = this.#core.getSliderState(this.value);
102
- const cssVars = getSliderCSSVars(state);
107
+ const cssVars = getSliderCSSVars(this.#slider.adjustForAlignment(state));
103
108
  applyStyles(this, cssVars);
104
109
  applyStateDataAttrs(this, state, SliderDataAttrs);
105
110
  this.#provider.setValue({
@@ -1 +1 @@
1
- {"version":3,"file":"slider-element.js","names":["#core","#provider","#disconnect","#slider"],"sources":["../../../../src/ui/slider/slider-element.ts"],"sourcesContent":["import { SliderCore, SliderDataAttrs } from '@videojs/core';\nimport { applyStateDataAttrs, createSlider, getSliderCSSVars, type SliderApi } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from './context';\n\nexport class SliderElement extends MediaElement {\n static readonly tagName = 'media-slider';\n\n static override properties = {\n label: { type: String },\n value: { type: Number },\n min: { type: Number },\n max: { type: Number },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<keyof SliderCore.Props>;\n\n label = SliderCore.defaultProps.label;\n value = SliderCore.defaultProps.value;\n min = SliderCore.defaultProps.min;\n max = SliderCore.defaultProps.max;\n step = SliderCore.defaultProps.step;\n largeStep = SliderCore.defaultProps.largeStep;\n orientation = SliderCore.defaultProps.orientation;\n disabled = SliderCore.defaultProps.disabled;\n thumbAlignment = SliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new SliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled,\n getPercent: () => this.#core.percentFromValue(this.value),\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueChange: (percent) => {\n this.value = this.#core.valueFromPercent(percent);\n this.dispatchEvent(new CustomEvent('value-change', { detail: { value: this.value }, bubbles: true }));\n },\n onValueCommit: (percent) => {\n this.value = this.#core.valueFromPercent(percent);\n this.dispatchEvent(new CustomEvent('value-commit', { detail: { value: this.value }, bubbles: true }));\n },\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n });\n\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n\n // Prevent default touch gestures and text selection during interaction.\n this.style.touchAction = 'none';\n this.style.userSelect = 'none';\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#slider?.destroy();\n this.#slider = null;\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n protected override willUpdate(_changed: PropertyValues): void {\n super.willUpdate(_changed);\n this.#core.setProps(this);\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#slider) return;\n\n this.#core.setInput(this.#slider.input.current);\n const state = this.#core.getSliderState(this.value);\n const cssVars = getSliderCSSVars(state);\n\n applyStyles(this, cssVars);\n\n // Apply state data attributes to the root element.\n applyStateDataAttrs(this, state, SliderDataAttrs);\n\n // Provide context to child elements (thumb, value, track, etc.).\n this.#provider.setValue({\n state,\n stateAttrMap: SliderDataAttrs,\n pointerValue: this.#core.valueFromPercent(state.pointerPercent),\n thumbAttrs: this.#core.getAttrs(state),\n thumbProps: this.#slider.thumbProps,\n });\n }\n}\n"],"mappings":";;;;;;;;AASA,IAAa,gBAAb,cAAmC,aAAa;;;eAetC,WAAW,aAAa;eACxB,WAAW,aAAa;aAC1B,WAAW,aAAa;aACxB,WAAW,aAAa;cACvB,WAAW,aAAa;mBACnB,WAAW,aAAa;qBACtB,WAAW,aAAa;kBAC3B,WAAW,aAAa;wBAClB,WAAW,aAAa;;;iBAtBf;;;oBAEG;GAC3B,OAAO,EAAE,MAAM,QAAQ;GACvB,OAAO,EAAE,MAAM,QAAQ;GACvB,KAAK,EAAE,MAAM,QAAQ;GACrB,KAAK,EAAE,MAAM,QAAQ;GACrB,MAAM,EAAE,MAAM,QAAQ;GACtB,WAAW;IAAE,MAAM;IAAQ,WAAW;IAAc;GACpD,aAAa,EAAE,MAAM,QAAQ;GAC7B,UAAU,EAAE,MAAM,SAAS;GAC3B,gBAAgB;IAAE,MAAM;IAAQ,WAAW;IAAmB;GAC/D;;CAYD,CAASA,OAAQ,IAAI,YAAY;CACjC,CAASC,WAAY,IAAI,gBAAgB,MAAM,EAAE,SAAS,eAAe,CAAC;CAE1E,UAA4B;CAC5B,cAAsC;CAEtC,AAAS,oBAA0B;AACjC,QAAM,mBAAmB;AAEzB,QAAKC,aAAc,IAAI,iBAAiB;EACxC,MAAM,SAAS,MAAKA,WAAY;AAEhC,QAAKC,SAAU,aAAa;GAC1B,kBAAkB;GAClB,uBAAuB,KAAK,cAA2B,qBAAqB;GAC5E,sBAAsB,KAAK;GAC3B,aAAa,MAAM,KAAK;GACxB,kBAAkB,KAAK;GACvB,kBAAkB,MAAKH,KAAM,iBAAiB,KAAK,MAAM;GACzD,sBAAsB,MAAKA,KAAM,gBAAgB;GACjD,2BAA2B,MAAKA,KAAM,qBAAqB;GAC3D,gBAAgB,YAAY;AAC1B,SAAK,QAAQ,MAAKA,KAAM,iBAAiB,QAAQ;AACjD,SAAK,cAAc,IAAI,YAAY,gBAAgB;KAAE,QAAQ,EAAE,OAAO,KAAK,OAAO;KAAE,SAAS;KAAM,CAAC,CAAC;;GAEvG,gBAAgB,YAAY;AAC1B,SAAK,QAAQ,MAAKA,KAAM,iBAAiB,QAAQ;AACjD,SAAK,cAAc,IAAI,YAAY,gBAAgB;KAAE,QAAQ,EAAE,OAAO,KAAK,OAAO;KAAE,SAAS;KAAM,CAAC,CAAC;;GAEvG,mBAAmB;AACjB,SAAK,cAAc,IAAI,YAAY,cAAc,EAAE,SAAS,MAAM,CAAC,CAAC;;GAEtE,iBAAiB;AACf,SAAK,cAAc,IAAI,YAAY,YAAY,EAAE,SAAS,MAAM,CAAC,CAAC;;GAErE,CAAC;AAEF,QAAKG,OAAQ,MAAM,gBAAgB,KAAK,eAAe,EAAE,EAAE,QAAQ,CAAC;AAGpE,OAAK,MAAM,cAAc;AACzB,OAAK,MAAM,aAAa;;CAG1B,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKA,QAAS,SAAS;AACvB,QAAKA,SAAU;AACf,QAAKD,YAAa,OAAO;AACzB,QAAKA,aAAc;;CAGrB,AAAmB,WAAW,UAAgC;AAC5D,QAAM,WAAW,SAAS;AAC1B,QAAKF,KAAM,SAAS,KAAK;;CAG3B,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;AACtB,MAAI,CAAC,MAAKG,OAAS;AAEnB,QAAKH,KAAM,SAAS,MAAKG,OAAQ,MAAM,QAAQ;EAC/C,MAAM,QAAQ,MAAKH,KAAM,eAAe,KAAK,MAAM;EACnD,MAAM,UAAU,iBAAiB,MAAM;AAEvC,cAAY,MAAM,QAAQ;AAG1B,sBAAoB,MAAM,OAAO,gBAAgB;AAGjD,QAAKC,SAAU,SAAS;GACtB;GACA,cAAc;GACd,cAAc,MAAKD,KAAM,iBAAiB,MAAM,eAAe;GAC/D,YAAY,MAAKA,KAAM,SAAS,MAAM;GACtC,YAAY,MAAKG,OAAQ;GAC1B,CAAC"}
1
+ {"version":3,"file":"slider-element.js","names":["#core","#provider","#disconnect","#slider"],"sources":["../../../../src/ui/slider/slider-element.ts"],"sourcesContent":["import { SliderCore, SliderDataAttrs } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createSlider,\n getSliderCSSVars,\n type SliderApi,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from './context';\n\nexport class SliderElement extends MediaElement {\n static readonly tagName = 'media-slider';\n\n static override properties = {\n label: { type: String },\n value: { type: Number },\n min: { type: Number },\n max: { type: Number },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<keyof SliderCore.Props>;\n\n label = SliderCore.defaultProps.label;\n value = SliderCore.defaultProps.value;\n min = SliderCore.defaultProps.min;\n max = SliderCore.defaultProps.max;\n step = SliderCore.defaultProps.step;\n largeStep = SliderCore.defaultProps.largeStep;\n orientation = SliderCore.defaultProps.orientation;\n disabled = SliderCore.defaultProps.disabled;\n thumbAlignment = SliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new SliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled,\n getPercent: () => this.#core.percentFromValue(this.value),\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueChange: (percent) => {\n this.value = this.#core.valueFromPercent(percent);\n this.dispatchEvent(new CustomEvent('value-change', { detail: { value: this.value }, bubbles: true }));\n },\n onValueCommit: (percent) => {\n this.value = this.#core.valueFromPercent(percent);\n this.dispatchEvent(new CustomEvent('value-commit', { detail: { value: this.value }, bubbles: true }));\n },\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),\n onResize: () => this.requestUpdate(),\n });\n\n applyElementProps(this, this.#slider.rootProps, { signal });\n applyStyles(this, this.#slider.rootStyle);\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n override destroyCallback(): void {\n this.#slider?.destroy();\n super.destroyCallback();\n }\n\n protected override willUpdate(_changed: PropertyValues): void {\n super.willUpdate(_changed);\n this.#core.setProps(this);\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#slider) return;\n\n this.#core.setInput(this.#slider.input.current);\n const state = this.#core.getSliderState(this.value);\n\n const cssVars = getSliderCSSVars(this.#slider.adjustForAlignment(state));\n\n applyStyles(this, cssVars);\n\n // Apply state data attributes to the root element.\n applyStateDataAttrs(this, state, SliderDataAttrs);\n\n // Provide context to child elements (thumb, value, track, etc.).\n this.#provider.setValue({\n state,\n stateAttrMap: SliderDataAttrs,\n pointerValue: this.#core.valueFromPercent(state.pointerPercent),\n thumbAttrs: this.#core.getAttrs(state),\n thumbProps: this.#slider.thumbProps,\n });\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,51 @@
1
+ import { MediaElement } from "../media-element.js";
2
+ import { sliderContext } from "./context.js";
3
+ import { applyStateDataAttrs, getSliderPreviewStyle } from "@videojs/core/dom";
4
+ import { ContextConsumer } from "@videojs/element/context";
5
+ import { applyStyles } from "@videojs/utils/dom";
6
+
7
+ //#region src/ui/slider/slider-preview-element.ts
8
+ var SliderPreviewElement = class extends MediaElement {
9
+ constructor(..._args) {
10
+ super(..._args);
11
+ this.overflow = "clamp";
12
+ }
13
+ static {
14
+ this.tagName = "media-slider-preview";
15
+ }
16
+ static {
17
+ this.properties = { overflow: { type: String } };
18
+ }
19
+ #ctx = new ContextConsumer(this, {
20
+ context: sliderContext,
21
+ subscribe: true
22
+ });
23
+ #resizeObserver = null;
24
+ #width = 0;
25
+ connectedCallback() {
26
+ super.connectedCallback();
27
+ this.#resizeObserver = new ResizeObserver(([entry]) => {
28
+ this.#width = entry.contentRect.width;
29
+ this.#applyPosition();
30
+ });
31
+ this.#resizeObserver.observe(this);
32
+ }
33
+ disconnectedCallback() {
34
+ super.disconnectedCallback();
35
+ this.#resizeObserver?.disconnect();
36
+ this.#resizeObserver = null;
37
+ }
38
+ #applyPosition() {
39
+ applyStyles(this, getSliderPreviewStyle(this.#width, this.overflow));
40
+ }
41
+ update(_changed) {
42
+ super.update(_changed);
43
+ const ctx = this.#ctx.value;
44
+ if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);
45
+ this.#applyPosition();
46
+ }
47
+ };
48
+
49
+ //#endregion
50
+ export { SliderPreviewElement };
51
+ //# sourceMappingURL=slider-preview-element.js.map