@videojs/html 10.0.0-beta.2 → 10.0.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. package/cdn/audio-minimal.dev.js +25 -39
  2. package/cdn/audio-minimal.dev.js.map +1 -1
  3. package/cdn/audio-minimal.js +4 -4
  4. package/cdn/audio-minimal.js.map +1 -1
  5. package/cdn/audio.css +1 -1
  6. package/cdn/audio.dev.js +26 -40
  7. package/cdn/audio.dev.js.map +1 -1
  8. package/cdn/audio.js +4 -4
  9. package/cdn/audio.js.map +1 -1
  10. package/cdn/background.dev.js +13 -7
  11. package/cdn/background.dev.js.map +1 -1
  12. package/cdn/background.js +4 -4
  13. package/cdn/background.js.map +1 -1
  14. package/cdn/video-minimal.css +1 -1
  15. package/cdn/video-minimal.dev.js +26 -52
  16. package/cdn/video-minimal.dev.js.map +1 -1
  17. package/cdn/video-minimal.js +5 -5
  18. package/cdn/video-minimal.js.map +1 -1
  19. package/cdn/video.css +1 -1
  20. package/cdn/video.dev.js +27 -53
  21. package/cdn/video.dev.js.map +1 -1
  22. package/cdn/video.js +5 -5
  23. package/cdn/video.js.map +1 -1
  24. package/dist/default/_virtual/inline-css_src/define/audio/skin.js +1 -1
  25. package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  26. package/dist/default/_virtual/inline-css_src/define/base.js +6 -0
  27. package/dist/default/_virtual/inline-css_src/define/base.js.map +1 -0
  28. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  29. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  30. package/dist/default/_virtual/inline-css_src/define/video/skin.js +1 -1
  31. package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  32. package/dist/default/define/audio/skin.css +2 -0
  33. package/dist/default/define/base.css +25 -0
  34. package/dist/default/define/skin-mixin.js +10 -18
  35. package/dist/default/define/skin-mixin.js.map +1 -1
  36. package/dist/default/define/video/minimal-skin.css +1 -64
  37. package/dist/default/define/video/minimal-skin.js.map +1 -1
  38. package/dist/default/define/video/minimal-skin.tailwind.js +1 -2
  39. package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
  40. package/dist/default/define/video/skin.css +3 -64
  41. package/dist/default/define/video/skin.js +1 -1
  42. package/dist/default/define/video/skin.js.map +1 -1
  43. package/dist/default/define/video/skin.tailwind.js +2 -2
  44. package/dist/default/define/video/skin.tailwind.js.map +1 -1
  45. package/dist/default/skins/dist/default/default/tailwind/components/root.js +1 -1
  46. package/dist/default/skins/dist/default/default/tailwind/components/root.js.map +1 -1
  47. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +1 -1
  48. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
  49. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +0 -1
  50. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
  51. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +0 -1
  52. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
  53. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +1 -1
  54. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  55. package/dist/dev/_virtual/inline-css_src/define/base.js +6 -0
  56. package/dist/dev/_virtual/inline-css_src/define/base.js.map +1 -0
  57. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  58. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  59. package/dist/dev/_virtual/inline-css_src/define/video/skin.js +1 -1
  60. package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  61. package/dist/dev/define/audio/skin.css +2 -0
  62. package/dist/dev/define/base.css +25 -0
  63. package/dist/dev/define/skin-mixin.d.ts +2 -2
  64. package/dist/dev/define/skin-mixin.d.ts.map +1 -1
  65. package/dist/dev/define/skin-mixin.js +10 -32
  66. package/dist/dev/define/skin-mixin.js.map +1 -1
  67. package/dist/dev/define/video/minimal-skin.css +1 -64
  68. package/dist/dev/define/video/minimal-skin.d.ts.map +1 -1
  69. package/dist/dev/define/video/minimal-skin.js +0 -12
  70. package/dist/dev/define/video/minimal-skin.js.map +1 -1
  71. package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -1
  72. package/dist/dev/define/video/minimal-skin.tailwind.js +0 -13
  73. package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -1
  74. package/dist/dev/define/video/skin.css +3 -64
  75. package/dist/dev/define/video/skin.d.ts.map +1 -1
  76. package/dist/dev/define/video/skin.js +1 -13
  77. package/dist/dev/define/video/skin.js.map +1 -1
  78. package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -1
  79. package/dist/dev/define/video/skin.tailwind.js +1 -13
  80. package/dist/dev/define/video/skin.tailwind.js.map +1 -1
  81. package/dist/dev/skins/dist/default/default/tailwind/components/root.js +1 -1
  82. package/dist/dev/skins/dist/default/default/tailwind/components/root.js.map +1 -1
  83. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +1 -1
  84. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
  85. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +0 -1
  86. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
  87. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +0 -1
  88. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
  89. package/package.json +8 -8
  90. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js +0 -15
  91. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js.map +0 -1
  92. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js +0 -15
  93. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"skin.js","names":[],"sources":["../../../../../../inline-css:src/define/video/skin.js"],"sourcesContent":["export default \"/* ==========================================================================\\n Icon State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state icon buttons.\\n Uses :is() with both element selectors (for HTML custom element wrappers)\\n and class selectors (for React rendered SVG elements).\\n ========================================================================== */\\n\\n/* --- All icons hidden by default --- */\\n\\n.media-button--play .media-icon--restart,\\n.media-button--play .media-icon--play,\\n.media-button--play .media-icon--pause,\\n.media-button--mute .media-icon--volume-off,\\n.media-button--mute .media-icon--volume-low,\\n.media-button--mute .media-icon--volume-high,\\n.media-button--fullscreen .media-icon--fullscreen-enter,\\n.media-button--fullscreen .media-icon--fullscreen-exit,\\n.media-button--captions .media-icon--captions-off,\\n.media-button--captions .media-icon--captions-on {\\n display: none;\\n opacity: 0;\\n}\\n\\n/* --- Active icon per state --- */\\n\\n/* Play: ended → restart */\\n.media-button--play[data-ended] .media-icon--restart,\\n/* Play: paused (not ended) → play */\\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\\n/* Play: playing (not paused, not ended) → pause */\\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\\n/* Mute: muted → volume off */\\n.media-button--mute[data-muted] .media-icon--volume-off,\\n/* Mute: volume low (not muted) → volume low */\\n.media-button--mute:not([data-muted])[data-volume-level=\\\"low\\\"] .media-icon--volume-low,\\n/* Mute: volume high (not muted, not low) → volume high */\\n.media-button--mute:not([data-muted]):not([data-volume-level=\\\"low\\\"]) .media-icon--volume-high,\\n/* Fullscreen: not fullscreen → enter */\\n.media-button--fullscreen:not([data-fullscreen]) .media-icon--fullscreen-enter,\\n/* Fullscreen: fullscreen → exit */\\n.media-button--fullscreen[data-fullscreen] .media-icon--fullscreen-exit,\\n/* Captions: not active → captions off */\\n.media-button--captions:not([data-active]) .media-icon--captions-off,\\n/* Captions: active → captions on */\\n.media-button--captions[data-active] .media-icon--captions-on {\\n display: block;\\n opacity: 1;\\n}\\n\\n/* ==========================================================================\\n Tooltip Label State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state tooltip labels.\\n Uses adjacent sibling selectors to match button state → tooltip content.\\n ========================================================================== */\\n\\n/* --- All multi-state labels hidden by default --- */\\n\\n.media-tooltip-label {\\n display: none;\\n}\\n\\n/* --- Active label per state --- */\\n\\n/* Play: ended → replay */\\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\\n/* Play: paused (not ended) → play */\\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\\n .media-tooltip-label--play,\\n/* Play: playing (not paused, not ended) → pause */\\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\\n .media-tooltip-label--pause,\\n/* Fullscreen: not fullscreen → enter */\\n .media-button--fullscreen:not([data-fullscreen]) + .media-tooltip\\n .media-tooltip-label--enter-fullscreen,\\n/* Fullscreen: fullscreen → exit */\\n .media-button--fullscreen[data-fullscreen] + .media-tooltip\\n .media-tooltip-label--exit-fullscreen,\\n/* Captions: not active → enable */\\n .media-button--captions:not([data-active]) + .media-tooltip\\n .media-tooltip-label--enable-captions,\\n/* Captions: active → disable */\\n .media-button--captions[data-active] + .media-tooltip\\n .media-tooltip-label--disable-captions,\\n/* PiP: not in pip → enter */\\n .media-button--pip:not([data-pip]) + .media-tooltip\\n .media-tooltip-label--enter-pip,\\n/* PiP: in pip → exit */\\n .media-button--pip[data-pip] + .media-tooltip\\n .media-tooltip-label--exit-pip {\\n display: block;\\n}\\n\\n/* ==========================================================================\\n Reset\\n ========================================================================== */\\n\\n.media-default-skin *,\\n.media-default-skin *::before,\\n.media-default-skin *::after {\\n box-sizing: border-box;\\n margin: 0;\\n}\\n.media-default-skin img,\\n.media-default-skin video,\\n.media-default-skin svg {\\n display: block;\\n max-width: 100%;\\n}\\n.media-default-skin button {\\n font: inherit;\\n}\\n@media (prefers-reduced-motion: no-preference) {\\n .media-default-skin {\\n interpolate-size: allow-keywords;\\n }\\n}\\n\\n/* ==========================================================================\\n Root Container\\n ========================================================================== */\\n\\n.media-default-skin {\\n position: relative;\\n isolation: isolate;\\n display: block;\\n container: media-root / inline-size;\\n border-radius: var(--media-border-radius, 2rem);\\n font-family:\\n Inter Variable,\\n Inter,\\n ui-sans-serif,\\n system-ui,\\n sans-serif;\\n font-size: 0.8125rem;\\n line-height: 1.5;\\n letter-spacing: normal;\\n -webkit-font-smoothing: auto;\\n -moz-osx-font-smoothing: auto;\\n\\n &:fullscreen {\\n border-radius: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Surface (shared glass effect for tooltips, popovers, controls)\\n ========================================================================== */\\n\\n.media-default-skin .media-surface {\\n background-color: var(--media-surface-background-color);\\n backdrop-filter: var(--media-surface-backdrop-filter);\\n box-shadow:\\n inset 0 0 0 1px var(--media-surface-inner-border-color),\\n 0 1px 3px 0 var(--media-surface-shadow-color),\\n 0 1px 2px -1px var(--media-surface-shadow-color);\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: 0 0 0 1px var(--media-surface-outer-border-color);\\n pointer-events: none;\\n }\\n\\n @media (prefers-reduced-transparency: reduce) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.7);\\n }\\n\\n @media (prefers-contrast: more) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.9);\\n }\\n}\\n\\n/* ==========================================================================\\n Media Element\\n ========================================================================== */\\n\\n.media-default-skin ::slotted(video),\\n.media-default-skin video {\\n display: block;\\n width: 100%;\\n height: 100%;\\n border-radius: var(--media-border-radius, 2rem);\\n}\\n\\n/* ==========================================================================\\n Poster Image\\n ========================================================================== */\\n\\n.media-default-skin > img {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n border-radius: inherit;\\n object-fit: cover;\\n transition: opacity 0.25s;\\n pointer-events: none;\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Overlay / Scrim\\n ========================================================================== */\\n\\n.media-default-skin .media-overlay {\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.5), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\\n backdrop-filter: blur(0) saturate(1.2) brightness(0.9);\\n opacity: 0;\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\n}\\n\\n.media-default-skin .media-controls[data-visible] ~ .media-overlay,\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n opacity: 1;\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n}\\n\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(8px) saturate(1.2) brightness(0.9);\\n}\\n\\n/* ==========================================================================\\n Buffering Indicator\\n ========================================================================== */\\n\\n.media-default-skin .media-buffering-indicator {\\n position: absolute;\\n inset: 0;\\n display: none;\\n align-items: center;\\n justify-content: center;\\n color: oklch(1 0 0);\\n pointer-events: none;\\n\\n &[data-visible] {\\n display: flex;\\n }\\n\\n .media-surface {\\n padding: 0.25rem;\\n border-radius: 100%;\\n }\\n}\\n\\n/* ==========================================================================\\n Error Dialog\\n ========================================================================== */\\n\\n.media-default-skin .media-error {\\n position: absolute;\\n inset: 0;\\n z-index: 20;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n}\\n\\n.media-default-skin .media-error__dialog {\\n display: flex;\\n flex-direction: column;\\n gap: 0.75rem;\\n max-width: 18rem;\\n padding: 0.75rem;\\n border-radius: 1.75rem;\\n color: oklch(1 0 0);\\n font-size: 0.875rem;\\n transition-property: opacity, transform;\\n transition-duration: 500ms;\\n transition-delay: 100ms;\\n transition-timing-function: linear(\\n 0,\\n 0.034 1.5%,\\n 0.763 9.7%,\\n 1.066 13.9%,\\n 1.198 19.9%,\\n 1.184 21.8%,\\n 0.963 37.5%,\\n 0.997 50.9%,\\n 1\\n );\\n\\n /* Simple, fast transition for reduced motion users */\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n }\\n}\\n\\n.media-default-skin .media-error[data-starting-style] .media-error__dialog,\\n.media-default-skin .media-error[data-ending-style] .media-error__dialog {\\n opacity: 0;\\n transform: scale(0.5);\\n}\\n\\n.media-default-skin .media-error__content {\\n display: flex;\\n flex-direction: column;\\n gap: 0.5rem;\\n padding: 0.5rem 0.5rem 0.375rem;\\n}\\n\\n.media-default-skin .media-error__title {\\n font-weight: 600;\\n line-height: 1.25;\\n}\\n\\n.media-default-skin .media-error__description {\\n opacity: 0.7;\\n}\\n\\n.media-default-skin .media-error__actions {\\n display: flex;\\n gap: 0.5rem;\\n\\n & > * {\\n flex: 1;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-default-skin .media-controls {\\n container: media-controls / inline-size;\\n display: flex;\\n align-items: center;\\n gap: 0.075rem;\\n padding: 0.175rem;\\n border-radius: calc(infinity * 1px);\\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\\n --media-controls-current-shadow-color-subtle: oklch(\\n from var(--media-controls-current-shadow-color) l c h /\\n calc(alpha * 0.4)\\n );\\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\\n\\n @container media-root (width > 40rem) {\\n gap: 0.125rem;\\n padding: 0.25rem;\\n }\\n}\\n\\n/* ==========================================================================\\n Time Display\\n ========================================================================== */\\n\\n.media-default-skin .media-time {\\n container: media-time / inline-size;\\n display: flex;\\n align-items: center;\\n flex: 1;\\n gap: 0.75rem;\\n padding-inline: 0.5rem;\\n\\n & .media-time__value:first-child {\\n display: none;\\n\\n @container media-time (width > 18rem) {\\n display: block;\\n }\\n }\\n}\\n\\n.media-default-skin .media-time__value {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Buttons\\n ========================================================================== */\\n\\n/* Base button */\\n.media-default-skin .media-button {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-shrink: 0;\\n padding: 0.5rem 1rem;\\n background: oklch(1 0 0);\\n border: none;\\n border-radius: calc(infinity * 1px);\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n color: oklch(0 0 0);\\n font-weight: 500;\\n text-align: center;\\n transition-property: background-color, color, outline-offset, transform;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n\\n &:focus-visible {\\n outline-color: oklch(62.3% 0.214 259.815);\\n outline-offset: 2px;\\n }\\n\\n &[disabled] {\\n opacity: 0.5;\\n filter: grayscale(1);\\n cursor: not-allowed;\\n }\\n\\n &[data-availability=\\\"unavailable\\\"] {\\n display: none;\\n }\\n}\\n\\n/* Icon button variant */\\n.media-default-skin .media-button--icon {\\n display: grid;\\n width: 2.125rem;\\n padding: 0;\\n aspect-ratio: 1;\\n background: transparent;\\n color: inherit;\\n text-shadow: inherit;\\n\\n &:hover,\\n &:focus-visible,\\n &[aria-expanded=\\\"true\\\"] {\\n background-color: oklch(from currentColor l c h / 0.1);\\n text-decoration: none;\\n }\\n\\n &:active {\\n transform: scale(0.9);\\n }\\n\\n & .media-icon {\\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\\n }\\n}\\n\\n/* Seek button */\\n.media-default-skin .media-button--seek {\\n & .media-icon__label {\\n position: absolute;\\n right: -1px;\\n bottom: -3px;\\n font-size: 0.75em;\\n font-weight: 480;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n &:has(.media-icon--flipped) .media-icon__label {\\n right: unset;\\n left: -1px;\\n }\\n\\n @container media-controls (width < 28rem) {\\n display: none;\\n }\\n}\\n\\n/* Playback rate button */\\n.media-default-skin .media-button--playback-rate {\\n padding: 0;\\n\\n &::after {\\n content: attr(data-rate) \\\"\\\\00D7\\\";\\n width: 4ch;\\n font-variant-numeric: tabular-nums;\\n }\\n}\\n\\n/* ==========================================================================\\n Icons\\n ========================================================================== */\\n\\n.media-default-skin .media-icon__container {\\n position: relative;\\n}\\n.media-default-skin .media-icon {\\n display: block;\\n flex-shrink: 0;\\n grid-area: 1 / 1;\\n width: 18px;\\n height: 18px;\\n transition-behavior: allow-discrete;\\n transition-property: display, opacity;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n}\\n.media-default-skin .media-icon--flipped {\\n scale: -1 1;\\n}\\n\\n/* ==========================================================================\\n Slider\\n ========================================================================== */\\n\\n.media-default-skin .media-slider {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex: 1;\\n border-radius: calc(infinity * 1px);\\n outline: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n min-width: 5rem;\\n width: 100%;\\n height: 1.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 1.25rem;\\n height: 5rem;\\n }\\n}\\n\\n/* Track */\\n.media-default-skin .media-slider__track {\\n position: relative;\\n isolation: isolate;\\n overflow: hidden;\\n border-radius: inherit;\\n user-select: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: 100%;\\n height: 0.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 0.25rem;\\n height: 100%;\\n }\\n}\\n\\n/* Thumb */\\n.media-default-skin .media-slider__thumb {\\n z-index: 10;\\n position: absolute;\\n transform: translate(-50%, -50%);\\n width: 0.625rem;\\n height: 0.625rem;\\n background-color: currentColor;\\n border-radius: calc(infinity * 1px);\\n box-shadow:\\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\\n opacity: 0;\\n transition-property: opacity, height, width, outline-offset;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n user-select: none;\\n outline: 4px solid transparent;\\n outline-offset: -4px;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n top: 50%;\\n left: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n left: 50%;\\n top: calc(100% - var(--media-slider-fill));\\n }\\n\\n &:hover,\\n &:focus {\\n outline-color: oklch(from currentColor l c h / 0.25);\\n outline-offset: 0;\\n }\\n}\\n\\n.media-default-skin .media-slider:active .media-slider__thumb,\\n.media-default-skin .media-slider__thumb--persistent {\\n width: 0.75rem;\\n height: 0.75rem;\\n}\\n\\n.media-default-skin .media-slider:hover .media-slider__thumb,\\n.media-default-skin .media-slider__thumb:focus-visible,\\n.media-default-skin .media-slider__thumb--persistent {\\n opacity: 1;\\n}\\n\\n/* Shared track fills */\\n.media-default-skin .media-slider__buffer,\\n.media-default-skin .media-slider__fill {\\n position: absolute;\\n border-radius: inherit;\\n pointer-events: none;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"horizontal\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"horizontal\\\"] {\\n inset-block: 0;\\n left: 0;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"vertical\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"vertical\\\"] {\\n inset-inline: 0;\\n bottom: 0;\\n}\\n\\n/* Buffer */\\n.media-default-skin .media-slider__buffer {\\n background-color: oklch(from currentColor l c h / 0.2);\\n transition-duration: 0.25s;\\n transition-timing-function: ease-out;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-buffer);\\n transition-property: width;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-buffer);\\n transition-property: height;\\n }\\n}\\n\\n/* Fill */\\n.media-default-skin .media-slider__fill {\\n background-color: currentColor;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-fill);\\n }\\n}\\n\\n/* Time display within slider */\\n.media-default-skin .media-slider__time-display {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Popups & Tooltips\\n ========================================================================== */\\n\\n.media-default-skin .media-popover,\\n.media-default-skin .media-tooltip {\\n margin: 0;\\n border: 0;\\n color: inherit;\\n overflow: visible;\\n transition-property: transform, scale, opacity, filter;\\n transition-duration: 200ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0);\\n filter: blur(8px);\\n }\\n\\n &[data-instant] {\\n transition-duration: 0ms;\\n }\\n\\n &[data-side=\\\"top\\\"] {\\n transform-origin: bottom;\\n }\\n &[data-side=\\\"bottom\\\"] {\\n transform-origin: top;\\n }\\n &[data-side=\\\"left\\\"] {\\n transform-origin: right;\\n }\\n &[data-side=\\\"right\\\"] {\\n transform-origin: left;\\n }\\n}\\n\\n.media-default-skin .media-popover {\\n --media-popover-side-offset: 0.5rem;\\n}\\n.media-default-skin .media-popover--volume {\\n padding: 0.625rem 0.25rem;\\n border-radius: calc(infinity * 1px);\\n}\\n\\n.media-default-skin .media-tooltip {\\n padding: 0.25rem 0.625rem;\\n border-radius: calc(infinity * 1px);\\n font-size: 0.75rem;\\n white-space: nowrap;\\n --media-tooltip-side-offset: 0.5rem;\\n}\\n\\n/* ==========================================================================\\n Captions\\n ========================================================================== */\\n\\n.media-default-skin .media-captions {\\n position: absolute;\\n inset: auto 1rem 1.5rem 1rem;\\n z-index: 20;\\n font-size: 1rem;\\n text-wrap: balance;\\n pointer-events: none;\\n\\n @container media-root (width > 20rem) {\\n font-size: 1.5rem;\\n }\\n\\n @container media-root (width > 48rem) {\\n font-size: 1.875rem;\\n }\\n\\n @container media-root (width > 80rem) {\\n font-size: 2.25rem;\\n }\\n}\\n\\n.media-default-skin .media-captions__container {\\n display: flex;\\n flex-direction: column;\\n align-items: center;\\n max-width: 42ch;\\n margin: 0 auto;\\n text-align: center;\\n}\\n\\n.media-default-skin .media-captions__text {\\n display: block;\\n padding: 0.125rem 0.5rem;\\n color: oklch(1 0 0);\\n text-shadow:\\n 0 0 1px oklch(0 0 0 / 0.7),\\n 0 0 8px oklch(0 0 0 / 0.7);\\n text-align: center;\\n white-space: pre-wrap;\\n line-height: 1.2;\\n\\n @media (prefers-contrast: more) {\\n background: oklch(0 0 0 / 0.7);\\n text-shadow: none;\\n box-decoration-break: clone;\\n }\\n\\n & > * {\\n display: inline;\\n }\\n}\\n\\n/* Caption shifting styles (custom and native) */\\n.media-default-skin {\\n --media-caption-track-delay: 600ms;\\n --media-caption-track-y: -0.5rem;\\n\\n &:has(.media-controls[data-visible]) {\\n --media-caption-track-delay: 25ms;\\n --media-caption-track-y: -3.5rem;\\n }\\n}\\n\\n.media-default-skin .media-captions,\\n.media-default-skin video::-webkit-media-text-track-container {\\n /* NOTE: The delay must account for the controls delay/duration */\\n transition: transform 150ms ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n}\\n\\n.media-default-skin video::-webkit-media-text-track-container {\\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n/* When controls are visible, shift captions up to avoid overlap */\\n.media-default-skin .media-controls[data-visible] ~ .media-captions {\\n transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));\\n}\\n\\n@media (prefers-reduced-motion: reduce) {\\n .media-default-skin .media-captions,\\n .media-default-skin video::-webkit-media-text-track-container {\\n transition-duration: 50ms;\\n }\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-default-skin--video {\\n background: oklch(0 0 0);\\n --media-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-background-color: oklch(1 0 0 / 0.1);\\n --media-surface-inner-border-color: oklch(1 0 0 / 0.05);\\n --media-surface-outer-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-shadow-color: oklch(0 0 0 / 0.15);\\n --media-surface-backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.1);\\n }\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: inset 0 0 0 1px var(--media-border-color);\\n pointer-events: none;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls (hide/show behavior)\\n ========================================================================== */\\n\\n.media-default-skin--video .media-controls {\\n position: absolute;\\n bottom: 0.75rem;\\n inset-inline: 0.75rem;\\n z-index: 10;\\n will-change: scale, transform, filter, opacity;\\n transition-property: scale, transform, filter, opacity;\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n transform-origin: bottom;\\n color: oklch(1 0 0);\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n scale: 0.9;\\n filter: blur(8px);\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n scale: 1;\\n filter: blur(0);\\n transition-duration: 100ms;\\n }\\n }\\n}\\n\\n/* ==========================================================================\\n Sliders\\n ========================================================================== */\\n\\n.media-default-skin--video .media-slider__track {\\n background-color: oklch(1 0 0 / 0.2);\\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\\n}\\n\\n\";"],"mappings":";AAAA,mBAAe"}
1
+ {"version":3,"file":"skin.js","names":[],"sources":["../../../../../../inline-css:src/define/video/skin.js"],"sourcesContent":["export default \"/* ==========================================================================\\n Icon State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state icon buttons.\\n Uses :is() with both element selectors (for HTML custom element wrappers)\\n and class selectors (for React rendered SVG elements).\\n ========================================================================== */\\n\\n/* --- All icons hidden by default --- */\\n\\n.media-button--play .media-icon--restart,\\n.media-button--play .media-icon--play,\\n.media-button--play .media-icon--pause,\\n.media-button--mute .media-icon--volume-off,\\n.media-button--mute .media-icon--volume-low,\\n.media-button--mute .media-icon--volume-high,\\n.media-button--fullscreen .media-icon--fullscreen-enter,\\n.media-button--fullscreen .media-icon--fullscreen-exit,\\n.media-button--captions .media-icon--captions-off,\\n.media-button--captions .media-icon--captions-on {\\n display: none;\\n opacity: 0;\\n}\\n\\n/* --- Active icon per state --- */\\n\\n/* Play: ended → restart */\\n.media-button--play[data-ended] .media-icon--restart,\\n/* Play: paused (not ended) → play */\\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\\n/* Play: playing (not paused, not ended) → pause */\\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\\n/* Mute: muted → volume off */\\n.media-button--mute[data-muted] .media-icon--volume-off,\\n/* Mute: volume low (not muted) → volume low */\\n.media-button--mute:not([data-muted])[data-volume-level=\\\"low\\\"] .media-icon--volume-low,\\n/* Mute: volume high (not muted, not low) → volume high */\\n.media-button--mute:not([data-muted]):not([data-volume-level=\\\"low\\\"]) .media-icon--volume-high,\\n/* Fullscreen: not fullscreen → enter */\\n.media-button--fullscreen:not([data-fullscreen]) .media-icon--fullscreen-enter,\\n/* Fullscreen: fullscreen → exit */\\n.media-button--fullscreen[data-fullscreen] .media-icon--fullscreen-exit,\\n/* Captions: not active → captions off */\\n.media-button--captions:not([data-active]) .media-icon--captions-off,\\n/* Captions: active → captions on */\\n.media-button--captions[data-active] .media-icon--captions-on {\\n display: block;\\n opacity: 1;\\n}\\n\\n/* ==========================================================================\\n Tooltip Label State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state tooltip labels.\\n Uses adjacent sibling selectors to match button state → tooltip content.\\n ========================================================================== */\\n\\n/* --- All multi-state labels hidden by default --- */\\n\\n.media-tooltip-label {\\n display: none;\\n}\\n\\n/* --- Active label per state --- */\\n\\n/* Play: ended → replay */\\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\\n/* Play: paused (not ended) → play */\\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\\n .media-tooltip-label--play,\\n/* Play: playing (not paused, not ended) → pause */\\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\\n .media-tooltip-label--pause,\\n/* Fullscreen: not fullscreen → enter */\\n .media-button--fullscreen:not([data-fullscreen]) + .media-tooltip\\n .media-tooltip-label--enter-fullscreen,\\n/* Fullscreen: fullscreen → exit */\\n .media-button--fullscreen[data-fullscreen] + .media-tooltip\\n .media-tooltip-label--exit-fullscreen,\\n/* Captions: not active → enable */\\n .media-button--captions:not([data-active]) + .media-tooltip\\n .media-tooltip-label--enable-captions,\\n/* Captions: active → disable */\\n .media-button--captions[data-active] + .media-tooltip\\n .media-tooltip-label--disable-captions,\\n/* PiP: not in pip → enter */\\n .media-button--pip:not([data-pip]) + .media-tooltip\\n .media-tooltip-label--enter-pip,\\n/* PiP: in pip → exit */\\n .media-button--pip[data-pip] + .media-tooltip\\n .media-tooltip-label--exit-pip {\\n display: block;\\n}\\n\\n/* ==========================================================================\\n Reset\\n ========================================================================== */\\n\\n.media-default-skin *,\\n.media-default-skin *::before,\\n.media-default-skin *::after {\\n box-sizing: border-box;\\n margin: 0;\\n}\\n.media-default-skin img,\\n.media-default-skin video,\\n.media-default-skin svg {\\n display: block;\\n max-width: 100%;\\n}\\n.media-default-skin button {\\n font: inherit;\\n}\\n@media (prefers-reduced-motion: no-preference) {\\n .media-default-skin {\\n interpolate-size: allow-keywords;\\n }\\n}\\n\\n/* ==========================================================================\\n Root Container\\n ========================================================================== */\\n\\n.media-default-skin {\\n position: relative;\\n isolation: isolate;\\n display: block;\\n height: 100%;\\n width: 100%;\\n container: media-root / inline-size;\\n border-radius: var(--media-border-radius, 2rem);\\n font-family:\\n Inter Variable,\\n Inter,\\n ui-sans-serif,\\n system-ui,\\n sans-serif;\\n font-size: 0.8125rem;\\n line-height: 1.5;\\n letter-spacing: normal;\\n -webkit-font-smoothing: auto;\\n -moz-osx-font-smoothing: auto;\\n\\n &:fullscreen {\\n border-radius: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Surface (shared glass effect for tooltips, popovers, controls)\\n ========================================================================== */\\n\\n.media-default-skin .media-surface {\\n background-color: var(--media-surface-background-color);\\n backdrop-filter: var(--media-surface-backdrop-filter);\\n box-shadow:\\n inset 0 0 0 1px var(--media-surface-inner-border-color),\\n 0 1px 3px 0 var(--media-surface-shadow-color),\\n 0 1px 2px -1px var(--media-surface-shadow-color);\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: 0 0 0 1px var(--media-surface-outer-border-color);\\n pointer-events: none;\\n }\\n\\n @media (prefers-reduced-transparency: reduce) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.7);\\n }\\n\\n @media (prefers-contrast: more) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.9);\\n }\\n}\\n\\n/* ==========================================================================\\n Media Element\\n ========================================================================== */\\n\\n.media-default-skin ::slotted(video),\\n.media-default-skin video {\\n display: block;\\n width: 100%;\\n height: 100%;\\n border-radius: var(--media-border-radius, 2rem);\\n}\\n\\n/* ==========================================================================\\n Poster Image\\n ========================================================================== */\\n\\n.media-default-skin > img {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n border-radius: inherit;\\n object-fit: cover;\\n transition: opacity 0.25s;\\n pointer-events: none;\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Overlay / Scrim\\n ========================================================================== */\\n\\n.media-default-skin .media-overlay {\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.5), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\\n backdrop-filter: blur(0) saturate(1.2) brightness(0.9);\\n opacity: 0;\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\n}\\n\\n.media-default-skin .media-controls[data-visible] ~ .media-overlay,\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n opacity: 1;\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n}\\n\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(8px) saturate(1.2) brightness(0.9);\\n}\\n\\n/* ==========================================================================\\n Buffering Indicator\\n ========================================================================== */\\n\\n.media-default-skin .media-buffering-indicator {\\n position: absolute;\\n inset: 0;\\n display: none;\\n align-items: center;\\n justify-content: center;\\n color: oklch(1 0 0);\\n pointer-events: none;\\n\\n &[data-visible] {\\n display: flex;\\n }\\n\\n .media-surface {\\n padding: 0.25rem;\\n border-radius: 100%;\\n }\\n}\\n\\n/* ==========================================================================\\n Error Dialog\\n ========================================================================== */\\n\\n.media-default-skin .media-error {\\n position: absolute;\\n inset: 0;\\n z-index: 20;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n}\\n\\n.media-default-skin .media-error__dialog {\\n display: flex;\\n flex-direction: column;\\n gap: 0.75rem;\\n max-width: 18rem;\\n padding: 0.75rem;\\n border-radius: 1.75rem;\\n color: oklch(1 0 0);\\n font-size: 0.875rem;\\n transition-property: opacity, transform;\\n transition-duration: 500ms;\\n transition-delay: 100ms;\\n transition-timing-function: linear(\\n 0,\\n 0.034 1.5%,\\n 0.763 9.7%,\\n 1.066 13.9%,\\n 1.198 19.9%,\\n 1.184 21.8%,\\n 0.963 37.5%,\\n 0.997 50.9%,\\n 1\\n );\\n\\n /* Simple, fast transition for reduced motion users */\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n }\\n}\\n\\n.media-default-skin .media-error[data-starting-style] .media-error__dialog,\\n.media-default-skin .media-error[data-ending-style] .media-error__dialog {\\n opacity: 0;\\n transform: scale(0.5);\\n}\\n\\n.media-default-skin .media-error__content {\\n display: flex;\\n flex-direction: column;\\n gap: 0.5rem;\\n padding: 0.5rem 0.5rem 0.375rem;\\n}\\n\\n.media-default-skin .media-error__title {\\n font-weight: 600;\\n line-height: 1.25;\\n}\\n\\n.media-default-skin .media-error__description {\\n opacity: 0.7;\\n}\\n\\n.media-default-skin .media-error__actions {\\n display: flex;\\n gap: 0.5rem;\\n\\n & > * {\\n flex: 1;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-default-skin .media-controls {\\n container: media-controls / inline-size;\\n display: flex;\\n align-items: center;\\n gap: 0.075rem;\\n padding: 0.175rem;\\n border-radius: calc(infinity * 1px);\\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\\n --media-controls-current-shadow-color-subtle: oklch(\\n from var(--media-controls-current-shadow-color) l c h /\\n calc(alpha * 0.4)\\n );\\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\\n\\n @container media-root (width > 40rem) {\\n gap: 0.125rem;\\n padding: 0.25rem;\\n }\\n}\\n\\n/* ==========================================================================\\n Time Display\\n ========================================================================== */\\n\\n.media-default-skin .media-time {\\n container: media-time / inline-size;\\n display: flex;\\n align-items: center;\\n flex: 1;\\n gap: 0.75rem;\\n padding-inline: 0.5rem;\\n\\n & .media-time__value:first-child {\\n display: none;\\n\\n @container media-time (width > 18rem) {\\n display: block;\\n }\\n }\\n}\\n\\n.media-default-skin .media-time__value {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Buttons\\n ========================================================================== */\\n\\n/* Base button */\\n.media-default-skin .media-button {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-shrink: 0;\\n padding: 0.5rem 1rem;\\n background: oklch(1 0 0);\\n border: none;\\n border-radius: calc(infinity * 1px);\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n color: oklch(0 0 0);\\n font-weight: 500;\\n text-align: center;\\n transition-property: background-color, color, outline-offset, transform;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n\\n &:focus-visible {\\n outline-color: oklch(62.3% 0.214 259.815);\\n outline-offset: 2px;\\n }\\n\\n &[disabled] {\\n opacity: 0.5;\\n filter: grayscale(1);\\n cursor: not-allowed;\\n }\\n\\n &[data-availability=\\\"unavailable\\\"] {\\n display: none;\\n }\\n}\\n\\n/* Icon button variant */\\n.media-default-skin .media-button--icon {\\n display: grid;\\n width: 2.125rem;\\n padding: 0;\\n aspect-ratio: 1;\\n background: transparent;\\n color: inherit;\\n text-shadow: inherit;\\n\\n &:hover,\\n &:focus-visible,\\n &[aria-expanded=\\\"true\\\"] {\\n background-color: oklch(from currentColor l c h / 0.1);\\n text-decoration: none;\\n }\\n\\n &:active {\\n transform: scale(0.9);\\n }\\n\\n & .media-icon {\\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\\n }\\n}\\n\\n/* Seek button */\\n.media-default-skin .media-button--seek {\\n & .media-icon__label {\\n position: absolute;\\n right: -1px;\\n bottom: -3px;\\n font-size: 0.75em;\\n font-weight: 480;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n &:has(.media-icon--flipped) .media-icon__label {\\n right: unset;\\n left: -1px;\\n }\\n\\n @container media-controls (width < 28rem) {\\n display: none;\\n }\\n}\\n\\n/* Playback rate button */\\n.media-default-skin .media-button--playback-rate {\\n padding: 0;\\n\\n &::after {\\n content: attr(data-rate) \\\"\\\\00D7\\\";\\n width: 4ch;\\n font-variant-numeric: tabular-nums;\\n }\\n}\\n\\n/* ==========================================================================\\n Icons\\n ========================================================================== */\\n\\n.media-default-skin .media-icon__container {\\n position: relative;\\n}\\n.media-default-skin .media-icon {\\n display: block;\\n flex-shrink: 0;\\n grid-area: 1 / 1;\\n width: 18px;\\n height: 18px;\\n transition-behavior: allow-discrete;\\n transition-property: display, opacity;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n}\\n.media-default-skin .media-icon--flipped {\\n scale: -1 1;\\n}\\n\\n/* ==========================================================================\\n Slider\\n ========================================================================== */\\n\\n.media-default-skin .media-slider {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex: 1;\\n border-radius: calc(infinity * 1px);\\n outline: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n min-width: 5rem;\\n width: 100%;\\n height: 1.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 1.25rem;\\n height: 5rem;\\n }\\n}\\n\\n/* Track */\\n.media-default-skin .media-slider__track {\\n position: relative;\\n isolation: isolate;\\n overflow: hidden;\\n border-radius: inherit;\\n user-select: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: 100%;\\n height: 0.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 0.25rem;\\n height: 100%;\\n }\\n}\\n\\n/* Thumb */\\n.media-default-skin .media-slider__thumb {\\n z-index: 10;\\n position: absolute;\\n transform: translate(-50%, -50%);\\n width: 0.625rem;\\n height: 0.625rem;\\n background-color: currentColor;\\n border-radius: calc(infinity * 1px);\\n box-shadow:\\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\\n opacity: 0;\\n transition-property: opacity, height, width, outline-offset;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n user-select: none;\\n outline: 4px solid transparent;\\n outline-offset: -4px;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n top: 50%;\\n left: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n left: 50%;\\n top: calc(100% - var(--media-slider-fill));\\n }\\n\\n &:hover,\\n &:focus {\\n outline-color: oklch(from currentColor l c h / 0.25);\\n outline-offset: 0;\\n }\\n}\\n\\n.media-default-skin .media-slider:active .media-slider__thumb,\\n.media-default-skin .media-slider__thumb--persistent {\\n width: 0.75rem;\\n height: 0.75rem;\\n}\\n\\n.media-default-skin .media-slider:hover .media-slider__thumb,\\n.media-default-skin .media-slider__thumb:focus-visible,\\n.media-default-skin .media-slider__thumb--persistent {\\n opacity: 1;\\n}\\n\\n/* Shared track fills */\\n.media-default-skin .media-slider__buffer,\\n.media-default-skin .media-slider__fill {\\n position: absolute;\\n border-radius: inherit;\\n pointer-events: none;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"horizontal\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"horizontal\\\"] {\\n inset-block: 0;\\n left: 0;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"vertical\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"vertical\\\"] {\\n inset-inline: 0;\\n bottom: 0;\\n}\\n\\n/* Buffer */\\n.media-default-skin .media-slider__buffer {\\n background-color: oklch(from currentColor l c h / 0.2);\\n transition-duration: 0.25s;\\n transition-timing-function: ease-out;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-buffer);\\n transition-property: width;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-buffer);\\n transition-property: height;\\n }\\n}\\n\\n/* Fill */\\n.media-default-skin .media-slider__fill {\\n background-color: currentColor;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-fill);\\n }\\n}\\n\\n/* Time display within slider */\\n.media-default-skin .media-slider__time-display {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Popups & Tooltips\\n ========================================================================== */\\n\\n.media-default-skin .media-popover,\\n.media-default-skin .media-tooltip {\\n margin: 0;\\n border: 0;\\n color: inherit;\\n overflow: visible;\\n transition-property: transform, scale, opacity, filter;\\n transition-duration: 200ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0);\\n filter: blur(8px);\\n }\\n\\n &[data-instant] {\\n transition-duration: 0ms;\\n }\\n\\n &[data-side=\\\"top\\\"] {\\n transform-origin: bottom;\\n }\\n &[data-side=\\\"bottom\\\"] {\\n transform-origin: top;\\n }\\n &[data-side=\\\"left\\\"] {\\n transform-origin: right;\\n }\\n &[data-side=\\\"right\\\"] {\\n transform-origin: left;\\n }\\n}\\n\\n.media-default-skin .media-popover {\\n --media-popover-side-offset: 0.5rem;\\n}\\n.media-default-skin .media-popover--volume {\\n padding: 0.625rem 0.25rem;\\n border-radius: calc(infinity * 1px);\\n}\\n\\n.media-default-skin .media-tooltip {\\n padding: 0.25rem 0.625rem;\\n border-radius: calc(infinity * 1px);\\n font-size: 0.75rem;\\n white-space: nowrap;\\n --media-tooltip-side-offset: 0.5rem;\\n}\\n\\n/* ==========================================================================\\n Native Caption Track\\n ========================================================================== */\\n\\n.media-default-skin {\\n --media-caption-track-delay: 600ms;\\n --media-caption-track-y: -0.5rem;\\n\\n &:has(.media-controls[data-visible]) {\\n --media-caption-track-delay: 25ms;\\n --media-caption-track-y: -3.5rem;\\n }\\n}\\n\\n.media-default-skin video::-webkit-media-text-track-container {\\n /* NOTE: The delay must account for the controls delay/duration */\\n transition: transform 150ms ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n@media (prefers-reduced-motion: reduce) {\\n .media-default-skin video::-webkit-media-text-track-container {\\n transition-duration: 50ms;\\n }\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-default-skin--video {\\n background: oklch(0 0 0);\\n --media-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-background-color: oklch(1 0 0 / 0.1);\\n --media-surface-inner-border-color: oklch(1 0 0 / 0.05);\\n --media-surface-outer-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-shadow-color: oklch(0 0 0 / 0.15);\\n --media-surface-backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.1);\\n }\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: inset 0 0 0 1px var(--media-border-color);\\n pointer-events: none;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls (hide/show behavior)\\n ========================================================================== */\\n\\n.media-default-skin--video .media-controls {\\n position: absolute;\\n bottom: 0.75rem;\\n inset-inline: 0.75rem;\\n z-index: 10;\\n will-change: scale, transform, filter, opacity;\\n transition-property: scale, transform, filter, opacity;\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n transform-origin: bottom;\\n color: oklch(1 0 0);\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n scale: 0.9;\\n filter: blur(8px);\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n scale: 1;\\n filter: blur(0);\\n transition-duration: 100ms;\\n }\\n }\\n}\\n\\n/* ==========================================================================\\n Sliders\\n ========================================================================== */\\n\\n.media-default-skin--video .media-slider__track {\\n background-color: oklch(1 0 0 / 0.2);\\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\\n}\\n\\n\";"],"mappings":";AAAA,mBAAe"}
@@ -95,6 +95,8 @@
95
95
  position: relative;
96
96
  isolation: isolate;
97
97
  display: block;
98
+ height: 100%;
99
+ width: 100%;
98
100
  container: media-root / inline-size;
99
101
  border-radius: var(--media-border-radius, 2rem);
100
102
  font-family:
@@ -0,0 +1,25 @@
1
+ video-player {
2
+ display: contents;
3
+ }
4
+
5
+ video-player video,
6
+ video-player hls-video,
7
+ video-player simple-hls-video {
8
+ display: block;
9
+ width: 100%;
10
+ height: 100%;
11
+ }
12
+
13
+ video-player video::-webkit-media-text-track-container {
14
+ transition: transform var(--media-caption-track-duration, 150ms) ease-out;
15
+ transition-delay: var(--media-caption-track-delay, 600ms);
16
+ transform: translateY(var(--media-caption-track-y, 0)) scale(0.98);
17
+ z-index: var(--media-caption-track-z, 1);
18
+ font-family: inherit;
19
+ }
20
+
21
+ @media (prefers-reduced-motion: reduce) {
22
+ video-player video::-webkit-media-text-track-container {
23
+ transition-duration: 50ms;
24
+ }
25
+ }
@@ -7,8 +7,8 @@ import { Constructor } from "@videojs/utils/types";
7
7
  * `getTemplateHTML` method into a shadow root. Native `<slot>` elements
8
8
  * handle light DOM projection automatically.
9
9
  *
10
- * When `static styles` is set, the stylesheet is adopted into the shadow
11
- * root via `adoptedStyleSheets`.
10
+ * When `static styles` is set, the stylesheet is adopted into the
11
+ * shadow root via `adoptedStyleSheets`.
12
12
  */
13
13
  declare function SkinMixin<Base extends Constructor<ReactiveElement>>(BaseClass: Base): Base & {
14
14
  shadowRootOptions: ShadowRootInit;
@@ -1 +1 @@
1
- {"version":3,"file":"skin-mixin.d.ts","names":[],"sources":["../../../src/define/skin-mixin.ts"],"mappings":";;;;;;AA6CA;;;;;;iBAAgB,SAAA,cAAuB,WAAA,CAAY,eAAA,EAAA,CACjD,SAAA,EAAW,IAAA,GACV,IAAA;EAAS,iBAAA,EAAmB,cAAA;EAAgB,MAAA,GAAS,aAAA;AAAA;;iBA8BxC,YAAA,CAAa,GAAA,WAAc,aAAA"}
1
+ {"version":3,"file":"skin-mixin.d.ts","names":[],"sources":["../../../src/define/skin-mixin.ts"],"mappings":";;;;;;AAsBA;;;;;;iBAAgB,SAAA,cAAuB,WAAA,CAAY,eAAA,EAAA,CACjD,SAAA,EAAW,IAAA,GACV,IAAA;EAAS,iBAAA,EAAmB,cAAA;EAAgB,MAAA,GAAS,aAAA;AAAA;;iBA6BxC,YAAA,CAAa,GAAA,WAAc,aAAA"}
@@ -1,33 +1,12 @@
1
- //#region src/define/skin-mixin.ts
2
- /**
3
- * Light DOM stylesheet that bridges CSS custom properties set by skins
4
- * to native WebKit text track pseudo-elements on the slotted `<video>`.
5
- *
6
- * `::slotted(video)::-webkit-media-text-track-container` is invalid per
7
- * CSS spec, so this bridge lives in light DOM where it can directly
8
- * target the video element's pseudo-elements.
9
- */
10
- const NATIVE_CAPTION_BRIDGE_CSS = `
11
- .media-skin > video::-webkit-media-text-track-container {
12
- transition: transform var(--media-caption-track-duration, 150ms) ease-out;
13
- transition-delay: var(--media-caption-track-delay, 600ms);
14
- transform: translateY(var(--media-caption-track-y, 0)) scale(0.98);
15
- z-index: var(--media-caption-track-z, 1);
16
- font-family: inherit;
17
- }
1
+ import base_default from "../_virtual/inline-css_src/define/base.js";
18
2
 
19
- @media (prefers-reduced-motion: reduce) {
20
- .media-skin > video::-webkit-media-text-track-container {
21
- transition-duration: 50ms;
22
- }
23
- }
24
- `;
25
- const BRIDGE_ID = "media-caption-bridge";
26
- function ensureCaptionBridge() {
27
- if (document.getElementById(BRIDGE_ID)) return;
3
+ //#region src/define/skin-mixin.ts
4
+ const STYLES_ID = "__media-styles";
5
+ function ensureStyles() {
6
+ if (document.getElementById(STYLES_ID)) return;
28
7
  const style = document.createElement("style");
29
- style.id = BRIDGE_ID;
30
- style.textContent = NATIVE_CAPTION_BRIDGE_CSS;
8
+ style.id = STYLES_ID;
9
+ style.textContent = base_default;
31
10
  document.head.appendChild(style);
32
11
  }
33
12
  /**
@@ -35,8 +14,8 @@ function ensureCaptionBridge() {
35
14
  * `getTemplateHTML` method into a shadow root. Native `<slot>` elements
36
15
  * handle light DOM projection automatically.
37
16
  *
38
- * When `static styles` is set, the stylesheet is adopted into the shadow
39
- * root via `adoptedStyleSheets`.
17
+ * When `static styles` is set, the stylesheet is adopted into the
18
+ * shadow root via `adoptedStyleSheets`.
40
19
  */
41
20
  function SkinMixin(BaseClass) {
42
21
  class SkinElement extends BaseClass {
@@ -45,8 +24,7 @@ function SkinMixin(BaseClass) {
45
24
  }
46
25
  constructor(...args) {
47
26
  super(...args);
48
- this.classList.add("media-skin");
49
- ensureCaptionBridge();
27
+ ensureStyles();
50
28
  if (!this.shadowRoot) {
51
29
  const ctor = this.constructor;
52
30
  this.attachShadow(ctor.shadowRootOptions);
@@ -1 +1 @@
1
- {"version":3,"file":"skin-mixin.js","names":[],"sources":["../../../src/define/skin-mixin.ts"],"sourcesContent":["import type { ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\n/**\n * Light DOM stylesheet that bridges CSS custom properties set by skins\n * to native WebKit text track pseudo-elements on the slotted `<video>`.\n *\n * `::slotted(video)::-webkit-media-text-track-container` is invalid per\n * CSS spec, so this bridge lives in light DOM where it can directly\n * target the video element's pseudo-elements.\n */\nconst NATIVE_CAPTION_BRIDGE_CSS = /* css */ `\n.media-skin > video::-webkit-media-text-track-container {\n transition: transform var(--media-caption-track-duration, 150ms) ease-out;\n transition-delay: var(--media-caption-track-delay, 600ms);\n transform: translateY(var(--media-caption-track-y, 0)) scale(0.98);\n z-index: var(--media-caption-track-z, 1);\n font-family: inherit;\n}\n\n@media (prefers-reduced-motion: reduce) {\n .media-skin > video::-webkit-media-text-track-container {\n transition-duration: 50ms;\n }\n}\n`;\n\nconst BRIDGE_ID = 'media-caption-bridge';\n\nfunction ensureCaptionBridge(): void {\n if (document.getElementById(BRIDGE_ID)) return;\n const style = document.createElement('style');\n style.id = BRIDGE_ID;\n style.textContent = NATIVE_CAPTION_BRIDGE_CSS;\n document.head.appendChild(style);\n}\n\n/**\n * Mixin for skin elements that renders the template from a static\n * `getTemplateHTML` method into a shadow root. Native `<slot>` elements\n * handle light DOM projection automatically.\n *\n * When `static styles` is set, the stylesheet is adopted into the shadow\n * root via `adoptedStyleSheets`.\n */\nexport function SkinMixin<Base extends Constructor<ReactiveElement>>(\n BaseClass: Base\n): Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet } {\n class SkinElement extends (BaseClass as Constructor<ReactiveElement>) {\n static shadowRootOptions: ShadowRootInit = { mode: 'open' };\n static styles?: CSSStyleSheet;\n\n constructor(...args: any[]) {\n super(...args);\n\n this.classList.add('media-skin');\n ensureCaptionBridge();\n\n if (!this.shadowRoot) {\n const ctor = this.constructor as typeof SkinElement & { getTemplateHTML?: () => string };\n this.attachShadow(ctor.shadowRootOptions);\n\n if (ctor.styles) {\n this.shadowRoot!.adoptedStyleSheets = [ctor.styles];\n }\n\n if (ctor.getTemplateHTML) {\n this.shadowRoot!.innerHTML = ctor.getTemplateHTML();\n }\n }\n }\n }\n\n return SkinElement as unknown as Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet };\n}\n\n/** Create a shared `CSSStyleSheet` from a CSS string. */\nexport function createStyles(css: string): CSSStyleSheet {\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(css);\n return sheet;\n}\n"],"mappings":";;;;;;;;;AAWA,MAAM,4BAAsC;;;;;;;;;;;;;;;AAgB5C,MAAM,YAAY;AAElB,SAAS,sBAA4B;AACnC,KAAI,SAAS,eAAe,UAAU,CAAE;CACxC,MAAM,QAAQ,SAAS,cAAc,QAAQ;AAC7C,OAAM,KAAK;AACX,OAAM,cAAc;AACpB,UAAS,KAAK,YAAY,MAAM;;;;;;;;;;AAWlC,SAAgB,UACd,WACsE;CACtE,MAAM,oBAAqB,UAA2C;;4BACzB,EAAE,MAAM,QAAQ;;EAG3D,YAAY,GAAG,MAAa;AAC1B,SAAM,GAAG,KAAK;AAEd,QAAK,UAAU,IAAI,aAAa;AAChC,wBAAqB;AAErB,OAAI,CAAC,KAAK,YAAY;IACpB,MAAM,OAAO,KAAK;AAClB,SAAK,aAAa,KAAK,kBAAkB;AAEzC,QAAI,KAAK,OACP,MAAK,WAAY,qBAAqB,CAAC,KAAK,OAAO;AAGrD,QAAI,KAAK,gBACP,MAAK,WAAY,YAAY,KAAK,iBAAiB;;;;AAM3D,QAAO;;;AAIT,SAAgB,aAAa,KAA4B;CACvD,MAAM,QAAQ,IAAI,eAAe;AACjC,OAAM,YAAY,IAAI;AACtB,QAAO"}
1
+ {"version":3,"file":"skin-mixin.js","names":["styles"],"sources":["../../../src/define/skin-mixin.ts"],"sourcesContent":["import type { ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\nimport styles from './base.css?inline';\n\nconst STYLES_ID = '__media-styles';\n\nfunction ensureStyles(): void {\n if (document.getElementById(STYLES_ID)) return;\n const style = document.createElement('style');\n style.id = STYLES_ID;\n style.textContent = styles;\n document.head.appendChild(style);\n}\n\n/**\n * Mixin for skin elements that renders the template from a static\n * `getTemplateHTML` method into a shadow root. Native `<slot>` elements\n * handle light DOM projection automatically.\n *\n * When `static styles` is set, the stylesheet is adopted into the\n * shadow root via `adoptedStyleSheets`.\n */\nexport function SkinMixin<Base extends Constructor<ReactiveElement>>(\n BaseClass: Base\n): Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet } {\n class SkinElement extends (BaseClass as Constructor<ReactiveElement>) {\n static shadowRootOptions: ShadowRootInit = { mode: 'open' };\n static styles?: CSSStyleSheet;\n\n constructor(...args: any[]) {\n super(...args);\n\n ensureStyles();\n\n if (!this.shadowRoot) {\n const ctor = this.constructor as typeof SkinElement & { getTemplateHTML?: () => string };\n this.attachShadow(ctor.shadowRootOptions);\n\n if (ctor.styles) {\n this.shadowRoot!.adoptedStyleSheets = [ctor.styles];\n }\n\n if (ctor.getTemplateHTML) {\n this.shadowRoot!.innerHTML = ctor.getTemplateHTML();\n }\n }\n }\n }\n\n return SkinElement as unknown as Base & { shadowRootOptions: ShadowRootInit; styles?: CSSStyleSheet };\n}\n\n/** Create a shared `CSSStyleSheet` from a CSS string. */\nexport function createStyles(css: string): CSSStyleSheet {\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(css);\n return sheet;\n}\n"],"mappings":";;;AAIA,MAAM,YAAY;AAElB,SAAS,eAAqB;AAC5B,KAAI,SAAS,eAAe,UAAU,CAAE;CACxC,MAAM,QAAQ,SAAS,cAAc,QAAQ;AAC7C,OAAM,KAAK;AACX,OAAM,cAAcA;AACpB,UAAS,KAAK,YAAY,MAAM;;;;;;;;;;AAWlC,SAAgB,UACd,WACsE;CACtE,MAAM,oBAAqB,UAA2C;;4BACzB,EAAE,MAAM,QAAQ;;EAG3D,YAAY,GAAG,MAAa;AAC1B,SAAM,GAAG,KAAK;AAEd,iBAAc;AAEd,OAAI,CAAC,KAAK,YAAY;IACpB,MAAM,OAAO,KAAK;AAClB,SAAK,aAAa,KAAK,kBAAkB;AAEzC,QAAI,KAAK,OACP,MAAK,WAAY,qBAAqB,CAAC,KAAK,OAAO;AAGrD,QAAI,KAAK,gBACP,MAAK,WAAY,YAAY,KAAK,iBAAiB;;;;AAM3D,QAAO;;;AAIT,SAAgB,aAAa,KAA4B;CACvD,MAAM,QAAQ,IAAI,eAAe;AACjC,OAAM,YAAY,IAAI;AACtB,QAAO"}
@@ -693,62 +693,9 @@
693
693
  }
694
694
 
695
695
  /* ==========================================================================
696
- Captions
696
+ Native Caption Track
697
697
  ========================================================================== */
698
698
 
699
- .media-minimal-skin .media-captions {
700
- position: absolute;
701
- inset: auto 1rem 1.5rem 1rem;
702
- z-index: 20;
703
- font-size: 1rem;
704
- text-wrap: balance;
705
- pointer-events: none;
706
-
707
- @container media-root (width > 20rem) {
708
- font-size: 1.5rem;
709
- }
710
-
711
- @container media-root (width > 48rem) {
712
- font-size: 1.875rem;
713
- }
714
-
715
- @container media-root (width > 80rem) {
716
- font-size: 2.25rem;
717
- }
718
- }
719
-
720
- .media-minimal-skin .media-captions__container {
721
- display: flex;
722
- flex-direction: column;
723
- align-items: center;
724
- max-width: 42ch;
725
- margin: 0 auto;
726
- text-align: center;
727
- }
728
-
729
- .media-minimal-skin .media-captions__text {
730
- display: block;
731
- padding: 0.125rem 0.5rem;
732
- color: oklch(1 0 0);
733
- text-shadow:
734
- 0 0 1px oklch(0 0 0 / 0.7),
735
- 0 0 8px oklch(0 0 0 / 0.7);
736
- text-align: center;
737
- white-space: pre-wrap;
738
- line-height: 1.2;
739
-
740
- @media (prefers-contrast: more) {
741
- background: oklch(0 0 0 / 0.7);
742
- text-shadow: none;
743
- box-decoration-break: clone;
744
- }
745
-
746
- & > * {
747
- display: inline;
748
- }
749
- }
750
-
751
- /* Caption shifting styles (custom and native) */
752
699
  .media-minimal-skin {
753
700
  --media-caption-track-delay: 600ms;
754
701
  --media-caption-track-y: -0.5rem;
@@ -759,26 +706,16 @@
759
706
  }
760
707
  }
761
708
 
762
- .media-minimal-skin .media-captions,
763
709
  .media-minimal-skin video::-webkit-media-text-track-container {
764
710
  /* NOTE: The delay must account for the controls delay/duration */
765
711
  transition: transform 150ms ease-out;
766
712
  transition-delay: var(--media-caption-track-delay);
767
- }
768
-
769
- .media-minimal-skin video::-webkit-media-text-track-container {
770
713
  transform: translateY(var(--media-caption-track-y)) scale(0.98);
771
714
  z-index: 1;
772
715
  font-family: inherit;
773
716
  }
774
717
 
775
- /* When controls are visible, shift captions up to avoid overlap */
776
- .media-minimal-skin .media-controls[data-visible] ~ .media-captions {
777
- transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));
778
- }
779
-
780
718
  @media (prefers-reduced-motion: reduce) {
781
- .media-minimal-skin .media-captions,
782
719
  .media-minimal-skin video::-webkit-media-text-track-container {
783
720
  transition-duration: 50ms;
784
721
  }
@@ -1 +1 @@
1
- {"version":3,"file":"minimal-skin.d.ts","names":[],"sources":["../../../../src/define/video/minimal-skin.ts"],"mappings":";;;iBAuBS,eAAA,CAAA;AAAA,cAAe,4BAAA;;;;cA4HX,uBAAA,SAAgC,4BAAA;EAAA,gBAC3B,OAAA;EAAA,OACT,MAAA,EAAM,aAAA;EAAA,OACN,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,uBAAA,CAAwB,OAAA,GAAU,uBAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"minimal-skin.d.ts","names":[],"sources":["../../../../src/define/video/minimal-skin.ts"],"mappings":";;;iBAuBS,eAAA,CAAA;AAAA,cAAe,4BAAA;;;;cAgHX,uBAAA,SAAgC,4BAAA;EAAA,gBAC3B,OAAA;EAAA,OACT,MAAA,EAAM,aAAA;EAAA,OACN,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,uBAAA,CAAwB,OAAA,GAAU,uBAAA;EAAA;AAAA"}
@@ -28,18 +28,6 @@ function getTemplateHTML() {
28
28
  ${renderIcon("spinner", { class: "media-icon" })}
29
29
  </media-buffering-indicator>
30
30
 
31
- <!--<div class="media-error" role="alertdialog" aria-labelledby="media-error-title" aria-describedby="media-error-description">
32
- <div class="media-error__dialog">
33
- <div class="media-error__content">
34
- <p id="media-error-title" class="media-error__title">Something went wrong.</p>
35
- <p id="media-error-description" class="media-error__description">An error occurred while trying to play the video. Please try again.</p>
36
- </div>
37
- <div class="media-error__actions">
38
- <button type="button" class="media-button">OK</button>
39
- </div>
40
- </div>
41
- </div>-->
42
-
43
31
  <media-controls class="media-controls">
44
32
  <span class="media-button-group">
45
33
  <media-play-button commandfor="play-tooltip" class="media-button media-button--icon media-button--play">
@@ -1 +1 @@
1
- {"version":3,"file":"minimal-skin.js","names":["styles"],"sources":["../../../../src/define/video/minimal-skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render/minimal';\nimport { createStyles, SkinMixin } from '../skin-mixin';\nimport styles from './minimal-skin.css?inline';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/buffering-indicator';\nimport '../ui/controls';\nimport '../ui/fullscreen-button';\nimport '../ui/mute-button';\nimport '../ui/pip-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"media-minimal-skin media-minimal-skin--video\">\n <slot name=\"media\"></slot>\n\n <media-buffering-indicator class=\"media-buffering-indicator\">\n ${renderIcon('spinner', { class: 'media-icon' })}\n </media-buffering-indicator>\n\n <!--<div class=\"media-error\" role=\"alertdialog\" aria-labelledby=\"media-error-title\" aria-describedby=\"media-error-description\">\n <div class=\"media-error__dialog\">\n <div class=\"media-error__content\">\n <p id=\"media-error-title\" class=\"media-error__title\">Something went wrong.</p>\n <p id=\"media-error-description\" class=\"media-error__description\">An error occurred while trying to play the video. Please try again.</p>\n </div>\n <div class=\"media-error__actions\">\n <button type=\"button\" class=\"media-button\">OK</button>\n </div>\n </div>\n </div>-->\n\n <media-controls class=\"media-controls\">\n <span class=\"media-button-group\">\n <media-play-button commandfor=\"play-tooltip\" class=\"media-button media-button--icon media-button--play\">\n ${renderIcon('restart', { class: 'media-icon media-icon--restart' })}\n ${renderIcon('play', { class: 'media-icon media-icon--play' })}\n ${renderIcon('pause', { class: 'media-icon media-icon--pause' })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--replay\">Replay</span>\n <span class=\"media-tooltip-label media-tooltip-label--play\">Play</span>\n <span class=\"media-tooltip-label media-tooltip-label--pause\">Pause</span>\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--flipped' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n </span>\n\n <span class=\"media-time-controls\">\n <media-time-group class=\"media-time\">\n <media-time type=\"current\" class=\"media-time__value media-time__value--current\"></media-time>\n <media-time-separator class=\"media-time__separator\"></media-time-separator>\n <media-time type=\"duration\" class=\"media-time__value media-time__value--duration\"></media-time>\n </media-time-group>\n\n <media-time-slider class=\"media-slider\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n <media-slider-buffer class=\"media-slider__buffer\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb\"></media-slider-thumb>\n </media-time-slider>\n </span>\n\n <span class=\"media-button-group\">\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"media-button media-button--icon media-button--playback-rate\"></media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"media-tooltip\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"video-volume-popover\" class=\"media-button media-button--icon media-button--mute\">\n ${renderIcon('volume-off', { class: 'media-icon media-icon--volume-off' })}\n ${renderIcon('volume-low', { class: 'media-icon media-icon--volume-low' })}\n ${renderIcon('volume-high', { class: 'media-icon media-icon--volume-high' })}\n </media-mute-button>\n\n <media-popover id=\"video-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"media-popover media-popover--volume\">\n <media-volume-slider class=\"media-slider\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb media-slider__thumb--persistent\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n\n <media-captions-button commandfor=\"captions-tooltip\" class=\"media-button media-button--icon media-button--captions\">\n ${renderIcon('captions-off', { class: 'media-icon media-icon--captions-off' })}\n ${renderIcon('captions-on', { class: 'media-icon media-icon--captions-on' })}\n </media-captions-button>\n <media-tooltip id=\"captions-tooltip\" side=\"top\" class=\"media-tooltip\">\n Toggle captions\n </media-tooltip>\n\n <media-pip-button commandfor=\"pip-tooltip\" class=\"media-button media-button--icon\">\n ${renderIcon('pip', { class: 'media-icon' })}\n </media-pip-button>\n <media-tooltip id=\"pip-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--enter-pip\">Enter picture-in-picture</span>\n <span class=\"media-tooltip-label media-tooltip-label--exit-pip\">Exit picture-in-picture</span>\n </media-tooltip>\n\n <media-fullscreen-button commandfor=\"fullscreen-tooltip\" class=\"media-button media-button--icon media-button--fullscreen\">\n ${renderIcon('fullscreen-enter', { class: 'media-icon media-icon--fullscreen-enter' })}\n ${renderIcon('fullscreen-exit', { class: 'media-icon media-icon--fullscreen-exit' })}\n </media-fullscreen-button>\n <media-tooltip id=\"fullscreen-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--enter-fullscreen\">Enter fullscreen</span>\n <span class=\"media-tooltip-label media-tooltip-label--exit-fullscreen\">Exit fullscreen</span>\n </media-tooltip>\n </span>\n </media-controls>\n\n <div class=\"media-overlay\"></div>\n </media-container>\n `;\n}\n\nexport class MinimalVideoSkinElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'video-minimal-skin';\n static styles = createStyles(styles);\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(MinimalVideoSkinElement.tagName, MinimalVideoSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [MinimalVideoSkinElement.tagName]: MinimalVideoSkinElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAqBA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;;;;;UAKR,WAAW,WAAW,EAAE,OAAO,cAAc,CAAC,CAAC;;;;;;;;;;;;;;;;;;cAkB3C,WAAW,WAAW,EAAE,OAAO,kCAAkC,CAAC,CAAC;cACnE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;cAC7D,WAAW,SAAS,EAAE,OAAO,gCAAgC,CAAC,CAAC;;;;;;;;2EAQF,CAAC,UAAU;;gBAEtE,WAAW,QAAQ,EAAE,OAAO,kCAAkC,CAAC,CAAC;gDAChC,UAAU;;;;4BAI9B,UAAU;;;0EAGoC,UAAU;;gBAEpE,WAAW,QAAQ,EAAE,OAAO,cAAc,CAAC,CAAC;gDACZ,UAAU;;;;2BAI/B,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;cA2BvB,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;cACzE,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;cACzE,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;;;;;;;cAa3E,WAAW,gBAAgB,EAAE,OAAO,uCAAuC,CAAC,CAAC;cAC7E,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;cAO3E,WAAW,OAAO,EAAE,OAAO,cAAc,CAAC,CAAC;;;;;;;;cAQ3C,WAAW,oBAAoB,EAAE,OAAO,2CAA2C,CAAC,CAAC;cACrF,WAAW,mBAAmB,EAAE,OAAO,0CAA0C,CAAC,CAAC;;;;;;;;;;;;;AAcjG,IAAa,0BAAb,cAA6C,UAAU,gBAAgB,CAAC;;iBAC5C;;;gBACV,aAAaA,qBAAO;;;yBACX;;;AAG3B,eAAe,OAAO,wBAAwB,SAAS,wBAAwB"}
1
+ {"version":3,"file":"minimal-skin.js","names":["styles"],"sources":["../../../../src/define/video/minimal-skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render/minimal';\nimport { createStyles, SkinMixin } from '../skin-mixin';\nimport styles from './minimal-skin.css?inline';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/buffering-indicator';\nimport '../ui/controls';\nimport '../ui/fullscreen-button';\nimport '../ui/mute-button';\nimport '../ui/pip-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"media-minimal-skin media-minimal-skin--video\">\n <slot name=\"media\"></slot>\n\n <media-buffering-indicator class=\"media-buffering-indicator\">\n ${renderIcon('spinner', { class: 'media-icon' })}\n </media-buffering-indicator>\n\n <media-controls class=\"media-controls\">\n <span class=\"media-button-group\">\n <media-play-button commandfor=\"play-tooltip\" class=\"media-button media-button--icon media-button--play\">\n ${renderIcon('restart', { class: 'media-icon media-icon--restart' })}\n ${renderIcon('play', { class: 'media-icon media-icon--play' })}\n ${renderIcon('pause', { class: 'media-icon media-icon--pause' })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--replay\">Replay</span>\n <span class=\"media-tooltip-label media-tooltip-label--play\">Play</span>\n <span class=\"media-tooltip-label media-tooltip-label--pause\">Pause</span>\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--flipped' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n </span>\n\n <span class=\"media-time-controls\">\n <media-time-group class=\"media-time\">\n <media-time type=\"current\" class=\"media-time__value media-time__value--current\"></media-time>\n <media-time-separator class=\"media-time__separator\"></media-time-separator>\n <media-time type=\"duration\" class=\"media-time__value media-time__value--duration\"></media-time>\n </media-time-group>\n\n <media-time-slider class=\"media-slider\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n <media-slider-buffer class=\"media-slider__buffer\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb\"></media-slider-thumb>\n </media-time-slider>\n </span>\n\n <span class=\"media-button-group\">\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"media-button media-button--icon media-button--playback-rate\"></media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"media-tooltip\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"video-volume-popover\" class=\"media-button media-button--icon media-button--mute\">\n ${renderIcon('volume-off', { class: 'media-icon media-icon--volume-off' })}\n ${renderIcon('volume-low', { class: 'media-icon media-icon--volume-low' })}\n ${renderIcon('volume-high', { class: 'media-icon media-icon--volume-high' })}\n </media-mute-button>\n\n <media-popover id=\"video-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"media-popover media-popover--volume\">\n <media-volume-slider class=\"media-slider\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb media-slider__thumb--persistent\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n\n <media-captions-button commandfor=\"captions-tooltip\" class=\"media-button media-button--icon media-button--captions\">\n ${renderIcon('captions-off', { class: 'media-icon media-icon--captions-off' })}\n ${renderIcon('captions-on', { class: 'media-icon media-icon--captions-on' })}\n </media-captions-button>\n <media-tooltip id=\"captions-tooltip\" side=\"top\" class=\"media-tooltip\">\n Toggle captions\n </media-tooltip>\n\n <media-pip-button commandfor=\"pip-tooltip\" class=\"media-button media-button--icon\">\n ${renderIcon('pip', { class: 'media-icon' })}\n </media-pip-button>\n <media-tooltip id=\"pip-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--enter-pip\">Enter picture-in-picture</span>\n <span class=\"media-tooltip-label media-tooltip-label--exit-pip\">Exit picture-in-picture</span>\n </media-tooltip>\n\n <media-fullscreen-button commandfor=\"fullscreen-tooltip\" class=\"media-button media-button--icon media-button--fullscreen\">\n ${renderIcon('fullscreen-enter', { class: 'media-icon media-icon--fullscreen-enter' })}\n ${renderIcon('fullscreen-exit', { class: 'media-icon media-icon--fullscreen-exit' })}\n </media-fullscreen-button>\n <media-tooltip id=\"fullscreen-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--enter-fullscreen\">Enter fullscreen</span>\n <span class=\"media-tooltip-label media-tooltip-label--exit-fullscreen\">Exit fullscreen</span>\n </media-tooltip>\n </span>\n </media-controls>\n\n <div class=\"media-overlay\"></div>\n </media-container>\n `;\n}\n\nexport class MinimalVideoSkinElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'video-minimal-skin';\n static styles = createStyles(styles);\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(MinimalVideoSkinElement.tagName, MinimalVideoSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [MinimalVideoSkinElement.tagName]: MinimalVideoSkinElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAqBA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;;;;;UAKR,WAAW,WAAW,EAAE,OAAO,cAAc,CAAC,CAAC;;;;;;cAM3C,WAAW,WAAW,EAAE,OAAO,kCAAkC,CAAC,CAAC;cACnE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;cAC7D,WAAW,SAAS,EAAE,OAAO,gCAAgC,CAAC,CAAC;;;;;;;;2EAQF,CAAC,UAAU;;gBAEtE,WAAW,QAAQ,EAAE,OAAO,kCAAkC,CAAC,CAAC;gDAChC,UAAU;;;;4BAI9B,UAAU;;;0EAGoC,UAAU;;gBAEpE,WAAW,QAAQ,EAAE,OAAO,cAAc,CAAC,CAAC;gDACZ,UAAU;;;;2BAI/B,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;cA2BvB,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;cACzE,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;cACzE,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;;;;;;;cAa3E,WAAW,gBAAgB,EAAE,OAAO,uCAAuC,CAAC,CAAC;cAC7E,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;cAO3E,WAAW,OAAO,EAAE,OAAO,cAAc,CAAC,CAAC;;;;;;;;cAQ3C,WAAW,oBAAoB,EAAE,OAAO,2CAA2C,CAAC,CAAC;cACrF,WAAW,mBAAmB,EAAE,OAAO,0CAA0C,CAAC,CAAC;;;;;;;;;;;;;AAcjG,IAAa,0BAAb,cAA6C,UAAU,gBAAgB,CAAC;;iBAC5C;;;gBACV,aAAaA,qBAAO;;;yBACX;;;AAG3B,eAAe,OAAO,wBAAwB,SAAS,wBAAwB"}
@@ -1 +1 @@
1
- {"version":3,"file":"minimal-skin.tailwind.d.ts","names":[],"sources":["../../../../src/define/video/minimal-skin.tailwind.ts"],"mappings":";;;iBA2CS,eAAA,CAAA;AAAA,cAAe,oCAAA;;;;cAsIX,+BAAA,SAAwC,oCAAA;EAAA,gBACnC,OAAA;EAAA,OACT,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,+BAAA,CAAgC,OAAA,GAAU,+BAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"minimal-skin.tailwind.d.ts","names":[],"sources":["../../../../src/define/video/minimal-skin.tailwind.ts"],"mappings":";;;iBA0CS,eAAA,CAAA;AAAA,cAAe,oCAAA;;;;cA0HX,+BAAA,SAAwC,oCAAA;EAAA,gBACnC,OAAA;EAAA,OACT,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,+BAAA,CAAgC,OAAA,GAAU,+BAAA;EAAA;AAAA"}
@@ -3,7 +3,6 @@ import { renderIcon } from "../../icons/dist/render/minimal/index.js";
3
3
  import { bufferingIndicator } from "../../skins/dist/default/minimal/tailwind/components/buffering.js";
4
4
  import { button } from "../../skins/dist/default/minimal/tailwind/components/button.js";
5
5
  import { buttonGroup } from "../../skins/dist/default/minimal/tailwind/components/button-group.js";
6
- import { error } from "../../skins/dist/default/minimal/tailwind/components/error.js";
7
6
  import { icon, iconContainer, iconFlipped } from "../../skins/dist/default/minimal/tailwind/components/icon.js";
8
7
  import { seek } from "../../skins/dist/default/minimal/tailwind/components/seek.js";
9
8
  import { time } from "../../skins/dist/default/minimal/tailwind/components/time.js";
@@ -41,18 +40,6 @@ function getTemplateHTML() {
41
40
  ${renderIcon("spinner")}
42
41
  </media-buffering-indicator>
43
42
 
44
- <!--<div class="${error.root}" role="alertdialog" aria-labelledby="media-error-title" aria-describedby="media-error-description">
45
- <div class="${error.dialog}">
46
- <div class="${error.content}">
47
- <p id="media-error-title" class="${error.title}">Something went wrong.</p>
48
- <p id="media-error-description">An error occurred while trying to play the video. Please try again.</p>
49
- </div>
50
- <div class="${error.actions}">
51
- <button type="button" class="${cn(button.base, button.default)}">OK</button>
52
- </div>
53
- </div>
54
- </div>-->
55
-
56
43
  <media-controls data-controls="" class="${controls}">
57
44
  <span class="${buttonGroup}">
58
45
  <span class="${tooltipState.play.wrapper}">
@@ -1 +1 @@
1
- {"version":3,"file":"minimal-skin.tailwind.js","names":[],"sources":["../../../../src/define/video/minimal-skin.tailwind.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render/minimal';\nimport {\n bufferingIndicator,\n button,\n buttonGroup,\n controls,\n error,\n icon,\n iconContainer,\n iconFlipped,\n iconState,\n overlay,\n popup,\n root,\n seek,\n slider,\n time,\n tooltipState,\n} from '@videojs/skins/minimal/tailwind/video.tailwind';\nimport { cn } from '@videojs/utils/style';\nimport { SkinMixin } from '../skin-mixin';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/buffering-indicator';\nimport '../ui/captions-button';\nimport '../ui/controls';\nimport '../ui/fullscreen-button';\nimport '../ui/mute-button';\nimport '../ui/pip-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/volume-slider';\nimport { playbackRate } from '@videojs/skins/default/tailwind/video.tailwind';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"${root(true)}\">\n <slot name=\"media\"></slot>\n\n <media-buffering-indicator class=\"${bufferingIndicator}\">\n ${renderIcon('spinner')}\n </media-buffering-indicator>\n\n <!--<div class=\"${error.root}\" role=\"alertdialog\" aria-labelledby=\"media-error-title\" aria-describedby=\"media-error-description\">\n <div class=\"${error.dialog}\">\n <div class=\"${error.content}\">\n <p id=\"media-error-title\" class=\"${error.title}\">Something went wrong.</p>\n <p id=\"media-error-description\">An error occurred while trying to play the video. Please try again.</p>\n </div>\n <div class=\"${error.actions}\">\n <button type=\"button\" class=\"${cn(button.base, button.default)}\">OK</button>\n </div>\n </div>\n </div>-->\n\n <media-controls data-controls=\"\" class=\"${controls}\">\n <span class=\"${buttonGroup}\">\n <span class=\"${tooltipState.play.wrapper}\">\n <media-play-button commandfor=\"play-tooltip\" class=\"${cn(button.base, button.icon, iconState.play.button)}\">\n ${renderIcon('restart', { class: cn(icon, iconState.play.restart) })}\n ${renderIcon('play', { class: cn(icon, iconState.play.play) })}\n ${renderIcon('pause', { class: cn(icon, iconState.play.pause) })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.play.replay}\">Replay</span>\n <span class=\"${tooltipState.play.play}\">Play</span>\n <span class=\"${tooltipState.play.pause}\">Pause</span>\n </media-tooltip>\n </span>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"${cn(button.base, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: cn(icon, iconFlipped) })}\n <span class=\"${cn(seek.label, seek.labelBackward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"${cn(button.base, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: icon })}\n <span class=\"${cn(seek.label, seek.labelForward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n </span>\n\n <span class=\"${time.controls}\">\n <media-time-group class=\"${time.group}\">\n <media-time type=\"current\" class=\"${time.current}\"></media-time>\n <media-time-separator class=\"${time.separator}\"></media-time-separator>\n <media-time type=\"duration\" class=\"${time.duration}\"></media-time>\n </media-time-group>\n\n <media-time-slider class=\"${slider.root}\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n <media-slider-buffer class=\"${cn(slider.fill.base, slider.fill.buffer)}\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"${cn(slider.thumb.base, slider.thumb.interactive)}\"></media-slider-thumb>\n </media-time-slider>\n </span>\n\n <span class=\"${buttonGroup}\">\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"${cn(button.base, button.icon, playbackRate.button)}\">\n </media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"video-volume-popover\" class=\"${cn(button.base, button.icon, iconState.mute.button)}\">\n ${renderIcon('volume-off', { class: cn(icon, iconState.mute.volumeOff) })}\n ${renderIcon('volume-low', { class: cn(icon, iconState.mute.volumeLow) })}\n ${renderIcon('volume-high', { class: cn(icon, iconState.mute.volumeHigh) })}\n </media-mute-button>\n\n <media-popover id=\"video-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"${cn(popup.volume)}\">\n <media-volume-slider class=\"${slider.root}\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"${slider.thumb.base}\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n\n <span class=\"${tooltipState.captions.wrapper}\">\n <media-captions-button commandfor=\"captions-tooltip\" class=\"${cn(button.base, button.icon, iconState.captions.button)}\">\n ${renderIcon('captions-off', { class: cn(icon, iconState.captions.off) })}\n ${renderIcon('captions-on', { class: cn(icon, iconState.captions.on) })}\n </media-captions-button>\n <media-tooltip id=\"captions-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.captions.enable}\">Enable captions</span>\n <span class=\"${tooltipState.captions.disable}\">Disable captions</span>\n </media-tooltip>\n </span>\n\n <span class=\"${tooltipState.pip.wrapper}\">\n <media-pip-button commandfor=\"pip-tooltip\" class=\"${cn(button.base, button.icon)}\">\n ${renderIcon('pip', { class: icon })}\n </media-pip-button>\n <media-tooltip id=\"pip-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.pip.enter}\">Enter picture-in-picture</span>\n <span class=\"${tooltipState.pip.exit}\">Exit picture-in-picture</span>\n </media-tooltip>\n </span>\n\n <span class=\"${tooltipState.fullscreen.wrapper}\">\n <media-fullscreen-button commandfor=\"fullscreen-tooltip\" class=\"${cn(button.base, button.icon, iconState.fullscreen.button)}\">\n ${renderIcon('fullscreen-enter', { class: cn(icon, iconState.fullscreen.enter) })}\n ${renderIcon('fullscreen-exit', { class: cn(icon, iconState.fullscreen.exit) })}\n </media-fullscreen-button>\n <media-tooltip id=\"fullscreen-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.fullscreen.enter}\">Enter fullscreen</span>\n <span class=\"${tooltipState.fullscreen.exit}\">Exit fullscreen</span>\n </media-tooltip>\n </span>\n </span>\n </media-controls>\n\n <div class=\"${overlay}\"></div>\n </media-container>\n `;\n}\n\nexport class MinimalVideoSkinTailwindElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'video-minimal-skin-tailwind';\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(MinimalVideoSkinTailwindElement.tagName, MinimalVideoSkinTailwindElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [MinimalVideoSkinTailwindElement.tagName]: MinimalVideoSkinTailwindElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyCA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;8BACY,KAAK,KAAK,CAAC;;;0CAGC,mBAAmB;UACnD,WAAW,UAAU,CAAC;;;wBAGR,MAAM,KAAK;sBACb,MAAM,OAAO;wBACX,MAAM,QAAQ;+CACS,MAAM,MAAM;;;wBAGnC,MAAM,QAAQ;2CACK,GAAG,OAAO,MAAM,OAAO,QAAQ,CAAC;;;;;gDAK3B,SAAS;uBAClC,YAAY;yBACV,aAAa,KAAK,QAAQ;kEACe,GAAG,OAAO,MAAM,OAAO,MAAM,UAAU,KAAK,OAAO,CAAC;gBACtG,WAAW,WAAW,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,QAAQ,EAAE,CAAC,CAAC;gBACnE,WAAW,QAAQ,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,KAAK,EAAE,CAAC,CAAC;gBAC7D,WAAW,SAAS,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,MAAM,EAAE,CAAC,CAAC;;iEAEd,GAAG,MAAM,QAAQ,CAAC;6BACtD,aAAa,KAAK,OAAO;6BACzB,aAAa,KAAK,KAAK;6BACvB,aAAa,KAAK,MAAM;;;;2EAIsB,CAAC,UAAU,WAAW,GAAG,OAAO,MAAM,OAAO,MAAM,KAAK,OAAO,CAAC;2BAChH,cAAc;gBACzB,WAAW,QAAQ,EAAE,OAAO,GAAG,MAAM,YAAY,EAAE,CAAC,CAAC;6BACxC,GAAG,KAAK,OAAO,KAAK,cAAc,CAAC,IAAI,UAAU;;;wEAGN,GAAG,MAAM,QAAQ,CAAC;4BAC9D,UAAU;;;0EAGoC,UAAU,WAAW,GAAG,OAAO,MAAM,OAAO,MAAM,KAAK,OAAO,CAAC;2BAC9G,cAAc;gBACzB,WAAW,QAAQ,EAAE,OAAO,MAAM,CAAC,CAAC;6BACvB,GAAG,KAAK,OAAO,KAAK,aAAa,CAAC,IAAI,UAAU;;;uEAGN,GAAG,MAAM,QAAQ,CAAC;2BAC9D,UAAU;;;;uBAId,KAAK,SAAS;qCACA,KAAK,MAAM;gDACA,KAAK,QAAQ;2CAClB,KAAK,UAAU;iDACT,KAAK,SAAS;;;sCAGzB,OAAO,KAAK;yCACT,OAAO,MAAM;0CACZ,GAAG,OAAO,KAAK,MAAM,OAAO,KAAK,KAAK,CAAC;4CACrC,GAAG,OAAO,KAAK,MAAM,OAAO,KAAK,OAAO,CAAC;;yCAE5C,GAAG,OAAO,MAAM,MAAM,OAAO,MAAM,YAAY,CAAC;;;;uBAIlE,YAAY;mFACgD,GAAG,OAAO,MAAM,OAAO,MAAM,aAAa,OAAO,CAAC;;wEAE7D,GAAG,MAAM,QAAQ,CAAC;;;;wEAIlB,GAAG,OAAO,MAAM,OAAO,MAAM,UAAU,KAAK,OAAO,CAAC;cAC9G,WAAW,cAAc,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,UAAU,EAAE,CAAC,CAAC;cACxE,WAAW,cAAc,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,UAAU,EAAE,CAAC,CAAC;cACxE,WAAW,eAAe,EAAE,OAAO,GAAG,MAAM,UAAU,KAAK,WAAW,EAAE,CAAC,CAAC;;;mHAG2B,GAAG,MAAM,OAAO,CAAC;0CAC1F,OAAO,KAAK;2CACX,OAAO,MAAM;4CACZ,GAAG,OAAO,KAAK,MAAM,OAAO,KAAK,KAAK,CAAC;;2CAExC,OAAO,MAAM,KAAK;;;;yBAIpC,aAAa,SAAS,QAAQ;0EACmB,GAAG,OAAO,MAAM,OAAO,MAAM,UAAU,SAAS,OAAO,CAAC;gBAClH,WAAW,gBAAgB,EAAE,OAAO,GAAG,MAAM,UAAU,SAAS,IAAI,EAAE,CAAC,CAAC;gBACxE,WAAW,eAAe,EAAE,OAAO,GAAG,MAAM,UAAU,SAAS,GAAG,EAAE,CAAC,CAAC;;qEAEjB,GAAG,MAAM,QAAQ,CAAC;6BAC1D,aAAa,SAAS,OAAO;6BAC7B,aAAa,SAAS,QAAQ;;;;yBAIlC,aAAa,IAAI,QAAQ;gEACc,GAAG,OAAO,MAAM,OAAO,KAAK,CAAC;gBAC7E,WAAW,OAAO,EAAE,OAAO,MAAM,CAAC,CAAC;;gEAEa,GAAG,MAAM,QAAQ,CAAC;6BACrD,aAAa,IAAI,MAAM;6BACvB,aAAa,IAAI,KAAK;;;;yBAI1B,aAAa,WAAW,QAAQ;8EACqB,GAAG,OAAO,MAAM,OAAO,MAAM,UAAU,WAAW,OAAO,CAAC;gBACxH,WAAW,oBAAoB,EAAE,OAAO,GAAG,MAAM,UAAU,WAAW,MAAM,EAAE,CAAC,CAAC;gBAChF,WAAW,mBAAmB,EAAE,OAAO,GAAG,MAAM,UAAU,WAAW,KAAK,EAAE,CAAC,CAAC;;uEAEvB,GAAG,MAAM,QAAQ,CAAC;6BAC5D,aAAa,WAAW,MAAM;6BAC9B,aAAa,WAAW,KAAK;;;;;;oBAMtC,QAAQ;;;;AAK5B,IAAa,kCAAb,cAAqD,UAAU,gBAAgB,CAAC;;iBACpD;;;yBACD;;;AAG3B,eAAe,OAAO,gCAAgC,SAAS,gCAAgC"}
1
+ {"version":3,"file":"minimal-skin.tailwind.js","names":[],"sources":["../../../../src/define/video/minimal-skin.tailwind.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render/minimal';\nimport {\n bufferingIndicator,\n button,\n buttonGroup,\n controls,\n icon,\n iconContainer,\n iconFlipped,\n iconState,\n overlay,\n popup,\n root,\n seek,\n slider,\n time,\n tooltipState,\n} from '@videojs/skins/minimal/tailwind/video.tailwind';\nimport { cn } from '@videojs/utils/style';\nimport { SkinMixin } from '../skin-mixin';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/buffering-indicator';\nimport '../ui/captions-button';\nimport '../ui/controls';\nimport '../ui/fullscreen-button';\nimport '../ui/mute-button';\nimport '../ui/pip-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/volume-slider';\nimport { playbackRate } from '@videojs/skins/default/tailwind/video.tailwind';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"${root(true)}\">\n <slot name=\"media\"></slot>\n\n <media-buffering-indicator class=\"${bufferingIndicator}\">\n ${renderIcon('spinner')}\n </media-buffering-indicator>\n\n <media-controls data-controls=\"\" class=\"${controls}\">\n <span class=\"${buttonGroup}\">\n <span class=\"${tooltipState.play.wrapper}\">\n <media-play-button commandfor=\"play-tooltip\" class=\"${cn(button.base, button.icon, iconState.play.button)}\">\n ${renderIcon('restart', { class: cn(icon, iconState.play.restart) })}\n ${renderIcon('play', { class: cn(icon, iconState.play.play) })}\n ${renderIcon('pause', { class: cn(icon, iconState.play.pause) })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.play.replay}\">Replay</span>\n <span class=\"${tooltipState.play.play}\">Play</span>\n <span class=\"${tooltipState.play.pause}\">Pause</span>\n </media-tooltip>\n </span>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"${cn(button.base, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: cn(icon, iconFlipped) })}\n <span class=\"${cn(seek.label, seek.labelBackward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"${cn(button.base, button.icon, seek.button)}\">\n <span class=\"${iconContainer}\">\n ${renderIcon('seek', { class: icon })}\n <span class=\"${cn(seek.label, seek.labelForward)}\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n </span>\n\n <span class=\"${time.controls}\">\n <media-time-group class=\"${time.group}\">\n <media-time type=\"current\" class=\"${time.current}\"></media-time>\n <media-time-separator class=\"${time.separator}\"></media-time-separator>\n <media-time type=\"duration\" class=\"${time.duration}\"></media-time>\n </media-time-group>\n\n <media-time-slider class=\"${slider.root}\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n <media-slider-buffer class=\"${cn(slider.fill.base, slider.fill.buffer)}\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"${cn(slider.thumb.base, slider.thumb.interactive)}\"></media-slider-thumb>\n </media-time-slider>\n </span>\n\n <span class=\"${buttonGroup}\">\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"${cn(button.base, button.icon, playbackRate.button)}\">\n </media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"video-volume-popover\" class=\"${cn(button.base, button.icon, iconState.mute.button)}\">\n ${renderIcon('volume-off', { class: cn(icon, iconState.mute.volumeOff) })}\n ${renderIcon('volume-low', { class: cn(icon, iconState.mute.volumeLow) })}\n ${renderIcon('volume-high', { class: cn(icon, iconState.mute.volumeHigh) })}\n </media-mute-button>\n\n <media-popover id=\"video-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"top\" class=\"${cn(popup.volume)}\">\n <media-volume-slider class=\"${slider.root}\" orientation=\"vertical\" thumb-alignment=\"edge\">\n <media-slider-track class=\"${slider.track}\">\n <media-slider-fill class=\"${cn(slider.fill.base, slider.fill.fill)}\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"${slider.thumb.base}\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n\n <span class=\"${tooltipState.captions.wrapper}\">\n <media-captions-button commandfor=\"captions-tooltip\" class=\"${cn(button.base, button.icon, iconState.captions.button)}\">\n ${renderIcon('captions-off', { class: cn(icon, iconState.captions.off) })}\n ${renderIcon('captions-on', { class: cn(icon, iconState.captions.on) })}\n </media-captions-button>\n <media-tooltip id=\"captions-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.captions.enable}\">Enable captions</span>\n <span class=\"${tooltipState.captions.disable}\">Disable captions</span>\n </media-tooltip>\n </span>\n\n <span class=\"${tooltipState.pip.wrapper}\">\n <media-pip-button commandfor=\"pip-tooltip\" class=\"${cn(button.base, button.icon)}\">\n ${renderIcon('pip', { class: icon })}\n </media-pip-button>\n <media-tooltip id=\"pip-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.pip.enter}\">Enter picture-in-picture</span>\n <span class=\"${tooltipState.pip.exit}\">Exit picture-in-picture</span>\n </media-tooltip>\n </span>\n\n <span class=\"${tooltipState.fullscreen.wrapper}\">\n <media-fullscreen-button commandfor=\"fullscreen-tooltip\" class=\"${cn(button.base, button.icon, iconState.fullscreen.button)}\">\n ${renderIcon('fullscreen-enter', { class: cn(icon, iconState.fullscreen.enter) })}\n ${renderIcon('fullscreen-exit', { class: cn(icon, iconState.fullscreen.exit) })}\n </media-fullscreen-button>\n <media-tooltip id=\"fullscreen-tooltip\" side=\"top\" class=\"${cn(popup.tooltip)}\">\n <span class=\"${tooltipState.fullscreen.enter}\">Enter fullscreen</span>\n <span class=\"${tooltipState.fullscreen.exit}\">Exit fullscreen</span>\n </media-tooltip>\n </span>\n </span>\n </media-controls>\n\n <div class=\"${overlay}\"></div>\n </media-container>\n `;\n}\n\nexport class MinimalVideoSkinTailwindElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'video-minimal-skin-tailwind';\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(MinimalVideoSkinTailwindElement.tagName, MinimalVideoSkinTailwindElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [MinimalVideoSkinTailwindElement.tagName]: MinimalVideoSkinTailwindElement;\n }\n}\n"],"mappings":"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"}
@@ -125,6 +125,8 @@
125
125
  position: relative;
126
126
  isolation: isolate;
127
127
  display: block;
128
+ height: 100%;
129
+ width: 100%;
128
130
  container: media-root / inline-size;
129
131
  border-radius: var(--media-border-radius, 2rem);
130
132
  font-family:
@@ -713,62 +715,9 @@
713
715
  }
714
716
 
715
717
  /* ==========================================================================
716
- Captions
718
+ Native Caption Track
717
719
  ========================================================================== */
718
720
 
719
- .media-default-skin .media-captions {
720
- position: absolute;
721
- inset: auto 1rem 1.5rem 1rem;
722
- z-index: 20;
723
- font-size: 1rem;
724
- text-wrap: balance;
725
- pointer-events: none;
726
-
727
- @container media-root (width > 20rem) {
728
- font-size: 1.5rem;
729
- }
730
-
731
- @container media-root (width > 48rem) {
732
- font-size: 1.875rem;
733
- }
734
-
735
- @container media-root (width > 80rem) {
736
- font-size: 2.25rem;
737
- }
738
- }
739
-
740
- .media-default-skin .media-captions__container {
741
- display: flex;
742
- flex-direction: column;
743
- align-items: center;
744
- max-width: 42ch;
745
- margin: 0 auto;
746
- text-align: center;
747
- }
748
-
749
- .media-default-skin .media-captions__text {
750
- display: block;
751
- padding: 0.125rem 0.5rem;
752
- color: oklch(1 0 0);
753
- text-shadow:
754
- 0 0 1px oklch(0 0 0 / 0.7),
755
- 0 0 8px oklch(0 0 0 / 0.7);
756
- text-align: center;
757
- white-space: pre-wrap;
758
- line-height: 1.2;
759
-
760
- @media (prefers-contrast: more) {
761
- background: oklch(0 0 0 / 0.7);
762
- text-shadow: none;
763
- box-decoration-break: clone;
764
- }
765
-
766
- & > * {
767
- display: inline;
768
- }
769
- }
770
-
771
- /* Caption shifting styles (custom and native) */
772
721
  .media-default-skin {
773
722
  --media-caption-track-delay: 600ms;
774
723
  --media-caption-track-y: -0.5rem;
@@ -779,26 +728,16 @@
779
728
  }
780
729
  }
781
730
 
782
- .media-default-skin .media-captions,
783
731
  .media-default-skin video::-webkit-media-text-track-container {
784
732
  /* NOTE: The delay must account for the controls delay/duration */
785
733
  transition: transform 150ms ease-out;
786
734
  transition-delay: var(--media-caption-track-delay);
787
- }
788
-
789
- .media-default-skin video::-webkit-media-text-track-container {
790
735
  transform: translateY(var(--media-caption-track-y)) scale(0.98);
791
736
  z-index: 1;
792
737
  font-family: inherit;
793
738
  }
794
739
 
795
- /* When controls are visible, shift captions up to avoid overlap */
796
- .media-default-skin .media-controls[data-visible] ~ .media-captions {
797
- transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));
798
- }
799
-
800
740
  @media (prefers-reduced-motion: reduce) {
801
- .media-default-skin .media-captions,
802
741
  .media-default-skin video::-webkit-media-text-track-container {
803
742
  transition-duration: 50ms;
804
743
  }
@@ -1 +1 @@
1
- {"version":3,"file":"skin.d.ts","names":[],"sources":["../../../../src/define/video/skin.ts"],"mappings":";;;iBAwBS,eAAA,CAAA;AAAA,cAAe,qBAAA;;;;cAuHX,gBAAA,SAAyB,qBAAA;EAAA,gBACpB,OAAA;EAAA,OACT,MAAA,EAAM,aAAA;EAAA,OACN,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,gBAAA,CAAiB,OAAA,GAAU,gBAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"skin.d.ts","names":[],"sources":["../../../../src/define/video/skin.ts"],"mappings":";;;iBAwBS,eAAA,CAAA;AAAA,cAAe,qBAAA;;;;cA2GX,gBAAA,SAAyB,qBAAA;EAAA,gBACpB,OAAA;EAAA,OACT,MAAA,EAAM,aAAA;EAAA,OACN,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,gBAAA,CAAiB,OAAA,GAAU,gBAAA;EAAA;AAAA"}