@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.
- package/cdn/chunks/vidstack-BBMfnVvt.js +1 -0
- package/cdn/chunks/vidstack-BF7lZRtq.js +3 -0
- package/cdn/chunks/vidstack-BYpysj84.js +1 -0
- package/cdn/chunks/vidstack-BkxGdzTJ.js +16 -0
- package/cdn/chunks/vidstack-Bzk6lVKb.js +1 -0
- package/cdn/chunks/vidstack-C0nMUcD9.js +1 -0
- package/cdn/chunks/vidstack-C1FlyyzK.js +1 -0
- package/cdn/chunks/vidstack-C51SKMUl.js +1 -0
- package/cdn/chunks/vidstack-CL95Hezv.js +1 -0
- package/cdn/chunks/vidstack-Cj0I-Rec.js +1 -0
- package/cdn/chunks/vidstack-CkaxOIJb.js +1 -0
- package/cdn/chunks/vidstack-Cu8FqSS9.js +1 -0
- package/cdn/chunks/vidstack-D84Fzc__.js +16 -0
- package/cdn/chunks/vidstack-DIPX97sJ.js +3 -0
- package/cdn/chunks/vidstack-DQvyz7Mm.js +1 -0
- package/cdn/chunks/vidstack-Dd9fqVv6.js +1 -0
- package/cdn/chunks/vidstack-DdAmWWBJ.js +1 -0
- package/cdn/chunks/vidstack-DhXI_0ND.js +1 -0
- package/cdn/chunks/vidstack-DiXE5sG8.js +1 -0
- package/cdn/chunks/vidstack-pFwe7gvT.js +3 -0
- package/cdn/chunks/vidstack-uMxrPflF.js +1 -0
- package/cdn/chunks/vidstack-zemsqC5d.js +1 -0
- package/cdn/providers/vidstack-audio-BAfEe7CJ.js +1 -0
- package/cdn/providers/vidstack-audio-BOGYlExy.js +1 -0
- package/cdn/providers/vidstack-dash-CGZUJqdT.js +1 -0
- package/cdn/providers/vidstack-dash-D4ZARr66.js +1 -0
- package/cdn/providers/vidstack-google-cast-Drb5Ncs5.js +1 -0
- package/cdn/providers/vidstack-hls-8-552IuX.js +1 -0
- package/cdn/providers/vidstack-hls-CVpa4usG.js +1 -0
- package/cdn/providers/vidstack-html-Bag27bH6.js +1 -0
- package/cdn/providers/vidstack-html-BvVaN2VT.js +1 -0
- package/cdn/providers/vidstack-video-BnwQZKER.js +1 -0
- package/cdn/providers/vidstack-video-DXUiSn4B.js +1 -0
- package/cdn/providers/vidstack-vimeo-DD6HUOtJ.js +1 -0
- package/cdn/providers/vidstack-vimeo-gJmBqtLK.js +1 -0
- package/cdn/providers/vidstack-youtube-BVNE075s.js +1 -0
- package/cdn/providers/vidstack-youtube-Chl_dTAz.js +1 -0
- package/cdn/vidstack.js +1 -1
- package/cdn/with-layouts/chunks/vidstack-2Rlth5Cf.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-4liSokT6.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-B97B8XDc.js +3 -0
- package/cdn/with-layouts/chunks/vidstack-BP3ybDy9.js +912 -0
- package/cdn/with-layouts/chunks/vidstack-BaNApRCP.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-BbFHhcVG.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-BlWKO1g1.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-BxJPOhv7.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-BxdAdQ0H.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-CROJF16Z.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-CXEcXyBI.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-CaW6KGwN.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-Ciq-n5rg.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-CmuGllcj.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-CwzW7rJU.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-CyNByJUW.js +912 -0
- package/cdn/with-layouts/chunks/vidstack-DJyGEdCH.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-DeLOZ-hK.js +3 -0
- package/cdn/with-layouts/chunks/vidstack-DhNpv7SU.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-Dp3Ib32P.js +1 -0
- package/cdn/with-layouts/chunks/vidstack-Dy1Hfo7P.js +3 -0
- package/cdn/with-layouts/providers/vidstack-audio-CwoQJvl2.js +1 -0
- package/cdn/with-layouts/providers/vidstack-audio-cxaZF4jF.js +1 -0
- package/cdn/with-layouts/providers/vidstack-dash-CJsKJfLI.js +1 -0
- package/cdn/with-layouts/providers/vidstack-dash-DX1VjdTW.js +1 -0
- package/cdn/with-layouts/providers/vidstack-google-cast-DYJgNlvD.js +1 -0
- package/cdn/with-layouts/providers/vidstack-hls-2d6-2JAG.js +1 -0
- package/cdn/with-layouts/providers/vidstack-hls-ji26kFdQ.js +1 -0
- package/cdn/with-layouts/providers/vidstack-html-BvHMxtoe.js +1 -0
- package/cdn/with-layouts/providers/vidstack-html-C9nnuK3r.js +1 -0
- package/cdn/with-layouts/providers/vidstack-video-1Uj5cNP2.js +1 -0
- package/cdn/with-layouts/providers/vidstack-video-EWE67g5i.js +1 -0
- package/cdn/with-layouts/providers/vidstack-vimeo-DACTbJaQ.js +1 -0
- package/cdn/with-layouts/providers/vidstack-vimeo-DqFeS0-d.js +1 -0
- package/cdn/with-layouts/providers/vidstack-youtube-RoLp-I6u.js +1 -0
- package/cdn/with-layouts/providers/vidstack-youtube-eivIFfMV.js +1 -0
- package/cdn/with-layouts/vidstack.js +1 -1
- package/dev/chunks/vidstack-0XhA3AD_.js +5181 -0
- package/dev/chunks/vidstack-44ILR0Cb.js +1521 -0
- package/dev/chunks/vidstack-5oWWZmVl.js +58 -0
- package/dev/chunks/vidstack-B4XOm7dP.js +104 -0
- package/dev/chunks/vidstack-BnBLcaA5.js +115 -0
- package/dev/chunks/vidstack-Bo8BNFJ2.js +2986 -0
- package/dev/chunks/vidstack-C3N4zIuV.js +254 -0
- package/dev/chunks/vidstack-CAL4iu_K.js +1482 -0
- package/dev/chunks/vidstack-CEjYxSqZ.js +297 -0
- package/dev/chunks/vidstack-CGyAjz8G.js +58 -0
- package/dev/chunks/vidstack-CJCnHmKE.js +104 -0
- package/dev/chunks/vidstack-CQdFhXSo.js +204 -0
- package/dev/chunks/vidstack-CzCQJ29U.js +107 -0
- package/dev/chunks/vidstack-DD_3HszA.js +1520 -0
- package/dev/chunks/vidstack-DV4g4XvL.js +33 -0
- package/dev/chunks/vidstack-DWtK42Sh.js +1483 -0
- package/dev/chunks/vidstack-D_LvMxPr.js +204 -0
- package/dev/chunks/vidstack-DdTXMZro.js +66 -0
- package/dev/chunks/vidstack-DrczgsqN.js +297 -0
- package/dev/chunks/vidstack-el2dbO0m.js +5181 -0
- package/dev/chunks/vidstack-gF_qqvCK.js +109 -0
- package/dev/chunks/vidstack-rvhuswgi.js +2986 -0
- package/dev/define/plyr-layout.js +7 -7
- package/dev/define/templates/plyr-layout.js +2 -2
- package/dev/define/templates/vidstack-audio-layout.js +3 -3
- package/dev/define/templates/vidstack-video-layout.js +7 -9
- package/dev/define/vidstack-player-default-layout.js +3 -3
- package/dev/define/vidstack-player-layouts.js +3 -3
- package/dev/define/vidstack-player-ui.js +9 -9
- package/dev/define/vidstack-player.js +5 -5
- package/dev/global/plyr.js +9 -9
- package/dev/global/vidstack-player.js +6 -6
- package/dev/providers/vidstack-audio.js +2 -2
- package/dev/providers/vidstack-dash.js +4 -4
- package/dev/providers/vidstack-hls.js +4 -4
- package/dev/providers/vidstack-html.js +1 -1
- package/dev/providers/vidstack-video.js +4 -4
- package/dev/providers/vidstack-vimeo.js +4 -4
- package/dev/providers/vidstack-youtube.js +3 -3
- package/dev/vidstack-elements.js +12 -12
- package/dev/vidstack.js +9 -9
- package/package.json +1 -1
- package/player/styles/default/layouts/video.css +113 -79
- package/prod/chunks/vidstack-BAqdCFIm.js +4771 -0
- package/prod/chunks/vidstack-BRnfTkxi.js +297 -0
- package/prod/chunks/vidstack-BexQYZop.js +2976 -0
- package/prod/chunks/vidstack-Bf1Q6kqO.js +109 -0
- package/prod/chunks/vidstack-Bn9yLryd.js +58 -0
- package/prod/chunks/vidstack-C-yd_bAJ.js +4771 -0
- package/prod/chunks/vidstack-C4PTiuot.js +107 -0
- package/prod/chunks/vidstack-Cs0fH84E.js +1521 -0
- package/prod/chunks/vidstack-DDePVDjt.js +2976 -0
- package/prod/chunks/vidstack-DMDDSV3t.js +104 -0
- package/prod/chunks/vidstack-DXfGRhxZ.js +201 -0
- package/prod/chunks/vidstack-Dg71uhRc.js +58 -0
- package/prod/chunks/vidstack-DlLwMLBL.js +33 -0
- package/prod/chunks/vidstack-DnRxQoqP.js +104 -0
- package/prod/chunks/vidstack-KShKSmYu.js +66 -0
- package/prod/chunks/vidstack-Ko2EJadT.js +1483 -0
- package/prod/chunks/vidstack-ShUhyBfI.js +201 -0
- package/prod/chunks/vidstack-V9U6gsde.js +1482 -0
- package/prod/chunks/vidstack-XA3zT5W9.js +297 -0
- package/prod/chunks/vidstack-kdaDngIm.js +1520 -0
- package/prod/chunks/vidstack-oNEzlviH.js +246 -0
- package/prod/chunks/vidstack-wTTCvdqe.js +115 -0
- package/prod/define/plyr-layout.js +7 -7
- package/prod/define/templates/plyr-layout.js +2 -2
- package/prod/define/templates/vidstack-audio-layout.js +3 -3
- package/prod/define/templates/vidstack-video-layout.js +7 -9
- package/prod/define/vidstack-player-default-layout.js +3 -3
- package/prod/define/vidstack-player-layouts.js +3 -3
- package/prod/define/vidstack-player-ui.js +9 -9
- package/prod/define/vidstack-player.js +5 -5
- package/prod/global/plyr.js +9 -9
- package/prod/global/vidstack-player.js +6 -6
- package/prod/providers/vidstack-audio.js +2 -2
- package/prod/providers/vidstack-dash.js +4 -4
- package/prod/providers/vidstack-hls.js +4 -4
- package/prod/providers/vidstack-html.js +1 -1
- package/prod/providers/vidstack-video.js +4 -4
- package/prod/providers/vidstack-vimeo.js +4 -4
- package/prod/providers/vidstack-youtube.js +3 -3
- package/prod/vidstack-elements.js +12 -12
- package/prod/vidstack.js +9 -9
- package/server/chunks/vidstack-B2Bc9g7_.js +2000 -0
- package/server/chunks/vidstack-BosyhF3p.js +207 -0
- package/server/chunks/vidstack-C8F1EUBn.js +104 -0
- package/server/chunks/vidstack-CWho6PlG.js +141 -0
- package/server/chunks/vidstack-DhF59-Up.js +4635 -0
- package/server/chunks/vidstack-DoHmOxNm.js +295 -0
- package/server/chunks/vidstack-DzWvfg1d.js +1503 -0
- package/server/chunks/vidstack-PnFpou7g.js +3035 -0
- package/server/chunks/vidstack-gEJMQpTE.js +2001 -0
- package/server/define/plyr-layout.js +2 -2
- package/server/define/vidstack-player-default-layout.js +1 -1
- package/server/define/vidstack-player-layouts.js +1 -1
- package/server/define/vidstack-player-ui.js +4 -4
- package/server/define/vidstack-player.js +2 -2
- package/server/global/plyr.js +4 -4
- package/server/global/vidstack-player.js +2 -2
- package/server/vidstack-elements.js +8 -8
- package/server/vidstack.js +4 -4
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { signal, listenEvent, effect, peek, isString } from './vidstack-C1PwJD_4.js';
|
|
2
|
+
import { appendParamsToURL } from './vidstack-DdTXMZro.js';
|
|
3
|
+
|
|
4
|
+
class EmbedProvider {
|
|
5
|
+
#iframe;
|
|
6
|
+
src = signal("");
|
|
7
|
+
/**
|
|
8
|
+
* Defines which referrer is sent when fetching the resource.
|
|
9
|
+
*
|
|
10
|
+
* @see {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLIFrameElement/referrerPolicy}
|
|
11
|
+
*/
|
|
12
|
+
referrerPolicy = null;
|
|
13
|
+
get iframe() {
|
|
14
|
+
return this.#iframe;
|
|
15
|
+
}
|
|
16
|
+
constructor(iframe) {
|
|
17
|
+
this.#iframe = iframe;
|
|
18
|
+
iframe.setAttribute("frameBorder", "0");
|
|
19
|
+
iframe.setAttribute("aria-hidden", "true");
|
|
20
|
+
iframe.setAttribute(
|
|
21
|
+
"allow",
|
|
22
|
+
"autoplay; fullscreen; encrypted-media; picture-in-picture; accelerometer; gyroscope"
|
|
23
|
+
);
|
|
24
|
+
if (this.referrerPolicy !== null) {
|
|
25
|
+
iframe.setAttribute("referrerpolicy", this.referrerPolicy);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
setup() {
|
|
29
|
+
listenEvent(window, "message", this.#onWindowMessage.bind(this));
|
|
30
|
+
listenEvent(this.#iframe, "load", this.onLoad.bind(this));
|
|
31
|
+
effect(this.#watchSrc.bind(this));
|
|
32
|
+
}
|
|
33
|
+
#watchSrc() {
|
|
34
|
+
const src = this.src();
|
|
35
|
+
if (!src.length) {
|
|
36
|
+
this.#iframe.setAttribute("src", "");
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const params = peek(() => this.buildParams());
|
|
40
|
+
this.#iframe.setAttribute("src", appendParamsToURL(src, params));
|
|
41
|
+
}
|
|
42
|
+
postMessage(message, target) {
|
|
43
|
+
this.#iframe.contentWindow?.postMessage(JSON.stringify(message), target ?? "*");
|
|
44
|
+
}
|
|
45
|
+
#onWindowMessage(event) {
|
|
46
|
+
const origin = this.getOrigin(), isOriginMatch = (event.source === null || event.source === this.#iframe?.contentWindow) && (!isString(origin) || origin === event.origin);
|
|
47
|
+
if (!isOriginMatch) return;
|
|
48
|
+
try {
|
|
49
|
+
const message = JSON.parse(event.data);
|
|
50
|
+
if (message) this.onMessage(message, event);
|
|
51
|
+
return;
|
|
52
|
+
} catch (e) {
|
|
53
|
+
}
|
|
54
|
+
if (event.data) this.onMessage(event.data, event);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export { EmbedProvider };
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Host, effect, setAttribute, computed } from './vidstack-C1PwJD_4.js';
|
|
2
|
+
import { MediaProvider, MediaPlayer } from './vidstack-el2dbO0m.js';
|
|
3
|
+
import { useMediaContext } from './vidstack-BjxlZzGu.js';
|
|
4
|
+
|
|
5
|
+
class MediaProviderElement extends Host(HTMLElement, MediaProvider) {
|
|
6
|
+
static tagName = "media-provider";
|
|
7
|
+
#media;
|
|
8
|
+
#target = null;
|
|
9
|
+
#blocker = null;
|
|
10
|
+
onSetup() {
|
|
11
|
+
this.#media = useMediaContext();
|
|
12
|
+
this.setAttribute("keep-alive", "");
|
|
13
|
+
}
|
|
14
|
+
onDestroy() {
|
|
15
|
+
this.#blocker?.remove();
|
|
16
|
+
this.#blocker = null;
|
|
17
|
+
this.#target?.remove();
|
|
18
|
+
this.#target = null;
|
|
19
|
+
}
|
|
20
|
+
onConnect() {
|
|
21
|
+
effect(() => {
|
|
22
|
+
const loader = this.$state.loader(), isYouTubeEmbed = loader?.name === "youtube", isVimeoEmbed = loader?.name === "vimeo", isEmbed = isYouTubeEmbed || isVimeoEmbed, isGoogleCast = loader?.name === "google-cast";
|
|
23
|
+
const target = loader ? isGoogleCast ? this.#createGoogleCastContainer() : isEmbed ? this.#createIFrame() : loader.mediaType() === "audio" ? this.#createAudio() : this.#createVideo() : null;
|
|
24
|
+
if (this.#target !== target) {
|
|
25
|
+
const parent = this.#target?.parentElement ?? this;
|
|
26
|
+
this.#target?.remove();
|
|
27
|
+
this.#target = target;
|
|
28
|
+
if (target) parent.prepend(target);
|
|
29
|
+
if (isEmbed && target) {
|
|
30
|
+
effect(() => {
|
|
31
|
+
const { nativeControls, viewType } = this.#media.$state, showNativeControls = nativeControls(), isAudioView = viewType() === "audio", showBlocker = !showNativeControls && !isAudioView;
|
|
32
|
+
if (showBlocker) {
|
|
33
|
+
this.#blocker = this.querySelector(".vds-blocker");
|
|
34
|
+
if (!this.#blocker) {
|
|
35
|
+
this.#blocker = document.createElement("div");
|
|
36
|
+
this.#blocker.classList.add("vds-blocker");
|
|
37
|
+
target.after(this.#blocker);
|
|
38
|
+
}
|
|
39
|
+
} else {
|
|
40
|
+
this.#blocker?.remove();
|
|
41
|
+
this.#blocker = null;
|
|
42
|
+
}
|
|
43
|
+
setAttribute(target, "data-no-controls", !showNativeControls);
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
if (isYouTubeEmbed) target?.classList.add("vds-youtube");
|
|
48
|
+
else if (isVimeoEmbed) target?.classList.add("vds-vimeo");
|
|
49
|
+
if (!isEmbed) {
|
|
50
|
+
this.#blocker?.remove();
|
|
51
|
+
this.#blocker = null;
|
|
52
|
+
}
|
|
53
|
+
this.load(target);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
#createAudio() {
|
|
57
|
+
const audio = this.#target instanceof HTMLAudioElement ? this.#target : document.createElement("audio");
|
|
58
|
+
const { controls, crossOrigin } = this.#media.$state;
|
|
59
|
+
effect(() => {
|
|
60
|
+
setAttribute(audio, "controls", controls());
|
|
61
|
+
setAttribute(audio, "crossorigin", crossOrigin());
|
|
62
|
+
});
|
|
63
|
+
return audio;
|
|
64
|
+
}
|
|
65
|
+
#createVideo() {
|
|
66
|
+
const video = this.#target instanceof HTMLVideoElement ? this.#target : document.createElement("video");
|
|
67
|
+
const { crossOrigin, poster, nativeControls } = this.#media.$state, $controls = computed(() => nativeControls() ? "true" : null), $poster = computed(() => poster() && nativeControls() ? poster() : null);
|
|
68
|
+
effect(() => {
|
|
69
|
+
setAttribute(video, "controls", $controls());
|
|
70
|
+
setAttribute(video, "crossorigin", crossOrigin());
|
|
71
|
+
setAttribute(video, "poster", $poster());
|
|
72
|
+
});
|
|
73
|
+
return video;
|
|
74
|
+
}
|
|
75
|
+
#createIFrame() {
|
|
76
|
+
const iframe = this.#target instanceof HTMLIFrameElement ? this.#target : document.createElement("iframe"), { nativeControls } = this.#media.$state;
|
|
77
|
+
effect(() => setAttribute(iframe, "tabindex", !nativeControls() ? -1 : null));
|
|
78
|
+
return iframe;
|
|
79
|
+
}
|
|
80
|
+
#createGoogleCastContainer() {
|
|
81
|
+
if (this.#target?.classList.contains("vds-google-cast")) {
|
|
82
|
+
return this.#target;
|
|
83
|
+
}
|
|
84
|
+
const container = document.createElement("div");
|
|
85
|
+
container.classList.add("vds-google-cast");
|
|
86
|
+
import('./vidstack-Bf6x4gWe.js').then(({ insertContent }) => {
|
|
87
|
+
insertContent(container, this.#media.$state);
|
|
88
|
+
});
|
|
89
|
+
return container;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
class MediaPlayerElement extends Host(HTMLElement, MediaPlayer) {
|
|
94
|
+
static tagName = "media-player";
|
|
95
|
+
static attrs = {
|
|
96
|
+
autoPlay: "autoplay",
|
|
97
|
+
crossOrigin: "crossorigin",
|
|
98
|
+
playsInline: "playsinline",
|
|
99
|
+
preferNativeHLS: "prefer-native-hls",
|
|
100
|
+
minLiveDVRWindow: "min-live-dvr-window"
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
export { MediaPlayerElement, MediaProviderElement };
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { isFunction, isUndefined, waitTimeout, isString } from './vidstack-C1PwJD_4.js';
|
|
2
|
+
|
|
3
|
+
const UA = navigator?.userAgent.toLowerCase() || "";
|
|
4
|
+
const IS_IOS = /iphone|ipad|ipod|ios|crios|fxios/i.test(UA);
|
|
5
|
+
const IS_IPHONE = /(iphone|ipod)/gi.test(navigator?.platform || "");
|
|
6
|
+
const IS_CHROME = !!window.chrome;
|
|
7
|
+
const IS_SAFARI = !!window.safari || IS_IOS;
|
|
8
|
+
function canOrientScreen() {
|
|
9
|
+
return canRotateScreen() && isFunction(screen.orientation.unlock);
|
|
10
|
+
}
|
|
11
|
+
function canRotateScreen() {
|
|
12
|
+
return !isUndefined(window.screen.orientation) && !isUndefined(window.screen.orientation.lock);
|
|
13
|
+
}
|
|
14
|
+
function canPlayAudioType(audio, type) {
|
|
15
|
+
if (!audio) audio = document.createElement("audio");
|
|
16
|
+
return audio.canPlayType(type).length > 0;
|
|
17
|
+
}
|
|
18
|
+
function canPlayVideoType(video, type) {
|
|
19
|
+
if (!video) video = document.createElement("video");
|
|
20
|
+
return video.canPlayType(type).length > 0;
|
|
21
|
+
}
|
|
22
|
+
function canPlayHLSNatively(video) {
|
|
23
|
+
if (!video) video = document.createElement("video");
|
|
24
|
+
return video.canPlayType("application/vnd.apple.mpegurl").length > 0;
|
|
25
|
+
}
|
|
26
|
+
function canUsePictureInPicture(video) {
|
|
27
|
+
if (!video) return false;
|
|
28
|
+
return !!document.pictureInPictureEnabled && !video.disablePictureInPicture;
|
|
29
|
+
}
|
|
30
|
+
function canUseVideoPresentation(video) {
|
|
31
|
+
return isFunction(video?.webkitSupportsPresentationMode) && isFunction(video?.webkitSetPresentationMode);
|
|
32
|
+
}
|
|
33
|
+
async function canChangeVolume() {
|
|
34
|
+
const video = document.createElement("video");
|
|
35
|
+
video.volume = 0.5;
|
|
36
|
+
await waitTimeout(0);
|
|
37
|
+
return video.volume === 0.5;
|
|
38
|
+
}
|
|
39
|
+
function getMediaSource() {
|
|
40
|
+
return window?.ManagedMediaSource ?? window?.MediaSource ?? window?.WebKitMediaSource;
|
|
41
|
+
}
|
|
42
|
+
function getSourceBuffer() {
|
|
43
|
+
return window?.SourceBuffer ?? window?.WebKitSourceBuffer;
|
|
44
|
+
}
|
|
45
|
+
function isHLSSupported() {
|
|
46
|
+
const MediaSource = getMediaSource();
|
|
47
|
+
if (isUndefined(MediaSource)) return false;
|
|
48
|
+
const isTypeSupported = MediaSource && isFunction(MediaSource.isTypeSupported) && MediaSource.isTypeSupported('video/mp4; codecs="avc1.42E01E,mp4a.40.2"');
|
|
49
|
+
const SourceBuffer = getSourceBuffer();
|
|
50
|
+
const isSourceBufferValid = isUndefined(SourceBuffer) || !isUndefined(SourceBuffer.prototype) && isFunction(SourceBuffer.prototype.appendBuffer) && isFunction(SourceBuffer.prototype.remove);
|
|
51
|
+
return !!isTypeSupported && !!isSourceBufferValid;
|
|
52
|
+
}
|
|
53
|
+
function isDASHSupported() {
|
|
54
|
+
return isHLSSupported();
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const AUDIO_EXTENSIONS = /\.(m4a|m4b|mp4a|mpga|mp2|mp2a|mp3|m2a|m3a|wav|weba|aac|oga|spx|flac)($|\?)/i;
|
|
58
|
+
const AUDIO_TYPES = /* @__PURE__ */ new Set([
|
|
59
|
+
"audio/mpeg",
|
|
60
|
+
"audio/ogg",
|
|
61
|
+
"audio/3gp",
|
|
62
|
+
"audio/mp3",
|
|
63
|
+
"audio/webm",
|
|
64
|
+
"audio/flac",
|
|
65
|
+
"audio/m4a",
|
|
66
|
+
"audio/m4b",
|
|
67
|
+
"audio/mp4a",
|
|
68
|
+
"audio/mp4"
|
|
69
|
+
]);
|
|
70
|
+
const VIDEO_EXTENSIONS = /\.(mp4|og[gv]|webm|mov|m4v)(#t=[,\d+]+)?($|\?)/i;
|
|
71
|
+
const VIDEO_TYPES = /* @__PURE__ */ new Set([
|
|
72
|
+
"video/mp4",
|
|
73
|
+
"video/webm",
|
|
74
|
+
"video/3gp",
|
|
75
|
+
"video/ogg",
|
|
76
|
+
"video/avi",
|
|
77
|
+
"video/mpeg"
|
|
78
|
+
]);
|
|
79
|
+
const HLS_VIDEO_EXTENSIONS = /\.(m3u8)($|\?)/i;
|
|
80
|
+
const DASH_VIDEO_EXTENSIONS = /\.(mpd)($|\?)/i;
|
|
81
|
+
const HLS_VIDEO_TYPES = /* @__PURE__ */ new Set([
|
|
82
|
+
// Apple sanctioned
|
|
83
|
+
"application/vnd.apple.mpegurl",
|
|
84
|
+
// Apple sanctioned for backwards compatibility
|
|
85
|
+
"audio/mpegurl",
|
|
86
|
+
// Very common
|
|
87
|
+
"audio/x-mpegurl",
|
|
88
|
+
// Very common
|
|
89
|
+
"application/x-mpegurl",
|
|
90
|
+
// Included for completeness
|
|
91
|
+
"video/x-mpegurl",
|
|
92
|
+
"video/mpegurl",
|
|
93
|
+
"application/mpegurl"
|
|
94
|
+
]);
|
|
95
|
+
const DASH_VIDEO_TYPES = /* @__PURE__ */ new Set(["application/dash+xml"]);
|
|
96
|
+
function isAudioSrc({ src, type }) {
|
|
97
|
+
return isString(src) ? AUDIO_EXTENSIONS.test(src) || AUDIO_TYPES.has(type) || src.startsWith("blob:") && type === "audio/object" : type === "audio/object";
|
|
98
|
+
}
|
|
99
|
+
function isVideoSrc(src) {
|
|
100
|
+
return isString(src.src) ? VIDEO_EXTENSIONS.test(src.src) || VIDEO_TYPES.has(src.type) || src.src.startsWith("blob:") && src.type === "video/object" || isHLSSrc(src) && canPlayHLSNatively() : src.type === "video/object";
|
|
101
|
+
}
|
|
102
|
+
function isHLSSrc({ src, type }) {
|
|
103
|
+
return isString(src) && HLS_VIDEO_EXTENSIONS.test(src) || HLS_VIDEO_TYPES.has(type);
|
|
104
|
+
}
|
|
105
|
+
function isDASHSrc({ src, type }) {
|
|
106
|
+
return isString(src) && DASH_VIDEO_EXTENSIONS.test(src) || DASH_VIDEO_TYPES.has(type);
|
|
107
|
+
}
|
|
108
|
+
function canGoogleCastSrc(src) {
|
|
109
|
+
return isString(src.src) && (isAudioSrc(src) || isVideoSrc(src) || isHLSSrc(src));
|
|
110
|
+
}
|
|
111
|
+
function isMediaStream(src) {
|
|
112
|
+
return typeof window.MediaStream !== "undefined" && src instanceof window.MediaStream;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export { AUDIO_EXTENSIONS, AUDIO_TYPES, DASH_VIDEO_EXTENSIONS, DASH_VIDEO_TYPES, HLS_VIDEO_EXTENSIONS, HLS_VIDEO_TYPES, IS_CHROME, IS_IOS, IS_IPHONE, IS_SAFARI, VIDEO_EXTENSIONS, VIDEO_TYPES, canChangeVolume, canGoogleCastSrc, canOrientScreen, canPlayAudioType, canPlayHLSNatively, canPlayVideoType, canRotateScreen, canUsePictureInPicture, canUseVideoPresentation, isAudioSrc, isDASHSrc, isDASHSupported, isHLSSrc, isHLSSupported, isMediaStream, isVideoSrc };
|