@videojs/html 10.0.0-beta.1 → 10.0.0-beta.11

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 (463) hide show
  1. package/cdn/audio-minimal.dev.d.ts +1 -0
  2. package/cdn/audio-minimal.dev.js +113 -0
  3. package/cdn/audio-minimal.dev.js.map +1 -0
  4. package/cdn/audio-minimal.js +2 -0
  5. package/cdn/audio-minimal.js.map +1 -0
  6. package/cdn/audio.dev.d.ts +1 -0
  7. package/cdn/audio.dev.js +104 -0
  8. package/cdn/audio.dev.js.map +1 -0
  9. package/cdn/audio.js +2 -0
  10. package/cdn/audio.js.map +1 -0
  11. package/cdn/background.dev.d.ts +1 -0
  12. package/cdn/background.dev.js +160 -0
  13. package/cdn/background.dev.js.map +1 -0
  14. package/cdn/background.js +2 -0
  15. package/cdn/background.js.map +1 -0
  16. package/cdn/context-Be8C5kVd.js +166 -0
  17. package/cdn/context-Be8C5kVd.js.map +1 -0
  18. package/cdn/context-CUBywtsB.js +14 -0
  19. package/cdn/context-CUBywtsB.js.map +1 -0
  20. package/cdn/create-player-AcfnN3li.js +3218 -0
  21. package/cdn/create-player-AcfnN3li.js.map +1 -0
  22. package/cdn/create-player-s_qISCpw.js +7 -0
  23. package/cdn/create-player-s_qISCpw.js.map +1 -0
  24. package/cdn/custom-media-element-DqevSVgS.js +47 -0
  25. package/cdn/custom-media-element-DqevSVgS.js.map +1 -0
  26. package/cdn/custom-media-element-moFa3UZp.js +303 -0
  27. package/cdn/custom-media-element-moFa3UZp.js.map +1 -0
  28. package/cdn/default-GgKND7a8.js +2 -0
  29. package/cdn/default-GgKND7a8.js.map +1 -0
  30. package/cdn/default-cLso8BHO.js +28 -0
  31. package/cdn/default-cLso8BHO.js.map +1 -0
  32. package/cdn/delegate-CzAcT1xm.js +44 -0
  33. package/cdn/delegate-CzAcT1xm.js.map +1 -0
  34. package/cdn/delegate-Uc-6tQDR.js +2 -0
  35. package/cdn/delegate-Uc-6tQDR.js.map +1 -0
  36. package/cdn/listen-4jqsRSKo.js +2 -0
  37. package/cdn/listen-4jqsRSKo.js.map +1 -0
  38. package/cdn/listen-YSH3Jfyk.js +9 -0
  39. package/cdn/listen-YSH3Jfyk.js.map +1 -0
  40. package/cdn/media/dash-video.dev.d.ts +1 -0
  41. package/cdn/media/dash-video.dev.js +39167 -0
  42. package/cdn/media/dash-video.dev.js.map +1 -0
  43. package/cdn/media/dash-video.js +21 -0
  44. package/cdn/media/dash-video.js.map +1 -0
  45. package/cdn/media/hls-video.dev.d.ts +1 -0
  46. package/cdn/media/hls-video.dev.js +28359 -0
  47. package/cdn/media/hls-video.dev.js.map +1 -0
  48. package/cdn/media/hls-video.js +41 -0
  49. package/cdn/media/hls-video.js.map +1 -0
  50. package/cdn/media/simple-hls-video.dev.d.ts +1 -0
  51. package/cdn/media/simple-hls-video.dev.js +3603 -0
  52. package/cdn/media/simple-hls-video.dev.js.map +1 -0
  53. package/cdn/media/simple-hls-video.js +2 -0
  54. package/cdn/media/simple-hls-video.js.map +1 -0
  55. package/cdn/media-attach-mixin-D5_nfJpa.js +2 -0
  56. package/cdn/media-attach-mixin-D5_nfJpa.js.map +1 -0
  57. package/cdn/media-attach-mixin-U_KQB_9O.js +44 -0
  58. package/cdn/media-attach-mixin-U_KQB_9O.js.map +1 -0
  59. package/cdn/minimal-BJfleQcQ.js +2 -0
  60. package/cdn/minimal-BJfleQcQ.js.map +1 -0
  61. package/cdn/minimal-DBMdC_0I.js +28 -0
  62. package/cdn/minimal-DBMdC_0I.js.map +1 -0
  63. package/cdn/player-C46h14iP.js +2 -0
  64. package/cdn/player-C46h14iP.js.map +1 -0
  65. package/cdn/player-CvrOeLpy.js +15 -0
  66. package/cdn/player-CvrOeLpy.js.map +1 -0
  67. package/cdn/poster-Olv5zDI_.js +195 -0
  68. package/cdn/poster-Olv5zDI_.js.map +1 -0
  69. package/cdn/poster-odJ4iwIv.js +2 -0
  70. package/cdn/poster-odJ4iwIv.js.map +1 -0
  71. package/cdn/predicate-BG-dj_kF.js +26 -0
  72. package/cdn/predicate-BG-dj_kF.js.map +1 -0
  73. package/cdn/predicate-Y9jDHLpX.js +2 -0
  74. package/cdn/predicate-Y9jDHLpX.js.map +1 -0
  75. package/cdn/safe-define-B8lHgj_K.js +9 -0
  76. package/cdn/safe-define-B8lHgj_K.js.map +1 -0
  77. package/cdn/safe-define-GrHW3P9e.js +2 -0
  78. package/cdn/safe-define-GrHW3P9e.js.map +1 -0
  79. package/cdn/video-minimal.dev.d.ts +1 -0
  80. package/cdn/video-minimal.dev.js +156 -0
  81. package/cdn/video-minimal.dev.js.map +1 -0
  82. package/cdn/video-minimal.js +2 -0
  83. package/cdn/video-minimal.js.map +1 -0
  84. package/cdn/video.dev.d.ts +1 -0
  85. package/cdn/video.dev.js +170 -0
  86. package/cdn/video.dev.js.map +1 -0
  87. package/cdn/video.js +2 -0
  88. package/cdn/video.js.map +1 -0
  89. package/cdn/volume-slider-D7BOdSDF.js +2459 -0
  90. package/cdn/volume-slider-D7BOdSDF.js.map +1 -0
  91. package/cdn/volume-slider-DPeFF5tt.js +8 -0
  92. package/cdn/volume-slider-DPeFF5tt.js.map +1 -0
  93. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js +1 -1
  94. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -1
  95. package/dist/default/_virtual/inline-css_src/define/audio/skin.js +1 -1
  96. package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  97. package/dist/default/_virtual/inline-css_src/define/background/skin.js +6 -0
  98. package/dist/default/_virtual/inline-css_src/define/background/skin.js.map +1 -0
  99. package/dist/default/_virtual/inline-css_src/define/base.js +6 -0
  100. package/dist/default/_virtual/inline-css_src/define/base.js.map +1 -0
  101. package/dist/default/_virtual/inline-css_src/define/shared.js +6 -0
  102. package/dist/default/_virtual/inline-css_src/define/shared.js.map +1 -0
  103. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  104. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  105. package/dist/default/_virtual/inline-css_src/define/video/skin.js +1 -1
  106. package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  107. package/dist/default/define/audio/minimal-skin.css +237 -157
  108. package/dist/default/define/audio/minimal-skin.js +2 -79
  109. package/dist/default/define/audio/minimal-skin.js.map +1 -1
  110. package/dist/default/define/audio/minimal-skin.tailwind.js +5 -82
  111. package/dist/default/define/audio/minimal-skin.tailwind.js.map +1 -1
  112. package/dist/default/define/audio/skin.css +234 -153
  113. package/dist/default/define/audio/skin.js +2 -70
  114. package/dist/default/define/audio/skin.js.map +1 -1
  115. package/dist/default/define/audio/skin.tailwind.js +6 -75
  116. package/dist/default/define/audio/skin.tailwind.js.map +1 -1
  117. package/dist/default/define/background/skin.css +1 -1
  118. package/dist/default/define/background/skin.js +11 -5
  119. package/dist/default/define/background/skin.js.map +1 -1
  120. package/dist/default/define/base.css +23 -0
  121. package/dist/default/define/media/dash-video.js +14 -0
  122. package/dist/default/define/media/dash-video.js.map +1 -0
  123. package/dist/default/define/shared.css +13 -0
  124. package/dist/default/define/skin-mixin.js +16 -33
  125. package/dist/default/define/skin-mixin.js.map +1 -1
  126. package/dist/default/define/video/minimal-skin.css +486 -301
  127. package/dist/default/define/video/minimal-skin.js +3 -121
  128. package/dist/default/define/video/minimal-skin.js.map +1 -1
  129. package/dist/default/define/video/minimal-skin.tailwind.js +8 -136
  130. package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
  131. package/dist/default/define/video/skin.css +484 -289
  132. package/dist/default/define/video/skin.js +3 -116
  133. package/dist/default/define/video/skin.js.map +1 -1
  134. package/dist/default/define/video/skin.tailwind.js +8 -128
  135. package/dist/default/define/video/skin.tailwind.js.map +1 -1
  136. package/dist/default/icons/dist/render/default/index.js +2 -1
  137. package/dist/default/icons/dist/render/default/index.js.map +1 -1
  138. package/dist/default/icons/dist/render/minimal/index.js +2 -1
  139. package/dist/default/icons/dist/render/minimal/index.js.map +1 -1
  140. package/dist/default/index.js +4 -2
  141. package/dist/default/media/background-video/index.js +6 -19
  142. package/dist/default/media/background-video/index.js.map +1 -1
  143. package/dist/default/media/container-element.js +5 -2
  144. package/dist/default/media/container-element.js.map +1 -1
  145. package/dist/default/media/dash-video/index.js +26 -0
  146. package/dist/default/media/dash-video/index.js.map +1 -0
  147. package/dist/default/media/hls-video/index.js +2 -1
  148. package/dist/default/media/hls-video/index.js.map +1 -1
  149. package/dist/default/media/simple-hls-video/index.js +3 -1
  150. package/dist/default/media/simple-hls-video/index.js.map +1 -1
  151. package/dist/default/player/context.js +6 -2
  152. package/dist/default/player/context.js.map +1 -1
  153. package/dist/default/player/create-player.js +11 -3
  154. package/dist/default/player/create-player.js.map +1 -1
  155. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js +10 -26
  156. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -1
  157. package/dist/default/skins/dist/default/default/tailwind/components/button.js +4 -3
  158. package/dist/default/skins/dist/default/default/tailwind/components/button.js.map +1 -1
  159. package/dist/default/skins/dist/default/default/tailwind/components/controls.js +1 -1
  160. package/dist/default/skins/dist/default/default/tailwind/components/controls.js.map +1 -1
  161. package/dist/default/skins/dist/default/default/tailwind/components/error.js +3 -3
  162. package/dist/default/skins/dist/default/default/tailwind/components/error.js.map +1 -1
  163. package/dist/default/skins/dist/default/default/tailwind/components/overlay.js +1 -1
  164. package/dist/default/skins/dist/default/default/tailwind/components/overlay.js.map +1 -1
  165. package/dist/default/skins/dist/default/default/tailwind/components/popup.js +3 -3
  166. package/dist/default/skins/dist/default/default/tailwind/components/popup.js.map +1 -1
  167. package/dist/default/skins/dist/default/default/tailwind/components/poster.js +16 -0
  168. package/dist/default/skins/dist/default/default/tailwind/components/poster.js.map +1 -0
  169. package/dist/default/skins/dist/default/default/tailwind/components/preview.js +13 -0
  170. package/dist/default/skins/dist/default/default/tailwind/components/preview.js.map +1 -0
  171. package/dist/default/skins/dist/default/default/tailwind/components/root.js +1 -1
  172. package/dist/default/skins/dist/default/default/tailwind/components/root.js.map +1 -1
  173. package/dist/default/skins/dist/default/default/tailwind/components/seek.js +1 -1
  174. package/dist/default/skins/dist/default/default/tailwind/components/seek.js.map +1 -1
  175. package/dist/default/skins/dist/default/default/tailwind/components/slider.js +1 -1
  176. package/dist/default/skins/dist/default/default/tailwind/components/slider.js.map +1 -1
  177. package/dist/default/skins/dist/default/default/tailwind/components/surface.js +1 -1
  178. package/dist/default/skins/dist/default/default/tailwind/components/surface.js.map +1 -1
  179. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +27 -16
  180. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
  181. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +11 -24
  182. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
  183. package/dist/default/skins/dist/default/minimal/tailwind/components/button.js +4 -3
  184. package/dist/default/skins/dist/default/minimal/tailwind/components/button.js.map +1 -1
  185. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js +1 -1
  186. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -1
  187. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js +3 -3
  188. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js.map +1 -1
  189. package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js +1 -1
  190. package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -1
  191. package/dist/default/skins/dist/default/minimal/tailwind/components/playback-rate.js +6 -0
  192. package/dist/default/skins/dist/default/minimal/tailwind/components/playback-rate.js.map +1 -0
  193. package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js +4 -3
  194. package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -1
  195. package/dist/default/skins/dist/default/minimal/tailwind/components/poster.js +16 -0
  196. package/dist/default/skins/dist/default/minimal/tailwind/components/poster.js.map +1 -0
  197. package/dist/default/skins/dist/default/minimal/tailwind/components/preview.js +14 -0
  198. package/dist/default/skins/dist/default/minimal/tailwind/components/preview.js.map +1 -0
  199. package/dist/default/skins/dist/default/minimal/tailwind/components/root.js +1 -1
  200. package/dist/default/skins/dist/default/minimal/tailwind/components/root.js.map +1 -1
  201. package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js +1 -1
  202. package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -1
  203. package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js +1 -1
  204. package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -1
  205. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js +1 -1
  206. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js.map +1 -1
  207. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +33 -16
  208. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
  209. package/dist/default/skins/dist/default/{default/tailwind/components → shared/tailwind}/icon-state.js +6 -1
  210. package/dist/default/skins/dist/default/shared/tailwind/icon-state.js.map +1 -0
  211. package/dist/{dev/skins/dist/default/default/tailwind/components → default/skins/dist/default/shared/tailwind}/tooltip-state.js +1 -1
  212. package/dist/default/skins/dist/default/shared/tailwind/tooltip-state.js.map +1 -0
  213. package/dist/default/store/container-mixin.js +16 -60
  214. package/dist/default/store/container-mixin.js.map +1 -1
  215. package/dist/default/store/media-attach-mixin.js +45 -0
  216. package/dist/default/store/media-attach-mixin.js.map +1 -0
  217. package/dist/default/store/provider-mixin.js +99 -9
  218. package/dist/default/store/provider-mixin.js.map +1 -1
  219. package/dist/default/ui/alert-dialog/alert-dialog-element.js +1 -1
  220. package/dist/default/ui/buffering-indicator/buffering-indicator-element.js +1 -1
  221. package/dist/default/ui/captions-button/captions-button-element.js +1 -1
  222. package/dist/default/ui/controls/controls-element.js +1 -1
  223. package/dist/default/ui/fullscreen-button/fullscreen-button-element.js +1 -1
  224. package/dist/default/ui/mute-button/mute-button-element.js +1 -1
  225. package/dist/default/ui/pip-button/pip-button-element.js +1 -1
  226. package/dist/default/ui/play-button/play-button-element.js +1 -1
  227. package/dist/default/ui/playback-rate-button/playback-rate-button-element.js +1 -1
  228. package/dist/default/ui/popover/popover-element.js +55 -4
  229. package/dist/default/ui/popover/popover-element.js.map +1 -1
  230. package/dist/default/ui/poster/poster-element.js +1 -1
  231. package/dist/default/ui/seek-button/seek-button-element.js +1 -1
  232. package/dist/default/ui/slider/slider-element.js +1 -1
  233. package/dist/default/ui/thumbnail/thumbnail-element.js +1 -1
  234. package/dist/default/ui/time/time-element.js +1 -1
  235. package/dist/default/ui/time-slider/time-slider-element.js +2 -2
  236. package/dist/default/ui/time-slider/time-slider-element.js.map +1 -1
  237. package/dist/default/ui/tooltip/tooltip-element.js +54 -4
  238. package/dist/default/ui/tooltip/tooltip-element.js.map +1 -1
  239. package/dist/default/ui/tooltip/tooltip-group-element.js +5 -2
  240. package/dist/default/ui/tooltip/tooltip-group-element.js.map +1 -1
  241. package/dist/default/ui/volume-slider/volume-slider-element.js +3 -3
  242. package/dist/default/ui/volume-slider/volume-slider-element.js.map +1 -1
  243. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js +1 -1
  244. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -1
  245. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +1 -1
  246. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  247. package/dist/dev/_virtual/inline-css_src/define/background/skin.js +6 -0
  248. package/dist/dev/_virtual/inline-css_src/define/background/skin.js.map +1 -0
  249. package/dist/dev/_virtual/inline-css_src/define/base.js +6 -0
  250. package/dist/dev/_virtual/inline-css_src/define/base.js.map +1 -0
  251. package/dist/dev/_virtual/inline-css_src/define/shared.js +6 -0
  252. package/dist/dev/_virtual/inline-css_src/define/shared.js.map +1 -0
  253. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  254. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  255. package/dist/dev/_virtual/inline-css_src/define/video/skin.js +1 -1
  256. package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  257. package/dist/dev/define/audio/minimal-skin.css +237 -157
  258. package/dist/dev/define/audio/minimal-skin.d.ts.map +1 -1
  259. package/dist/dev/define/audio/minimal-skin.js +69 -64
  260. package/dist/dev/define/audio/minimal-skin.js.map +1 -1
  261. package/dist/dev/define/audio/minimal-skin.tailwind.d.ts.map +1 -1
  262. package/dist/dev/define/audio/minimal-skin.tailwind.js +73 -66
  263. package/dist/dev/define/audio/minimal-skin.tailwind.js.map +1 -1
  264. package/dist/dev/define/audio/skin.css +234 -153
  265. package/dist/dev/define/audio/skin.d.ts.map +1 -1
  266. package/dist/dev/define/audio/skin.js +61 -56
  267. package/dist/dev/define/audio/skin.js.map +1 -1
  268. package/dist/dev/define/audio/skin.tailwind.d.ts.map +1 -1
  269. package/dist/dev/define/audio/skin.tailwind.js +67 -61
  270. package/dist/dev/define/audio/skin.tailwind.js.map +1 -1
  271. package/dist/dev/define/background/skin.css +1 -1
  272. package/dist/dev/define/background/skin.d.ts.map +1 -1
  273. package/dist/dev/define/background/skin.js +13 -1
  274. package/dist/dev/define/background/skin.js.map +1 -1
  275. package/dist/dev/define/base.css +23 -0
  276. package/dist/dev/define/media/dash-video.d.ts +14 -0
  277. package/dist/dev/define/media/dash-video.d.ts.map +1 -0
  278. package/dist/dev/define/media/dash-video.js +14 -0
  279. package/dist/dev/define/media/dash-video.js.map +1 -0
  280. package/dist/dev/define/shared.css +13 -0
  281. package/dist/dev/define/skin-mixin.d.ts +2 -2
  282. package/dist/dev/define/skin-mixin.d.ts.map +1 -1
  283. package/dist/dev/define/skin-mixin.js +16 -33
  284. package/dist/dev/define/skin-mixin.js.map +1 -1
  285. package/dist/dev/define/video/minimal-skin.css +486 -301
  286. package/dist/dev/define/video/minimal-skin.d.ts.map +1 -1
  287. package/dist/dev/define/video/minimal-skin.js +110 -103
  288. package/dist/dev/define/video/minimal-skin.js.map +1 -1
  289. package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -1
  290. package/dist/dev/define/video/minimal-skin.tailwind.js +123 -116
  291. package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -1
  292. package/dist/dev/define/video/skin.css +484 -289
  293. package/dist/dev/define/video/skin.d.ts.map +1 -1
  294. package/dist/dev/define/video/skin.js +105 -100
  295. package/dist/dev/define/video/skin.js.map +1 -1
  296. package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -1
  297. package/dist/dev/define/video/skin.tailwind.js +114 -108
  298. package/dist/dev/define/video/skin.tailwind.js.map +1 -1
  299. package/dist/dev/icons/dist/render/default/index.js +2 -1
  300. package/dist/dev/icons/dist/render/default/index.js.map +1 -1
  301. package/dist/dev/icons/dist/render/minimal/index.js +2 -1
  302. package/dist/dev/icons/dist/render/minimal/index.js.map +1 -1
  303. package/dist/dev/index.d.ts +6 -4
  304. package/dist/dev/index.js +4 -2
  305. package/dist/dev/media/background-video/index.d.ts +8 -1
  306. package/dist/dev/media/background-video/index.d.ts.map +1 -1
  307. package/dist/dev/media/background-video/index.js +5 -1
  308. package/dist/dev/media/background-video/index.js.map +1 -1
  309. package/dist/dev/media/container-element.js +5 -2
  310. package/dist/dev/media/container-element.js.map +1 -1
  311. package/dist/dev/media/dash-video/index.d.ts +13 -0
  312. package/dist/dev/media/dash-video/index.d.ts.map +1 -0
  313. package/dist/dev/media/dash-video/index.js +26 -0
  314. package/dist/dev/media/dash-video/index.js.map +1 -0
  315. package/dist/dev/media/hls-video/index.d.ts +2 -1
  316. package/dist/dev/media/hls-video/index.d.ts.map +1 -1
  317. package/dist/dev/media/hls-video/index.js +2 -1
  318. package/dist/dev/media/hls-video/index.js.map +1 -1
  319. package/dist/dev/media/simple-hls-video/index.d.ts +2 -1
  320. package/dist/dev/media/simple-hls-video/index.d.ts.map +1 -1
  321. package/dist/dev/media/simple-hls-video/index.js +3 -1
  322. package/dist/dev/media/simple-hls-video/index.js.map +1 -1
  323. package/dist/dev/player/context.d.ts +16 -2
  324. package/dist/dev/player/context.d.ts.map +1 -1
  325. package/dist/dev/player/context.js +6 -2
  326. package/dist/dev/player/context.js.map +1 -1
  327. package/dist/dev/player/create-player.d.ts +1 -1
  328. package/dist/dev/player/create-player.js +11 -3
  329. package/dist/dev/player/create-player.js.map +1 -1
  330. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js +10 -26
  331. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -1
  332. package/dist/dev/skins/dist/default/default/tailwind/components/button.js +4 -3
  333. package/dist/dev/skins/dist/default/default/tailwind/components/button.js.map +1 -1
  334. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js +1 -1
  335. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js.map +1 -1
  336. package/dist/dev/skins/dist/default/default/tailwind/components/error.js +3 -3
  337. package/dist/dev/skins/dist/default/default/tailwind/components/error.js.map +1 -1
  338. package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js +1 -1
  339. package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js.map +1 -1
  340. package/dist/dev/skins/dist/default/default/tailwind/components/popup.js +3 -3
  341. package/dist/dev/skins/dist/default/default/tailwind/components/popup.js.map +1 -1
  342. package/dist/dev/skins/dist/default/default/tailwind/components/poster.js +16 -0
  343. package/dist/dev/skins/dist/default/default/tailwind/components/poster.js.map +1 -0
  344. package/dist/dev/skins/dist/default/default/tailwind/components/preview.js +13 -0
  345. package/dist/dev/skins/dist/default/default/tailwind/components/preview.js.map +1 -0
  346. package/dist/dev/skins/dist/default/default/tailwind/components/root.js +1 -1
  347. package/dist/dev/skins/dist/default/default/tailwind/components/root.js.map +1 -1
  348. package/dist/dev/skins/dist/default/default/tailwind/components/seek.js +1 -1
  349. package/dist/dev/skins/dist/default/default/tailwind/components/seek.js.map +1 -1
  350. package/dist/dev/skins/dist/default/default/tailwind/components/slider.js +1 -1
  351. package/dist/dev/skins/dist/default/default/tailwind/components/slider.js.map +1 -1
  352. package/dist/dev/skins/dist/default/default/tailwind/components/surface.js +1 -1
  353. package/dist/dev/skins/dist/default/default/tailwind/components/surface.js.map +1 -1
  354. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +27 -16
  355. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
  356. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +11 -24
  357. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
  358. package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js +4 -3
  359. package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js.map +1 -1
  360. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js +1 -1
  361. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -1
  362. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js +3 -3
  363. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js.map +1 -1
  364. package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js +1 -1
  365. package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -1
  366. package/dist/dev/skins/dist/default/minimal/tailwind/components/playback-rate.js +6 -0
  367. package/dist/dev/skins/dist/default/minimal/tailwind/components/playback-rate.js.map +1 -0
  368. package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js +4 -3
  369. package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -1
  370. package/dist/dev/skins/dist/default/minimal/tailwind/components/poster.js +16 -0
  371. package/dist/dev/skins/dist/default/minimal/tailwind/components/poster.js.map +1 -0
  372. package/dist/dev/skins/dist/default/minimal/tailwind/components/preview.js +14 -0
  373. package/dist/dev/skins/dist/default/minimal/tailwind/components/preview.js.map +1 -0
  374. package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js +1 -1
  375. package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js.map +1 -1
  376. package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js +1 -1
  377. package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -1
  378. package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js +1 -1
  379. package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -1
  380. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js +1 -1
  381. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js.map +1 -1
  382. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +33 -16
  383. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
  384. package/dist/{default/skins/dist/default/minimal/tailwind/components → dev/skins/dist/default/shared/tailwind}/icon-state.js +6 -1
  385. package/dist/dev/skins/dist/default/shared/tailwind/icon-state.js.map +1 -0
  386. package/dist/dev/skins/dist/default/{minimal/tailwind/components → shared/tailwind}/tooltip-state.js +1 -1
  387. package/dist/dev/skins/dist/default/shared/tailwind/tooltip-state.js.map +1 -0
  388. package/dist/dev/store/container-mixin.d.ts +10 -5
  389. package/dist/dev/store/container-mixin.d.ts.map +1 -1
  390. package/dist/dev/store/container-mixin.js +16 -60
  391. package/dist/dev/store/container-mixin.js.map +1 -1
  392. package/dist/dev/store/media-attach-mixin.d.ts +19 -0
  393. package/dist/dev/store/media-attach-mixin.d.ts.map +1 -0
  394. package/dist/dev/store/media-attach-mixin.js +45 -0
  395. package/dist/dev/store/media-attach-mixin.js.map +1 -0
  396. package/dist/dev/store/provider-mixin.d.ts +19 -6
  397. package/dist/dev/store/provider-mixin.d.ts.map +1 -1
  398. package/dist/dev/store/provider-mixin.js +99 -9
  399. package/dist/dev/store/provider-mixin.js.map +1 -1
  400. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts +1 -1
  401. package/dist/dev/ui/alert-dialog/alert-dialog-element.js +1 -1
  402. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts +1 -1
  403. package/dist/dev/ui/buffering-indicator/buffering-indicator-element.js +1 -1
  404. package/dist/dev/ui/captions-button/captions-button-element.d.ts +1 -1
  405. package/dist/dev/ui/captions-button/captions-button-element.js +1 -1
  406. package/dist/dev/ui/context-part-element.d.ts +1 -1
  407. package/dist/dev/ui/controls/controls-element.js +1 -1
  408. package/dist/dev/ui/controls/controls-group-element.d.ts +1 -1
  409. package/dist/dev/ui/fullscreen-button/fullscreen-button-element.d.ts +1 -1
  410. package/dist/dev/ui/fullscreen-button/fullscreen-button-element.js +1 -1
  411. package/dist/dev/ui/media-button-element.d.ts +1 -1
  412. package/dist/dev/ui/media-ui-element.d.ts +1 -1
  413. package/dist/dev/ui/mute-button/mute-button-element.d.ts +1 -1
  414. package/dist/dev/ui/mute-button/mute-button-element.js +1 -1
  415. package/dist/dev/ui/pip-button/pip-button-element.d.ts +1 -1
  416. package/dist/dev/ui/pip-button/pip-button-element.js +1 -1
  417. package/dist/dev/ui/play-button/play-button-element.d.ts +1 -1
  418. package/dist/dev/ui/play-button/play-button-element.js +1 -1
  419. package/dist/dev/ui/playback-rate-button/playback-rate-button-element.d.ts +1 -1
  420. package/dist/dev/ui/playback-rate-button/playback-rate-button-element.js +1 -1
  421. package/dist/dev/ui/popover/popover-element.d.ts +1 -1
  422. package/dist/dev/ui/popover/popover-element.d.ts.map +1 -1
  423. package/dist/dev/ui/popover/popover-element.js +55 -4
  424. package/dist/dev/ui/popover/popover-element.js.map +1 -1
  425. package/dist/dev/ui/poster/poster-element.d.ts +1 -1
  426. package/dist/dev/ui/poster/poster-element.js +1 -1
  427. package/dist/dev/ui/seek-button/seek-button-element.d.ts +1 -1
  428. package/dist/dev/ui/seek-button/seek-button-element.js +1 -1
  429. package/dist/dev/ui/slider/context.d.ts +1 -1
  430. package/dist/dev/ui/slider/slider-buffer-element.d.ts +1 -1
  431. package/dist/dev/ui/slider/slider-element.d.ts +1 -1
  432. package/dist/dev/ui/slider/slider-element.js +1 -1
  433. package/dist/dev/ui/slider/slider-fill-element.d.ts +1 -1
  434. package/dist/dev/ui/slider/slider-track-element.d.ts +1 -1
  435. package/dist/dev/ui/thumbnail/thumbnail-element.d.ts +1 -1
  436. package/dist/dev/ui/thumbnail/thumbnail-element.js +1 -1
  437. package/dist/dev/ui/time/time-element.d.ts +1 -1
  438. package/dist/dev/ui/time/time-element.js +1 -1
  439. package/dist/dev/ui/time-slider/time-slider-element.d.ts +1 -1
  440. package/dist/dev/ui/time-slider/time-slider-element.js +2 -2
  441. package/dist/dev/ui/time-slider/time-slider-element.js.map +1 -1
  442. package/dist/dev/ui/tooltip/tooltip-element.d.ts +1 -1
  443. package/dist/dev/ui/tooltip/tooltip-element.d.ts.map +1 -1
  444. package/dist/dev/ui/tooltip/tooltip-element.js +54 -4
  445. package/dist/dev/ui/tooltip/tooltip-element.js.map +1 -1
  446. package/dist/dev/ui/tooltip/tooltip-group-element.js +5 -2
  447. package/dist/dev/ui/tooltip/tooltip-group-element.js.map +1 -1
  448. package/dist/dev/ui/volume-slider/volume-slider-element.d.ts +1 -1
  449. package/dist/dev/ui/volume-slider/volume-slider-element.js +3 -3
  450. package/dist/dev/ui/volume-slider/volume-slider-element.js.map +1 -1
  451. package/package.json +26 -13
  452. package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js.map +0 -1
  453. package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js +0 -28
  454. package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js.map +0 -1
  455. package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js.map +0 -1
  456. package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js +0 -28
  457. package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +0 -1
  458. package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js +0 -29
  459. package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js.map +0 -1
  460. package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js.map +0 -1
  461. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js +0 -29
  462. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js.map +0 -1
  463. package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"skin.js","names":["styles"],"sources":["../../../../src/define/audio/skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render';\nimport { createStyles, SkinMixin } from '../skin-mixin';\nimport styles from './skin.css?inline';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/mute-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"media-default-skin media-default-skin--audio\">\n <slot name=\"media\"></slot>\n\n <div class=\"media-surface media-controls\">\n <media-play-button commandfor=\"play-tooltip\" class=\"media-button media-button--icon media-button--play\">\n ${renderIcon('restart', { class: 'media-icon media-icon--restart' })}\n ${renderIcon('play', { class: 'media-icon media-icon--play' })}\n ${renderIcon('pause', { class: 'media-icon media-icon--pause' })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--replay\">Replay</span>\n <span class=\"media-tooltip-label media-tooltip-label--play\">Play</span>\n <span class=\"media-tooltip-label media-tooltip-label--pause\">Pause</span>\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek media-icon--flipped' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-time-group class=\"media-time\">\n <media-time type=\"current\" class=\"media-time__value\"></media-time>\n <media-time-slider class=\"media-slider\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n <media-slider-buffer class=\"media-slider__buffer\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb\"></media-slider-thumb>\n </media-time-slider>\n <media-time type=\"duration\" class=\"media-time__value\"></media-time>\n </media-time-group>\n\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"media-button media-button--icon media-button--playback-rate\"></media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"audio-volume-popover\" class=\"media-button media-button--icon media-button--mute\">\n ${renderIcon('volume-off', { class: 'media-icon media-icon--volume-off' })}\n ${renderIcon('volume-low', { class: 'media-icon media-icon--volume-low' })}\n ${renderIcon('volume-high', { class: 'media-icon media-icon--volume-high' })}\n </media-mute-button>\n\n <media-popover id=\"audio-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"media-surface media-popover media-popover--volume\">\n <media-volume-slider class=\"media-slider\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb media-slider__thumb--persistent\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n </div>\n </media-container>\n `;\n}\n\nexport class AudioSkinElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'audio-skin';\n static styles = createStyles(styles);\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(AudioSkinElement.tagName, AudioSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AudioSkinElement.tagName]: AudioSkinElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAiBA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;;;;;;YAMN,WAAW,WAAW,EAAE,OAAO,kCAAkC,CAAC,CAAC;YACnE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;YAC7D,WAAW,SAAS,EAAE,OAAO,gCAAgC,CAAC,CAAC;;;;;;;;yEAQF,CAAC,UAAU;;cAEtE,WAAW,QAAQ,EAAE,OAAO,mDAAmD,CAAC,CAAC;8CACjD,UAAU;;;;0BAI9B,UAAU;;;wEAGoC,UAAU;;cAEpE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;8CAC7B,UAAU;;;;yBAI/B,UAAU;;;;;;;;;;;;;;;;;;;;;YAqBvB,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;YACzE,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;YACzE,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;;;;;;;;;AAgBvF,IAAa,mBAAb,cAAsC,UAAU,gBAAgB,CAAC;;iBACrC;;;gBACV,aAAaA,aAAO;;;yBACX;;;AAG3B,eAAe,OAAO,iBAAiB,SAAS,iBAAiB"}
1
+ {"version":3,"file":"skin.js","names":[],"sources":["../../../../src/define/audio/skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render';\nimport { createStyles, SkinMixin } from '../skin-mixin';\nimport styles from './skin.css?inline';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/mute-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/tooltip-group';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"media-default-skin media-default-skin--audio\">\n <!-- @deprecated slot=\"media\" is no longer required, use the default slot instead -->\n <slot name=\"media\"></slot>\n <slot></slot>\n\n <div class=\"media-surface media-controls\">\n <media-tooltip-group>\n <media-play-button commandfor=\"play-tooltip\" class=\"media-button media-button--subtle media-button--icon media-button--play\">\n ${renderIcon('restart', { class: 'media-icon media-icon--restart' })}\n ${renderIcon('play', { class: 'media-icon media-icon--play' })}\n ${renderIcon('pause', { class: 'media-icon media-icon--pause' })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--replay\">Replay</span>\n <span class=\"media-tooltip-label media-tooltip-label--play\">Play</span>\n <span class=\"media-tooltip-label media-tooltip-label--pause\">Pause</span>\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"media-button media-button--subtle media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek media-icon--flipped' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"media-button media-button--subtle media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-time-group class=\"media-time\">\n <media-time type=\"current\" class=\"media-time__value\"></media-time>\n <media-time-slider class=\"media-slider\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n <media-slider-buffer class=\"media-slider__buffer\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb\"></media-slider-thumb>\n </media-time-slider>\n <media-time type=\"duration\" class=\"media-time__value\"></media-time>\n </media-time-group>\n\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"media-button media-button--subtle media-button--icon media-button--playback-rate\"></media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"media-surface media-tooltip\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"audio-volume-popover\" class=\"media-button media-button--subtle media-button--icon media-button--mute\">\n ${renderIcon('volume-off', { class: 'media-icon media-icon--volume-off' })}\n ${renderIcon('volume-low', { class: 'media-icon media-icon--volume-low' })}\n ${renderIcon('volume-high', { class: 'media-icon media-icon--volume-high' })}\n </media-mute-button>\n\n <media-popover id=\"audio-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"media-surface media-popover media-popover--volume\">\n <media-volume-slider class=\"media-slider\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb media-slider__thumb--persistent\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n </media-tooltip-group>\n </div>\n </media-container>\n `;\n}\n\nexport class AudioSkinElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'audio-skin';\n static styles = createStyles(styles);\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(AudioSkinElement.tagName, AudioSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AudioSkinElement.tagName]: AudioSkinElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAkBA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB,6SAAA,WAAA,WAAA,EAAA,OAAA,kCAAA,CAAA,CAAA,GAAA,WAAA,QAAA,EAAA,OAAA,+BAAA,CAAA,CAAA,GAAA,WAAA,SAAA,EAAA,OAAA,gCAAA,CAAA,CAAA,iZAAA,CAAA,UAAA,0HAAA,WAAA,QAAA,EAAA,OAAA,mDAAA,CAAA,CAAA,mCAAA,UAAA,4IAAA,UAAA,yFAAA,UAAA,0HAAA,WAAA,QAAA,EAAA,OAAA,+BAAA,CAAA,CAAA,mCAAA,UAAA,0IAAA,UAAA,k+BAAA,WAAA,cAAA,EAAA,OAAA,qCAAA,CAAA,CAAA,GAAA,WAAA,cAAA,EAAA,OAAA,qCAAA,CAAA,CAAA,GAAA,WAAA,eAAA,EAAA,OAAA,sCAAA,CAAA,CAAA;;AAGlB,IAAY,mBAAZ,cAA+B,UAAA,gBAAA,CAAA;;iBACb;;;;;;yBAEM;;;AAGxB,eAAc,OAAA,iBAAwB,SAAQ,iBAAiB"}
@@ -1,4 +1,6 @@
1
1
  import { SkinMixin } from "../skin-mixin.js";
2
+ import { iconState } from "../../skins/dist/default/shared/tailwind/icon-state.js";
3
+ import { tooltipState } from "../../skins/dist/default/shared/tailwind/tooltip-state.js";
2
4
  import "../media/container.js";
3
5
  import "../ui/mute-button.js";
4
6
  import "../ui/play-button.js";
@@ -8,93 +10,22 @@ import "../ui/seek-button.js";
8
10
  import "../ui/time.js";
9
11
  import "../ui/time-slider.js";
10
12
  import "../ui/tooltip.js";
13
+ import "../ui/tooltip-group.js";
11
14
  import "../ui/volume-slider.js";
15
+ import { renderIcon } from "../../icons/dist/render/default/index.js";
12
16
  import { button } from "../../skins/dist/default/default/tailwind/components/button.js";
13
17
  import { icon, iconContainer, iconFlipped } from "../../skins/dist/default/default/tailwind/components/icon.js";
14
18
  import { playbackRate } from "../../skins/dist/default/default/tailwind/components/playback-rate.js";
15
- import { root } from "../../skins/dist/default/default/tailwind/components/root.js";
16
19
  import { seek } from "../../skins/dist/default/default/tailwind/components/seek.js";
17
20
  import { time } from "../../skins/dist/default/default/tailwind/components/time.js";
18
- import { renderIcon } from "../../icons/dist/render/default/index.js";
19
- import { controls, iconState, popup, slider, tooltipState } from "../../skins/dist/default/default/tailwind/audio.tailwind.js";
21
+ import { controls, popup, root, slider } from "../../skins/dist/default/default/tailwind/audio.tailwind.js";
20
22
  import { ReactiveElement } from "@videojs/element";
21
23
  import { cn } from "@videojs/utils/style";
22
24
 
23
25
  //#region src/define/audio/skin.tailwind.ts
24
26
  const SEEK_TIME = 10;
25
27
  function getTemplateHTML() {
26
- return `
27
- <media-container class="${root}">
28
- <slot name="media"></slot>
29
-
30
- <div class="${controls}">
31
- <span class="${tooltipState.play.wrapper}">
32
- <media-play-button commandfor="play-tooltip" class="${cn(button.base, button.icon, iconState.play.button)}">
33
- ${renderIcon("restart", { class: cn(icon, iconState.play.restart) })}
34
- ${renderIcon("play", { class: cn(icon, iconState.play.play) })}
35
- ${renderIcon("pause", { class: cn(icon, iconState.play.pause) })}
36
- </media-play-button>
37
- <media-tooltip id="play-tooltip" side="top" class="${cn(popup.tooltip)}">
38
- <span class="${tooltipState.play.replay}">Replay</span>
39
- <span class="${tooltipState.play.play}">Play</span>
40
- <span class="${tooltipState.play.pause}">Pause</span>
41
- </media-tooltip>
42
- </span>
43
-
44
- <media-seek-button commandfor="seek-backward-tooltip" seconds="${-SEEK_TIME}" class="${cn(button.base, button.icon, seek.button)}">
45
- <span class="${iconContainer}">
46
- ${renderIcon("seek", { class: cn(icon, iconFlipped) })}
47
- <span class="${cn(seek.label, seek.labelBackward)}">${SEEK_TIME}</span>
48
- </span>
49
- </media-seek-button>
50
- <media-tooltip id="seek-backward-tooltip" side="top" class="${cn(popup.tooltip)}">
51
- Seek backward ${SEEK_TIME} seconds
52
- </media-tooltip>
53
-
54
- <media-seek-button commandfor="seek-forward-tooltip" seconds="${SEEK_TIME}" class="${cn(button.base, button.icon, seek.button)}">
55
- <span class="${iconContainer}">
56
- ${renderIcon("seek", { class: icon })}
57
- <span class="${cn(seek.label, seek.labelForward)}">${SEEK_TIME}</span>
58
- </span>
59
- </media-seek-button>
60
- <media-tooltip id="seek-forward-tooltip" side="top" class="${cn(popup.tooltip)}">
61
- Seek forward ${SEEK_TIME} seconds
62
- </media-tooltip>
63
-
64
- <media-time-group class="${time.group}">
65
- <media-time type="current" class="${time.current}"></media-time>
66
- <media-time-slider class="${slider.root}">
67
- <media-slider-track class="${slider.track}">
68
- <media-slider-fill class="${cn(slider.fill.base, slider.fill.fill)}"></media-slider-fill>
69
- <media-slider-buffer class="${cn(slider.fill.base, slider.fill.buffer)}"></media-slider-buffer>
70
- </media-slider-track>
71
- <media-slider-thumb class="${cn(slider.thumb.base, slider.thumb.interactive)}"></media-slider-thumb>
72
- </media-time-slider>
73
- <media-time type="duration" class="${time.duration}"></media-time>
74
- </media-time-group>
75
-
76
- <media-playback-rate-button commandfor="playback-rate-tooltip" class="${cn(button.base, button.icon, playbackRate.button)}"></media-playback-rate-button>
77
- <media-tooltip id="playback-rate-tooltip" side="top" class="${cn(popup.tooltip)}">
78
- Toggle playback rate
79
- </media-tooltip>
80
-
81
- <media-mute-button commandfor="audio-volume-popover" class="${cn(button.base, button.icon, iconState.mute.button)}">
82
- ${renderIcon("volume-off", { class: cn(icon, iconState.mute.volumeOff) })}
83
- ${renderIcon("volume-low", { class: cn(icon, iconState.mute.volumeLow) })}
84
- ${renderIcon("volume-high", { class: cn(icon, iconState.mute.volumeHigh) })}
85
- </media-mute-button>
86
-
87
- <media-popover id="audio-volume-popover" open-on-hover delay="200" close-delay="100" side="top" class="${cn(popup.popover, popup.volume)}">
88
- <media-volume-slider class="${slider.root}" orientation="vertical" thumb-alignment="edge">
89
- <media-slider-track class="${slider.track}">
90
- <media-slider-fill class="${cn(slider.fill.base, slider.fill.fill)}"></media-slider-fill>
91
- </media-slider-track>
92
- <media-slider-thumb class="${cn(slider.thumb.base, slider.thumb.persistent)}"></media-slider-thumb>
93
- </media-volume-slider>
94
- </media-popover>
95
- </div>
96
- </media-container>
97
- `;
28
+ return `<media-container class="${root}"> <slot name="media"></slot><slot></slot><div class="${controls}"> <media-tooltip-group><span class="${tooltipState.play.wrapper}"> <media-play-button commandfor="play-tooltip" class="${cn(button.base, button.subtle, button.icon, iconState.play.button)}"> ${renderIcon("restart", { class: cn(icon, iconState.play.restart) })} ${renderIcon("play", { class: cn(icon, iconState.play.play) })} ${renderIcon("pause", { class: cn(icon, iconState.play.pause) })} </media-play-button><media-tooltip id="play-tooltip" side="top" class="${cn(popup.tooltip)}"> <span class="${tooltipState.play.replay}">Replay</span><span class="${tooltipState.play.play}">Play</span><span class="${tooltipState.play.pause}">Pause</span></media-tooltip></span><media-seek-button commandfor="seek-backward-tooltip" seconds="${-SEEK_TIME}" class="${cn(button.base, button.subtle, button.icon, seek.button)}"> <span class="${iconContainer}"> ${renderIcon("seek", { class: cn(icon, iconFlipped) })} <span class="${cn(seek.label, seek.labelBackward)}">${SEEK_TIME}</span></span></media-seek-button><media-tooltip id="seek-backward-tooltip" side="top" class="${cn(popup.tooltip)}"> Seek backward ${SEEK_TIME} seconds </media-tooltip><media-seek-button commandfor="seek-forward-tooltip" seconds="${SEEK_TIME}" class="${cn(button.base, button.subtle, button.icon, seek.button)}"> <span class="${iconContainer}"> ${renderIcon("seek", { class: icon })} <span class="${cn(seek.label, seek.labelForward)}">${SEEK_TIME}</span></span></media-seek-button><media-tooltip id="seek-forward-tooltip" side="top" class="${cn(popup.tooltip)}"> Seek forward ${SEEK_TIME} seconds </media-tooltip><media-time-group class="${time.group}"> <media-time type="current" class="${time.current}"></media-time><media-time-slider class="${slider.root}"> <media-slider-track class="${slider.track}"> <media-slider-fill class="${cn(slider.fill.base, slider.fill.fill)}"></media-slider-fill><media-slider-buffer class="${cn(slider.fill.base, slider.fill.buffer)}"></media-slider-buffer></media-slider-track><media-slider-thumb class="${cn(slider.thumb.base, slider.thumb.interactive)}"></media-slider-thumb></media-time-slider><media-time type="duration" class="${time.duration}"></media-time></media-time-group><media-playback-rate-button commandfor="playback-rate-tooltip" class="${cn(button.base, button.subtle, button.icon, playbackRate.button)}"></media-playback-rate-button><media-tooltip id="playback-rate-tooltip" side="top" class="${cn(popup.tooltip)}"> Toggle playback rate </media-tooltip><media-mute-button commandfor="audio-volume-popover" class="${cn(button.base, button.subtle, button.icon, iconState.mute.button)}"> ${renderIcon("volume-off", { class: cn(icon, iconState.mute.volumeOff) })} ${renderIcon("volume-low", { class: cn(icon, iconState.mute.volumeLow) })} ${renderIcon("volume-high", { class: cn(icon, iconState.mute.volumeHigh) })} </media-mute-button><media-popover id="audio-volume-popover" open-on-hover delay="200" close-delay="100" side="top" class="${cn(popup.popover, popup.volume)}"> <media-volume-slider class="${slider.root}" orientation="vertical" thumb-alignment="edge"> <media-slider-track class="${slider.track}"> <media-slider-fill class="${cn(slider.fill.base, slider.fill.fill)}"></media-slider-fill></media-slider-track><media-slider-thumb class="${cn(slider.thumb.base, slider.thumb.persistent)}"></media-slider-thumb></media-volume-slider></media-popover></media-tooltip-group></div></media-container>`;
98
29
  }
99
30
  var AudioSkinTailwindElement = class extends SkinMixin(ReactiveElement) {
100
31
  static {
@@ -1 +1 @@
1
- {"version":3,"file":"skin.tailwind.js","names":[],"sources":["../../../../src/define/audio/skin.tailwind.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render';\nimport {\n button,\n controls,\n icon,\n iconContainer,\n iconFlipped,\n iconState,\n playbackRate,\n popup,\n root,\n seek,\n slider,\n time,\n tooltipState,\n} from '@videojs/skins/default/tailwind/audio.tailwind';\nimport { cn } from '@videojs/utils/style';\nimport { SkinMixin } from '../skin-mixin';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/mute-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"${root}\">\n <slot name=\"media\"></slot>\n\n <div class=\"${controls}\">\n <span class=\"${tooltipState.play.wrapper}\">\n <media-play-button commandfor=\"play-tooltip\" class=\"${cn(button.base, button.icon, iconState.play.button)}\">\n ${renderIcon('restart', { class: cn(icon, iconState.play.restart) })}\n ${renderIcon('play', { class: cn(icon, iconState.play.play) })}\n ${renderIcon('pause', { class: cn(icon, iconState.play.pause) })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.play.replay}\">Replay</span>\n <span class=\"${tooltipState.play.play}\">Play</span>\n <span class=\"${tooltipState.play.pause}\">Pause</span>\n </media-tooltip>\n </span>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"${cn(button.base, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: cn(icon, iconFlipped) })}\n <span class=\"${cn(seek.label, seek.labelBackward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"${cn(button.base, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: icon })}\n <span class=\"${cn(seek.label, seek.labelForward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-time-group class=\"${time.group}\">\n <media-time type=\"current\" class=\"${time.current}\"></media-time>\n <media-time-slider class=\"${slider.root}\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n <media-slider-buffer class=\"${cn(slider.fill.base, slider.fill.buffer)}\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"${cn(slider.thumb.base, slider.thumb.interactive)}\"></media-slider-thumb>\n </media-time-slider>\n <media-time type=\"duration\" class=\"${time.duration}\"></media-time>\n </media-time-group>\n\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"${cn(button.base, button.icon, playbackRate.button)}\"></media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"audio-volume-popover\" class=\"${cn(button.base, button.icon, iconState.mute.button)}\">\n ${renderIcon('volume-off', { class: cn(icon, iconState.mute.volumeOff) })}\n ${renderIcon('volume-low', { class: cn(icon, iconState.mute.volumeLow) })}\n ${renderIcon('volume-high', { class: cn(icon, iconState.mute.volumeHigh) })}\n </media-mute-button>\n\n <media-popover id=\"audio-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"${cn(popup.popover, popup.volume)}\">\n <media-volume-slider class=\"${slider.root}\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"${cn(slider.thumb.base, slider.thumb.persistent)}\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n </div>\n </media-container>\n `;\n}\n\nexport class AudioSkinTailwindElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'audio-skin-tailwind';\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(AudioSkinTailwindElement.tagName, AudioSkinTailwindElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AudioSkinTailwindElement.tagName]: AudioSkinTailwindElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAgCA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;8BACY,KAAK;;;oBAGf,SAAS;uBACN,aAAa,KAAK,QAAQ;gEACe,GAAG,OAAO,MAAM,OAAO,MAAM,UAAU,KAAK,OAAO,CAAC;cACtG,WAAW,WAAW,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,QAAQ,EAAE,CAAC,CAAC;cACnE,WAAW,QAAQ,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,KAAK,EAAE,CAAC,CAAC;cAC7D,WAAW,SAAS,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,MAAM,EAAE,CAAC,CAAC;;+DAEd,GAAG,MAAM,QAAQ,CAAC;2BACtD,aAAa,KAAK,OAAO;2BACzB,aAAa,KAAK,KAAK;2BACvB,aAAa,KAAK,MAAM;;;;yEAIsB,CAAC,UAAU,WAAW,GAAG,OAAO,MAAM,OAAO,MAAM,KAAK,OAAO,CAAC;yBAChH,cAAc;cACzB,WAAW,QAAQ,EAAE,OAAO,GAAG,MAAM,YAAY,EAAE,CAAC,CAAC;2BACxC,GAAG,KAAK,OAAO,KAAK,cAAc,CAAC,IAAI,UAAU;;;sEAGN,GAAG,MAAM,QAAQ,CAAC;0BAC9D,UAAU;;;wEAGoC,UAAU,WAAW,GAAG,OAAO,MAAM,OAAO,MAAM,KAAK,OAAO,CAAC;yBAC9G,cAAc;cACzB,WAAW,QAAQ,EAAE,OAAO,MAAM,CAAC,CAAC;2BACvB,GAAG,KAAK,OAAO,KAAK,aAAa,CAAC,IAAI,UAAU;;;qEAGN,GAAG,MAAM,QAAQ,CAAC;yBAC9D,UAAU;;;mCAGA,KAAK,MAAM;8CACA,KAAK,QAAQ;sCACrB,OAAO,KAAK;yCACT,OAAO,MAAM;0CACZ,GAAG,OAAO,KAAK,MAAM,OAAO,KAAK,KAAK,CAAC;4CACrC,GAAG,OAAO,KAAK,MAAM,OAAO,KAAK,OAAO,CAAC;;yCAE5C,GAAG,OAAO,MAAM,MAAM,OAAO,MAAM,YAAY,CAAC;;+CAE1C,KAAK,SAAS;;;iFAGoB,GAAG,OAAO,MAAM,OAAO,MAAM,aAAa,OAAO,CAAC;sEAC7D,GAAG,MAAM,QAAQ,CAAC;;;;sEAIlB,GAAG,OAAO,MAAM,OAAO,MAAM,UAAU,KAAK,OAAO,CAAC;YAC9G,WAAW,cAAc,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,UAAU,EAAE,CAAC,CAAC;YACxE,WAAW,cAAc,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,UAAU,EAAE,CAAC,CAAC;YACxE,WAAW,eAAe,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,WAAW,EAAE,CAAC,CAAC;;;iHAG2B,GAAG,MAAM,SAAS,MAAM,OAAO,CAAC;wCACzG,OAAO,KAAK;yCACX,OAAO,MAAM;0CACZ,GAAG,OAAO,KAAK,MAAM,OAAO,KAAK,KAAK,CAAC;;yCAExC,GAAG,OAAO,MAAM,MAAM,OAAO,MAAM,WAAW,CAAC;;;;;;;AAQxF,IAAa,2BAAb,cAA8C,UAAU,gBAAgB,CAAC;;iBAC7C;;;yBACD;;;AAG3B,eAAe,OAAO,yBAAyB,SAAS,yBAAyB"}
1
+ {"version":3,"file":"skin.tailwind.js","names":[],"sources":["../../../../src/define/audio/skin.tailwind.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render';\nimport {\n button,\n controls,\n icon,\n iconContainer,\n iconFlipped,\n iconState,\n playbackRate,\n popup,\n root,\n seek,\n slider,\n time,\n tooltipState,\n} from '@videojs/skins/default/tailwind/audio.tailwind';\nimport { cn } from '@videojs/utils/style';\nimport { SkinMixin } from '../skin-mixin';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/mute-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/tooltip-group';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"${root}\">\n <!-- @deprecated slot=\"media\" is no longer required, use the default slot instead -->\n <slot name=\"media\"></slot>\n <slot></slot>\n\n <div class=\"${controls}\">\n <media-tooltip-group>\n <span class=\"${tooltipState.play.wrapper}\">\n <media-play-button commandfor=\"play-tooltip\" class=\"${cn(button.base, button.subtle, button.icon, iconState.play.button)}\">\n ${renderIcon('restart', { class: cn(icon, iconState.play.restart) })}\n ${renderIcon('play', { class: cn(icon, iconState.play.play) })}\n ${renderIcon('pause', { class: cn(icon, iconState.play.pause) })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.play.replay}\">Replay</span>\n <span class=\"${tooltipState.play.play}\">Play</span>\n <span class=\"${tooltipState.play.pause}\">Pause</span>\n </media-tooltip>\n </span>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"${cn(button.base, button.subtle, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: cn(icon, iconFlipped) })}\n <span class=\"${cn(seek.label, seek.labelBackward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"${cn(button.base, button.subtle, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: icon })}\n <span class=\"${cn(seek.label, seek.labelForward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-time-group class=\"${time.group}\">\n <media-time type=\"current\" class=\"${time.current}\"></media-time>\n <media-time-slider class=\"${slider.root}\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n <media-slider-buffer class=\"${cn(slider.fill.base, slider.fill.buffer)}\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"${cn(slider.thumb.base, slider.thumb.interactive)}\"></media-slider-thumb>\n </media-time-slider>\n <media-time type=\"duration\" class=\"${time.duration}\"></media-time>\n </media-time-group>\n\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"${cn(button.base, button.subtle, button.icon, playbackRate.button)}\"></media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"audio-volume-popover\" class=\"${cn(button.base, button.subtle, button.icon, iconState.mute.button)}\">\n ${renderIcon('volume-off', { class: cn(icon, iconState.mute.volumeOff) })}\n ${renderIcon('volume-low', { class: cn(icon, iconState.mute.volumeLow) })}\n ${renderIcon('volume-high', { class: cn(icon, iconState.mute.volumeHigh) })}\n </media-mute-button>\n\n <media-popover id=\"audio-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"${cn(popup.popover, popup.volume)}\">\n <media-volume-slider class=\"${slider.root}\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"${cn(slider.thumb.base, slider.thumb.persistent)}\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n </media-tooltip-group>\n </div>\n </media-container>\n `;\n}\n\nexport class AudioSkinTailwindElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'audio-skin-tailwind';\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(AudioSkinTailwindElement.tagName, AudioSkinTailwindElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AudioSkinTailwindElement.tagName]: AudioSkinTailwindElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAiCA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB,2BAAA,KAAA,wDAAA,SAAA,uCAAA,aAAA,KAAA,QAAA,yDAAA,GAAA,OAAA,MAAA,OAAA,QAAA,OAAA,MAAA,UAAA,KAAA,OAAA,CAAA,KAAA,WAAA,WAAA,EAAA,OAAA,GAAA,MAAA,UAAA,KAAA,QAAA,EAAA,CAAA,CAAA,GAAA,WAAA,QAAA,EAAA,OAAA,GAAA,MAAA,UAAA,KAAA,KAAA,EAAA,CAAA,CAAA,GAAA,WAAA,SAAA,EAAA,OAAA,GAAA,MAAA,UAAA,KAAA,MAAA,EAAA,CAAA,CAAA,0EAAA,GAAA,MAAA,QAAA,CAAA,kBAAA,aAAA,KAAA,OAAA,8BAAA,aAAA,KAAA,KAAA,4BAAA,aAAA,KAAA,MAAA,sGAAA,CAAA,UAAA,WAAA,GAAA,OAAA,MAAA,OAAA,QAAA,OAAA,MAAA,KAAA,OAAA,CAAA,kBAAA,cAAA,KAAA,WAAA,QAAA,EAAA,OAAA,GAAA,MAAA,YAAA,EAAA,CAAA,CAAA,gBAAA,GAAA,KAAA,OAAA,KAAA,cAAA,CAAA,IAAA,UAAA,gGAAA,GAAA,MAAA,QAAA,CAAA,mBAAA,UAAA,yFAAA,UAAA,WAAA,GAAA,OAAA,MAAA,OAAA,QAAA,OAAA,MAAA,KAAA,OAAA,CAAA,kBAAA,cAAA,KAAA,WAAA,QAAA,EAAA,OAAA,MAAA,CAAA,CAAA,gBAAA,GAAA,KAAA,OAAA,KAAA,aAAA,CAAA,IAAA,UAAA,+FAAA,GAAA,MAAA,QAAA,CAAA,kBAAA,UAAA,oDAAA,KAAA,MAAA,uCAAA,KAAA,QAAA,2CAAA,OAAA,KAAA,gCAAA,OAAA,MAAA,+BAAA,GAAA,OAAA,KAAA,MAAA,OAAA,KAAA,KAAA,CAAA,oDAAA,GAAA,OAAA,KAAA,MAAA,OAAA,KAAA,OAAA,CAAA,0EAAA,GAAA,OAAA,MAAA,MAAA,OAAA,MAAA,YAAA,CAAA,gFAAA,KAAA,SAAA,0GAAA,GAAA,OAAA,MAAA,OAAA,QAAA,OAAA,MAAA,aAAA,OAAA,CAAA,6FAAA,GAAA,MAAA,QAAA,CAAA,sGAAA,GAAA,OAAA,MAAA,OAAA,QAAA,OAAA,MAAA,UAAA,KAAA,OAAA,CAAA,KAAA,WAAA,cAAA,EAAA,OAAA,GAAA,MAAA,UAAA,KAAA,UAAA,EAAA,CAAA,CAAA,GAAA,WAAA,cAAA,EAAA,OAAA,GAAA,MAAA,UAAA,KAAA,UAAA,EAAA,CAAA,CAAA,GAAA,WAAA,eAAA,EAAA,OAAA,GAAA,MAAA,UAAA,KAAA,WAAA,EAAA,CAAA,CAAA,8HAAA,GAAA,MAAA,SAAA,MAAA,OAAA,CAAA,iCAAA,OAAA,KAAA,8EAAA,OAAA,MAAA,+BAAA,GAAA,OAAA,KAAA,MAAA,OAAA,KAAA,KAAA,CAAA,wEAAA,GAAA,OAAA,MAAA,MAAA,OAAA,MAAA,WAAA,CAAA;;AAGlB,IAAY,2BAAZ,cAA+B,UAAA,gBAAA,CAAA;;iBACb;;;;;;AAIlB,eAAe,OAAO,yBAAqB,SAAS,yBAAA"}
@@ -11,7 +11,7 @@ background-video-skin {
11
11
  object-fit: var(--media-object-fit);
12
12
  }
13
13
 
14
- background-video-skin > [slot="media"] {
14
+ background-video-skin > background-video {
15
15
  position: absolute;
16
16
  inset: 0;
17
17
  width: 100%;
@@ -1,14 +1,19 @@
1
1
  import { safeDefine } from "../safe-define.js";
2
+ import skin_default from "../../_virtual/inline-css_src/define/background/skin.js";
2
3
  import { ReactiveElement } from "@videojs/element";
3
4
  import { namedNodeMapToObject } from "@videojs/utils/dom";
4
5
 
5
6
  //#region src/define/background/skin.ts
7
+ const STYLES_ID = "__media-background-styles";
8
+ function ensureBackgroundStyles() {
9
+ if (document.getElementById(STYLES_ID)) return;
10
+ const style = document.createElement("style");
11
+ style.id = STYLES_ID;
12
+ style.textContent = skin_default;
13
+ document.head.appendChild(style);
14
+ }
6
15
  function getTemplateHTML(_attrs) {
7
- return `
8
- <media-container>
9
- <slot name="media" slot="media"></slot>
10
- </media-container>
11
- `;
16
+ return `<media-container><slot name="media"></slot><slot></slot></media-container>`;
12
17
  }
13
18
  var BackgroundVideoSkinElement = class extends ReactiveElement {
14
19
  static {
@@ -22,6 +27,7 @@ var BackgroundVideoSkinElement = class extends ReactiveElement {
22
27
  }
23
28
  constructor() {
24
29
  super();
30
+ ensureBackgroundStyles();
25
31
  if (!this.shadowRoot) {
26
32
  this.attachShadow(this.constructor.shadowRootOptions);
27
33
  this.shadowRoot.innerHTML = getTemplateHTML(namedNodeMapToObject(this.attributes));
@@ -1 +1 @@
1
- {"version":3,"file":"skin.js","names":[],"sources":["../../../../src/define/background/skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { namedNodeMapToObject } from '@videojs/utils/dom';\nimport { safeDefine } from '../safe-define';\n\nfunction getTemplateHTML(_attrs: Record<string, string>) {\n return /*html*/ `\n <media-container>\n <slot name=\"media\" slot=\"media\"></slot>\n </media-container>\n `;\n}\n\nexport class BackgroundVideoSkinElement extends ReactiveElement {\n static readonly tagName = 'background-video-skin';\n static shadowRootOptions = { mode: 'open' as ShadowRootMode };\n static getTemplateHTML = getTemplateHTML;\n\n constructor() {\n super();\n\n if (!this.shadowRoot) {\n this.attachShadow((this.constructor as typeof BackgroundVideoSkinElement).shadowRootOptions);\n this.shadowRoot!.innerHTML = getTemplateHTML(namedNodeMapToObject(this.attributes));\n }\n }\n}\n\nsafeDefine(BackgroundVideoSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [BackgroundVideoSkinElement.tagName]: BackgroundVideoSkinElement;\n }\n}\n"],"mappings":";;;;;AAIA,SAAS,gBAAgB,QAAgC;AACvD,QAAgB;;;;;;AAOlB,IAAa,6BAAb,cAAgD,gBAAgB;;iBACpC;;;2BACC,EAAE,MAAM,QAA0B;;;yBACpC;;CAEzB,cAAc;AACZ,SAAO;AAEP,MAAI,CAAC,KAAK,YAAY;AACpB,QAAK,aAAc,KAAK,YAAkD,kBAAkB;AAC5F,QAAK,WAAY,YAAY,gBAAgB,qBAAqB,KAAK,WAAW,CAAC;;;;AAKzF,WAAW,2BAA2B"}
1
+ {"version":3,"file":"skin.js","names":[],"sources":["../../../../src/define/background/skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { namedNodeMapToObject } from '@videojs/utils/dom';\nimport { safeDefine } from '../safe-define';\nimport styles from './skin.css?inline';\n\nconst STYLES_ID = '__media-background-styles';\n\nfunction ensureBackgroundStyles(): void {\n if (document.getElementById(STYLES_ID)) return;\n const style = document.createElement('style');\n style.id = STYLES_ID;\n style.textContent = styles;\n document.head.appendChild(style);\n}\n\nfunction getTemplateHTML(_attrs: Record<string, string>) {\n return /*html*/ `\n <media-container>\n <!-- @deprecated slot=\"media\" is no longer required, use the default slot instead -->\n <slot name=\"media\"></slot>\n <slot></slot>\n </media-container>\n `;\n}\n\nexport class BackgroundVideoSkinElement extends ReactiveElement {\n static readonly tagName = 'background-video-skin';\n static shadowRootOptions = { mode: 'open' as ShadowRootMode };\n static getTemplateHTML = getTemplateHTML;\n\n constructor() {\n super();\n\n ensureBackgroundStyles();\n\n if (!this.shadowRoot) {\n this.attachShadow((this.constructor as typeof BackgroundVideoSkinElement).shadowRootOptions);\n this.shadowRoot!.innerHTML = getTemplateHTML(namedNodeMapToObject(this.attributes));\n }\n }\n}\n\nsafeDefine(BackgroundVideoSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [BackgroundVideoSkinElement.tagName]: BackgroundVideoSkinElement;\n }\n}\n"],"mappings":";;;;;;AAKA,MAAM,YAAY;AAElB,SAAS,yBAA+B;AACtC,KAAI,SAAS,eAAe,UAAU,CAAE;CACxC,MAAM,QAAQ,SAAS,cAAc,QAAQ;AAC7C,OAAM,KAAK;AACX,OAAM,cAAc;AACpB,UAAS,KAAK,YAAY,MAAM;;AAGlC,SAAS,gBAAgB,QAAgC;AACvD,QAAgB;;AAGlB,IAAY,6BAAZ,cAA+B,gBAAA;;iBACb;;;2BACG,EAAA,MAAA,QAAA;;;yBAClB;;;AAGH,SAAO;AAEL,0BAA0B;;AAG1B,QAAA,aAAc,KAAA,YAAA,kBAAA;AACZ,QAAO,WAAA,YAAA,gBAAA,qBAAA,KAAA,WAAA,CAAA;;;;AAKX,WAAW,2BAAmB"}
@@ -0,0 +1,23 @@
1
+ video-player {
2
+ display: contents;
3
+ }
4
+
5
+ /*
6
+ Required to override any default video and image styles (such as
7
+ Tailwind's CSS reset) and ensure they fill the container as expected.
8
+ */
9
+ video-player video,
10
+ video-player [slot="poster"] {
11
+ display: block;
12
+ width: 100%;
13
+ height: 100%;
14
+ }
15
+
16
+ video-player video::-webkit-media-text-track-container {
17
+ transition: translate var(--media-caption-track-duration, 0) ease-out;
18
+ transition-delay: var(--media-caption-track-delay, 0);
19
+ translate: 0 var(--media-caption-track-y, 0);
20
+ scale: 0.98;
21
+ z-index: 1;
22
+ font-family: inherit;
23
+ }
@@ -0,0 +1,14 @@
1
+ import { safeDefine } from "../safe-define.js";
2
+ import { DashVideo } from "../../media/dash-video/index.js";
3
+
4
+ //#region src/define/media/dash-video.ts
5
+ var DashVideoElement = class extends DashVideo {
6
+ static {
7
+ this.tagName = "dash-video";
8
+ }
9
+ };
10
+ safeDefine(DashVideoElement);
11
+
12
+ //#endregion
13
+ export { DashVideoElement };
14
+ //# sourceMappingURL=dash-video.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dash-video.js","names":[],"sources":["../../../../src/define/media/dash-video.ts"],"sourcesContent":["import { DashVideo } from '../../media/dash-video';\nimport { safeDefine } from '../safe-define';\n\nexport class DashVideoElement extends DashVideo {\n static readonly tagName = 'dash-video';\n}\n\nsafeDefine(DashVideoElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [DashVideoElement.tagName]: DashVideoElement;\n }\n}\n"],"mappings":";;;;AAGA,IAAa,mBAAb,cAAsC,UAAU;;iBACpB;;;AAG5B,WAAW,iBAAiB"}
@@ -0,0 +1,13 @@
1
+ media-tooltip-group {
2
+ display: contents;
3
+ }
4
+
5
+ /* Fixes a weird issue with Safari when setting aspect-ratio */
6
+ :host {
7
+ display: grid;
8
+ }
9
+
10
+ /* Hide volume popover when volume control is unsupported (e.g., iOS Safari). */
11
+ .media-popover--volume:has(media-volume-slider[data-availability="unsupported"]) {
12
+ display: none;
13
+ }
@@ -1,42 +1,24 @@
1
- //#region src/define/skin-mixin.ts
2
- /**
3
- * Light DOM stylesheet that bridges CSS custom properties set by skins
4
- * to native WebKit text track pseudo-elements on the slotted `<video>`.
5
- *
6
- * `::slotted(video)::-webkit-media-text-track-container` is invalid per
7
- * CSS spec, so this bridge lives in light DOM where it can directly
8
- * target the video element's pseudo-elements.
9
- */
10
- const NATIVE_CAPTION_BRIDGE_CSS = `
11
- .media-skin > video::-webkit-media-text-track-container {
12
- transition: transform var(--media-caption-track-duration, 150ms) ease-out;
13
- transition-delay: var(--media-caption-track-delay, 600ms);
14
- transform: translateY(var(--media-caption-track-y, 0)) scale(0.98);
15
- z-index: var(--media-caption-track-z, 1);
16
- font-family: inherit;
17
- }
1
+ import base_default from "../_virtual/inline-css_src/define/base.js";
2
+ import shared_default from "../_virtual/inline-css_src/define/shared.js";
18
3
 
19
- @media (prefers-reduced-motion: reduce) {
20
- .media-skin > video::-webkit-media-text-track-container {
21
- transition-duration: 50ms;
22
- }
23
- }
24
- `;
25
- const BRIDGE_ID = "media-caption-bridge";
26
- function ensureCaptionBridge() {
27
- if (document.getElementById(BRIDGE_ID)) return;
4
+ //#region src/define/skin-mixin.ts
5
+ const STYLES_ID = "__media-styles";
6
+ function ensureRootStyles() {
7
+ if (document.getElementById(STYLES_ID)) return;
28
8
  const style = document.createElement("style");
29
- style.id = BRIDGE_ID;
30
- style.textContent = NATIVE_CAPTION_BRIDGE_CSS;
9
+ style.id = STYLES_ID;
10
+ style.textContent = base_default;
31
11
  document.head.appendChild(style);
32
12
  }
13
+ const sharedSheet = new CSSStyleSheet();
14
+ sharedSheet.replaceSync(shared_default);
33
15
  /**
34
16
  * Mixin for skin elements that renders the template from a static
35
17
  * `getTemplateHTML` method into a shadow root. Native `<slot>` elements
36
18
  * handle light DOM projection automatically.
37
19
  *
38
- * When `static styles` is set, the stylesheet is adopted into the shadow
39
- * root via `adoptedStyleSheets`.
20
+ * When `static styles` is set, the stylesheet is adopted into the
21
+ * shadow root via `adoptedStyleSheets`.
40
22
  */
41
23
  function SkinMixin(BaseClass) {
42
24
  class SkinElement extends BaseClass {
@@ -45,12 +27,13 @@ function SkinMixin(BaseClass) {
45
27
  }
46
28
  constructor(...args) {
47
29
  super(...args);
48
- this.classList.add("media-skin");
49
- ensureCaptionBridge();
30
+ ensureRootStyles();
50
31
  if (!this.shadowRoot) {
51
32
  const ctor = this.constructor;
52
33
  this.attachShadow(ctor.shadowRootOptions);
53
- if (ctor.styles) this.shadowRoot.adoptedStyleSheets = [ctor.styles];
34
+ const sheets = [sharedSheet];
35
+ if (ctor.styles) sheets.push(ctor.styles);
36
+ this.shadowRoot.adoptedStyleSheets = sheets;
54
37
  if (ctor.getTemplateHTML) this.shadowRoot.innerHTML = ctor.getTemplateHTML();
55
38
  }
56
39
  }
@@ -1 +1 @@
1
- {"version":3,"file":"skin-mixin.js","names":[],"sources":["../../../src/define/skin-mixin.ts"],"sourcesContent":["import type { ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\n/**\n * Light DOM stylesheet that bridges CSS custom properties set by skins\n * to native WebKit text track pseudo-elements on the slotted `<video>`.\n *\n * `::slotted(video)::-webkit-media-text-track-container` is invalid per\n * CSS spec, so this bridge lives in light DOM where it can directly\n * target the video element's pseudo-elements.\n */\nconst NATIVE_CAPTION_BRIDGE_CSS = /* css */ `\n.media-skin > video::-webkit-media-text-track-container {\n transition: transform var(--media-caption-track-duration, 150ms) ease-out;\n transition-delay: var(--media-caption-track-delay, 600ms);\n transform: translateY(var(--media-caption-track-y, 0)) scale(0.98);\n z-index: var(--media-caption-track-z, 1);\n font-family: inherit;\n}\n\n@media (prefers-reduced-motion: reduce) {\n .media-skin > video::-webkit-media-text-track-container {\n transition-duration: 50ms;\n }\n}\n`;\n\nconst BRIDGE_ID = 'media-caption-bridge';\n\nfunction ensureCaptionBridge(): void {\n if (document.getElementById(BRIDGE_ID)) return;\n const style = document.createElement('style');\n style.id = BRIDGE_ID;\n style.textContent = NATIVE_CAPTION_BRIDGE_CSS;\n document.head.appendChild(style);\n}\n\n/**\n * Mixin for skin elements that renders the template from a static\n * `getTemplateHTML` method into a shadow root. Native `<slot>` elements\n * handle light DOM projection automatically.\n *\n * When `static styles` is set, the stylesheet is adopted into the shadow\n * root via `adoptedStyleSheets`.\n */\nexport function SkinMixin<Base extends Constructor<ReactiveElement>>(\n BaseClass: Base\n): Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet } {\n class SkinElement extends (BaseClass as Constructor<ReactiveElement>) {\n static shadowRootOptions: ShadowRootInit = { mode: 'open' };\n static styles?: CSSStyleSheet;\n\n constructor(...args: any[]) {\n super(...args);\n\n this.classList.add('media-skin');\n ensureCaptionBridge();\n\n if (!this.shadowRoot) {\n const ctor = this.constructor as typeof SkinElement & { getTemplateHTML?: () => string };\n this.attachShadow(ctor.shadowRootOptions);\n\n if (ctor.styles) {\n this.shadowRoot!.adoptedStyleSheets = [ctor.styles];\n }\n\n if (ctor.getTemplateHTML) {\n this.shadowRoot!.innerHTML = ctor.getTemplateHTML();\n }\n }\n }\n }\n\n return SkinElement as unknown as Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet };\n}\n\n/** Create a shared `CSSStyleSheet` from a CSS string. */\nexport function createStyles(css: string): CSSStyleSheet {\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(css);\n return sheet;\n}\n"],"mappings":";;;;;;;;;AAWA,MAAM,4BAAsC;;;;;;;;;;;;;;;AAgB5C,MAAM,YAAY;AAElB,SAAS,sBAA4B;AACnC,KAAI,SAAS,eAAe,UAAU,CAAE;CACxC,MAAM,QAAQ,SAAS,cAAc,QAAQ;AAC7C,OAAM,KAAK;AACX,OAAM,cAAc;AACpB,UAAS,KAAK,YAAY,MAAM;;;;;;;;;;AAWlC,SAAgB,UACd,WACsE;CACtE,MAAM,oBAAqB,UAA2C;;4BACzB,EAAE,MAAM,QAAQ;;EAG3D,YAAY,GAAG,MAAa;AAC1B,SAAM,GAAG,KAAK;AAEd,QAAK,UAAU,IAAI,aAAa;AAChC,wBAAqB;AAErB,OAAI,CAAC,KAAK,YAAY;IACpB,MAAM,OAAO,KAAK;AAClB,SAAK,aAAa,KAAK,kBAAkB;AAEzC,QAAI,KAAK,OACP,MAAK,WAAY,qBAAqB,CAAC,KAAK,OAAO;AAGrD,QAAI,KAAK,gBACP,MAAK,WAAY,YAAY,KAAK,iBAAiB;;;;AAM3D,QAAO;;;AAIT,SAAgB,aAAa,KAA4B;CACvD,MAAM,QAAQ,IAAI,eAAe;AACjC,OAAM,YAAY,IAAI;AACtB,QAAO"}
1
+ {"version":3,"file":"skin-mixin.js","names":["rootStyles","sharedStyles"],"sources":["../../../src/define/skin-mixin.ts"],"sourcesContent":["import type { ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\nimport rootStyles from './base.css?inline';\nimport sharedStyles from './shared.css?inline';\n\nconst STYLES_ID = '__media-styles';\n\nfunction ensureRootStyles(): void {\n if (document.getElementById(STYLES_ID)) return;\n const style = document.createElement('style');\n style.id = STYLES_ID;\n style.textContent = rootStyles;\n document.head.appendChild(style);\n}\n\nconst sharedSheet = new CSSStyleSheet();\nsharedSheet.replaceSync(sharedStyles);\n\n/**\n * Mixin for skin elements that renders the template from a static\n * `getTemplateHTML` method into a shadow root. Native `<slot>` elements\n * handle light DOM projection automatically.\n *\n * When `static styles` is set, the stylesheet is adopted into the\n * shadow root via `adoptedStyleSheets`.\n */\nexport function SkinMixin<Base extends Constructor<ReactiveElement>>(\n BaseClass: Base\n): Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet } {\n class SkinElement extends (BaseClass as Constructor<ReactiveElement>) {\n static shadowRootOptions: ShadowRootInit = { mode: 'open' };\n static styles?: CSSStyleSheet;\n\n constructor(...args: any[]) {\n super(...args);\n\n ensureRootStyles();\n\n if (!this.shadowRoot) {\n const ctor = this.constructor as typeof SkinElement & { getTemplateHTML?: () => string };\n this.attachShadow(ctor.shadowRootOptions);\n\n const sheets: CSSStyleSheet[] = [sharedSheet];\n if (ctor.styles) {\n sheets.push(ctor.styles);\n }\n this.shadowRoot!.adoptedStyleSheets = sheets;\n\n if (ctor.getTemplateHTML) {\n this.shadowRoot!.innerHTML = ctor.getTemplateHTML();\n }\n }\n }\n }\n\n return SkinElement as unknown as Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet };\n}\n\n/** Create a shared `CSSStyleSheet` from a CSS string. */\nexport function createStyles(css: string): CSSStyleSheet {\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(css);\n return sheet;\n}\n"],"mappings":";;;;AAKA,MAAM,YAAY;AAElB,SAAS,mBAAyB;AAChC,KAAI,SAAS,eAAe,UAAU,CAAE;CACxC,MAAM,QAAQ,SAAS,cAAc,QAAQ;AAC7C,OAAM,KAAK;AACX,OAAM,cAAcA;AACpB,UAAS,KAAK,YAAY,MAAM;;AAGlC,MAAM,cAAc,IAAI,eAAe;AACvC,YAAY,YAAYC,eAAa;;;;;;;;;AAUrC,SAAgB,UACd,WACsE;CACtE,MAAM,oBAAqB,UAA2C;;4BACzB,EAAE,MAAM,QAAQ;;EAG3D,YAAY,GAAG,MAAa;AAC1B,SAAM,GAAG,KAAK;AAEd,qBAAkB;AAElB,OAAI,CAAC,KAAK,YAAY;IACpB,MAAM,OAAO,KAAK;AAClB,SAAK,aAAa,KAAK,kBAAkB;IAEzC,MAAM,SAA0B,CAAC,YAAY;AAC7C,QAAI,KAAK,OACP,QAAO,KAAK,KAAK,OAAO;AAE1B,SAAK,WAAY,qBAAqB;AAEtC,QAAI,KAAK,gBACP,MAAK,WAAY,YAAY,KAAK,iBAAiB;;;;AAM3D,QAAO;;;AAIT,SAAgB,aAAa,KAA4B;CACvD,MAAM,QAAQ,IAAI,eAAe;AACjC,OAAM,YAAY,IAAI;AACtB,QAAO"}