@hanifhan1f/vidstack 1.12.19 → 1.12.25

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 (177) hide show
  1. package/cdn/chunks/vidstack-BBMfnVvt.js +1 -0
  2. package/cdn/chunks/vidstack-BF7lZRtq.js +3 -0
  3. package/cdn/chunks/vidstack-BYpysj84.js +1 -0
  4. package/cdn/chunks/vidstack-BkxGdzTJ.js +16 -0
  5. package/cdn/chunks/vidstack-Bzk6lVKb.js +1 -0
  6. package/cdn/chunks/vidstack-C0nMUcD9.js +1 -0
  7. package/cdn/chunks/vidstack-C1FlyyzK.js +1 -0
  8. package/cdn/chunks/vidstack-C51SKMUl.js +1 -0
  9. package/cdn/chunks/vidstack-CL95Hezv.js +1 -0
  10. package/cdn/chunks/vidstack-Cj0I-Rec.js +1 -0
  11. package/cdn/chunks/vidstack-CkaxOIJb.js +1 -0
  12. package/cdn/chunks/vidstack-Cu8FqSS9.js +1 -0
  13. package/cdn/chunks/vidstack-D84Fzc__.js +16 -0
  14. package/cdn/chunks/vidstack-DIPX97sJ.js +3 -0
  15. package/cdn/chunks/vidstack-DQvyz7Mm.js +1 -0
  16. package/cdn/chunks/vidstack-Dd9fqVv6.js +1 -0
  17. package/cdn/chunks/vidstack-DdAmWWBJ.js +1 -0
  18. package/cdn/chunks/vidstack-DhXI_0ND.js +1 -0
  19. package/cdn/chunks/vidstack-DiXE5sG8.js +1 -0
  20. package/cdn/chunks/vidstack-pFwe7gvT.js +3 -0
  21. package/cdn/chunks/vidstack-uMxrPflF.js +1 -0
  22. package/cdn/chunks/vidstack-zemsqC5d.js +1 -0
  23. package/cdn/providers/vidstack-audio-BAfEe7CJ.js +1 -0
  24. package/cdn/providers/vidstack-audio-BOGYlExy.js +1 -0
  25. package/cdn/providers/vidstack-dash-CGZUJqdT.js +1 -0
  26. package/cdn/providers/vidstack-dash-D4ZARr66.js +1 -0
  27. package/cdn/providers/vidstack-google-cast-Drb5Ncs5.js +1 -0
  28. package/cdn/providers/vidstack-hls-8-552IuX.js +1 -0
  29. package/cdn/providers/vidstack-hls-CVpa4usG.js +1 -0
  30. package/cdn/providers/vidstack-html-Bag27bH6.js +1 -0
  31. package/cdn/providers/vidstack-html-BvVaN2VT.js +1 -0
  32. package/cdn/providers/vidstack-video-BnwQZKER.js +1 -0
  33. package/cdn/providers/vidstack-video-DXUiSn4B.js +1 -0
  34. package/cdn/providers/vidstack-vimeo-DD6HUOtJ.js +1 -0
  35. package/cdn/providers/vidstack-vimeo-gJmBqtLK.js +1 -0
  36. package/cdn/providers/vidstack-youtube-BVNE075s.js +1 -0
  37. package/cdn/providers/vidstack-youtube-Chl_dTAz.js +1 -0
  38. package/cdn/vidstack.js +1 -1
  39. package/cdn/with-layouts/chunks/vidstack-2Rlth5Cf.js +1 -0
  40. package/cdn/with-layouts/chunks/vidstack-4liSokT6.js +1 -0
  41. package/cdn/with-layouts/chunks/vidstack-B97B8XDc.js +3 -0
  42. package/cdn/with-layouts/chunks/vidstack-BP3ybDy9.js +912 -0
  43. package/cdn/with-layouts/chunks/vidstack-BaNApRCP.js +1 -0
  44. package/cdn/with-layouts/chunks/vidstack-BbFHhcVG.js +1 -0
  45. package/cdn/with-layouts/chunks/vidstack-BlWKO1g1.js +1 -0
  46. package/cdn/with-layouts/chunks/vidstack-BxJPOhv7.js +1 -0
  47. package/cdn/with-layouts/chunks/vidstack-BxdAdQ0H.js +1 -0
  48. package/cdn/with-layouts/chunks/vidstack-CROJF16Z.js +1 -0
  49. package/cdn/with-layouts/chunks/vidstack-CXEcXyBI.js +1 -0
  50. package/cdn/with-layouts/chunks/vidstack-CaW6KGwN.js +1 -0
  51. package/cdn/with-layouts/chunks/vidstack-Ciq-n5rg.js +1 -0
  52. package/cdn/with-layouts/chunks/vidstack-CmuGllcj.js +1 -0
  53. package/cdn/with-layouts/chunks/vidstack-CwzW7rJU.js +1 -0
  54. package/cdn/with-layouts/chunks/vidstack-CyNByJUW.js +912 -0
  55. package/cdn/with-layouts/chunks/vidstack-DJyGEdCH.js +1 -0
  56. package/cdn/with-layouts/chunks/vidstack-DeLOZ-hK.js +3 -0
  57. package/cdn/with-layouts/chunks/vidstack-DhNpv7SU.js +1 -0
  58. package/cdn/with-layouts/chunks/vidstack-Dp3Ib32P.js +1 -0
  59. package/cdn/with-layouts/chunks/vidstack-Dy1Hfo7P.js +3 -0
  60. package/cdn/with-layouts/providers/vidstack-audio-CwoQJvl2.js +1 -0
  61. package/cdn/with-layouts/providers/vidstack-audio-cxaZF4jF.js +1 -0
  62. package/cdn/with-layouts/providers/vidstack-dash-CJsKJfLI.js +1 -0
  63. package/cdn/with-layouts/providers/vidstack-dash-DX1VjdTW.js +1 -0
  64. package/cdn/with-layouts/providers/vidstack-google-cast-DYJgNlvD.js +1 -0
  65. package/cdn/with-layouts/providers/vidstack-hls-2d6-2JAG.js +1 -0
  66. package/cdn/with-layouts/providers/vidstack-hls-ji26kFdQ.js +1 -0
  67. package/cdn/with-layouts/providers/vidstack-html-BvHMxtoe.js +1 -0
  68. package/cdn/with-layouts/providers/vidstack-html-C9nnuK3r.js +1 -0
  69. package/cdn/with-layouts/providers/vidstack-video-1Uj5cNP2.js +1 -0
  70. package/cdn/with-layouts/providers/vidstack-video-EWE67g5i.js +1 -0
  71. package/cdn/with-layouts/providers/vidstack-vimeo-DACTbJaQ.js +1 -0
  72. package/cdn/with-layouts/providers/vidstack-vimeo-DqFeS0-d.js +1 -0
  73. package/cdn/with-layouts/providers/vidstack-youtube-RoLp-I6u.js +1 -0
  74. package/cdn/with-layouts/providers/vidstack-youtube-eivIFfMV.js +1 -0
  75. package/cdn/with-layouts/vidstack.js +1 -1
  76. package/dev/chunks/vidstack-0XhA3AD_.js +5181 -0
  77. package/dev/chunks/vidstack-44ILR0Cb.js +1521 -0
  78. package/dev/chunks/vidstack-5oWWZmVl.js +58 -0
  79. package/dev/chunks/vidstack-B4XOm7dP.js +104 -0
  80. package/dev/chunks/vidstack-BnBLcaA5.js +115 -0
  81. package/dev/chunks/vidstack-Bo8BNFJ2.js +2986 -0
  82. package/dev/chunks/vidstack-C3N4zIuV.js +254 -0
  83. package/dev/chunks/vidstack-CAL4iu_K.js +1482 -0
  84. package/dev/chunks/vidstack-CEjYxSqZ.js +297 -0
  85. package/dev/chunks/vidstack-CGyAjz8G.js +58 -0
  86. package/dev/chunks/vidstack-CJCnHmKE.js +104 -0
  87. package/dev/chunks/vidstack-CQdFhXSo.js +204 -0
  88. package/dev/chunks/vidstack-CzCQJ29U.js +107 -0
  89. package/dev/chunks/vidstack-DD_3HszA.js +1520 -0
  90. package/dev/chunks/vidstack-DV4g4XvL.js +33 -0
  91. package/dev/chunks/vidstack-DWtK42Sh.js +1483 -0
  92. package/dev/chunks/vidstack-D_LvMxPr.js +204 -0
  93. package/dev/chunks/vidstack-DdTXMZro.js +66 -0
  94. package/dev/chunks/vidstack-DrczgsqN.js +297 -0
  95. package/dev/chunks/vidstack-el2dbO0m.js +5181 -0
  96. package/dev/chunks/vidstack-gF_qqvCK.js +109 -0
  97. package/dev/chunks/vidstack-rvhuswgi.js +2986 -0
  98. package/dev/define/plyr-layout.js +7 -7
  99. package/dev/define/templates/plyr-layout.js +2 -2
  100. package/dev/define/templates/vidstack-audio-layout.js +3 -3
  101. package/dev/define/templates/vidstack-video-layout.js +7 -9
  102. package/dev/define/vidstack-player-default-layout.js +3 -3
  103. package/dev/define/vidstack-player-layouts.js +3 -3
  104. package/dev/define/vidstack-player-ui.js +9 -9
  105. package/dev/define/vidstack-player.js +5 -5
  106. package/dev/global/plyr.js +9 -9
  107. package/dev/global/vidstack-player.js +6 -6
  108. package/dev/providers/vidstack-audio.js +2 -2
  109. package/dev/providers/vidstack-dash.js +4 -4
  110. package/dev/providers/vidstack-hls.js +4 -4
  111. package/dev/providers/vidstack-html.js +1 -1
  112. package/dev/providers/vidstack-video.js +4 -4
  113. package/dev/providers/vidstack-vimeo.js +4 -4
  114. package/dev/providers/vidstack-youtube.js +3 -3
  115. package/dev/vidstack-elements.js +12 -12
  116. package/dev/vidstack.js +9 -9
  117. package/package.json +1 -1
  118. package/player/styles/default/layouts/video.css +113 -79
  119. package/prod/chunks/vidstack-BAqdCFIm.js +4771 -0
  120. package/prod/chunks/vidstack-BRnfTkxi.js +297 -0
  121. package/prod/chunks/vidstack-BexQYZop.js +2976 -0
  122. package/prod/chunks/vidstack-Bf1Q6kqO.js +109 -0
  123. package/prod/chunks/vidstack-Bn9yLryd.js +58 -0
  124. package/prod/chunks/vidstack-C-yd_bAJ.js +4771 -0
  125. package/prod/chunks/vidstack-C4PTiuot.js +107 -0
  126. package/prod/chunks/vidstack-Cs0fH84E.js +1521 -0
  127. package/prod/chunks/vidstack-DDePVDjt.js +2976 -0
  128. package/prod/chunks/vidstack-DMDDSV3t.js +104 -0
  129. package/prod/chunks/vidstack-DXfGRhxZ.js +201 -0
  130. package/prod/chunks/vidstack-Dg71uhRc.js +58 -0
  131. package/prod/chunks/vidstack-DlLwMLBL.js +33 -0
  132. package/prod/chunks/vidstack-DnRxQoqP.js +104 -0
  133. package/prod/chunks/vidstack-KShKSmYu.js +66 -0
  134. package/prod/chunks/vidstack-Ko2EJadT.js +1483 -0
  135. package/prod/chunks/vidstack-ShUhyBfI.js +201 -0
  136. package/prod/chunks/vidstack-V9U6gsde.js +1482 -0
  137. package/prod/chunks/vidstack-XA3zT5W9.js +297 -0
  138. package/prod/chunks/vidstack-kdaDngIm.js +1520 -0
  139. package/prod/chunks/vidstack-oNEzlviH.js +246 -0
  140. package/prod/chunks/vidstack-wTTCvdqe.js +115 -0
  141. package/prod/define/plyr-layout.js +7 -7
  142. package/prod/define/templates/plyr-layout.js +2 -2
  143. package/prod/define/templates/vidstack-audio-layout.js +3 -3
  144. package/prod/define/templates/vidstack-video-layout.js +7 -9
  145. package/prod/define/vidstack-player-default-layout.js +3 -3
  146. package/prod/define/vidstack-player-layouts.js +3 -3
  147. package/prod/define/vidstack-player-ui.js +9 -9
  148. package/prod/define/vidstack-player.js +5 -5
  149. package/prod/global/plyr.js +9 -9
  150. package/prod/global/vidstack-player.js +6 -6
  151. package/prod/providers/vidstack-audio.js +2 -2
  152. package/prod/providers/vidstack-dash.js +4 -4
  153. package/prod/providers/vidstack-hls.js +4 -4
  154. package/prod/providers/vidstack-html.js +1 -1
  155. package/prod/providers/vidstack-video.js +4 -4
  156. package/prod/providers/vidstack-vimeo.js +4 -4
  157. package/prod/providers/vidstack-youtube.js +3 -3
  158. package/prod/vidstack-elements.js +12 -12
  159. package/prod/vidstack.js +9 -9
  160. package/server/chunks/vidstack-B2Bc9g7_.js +2000 -0
  161. package/server/chunks/vidstack-BosyhF3p.js +207 -0
  162. package/server/chunks/vidstack-C8F1EUBn.js +104 -0
  163. package/server/chunks/vidstack-CWho6PlG.js +141 -0
  164. package/server/chunks/vidstack-DhF59-Up.js +4635 -0
  165. package/server/chunks/vidstack-DoHmOxNm.js +295 -0
  166. package/server/chunks/vidstack-DzWvfg1d.js +1503 -0
  167. package/server/chunks/vidstack-PnFpou7g.js +3035 -0
  168. package/server/chunks/vidstack-gEJMQpTE.js +2001 -0
  169. package/server/define/plyr-layout.js +2 -2
  170. package/server/define/vidstack-player-default-layout.js +1 -1
  171. package/server/define/vidstack-player-layouts.js +1 -1
  172. package/server/define/vidstack-player-ui.js +4 -4
  173. package/server/define/vidstack-player.js +2 -2
  174. package/server/global/plyr.js +4 -4
  175. package/server/global/vidstack-player.js +2 -2
  176. package/server/vidstack-elements.js +8 -8
  177. package/server/vidstack.js +4 -4
@@ -0,0 +1,107 @@
1
+ import { Component, State, effect, isNull, setAttribute, EventsController } from './vidstack-C1PwJD_4.js';
2
+ import { useMediaContext } from './vidstack-BjxlZzGu.js';
3
+ import { preconnect } from './vidstack-DdTXMZro.js';
4
+
5
+ class Poster extends Component {
6
+ static props = {
7
+ src: null,
8
+ alt: null,
9
+ crossOrigin: null
10
+ };
11
+ static state = new State({
12
+ img: null,
13
+ src: null,
14
+ alt: null,
15
+ crossOrigin: null,
16
+ loading: true,
17
+ error: null,
18
+ hidden: false
19
+ });
20
+ #media;
21
+ onSetup() {
22
+ this.#media = useMediaContext();
23
+ this.#watchSrc();
24
+ this.#watchAlt();
25
+ this.#watchCrossOrigin();
26
+ this.#watchHidden();
27
+ }
28
+ onAttach(el) {
29
+ el.style.setProperty("pointer-events", "none");
30
+ effect(this.#watchImg.bind(this));
31
+ effect(this.#watchSrc.bind(this));
32
+ effect(this.#watchAlt.bind(this));
33
+ effect(this.#watchCrossOrigin.bind(this));
34
+ effect(this.#watchHidden.bind(this));
35
+ const { started } = this.#media.$state;
36
+ this.setAttributes({
37
+ "data-visible": () => !started() && !this.$state.hidden(),
38
+ "data-loading": this.#isLoading.bind(this),
39
+ "data-error": this.#hasError.bind(this),
40
+ "data-hidden": this.$state.hidden
41
+ });
42
+ }
43
+ onConnect(el) {
44
+ effect(this.#onPreconnect.bind(this));
45
+ effect(this.#onLoadStart.bind(this));
46
+ }
47
+ #hasError() {
48
+ const { error } = this.$state;
49
+ return !isNull(error());
50
+ }
51
+ #onPreconnect() {
52
+ const { canLoadPoster, poster } = this.#media.$state;
53
+ if (!canLoadPoster() && poster()) preconnect(poster(), "preconnect");
54
+ }
55
+ #watchHidden() {
56
+ const { src } = this.$props, { poster, nativeControls } = this.#media.$state;
57
+ this.el && setAttribute(this.el, "display", nativeControls() ? "none" : null);
58
+ this.$state.hidden.set(this.#hasError() || !(src() || poster()) || nativeControls());
59
+ }
60
+ #isLoading() {
61
+ const { loading, hidden } = this.$state;
62
+ return !hidden() && loading();
63
+ }
64
+ #watchImg() {
65
+ const img = this.$state.img();
66
+ if (!img) return;
67
+ new EventsController(img).add("load", this.#onLoad.bind(this)).add("error", this.#onError.bind(this));
68
+ if (img.complete) this.#onLoad();
69
+ }
70
+ #prevSrc = "";
71
+ #watchSrc() {
72
+ const { poster: defaultPoster } = this.#media.$props, { canLoadPoster, providedPoster, inferredPoster } = this.#media.$state;
73
+ const src = this.$props.src() || "", poster = src || defaultPoster() || inferredPoster();
74
+ if (this.#prevSrc === providedPoster()) {
75
+ providedPoster.set(src);
76
+ }
77
+ this.$state.src.set(canLoadPoster() && poster.length ? poster : null);
78
+ this.#prevSrc = src;
79
+ }
80
+ #watchAlt() {
81
+ const { src } = this.$props, { alt } = this.$state, { poster } = this.#media.$state;
82
+ alt.set(src() || poster() ? this.$props.alt() : null);
83
+ }
84
+ #watchCrossOrigin() {
85
+ const { crossOrigin: crossOriginProp } = this.$props, { crossOrigin: crossOriginState } = this.$state, { crossOrigin: mediaCrossOrigin, poster: src } = this.#media.$state, crossOrigin = crossOriginProp() !== null ? crossOriginProp() : mediaCrossOrigin();
86
+ crossOriginState.set(
87
+ /ytimg\.com|vimeo/.test(src() || "") ? null : crossOrigin === true ? "anonymous" : crossOrigin
88
+ );
89
+ }
90
+ #onLoadStart() {
91
+ const { loading, error } = this.$state, { canLoadPoster, poster } = this.#media.$state;
92
+ loading.set(canLoadPoster() && !!poster());
93
+ error.set(null);
94
+ }
95
+ #onLoad() {
96
+ const { loading, error } = this.$state;
97
+ loading.set(false);
98
+ error.set(null);
99
+ }
100
+ #onError(event) {
101
+ const { loading, error } = this.$state;
102
+ loading.set(false);
103
+ error.set(event);
104
+ }
105
+ }
106
+
107
+ export { Poster };