@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
@@ -0,0 +1,19 @@
1
+ import { PlayerController } from "../../player/player-controller.js";
2
+ import { MediaButtonElement } from "../media-button-element.js";
3
+ import * as _videojs_core_dom0 from "@videojs/core/dom";
4
+ import { CaptionsButtonCore, MediaTextTrackState } from "@videojs/core";
5
+
6
+ //#region src/ui/captions-button/captions-button-element.d.ts
7
+ declare class CaptionsButtonElement extends MediaButtonElement<CaptionsButtonCore> {
8
+ static readonly tagName = "media-captions-button";
9
+ protected readonly core: CaptionsButtonCore;
10
+ protected readonly stateAttrMap: {
11
+ readonly subtitlesShowing: "data-active";
12
+ readonly availability: "data-availability";
13
+ };
14
+ protected readonly mediaState: PlayerController<_videojs_core_dom0.AnyPlayerStore, MediaTextTrackState | undefined>;
15
+ protected activate(state: MediaTextTrackState): void;
16
+ }
17
+ //#endregion
18
+ export { CaptionsButtonElement };
19
+ //# sourceMappingURL=captions-button-element.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"captions-button-element.d.ts","names":[],"sources":["../../../../src/ui/captions-button/captions-button-element.ts"],"mappings":";;;;;;cAOa,qBAAA,SAA8B,kBAAA,CAAmB,kBAAA;EAAA,gBAC5C,OAAA;EAAA,mBAEG,IAAA,EAAI,kBAAA;EAAA,mBACJ,YAAA;IAAA;;;qBACA,UAAA,EAAU,gBAAA,CAFN,kBAAA,CAEM,cAAA,EAAA,mBAAA;EAAA,UAEnB,QAAA,CAAS,KAAA,EAAO,mBAAA;AAAA"}
@@ -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 { ControlsContextValue } from "./context.js";
2
1
  import { ContextPartElement } from "../context-part-element.js";
2
+ import { ControlsContextValue } from "./context.js";
3
3
  import { ContextConsumer } from "@videojs/element/context";
4
4
  import { ControlsState } from "@videojs/core";
5
5
 
@@ -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,8 +1,11 @@
1
+ import * as _videojs_element0 from "@videojs/element";
1
2
  import { ReactiveElement } from "@videojs/element";
2
3
  import { Constructor } from "@videojs/utils/types";
3
4
 
4
5
  //#region src/ui/media-element.d.ts
5
- declare class MediaElement extends ReactiveElement {}
6
+ declare const MediaElement_base: typeof ReactiveElement & (new (...args: any[]) => _videojs_element0.Destroyable);
7
+ /** Base class for interactive media UI elements. */
8
+ declare class MediaElement extends MediaElement_base {}
6
9
  interface MediaElementConstructor extends Constructor<MediaElement> {}
7
10
  //#endregion
8
11
  export { MediaElement, MediaElementConstructor };
@@ -1 +1 @@
1
- {"version":3,"file":"media-element.d.ts","names":[],"sources":["../../../src/ui/media-element.ts"],"mappings":";;;;cAGa,YAAA,SAAqB,eAAA;AAAA,UAEjB,uBAAA,SAAgC,WAAA,CAAY,YAAA"}
1
+ {"version":3,"file":"media-element.d.ts","names":[],"sources":["../../../src/ui/media-element.ts"],"mappings":";;;;;cACwD,iBAAA;;cAG3C,YAAA,SAAqB,iBAAA;AAAA,UAEjB,uBAAA,SAAgC,WAAA,CAAY,YAAA"}
@@ -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"}
@@ -57,6 +57,7 @@ declare class PopoverElement extends MediaElement {
57
57
  connectedCallback(): void;
58
58
  protected firstUpdated(changed: PropertyValues): void;
59
59
  disconnectedCallback(): void;
60
+ destroyCallback(): void;
60
61
  protected willUpdate(changed: PropertyValues): void;
61
62
  protected update(_changed: PropertyValues): void;
62
63
  }
@@ -1 +1 @@
1
- {"version":3,"file":"popover-element.d.ts","names":[],"sources":["../../../../src/ui/popover/popover-element.ts"],"mappings":";;;;;;cAkBa,cAAA,SAAuB,YAAA;EAAA;kBAClB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAahB,IAAA;EACA,WAAA;EACA,IAAA,iBAAI,WAAA;EACJ,KAAA,EADI,cAAA,CACC,YAAA;EACL,KAAA,EAAO,YAAA;EACP,aAAA;EACA,mBAAA;EACA,WAAA;EACA,KAAA;EACA,UAAA;EAWS,iBAAA,CAAA;EAAA,UAiCU,YAAA,CAAa,OAAA,EAAS,cAAA;EAUhC,oBAAA,CAAA;EAAA,UASU,UAAA,CAAW,OAAA,EAAS,cAAA;EAAA,UAiBpB,MAAA,CAAO,QAAA,EAAU,cAAA;AAAA"}
1
+ {"version":3,"file":"popover-element.d.ts","names":[],"sources":["../../../../src/ui/popover/popover-element.ts"],"mappings":";;;;;;cAkBa,cAAA,SAAuB,YAAA;EAAA;kBAClB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAahB,IAAA;EACA,WAAA;EACA,IAAA,iBAAI,WAAA;EACJ,KAAA,EADI,cAAA,CACC,YAAA;EACL,KAAA,EAAO,YAAA;EACP,aAAA;EACA,mBAAA;EACA,WAAA;EACA,KAAA;EACA,UAAA;EAWS,iBAAA,CAAA;EAAA,UAmCU,YAAA,CAAa,OAAA,EAAS,cAAA;EAUhC,oBAAA,CAAA;EAMA,eAAA,CAAA;EAAA,UAMU,UAAA,CAAW,OAAA,EAAS,cAAA;EAAA,UAiBpB,MAAA,CAAO,QAAA,EAAU,cAAA;AAAA"}
@@ -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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"}
@@ -48,6 +48,7 @@ declare class SliderElement extends MediaElement {
48
48
  thumbAlignment: "center" | "edge";
49
49
  connectedCallback(): void;
50
50
  disconnectedCallback(): void;
51
+ destroyCallback(): void;
51
52
  protected willUpdate(_changed: PropertyValues): void;
52
53
  protected update(_changed: PropertyValues): void;
53
54
  }
@@ -1 +1 @@
1
- {"version":3,"file":"slider-element.d.ts","names":[],"sources":["../../../../src/ui/slider/slider-element.ts"],"mappings":";;;;;cASa,aAAA,SAAsB,YAAA;EAAA;kBACjB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAYhB,KAAA,aAAK,KAAA,iBAAA,WAAA;EACL,KAAA;EACA,GAAA;EACA,GAAA;EACA,IAAA;EACA,SAAA;EACA,WAAA;EACA,QAAA;EACA,cAAA;EAQS,iBAAA,CAAA;EAsCA,oBAAA,CAAA;EAAA,UAQU,UAAA,CAAW,QAAA,EAAU,cAAA;EAAA,UAKrB,MAAA,CAAO,QAAA,EAAU,cAAA;AAAA"}
1
+ {"version":3,"file":"slider-element.d.ts","names":[],"sources":["../../../../src/ui/slider/slider-element.ts"],"mappings":";;;;;cAea,aAAA,SAAsB,YAAA;EAAA;kBACjB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAYhB,KAAA,aAAK,KAAA,iBAAA,WAAA;EACL,KAAA;EACA,GAAA;EACA,GAAA;EACA,IAAA;EACA,SAAA;EACA,WAAA;EACA,QAAA;EACA,cAAA;EAQS,iBAAA,CAAA;EAuCA,oBAAA,CAAA;EAMA,eAAA,CAAA;EAAA,UAKU,UAAA,CAAW,QAAA,EAAU,cAAA;EAAA,UAKrB,MAAA,CAAO,QAAA,EAAU,cAAA;AAAA"}
@@ -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":";;;;;;;;AAeA,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;AACzB,MAAI,KAAK,UAAW;AAEpB,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;;GAEpE,gBAAgB,KAAK,WAAW,cAAc,MAAKA,KAAM,0BAA0B,KAAK,WAAW,UAAU;GAC7G,gBAAgB,KAAK,eAAe;GACrC,CAAC;AAEF,oBAAkB,MAAM,MAAKG,OAAQ,WAAW,EAAE,QAAQ,CAAC;AAC3D,cAAY,MAAM,MAAKA,OAAQ,UAAU;AACzC,QAAKA,OAAQ,MAAM,gBAAgB,KAAK,eAAe,EAAE,EAAE,QAAQ,CAAC;;CAGtE,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKD,YAAa,OAAO;AACzB,QAAKA,aAAc;;CAGrB,AAAS,kBAAwB;AAC/B,QAAKC,QAAS,SAAS;AACvB,QAAM,iBAAiB;;CAGzB,AAAmB,WAAW,UAAgC;AAC5D,QAAM,WAAW,SAAS;AAC1B,QAAKH,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;EAEnD,MAAM,UAAU,iBAAiB,MAAKG,OAAQ,mBAAmB,MAAM,CAAC;AAExE,cAAY,MAAM,QAAQ;AAG1B,sBAAoB,MAAM,OAAO,gBAAgB;AAGjD,QAAKF,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"}
@@ -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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slider-preview-element.js","names":["#ctx","#resizeObserver","#width","#applyPosition"],"sources":["../../../../src/ui/slider/slider-preview-element.ts"],"sourcesContent":["import type { SliderPreviewOverflow } from '@videojs/core/dom';\nimport { applyStateDataAttrs, getSliderPreviewStyle } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { applyStyles } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from './context';\n\nexport class SliderPreviewElement extends MediaElement {\n static readonly tagName = 'media-slider-preview';\n\n static override properties = {\n overflow: { type: String },\n } satisfies PropertyDeclarationMap<'overflow'>;\n\n overflow: SliderPreviewOverflow = 'clamp';\n\n readonly #ctx = new ContextConsumer(this, {\n context: sliderContext,\n subscribe: true,\n });\n\n #resizeObserver: ResizeObserver | null = null;\n #width = 0;\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#resizeObserver = new ResizeObserver(([entry]) => {\n this.#width = entry!.contentRect.width;\n this.#applyPosition();\n });\n\n this.#resizeObserver.observe(this);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#resizeObserver?.disconnect();\n this.#resizeObserver = null;\n }\n\n #applyPosition(): void {\n applyStyles(this, getSliderPreviewStyle(this.#width, this.overflow));\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n\n const ctx = this.#ctx.value;\n if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);\n\n this.#applyPosition();\n }\n}\n"],"mappings":";;;;;;;AASA,IAAa,uBAAb,cAA0C,aAAa;;;kBAOnB;;;iBANR;;;oBAEG,EAC3B,UAAU,EAAE,MAAM,QAAQ,EAC3B;;CAID,CAASA,MAAO,IAAI,gBAAgB,MAAM;EACxC,SAAS;EACT,WAAW;EACZ,CAAC;CAEF,kBAAyC;CACzC,SAAS;CAET,AAAS,oBAA0B;AACjC,QAAM,mBAAmB;AAEzB,QAAKC,iBAAkB,IAAI,gBAAgB,CAAC,WAAW;AACrD,SAAKC,QAAS,MAAO,YAAY;AACjC,SAAKC,eAAgB;IACrB;AAEF,QAAKF,eAAgB,QAAQ,KAAK;;CAGpC,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKA,gBAAiB,YAAY;AAClC,QAAKA,iBAAkB;;CAGzB,iBAAuB;AACrB,cAAY,MAAM,sBAAsB,MAAKC,OAAQ,KAAK,SAAS,CAAC;;CAGtE,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;EAEtB,MAAM,MAAM,MAAKF,IAAK;AACtB,MAAI,IAAK,qBAAoB,MAAM,IAAI,OAAO,IAAI,aAAa;AAE/D,QAAKG,eAAgB"}
@@ -0,0 +1,12 @@
1
+ import { ThumbnailElement } from "../thumbnail/thumbnail-element.js";
2
+ import { PropertyValues } from "@videojs/element";
3
+
4
+ //#region src/ui/slider/slider-thumbnail-element.d.ts
5
+ declare class SliderThumbnailElement extends ThumbnailElement {
6
+ #private;
7
+ static readonly tagName = "media-slider-thumbnail";
8
+ protected update(changed: PropertyValues): void;
9
+ }
10
+ //#endregion
11
+ export { SliderThumbnailElement };
12
+ //# sourceMappingURL=slider-thumbnail-element.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slider-thumbnail-element.d.ts","names":[],"sources":["../../../../src/ui/slider/slider-thumbnail-element.ts"],"mappings":";;;;cAOa,sBAAA,SAA+B,gBAAA;EAAA;kBACjB,OAAA;EAAA,UAON,MAAA,CAAO,OAAA,EAAS,cAAA;AAAA"}
@@ -0,0 +1,23 @@
1
+ import { sliderContext } from "./context.js";
2
+ import { ThumbnailElement } from "../thumbnail/thumbnail-element.js";
3
+ import { ContextConsumer } from "@videojs/element/context";
4
+
5
+ //#region src/ui/slider/slider-thumbnail-element.ts
6
+ var SliderThumbnailElement = class extends ThumbnailElement {
7
+ static {
8
+ this.tagName = "media-slider-thumbnail";
9
+ }
10
+ #ctx = new ContextConsumer(this, {
11
+ context: sliderContext,
12
+ subscribe: true
13
+ });
14
+ update(changed) {
15
+ const ctx = this.#ctx.value;
16
+ if (ctx) this.time = ctx.pointerValue;
17
+ super.update(changed);
18
+ }
19
+ };
20
+
21
+ //#endregion
22
+ export { SliderThumbnailElement };
23
+ //# sourceMappingURL=slider-thumbnail-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slider-thumbnail-element.js","names":["#ctx"],"sources":["../../../../src/ui/slider/slider-thumbnail-element.ts"],"sourcesContent":["import type { PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { ThumbnailElement } from '../thumbnail/thumbnail-element';\nimport { sliderContext } from './context';\n\n// @ts-expect-error TS2417 — tagName narrows to a different literal for custom element registration.\nexport class SliderThumbnailElement extends ThumbnailElement {\n static override readonly tagName = 'media-slider-thumbnail';\n\n readonly #ctx = new ContextConsumer(this, {\n context: sliderContext,\n subscribe: true,\n });\n\n protected override update(changed: PropertyValues): void {\n const ctx = this.#ctx.value;\n if (ctx) this.time = ctx.pointerValue;\n super.update(changed);\n }\n}\n"],"mappings":";;;;;AAOA,IAAa,yBAAb,cAA4C,iBAAiB;;iBACxB;;CAEnC,CAASA,MAAO,IAAI,gBAAgB,MAAM;EACxC,SAAS;EACT,WAAW;EACZ,CAAC;CAEF,AAAmB,OAAO,SAA+B;EACvD,MAAM,MAAM,MAAKA,IAAK;AACtB,MAAI,IAAK,MAAK,OAAO,IAAI;AACzB,QAAM,OAAO,QAAQ"}
@@ -35,6 +35,7 @@ declare class ThumbnailElement extends MediaElement {
35
35
  set thumbnails(value: ThumbnailImage[] | undefined);
36
36
  connectedCallback(): void;
37
37
  disconnectedCallback(): void;
38
+ destroyCallback(): void;
38
39
  protected update(changed: PropertyValues): void;
39
40
  }
40
41
  //#endregion
@@ -1 +1 @@
1
- {"version":3,"file":"thumbnail-element.d.ts","names":[],"sources":["../../../../src/ui/thumbnail/thumbnail-element.ts"],"mappings":";;;;;cAyBa,gBAAA,SAAyB,YAAA;EAAA;kBACpB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;EAOhB,IAAA;EACA,WAAA,EAAa,aAAA,CAAc,KAAA;EAC3B,OAAA,EAAS,aAAA,CAAc,KAAA;EACvB,aAAA,EAAe,aAAA,CAAc,KAAA;;;;;;MA+BzB,UAAA,CAAA,GAAc,cAAA;EAAA,IAId,UAAA,CAAW,KAAA,EAAO,cAAA;EAKb,iBAAA,CAAA;EAUA,oBAAA,CAAA;EAAA,UAMU,MAAA,CAAO,OAAA,EAAS,cAAA;AAAA"}
1
+ {"version":3,"file":"thumbnail-element.d.ts","names":[],"sources":["../../../../src/ui/thumbnail/thumbnail-element.ts"],"mappings":";;;;;cAyBa,gBAAA,SAAyB,YAAA;EAAA;kBACpB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;EAOhB,IAAA;EACA,WAAA,EAAa,aAAA,CAAc,KAAA;EAC3B,OAAA,EAAS,aAAA,CAAc,KAAA;EACvB,aAAA,EAAe,aAAA,CAAc,KAAA;;;;;;MA+BzB,UAAA,CAAA,GAAc,cAAA;EAAA,IAId,UAAA,CAAW,KAAA,EAAO,cAAA;EAKb,iBAAA,CAAA;EAWA,oBAAA,CAAA;EAIA,eAAA,CAAA;EAAA,UAKU,MAAA,CAAO,OAAA,EAAS,cAAA;AAAA"}
@@ -64,6 +64,7 @@ var ThumbnailElement = class extends MediaElement {
64
64
  }
65
65
  connectedCallback() {
66
66
  super.connectedCallback();
67
+ if (this.destroyed) return;
67
68
  this.#api = createThumbnail({
68
69
  getContainer: () => this,
69
70
  getImg: () => this.#img,
@@ -72,8 +73,10 @@ var ThumbnailElement = class extends MediaElement {
72
73
  }
73
74
  disconnectedCallback() {
74
75
  super.disconnectedCallback();
76
+ }
77
+ destroyCallback() {
75
78
  this.#api?.destroy();
76
- this.#api = null;
79
+ super.destroyCallback();
77
80
  }
78
81
  update(changed) {
79
82
  super.update(changed);
@@ -1 +1 @@
1
- {"version":3,"file":"thumbnail-element.js","names":["#core","#img","#textTracks","#externalThumbnails","#api","#thumbnails","#lastTextTrack","#resetStyles","#applyResize"],"sources":["../../../../src/ui/thumbnail/thumbnail-element.ts"],"sourcesContent":["import {\n type MediaTextTrackState,\n mapCuesToThumbnails,\n ThumbnailCore,\n ThumbnailDataAttrs,\n type ThumbnailImage,\n type ThumbnailResizeResult,\n} from '@videojs/core';\nimport type { ThumbnailApi } from '@videojs/core/dom';\nimport { applyElementProps, applyStateDataAttrs, createThumbnail, selectTextTrack } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\n\nconst SHADOW_CSS = `\\\n:host {\n display: inline-block;\n overflow: hidden;\n}\nimg {\n display: block;\n}`;\n\nexport class ThumbnailElement extends MediaElement {\n static readonly tagName = 'media-thumbnail';\n\n static override properties = {\n time: { type: Number },\n crossOrigin: { type: String, attribute: 'crossorigin' },\n loading: { type: String },\n fetchPriority: { type: String, attribute: 'fetchpriority' },\n } satisfies PropertyDeclarationMap<keyof ThumbnailCore.Props>;\n\n time = 0;\n crossOrigin: ThumbnailCore.Props['crossOrigin'];\n loading: ThumbnailCore.Props['loading'];\n fetchPriority: ThumbnailCore.Props['fetchPriority'];\n\n readonly #core = new ThumbnailCore();\n readonly #img = document.createElement('img');\n readonly #textTracks = new PlayerController(this, playerContext, selectTextTrack);\n\n #thumbnails: ThumbnailImage[] = [];\n #externalThumbnails: ThumbnailImage[] | undefined;\n #lastTextTrack: MediaTextTrackState | undefined;\n #api: ThumbnailApi | null = null;\n\n constructor() {\n super();\n\n const shadow = this.attachShadow({ mode: 'open' });\n\n const style = document.createElement('style');\n style.textContent = SHADOW_CSS;\n shadow.appendChild(style);\n\n this.#img.alt = '';\n this.#img.setAttribute('part', 'img');\n this.#img.setAttribute('aria-hidden', 'true');\n this.#img.setAttribute('decoding', 'async');\n shadow.appendChild(this.#img);\n }\n\n /**\n * Set thumbnail images directly, bypassing the automatic `<track>` detection.\n * When set, this takes priority over the text track path.\n */\n get thumbnails(): ThumbnailImage[] | undefined {\n return this.#externalThumbnails;\n }\n\n set thumbnails(value: ThumbnailImage[] | undefined) {\n this.#externalThumbnails = value;\n this.requestUpdate();\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#api = createThumbnail({\n getContainer: () => this,\n getImg: () => this.#img,\n onStateChange: () => this.requestUpdate(),\n });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#api?.destroy();\n this.#api = null;\n }\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n\n // Resolve thumbnails: external prop takes priority over auto <track> path.\n if (this.#externalThumbnails) {\n this.#thumbnails = this.#externalThumbnails;\n } else {\n const textTrack = this.#textTracks.value;\n\n if (textTrack !== this.#lastTextTrack) {\n this.#lastTextTrack = textTrack;\n this.#thumbnails =\n textTrack && textTrack.thumbnailCues.length > 0\n ? mapCuesToThumbnails(textTrack.thumbnailCues, textTrack.thumbnailTrackSrc ?? undefined)\n : [];\n }\n }\n\n const thumbnail = this.#core.findActiveThumbnail(this.#thumbnails, this.time);\n\n // Sync img attributes from element properties.\n applyElementProps(this.#img, {\n crossorigin: this.crossOrigin || undefined,\n loading: this.loading,\n fetchpriority: this.fetchPriority,\n });\n\n // Track src changes via the thumbnail API.\n this.#api?.updateSrc(thumbnail?.url);\n\n if (!thumbnail) {\n this.#img.removeAttribute('src');\n this.#resetStyles();\n\n const state = this.#core.getState(false, false, undefined);\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, ThumbnailDataAttrs);\n return;\n }\n\n // Set the img src directly (imperative DOM).\n if (this.#img.getAttribute('src') !== thumbnail.url) {\n this.#img.src = thumbnail.url;\n }\n\n const api = this.#api;\n const state = this.#core.getState(api?.loading ?? false, api?.error ?? false, thumbnail);\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, ThumbnailDataAttrs);\n\n if (api?.naturalWidth && api.naturalHeight) {\n const constraints = api.readConstraints();\n const result = this.#core.resize(thumbnail, api.naturalWidth, api.naturalHeight, constraints);\n\n if (result) {\n this.#applyResize(result);\n }\n }\n }\n\n #applyResize(result: ThumbnailResizeResult): void {\n this.style.width = `${result.containerWidth}px`;\n this.style.height = `${result.containerHeight}px`;\n\n const imgStyle = this.#img.style;\n imgStyle.width = `${result.imageWidth}px`;\n imgStyle.height = `${result.imageHeight}px`;\n imgStyle.maxWidth = 'none';\n imgStyle.transform =\n result.offsetX || result.offsetY ? `translate(-${result.offsetX}px, -${result.offsetY}px)` : '';\n }\n\n #resetStyles(): void {\n this.style.width = '';\n this.style.height = '';\n\n const imgStyle = this.#img.style;\n imgStyle.width = '';\n imgStyle.height = '';\n imgStyle.maxWidth = '';\n imgStyle.transform = '';\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"thumbnail-element.js","names":["#core","#img","#textTracks","#externalThumbnails","#api","#thumbnails","#lastTextTrack","#resetStyles","#applyResize"],"sources":["../../../../src/ui/thumbnail/thumbnail-element.ts"],"sourcesContent":["import {\n type MediaTextTrackState,\n mapCuesToThumbnails,\n ThumbnailCore,\n ThumbnailDataAttrs,\n type ThumbnailImage,\n type ThumbnailResizeResult,\n} from '@videojs/core';\nimport type { ThumbnailApi } from '@videojs/core/dom';\nimport { applyElementProps, applyStateDataAttrs, createThumbnail, selectTextTrack } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\n\nconst SHADOW_CSS = `\\\n:host {\n display: inline-block;\n overflow: hidden;\n}\nimg {\n display: block;\n}`;\n\nexport class ThumbnailElement extends MediaElement {\n static readonly tagName = 'media-thumbnail';\n\n static override properties = {\n time: { type: Number },\n crossOrigin: { type: String, attribute: 'crossorigin' },\n loading: { type: String },\n fetchPriority: { type: String, attribute: 'fetchpriority' },\n } satisfies PropertyDeclarationMap<keyof ThumbnailCore.Props>;\n\n time = 0;\n crossOrigin: ThumbnailCore.Props['crossOrigin'];\n loading: ThumbnailCore.Props['loading'];\n fetchPriority: ThumbnailCore.Props['fetchPriority'];\n\n readonly #core = new ThumbnailCore();\n readonly #img = document.createElement('img');\n readonly #textTracks = new PlayerController(this, playerContext, selectTextTrack);\n\n #thumbnails: ThumbnailImage[] = [];\n #externalThumbnails: ThumbnailImage[] | undefined;\n #lastTextTrack: MediaTextTrackState | undefined;\n #api: ThumbnailApi | null = null;\n\n constructor() {\n super();\n\n const shadow = this.attachShadow({ mode: 'open' });\n\n const style = document.createElement('style');\n style.textContent = SHADOW_CSS;\n shadow.appendChild(style);\n\n this.#img.alt = '';\n this.#img.setAttribute('part', 'img');\n this.#img.setAttribute('aria-hidden', 'true');\n this.#img.setAttribute('decoding', 'async');\n shadow.appendChild(this.#img);\n }\n\n /**\n * Set thumbnail images directly, bypassing the automatic `<track>` detection.\n * When set, this takes priority over the text track path.\n */\n get thumbnails(): ThumbnailImage[] | undefined {\n return this.#externalThumbnails;\n }\n\n set thumbnails(value: ThumbnailImage[] | undefined) {\n this.#externalThumbnails = value;\n this.requestUpdate();\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#api = createThumbnail({\n getContainer: () => this,\n getImg: () => this.#img,\n onStateChange: () => this.requestUpdate(),\n });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n }\n\n override destroyCallback(): void {\n this.#api?.destroy();\n super.destroyCallback();\n }\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n\n // Resolve thumbnails: external prop takes priority over auto <track> path.\n if (this.#externalThumbnails) {\n this.#thumbnails = this.#externalThumbnails;\n } else {\n const textTrack = this.#textTracks.value;\n\n if (textTrack !== this.#lastTextTrack) {\n this.#lastTextTrack = textTrack;\n this.#thumbnails =\n textTrack && textTrack.thumbnailCues.length > 0\n ? mapCuesToThumbnails(textTrack.thumbnailCues, textTrack.thumbnailTrackSrc ?? undefined)\n : [];\n }\n }\n\n const thumbnail = this.#core.findActiveThumbnail(this.#thumbnails, this.time);\n\n // Sync img attributes from element properties.\n applyElementProps(this.#img, {\n crossorigin: this.crossOrigin || undefined,\n loading: this.loading,\n fetchpriority: this.fetchPriority,\n });\n\n // Track src changes via the thumbnail API.\n this.#api?.updateSrc(thumbnail?.url);\n\n if (!thumbnail) {\n this.#img.removeAttribute('src');\n this.#resetStyles();\n\n const state = this.#core.getState(false, false, undefined);\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, ThumbnailDataAttrs);\n return;\n }\n\n // Set the img src directly (imperative DOM).\n if (this.#img.getAttribute('src') !== thumbnail.url) {\n this.#img.src = thumbnail.url;\n }\n\n const api = this.#api;\n const state = this.#core.getState(api?.loading ?? false, api?.error ?? false, thumbnail);\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, ThumbnailDataAttrs);\n\n if (api?.naturalWidth && api.naturalHeight) {\n const constraints = api.readConstraints();\n const result = this.#core.resize(thumbnail, api.naturalWidth, api.naturalHeight, constraints);\n\n if (result) {\n this.#applyResize(result);\n }\n }\n }\n\n #applyResize(result: ThumbnailResizeResult): void {\n this.style.width = `${result.containerWidth}px`;\n this.style.height = `${result.containerHeight}px`;\n\n const imgStyle = this.#img.style;\n imgStyle.width = `${result.imageWidth}px`;\n imgStyle.height = `${result.imageHeight}px`;\n imgStyle.maxWidth = 'none';\n imgStyle.transform =\n result.offsetX || result.offsetY ? `translate(-${result.offsetX}px, -${result.offsetY}px)` : '';\n }\n\n #resetStyles(): void {\n this.style.width = '';\n this.style.height = '';\n\n const imgStyle = this.#img.style;\n imgStyle.width = '';\n imgStyle.height = '';\n imgStyle.maxWidth = '';\n imgStyle.transform = '';\n }\n}\n"],"mappings":"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"}
@@ -41,6 +41,7 @@ declare class TimeSliderElement extends MediaElement {
41
41
  thumbAlignment: "center" | "edge";
42
42
  connectedCallback(): void;
43
43
  disconnectedCallback(): void;
44
+ destroyCallback(): void;
44
45
  protected willUpdate(_changed: PropertyValues): void;
45
46
  protected update(_changed: PropertyValues): void;
46
47
  }
@@ -1 +1 @@
1
- {"version":3,"file":"time-slider-element.d.ts","names":[],"sources":["../../../../src/ui/time-slider/time-slider-element.ts"],"mappings":";;;;;cAoBa,iBAAA,SAA0B,YAAA;EAAA;kBACrB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;;;;;;;;;;;EAUhB,KAAA,aAAK,KAAA,iBAAA,WAAA;EACL,cAAA;EACA,IAAA;EACA,SAAA;EACA,WAAA;EACA,QAAA;EACA,cAAA;EAUS,iBAAA,CAAA;EA2CA,oBAAA,CAAA;EAAA,UAQU,UAAA,CAAW,QAAA,EAAU,cAAA;EAAA,UAKrB,MAAA,CAAO,QAAA,EAAU,cAAA;AAAA"}
1
+ {"version":3,"file":"time-slider-element.d.ts","names":[],"sources":["../../../../src/ui/time-slider/time-slider-element.ts"],"mappings":";;;;;cAqBa,iBAAA,SAA0B,YAAA;EAAA;kBACrB,OAAA;EAAA,OAEA,UAAA;;;;;;;;;;;;;;;;;;;;;;;;;;EAUhB,KAAA,aAAK,KAAA,iBAAA,WAAA;EACL,cAAA;EACA,IAAA;EACA,SAAA;EACA,WAAA;EACA,QAAA;EACA,cAAA;EAUS,iBAAA,CAAA;EA4CA,oBAAA,CAAA;EAMA,eAAA,CAAA;EAAA,UAKU,UAAA,CAAW,QAAA,EAAU,cAAA;EAAA,UAKrB,MAAA,CAAO,QAAA,EAAU,cAAA;AAAA"}
@@ -2,7 +2,7 @@ import { playerContext } from "../../player/context.js";
2
2
  import { MediaElement } from "../media-element.js";
3
3
  import { PlayerController } from "../../player/player-controller.js";
4
4
  import { sliderContext } from "../slider/context.js";
5
- import { applyStateDataAttrs, createSlider, getTimeSliderCSSVars, logMissingFeature, selectBuffer, selectTime } from "@videojs/core/dom";
5
+ import { applyElementProps, applyStateDataAttrs, createSlider, getTimeSliderCSSVars, logMissingFeature, selectBuffer, selectTime } from "@videojs/core/dom";
6
6
  import { ContextProvider } from "@videojs/element/context";
7
7
  import { TimeSliderCore, TimeSliderDataAttrs } from "@videojs/core";
8
8
  import { applyStyles, isRTL } from "@videojs/utils/dom";
@@ -51,6 +51,7 @@ var TimeSliderElement = class extends MediaElement {
51
51
  #disconnect = null;
52
52
  connectedCallback() {
53
53
  super.connectedCallback();
54
+ if (this.destroyed) return;
54
55
  this.#disconnect = new AbortController();
55
56
  const signal = this.#disconnect.signal;
56
57
  this.#slider = createSlider({
@@ -76,20 +77,24 @@ var TimeSliderElement = class extends MediaElement {
76
77
  },
77
78
  onDragEnd: () => {
78
79
  this.dispatchEvent(new CustomEvent("drag-end", { bubbles: true }));
79
- }
80
+ },
81
+ adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),
82
+ onResize: () => this.requestUpdate()
80
83
  });
84
+ applyElementProps(this, this.#slider.rootProps, { signal });
85
+ applyStyles(this, this.#slider.rootStyle);
81
86
  this.#slider.input.subscribe(() => this.requestUpdate(), { signal });
82
- this.style.touchAction = "none";
83
- this.style.userSelect = "none";
84
87
  if (!this.#timeState.value) logMissingFeature(this.localName, this.#timeState.displayName);
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);
@@ -110,7 +115,7 @@ var TimeSliderElement = class extends MediaElement {
110
115
  };
111
116
  this.#core.setMedia(media);
112
117
  const state = this.#core.getState();
113
- const cssVars = getTimeSliderCSSVars(state);
118
+ const cssVars = getTimeSliderCSSVars(this.#slider.adjustForAlignment(state));
114
119
  applyStyles(this, cssVars);
115
120
  applyStateDataAttrs(this, state, TimeSliderDataAttrs);
116
121
  this.#provider.setValue({