@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.
- package/README.md +2 -2
- package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js +6 -0
- package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -0
- package/dist/default/_virtual/inline-css_src/define/audio/skin.js +6 -0
- package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -0
- package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +6 -0
- package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -0
- package/dist/default/_virtual/inline-css_src/define/video/skin.js +6 -0
- package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -0
- package/dist/default/define/audio/minimal-skin.css +630 -5
- package/dist/default/define/audio/minimal-skin.js +97 -9
- package/dist/default/define/audio/minimal-skin.js.map +1 -1
- package/dist/default/define/audio/minimal-skin.tailwind.js +121 -0
- package/dist/default/define/audio/minimal-skin.tailwind.js.map +1 -0
- package/dist/default/define/audio/skin.css +655 -6
- package/dist/default/define/audio/skin.js +88 -9
- package/dist/default/define/audio/skin.js.map +1 -1
- package/dist/default/define/audio/skin.tailwind.js +111 -0
- package/dist/default/define/audio/skin.tailwind.js.map +1 -0
- package/dist/default/define/media/simple-hls-video.js +13 -0
- package/dist/default/define/media/simple-hls-video.js.map +1 -0
- package/dist/default/define/skin-mixin.js +53 -19
- package/dist/default/define/skin-mixin.js.map +1 -1
- package/dist/default/define/ui/alert-dialog-close.js +8 -0
- package/dist/default/define/ui/alert-dialog-close.js.map +1 -0
- package/dist/default/define/ui/alert-dialog-description.js +8 -0
- package/dist/default/define/ui/alert-dialog-description.js.map +1 -0
- package/dist/default/define/ui/alert-dialog-title.js +8 -0
- package/dist/default/define/ui/alert-dialog-title.js.map +1 -0
- package/dist/default/define/ui/alert-dialog.js +14 -0
- package/dist/default/define/ui/alert-dialog.js.map +1 -0
- package/dist/default/define/ui/captions-button.js +7 -0
- package/dist/default/define/ui/captions-button.js.map +1 -0
- package/dist/default/define/ui/slider-thumbnail.js +8 -0
- package/dist/default/define/ui/slider-thumbnail.js.map +1 -0
- package/dist/default/define/ui/slider.js +2 -0
- package/dist/default/define/ui/slider.js.map +1 -1
- package/dist/default/define/ui/time-slider.js +4 -0
- package/dist/default/define/ui/time-slider.js.map +1 -1
- package/dist/default/define/ui/tooltip-group.js +8 -0
- package/dist/default/define/ui/tooltip-group.js.map +1 -0
- package/dist/default/define/ui/tooltip.js +8 -0
- package/dist/default/define/ui/tooltip.js.map +1 -0
- package/dist/default/define/ui/volume-slider.js +2 -0
- package/dist/default/define/ui/volume-slider.js.map +1 -1
- package/dist/default/define/video/minimal-skin.css +367 -256
- package/dist/default/define/video/minimal-skin.js +46 -17
- package/dist/default/define/video/minimal-skin.js.map +1 -1
- package/dist/default/define/video/minimal-skin.tailwind.js +77 -31
- package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
- package/dist/default/define/video/skin.css +395 -280
- package/dist/default/define/video/skin.js +46 -15
- package/dist/default/define/video/skin.js.map +1 -1
- package/dist/default/define/video/skin.tailwind.js +71 -28
- package/dist/default/define/video/skin.tailwind.js.map +1 -1
- package/dist/default/icons/dist/render/default/index.js +13 -13
- package/dist/default/icons/dist/render/default/index.js.map +1 -1
- package/dist/default/icons/dist/render/minimal/index.js +13 -13
- package/dist/default/icons/dist/render/minimal/index.js.map +1 -1
- package/dist/default/index.js +13 -3
- package/dist/default/media/hls-video/index.js +5 -1
- package/dist/default/media/hls-video/index.js.map +1 -1
- package/dist/default/media/simple-hls-video/index.js +21 -0
- package/dist/default/media/simple-hls-video/index.js.map +1 -0
- package/dist/default/player/create-player.js.map +1 -1
- package/dist/default/presets/audio.js +3 -1
- package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js +58 -0
- package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/buffering.js +9 -0
- package/dist/default/skins/dist/default/default/tailwind/components/buffering.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/button.js +12 -0
- package/dist/default/skins/dist/default/default/tailwind/components/button.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/controls.js +8 -0
- package/dist/default/skins/dist/default/default/tailwind/components/controls.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/error.js +15 -0
- package/dist/default/skins/dist/default/default/tailwind/components/error.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js +29 -0
- package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/icon.js +10 -0
- package/dist/default/skins/dist/default/default/tailwind/components/icon.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/overlay.js +8 -0
- package/dist/default/skins/dist/default/default/tailwind/components/overlay.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/playback-rate.js +6 -0
- package/dist/default/skins/dist/default/default/tailwind/components/playback-rate.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/popup.js +13 -0
- package/dist/default/skins/dist/default/default/tailwind/components/popup.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/root.js +8 -0
- package/dist/default/skins/dist/default/default/tailwind/components/root.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/seek.js +11 -0
- package/dist/default/skins/dist/default/default/tailwind/components/seek.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/slider.js +21 -0
- package/dist/default/skins/dist/default/default/tailwind/components/slider.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/surface.js +8 -0
- package/dist/default/skins/dist/default/default/tailwind/components/surface.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/time.js +10 -0
- package/dist/default/skins/dist/default/default/tailwind/components/time.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js +28 -0
- package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js.map +1 -0
- package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +55 -0
- package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +44 -0
- package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/buffering.js +6 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/buffering.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/button-group.js +8 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/button-group.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/button.js +12 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/button.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js +8 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/error.js +15 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/error.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js +29 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/icon.js +10 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/icon.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js +8 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js +12 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/root.js +8 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/root.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js +11 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js +20 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/time.js +14 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/time.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js +28 -0
- package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +1 -0
- package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +44 -0
- package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -0
- package/dist/default/store/container-mixin.js +17 -3
- package/dist/default/store/container-mixin.js.map +1 -1
- package/dist/default/store/provider-mixin.js +2 -2
- package/dist/default/store/provider-mixin.js.map +1 -1
- package/dist/default/ui/alert-dialog/alert-dialog-close-element.js +46 -0
- package/dist/default/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/alert-dialog-description-element.js +26 -0
- package/dist/default/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/alert-dialog-element.js +73 -0
- package/dist/default/ui/alert-dialog/alert-dialog-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/alert-dialog-title-element.js +26 -0
- package/dist/default/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/context.js +9 -0
- package/dist/default/ui/alert-dialog/context.js.map +1 -0
- package/dist/default/ui/captions-button/captions-button-element.js +25 -0
- package/dist/default/ui/captions-button/captions-button-element.js.map +1 -0
- package/dist/default/ui/controls/controls-group-element.js +1 -1
- package/dist/default/ui/media-element.js +3 -2
- package/dist/default/ui/media-element.js.map +1 -1
- package/dist/default/ui/popover/popover-element.js +9 -4
- package/dist/default/ui/popover/popover-element.js.map +1 -1
- package/dist/default/ui/slider/slider-element.js +12 -7
- package/dist/default/ui/slider/slider-element.js.map +1 -1
- package/dist/default/ui/slider/slider-preview-element.js +51 -0
- package/dist/default/ui/slider/slider-preview-element.js.map +1 -0
- package/dist/default/ui/slider/slider-thumbnail-element.js +23 -0
- package/dist/default/ui/slider/slider-thumbnail-element.js.map +1 -0
- package/dist/default/ui/thumbnail/thumbnail-element.js +4 -1
- package/dist/default/ui/thumbnail/thumbnail-element.js.map +1 -1
- package/dist/default/ui/time-slider/time-slider-element.js +12 -7
- package/dist/default/ui/time-slider/time-slider-element.js.map +1 -1
- package/dist/default/ui/tooltip/context.js +9 -0
- package/dist/default/ui/tooltip/context.js.map +1 -0
- package/dist/default/ui/tooltip/tooltip-element.js +154 -0
- package/dist/default/ui/tooltip/tooltip-element.js.map +1 -0
- package/dist/default/ui/tooltip/tooltip-group-element.js +38 -0
- package/dist/default/ui/tooltip/tooltip-group-element.js.map +1 -0
- package/dist/default/ui/volume-slider/volume-slider-element.js +13 -8
- package/dist/default/ui/volume-slider/volume-slider-element.js.map +1 -1
- package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js +6 -0
- package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -0
- package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +6 -0
- package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -0
- package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +6 -0
- package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -0
- package/dist/dev/_virtual/inline-css_src/define/video/skin.js +6 -0
- package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -0
- package/dist/dev/define/audio/minimal-skin.css +630 -5
- package/dist/dev/define/audio/minimal-skin.d.ts +6 -2
- package/dist/dev/define/audio/minimal-skin.d.ts.map +1 -1
- package/dist/dev/define/audio/minimal-skin.js +97 -9
- package/dist/dev/define/audio/minimal-skin.js.map +1 -1
- package/dist/dev/define/audio/minimal-skin.tailwind.d.ts +20 -0
- package/dist/dev/define/audio/minimal-skin.tailwind.d.ts.map +1 -0
- package/dist/dev/define/audio/minimal-skin.tailwind.js +121 -0
- package/dist/dev/define/audio/minimal-skin.tailwind.js.map +1 -0
- package/dist/dev/define/audio/player.d.ts +0 -1
- package/dist/dev/define/audio/player.d.ts.map +1 -1
- package/dist/dev/define/audio/skin.css +655 -6
- package/dist/dev/define/audio/skin.d.ts +6 -2
- package/dist/dev/define/audio/skin.d.ts.map +1 -1
- package/dist/dev/define/audio/skin.js +88 -9
- package/dist/dev/define/audio/skin.js.map +1 -1
- package/dist/dev/define/audio/skin.tailwind.d.ts +20 -0
- package/dist/dev/define/audio/skin.tailwind.d.ts.map +1 -0
- package/dist/dev/define/audio/skin.tailwind.js +111 -0
- package/dist/dev/define/audio/skin.tailwind.js.map +1 -0
- package/dist/dev/define/background/player.d.ts +0 -1
- package/dist/dev/define/background/player.d.ts.map +1 -1
- package/dist/dev/define/media/simple-hls-video.d.ts +14 -0
- package/dist/dev/define/media/simple-hls-video.d.ts.map +1 -0
- package/dist/dev/define/media/simple-hls-video.js +13 -0
- package/dist/dev/define/media/simple-hls-video.js.map +1 -0
- package/dist/dev/define/skin-mixin.d.ts +12 -4
- package/dist/dev/define/skin-mixin.d.ts.map +1 -1
- package/dist/dev/define/skin-mixin.js +53 -19
- package/dist/dev/define/skin-mixin.js.map +1 -1
- package/dist/dev/define/ui/alert-dialog-close.d.ts +9 -0
- package/dist/dev/define/ui/alert-dialog-close.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog-close.js +8 -0
- package/dist/dev/define/ui/alert-dialog-close.js.map +1 -0
- package/dist/dev/define/ui/alert-dialog-description.d.ts +9 -0
- package/dist/dev/define/ui/alert-dialog-description.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog-description.js +8 -0
- package/dist/dev/define/ui/alert-dialog-description.js.map +1 -0
- package/dist/dev/define/ui/alert-dialog-title.d.ts +9 -0
- package/dist/dev/define/ui/alert-dialog-title.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog-title.js +8 -0
- package/dist/dev/define/ui/alert-dialog-title.js.map +1 -0
- package/dist/dev/define/ui/alert-dialog.d.ts +15 -0
- package/dist/dev/define/ui/alert-dialog.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog.js +14 -0
- package/dist/dev/define/ui/alert-dialog.js.map +1 -0
- package/dist/dev/define/ui/captions-button.d.ts +9 -0
- package/dist/dev/define/ui/captions-button.d.ts.map +1 -0
- package/dist/dev/define/ui/captions-button.js +7 -0
- package/dist/dev/define/ui/captions-button.js.map +1 -0
- package/dist/dev/define/ui/slider-thumbnail.d.ts +9 -0
- package/dist/dev/define/ui/slider-thumbnail.d.ts.map +1 -0
- package/dist/dev/define/ui/slider-thumbnail.js +8 -0
- package/dist/dev/define/ui/slider-thumbnail.js.map +1 -0
- package/dist/dev/define/ui/slider.d.ts.map +1 -1
- package/dist/dev/define/ui/slider.js +2 -0
- package/dist/dev/define/ui/slider.js.map +1 -1
- package/dist/dev/define/ui/time-slider.d.ts.map +1 -1
- package/dist/dev/define/ui/time-slider.js +4 -0
- package/dist/dev/define/ui/time-slider.js.map +1 -1
- package/dist/dev/define/ui/tooltip-group.d.ts +9 -0
- package/dist/dev/define/ui/tooltip-group.d.ts.map +1 -0
- package/dist/dev/define/ui/tooltip-group.js +8 -0
- package/dist/dev/define/ui/tooltip-group.js.map +1 -0
- package/dist/dev/define/ui/tooltip.d.ts +9 -0
- package/dist/dev/define/ui/tooltip.d.ts.map +1 -0
- package/dist/dev/define/ui/tooltip.js +8 -0
- package/dist/dev/define/ui/tooltip.js.map +1 -0
- package/dist/dev/define/ui/volume-slider.d.ts.map +1 -1
- package/dist/dev/define/ui/volume-slider.js +2 -0
- package/dist/dev/define/ui/volume-slider.js.map +1 -1
- package/dist/dev/define/video/minimal-skin.css +367 -256
- package/dist/dev/define/video/minimal-skin.d.ts +5 -14
- package/dist/dev/define/video/minimal-skin.d.ts.map +1 -1
- package/dist/dev/define/video/minimal-skin.js +46 -17
- package/dist/dev/define/video/minimal-skin.js.map +1 -1
- package/dist/dev/define/video/minimal-skin.tailwind.d.ts +4 -14
- package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -1
- package/dist/dev/define/video/minimal-skin.tailwind.js +77 -31
- package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -1
- package/dist/dev/define/video/player.d.ts +0 -1
- package/dist/dev/define/video/player.d.ts.map +1 -1
- package/dist/dev/define/video/skin.css +395 -280
- package/dist/dev/define/video/skin.d.ts +5 -14
- package/dist/dev/define/video/skin.d.ts.map +1 -1
- package/dist/dev/define/video/skin.js +46 -15
- package/dist/dev/define/video/skin.js.map +1 -1
- package/dist/dev/define/video/skin.tailwind.d.ts +4 -14
- package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -1
- package/dist/dev/define/video/skin.tailwind.js +71 -28
- package/dist/dev/define/video/skin.tailwind.js.map +1 -1
- package/dist/dev/icons/dist/render/default/index.js +13 -13
- package/dist/dev/icons/dist/render/default/index.js.map +1 -1
- package/dist/dev/icons/dist/render/minimal/index.js +13 -13
- package/dist/dev/icons/dist/render/minimal/index.js.map +1 -1
- package/dist/dev/index.d.ts +15 -5
- package/dist/dev/index.js +13 -3
- package/dist/dev/media/container-element.d.ts +0 -1
- package/dist/dev/media/container-element.d.ts.map +1 -1
- package/dist/dev/media/hls-video/index.d.ts +1 -0
- package/dist/dev/media/hls-video/index.d.ts.map +1 -1
- package/dist/dev/media/hls-video/index.js +5 -1
- package/dist/dev/media/hls-video/index.js.map +1 -1
- package/dist/dev/media/simple-hls-video/index.d.ts +11 -0
- package/dist/dev/media/simple-hls-video/index.d.ts.map +1 -0
- package/dist/dev/media/simple-hls-video/index.js +21 -0
- package/dist/dev/media/simple-hls-video/index.js.map +1 -0
- package/dist/dev/player/create-player.d.ts +1 -1
- package/dist/dev/player/create-player.js.map +1 -1
- package/dist/dev/presets/audio.d.ts +3 -1
- package/dist/dev/presets/audio.js +3 -1
- package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js +58 -0
- package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/buffering.js +9 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/buffering.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/button.js +12 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/button.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/controls.js +8 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/controls.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/error.js +15 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/error.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js +29 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/icon.js +10 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/icon.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js +8 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/playback-rate.js +6 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/playback-rate.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/popup.js +13 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/popup.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/root.js +8 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/root.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/seek.js +11 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/seek.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/slider.js +21 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/slider.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/surface.js +8 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/surface.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/time.js +10 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/time.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js +28 -0
- package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js.map +1 -0
- package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +55 -0
- package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +44 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/buffering.js +6 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/buffering.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/button-group.js +8 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/button-group.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js +12 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js +8 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js +15 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js +29 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/icon.js +10 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/icon.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js +8 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js +12 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js +8 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js +11 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js +20 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js +14 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js +28 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +1 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +44 -0
- package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -0
- package/dist/dev/store/container-mixin.d.ts +1 -1
- package/dist/dev/store/container-mixin.js +17 -3
- package/dist/dev/store/container-mixin.js.map +1 -1
- package/dist/dev/store/provider-mixin.d.ts +1 -1
- package/dist/dev/store/provider-mixin.js +2 -2
- package/dist/dev/store/provider-mixin.js.map +1 -1
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts +20 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js +46 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts +17 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js +26 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts +22 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.js +73 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts +17 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js +26 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/context.d.ts +14 -0
- package/dist/dev/ui/alert-dialog/context.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/context.js +9 -0
- package/dist/dev/ui/alert-dialog/context.js.map +1 -0
- package/dist/dev/ui/captions-button/captions-button-element.d.ts +19 -0
- package/dist/dev/ui/captions-button/captions-button-element.d.ts.map +1 -0
- package/dist/dev/ui/captions-button/captions-button-element.js +25 -0
- package/dist/dev/ui/captions-button/captions-button-element.js.map +1 -0
- package/dist/dev/ui/controls/controls-group-element.d.ts +1 -1
- package/dist/dev/ui/controls/controls-group-element.js +1 -1
- package/dist/dev/ui/media-element.d.ts +4 -1
- package/dist/dev/ui/media-element.d.ts.map +1 -1
- package/dist/dev/ui/media-element.js +3 -2
- package/dist/dev/ui/media-element.js.map +1 -1
- package/dist/dev/ui/popover/popover-element.d.ts +1 -0
- package/dist/dev/ui/popover/popover-element.d.ts.map +1 -1
- package/dist/dev/ui/popover/popover-element.js +9 -4
- package/dist/dev/ui/popover/popover-element.js.map +1 -1
- package/dist/dev/ui/slider/slider-element.d.ts +1 -0
- package/dist/dev/ui/slider/slider-element.d.ts.map +1 -1
- package/dist/dev/ui/slider/slider-element.js +12 -7
- package/dist/dev/ui/slider/slider-element.js.map +1 -1
- package/dist/dev/ui/slider/slider-preview-element.js +51 -0
- package/dist/dev/ui/slider/slider-preview-element.js.map +1 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.d.ts +12 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.d.ts.map +1 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.js +23 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.js.map +1 -0
- package/dist/dev/ui/thumbnail/thumbnail-element.d.ts +1 -0
- package/dist/dev/ui/thumbnail/thumbnail-element.d.ts.map +1 -1
- package/dist/dev/ui/thumbnail/thumbnail-element.js +4 -1
- package/dist/dev/ui/thumbnail/thumbnail-element.js.map +1 -1
- package/dist/dev/ui/time-slider/time-slider-element.d.ts +1 -0
- package/dist/dev/ui/time-slider/time-slider-element.d.ts.map +1 -1
- package/dist/dev/ui/time-slider/time-slider-element.js +12 -7
- package/dist/dev/ui/time-slider/time-slider-element.js.map +1 -1
- package/dist/dev/ui/tooltip/context.d.ts +9 -0
- package/dist/dev/ui/tooltip/context.d.ts.map +1 -0
- package/dist/dev/ui/tooltip/context.js +9 -0
- package/dist/dev/ui/tooltip/context.js.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-element.d.ts +54 -0
- package/dist/dev/ui/tooltip/tooltip-element.d.ts.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-element.js +154 -0
- package/dist/dev/ui/tooltip/tooltip-element.js.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.d.ts +27 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.d.ts.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.js +38 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.js.map +1 -0
- package/dist/dev/ui/volume-slider/volume-slider-element.d.ts +1 -0
- package/dist/dev/ui/volume-slider/volume-slider-element.d.ts.map +1 -1
- package/dist/dev/ui/volume-slider/volume-slider-element.js +13 -8
- package/dist/dev/ui/volume-slider/volume-slider-element.js.map +1 -1
- package/package.json +8 -7
- package/dist/default/skins/dist/default/video/default.tailwind.js +0 -90
- package/dist/default/skins/dist/default/video/default.tailwind.js.map +0 -1
- package/dist/default/skins/dist/default/video/minimal.tailwind.js +0 -86
- package/dist/default/skins/dist/default/video/minimal.tailwind.js.map +0 -1
- package/dist/dev/skins/dist/default/video/default.tailwind.js +0 -90
- package/dist/dev/skins/dist/default/video/default.tailwind.js.map +0 -1
- package/dist/dev/skins/dist/default/video/minimal.tailwind.js +0 -86
- package/dist/dev/skins/dist/default/video/minimal.tailwind.js.map +0 -1
|
@@ -34,20 +34,33 @@ function createContainerMixin(context) {
|
|
|
34
34
|
});
|
|
35
35
|
this.#observer.observe(this, {
|
|
36
36
|
childList: true,
|
|
37
|
-
subtree: true
|
|
37
|
+
subtree: true,
|
|
38
|
+
attributes: true,
|
|
39
|
+
attributeFilter: ["data-media-element"]
|
|
38
40
|
});
|
|
41
|
+
this.addEventListener("slotchange", this.#onSlotChange);
|
|
39
42
|
this.#attachMedia();
|
|
40
43
|
}
|
|
41
44
|
disconnectedCallback() {
|
|
42
45
|
super.disconnectedCallback();
|
|
43
46
|
this.#observer?.disconnect();
|
|
44
47
|
this.#observer = null;
|
|
48
|
+
this.removeEventListener("slotchange", this.#onSlotChange);
|
|
45
49
|
this.#detach();
|
|
46
50
|
}
|
|
51
|
+
#onSlotChange = () => {
|
|
52
|
+
this.#attachMedia();
|
|
53
|
+
};
|
|
54
|
+
#getSlottedMedia() {
|
|
55
|
+
const slot = this.querySelector("slot[name=\"media\"]");
|
|
56
|
+
if (!slot) return null;
|
|
57
|
+
for (const el of slot.assignedElements({ flatten: true })) if (el instanceof HTMLMediaElement) return el;
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
47
60
|
#attachMedia() {
|
|
48
61
|
const store = this.#contextStore ?? this.store;
|
|
49
62
|
if (!store) return;
|
|
50
|
-
const media = this.querySelector("video, audio");
|
|
63
|
+
const media = this.querySelector("video, audio, [data-media-element]") ?? this.#getSlottedMedia();
|
|
51
64
|
if (!media) {
|
|
52
65
|
this.#detach();
|
|
53
66
|
this.#detach = noop;
|
|
@@ -68,9 +81,10 @@ function createContainerMixin(context) {
|
|
|
68
81
|
};
|
|
69
82
|
}
|
|
70
83
|
function isMediaNode(node) {
|
|
71
|
-
return node instanceof HTMLMediaElement;
|
|
84
|
+
return node instanceof HTMLMediaElement || node instanceof Element && node.hasAttribute("data-media-element");
|
|
72
85
|
}
|
|
73
86
|
function hasMediaNode(record) {
|
|
87
|
+
if (record.type === "attributes" && record.target instanceof Element) return record.target.hasAttribute("data-media-element");
|
|
74
88
|
for (const node of record.addedNodes) if (isMediaNode(node)) return true;
|
|
75
89
|
for (const node of record.removedNodes) if (isMediaNode(node)) return true;
|
|
76
90
|
return false;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"container-mixin.js","names":["#contextStore","#attachMedia","#observer","#detach"],"sources":["../../../src/store/container-mixin.ts"],"sourcesContent":["import type { MediaContainer, PlayerStore, PlayerTarget } from '@videojs/core/dom';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { noop } from '@videojs/utils/function';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerConsumer, PlayerConsumerConstructor } from './types';\n\nexport type ContainerMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerConsumerConstructor<Store>;\n\n/**\n * Create a mixin that consumes player context and auto-attaches media elements.\n *\n * @param context - Player context to consume from an ancestor provider.\n */\nexport function createContainerMixin<Store extends PlayerStore>(context: PlayerContext<Store>): ContainerMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerContainerElement extends BaseClass implements PlayerConsumer<Store>, MediaContainer {\n #detach = noop;\n #observer: MutationObserver | null = null;\n #contextStore: Store | null = null;\n\n constructor(...args: any[]) {\n super(...args);\n\n // Created in the constructor body (after all field initializers) so\n // that #contextStore's private slot exists if the callback fires\n // synchronously — which happens when the element is already connected.\n // The host's controller list keeps the consumer alive; no field needed.\n new ContextConsumer(this, {\n context,\n callback: (value) => {\n this.#contextStore = value ?? null;\n this.#attachMedia();\n },\n subscribe: true,\n });\n }\n\n get store(): Store | null {\n return this.#contextStore;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n\n this.#observer = new MutationObserver((records) => {\n if (records.some(hasMediaNode)) this.#attachMedia();\n });\n\n this.#observer.observe(this, {
|
|
1
|
+
{"version":3,"file":"container-mixin.js","names":["#contextStore","#attachMedia","#observer","#onSlotChange","#detach","#getSlottedMedia"],"sources":["../../../src/store/container-mixin.ts"],"sourcesContent":["import type { MediaContainer, PlayerStore, PlayerTarget } from '@videojs/core/dom';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { noop } from '@videojs/utils/function';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerConsumer, PlayerConsumerConstructor } from './types';\n\nexport type ContainerMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerConsumerConstructor<Store>;\n\n/**\n * Create a mixin that consumes player context and auto-attaches media elements.\n *\n * @param context - Player context to consume from an ancestor provider.\n */\nexport function createContainerMixin<Store extends PlayerStore>(context: PlayerContext<Store>): ContainerMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerContainerElement extends BaseClass implements PlayerConsumer<Store>, MediaContainer {\n #detach = noop;\n #observer: MutationObserver | null = null;\n #contextStore: Store | null = null;\n\n constructor(...args: any[]) {\n super(...args);\n\n // Created in the constructor body (after all field initializers) so\n // that #contextStore's private slot exists if the callback fires\n // synchronously — which happens when the element is already connected.\n // The host's controller list keeps the consumer alive; no field needed.\n new ContextConsumer(this, {\n context,\n callback: (value) => {\n this.#contextStore = value ?? null;\n this.#attachMedia();\n },\n subscribe: true,\n });\n }\n\n get store(): Store | null {\n return this.#contextStore;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n\n this.#observer = new MutationObserver((records) => {\n if (records.some(hasMediaNode)) this.#attachMedia();\n });\n\n this.#observer.observe(this, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['data-media-element'],\n });\n\n // Slotted media elements don't appear in the container's subtree,\n // so listen for slot reassignments to pick them up.\n this.addEventListener('slotchange', this.#onSlotChange);\n\n this.#attachMedia();\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#observer?.disconnect();\n this.#observer = null;\n this.removeEventListener('slotchange', this.#onSlotChange);\n this.#detach();\n }\n\n #onSlotChange = () => {\n this.#attachMedia();\n };\n\n #getSlottedMedia(): HTMLMediaElement | null {\n const slot = this.querySelector<HTMLSlotElement>('slot[name=\"media\"]');\n if (!slot) return null;\n\n for (const el of slot.assignedElements({ flatten: true })) {\n if (el instanceof HTMLMediaElement) return el;\n }\n\n return null;\n }\n\n #attachMedia() {\n // Prefer the cached context value; fall back to `this.store` which\n // ProviderMixin overrides when both mixins are applied to one element.\n const store = this.#contextStore ?? this.store;\n if (!store) return;\n\n const media =\n this.querySelector<HTMLMediaElement>('video, audio, [data-media-element]') ?? this.#getSlottedMedia();\n\n if (!media) {\n this.#detach();\n this.#detach = noop;\n return;\n }\n\n const target: PlayerTarget = {\n media,\n container: this,\n };\n\n const hasMediaChanged = store.target?.media !== target.media,\n hasContainerChanged = store.target?.container !== target.container;\n\n if (hasMediaChanged || hasContainerChanged) {\n this.#detach();\n this.#detach = store.attach(target);\n }\n }\n }\n\n return PlayerContainerElement;\n };\n}\n\nfunction isMediaNode(node: Node): boolean {\n return node instanceof HTMLMediaElement || (node instanceof Element && node.hasAttribute('data-media-element'));\n}\n\nfunction hasMediaNode(record: MutationRecord): boolean {\n // Attribute mutation: data-media-element was added to a descendant\n if (record.type === 'attributes' && record.target instanceof Element) {\n return record.target.hasAttribute('data-media-element');\n }\n\n for (const node of record.addedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n for (const node of record.removedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n return false;\n}\n"],"mappings":";;;;;;;;;AAgBA,SAAgB,qBAAgD,SAAsD;AACpH,SAA+C,cAAqB;EAClE,MAAM,+BAA+B,UAA2D;GAC9F,UAAU;GACV,YAAqC;GACrC,gBAA8B;GAE9B,YAAY,GAAG,MAAa;AAC1B,UAAM,GAAG,KAAK;AAMd,QAAI,gBAAgB,MAAM;KACxB;KACA,WAAW,UAAU;AACnB,YAAKA,eAAgB,SAAS;AAC9B,YAAKC,aAAc;;KAErB,WAAW;KACZ,CAAC;;GAGJ,IAAI,QAAsB;AACxB,WAAO,MAAKD;;GAGd,AAAS,oBAAoB;AAC3B,UAAM,mBAAmB;AAEzB,UAAKE,WAAY,IAAI,kBAAkB,YAAY;AACjD,SAAI,QAAQ,KAAK,aAAa,CAAE,OAAKD,aAAc;MACnD;AAEF,UAAKC,SAAU,QAAQ,MAAM;KAC3B,WAAW;KACX,SAAS;KACT,YAAY;KACZ,iBAAiB,CAAC,qBAAqB;KACxC,CAAC;AAIF,SAAK,iBAAiB,cAAc,MAAKC,aAAc;AAEvD,UAAKF,aAAc;;GAGrB,AAAS,uBAAuB;AAC9B,UAAM,sBAAsB;AAC5B,UAAKC,UAAW,YAAY;AAC5B,UAAKA,WAAY;AACjB,SAAK,oBAAoB,cAAc,MAAKC,aAAc;AAC1D,UAAKC,QAAS;;GAGhB,sBAAsB;AACpB,UAAKH,aAAc;;GAGrB,mBAA4C;IAC1C,MAAM,OAAO,KAAK,cAA+B,uBAAqB;AACtE,QAAI,CAAC,KAAM,QAAO;AAElB,SAAK,MAAM,MAAM,KAAK,iBAAiB,EAAE,SAAS,MAAM,CAAC,CACvD,KAAI,cAAc,iBAAkB,QAAO;AAG7C,WAAO;;GAGT,eAAe;IAGb,MAAM,QAAQ,MAAKD,gBAAiB,KAAK;AACzC,QAAI,CAAC,MAAO;IAEZ,MAAM,QACJ,KAAK,cAAgC,qCAAqC,IAAI,MAAKK,iBAAkB;AAEvG,QAAI,CAAC,OAAO;AACV,WAAKD,QAAS;AACd,WAAKA,SAAU;AACf;;IAGF,MAAM,SAAuB;KAC3B;KACA,WAAW;KACZ;IAED,MAAM,kBAAkB,MAAM,QAAQ,UAAU,OAAO,OACrD,sBAAsB,MAAM,QAAQ,cAAc,OAAO;AAE3D,QAAI,mBAAmB,qBAAqB;AAC1C,WAAKA,QAAS;AACd,WAAKA,SAAU,MAAM,OAAO,OAAO;;;;AAKzC,SAAO;;;AAIX,SAAS,YAAY,MAAqB;AACxC,QAAO,gBAAgB,oBAAqB,gBAAgB,WAAW,KAAK,aAAa,qBAAqB;;AAGhH,SAAS,aAAa,QAAiC;AAErD,KAAI,OAAO,SAAS,gBAAgB,OAAO,kBAAkB,QAC3D,QAAO,OAAO,OAAO,aAAa,qBAAqB;AAGzD,MAAK,MAAM,QAAQ,OAAO,WACxB,KAAI,YAAY,KAAK,CAAE,QAAO;AAGhC,MAAK,MAAM,QAAQ,OAAO,aACxB,KAAI,YAAY,KAAK,CAAE,QAAO;AAGhC,QAAO"}
|
|
@@ -24,10 +24,10 @@ function createProviderMixin(context, factory) {
|
|
|
24
24
|
super.connectedCallback();
|
|
25
25
|
this.#provider.setValue(this.store);
|
|
26
26
|
}
|
|
27
|
-
|
|
28
|
-
super.disconnectedCallback();
|
|
27
|
+
destroyCallback() {
|
|
29
28
|
this.#store?.destroy();
|
|
30
29
|
this.#store = null;
|
|
30
|
+
super.destroyCallback();
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
return PlayerProviderElement;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider-mixin.js","names":["#store","#provider"],"sources":["../../../src/store/provider-mixin.ts"],"sourcesContent":["import type { PlayerStore } from '@videojs/core/dom';\nimport { ContextProvider } from '@videojs/element/context';\nimport { isNull } from '@videojs/utils/predicate';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerProvider, PlayerProviderConstructor } from './types';\n\nexport type ProviderMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerProviderConstructor<Store>;\n\n/**\n * Create a mixin that provides player context to descendant elements.\n *\n * @param context - Player context to provide to descendants.\n * @param factory - Factory function that creates a store instance.\n */\nexport function createProviderMixin<Store extends PlayerStore>(\n context: PlayerContext<Store>,\n factory: () => Store\n): ProviderMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerProviderElement extends BaseClass implements PlayerProvider<Store> {\n #store: Store | null = factory();\n\n #provider = new ContextProvider(this, {\n context,\n initialValue: this.store,\n });\n\n get store(): Store {\n if (isNull(this.#store)) {\n this.#store = factory();\n }\n\n return this.#store;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#provider.setValue(this.store);\n }\n\n override
|
|
1
|
+
{"version":3,"file":"provider-mixin.js","names":["#store","#provider"],"sources":["../../../src/store/provider-mixin.ts"],"sourcesContent":["import type { PlayerStore } from '@videojs/core/dom';\nimport { ContextProvider } from '@videojs/element/context';\nimport { isNull } from '@videojs/utils/predicate';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerProvider, PlayerProviderConstructor } from './types';\n\nexport type ProviderMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerProviderConstructor<Store>;\n\n/**\n * Create a mixin that provides player context to descendant elements.\n *\n * @param context - Player context to provide to descendants.\n * @param factory - Factory function that creates a store instance.\n */\nexport function createProviderMixin<Store extends PlayerStore>(\n context: PlayerContext<Store>,\n factory: () => Store\n): ProviderMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerProviderElement extends BaseClass implements PlayerProvider<Store> {\n #store: Store | null = factory();\n\n #provider = new ContextProvider(this, {\n context,\n initialValue: this.store,\n });\n\n get store(): Store {\n if (isNull(this.#store)) {\n this.#store = factory();\n }\n\n return this.#store;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#provider.setValue(this.store);\n }\n\n override destroyCallback() {\n this.#store?.destroy();\n this.#store = null;\n super.destroyCallback();\n }\n }\n\n return PlayerProviderElement;\n };\n}\n"],"mappings":";;;;;;;;;;AAiBA,SAAgB,oBACd,SACA,SACsB;AACtB,SAA+C,cAAqB;EAClE,MAAM,8BAA8B,UAA2C;GAC7E,SAAuB,SAAS;GAEhC,YAAY,IAAI,gBAAgB,MAAM;IACpC;IACA,cAAc,KAAK;IACpB,CAAC;GAEF,IAAI,QAAe;AACjB,QAAI,OAAO,MAAKA,MAAO,CACrB,OAAKA,QAAS,SAAS;AAGzB,WAAO,MAAKA;;GAGd,AAAS,oBAAoB;AAC3B,UAAM,mBAAmB;AACzB,UAAKC,SAAU,SAAS,KAAK,MAAM;;GAGrC,AAAS,kBAAkB;AACzB,UAAKD,OAAQ,SAAS;AACtB,UAAKA,QAAS;AACd,UAAM,iBAAiB;;;AAI3B,SAAO"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { MediaElement } from "../media-element.js";
|
|
2
|
+
import { alertDialogContext } from "./context.js";
|
|
3
|
+
import { applyElementProps, applyStateDataAttrs, createButton } from "@videojs/core/dom";
|
|
4
|
+
import { ContextConsumer } from "@videojs/element/context";
|
|
5
|
+
|
|
6
|
+
//#region src/ui/alert-dialog/alert-dialog-close-element.ts
|
|
7
|
+
var AlertDialogCloseElement = class extends MediaElement {
|
|
8
|
+
constructor(..._args) {
|
|
9
|
+
super(..._args);
|
|
10
|
+
this.disabled = false;
|
|
11
|
+
}
|
|
12
|
+
static {
|
|
13
|
+
this.tagName = "media-alert-dialog-close";
|
|
14
|
+
}
|
|
15
|
+
static {
|
|
16
|
+
this.properties = { disabled: { type: Boolean } };
|
|
17
|
+
}
|
|
18
|
+
#ctx = new ContextConsumer(this, {
|
|
19
|
+
context: alertDialogContext,
|
|
20
|
+
subscribe: true
|
|
21
|
+
});
|
|
22
|
+
#disconnect = null;
|
|
23
|
+
connectedCallback() {
|
|
24
|
+
super.connectedCallback();
|
|
25
|
+
this.#disconnect = new AbortController();
|
|
26
|
+
const buttonProps = createButton({
|
|
27
|
+
onActivate: () => this.#ctx.value?.close(),
|
|
28
|
+
isDisabled: () => this.disabled
|
|
29
|
+
});
|
|
30
|
+
applyElementProps(this, buttonProps, { signal: this.#disconnect.signal });
|
|
31
|
+
}
|
|
32
|
+
disconnectedCallback() {
|
|
33
|
+
super.disconnectedCallback();
|
|
34
|
+
this.#disconnect?.abort();
|
|
35
|
+
this.#disconnect = null;
|
|
36
|
+
}
|
|
37
|
+
update(_changed) {
|
|
38
|
+
super.update(_changed);
|
|
39
|
+
const ctx = this.#ctx.value;
|
|
40
|
+
if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
//#endregion
|
|
45
|
+
export { AlertDialogCloseElement };
|
|
46
|
+
//# sourceMappingURL=alert-dialog-close-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-close-element.js","names":["#ctx","#disconnect"],"sources":["../../../../src/ui/alert-dialog/alert-dialog-close-element.ts"],"sourcesContent":["import { applyElementProps, applyStateDataAttrs, createButton } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { MediaElement } from '../media-element';\nimport { alertDialogContext } from './context';\n\nexport class AlertDialogCloseElement extends MediaElement {\n static readonly tagName = 'media-alert-dialog-close';\n\n static override properties = {\n disabled: { type: Boolean },\n } satisfies PropertyDeclarationMap<'disabled'>;\n\n disabled = false;\n\n readonly #ctx = new ContextConsumer(this, { context: alertDialogContext, subscribe: true });\n\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.#disconnect = new AbortController();\n\n const buttonProps = createButton({\n onActivate: () => this.#ctx.value?.close(),\n isDisabled: () => this.disabled,\n });\n\n applyElementProps(this, buttonProps, { signal: this.#disconnect.signal });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n const ctx = this.#ctx.value;\n if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);\n }\n}\n"],"mappings":";;;;;;AAOA,IAAa,0BAAb,cAA6C,aAAa;;;kBAO7C;;;iBANe;;;oBAEG,EAC3B,UAAU,EAAE,MAAM,SAAS,EAC5B;;CAID,CAASA,MAAO,IAAI,gBAAgB,MAAM;EAAE,SAAS;EAAoB,WAAW;EAAM,CAAC;CAE3F,cAAsC;CAEtC,AAAS,oBAA0B;AACjC,QAAM,mBAAmB;AACzB,QAAKC,aAAc,IAAI,iBAAiB;EAExC,MAAM,cAAc,aAAa;GAC/B,kBAAkB,MAAKD,IAAK,OAAO,OAAO;GAC1C,kBAAkB,KAAK;GACxB,CAAC;AAEF,oBAAkB,MAAM,aAAa,EAAE,QAAQ,MAAKC,WAAY,QAAQ,CAAC;;CAG3E,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKA,YAAa,OAAO;AACzB,QAAKA,aAAc;;CAGrB,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;EACtB,MAAM,MAAM,MAAKD,IAAK;AACtB,MAAI,IAAK,qBAAoB,MAAM,IAAI,OAAO,IAAI,aAAa"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { alertDialogContext } from "./context.js";
|
|
2
|
+
import { ContextPartElement } from "../context-part-element.js";
|
|
3
|
+
import { ContextConsumer } from "@videojs/element/context";
|
|
4
|
+
|
|
5
|
+
//#region src/ui/alert-dialog/alert-dialog-description-element.ts
|
|
6
|
+
var AlertDialogDescriptionElement = class extends ContextPartElement {
|
|
7
|
+
constructor(..._args) {
|
|
8
|
+
super(..._args);
|
|
9
|
+
this.consumer = new ContextConsumer(this, {
|
|
10
|
+
context: alertDialogContext,
|
|
11
|
+
subscribe: true
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
static {
|
|
15
|
+
this.tagName = "media-alert-dialog-description";
|
|
16
|
+
}
|
|
17
|
+
update(changed) {
|
|
18
|
+
super.update(changed);
|
|
19
|
+
const descriptionId = this.consumer.value?.state.descriptionId;
|
|
20
|
+
if (descriptionId) this.id = descriptionId;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
//#endregion
|
|
25
|
+
export { AlertDialogDescriptionElement };
|
|
26
|
+
//# sourceMappingURL=alert-dialog-description-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-description-element.js","names":[],"sources":["../../../../src/ui/alert-dialog/alert-dialog-description-element.ts"],"sourcesContent":["import type { AlertDialogState } from '@videojs/core';\nimport type { PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { ContextPartElement } from '../context-part-element';\nimport { alertDialogContext } from './context';\n\nexport class AlertDialogDescriptionElement extends ContextPartElement<AlertDialogState> {\n static readonly tagName = 'media-alert-dialog-description';\n\n protected readonly consumer = new ContextConsumer(this, { context: alertDialogContext, subscribe: true });\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n const descriptionId = this.consumer.value?.state.descriptionId;\n if (descriptionId) this.id = descriptionId;\n }\n}\n"],"mappings":";;;;;AAOA,IAAa,gCAAb,cAAmD,mBAAqC;;;kBAGxD,IAAI,gBAAgB,MAAM;GAAE,SAAS;GAAoB,WAAW;GAAM,CAAC;;;iBAF/E;;CAI1B,AAAmB,OAAO,SAA+B;AACvD,QAAM,OAAO,QAAQ;EACrB,MAAM,gBAAgB,KAAK,SAAS,OAAO,MAAM;AACjD,MAAI,cAAe,MAAK,KAAK"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { MediaElement } from "../media-element.js";
|
|
2
|
+
import { alertDialogContext } from "./context.js";
|
|
3
|
+
import { applyElementProps, applyStateDataAttrs, createAlertDialog, createTransition } from "@videojs/core/dom";
|
|
4
|
+
import { ContextProvider } from "@videojs/element/context";
|
|
5
|
+
import { SnapshotController } from "@videojs/store/html";
|
|
6
|
+
import { AlertDialogCore, AlertDialogDataAttrs } from "@videojs/core";
|
|
7
|
+
|
|
8
|
+
//#region src/ui/alert-dialog/alert-dialog-element.ts
|
|
9
|
+
let idCounter = 0;
|
|
10
|
+
var AlertDialogElement = class extends MediaElement {
|
|
11
|
+
static {
|
|
12
|
+
this.tagName = "media-alert-dialog";
|
|
13
|
+
}
|
|
14
|
+
static {
|
|
15
|
+
this.properties = { open: { type: Boolean } };
|
|
16
|
+
}
|
|
17
|
+
#core = new AlertDialogCore();
|
|
18
|
+
#provider = new ContextProvider(this, { context: alertDialogContext });
|
|
19
|
+
#titleId = `vjs-alert-dialog-title-${idCounter++}`;
|
|
20
|
+
#descriptionId = `vjs-alert-dialog-desc-${idCounter++}`;
|
|
21
|
+
#dialog = null;
|
|
22
|
+
#snapshot = null;
|
|
23
|
+
constructor() {
|
|
24
|
+
super();
|
|
25
|
+
this.open = false;
|
|
26
|
+
this.#core.setTitleId(this.#titleId);
|
|
27
|
+
this.#core.setDescriptionId(this.#descriptionId);
|
|
28
|
+
}
|
|
29
|
+
connectedCallback() {
|
|
30
|
+
super.connectedCallback();
|
|
31
|
+
this.#dialog = createAlertDialog({
|
|
32
|
+
transition: createTransition(),
|
|
33
|
+
onOpenChange: (nextOpen) => {
|
|
34
|
+
this.open = nextOpen;
|
|
35
|
+
this.dispatchEvent(new CustomEvent("open-change", { detail: { open: nextOpen } }));
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
this.#dialog.setElement(this);
|
|
39
|
+
if (this.#snapshot) this.#snapshot.track(this.#dialog.input);
|
|
40
|
+
else this.#snapshot = new SnapshotController(this, this.#dialog.input);
|
|
41
|
+
}
|
|
42
|
+
disconnectedCallback() {
|
|
43
|
+
super.disconnectedCallback();
|
|
44
|
+
this.#dialog?.destroy();
|
|
45
|
+
this.#dialog = null;
|
|
46
|
+
}
|
|
47
|
+
willUpdate(changed) {
|
|
48
|
+
super.willUpdate(changed);
|
|
49
|
+
if (this.#dialog && changed.has("open")) {
|
|
50
|
+
const { active: inputOpen } = this.#dialog.input.current;
|
|
51
|
+
if (this.open !== inputOpen) if (this.open) this.#dialog.open();
|
|
52
|
+
else this.#dialog.close();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
update(_changed) {
|
|
56
|
+
super.update(_changed);
|
|
57
|
+
if (!this.#dialog) return;
|
|
58
|
+
const input = this.#dialog.input.current;
|
|
59
|
+
this.#core.setInput(input);
|
|
60
|
+
const state = this.#core.getState();
|
|
61
|
+
applyElementProps(this, this.#core.getAttrs(state));
|
|
62
|
+
applyStateDataAttrs(this, state, AlertDialogDataAttrs);
|
|
63
|
+
this.#provider.setValue({
|
|
64
|
+
state,
|
|
65
|
+
stateAttrMap: AlertDialogDataAttrs,
|
|
66
|
+
close: () => this.#dialog?.close()
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
//#endregion
|
|
72
|
+
export { AlertDialogElement };
|
|
73
|
+
//# sourceMappingURL=alert-dialog-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-element.js","names":["#core","#provider","#titleId","#descriptionId","#dialog","#snapshot"],"sources":["../../../../src/ui/alert-dialog/alert-dialog-element.ts"],"sourcesContent":["import { AlertDialogCore, AlertDialogDataAttrs, type AlertDialogInput } from '@videojs/core';\nimport {\n type AlertDialogApi,\n applyElementProps,\n applyStateDataAttrs,\n createAlertDialog,\n createTransition,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { SnapshotController } from '@videojs/store/html';\n\nimport { MediaElement } from '../media-element';\nimport { alertDialogContext } from './context';\n\nlet idCounter = 0;\n\nexport class AlertDialogElement extends MediaElement {\n static readonly tagName = 'media-alert-dialog';\n\n static override properties = {\n open: { type: Boolean },\n } satisfies PropertyDeclarationMap<'open'>;\n\n open = false;\n\n readonly #core = new AlertDialogCore();\n readonly #provider = new ContextProvider(this, { context: alertDialogContext });\n readonly #titleId = `vjs-alert-dialog-title-${idCounter++}`;\n readonly #descriptionId = `vjs-alert-dialog-desc-${idCounter++}`;\n\n #dialog: AlertDialogApi | null = null;\n #snapshot: SnapshotController<AlertDialogInput> | null = null;\n\n constructor() {\n super();\n this.#core.setTitleId(this.#titleId);\n this.#core.setDescriptionId(this.#descriptionId);\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#dialog = createAlertDialog({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen } }));\n },\n });\n\n // Register self as the dialog element.\n this.#dialog.setElement(this);\n\n if (this.#snapshot) {\n this.#snapshot.track(this.#dialog.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#dialog.input);\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#dialog?.destroy();\n this.#dialog = null;\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n\n // Sync controlled open state.\n if (this.#dialog && changed.has('open')) {\n const { active: inputOpen } = this.#dialog.input.current;\n if (this.open !== inputOpen) {\n if (this.open) {\n this.#dialog.open();\n } else {\n this.#dialog.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#dialog) return;\n\n const input = this.#dialog.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, AlertDialogDataAttrs);\n\n this.#provider.setValue({\n state,\n stateAttrMap: AlertDialogDataAttrs,\n close: () => this.#dialog?.close(),\n });\n }\n}\n"],"mappings":";;;;;;;;AAeA,IAAI,YAAY;AAEhB,IAAa,qBAAb,cAAwC,aAAa;;iBACzB;;;oBAEG,EAC3B,MAAM,EAAE,MAAM,SAAS,EACxB;;CAID,CAASA,OAAQ,IAAI,iBAAiB;CACtC,CAASC,WAAY,IAAI,gBAAgB,MAAM,EAAE,SAAS,oBAAoB,CAAC;CAC/E,CAASC,UAAW,0BAA0B;CAC9C,CAASC,gBAAiB,yBAAyB;CAEnD,UAAiC;CACjC,YAAyD;CAEzD,cAAc;AACZ,SAAO;cAXF;AAYL,QAAKH,KAAM,WAAW,MAAKE,QAAS;AACpC,QAAKF,KAAM,iBAAiB,MAAKG,cAAe;;CAGlD,AAAS,oBAA0B;AACjC,QAAM,mBAAmB;AAEzB,QAAKC,SAAU,kBAAkB;GAC/B,YAAY,kBAAkB;GAC9B,eAAe,aAAsB;AACnC,SAAK,OAAO;AACZ,SAAK,cAAc,IAAI,YAAY,eAAe,EAAE,QAAQ,EAAE,MAAM,UAAU,EAAE,CAAC,CAAC;;GAErF,CAAC;AAGF,QAAKA,OAAQ,WAAW,KAAK;AAE7B,MAAI,MAAKC,SACP,OAAKA,SAAU,MAAM,MAAKD,OAAQ,MAAM;MAExC,OAAKC,WAAY,IAAI,mBAAmB,MAAM,MAAKD,OAAQ,MAAM;;CAIrE,AAAS,uBAA6B;AACpC,QAAM,sBAAsB;AAC5B,QAAKA,QAAS,SAAS;AACvB,QAAKA,SAAU;;CAGjB,AAAmB,WAAW,SAA+B;AAC3D,QAAM,WAAW,QAAQ;AAGzB,MAAI,MAAKA,UAAW,QAAQ,IAAI,OAAO,EAAE;GACvC,MAAM,EAAE,QAAQ,cAAc,MAAKA,OAAQ,MAAM;AACjD,OAAI,KAAK,SAAS,UAChB,KAAI,KAAK,KACP,OAAKA,OAAQ,MAAM;OAEnB,OAAKA,OAAQ,OAAO;;;CAM5B,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;AACtB,MAAI,CAAC,MAAKA,OAAS;EAEnB,MAAM,QAAQ,MAAKA,OAAQ,MAAM;AACjC,QAAKJ,KAAM,SAAS,MAAM;EAC1B,MAAM,QAAQ,MAAKA,KAAM,UAAU;AAEnC,oBAAkB,MAAM,MAAKA,KAAM,SAAS,MAAM,CAAC;AACnD,sBAAoB,MAAM,OAAO,qBAAqB;AAEtD,QAAKC,SAAU,SAAS;GACtB;GACA,cAAc;GACd,aAAa,MAAKG,QAAS,OAAO;GACnC,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { alertDialogContext } from "./context.js";
|
|
2
|
+
import { ContextPartElement } from "../context-part-element.js";
|
|
3
|
+
import { ContextConsumer } from "@videojs/element/context";
|
|
4
|
+
|
|
5
|
+
//#region src/ui/alert-dialog/alert-dialog-title-element.ts
|
|
6
|
+
var AlertDialogTitleElement = class extends ContextPartElement {
|
|
7
|
+
constructor(..._args) {
|
|
8
|
+
super(..._args);
|
|
9
|
+
this.consumer = new ContextConsumer(this, {
|
|
10
|
+
context: alertDialogContext,
|
|
11
|
+
subscribe: true
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
static {
|
|
15
|
+
this.tagName = "media-alert-dialog-title";
|
|
16
|
+
}
|
|
17
|
+
update(changed) {
|
|
18
|
+
super.update(changed);
|
|
19
|
+
const titleId = this.consumer.value?.state.titleId;
|
|
20
|
+
if (titleId) this.id = titleId;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
//#endregion
|
|
25
|
+
export { AlertDialogTitleElement };
|
|
26
|
+
//# sourceMappingURL=alert-dialog-title-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-title-element.js","names":[],"sources":["../../../../src/ui/alert-dialog/alert-dialog-title-element.ts"],"sourcesContent":["import type { AlertDialogState } from '@videojs/core';\nimport type { PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { ContextPartElement } from '../context-part-element';\nimport { alertDialogContext } from './context';\n\nexport class AlertDialogTitleElement extends ContextPartElement<AlertDialogState> {\n static readonly tagName = 'media-alert-dialog-title';\n\n protected readonly consumer = new ContextConsumer(this, { context: alertDialogContext, subscribe: true });\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n const titleId = this.consumer.value?.state.titleId;\n if (titleId) this.id = titleId;\n }\n}\n"],"mappings":";;;;;AAOA,IAAa,0BAAb,cAA6C,mBAAqC;;;kBAGlD,IAAI,gBAAgB,MAAM;GAAE,SAAS;GAAoB,WAAW;GAAM,CAAC;;;iBAF/E;;CAI1B,AAAmB,OAAO,SAA+B;AACvD,QAAM,OAAO,QAAQ;EACrB,MAAM,UAAU,KAAK,SAAS,OAAO,MAAM;AAC3C,MAAI,QAAS,MAAK,KAAK"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { createContext } from "@videojs/element/context";
|
|
2
|
+
|
|
3
|
+
//#region src/ui/alert-dialog/context.ts
|
|
4
|
+
const ALERT_DIALOG_CONTEXT_KEY = Symbol("@videojs/alert-dialog");
|
|
5
|
+
const alertDialogContext = createContext(ALERT_DIALOG_CONTEXT_KEY);
|
|
6
|
+
|
|
7
|
+
//#endregion
|
|
8
|
+
export { alertDialogContext };
|
|
9
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","names":[],"sources":["../../../../src/ui/alert-dialog/context.ts"],"sourcesContent":["import type { AlertDialogState, StateAttrMap } from '@videojs/core';\nimport { createContext } from '@videojs/element/context';\n\nexport interface AlertDialogContextValue {\n state: AlertDialogState;\n stateAttrMap: StateAttrMap<AlertDialogState>;\n close: () => void;\n}\n\nconst ALERT_DIALOG_CONTEXT_KEY = Symbol('@videojs/alert-dialog');\n\nexport const alertDialogContext = createContext<AlertDialogContextValue>(ALERT_DIALOG_CONTEXT_KEY);\n"],"mappings":";;;AASA,MAAM,2BAA2B,OAAO,wBAAwB;AAEhE,MAAa,qBAAqB,cAAuC,yBAAyB"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { playerContext } from "../../player/context.js";
|
|
2
|
+
import { PlayerController } from "../../player/player-controller.js";
|
|
3
|
+
import { MediaButtonElement } from "../media-button-element.js";
|
|
4
|
+
import { selectTextTrack } from "@videojs/core/dom";
|
|
5
|
+
import { CaptionsButtonCore, CaptionsButtonDataAttrs } from "@videojs/core";
|
|
6
|
+
|
|
7
|
+
//#region src/ui/captions-button/captions-button-element.ts
|
|
8
|
+
var CaptionsButtonElement = class extends MediaButtonElement {
|
|
9
|
+
constructor(..._args) {
|
|
10
|
+
super(..._args);
|
|
11
|
+
this.core = new CaptionsButtonCore();
|
|
12
|
+
this.stateAttrMap = CaptionsButtonDataAttrs;
|
|
13
|
+
this.mediaState = new PlayerController(this, playerContext, selectTextTrack);
|
|
14
|
+
}
|
|
15
|
+
static {
|
|
16
|
+
this.tagName = "media-captions-button";
|
|
17
|
+
}
|
|
18
|
+
activate(state) {
|
|
19
|
+
this.core.toggle(state);
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
//#endregion
|
|
24
|
+
export { CaptionsButtonElement };
|
|
25
|
+
//# sourceMappingURL=captions-button-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"captions-button-element.js","names":[],"sources":["../../../../src/ui/captions-button/captions-button-element.ts"],"sourcesContent":["import { CaptionsButtonCore, CaptionsButtonDataAttrs, type MediaTextTrackState } from '@videojs/core';\nimport { selectTextTrack } from '@videojs/core/dom';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaButtonElement } from '../media-button-element';\n\nexport class CaptionsButtonElement extends MediaButtonElement<CaptionsButtonCore> {\n static readonly tagName = 'media-captions-button';\n\n protected readonly core = new CaptionsButtonCore();\n protected readonly stateAttrMap = CaptionsButtonDataAttrs;\n protected readonly mediaState = new PlayerController(this, playerContext, selectTextTrack);\n\n protected activate(state: MediaTextTrackState): void {\n this.core.toggle(state);\n }\n}\n"],"mappings":";;;;;;;AAOA,IAAa,wBAAb,cAA2C,mBAAuC;;;cAGtD,IAAI,oBAAoB;sBAChB;oBACF,IAAI,iBAAiB,MAAM,eAAe,gBAAgB;;;iBAJhE;;CAM1B,AAAU,SAAS,OAAkC;AACnD,OAAK,KAAK,OAAO,MAAM"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { controlsContext } from "./context.js";
|
|
2
1
|
import { ContextPartElement } from "../context-part-element.js";
|
|
2
|
+
import { controlsContext } from "./context.js";
|
|
3
3
|
import { ContextConsumer } from "@videojs/element/context";
|
|
4
4
|
|
|
5
5
|
//#region src/ui/controls/controls-group-element.ts
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { ReactiveElement } from "@videojs/element";
|
|
1
|
+
import { DestroyMixin, ReactiveElement } from "@videojs/element";
|
|
2
2
|
|
|
3
3
|
//#region src/ui/media-element.ts
|
|
4
|
-
|
|
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":"
|
|
1
|
+
{"version":3,"file":"media-element.js","names":[],"sources":["../../../src/ui/media-element.ts"],"sourcesContent":["import { DestroyMixin, ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\n/** Base class for interactive media UI elements. */\nexport class MediaElement extends DestroyMixin(ReactiveElement) {}\n\nexport interface MediaElementConstructor extends Constructor<MediaElement> {}\n"],"mappings":";;;;AAIA,IAAa,eAAb,cAAkC,aAAa,gBAAgB,CAAC"}
|
|
@@ -2,7 +2,7 @@ import { MediaElement } from "../media-element.js";
|
|
|
2
2
|
import { applyElementProps, applyStateDataAttrs, createPopover, createTransition, getAnchorNameStyle, getAnchorPositionStyle, resolveOffsets } from "@videojs/core/dom";
|
|
3
3
|
import { SnapshotController } from "@videojs/store/html";
|
|
4
4
|
import { PopoverCore, PopoverDataAttrs } from "@videojs/core";
|
|
5
|
-
import { applyStyles, supportsAnchorPositioning } from "@videojs/utils/dom";
|
|
5
|
+
import { applyStyles, supportsAnchorPositioning, tryHidePopover, tryShowPopover } from "@videojs/utils/dom";
|
|
6
6
|
|
|
7
7
|
//#region src/ui/popover/popover-element.ts
|
|
8
8
|
var PopoverElement = class extends MediaElement {
|
|
@@ -59,6 +59,7 @@ var PopoverElement = class extends MediaElement {
|
|
|
59
59
|
#currentTrigger = null;
|
|
60
60
|
connectedCallback() {
|
|
61
61
|
super.connectedCallback();
|
|
62
|
+
if (this.destroyed) return;
|
|
62
63
|
this.#disconnect = new AbortController();
|
|
63
64
|
this.#popover = createPopover({
|
|
64
65
|
transition: createTransition(),
|
|
@@ -86,12 +87,14 @@ var PopoverElement = class extends MediaElement {
|
|
|
86
87
|
}
|
|
87
88
|
disconnectedCallback() {
|
|
88
89
|
super.disconnectedCallback();
|
|
89
|
-
this.#cleanupTrigger();
|
|
90
|
-
this.#popover?.destroy();
|
|
91
|
-
this.#popover = null;
|
|
92
90
|
this.#disconnect?.abort();
|
|
93
91
|
this.#disconnect = null;
|
|
94
92
|
}
|
|
93
|
+
destroyCallback() {
|
|
94
|
+
this.#cleanupTrigger();
|
|
95
|
+
this.#popover?.destroy();
|
|
96
|
+
super.destroyCallback();
|
|
97
|
+
}
|
|
95
98
|
willUpdate(changed) {
|
|
96
99
|
super.willUpdate(changed);
|
|
97
100
|
this.#core.setProps(this);
|
|
@@ -111,6 +114,8 @@ var PopoverElement = class extends MediaElement {
|
|
|
111
114
|
const state = this.#core.getState();
|
|
112
115
|
applyElementProps(this, this.#core.getPopupAttrs(state));
|
|
113
116
|
applyStateDataAttrs(this, state, PopoverDataAttrs);
|
|
117
|
+
if (state.open) tryShowPopover(this);
|
|
118
|
+
else tryHidePopover(this);
|
|
114
119
|
if (this.#currentTrigger) {
|
|
115
120
|
applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));
|
|
116
121
|
applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"popover-element.js","names":["#core","#disconnect","#popover","#snapshot","#cleanupTrigger","#findTrigger","#syncTrigger","#currentTrigger","#triggerAbort"],"sources":["../../../../src/ui/popover/popover-element.ts"],"sourcesContent":["import { PopoverCore, PopoverDataAttrs, type PopoverInput, type PopoverProps } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createPopover,\n createTransition,\n getAnchorNameStyle,\n getAnchorPositionStyle,\n type PopoverApi,\n type PopoverChangeDetails,\n resolveOffsets,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { SnapshotController } from '@videojs/store/html';\nimport { applyStyles, supportsAnchorPositioning } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\n\nexport class PopoverElement extends MediaElement {\n static readonly tagName = 'media-popover';\n\n static override properties = {\n open: { type: Boolean },\n defaultOpen: { type: Boolean, attribute: 'default-open' },\n side: { type: String },\n align: { type: String },\n modal: { type: Boolean },\n closeOnEscape: { type: Boolean, attribute: 'close-on-escape' },\n closeOnOutsideClick: { type: Boolean, attribute: 'close-on-outside-click' },\n openOnHover: { type: Boolean, attribute: 'open-on-hover' },\n delay: { type: Number },\n closeDelay: { type: Number, attribute: 'close-delay' },\n } satisfies PropertyDeclarationMap<keyof PopoverCore.Props>;\n\n open = PopoverCore.defaultProps.open;\n defaultOpen = PopoverCore.defaultProps.defaultOpen;\n side = PopoverCore.defaultProps.side;\n align = PopoverCore.defaultProps.align;\n modal: PopoverProps['modal'] = PopoverCore.defaultProps.modal;\n closeOnEscape = PopoverCore.defaultProps.closeOnEscape;\n closeOnOutsideClick = PopoverCore.defaultProps.closeOnOutsideClick;\n openOnHover = PopoverCore.defaultProps.openOnHover;\n delay = PopoverCore.defaultProps.delay;\n closeDelay = PopoverCore.defaultProps.closeDelay;\n\n readonly #core = new PopoverCore();\n #popover: PopoverApi | null = null;\n #snapshot: SnapshotController<PopoverInput> | null = null;\n\n // Cleanup controllers\n #disconnect: AbortController | null = null;\n #triggerAbort: AbortController | null = null;\n #currentTrigger: HTMLElement | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.#disconnect = new AbortController();\n\n this.#popover = createPopover({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean, details: PopoverChangeDetails) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen, ...details } }));\n },\n closeOnEscape: () => this.closeOnEscape,\n closeOnOutsideClick: () => this.closeOnOutsideClick,\n openOnHover: () => this.openOnHover,\n delay: () => this.delay,\n closeDelay: () => this.closeDelay,\n });\n\n // Register self as the popup element — the element IS the popup.\n this.#popover.setPopupElement(this);\n\n // Apply popup event handlers (pointerenter/leave, focusout) to self.\n applyElementProps(this, this.#popover.popupProps, { signal: this.#disconnect.signal });\n\n // Subscribe to interaction state for reactive updates.\n // Reuse the controller across connect/disconnect cycles to avoid\n // leaking stale controllers in the host's controller set.\n if (this.#snapshot) {\n this.#snapshot.track(this.#popover.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#popover.input);\n }\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n\n // Uncontrolled mode: open if `defaultOpen` is set. Controlled `open`\n // is already synced by `willUpdate` on the first render cycle.\n if (this.defaultOpen && !this.open) {\n this.#popover?.open();\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#cleanupTrigger();\n this.#popover?.destroy();\n this.#popover = null;\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n this.#core.setProps(this);\n\n // Sync controlled open state\n if (this.#popover && changed.has('open')) {\n const { active: interactionOpen } = this.#popover.input.current;\n if (this.open !== interactionOpen) {\n if (this.open) {\n this.#popover.open();\n } else {\n this.#popover.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#popover) return;\n\n // Discover trigger via commandfor linkage.\n const triggerEl = this.#findTrigger();\n this.#syncTrigger(triggerEl);\n\n // Derive state from core + input.\n const input = this.#popover.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n // Apply popup ARIA and data attributes to self.\n applyElementProps(this, this.#core.getPopupAttrs(state));\n applyStateDataAttrs(this, state, PopoverDataAttrs);\n\n // Apply trigger ARIA and anchor-name to the discovered trigger.\n if (this.#currentTrigger) {\n applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));\n applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));\n }\n\n // Skip positioning when closed — no rects to measure.\n if (!state.open) return;\n\n // Apply positioning styles to self.\n const posOpts = { side: state.side, align: state.align };\n\n if (supportsAnchorPositioning()) {\n // Native CSS Anchor Positioning — no JS rect measurements needed.\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts));\n } else {\n // JS fallback: measure rects and resolve CSS var offsets.\n const triggerRect = this.#currentTrigger?.getBoundingClientRect();\n const selfRect = this.getBoundingClientRect();\n const boundaryRect = document.documentElement.getBoundingClientRect();\n const offsets = resolveOffsets(this);\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts, triggerRect, selfRect, boundaryRect, offsets));\n }\n }\n\n // --- Trigger discovery ---\n\n #findTrigger(): HTMLElement | null {\n if (!this.id) return null;\n const root = this.getRootNode() as Document | ShadowRoot;\n return root.querySelector<HTMLElement>(`[commandfor=\"${this.id}\"]`);\n }\n\n #syncTrigger(triggerEl: HTMLElement | null): void {\n if (triggerEl === this.#currentTrigger) return;\n\n this.#cleanupTrigger();\n this.#currentTrigger = triggerEl;\n this.#popover?.setTriggerElement(triggerEl);\n\n if (triggerEl && this.#popover) {\n this.#triggerAbort = new AbortController();\n applyElementProps(triggerEl, this.#popover.triggerProps, { signal: this.#triggerAbort.signal });\n }\n }\n\n #cleanupTrigger(): void {\n if (this.#currentTrigger) {\n // Remove ARIA attributes and anchor-name style from the old trigger.\n applyElementProps(this.#currentTrigger, {\n 'aria-expanded': undefined,\n 'aria-haspopup': undefined,\n 'aria-controls': undefined,\n });\n this.#currentTrigger.style.removeProperty('anchor-name');\n }\n\n this.#triggerAbort?.abort();\n this.#triggerAbort = null;\n this.#currentTrigger = null;\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"popover-element.js","names":["#core","#disconnect","#popover","#snapshot","#cleanupTrigger","#findTrigger","#syncTrigger","#currentTrigger","#triggerAbort"],"sources":["../../../../src/ui/popover/popover-element.ts"],"sourcesContent":["import { PopoverCore, PopoverDataAttrs, type PopoverInput, type PopoverProps } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createPopover,\n createTransition,\n getAnchorNameStyle,\n getAnchorPositionStyle,\n type PopoverApi,\n type PopoverChangeDetails,\n resolveOffsets,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { SnapshotController } from '@videojs/store/html';\nimport { applyStyles, supportsAnchorPositioning, tryHidePopover, tryShowPopover } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\n\nexport class PopoverElement extends MediaElement {\n static readonly tagName = 'media-popover';\n\n static override properties = {\n open: { type: Boolean },\n defaultOpen: { type: Boolean, attribute: 'default-open' },\n side: { type: String },\n align: { type: String },\n modal: { type: Boolean },\n closeOnEscape: { type: Boolean, attribute: 'close-on-escape' },\n closeOnOutsideClick: { type: Boolean, attribute: 'close-on-outside-click' },\n openOnHover: { type: Boolean, attribute: 'open-on-hover' },\n delay: { type: Number },\n closeDelay: { type: Number, attribute: 'close-delay' },\n } satisfies PropertyDeclarationMap<keyof PopoverCore.Props>;\n\n open = PopoverCore.defaultProps.open;\n defaultOpen = PopoverCore.defaultProps.defaultOpen;\n side = PopoverCore.defaultProps.side;\n align = PopoverCore.defaultProps.align;\n modal: PopoverProps['modal'] = PopoverCore.defaultProps.modal;\n closeOnEscape = PopoverCore.defaultProps.closeOnEscape;\n closeOnOutsideClick = PopoverCore.defaultProps.closeOnOutsideClick;\n openOnHover = PopoverCore.defaultProps.openOnHover;\n delay = PopoverCore.defaultProps.delay;\n closeDelay = PopoverCore.defaultProps.closeDelay;\n\n readonly #core = new PopoverCore();\n #popover: PopoverApi | null = null;\n #snapshot: SnapshotController<PopoverInput> | null = null;\n\n // Cleanup controllers\n #disconnect: AbortController | null = null;\n #triggerAbort: AbortController | null = null;\n #currentTrigger: HTMLElement | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#disconnect = new AbortController();\n\n this.#popover = createPopover({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean, details: PopoverChangeDetails) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen, ...details } }));\n },\n closeOnEscape: () => this.closeOnEscape,\n closeOnOutsideClick: () => this.closeOnOutsideClick,\n openOnHover: () => this.openOnHover,\n delay: () => this.delay,\n closeDelay: () => this.closeDelay,\n });\n\n // Register self as the popup element — the element IS the popup.\n this.#popover.setPopupElement(this);\n\n // Apply popup event handlers (pointerenter/leave, focusout) to self.\n applyElementProps(this, this.#popover.popupProps, { signal: this.#disconnect.signal });\n\n // Subscribe to interaction state for reactive updates.\n // Reuse the controller across connect/disconnect cycles to avoid\n // leaking stale controllers in the host's controller set.\n if (this.#snapshot) {\n this.#snapshot.track(this.#popover.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#popover.input);\n }\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n\n // Uncontrolled mode: open if `defaultOpen` is set. Controlled `open`\n // is already synced by `willUpdate` on the first render cycle.\n if (this.defaultOpen && !this.open) {\n this.#popover?.open();\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n override destroyCallback(): void {\n this.#cleanupTrigger();\n this.#popover?.destroy();\n super.destroyCallback();\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n this.#core.setProps(this);\n\n // Sync controlled open state\n if (this.#popover && changed.has('open')) {\n const { active: interactionOpen } = this.#popover.input.current;\n if (this.open !== interactionOpen) {\n if (this.open) {\n this.#popover.open();\n } else {\n this.#popover.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#popover) return;\n\n // Discover trigger via commandfor linkage.\n const triggerEl = this.#findTrigger();\n this.#syncTrigger(triggerEl);\n\n // Derive state from core + input.\n const input = this.#popover.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n // Apply popup ARIA and data attributes to self.\n applyElementProps(this, this.#core.getPopupAttrs(state));\n applyStateDataAttrs(this, state, PopoverDataAttrs);\n\n // Show/hide via Popover API AFTER data attributes are applied so\n // `data-starting-style` is present before the first visible frame.\n if (state.open) {\n tryShowPopover(this);\n } else {\n tryHidePopover(this);\n }\n\n // Apply trigger ARIA and anchor-name to the discovered trigger.\n if (this.#currentTrigger) {\n applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));\n applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));\n }\n\n // Skip positioning when closed — no rects to measure.\n if (!state.open) return;\n\n // Apply positioning styles to self.\n const posOpts = { side: state.side, align: state.align };\n\n if (supportsAnchorPositioning()) {\n // Native CSS Anchor Positioning — no JS rect measurements needed.\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts));\n } else {\n // JS fallback: measure rects and resolve CSS var offsets.\n const triggerRect = this.#currentTrigger?.getBoundingClientRect();\n const selfRect = this.getBoundingClientRect();\n const boundaryRect = document.documentElement.getBoundingClientRect();\n const offsets = resolveOffsets(this);\n applyStyles(this, getAnchorPositionStyle(this.id, posOpts, triggerRect, selfRect, boundaryRect, offsets));\n }\n }\n\n // --- Trigger discovery ---\n\n #findTrigger(): HTMLElement | null {\n if (!this.id) return null;\n const root = this.getRootNode() as Document | ShadowRoot;\n return root.querySelector<HTMLElement>(`[commandfor=\"${this.id}\"]`);\n }\n\n #syncTrigger(triggerEl: HTMLElement | null): void {\n if (triggerEl === this.#currentTrigger) return;\n\n this.#cleanupTrigger();\n this.#currentTrigger = triggerEl;\n this.#popover?.setTriggerElement(triggerEl);\n\n if (triggerEl && this.#popover) {\n this.#triggerAbort = new AbortController();\n applyElementProps(triggerEl, this.#popover.triggerProps, { signal: this.#triggerAbort.signal });\n }\n }\n\n #cleanupTrigger(): void {\n if (this.#currentTrigger) {\n // Remove ARIA attributes and anchor-name style from the old trigger.\n applyElementProps(this.#currentTrigger, {\n 'aria-expanded': undefined,\n 'aria-haspopup': undefined,\n 'aria-controls': undefined,\n });\n this.#currentTrigger.style.removeProperty('anchor-name');\n }\n\n this.#triggerAbort?.abort();\n this.#triggerAbort = null;\n this.#currentTrigger = null;\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MediaElement } from "../media-element.js";
|
|
2
2
|
import { sliderContext } from "./context.js";
|
|
3
|
-
import { applyStateDataAttrs, createSlider, getSliderCSSVars } from "@videojs/core/dom";
|
|
3
|
+
import { applyElementProps, applyStateDataAttrs, createSlider, getSliderCSSVars } from "@videojs/core/dom";
|
|
4
4
|
import { ContextProvider } from "@videojs/element/context";
|
|
5
5
|
import { SliderCore, SliderDataAttrs } from "@videojs/core";
|
|
6
6
|
import { applyStyles, isRTL } from "@videojs/utils/dom";
|
|
@@ -47,6 +47,7 @@ var SliderElement = class extends MediaElement {
|
|
|
47
47
|
#disconnect = null;
|
|
48
48
|
connectedCallback() {
|
|
49
49
|
super.connectedCallback();
|
|
50
|
+
if (this.destroyed) return;
|
|
50
51
|
this.#disconnect = new AbortController();
|
|
51
52
|
const signal = this.#disconnect.signal;
|
|
52
53
|
this.#slider = createSlider({
|
|
@@ -77,19 +78,23 @@ var SliderElement = class extends MediaElement {
|
|
|
77
78
|
},
|
|
78
79
|
onDragEnd: () => {
|
|
79
80
|
this.dispatchEvent(new CustomEvent("drag-end", { bubbles: true }));
|
|
80
|
-
}
|
|
81
|
+
},
|
|
82
|
+
adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),
|
|
83
|
+
onResize: () => this.requestUpdate()
|
|
81
84
|
});
|
|
85
|
+
applyElementProps(this, this.#slider.rootProps, { signal });
|
|
86
|
+
applyStyles(this, this.#slider.rootStyle);
|
|
82
87
|
this.#slider.input.subscribe(() => this.requestUpdate(), { signal });
|
|
83
|
-
this.style.touchAction = "none";
|
|
84
|
-
this.style.userSelect = "none";
|
|
85
88
|
}
|
|
86
89
|
disconnectedCallback() {
|
|
87
90
|
super.disconnectedCallback();
|
|
88
|
-
this.#slider?.destroy();
|
|
89
|
-
this.#slider = null;
|
|
90
91
|
this.#disconnect?.abort();
|
|
91
92
|
this.#disconnect = null;
|
|
92
93
|
}
|
|
94
|
+
destroyCallback() {
|
|
95
|
+
this.#slider?.destroy();
|
|
96
|
+
super.destroyCallback();
|
|
97
|
+
}
|
|
93
98
|
willUpdate(_changed) {
|
|
94
99
|
super.willUpdate(_changed);
|
|
95
100
|
this.#core.setProps(this);
|
|
@@ -99,7 +104,7 @@ var SliderElement = class extends MediaElement {
|
|
|
99
104
|
if (!this.#slider) return;
|
|
100
105
|
this.#core.setInput(this.#slider.input.current);
|
|
101
106
|
const state = this.#core.getSliderState(this.value);
|
|
102
|
-
const cssVars = getSliderCSSVars(state);
|
|
107
|
+
const cssVars = getSliderCSSVars(this.#slider.adjustForAlignment(state));
|
|
103
108
|
applyStyles(this, cssVars);
|
|
104
109
|
applyStateDataAttrs(this, state, SliderDataAttrs);
|
|
105
110
|
this.#provider.setValue({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slider-element.js","names":["#core","#provider","#disconnect","#slider"],"sources":["../../../../src/ui/slider/slider-element.ts"],"sourcesContent":["import { SliderCore, SliderDataAttrs } from '@videojs/core';\nimport {
|
|
1
|
+
{"version":3,"file":"slider-element.js","names":["#core","#provider","#disconnect","#slider"],"sources":["../../../../src/ui/slider/slider-element.ts"],"sourcesContent":["import { SliderCore, SliderDataAttrs } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createSlider,\n getSliderCSSVars,\n type SliderApi,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from './context';\n\nexport class SliderElement extends MediaElement {\n static readonly tagName = 'media-slider';\n\n static override properties = {\n label: { type: String },\n value: { type: Number },\n min: { type: Number },\n max: { type: Number },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<keyof SliderCore.Props>;\n\n label = SliderCore.defaultProps.label;\n value = SliderCore.defaultProps.value;\n min = SliderCore.defaultProps.min;\n max = SliderCore.defaultProps.max;\n step = SliderCore.defaultProps.step;\n largeStep = SliderCore.defaultProps.largeStep;\n orientation = SliderCore.defaultProps.orientation;\n disabled = SliderCore.defaultProps.disabled;\n thumbAlignment = SliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new SliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled,\n getPercent: () => this.#core.percentFromValue(this.value),\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueChange: (percent) => {\n this.value = this.#core.valueFromPercent(percent);\n this.dispatchEvent(new CustomEvent('value-change', { detail: { value: this.value }, bubbles: true }));\n },\n onValueCommit: (percent) => {\n this.value = this.#core.valueFromPercent(percent);\n this.dispatchEvent(new CustomEvent('value-commit', { detail: { value: this.value }, bubbles: true }));\n },\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),\n onResize: () => this.requestUpdate(),\n });\n\n applyElementProps(this, this.#slider.rootProps, { signal });\n applyStyles(this, this.#slider.rootStyle);\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n override destroyCallback(): void {\n this.#slider?.destroy();\n super.destroyCallback();\n }\n\n protected override willUpdate(_changed: PropertyValues): void {\n super.willUpdate(_changed);\n this.#core.setProps(this);\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#slider) return;\n\n this.#core.setInput(this.#slider.input.current);\n const state = this.#core.getSliderState(this.value);\n\n const cssVars = getSliderCSSVars(this.#slider.adjustForAlignment(state));\n\n applyStyles(this, cssVars);\n\n // Apply state data attributes to the root element.\n applyStateDataAttrs(this, state, SliderDataAttrs);\n\n // Provide context to child elements (thumb, value, track, etc.).\n this.#provider.setValue({\n state,\n stateAttrMap: SliderDataAttrs,\n pointerValue: this.#core.valueFromPercent(state.pointerPercent),\n thumbAttrs: this.#core.getAttrs(state),\n thumbProps: this.#slider.thumbProps,\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { MediaElement } from "../media-element.js";
|
|
2
|
+
import { sliderContext } from "./context.js";
|
|
3
|
+
import { applyStateDataAttrs, getSliderPreviewStyle } from "@videojs/core/dom";
|
|
4
|
+
import { ContextConsumer } from "@videojs/element/context";
|
|
5
|
+
import { applyStyles } from "@videojs/utils/dom";
|
|
6
|
+
|
|
7
|
+
//#region src/ui/slider/slider-preview-element.ts
|
|
8
|
+
var SliderPreviewElement = class extends MediaElement {
|
|
9
|
+
constructor(..._args) {
|
|
10
|
+
super(..._args);
|
|
11
|
+
this.overflow = "clamp";
|
|
12
|
+
}
|
|
13
|
+
static {
|
|
14
|
+
this.tagName = "media-slider-preview";
|
|
15
|
+
}
|
|
16
|
+
static {
|
|
17
|
+
this.properties = { overflow: { type: String } };
|
|
18
|
+
}
|
|
19
|
+
#ctx = new ContextConsumer(this, {
|
|
20
|
+
context: sliderContext,
|
|
21
|
+
subscribe: true
|
|
22
|
+
});
|
|
23
|
+
#resizeObserver = null;
|
|
24
|
+
#width = 0;
|
|
25
|
+
connectedCallback() {
|
|
26
|
+
super.connectedCallback();
|
|
27
|
+
this.#resizeObserver = new ResizeObserver(([entry]) => {
|
|
28
|
+
this.#width = entry.contentRect.width;
|
|
29
|
+
this.#applyPosition();
|
|
30
|
+
});
|
|
31
|
+
this.#resizeObserver.observe(this);
|
|
32
|
+
}
|
|
33
|
+
disconnectedCallback() {
|
|
34
|
+
super.disconnectedCallback();
|
|
35
|
+
this.#resizeObserver?.disconnect();
|
|
36
|
+
this.#resizeObserver = null;
|
|
37
|
+
}
|
|
38
|
+
#applyPosition() {
|
|
39
|
+
applyStyles(this, getSliderPreviewStyle(this.#width, this.overflow));
|
|
40
|
+
}
|
|
41
|
+
update(_changed) {
|
|
42
|
+
super.update(_changed);
|
|
43
|
+
const ctx = this.#ctx.value;
|
|
44
|
+
if (ctx) applyStateDataAttrs(this, ctx.state, ctx.stateAttrMap);
|
|
45
|
+
this.#applyPosition();
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
//#endregion
|
|
50
|
+
export { SliderPreviewElement };
|
|
51
|
+
//# sourceMappingURL=slider-preview-element.js.map
|