@videojs/html 0.1.0-preview.2 → 0.1.0-preview.4

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 (127) hide show
  1. package/README.md +2 -2
  2. package/dist/button-D1DWjsQu.js +57 -0
  3. package/dist/button-D1DWjsQu.js.map +1 -0
  4. package/dist/component-factory-DeAN6cjC.js +47 -0
  5. package/dist/component-factory-DeAN6cjC.js.map +1 -0
  6. package/dist/current-time-display-C3qndGf5.js +47 -0
  7. package/dist/current-time-display-C3qndGf5.js.map +1 -0
  8. package/dist/custom-element-3bDlB2XO.js +10 -0
  9. package/dist/custom-element-3bDlB2XO.js.map +1 -0
  10. package/dist/define/index.d.ts +12 -0
  11. package/dist/define/index.js +27 -0
  12. package/dist/define/media-container.d.ts +1 -0
  13. package/dist/define/media-container.js +3 -0
  14. package/dist/define/media-current-time-display.d.ts +1 -0
  15. package/dist/define/media-current-time-display.js +4 -0
  16. package/dist/define/media-duration-display.d.ts +1 -0
  17. package/dist/define/media-duration-display.js +4 -0
  18. package/dist/define/media-fullscreen-button.d.ts +1 -0
  19. package/dist/define/media-fullscreen-button.js +5 -0
  20. package/dist/define/media-mute-button.d.ts +1 -0
  21. package/dist/define/media-mute-button.js +5 -0
  22. package/dist/define/media-play-button.d.ts +1 -0
  23. package/dist/define/media-play-button.js +5 -0
  24. package/dist/define/media-popover.d.ts +1 -0
  25. package/dist/define/media-popover.js +3 -0
  26. package/dist/define/media-preview-time-display.d.ts +1 -0
  27. package/dist/define/media-preview-time-display.js +4 -0
  28. package/dist/define/media-provider.d.ts +1 -0
  29. package/dist/define/media-provider.js +3 -0
  30. package/dist/define/media-time-slider.d.ts +1 -0
  31. package/dist/define/media-time-slider.js +4 -0
  32. package/dist/define/media-tooltip.d.ts +1 -0
  33. package/dist/define/media-tooltip.js +3 -0
  34. package/dist/define/media-volume-slider.d.ts +1 -0
  35. package/dist/define/media-volume-slider.js +4 -0
  36. package/dist/duration-display-JOPp3bdU.js +49 -0
  37. package/dist/duration-display-JOPp3bdU.js.map +1 -0
  38. package/dist/fullscreen-button-CGO2UJjs.js +48 -0
  39. package/dist/fullscreen-button-CGO2UJjs.js.map +1 -0
  40. package/dist/{icons-YlVTDFdV.js → icons-CuxuONCk.js} +59 -48
  41. package/dist/icons-CuxuONCk.js.map +1 -0
  42. package/dist/icons.d.ts +1 -2
  43. package/dist/icons.js +2 -3
  44. package/dist/index-LKrIp3Oo.d.ts +1 -0
  45. package/dist/index.d.ts +172 -4
  46. package/dist/index.d.ts.map +1 -1
  47. package/dist/index.js +16 -9
  48. package/dist/media-container-BGEXSi9g.js +8 -0
  49. package/dist/media-container-BGEXSi9g.js.map +1 -0
  50. package/dist/media-container-C0MUzkJ_.js +83 -0
  51. package/dist/media-container-C0MUzkJ_.js.map +1 -0
  52. package/dist/media-container-DPnFjmtK.d.ts +1 -0
  53. package/dist/media-current-time-display-B-4Cp845.js +8 -0
  54. package/dist/media-current-time-display-B-4Cp845.js.map +1 -0
  55. package/dist/media-current-time-display-Cd0rPAuj.d.ts +1 -0
  56. package/dist/media-duration-display-BLMr7VHo.js +8 -0
  57. package/dist/media-duration-display-BLMr7VHo.js.map +1 -0
  58. package/dist/media-duration-display-qvm6YX-q.d.ts +1 -0
  59. package/dist/media-fullscreen-button-BgUK3lgu.d.ts +1 -0
  60. package/dist/media-fullscreen-button-Dcflbt54.js +8 -0
  61. package/dist/media-fullscreen-button-Dcflbt54.js.map +1 -0
  62. package/dist/media-mute-button-BOVhZ3aP.js +8 -0
  63. package/dist/media-mute-button-BOVhZ3aP.js.map +1 -0
  64. package/dist/media-mute-button-NVJF2EEW.d.ts +1 -0
  65. package/dist/media-play-button-CLj-hkwn.js +8 -0
  66. package/dist/media-play-button-CLj-hkwn.js.map +1 -0
  67. package/dist/media-play-button-oq8yDlxe.d.ts +1 -0
  68. package/dist/media-popover-BtJmPv0E.d.ts +1 -0
  69. package/dist/media-popover-F4M4Tq4z.js +8 -0
  70. package/dist/media-popover-F4M4Tq4z.js.map +1 -0
  71. package/dist/media-preview-time-display-4YX5Rics.d.ts +1 -0
  72. package/dist/media-preview-time-display-DAiMgLPX.js +8 -0
  73. package/dist/media-preview-time-display-DAiMgLPX.js.map +1 -0
  74. package/dist/media-provider-CyoL0bCx.js +17 -0
  75. package/dist/media-provider-CyoL0bCx.js.map +1 -0
  76. package/dist/media-provider-D7P2TLXG.d.ts +1 -0
  77. package/dist/media-provider-D_GL2_DN.js +8 -0
  78. package/dist/media-provider-D_GL2_DN.js.map +1 -0
  79. package/dist/media-skin-Di3vSHvS.d.ts +11 -0
  80. package/dist/media-skin-Di3vSHvS.d.ts.map +1 -0
  81. package/dist/media-skin-mHWwUPg3.js +36 -0
  82. package/dist/media-skin-mHWwUPg3.js.map +1 -0
  83. package/dist/media-time-slider-Bp2qnwsW.js +12 -0
  84. package/dist/media-time-slider-Bp2qnwsW.js.map +1 -0
  85. package/dist/media-time-slider-DvMnfYXZ.d.ts +1 -0
  86. package/dist/media-tooltip-BqV17mdM.d.ts +1 -0
  87. package/dist/media-tooltip-ClcVafMb.js +14 -0
  88. package/dist/media-tooltip-ClcVafMb.js.map +1 -0
  89. package/dist/media-volume-slider-CKSxmdQv.js +11 -0
  90. package/dist/media-volume-slider-CKSxmdQv.js.map +1 -0
  91. package/dist/media-volume-slider-DP47VLVi.d.ts +1 -0
  92. package/dist/mute-button-vW2sLqqY.js +50 -0
  93. package/dist/mute-button-vW2sLqqY.js.map +1 -0
  94. package/dist/play-button-aVb0g10G.js +44 -0
  95. package/dist/play-button-aVb0g10G.js.map +1 -0
  96. package/dist/popover-Dc0hyhwB.js +187 -0
  97. package/dist/popover-Dc0hyhwB.js.map +1 -0
  98. package/dist/preview-time-display-Dax0FQ2X.js +44 -0
  99. package/dist/preview-time-display-Dax0FQ2X.js.map +1 -0
  100. package/dist/skins/frosted.d.ts +23 -0
  101. package/dist/skins/frosted.d.ts.map +1 -0
  102. package/dist/skins/frosted.js +144 -0
  103. package/dist/skins/frosted.js.map +1 -0
  104. package/dist/skins/minimal.d.ts +23 -0
  105. package/dist/skins/minimal.d.ts.map +1 -0
  106. package/dist/skins/minimal.js +149 -0
  107. package/dist/skins/minimal.js.map +1 -0
  108. package/dist/time-slider-CA1GMs6A.js +201 -0
  109. package/dist/time-slider-CA1GMs6A.js.map +1 -0
  110. package/dist/tooltip-54fBUUpb.js +296 -0
  111. package/dist/tooltip-54fBUUpb.js.map +1 -0
  112. package/dist/volume-slider-guD8gqpi.js +206 -0
  113. package/dist/volume-slider-guD8gqpi.js.map +1 -0
  114. package/package.json +16 -7
  115. package/dist/chunk-Bp6m_JJh.js +0 -13
  116. package/dist/icons-YlVTDFdV.js.map +0 -1
  117. package/dist/index-BtSCzZKn.d.ts +0 -62
  118. package/dist/index-BtSCzZKn.d.ts.map +0 -1
  119. package/dist/index.js.map +0 -1
  120. package/dist/media-skin-BlXPC9wG.js +0 -1458
  121. package/dist/media-skin-BlXPC9wG.js.map +0 -1
  122. package/dist/media-skin-CbuyuCb-.d.ts +0 -208
  123. package/dist/media-skin-CbuyuCb-.d.ts.map +0 -1
  124. package/dist/skins/default.d.ts +0 -12
  125. package/dist/skins/default.d.ts.map +0 -1
  126. package/dist/skins/default.js +0 -424
  127. package/dist/skins/default.js.map +0 -1
@@ -1,8 +1,8 @@
1
- import { t as __export } from "./chunk-Bp6m_JJh.js";
1
+ import { t as defineCustomElement } from "./custom-element-3bDlB2XO.js";
2
2
  import { SVG_ICONS } from "@videojs/icons";
3
3
 
4
4
  //#region src/icons/media-chrome-icon.ts
5
- function getTemplateHTML$7() {
5
+ function getTemplateHTML$9() {
6
6
  return `
7
7
  <style>
8
8
  :host {
@@ -19,7 +19,7 @@ var MediaChromeIcon = class extends HTMLElement {
19
19
  this.shadowRootOptions = { mode: "open" };
20
20
  }
21
21
  static {
22
- this.getTemplateHTML = getTemplateHTML$7;
22
+ this.getTemplateHTML = getTemplateHTML$9;
23
23
  }
24
24
  constructor() {
25
25
  super();
@@ -30,13 +30,29 @@ var MediaChromeIcon = class extends HTMLElement {
30
30
  }
31
31
  };
32
32
 
33
+ //#endregion
34
+ //#region src/icons/media-fullscreen-enter-alt-icon.ts
35
+ function getTemplateHTML$8() {
36
+ return `
37
+ ${MediaChromeIcon.getTemplateHTML()}
38
+ <style>
39
+ :host {
40
+ display: var(--media-fullscreen-enter-icon-display, inline-flex);
41
+ }
42
+ </style>
43
+ ${SVG_ICONS.fullscreenEnterAlt}
44
+ `;
45
+ }
46
+ var MediaFullscreenEnterAltIconElement = class extends MediaChromeIcon {
47
+ static {
48
+ this.getTemplateHTML = getTemplateHTML$8;
49
+ }
50
+ };
51
+ defineCustomElement("media-fullscreen-enter-alt-icon", MediaFullscreenEnterAltIconElement);
52
+
33
53
  //#endregion
34
54
  //#region src/icons/media-fullscreen-enter-icon.ts
35
- var media_fullscreen_enter_icon_exports = /* @__PURE__ */ __export({
36
- MediaFullscreenEnterIcon: () => MediaFullscreenEnterIcon,
37
- getTemplateHTML: () => getTemplateHTML$6
38
- });
39
- function getTemplateHTML$6() {
55
+ function getTemplateHTML$7() {
40
56
  return `
41
57
  ${MediaChromeIcon.getTemplateHTML()}
42
58
  <style>
@@ -47,19 +63,35 @@ function getTemplateHTML$6() {
47
63
  ${SVG_ICONS.fullscreenEnter}
48
64
  `;
49
65
  }
50
- var MediaFullscreenEnterIcon = class extends MediaChromeIcon {
66
+ var MediaFullscreenEnterIconElement = class extends MediaChromeIcon {
67
+ static {
68
+ this.getTemplateHTML = getTemplateHTML$7;
69
+ }
70
+ };
71
+ defineCustomElement("media-fullscreen-enter-icon", MediaFullscreenEnterIconElement);
72
+
73
+ //#endregion
74
+ //#region src/icons/media-fullscreen-exit-alt-icon.ts
75
+ function getTemplateHTML$6() {
76
+ return `
77
+ ${MediaChromeIcon.getTemplateHTML()}
78
+ <style>
79
+ :host {
80
+ display: var(--media-fullscreen-exit-icon-display, inline-flex);
81
+ }
82
+ </style>
83
+ ${SVG_ICONS.fullscreenExitAlt}
84
+ `;
85
+ }
86
+ var MediaFullscreenExitAltIconElement = class extends MediaChromeIcon {
51
87
  static {
52
88
  this.getTemplateHTML = getTemplateHTML$6;
53
89
  }
54
90
  };
55
- customElements.define("media-fullscreen-enter-icon", MediaFullscreenEnterIcon);
91
+ defineCustomElement("media-fullscreen-exit-alt-icon", MediaFullscreenExitAltIconElement);
56
92
 
57
93
  //#endregion
58
94
  //#region src/icons/media-fullscreen-exit-icon.ts
59
- var media_fullscreen_exit_icon_exports = /* @__PURE__ */ __export({
60
- MediaFullscreenExitIcon: () => MediaFullscreenExitIcon,
61
- getTemplateHTML: () => getTemplateHTML$5
62
- });
63
95
  function getTemplateHTML$5() {
64
96
  return `
65
97
  ${MediaChromeIcon.getTemplateHTML()}
@@ -71,38 +103,30 @@ function getTemplateHTML$5() {
71
103
  ${SVG_ICONS.fullscreenExit}
72
104
  `;
73
105
  }
74
- var MediaFullscreenExitIcon = class extends MediaChromeIcon {
106
+ var MediaFullscreenExitIconElement = class extends MediaChromeIcon {
75
107
  static {
76
108
  this.getTemplateHTML = getTemplateHTML$5;
77
109
  }
78
110
  };
79
- customElements.define("media-fullscreen-exit-icon", MediaFullscreenExitIcon);
111
+ defineCustomElement("media-fullscreen-exit-icon", MediaFullscreenExitIconElement);
80
112
 
81
113
  //#endregion
82
114
  //#region src/icons/media-pause-icon.ts
83
- var media_pause_icon_exports = /* @__PURE__ */ __export({
84
- MediaPauseIcon: () => MediaPauseIcon,
85
- getTemplateHTML: () => getTemplateHTML$4
86
- });
87
115
  function getTemplateHTML$4() {
88
116
  return `
89
117
  ${MediaChromeIcon.getTemplateHTML()}
90
118
  ${SVG_ICONS.pause}
91
119
  `;
92
120
  }
93
- var MediaPauseIcon = class extends MediaChromeIcon {
121
+ var MediaPauseIconElement = class extends MediaChromeIcon {
94
122
  static {
95
123
  this.getTemplateHTML = getTemplateHTML$4;
96
124
  }
97
125
  };
98
- customElements.define("media-pause-icon", MediaPauseIcon);
126
+ defineCustomElement("media-pause-icon", MediaPauseIconElement);
99
127
 
100
128
  //#endregion
101
129
  //#region src/icons/media-play-icon.ts
102
- var media_play_icon_exports = /* @__PURE__ */ __export({
103
- MediaPlayIcon: () => MediaPlayIcon,
104
- getTemplateHTML: () => getTemplateHTML$3
105
- });
106
130
  function getTemplateHTML$3() {
107
131
  return `
108
132
  ${MediaChromeIcon.getTemplateHTML()}
@@ -114,19 +138,15 @@ function getTemplateHTML$3() {
114
138
  ${SVG_ICONS.play}
115
139
  `;
116
140
  }
117
- var MediaPlayIcon = class extends MediaChromeIcon {
141
+ var MediaPlayIconElement = class extends MediaChromeIcon {
118
142
  static {
119
143
  this.getTemplateHTML = getTemplateHTML$3;
120
144
  }
121
145
  };
122
- customElements.define("media-play-icon", MediaPlayIcon);
146
+ defineCustomElement("media-play-icon", MediaPlayIconElement);
123
147
 
124
148
  //#endregion
125
149
  //#region src/icons/media-volume-high-icon.ts
126
- var media_volume_high_icon_exports = /* @__PURE__ */ __export({
127
- MediaVolumeHighIcon: () => MediaVolumeHighIcon,
128
- getTemplateHTML: () => getTemplateHTML$2
129
- });
130
150
  function getTemplateHTML$2() {
131
151
  return `
132
152
  ${MediaChromeIcon.getTemplateHTML()}
@@ -138,19 +158,15 @@ function getTemplateHTML$2() {
138
158
  ${SVG_ICONS.volumeHigh}
139
159
  `;
140
160
  }
141
- var MediaVolumeHighIcon = class extends MediaChromeIcon {
161
+ var MediaVolumeHighIconElement = class extends MediaChromeIcon {
142
162
  static {
143
163
  this.getTemplateHTML = getTemplateHTML$2;
144
164
  }
145
165
  };
146
- customElements.define("media-volume-high-icon", MediaVolumeHighIcon);
166
+ defineCustomElement("media-volume-high-icon", MediaVolumeHighIconElement);
147
167
 
148
168
  //#endregion
149
169
  //#region src/icons/media-volume-low-icon.ts
150
- var media_volume_low_icon_exports = /* @__PURE__ */ __export({
151
- MediaVolumeLowIcon: () => MediaVolumeLowIcon,
152
- getTemplateHTML: () => getTemplateHTML$1
153
- });
154
170
  function getTemplateHTML$1() {
155
171
  return `
156
172
  ${MediaChromeIcon.getTemplateHTML()}
@@ -162,19 +178,15 @@ function getTemplateHTML$1() {
162
178
  ${SVG_ICONS.volumeLow}
163
179
  `;
164
180
  }
165
- var MediaVolumeLowIcon = class extends MediaChromeIcon {
181
+ var MediaVolumeLowIconElement = class extends MediaChromeIcon {
166
182
  static {
167
183
  this.getTemplateHTML = getTemplateHTML$1;
168
184
  }
169
185
  };
170
- customElements.define("media-volume-low-icon", MediaVolumeLowIcon);
186
+ defineCustomElement("media-volume-low-icon", MediaVolumeLowIconElement);
171
187
 
172
188
  //#endregion
173
189
  //#region src/icons/media-volume-off-icon.ts
174
- var media_volume_off_icon_exports = /* @__PURE__ */ __export({
175
- MediaVolumeOffIcon: () => MediaVolumeOffIcon,
176
- getTemplateHTML: () => getTemplateHTML
177
- });
178
190
  function getTemplateHTML() {
179
191
  return `
180
192
  ${MediaChromeIcon.getTemplateHTML()}
@@ -186,13 +198,12 @@ function getTemplateHTML() {
186
198
  ${SVG_ICONS.volumeOff}
187
199
  `;
188
200
  }
189
- var MediaVolumeOffIcon = class extends MediaChromeIcon {
201
+ var MediaVolumeOffIconElement = class extends MediaChromeIcon {
190
202
  static {
191
203
  this.getTemplateHTML = getTemplateHTML;
192
204
  }
193
205
  };
194
- customElements.define("media-volume-off-icon", MediaVolumeOffIcon);
206
+ defineCustomElement("media-volume-off-icon", MediaVolumeOffIconElement);
195
207
 
196
208
  //#endregion
197
- export { media_pause_icon_exports as a, media_play_icon_exports as i, media_volume_low_icon_exports as n, media_fullscreen_exit_icon_exports as o, media_volume_high_icon_exports as r, media_fullscreen_enter_icon_exports as s, media_volume_off_icon_exports as t };
198
- //# sourceMappingURL=icons-YlVTDFdV.js.map
209
+ //# sourceMappingURL=icons-CuxuONCk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons-CuxuONCk.js","names":["getTemplateHTML","getTemplateHTML","getTemplateHTML","getTemplateHTML","getTemplateHTML","getTemplateHTML","getTemplateHTML","getTemplateHTML","getTemplateHTML"],"sources":["../src/icons/media-chrome-icon.ts","../src/icons/media-fullscreen-enter-alt-icon.ts","../src/icons/media-fullscreen-enter-icon.ts","../src/icons/media-fullscreen-exit-alt-icon.ts","../src/icons/media-fullscreen-exit-icon.ts","../src/icons/media-pause-icon.ts","../src/icons/media-play-icon.ts","../src/icons/media-volume-high-icon.ts","../src/icons/media-volume-low-icon.ts","../src/icons/media-volume-off-icon.ts"],"sourcesContent":["export function getTemplateHTML() {\n return /* html */ `\n <style>\n :host {\n display: inline-block;\n }\n svg {\n fill: currentColor;\n }\n </style>\n `;\n}\n\nexport class MediaChromeIcon extends HTMLElement {\n static shadowRootOptions = { mode: 'open' as ShadowRootMode };\n static getTemplateHTML: () => string = getTemplateHTML;\n\n constructor() {\n super();\n\n if (!this.shadowRoot) {\n this.attachShadow((this.constructor as typeof MediaChromeIcon).shadowRootOptions);\n this.shadowRoot!.innerHTML = (this.constructor as typeof MediaChromeIcon).getTemplateHTML();\n }\n }\n}\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-fullscreen-enter-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.fullscreenEnterAlt}\n `;\n}\n\nexport class MediaFullscreenEnterAltIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-fullscreen-enter-alt-icon', MediaFullscreenEnterAltIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-fullscreen-enter-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.fullscreenEnter}\n `;\n}\n\nexport class MediaFullscreenEnterIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-fullscreen-enter-icon', MediaFullscreenEnterIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-fullscreen-exit-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.fullscreenExitAlt}\n `;\n}\n\nexport class MediaFullscreenExitAltIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-fullscreen-exit-alt-icon', MediaFullscreenExitAltIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-fullscreen-exit-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.fullscreenExit}\n `;\n}\n\nexport class MediaFullscreenExitIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-fullscreen-exit-icon', MediaFullscreenExitIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n ${SVG_ICONS.pause}\n `;\n}\n\nexport class MediaPauseIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-pause-icon', MediaPauseIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-play-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.play}\n `;\n}\n\nexport class MediaPlayIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-play-icon', MediaPlayIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-play-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.volumeHigh}\n `;\n}\n\nexport class MediaVolumeHighIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-volume-high-icon', MediaVolumeHighIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-play-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.volumeLow}\n `;\n}\n\nexport class MediaVolumeLowIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-volume-low-icon', MediaVolumeLowIconElement);\n","import { SVG_ICONS } from '@videojs/icons';\n\nimport { defineCustomElement } from '@/utils/custom-element';\nimport { MediaChromeIcon } from './media-chrome-icon';\n\nexport function getTemplateHTML() {\n return /* html */ `\n ${MediaChromeIcon.getTemplateHTML()}\n <style>\n :host {\n display: var(--media-play-icon-display, inline-flex);\n }\n </style>\n ${SVG_ICONS.volumeOff}\n `;\n}\n\nexport class MediaVolumeOffIconElement extends MediaChromeIcon {\n static getTemplateHTML: () => string = getTemplateHTML;\n}\n\ndefineCustomElement('media-volume-off-icon', MediaVolumeOffIconElement);\n"],"mappings":";;;;AAAA,SAAgBA,oBAAkB;AAChC,QAAkB;;;;;;;;;;;AAYpB,IAAa,kBAAb,cAAqC,YAAY;;2BACpB,EAAE,MAAM,QAA0B;;;yBACtBA;;CAEvC,cAAc;AACZ,SAAO;AAEP,MAAI,CAAC,KAAK,YAAY;AACpB,QAAK,aAAc,KAAK,YAAuC,kBAAkB;AACjF,QAAK,WAAY,YAAa,KAAK,YAAuC,iBAAiB;;;;;;;ACjBjG,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,mBAAmB;;;AAInC,IAAa,qCAAb,cAAwD,gBAAgB;;yBAC/BA;;;AAGzC,oBAAoB,mCAAmC,mCAAmC;;;;AChB1F,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,gBAAgB;;;AAIhC,IAAa,kCAAb,cAAqD,gBAAgB;;yBAC5BA;;;AAGzC,oBAAoB,+BAA+B,gCAAgC;;;;AChBnF,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,kBAAkB;;;AAIlC,IAAa,oCAAb,cAAuD,gBAAgB;;yBAC9BA;;;AAGzC,oBAAoB,kCAAkC,kCAAkC;;;;AChBxF,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,eAAe;;;AAI/B,IAAa,iCAAb,cAAoD,gBAAgB;;yBAC3BA;;;AAGzC,oBAAoB,8BAA8B,+BAA+B;;;;AChBjF,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;MAClC,UAAU,MAAM;;;AAItB,IAAa,wBAAb,cAA2C,gBAAgB;;yBAClBA;;;AAGzC,oBAAoB,oBAAoB,sBAAsB;;;;ACX9D,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,KAAK;;;AAIrB,IAAa,uBAAb,cAA0C,gBAAgB;;yBACjBA;;;AAGzC,oBAAoB,mBAAmB,qBAAqB;;;;AChB5D,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,WAAW;;;AAI3B,IAAa,6BAAb,cAAgD,gBAAgB;;yBACvBA;;;AAGzC,oBAAoB,0BAA0B,2BAA2B;;;;AChBzE,SAAgBC,oBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,UAAU;;;AAI1B,IAAa,4BAAb,cAA+C,gBAAgB;;yBACtBA;;;AAGzC,oBAAoB,yBAAyB,0BAA0B;;;;AChBvE,SAAgB,kBAAkB;AAChC,QAAkB;MACd,gBAAgB,iBAAiB,CAAC;;;;;;MAMlC,UAAU,UAAU;;;AAI1B,IAAa,4BAAb,cAA+C,gBAAgB;;yBACtB;;;AAGzC,oBAAoB,yBAAyB,0BAA0B"}
package/dist/icons.d.ts CHANGED
@@ -1,2 +1 @@
1
- import { a as media_pause_icon_d_exports, i as media_play_icon_d_exports, n as media_volume_low_icon_d_exports, o as media_fullscreen_exit_icon_d_exports, r as media_volume_high_icon_d_exports, s as media_fullscreen_enter_icon_d_exports, t as media_volume_off_icon_d_exports } from "./index-BtSCzZKn.js";
2
- export { media_fullscreen_enter_icon_d_exports as MediaFullscreenEnterIcon, media_fullscreen_exit_icon_d_exports as MediaFullscreenExitIcon, media_pause_icon_d_exports as MediaPauseIcon, media_play_icon_d_exports as MediaPlayIcon, media_volume_high_icon_d_exports as MediaVolumeHighIcon, media_volume_low_icon_d_exports as MediaVolumeLowIcon, media_volume_off_icon_d_exports as MediaVolumeOffIcon };
1
+ import "./index-LKrIp3Oo.js";
package/dist/icons.js CHANGED
@@ -1,3 +1,2 @@
1
- import { a as media_pause_icon_exports, i as media_play_icon_exports, n as media_volume_low_icon_exports, o as media_fullscreen_exit_icon_exports, r as media_volume_high_icon_exports, s as media_fullscreen_enter_icon_exports, t as media_volume_off_icon_exports } from "./icons-YlVTDFdV.js";
2
-
3
- export { media_fullscreen_enter_icon_exports as MediaFullscreenEnterIcon, media_fullscreen_exit_icon_exports as MediaFullscreenExitIcon, media_pause_icon_exports as MediaPauseIcon, media_play_icon_exports as MediaPlayIcon, media_volume_high_icon_exports as MediaVolumeHighIcon, media_volume_low_icon_exports as MediaVolumeLowIcon, media_volume_off_icon_exports as MediaVolumeOffIcon };
1
+ import "./custom-element-3bDlB2XO.js";
2
+ import "./icons-CuxuONCk.js";
@@ -0,0 +1 @@
1
+ export { };
package/dist/index.d.ts CHANGED
@@ -1,8 +1,176 @@
1
- import { a as Tooltip, c as PlayButton, d as DurationDisplay, f as CurrentTimeDisplay, i as VolumeSlider, l as MuteButton, n as MediaProvider, o as TimeSlider, r as MediaContainer, s as Popover, t as MediaSkin, u as FullscreenButton } from "./media-skin-CbuyuCb-.js";
1
+ import { t as MediaSkinElement } from "./media-skin-Di3vSHvS.js";
2
+ import { CurrentTimeDisplayState, DurationDisplayState, FullscreenButtonState, MediaStore, MuteButtonState, PlayButtonState, PreviewTimeDisplayState } from "@videojs/core/store";
3
+ import { Constructor, CustomElement } from "@open-wc/context-protocol";
4
+ import { Placement } from "@floating-ui/dom";
5
+ import { TimeSlider, VolumeSlider } from "@videojs/core";
2
6
 
3
- //#region src/index.d.ts
7
+ //#region src/utils/component-factory.d.ts
4
8
 
5
- declare function defineVjsPlayer(): void;
9
+ interface ConnectedComponentConstructor<State> {
10
+ new (state: State): HTMLElement;
11
+ }
6
12
  //#endregion
7
- export { CurrentTimeDisplay, DurationDisplay, FullscreenButton, MediaContainer, MediaProvider, MediaSkin, MuteButton, PlayButton, Popover, TimeSlider, Tooltip, VolumeSlider, defineVjsPlayer };
13
+ //#region src/elements/current-time-display.d.ts
14
+
15
+ declare const CurrentTimeDisplayElement: ConnectedComponentConstructor<CurrentTimeDisplayState>;
16
+ //#endregion
17
+ //#region src/elements/duration-display.d.ts
18
+
19
+ declare const DurationDisplayElement: ConnectedComponentConstructor<DurationDisplayState>;
20
+ //#endregion
21
+ //#region src/elements/fullscreen-button.d.ts
22
+
23
+ declare const FullscreenButtonElement: ConnectedComponentConstructor<FullscreenButtonState>;
24
+ //#endregion
25
+ //#region src/elements/mute-button.d.ts
26
+ declare const MuteButtonElement: ConnectedComponentConstructor<MuteButtonState>;
27
+ //#endregion
28
+ //#region src/elements/play-button.d.ts
29
+ declare const PlayButtonElement: ConnectedComponentConstructor<PlayButtonState>;
30
+ //#endregion
31
+ //#region src/elements/popover.d.ts
32
+ declare class PopoverElement extends HTMLElement {
33
+ #private;
34
+ connectedCallback(): void;
35
+ disconnectedCallback(): void;
36
+ handleEvent(event: Event): void;
37
+ static get observedAttributes(): string[];
38
+ get openOnHover(): boolean;
39
+ get delay(): number;
40
+ get closeDelay(): number;
41
+ get side(): Placement;
42
+ get sideOffset(): number;
43
+ }
44
+ //#endregion
45
+ //#region src/elements/preview-time-display.d.ts
46
+ declare const PreviewTimeDisplayElement: ConnectedComponentConstructor<PreviewTimeDisplayState>;
47
+ //#endregion
48
+ //#region src/elements/time-slider.d.ts
49
+
50
+ declare const TimeSliderRootElement: ConnectedComponentConstructor<{
51
+ currentTime: number;
52
+ duration: number;
53
+ requestSeek: (time: number) => void;
54
+ core: TimeSlider | null;
55
+ }>;
56
+ declare const TimeSliderTrackElement: ConnectedComponentConstructor<any>;
57
+ declare const TimeSliderProgressElement: ConnectedComponentConstructor<any>;
58
+ declare const TimeSliderPointerElement: ConnectedComponentConstructor<any>;
59
+ declare const TimeSliderThumbElement: ConnectedComponentConstructor<any>;
60
+ declare const TimeSliderElement: {
61
+ Root: typeof TimeSliderRootElement;
62
+ Track: typeof TimeSliderTrackElement;
63
+ Progress: typeof TimeSliderProgressElement;
64
+ Pointer: typeof TimeSliderPointerElement;
65
+ Thumb: typeof TimeSliderThumbElement;
66
+ };
67
+ //#endregion
68
+ //#region src/elements/tooltip.d.ts
69
+ declare class TooltipRootElement extends HTMLElement {
70
+ #private;
71
+ constructor();
72
+ handleEvent(event: Event): void;
73
+ connectedCallback(): void;
74
+ disconnectedCallback(): void;
75
+ static get observedAttributes(): string[];
76
+ get delay(): number;
77
+ get closeDelay(): number;
78
+ get trackCursorAxis(): "x" | "y" | "both" | undefined;
79
+ }
80
+ declare class TooltipTriggerElement extends HTMLElement {
81
+ connectedCallback(): void;
82
+ }
83
+ declare class TooltipPortalElement extends HTMLElement {
84
+ #private;
85
+ connectedCallback(): void;
86
+ disconnectedCallback(): void;
87
+ querySelector(selector: string): HTMLElement | null;
88
+ }
89
+ declare class TooltipPositionerElement extends HTMLElement {
90
+ connectedCallback(): void;
91
+ get side(): Placement;
92
+ get sideOffset(): number;
93
+ get collisionPadding(): number;
94
+ }
95
+ declare class TooltipPopupElement extends HTMLElement {
96
+ connectedCallback(): void;
97
+ }
98
+ declare class TooltipArrowElement extends HTMLElement {
99
+ connectedCallback(): void;
100
+ }
101
+ declare const TooltipElement: {
102
+ Root: typeof TooltipRootElement;
103
+ Trigger: typeof TooltipTriggerElement;
104
+ Portal: typeof TooltipPortalElement;
105
+ Positioner: typeof TooltipPositionerElement;
106
+ Popup: typeof TooltipPopupElement;
107
+ Arrow: typeof TooltipArrowElement;
108
+ };
109
+ //#endregion
110
+ //#region src/elements/volume-slider.d.ts
111
+
112
+ /**
113
+ * Connected VolumeSlider Root component using hook-style architecture
114
+ */
115
+ declare const VolumeSliderRootElement: ConnectedComponentConstructor<{
116
+ volume: number;
117
+ muted: boolean;
118
+ volumeLevel: string;
119
+ requestVolumeChange: (volume: number) => void;
120
+ core: VolumeSlider | null;
121
+ }>;
122
+ /**
123
+ * Connected VolumeSlider Track component
124
+ */
125
+ declare const VolumeSliderTrackElement: ConnectedComponentConstructor<any>;
126
+ /**
127
+ * Connected VolumeSlider Progress component
128
+ */
129
+ declare const VolumeSliderProgressElement: ConnectedComponentConstructor<any>;
130
+ /**
131
+ * Connected VolumeSlider Thumb component
132
+ */
133
+ declare const VolumeSliderThumbElement: ConnectedComponentConstructor<any>;
134
+ /**
135
+ * Compound VolumeSlider component object
136
+ */
137
+ declare const VolumeSliderElement: {
138
+ Root: typeof VolumeSliderRootElement;
139
+ Track: typeof VolumeSliderTrackElement;
140
+ Progress: typeof VolumeSliderProgressElement;
141
+ Thumb: typeof VolumeSliderThumbElement;
142
+ };
143
+ //#endregion
144
+ //#region src/media/media-container.d.ts
145
+ declare const CustomElementConsumer: Constructor<CustomElement & HTMLElement>;
146
+ declare class MediaContainerElement extends CustomElementConsumer {
147
+ static shadowRootOptions: {
148
+ mode: ShadowRootMode;
149
+ };
150
+ static getTemplateHTML: () => string;
151
+ _mediaStore: any;
152
+ _mediaSlot: HTMLSlotElement;
153
+ _paused: boolean;
154
+ contexts: {
155
+ mediaStore: (mediaStore: any) => void;
156
+ };
157
+ constructor();
158
+ connectedCallback(): void;
159
+ disconnectedCallback(): void;
160
+ _registerContainerStateOwner: () => void;
161
+ _unregisterContainerStateOwner: () => void;
162
+ _handleMediaSlotChange: () => void;
163
+ _handleClick: (event: Event) => void;
164
+ _subscribeToPlayState: () => void;
165
+ }
166
+ //#endregion
167
+ //#region src/media/media-provider.d.ts
168
+ declare const ProviderHTMLElement: Constructor<CustomElement & HTMLElement>;
169
+ declare class MediaProviderElement extends ProviderHTMLElement {
170
+ contexts: {
171
+ mediaStore: () => MediaStore;
172
+ };
173
+ }
174
+ //#endregion
175
+ export { CurrentTimeDisplayElement, DurationDisplayElement, FullscreenButtonElement, MediaContainerElement, MediaProviderElement, MediaSkinElement, MuteButtonElement, PlayButtonElement, PopoverElement, PreviewTimeDisplayElement, TimeSliderElement, TooltipElement, VolumeSliderElement };
8
176
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","names":[],"sources":["../src/index.ts"],"sourcesContent":[],"mappings":";;;;iBAagB,eAAA,CAAA"}
1
+ {"version":3,"file":"index.d.ts","names":["useCurrentTimeDisplayState: StateHook<{\n currentTime: number | undefined;\n duration: number | undefined;\n}>","getCurrentTimeDisplayProps: PropsHook<{\n currentTime: number | undefined;\n duration: number | undefined;\n}>","CurrentTimeDisplayElement: ConnectedComponentConstructor<CurrentTimeDisplayState>","useDurationDisplayState: StateHook<{\n duration: number | undefined;\n}>","getDurationDisplayProps: PropsHook<{\n duration: number | undefined;\n}>","DurationDisplayElement: ConnectedComponentConstructor<DurationDisplayState>","getFullscreenButtonState: StateHook<{ fullscreen: boolean }>","getFullscreenButtonProps: PropsHook<{ fullscreen: boolean }>","FullscreenButtonElement: ConnectedComponentConstructor<FullscreenButtonState>","getMuteButtonState: StateHook<{\n muted: boolean;\n volumeLevel: string;\n}>","getMuteButtonProps: PropsHook<{\n muted: boolean;\n volumeLevel: string;\n}>","MuteButtonElement: ConnectedComponentConstructor<MuteButtonState>","getPlayButtonState: StateHook<{ paused: boolean }>","getPlayButtonProps: PropsHook<{ paused: boolean }>","PlayButtonElement: ConnectedComponentConstructor<PlayButtonState>","usePreviewTimeDisplayState: StateHook<{\n previewTime: number | undefined;\n}>","getPreviewTimeDisplayProps: PropsHook<{\n previewTime: number | undefined;\n}>","PreviewTimeDisplayElement: ConnectedComponentConstructor<PreviewTimeDisplayState>","getTimeSliderRootProps: PropsHook<{\n currentTime: number;\n duration: number;\n requestSeek: (time: number) => void;\n core: CoreTimeSlider | null;\n}>","useTimeSliderRootState: StateHook<{\n currentTime: number;\n duration: number;\n requestSeek: (time: number) => void;\n core: CoreTimeSlider | null;\n}>","getTimeSliderTrackProps: PropsHook<Record<string, never>>","getTimeSliderProgressProps: PropsHook<Record<string, never>>","getTimeSliderPointerProps: PropsHook<Record<string, never>>","getTimeSliderThumbProps: PropsHook<Record<string, never>>","TimeSliderRootElement: ConnectedComponentConstructor<{\n currentTime: number;\n duration: number;\n requestSeek: (time: number) => void;\n core: CoreTimeSlider | null;\n}>","TimeSliderTrackElement: ConnectedComponentConstructor<any>","TimeSliderProgressElement: ConnectedComponentConstructor<any>","TimeSliderPointerElement: ConnectedComponentConstructor<any>","TimeSliderThumbElement: ConnectedComponentConstructor<any>","TooltipElement: {\n Root: typeof TooltipRootElement;\n Trigger: typeof TooltipTriggerElement;\n Portal: typeof TooltipPortalElement;\n Positioner: typeof TooltipPositionerElement;\n Popup: typeof TooltipPopupElement;\n Arrow: typeof TooltipArrowElement;\n}","getVolumeSliderRootProps: PropsHook<{\n volume: number;\n muted: boolean;\n volumeLevel: string;\n requestVolumeChange: (volume: number) => void;\n core: CoreVolumeSlider | null;\n}>","useVolumeSliderRootState: StateHook<{\n volume: number;\n muted: boolean;\n volumeLevel: string;\n requestVolumeChange: (volume: number) => void;\n core: CoreVolumeSlider | null;\n}>","getVolumeSliderTrackProps: PropsHook<Record<string, never>>","getVolumeSliderProgressProps: PropsHook<Record<string, never>>","getVolumeSliderThumbProps: PropsHook<Record<string, never>>","VolumeSliderRootElement: ConnectedComponentConstructor<{\n volume: number;\n muted: boolean;\n volumeLevel: string;\n requestVolumeChange: (volume: number) => void;\n core: CoreVolumeSlider | null;\n}>","VolumeSliderTrackElement: ConnectedComponentConstructor<any>","VolumeSliderProgressElement: ConnectedComponentConstructor<any>","VolumeSliderThumbElement: ConnectedComponentConstructor<any>","CustomElementConsumer: Constructor<CustomElement & HTMLElement>","ProviderHTMLElement: Constructor<CustomElement & HTMLElement>"],"sources":["../src/utils/component-factory.ts","../src/elements/current-time-display.ts","../src/elements/duration-display.ts","../src/elements/fullscreen-button.ts","../src/elements/mute-button.ts","../src/elements/play-button.ts","../src/elements/popover.ts","../src/elements/preview-time-display.ts","../src/elements/time-slider.ts","../src/elements/tooltip.ts","../src/elements/volume-slider.ts","../src/media/media-container.ts","../src/media/media-provider.ts"],"sourcesContent":[],"mappings":";;;;;;;;UAaiB;cACH,QAAQ;;;;;cCqETE,2BAA2B,8BAA8B;;;;cCNzDG,wBAAwB,8BAA8B;;;;AEQtDM,cDXAH,uBCWiD,EDXxB,6BCWN,CDXoC,qBCWpC,CAAA;;;AAAnBG,cAAAA,iBAAiD,EAA9B,6BAAA,CAA8B,eAA9B,CAAA;;;ADXnBH,cEVAM,iBFUuD,EEVpC,6BFUM,CEVwB,eFUxB,CAAA;;;cG1DzB,cAAA,SAAuB,WAAA;;;;qBAmCf;;ENtCrB,IAAiB,WAAA,CAAA,CAAA,EAAA,OAAA;;;cM4EH;ELNd,IAAaZ,UAAAA,CAAAA,CAAAA,EAAAA,MAAAA;;;;cMVAe,2BAA2B,8BAA8B;;;;cCsKzDO,uBAAuB;;ECzOpC,QAAa,EAAA,MAAA;EAgQb,WAAa,EAAA,CAAA,IAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EA8Cb,IAAa,EDjEL,UCiEK,GAAA,IAAA;AAkDb,CAAA,CAAA;AA2Ba,cD3IAC,sBC2I4B,ED3IJ,6BC2II,CAAA,GAAA,CAAA;AAM5B,cD1IAC,yBC0I4B,ED1ID,6BC0IC,CAAA,GAAA,CAAA;AAM5BG,cDzIAF,wBCyIAE,EDzI0B,6BCyI1BA,CAAAA,GAAAA,CAAAA;AACE,cDnIFD,sBCmIE,EDnIsB,6BCmItB,CAAA,GAAA,CAAA;AACG,cD7HL,iBC6HK,EAAA;EACD,IAAA,EAAA,ODpHF,qBCoHE;EACI,KAAA,EAAA,ODpHL,sBCoHK;EACL,QAAA,EAAA,ODpHG,yBCoHH;EACA,OAAA,EAAA,ODpHE,wBCoHF;EAAA,KAAA,EAAA,ODnHA,sBCmHA;;;;cA7YH,kBAAA,SAA2B,WAAA;;;qBAkBnB;;;ETXrB,WAAiB,kBAAA,CAAA,CAAA,EAAA,MAAA,EAAA;;;;ACsEjB;cQmLa,qBAAA,SAA8B,WAAA;;;APzL9BvB,cOuOA,oBAAA,SAA6B,WAAA,CPvOyB;;;;ECHnE,aAAaG,CAAAA,QAAAA,EAAAA,MAAuD,CAAA,EMsPjC,WNtPiC,GAAA,IAAA;;cM4RvD,wBAAA,SAAiC,WAAA;;ELjR9C,IAAaG,IAAAA,CAAAA,CAAAA,EK+RC,SL/RDA;;;;ACrBAG,cIiUA,mBAAA,SAA4B,WAAA,CJjUT;;;cIuUnB,mBAAA,SAA4B,WAAA;EHvXzC,iBAAa,CAAA,CAAA,EAAA,IAAA;;AAyEC,cGoTDe,cHpTC,EAAA;EAzEsB,IAAA,EAAA,OG8XrB,kBH9XqB;EAAA,OAAA,EAAA,OG+XlB,qBH/XkB;iBGgYnB;qBACI;gBACL;EFzUhB,KAAaZ,EAAAA,OE0UG,mBF1UsD;;;;;;;;AGwNtD,cArDHkB,uBAqDG,EArDsB,6BAqDtB,CAAA;EAAA,MAAA,EAAA,MAAA;;;;EC5RA,IAUVI,EDkOE,YClOFA,GAAAA,IAAmD;CAAhB,CAAA;;;;AAE5B,cDsOAH,wBCtOA,EDsO0B,6BCtO1B,CAAA,GAAA,CAAA;;;;AAA8B,cDgP9BC,2BChP8B,EDgPD,6BChPC,CAAA,GAAA,CAAA;;;;cD0P9BC,0BAA0B;AE1QP;;;AAKL,cF+Qd,mBE/Qc,EAAA;EAAA,IAAA,EAAA,OFwRZ,uBExRY;EAE3B,KAAa,EAAA,OFuRG,wBErRI;mBFsRD;gBACH;;;;cClRVC,uBAAuB,YAAY,gBAAgB;cAE5C,qBAAA,SAA8B,qBAAA;;UACI;;EXL/C,OAAiB,eAAA,EAAA,GAAA,GAAA,MAAA;;cWSH;;EV6Dd,QAAarC,EAAAA;;;;ECNb,iBAAaG,CAAAA,CAAAA,EAAAA,IAAAA;;;;ECHb,sBAAaG,EAAAA,GAAAA,GAAuD,IAAA;wBQD3C;;;;;cCnEnBgC,qBAAqB,YAAY,gBAAgB;cAE1C,oBAAA,SAA6B,mBAAA;;sBAEtB;;AZGpB"}
package/dist/index.js CHANGED
@@ -1,10 +1,17 @@
1
- import { a as Tooltip, c as PlayButton, d as DurationDisplay, f as CurrentTimeDisplay, i as VolumeSlider, l as MuteButton, n as MediaProvider, o as TimeSlider, r as MediaContainer, s as Popover, t as MediaSkin, u as FullscreenButton } from "./media-skin-BlXPC9wG.js";
1
+ import "./component-factory-DeAN6cjC.js";
2
+ import { t as CurrentTimeDisplayElement } from "./current-time-display-C3qndGf5.js";
3
+ import { t as DurationDisplayElement } from "./duration-display-JOPp3bdU.js";
4
+ import "./button-D1DWjsQu.js";
5
+ import { t as FullscreenButtonElement } from "./fullscreen-button-CGO2UJjs.js";
6
+ import { t as MuteButtonElement } from "./mute-button-vW2sLqqY.js";
7
+ import { t as PlayButtonElement } from "./play-button-aVb0g10G.js";
8
+ import { t as PopoverElement } from "./popover-Dc0hyhwB.js";
9
+ import { t as PreviewTimeDisplayElement } from "./preview-time-display-Dax0FQ2X.js";
10
+ import { t as TimeSliderElement } from "./time-slider-CA1GMs6A.js";
11
+ import { n as TooltipElement } from "./tooltip-54fBUUpb.js";
12
+ import { t as VolumeSliderElement } from "./volume-slider-guD8gqpi.js";
13
+ import { t as MediaContainerElement } from "./media-container-C0MUzkJ_.js";
14
+ import { t as MediaProviderElement } from "./media-provider-CyoL0bCx.js";
15
+ import { t as MediaSkinElement } from "./media-skin-mHWwUPg3.js";
2
16
 
3
- //#region src/index.ts
4
- function defineVjsPlayer() {
5
- /** @TODO - Reimplement me (at least as a POC) (CJP) */
6
- }
7
-
8
- //#endregion
9
- export { CurrentTimeDisplay, DurationDisplay, FullscreenButton, MediaContainer, MediaProvider, MediaSkin, MuteButton, PlayButton, Popover, TimeSlider, Tooltip, VolumeSlider, defineVjsPlayer };
10
- //# sourceMappingURL=index.js.map
17
+ export { CurrentTimeDisplayElement, DurationDisplayElement, FullscreenButtonElement, MediaContainerElement, MediaProviderElement, MediaSkinElement, MuteButtonElement, PlayButtonElement, PopoverElement, PreviewTimeDisplayElement, TimeSliderElement, TooltipElement, VolumeSliderElement };
@@ -0,0 +1,8 @@
1
+ import { t as MediaContainerElement } from "./media-container-C0MUzkJ_.js";
2
+ import { t as defineCustomElement } from "./custom-element-3bDlB2XO.js";
3
+
4
+ //#region src/define/media-container.ts
5
+ defineCustomElement("media-container", MediaContainerElement);
6
+
7
+ //#endregion
8
+ //# sourceMappingURL=media-container-BGEXSi9g.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-container-BGEXSi9g.js","names":[],"sources":["../src/define/media-container.ts"],"sourcesContent":["import { MediaContainerElement } from '@/media/media-container';\nimport { defineCustomElement } from '@/utils/custom-element';\n\ndefineCustomElement('media-container', MediaContainerElement);\n"],"mappings":";;;;AAGA,oBAAoB,mBAAmB,sBAAsB"}
@@ -0,0 +1,83 @@
1
+ import { ConsumerMixin } from "@open-wc/context-protocol";
2
+
3
+ //#region src/media/media-container.ts
4
+ function getTemplateHTML() {
5
+ return `
6
+ <slot name="media"></slot>
7
+ <slot></slot>
8
+ <div id="@default_portal_id" style={ position: absolute; zIndex: 10; }>
9
+ <slot name="portal"></slot>
10
+ </div>
11
+ `;
12
+ }
13
+ const CustomElementConsumer = ConsumerMixin(HTMLElement);
14
+ var MediaContainerElement = class extends CustomElementConsumer {
15
+ static {
16
+ this.shadowRootOptions = { mode: "open" };
17
+ }
18
+ static {
19
+ this.getTemplateHTML = getTemplateHTML;
20
+ }
21
+ constructor() {
22
+ super();
23
+ this._paused = true;
24
+ this.contexts = { mediaStore: (mediaStore) => {
25
+ this._mediaStore = mediaStore;
26
+ this._handleMediaSlotChange();
27
+ this._registerContainerStateOwner();
28
+ this._subscribeToPlayState();
29
+ } };
30
+ this._registerContainerStateOwner = () => {
31
+ if (!this._mediaStore) return;
32
+ this._mediaStore.dispatch({
33
+ type: "containerstateownerchangerequest",
34
+ detail: this
35
+ });
36
+ };
37
+ this._unregisterContainerStateOwner = () => {
38
+ if (!this._mediaStore) return;
39
+ this._mediaStore.dispatch({
40
+ type: "containerstateownerchangerequest",
41
+ detail: null
42
+ });
43
+ };
44
+ this._handleMediaSlotChange = () => {
45
+ const media = this._mediaSlot.assignedElements({ flatten: true })[0];
46
+ this._mediaStore.dispatch({
47
+ type: "mediastateownerchangerequest",
48
+ detail: media
49
+ });
50
+ };
51
+ this._handleClick = (event) => {
52
+ if (!this._mediaStore) return;
53
+ if (!["video", "audio"].includes(event.target.localName || "")) return;
54
+ if (this._paused) this._mediaStore.dispatch({ type: "playrequest" });
55
+ else this._mediaStore.dispatch({ type: "pauserequest" });
56
+ };
57
+ this._subscribeToPlayState = () => {
58
+ if (!this._mediaStore) return;
59
+ this._mediaStore.subscribe((state) => {
60
+ this._paused = state.paused ?? true;
61
+ });
62
+ };
63
+ if (!this.shadowRoot) {
64
+ this.attachShadow(this.constructor.shadowRootOptions);
65
+ this.shadowRoot.innerHTML = this.constructor.getTemplateHTML();
66
+ }
67
+ this._mediaSlot = this.shadowRoot.querySelector("slot[name=media]");
68
+ this._mediaSlot.addEventListener("slotchange", this._handleMediaSlotChange);
69
+ this.addEventListener("click", this._handleClick);
70
+ }
71
+ connectedCallback() {
72
+ super.connectedCallback?.();
73
+ this._registerContainerStateOwner();
74
+ }
75
+ disconnectedCallback() {
76
+ super.disconnectedCallback?.();
77
+ this._unregisterContainerStateOwner();
78
+ }
79
+ };
80
+
81
+ //#endregion
82
+ export { MediaContainerElement as t };
83
+ //# sourceMappingURL=media-container-C0MUzkJ_.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-container-C0MUzkJ_.js","names":["CustomElementConsumer: Constructor<CustomElement & HTMLElement>"],"sources":["../src/media/media-container.ts"],"sourcesContent":["import type { Constructor, CustomElement } from '@open-wc/context-protocol';\n\nimport { ConsumerMixin } from '@open-wc/context-protocol';\n\n/* @TODO We need to make sure portal logic is non-brittle longer term (CJP) */\nexport function getTemplateHTML() {\n return /* html */ `\n <slot name=\"media\"></slot>\n <slot></slot>\n <div id=\"@default_portal_id\" style={ position: absolute; zIndex: 10; }>\n <slot name=\"portal\"></slot>\n </div>\n `;\n}\n\nconst CustomElementConsumer: Constructor<CustomElement & HTMLElement> = ConsumerMixin(HTMLElement);\n\nexport class MediaContainerElement extends CustomElementConsumer {\n static shadowRootOptions = { mode: 'open' as ShadowRootMode };\n static getTemplateHTML: () => string = getTemplateHTML;\n\n _mediaStore: any;\n _mediaSlot: HTMLSlotElement;\n _paused: boolean = true;\n contexts = {\n mediaStore: (mediaStore: any): void => {\n this._mediaStore = mediaStore;\n this._handleMediaSlotChange();\n this._registerContainerStateOwner();\n this._subscribeToPlayState();\n },\n };\n\n constructor() {\n super();\n\n if (!this.shadowRoot) {\n this.attachShadow((this.constructor as typeof MediaContainerElement).shadowRootOptions);\n this.shadowRoot!.innerHTML = (this.constructor as typeof MediaContainerElement).getTemplateHTML();\n }\n\n this._mediaSlot = this.shadowRoot!.querySelector('slot[name=media]') as HTMLSlotElement;\n this._mediaSlot.addEventListener('slotchange', this._handleMediaSlotChange);\n\n // Add click handler for play/pause functionality\n this.addEventListener('click', this._handleClick);\n }\n\n connectedCallback(): void {\n super.connectedCallback?.();\n this._registerContainerStateOwner();\n }\n\n disconnectedCallback(): void {\n super.disconnectedCallback?.();\n this._unregisterContainerStateOwner();\n }\n\n _registerContainerStateOwner = (): void => {\n if (!this._mediaStore) return;\n this._mediaStore.dispatch({ type: 'containerstateownerchangerequest', detail: this });\n };\n\n _unregisterContainerStateOwner = (): void => {\n if (!this._mediaStore) return;\n this._mediaStore.dispatch({ type: 'containerstateownerchangerequest', detail: null });\n };\n\n _handleMediaSlotChange = (): void => {\n const media = this._mediaSlot.assignedElements({ flatten: true })[0];\n this._mediaStore.dispatch({ type: 'mediastateownerchangerequest', detail: media });\n };\n\n _handleClick = (event: Event): void => {\n if (!this._mediaStore) return;\n\n if (!['video', 'audio'].includes((event.target as HTMLElement).localName || '')) return;\n\n if (this._paused) {\n this._mediaStore.dispatch({ type: 'playrequest' });\n } else {\n this._mediaStore.dispatch({ type: 'pauserequest' });\n }\n };\n\n _subscribeToPlayState = (): void => {\n if (!this._mediaStore) return;\n\n // Subscribe to paused state changes\n this._mediaStore.subscribe((state: any) => {\n this._paused = state.paused ?? true;\n });\n };\n}\n"],"mappings":";;;AAKA,SAAgB,kBAAkB;AAChC,QAAkB;;;;;;;;AASpB,MAAMA,wBAAkE,cAAc,YAAY;AAElG,IAAa,wBAAb,cAA2C,sBAAsB;;2BACpC,EAAE,MAAM,QAA0B;;;yBACtB;;CAcvC,cAAc;AACZ,SAAO;iBAXU;kBACR,EACT,aAAa,eAA0B;AACrC,QAAK,cAAc;AACnB,QAAK,wBAAwB;AAC7B,QAAK,8BAA8B;AACnC,QAAK,uBAAuB;KAE/B;4CA2B0C;AACzC,OAAI,CAAC,KAAK,YAAa;AACvB,QAAK,YAAY,SAAS;IAAE,MAAM;IAAoC,QAAQ;IAAM,CAAC;;8CAG1C;AAC3C,OAAI,CAAC,KAAK,YAAa;AACvB,QAAK,YAAY,SAAS;IAAE,MAAM;IAAoC,QAAQ;IAAM,CAAC;;sCAGlD;GACnC,MAAM,QAAQ,KAAK,WAAW,iBAAiB,EAAE,SAAS,MAAM,CAAC,CAAC;AAClE,QAAK,YAAY,SAAS;IAAE,MAAM;IAAgC,QAAQ;IAAO,CAAC;;uBAGpE,UAAuB;AACrC,OAAI,CAAC,KAAK,YAAa;AAEvB,OAAI,CAAC,CAAC,SAAS,QAAQ,CAAC,SAAU,MAAM,OAAuB,aAAa,GAAG,CAAE;AAEjF,OAAI,KAAK,QACP,MAAK,YAAY,SAAS,EAAE,MAAM,eAAe,CAAC;OAElD,MAAK,YAAY,SAAS,EAAE,MAAM,gBAAgB,CAAC;;qCAInB;AAClC,OAAI,CAAC,KAAK,YAAa;AAGvB,QAAK,YAAY,WAAW,UAAe;AACzC,SAAK,UAAU,MAAM,UAAU;KAC/B;;AAvDF,MAAI,CAAC,KAAK,YAAY;AACpB,QAAK,aAAc,KAAK,YAA6C,kBAAkB;AACvF,QAAK,WAAY,YAAa,KAAK,YAA6C,iBAAiB;;AAGnG,OAAK,aAAa,KAAK,WAAY,cAAc,mBAAmB;AACpE,OAAK,WAAW,iBAAiB,cAAc,KAAK,uBAAuB;AAG3E,OAAK,iBAAiB,SAAS,KAAK,aAAa;;CAGnD,oBAA0B;AACxB,QAAM,qBAAqB;AAC3B,OAAK,8BAA8B;;CAGrC,uBAA6B;AAC3B,QAAM,wBAAwB;AAC9B,OAAK,gCAAgC"}
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1,8 @@
1
+ import { t as CurrentTimeDisplayElement } from "./current-time-display-C3qndGf5.js";
2
+ import { t as defineCustomElement } from "./custom-element-3bDlB2XO.js";
3
+
4
+ //#region src/define/media-current-time-display.ts
5
+ defineCustomElement("media-current-time-display", CurrentTimeDisplayElement);
6
+
7
+ //#endregion
8
+ //# sourceMappingURL=media-current-time-display-B-4Cp845.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-current-time-display-B-4Cp845.js","names":[],"sources":["../src/define/media-current-time-display.ts"],"sourcesContent":["import { CurrentTimeDisplayElement } from '@/elements/current-time-display';\nimport { defineCustomElement } from '@/utils/custom-element';\n\ndefineCustomElement('media-current-time-display', CurrentTimeDisplayElement);\n"],"mappings":";;;;AAGA,oBAAoB,8BAA8B,0BAA0B"}
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1,8 @@
1
+ import { t as DurationDisplayElement } from "./duration-display-JOPp3bdU.js";
2
+ import { t as defineCustomElement } from "./custom-element-3bDlB2XO.js";
3
+
4
+ //#region src/define/media-duration-display.ts
5
+ defineCustomElement("media-duration-display", DurationDisplayElement);
6
+
7
+ //#endregion
8
+ //# sourceMappingURL=media-duration-display-BLMr7VHo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-duration-display-BLMr7VHo.js","names":[],"sources":["../src/define/media-duration-display.ts"],"sourcesContent":["import { DurationDisplayElement } from '@/elements/duration-display';\nimport { defineCustomElement } from '@/utils/custom-element';\n\ndefineCustomElement('media-duration-display', DurationDisplayElement);\n"],"mappings":";;;;AAGA,oBAAoB,0BAA0B,uBAAuB"}
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1,8 @@
1
+ import { t as FullscreenButtonElement } from "./fullscreen-button-CGO2UJjs.js";
2
+ import { t as defineCustomElement } from "./custom-element-3bDlB2XO.js";
3
+
4
+ //#region src/define/media-fullscreen-button.ts
5
+ defineCustomElement("media-fullscreen-button", FullscreenButtonElement);
6
+
7
+ //#endregion
8
+ //# sourceMappingURL=media-fullscreen-button-Dcflbt54.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-fullscreen-button-Dcflbt54.js","names":[],"sources":["../src/define/media-fullscreen-button.ts"],"sourcesContent":["import { FullscreenButtonElement } from '@/elements/fullscreen-button';\nimport { defineCustomElement } from '@/utils/custom-element';\n\ndefineCustomElement('media-fullscreen-button', FullscreenButtonElement);\n"],"mappings":";;;;AAGA,oBAAoB,2BAA2B,wBAAwB"}