@mux/mux-player 2.8.0 → 2.8.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs.js +143 -132
- package/dist/index.mjs +26 -14
- package/dist/mux-player.js +144 -133
- package/dist/mux-player.mjs +144 -133
- package/dist/themes/classic/index.cjs.js +32 -17
- package/dist/themes/classic/index.js +32 -17
- package/dist/themes/classic/index.mjs +32 -17
- package/dist/themes/gerwig/index.cjs.js +32 -17
- package/dist/themes/gerwig/index.js +32 -17
- package/dist/themes/gerwig/index.mjs +32 -17
- package/dist/themes/microvideo/index.cjs.js +22 -16
- package/dist/themes/microvideo/index.js +22 -16
- package/dist/themes/microvideo/index.mjs +22 -16
- package/dist/themes/minimal/index.cjs.js +18 -15
- package/dist/themes/minimal/index.js +18 -15
- package/dist/themes/minimal/index.mjs +18 -15
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -3
|
@@ -107,16 +107,28 @@ var classic_default = `<!-- prettier-ignore -->
|
|
|
107
107
|
|
|
108
108
|
/* 0.433s is the transition duration for VTT Regions.
|
|
109
109
|
* Borrowed here, so the captions don't move too fast. */
|
|
110
|
-
media-controller
|
|
110
|
+
media-controller {
|
|
111
111
|
--media-webkit-text-track-transition: transform 0.433s ease-out 0.3s;
|
|
112
112
|
}
|
|
113
|
-
media-controller:is([mediapaused],:not([userinactive]))
|
|
113
|
+
media-controller:is([mediapaused],:not([userinactive])) {
|
|
114
114
|
/* 42px is the height of the control bar and progress bar
|
|
115
115
|
* with an additional 5px as a buffer, to get 47px */
|
|
116
116
|
--media-webkit-text-track-transform: translateY(-47px);
|
|
117
117
|
--media-webkit-text-track-transition: transform 0.15s ease;
|
|
118
118
|
}
|
|
119
119
|
|
|
120
|
+
/*
|
|
121
|
+
* CSS specific to iOS devices.
|
|
122
|
+
* See: https://stackoverflow.com/questions/30102792/css-media-query-to-target-only-ios-devices/60220757#60220757
|
|
123
|
+
*/
|
|
124
|
+
@supports (-webkit-touch-callout: none) {
|
|
125
|
+
/* Disable subtitle adjusting for iOS Safari */
|
|
126
|
+
media-controller[mediaisfullscreen] {
|
|
127
|
+
--media-webkit-text-track-transform: unset;
|
|
128
|
+
--media-webkit-text-track-transition: unset;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
120
132
|
:host media-time-range {
|
|
121
133
|
color: var(--_primary-color);
|
|
122
134
|
--media-range-thumb-opacity: 0;
|
|
@@ -1014,7 +1026,6 @@ var documentShim = {
|
|
|
1014
1026
|
dispatchEvent(event) {
|
|
1015
1027
|
return false;
|
|
1016
1028
|
}
|
|
1017
|
-
// eslint-disable-line no-unused-vars
|
|
1018
1029
|
};
|
|
1019
1030
|
var globalThisShim2 = {
|
|
1020
1031
|
ResizeObserver,
|
|
@@ -1036,11 +1047,10 @@ var globalThisShim2 = {
|
|
|
1036
1047
|
/**
|
|
1037
1048
|
* @param {string} key
|
|
1038
1049
|
* @returns {string|null}
|
|
1039
|
-
|
|
1050
|
+
*/
|
|
1040
1051
|
getItem(key) {
|
|
1041
1052
|
return null;
|
|
1042
1053
|
},
|
|
1043
|
-
// eslint-disable-line no-unused-vars
|
|
1044
1054
|
/**
|
|
1045
1055
|
* @param {string} key
|
|
1046
1056
|
* @param {string} value
|
|
@@ -1050,7 +1060,7 @@ var globalThisShim2 = {
|
|
|
1050
1060
|
// eslint-disable-line no-unused-vars
|
|
1051
1061
|
/**
|
|
1052
1062
|
* @param {string} key
|
|
1053
|
-
|
|
1063
|
+
*/
|
|
1054
1064
|
removeItem(key) {
|
|
1055
1065
|
}
|
|
1056
1066
|
// eslint-disable-line no-unused-vars
|
|
@@ -1471,7 +1481,9 @@ var processor = {
|
|
|
1471
1481
|
for (const [expression, part] of parts) {
|
|
1472
1482
|
if (part instanceof InnerTemplatePart) {
|
|
1473
1483
|
if (!part.directive) {
|
|
1474
|
-
const directive = DirectiveNames.find(
|
|
1484
|
+
const directive = DirectiveNames.find(
|
|
1485
|
+
(n) => part.template.hasAttribute(n)
|
|
1486
|
+
);
|
|
1475
1487
|
if (directive) {
|
|
1476
1488
|
part.directive = directive;
|
|
1477
1489
|
part.expression = part.template.getAttribute(directive);
|
|
@@ -1484,11 +1496,7 @@ var processor = {
|
|
|
1484
1496
|
if (value instanceof PartialTemplate) {
|
|
1485
1497
|
if (templates.get(part) !== value.template) {
|
|
1486
1498
|
templates.set(part, value.template);
|
|
1487
|
-
value = new TemplateInstance(
|
|
1488
|
-
value.template,
|
|
1489
|
-
value.state,
|
|
1490
|
-
processor
|
|
1491
|
-
);
|
|
1499
|
+
value = new TemplateInstance(value.template, value.state, processor);
|
|
1492
1500
|
part.value = value;
|
|
1493
1501
|
templateInstances.set(part, value);
|
|
1494
1502
|
} else {
|
|
@@ -1766,7 +1774,10 @@ var MediaThemeElement = class extends GlobalThis.HTMLElement {
|
|
|
1766
1774
|
attributes: true,
|
|
1767
1775
|
subtree: true
|
|
1768
1776
|
});
|
|
1769
|
-
this.addEventListener(
|
|
1777
|
+
this.addEventListener(
|
|
1778
|
+
MediaStateChangeEvents.BREAKPOINTS_COMPUTED,
|
|
1779
|
+
this.render
|
|
1780
|
+
);
|
|
1770
1781
|
__privateMethod(this, _upgradeProperty, upgradeProperty_fn).call(this, "template");
|
|
1771
1782
|
}
|
|
1772
1783
|
/** @type {HTMLElement & { breakpointsComputed?: boolean }} */
|
|
@@ -1785,9 +1796,11 @@ var MediaThemeElement = class extends GlobalThis.HTMLElement {
|
|
|
1785
1796
|
get props() {
|
|
1786
1797
|
var _a2, _b2, _c;
|
|
1787
1798
|
const observedAttributes = [
|
|
1788
|
-
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
1789
|
-
|
|
1790
|
-
|
|
1799
|
+
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
1800
|
+
({ name }) => {
|
|
1801
|
+
return observedMediaAttributes[name] || name.startsWith("breakpoint");
|
|
1802
|
+
}
|
|
1803
|
+
),
|
|
1791
1804
|
...Array.from(this.attributes)
|
|
1792
1805
|
];
|
|
1793
1806
|
const props = {};
|
|
@@ -1889,7 +1902,9 @@ function isValidUrl(url) {
|
|
|
1889
1902
|
async function request(resource) {
|
|
1890
1903
|
const response = await fetch(resource);
|
|
1891
1904
|
if (response.status !== 200) {
|
|
1892
|
-
throw new Error(
|
|
1905
|
+
throw new Error(
|
|
1906
|
+
`Failed to load resource: the server responded with a status of ${response.status}`
|
|
1907
|
+
);
|
|
1893
1908
|
}
|
|
1894
1909
|
return response.text();
|
|
1895
1910
|
}
|
|
@@ -107,16 +107,28 @@ var mediaThemeClassic = (() => {
|
|
|
107
107
|
|
|
108
108
|
/* 0.433s is the transition duration for VTT Regions.
|
|
109
109
|
* Borrowed here, so the captions don't move too fast. */
|
|
110
|
-
media-controller
|
|
110
|
+
media-controller {
|
|
111
111
|
--media-webkit-text-track-transition: transform 0.433s ease-out 0.3s;
|
|
112
112
|
}
|
|
113
|
-
media-controller:is([mediapaused],:not([userinactive]))
|
|
113
|
+
media-controller:is([mediapaused],:not([userinactive])) {
|
|
114
114
|
/* 42px is the height of the control bar and progress bar
|
|
115
115
|
* with an additional 5px as a buffer, to get 47px */
|
|
116
116
|
--media-webkit-text-track-transform: translateY(-47px);
|
|
117
117
|
--media-webkit-text-track-transition: transform 0.15s ease;
|
|
118
118
|
}
|
|
119
119
|
|
|
120
|
+
/*
|
|
121
|
+
* CSS specific to iOS devices.
|
|
122
|
+
* See: https://stackoverflow.com/questions/30102792/css-media-query-to-target-only-ios-devices/60220757#60220757
|
|
123
|
+
*/
|
|
124
|
+
@supports (-webkit-touch-callout: none) {
|
|
125
|
+
/* Disable subtitle adjusting for iOS Safari */
|
|
126
|
+
media-controller[mediaisfullscreen] {
|
|
127
|
+
--media-webkit-text-track-transform: unset;
|
|
128
|
+
--media-webkit-text-track-transition: unset;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
120
132
|
:host media-time-range {
|
|
121
133
|
color: var(--_primary-color);
|
|
122
134
|
--media-range-thumb-opacity: 0;
|
|
@@ -1014,7 +1026,6 @@ var mediaThemeClassic = (() => {
|
|
|
1014
1026
|
dispatchEvent(event) {
|
|
1015
1027
|
return false;
|
|
1016
1028
|
}
|
|
1017
|
-
// eslint-disable-line no-unused-vars
|
|
1018
1029
|
};
|
|
1019
1030
|
var globalThisShim2 = {
|
|
1020
1031
|
ResizeObserver,
|
|
@@ -1036,11 +1047,10 @@ var mediaThemeClassic = (() => {
|
|
|
1036
1047
|
/**
|
|
1037
1048
|
* @param {string} key
|
|
1038
1049
|
* @returns {string|null}
|
|
1039
|
-
|
|
1050
|
+
*/
|
|
1040
1051
|
getItem(key) {
|
|
1041
1052
|
return null;
|
|
1042
1053
|
},
|
|
1043
|
-
// eslint-disable-line no-unused-vars
|
|
1044
1054
|
/**
|
|
1045
1055
|
* @param {string} key
|
|
1046
1056
|
* @param {string} value
|
|
@@ -1050,7 +1060,7 @@ var mediaThemeClassic = (() => {
|
|
|
1050
1060
|
// eslint-disable-line no-unused-vars
|
|
1051
1061
|
/**
|
|
1052
1062
|
* @param {string} key
|
|
1053
|
-
|
|
1063
|
+
*/
|
|
1054
1064
|
removeItem(key) {
|
|
1055
1065
|
}
|
|
1056
1066
|
// eslint-disable-line no-unused-vars
|
|
@@ -1471,7 +1481,9 @@ var mediaThemeClassic = (() => {
|
|
|
1471
1481
|
for (const [expression, part] of parts) {
|
|
1472
1482
|
if (part instanceof InnerTemplatePart) {
|
|
1473
1483
|
if (!part.directive) {
|
|
1474
|
-
const directive = DirectiveNames.find(
|
|
1484
|
+
const directive = DirectiveNames.find(
|
|
1485
|
+
(n) => part.template.hasAttribute(n)
|
|
1486
|
+
);
|
|
1475
1487
|
if (directive) {
|
|
1476
1488
|
part.directive = directive;
|
|
1477
1489
|
part.expression = part.template.getAttribute(directive);
|
|
@@ -1484,11 +1496,7 @@ var mediaThemeClassic = (() => {
|
|
|
1484
1496
|
if (value instanceof PartialTemplate) {
|
|
1485
1497
|
if (templates.get(part) !== value.template) {
|
|
1486
1498
|
templates.set(part, value.template);
|
|
1487
|
-
value = new TemplateInstance(
|
|
1488
|
-
value.template,
|
|
1489
|
-
value.state,
|
|
1490
|
-
processor
|
|
1491
|
-
);
|
|
1499
|
+
value = new TemplateInstance(value.template, value.state, processor);
|
|
1492
1500
|
part.value = value;
|
|
1493
1501
|
templateInstances.set(part, value);
|
|
1494
1502
|
} else {
|
|
@@ -1766,7 +1774,10 @@ var mediaThemeClassic = (() => {
|
|
|
1766
1774
|
attributes: true,
|
|
1767
1775
|
subtree: true
|
|
1768
1776
|
});
|
|
1769
|
-
this.addEventListener(
|
|
1777
|
+
this.addEventListener(
|
|
1778
|
+
MediaStateChangeEvents.BREAKPOINTS_COMPUTED,
|
|
1779
|
+
this.render
|
|
1780
|
+
);
|
|
1770
1781
|
__privateMethod(this, _upgradeProperty, upgradeProperty_fn).call(this, "template");
|
|
1771
1782
|
}
|
|
1772
1783
|
/** @type {HTMLElement & { breakpointsComputed?: boolean }} */
|
|
@@ -1785,9 +1796,11 @@ var mediaThemeClassic = (() => {
|
|
|
1785
1796
|
get props() {
|
|
1786
1797
|
var _a2, _b2, _c;
|
|
1787
1798
|
const observedAttributes = [
|
|
1788
|
-
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
1789
|
-
|
|
1790
|
-
|
|
1799
|
+
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
1800
|
+
({ name }) => {
|
|
1801
|
+
return observedMediaAttributes[name] || name.startsWith("breakpoint");
|
|
1802
|
+
}
|
|
1803
|
+
),
|
|
1791
1804
|
...Array.from(this.attributes)
|
|
1792
1805
|
];
|
|
1793
1806
|
const props = {};
|
|
@@ -1889,7 +1902,9 @@ var mediaThemeClassic = (() => {
|
|
|
1889
1902
|
async function request(resource) {
|
|
1890
1903
|
const response = await fetch(resource);
|
|
1891
1904
|
if (response.status !== 200) {
|
|
1892
|
-
throw new Error(
|
|
1905
|
+
throw new Error(
|
|
1906
|
+
`Failed to load resource: the server responded with a status of ${response.status}`
|
|
1907
|
+
);
|
|
1893
1908
|
}
|
|
1894
1909
|
return response.text();
|
|
1895
1910
|
}
|
|
@@ -82,16 +82,28 @@ var classic_default = `<!-- prettier-ignore -->
|
|
|
82
82
|
|
|
83
83
|
/* 0.433s is the transition duration for VTT Regions.
|
|
84
84
|
* Borrowed here, so the captions don't move too fast. */
|
|
85
|
-
media-controller
|
|
85
|
+
media-controller {
|
|
86
86
|
--media-webkit-text-track-transition: transform 0.433s ease-out 0.3s;
|
|
87
87
|
}
|
|
88
|
-
media-controller:is([mediapaused],:not([userinactive]))
|
|
88
|
+
media-controller:is([mediapaused],:not([userinactive])) {
|
|
89
89
|
/* 42px is the height of the control bar and progress bar
|
|
90
90
|
* with an additional 5px as a buffer, to get 47px */
|
|
91
91
|
--media-webkit-text-track-transform: translateY(-47px);
|
|
92
92
|
--media-webkit-text-track-transition: transform 0.15s ease;
|
|
93
93
|
}
|
|
94
94
|
|
|
95
|
+
/*
|
|
96
|
+
* CSS specific to iOS devices.
|
|
97
|
+
* See: https://stackoverflow.com/questions/30102792/css-media-query-to-target-only-ios-devices/60220757#60220757
|
|
98
|
+
*/
|
|
99
|
+
@supports (-webkit-touch-callout: none) {
|
|
100
|
+
/* Disable subtitle adjusting for iOS Safari */
|
|
101
|
+
media-controller[mediaisfullscreen] {
|
|
102
|
+
--media-webkit-text-track-transform: unset;
|
|
103
|
+
--media-webkit-text-track-transition: unset;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
95
107
|
:host media-time-range {
|
|
96
108
|
color: var(--_primary-color);
|
|
97
109
|
--media-range-thumb-opacity: 0;
|
|
@@ -989,7 +1001,6 @@ var documentShim = {
|
|
|
989
1001
|
dispatchEvent(event) {
|
|
990
1002
|
return false;
|
|
991
1003
|
}
|
|
992
|
-
// eslint-disable-line no-unused-vars
|
|
993
1004
|
};
|
|
994
1005
|
var globalThisShim2 = {
|
|
995
1006
|
ResizeObserver,
|
|
@@ -1011,11 +1022,10 @@ var globalThisShim2 = {
|
|
|
1011
1022
|
/**
|
|
1012
1023
|
* @param {string} key
|
|
1013
1024
|
* @returns {string|null}
|
|
1014
|
-
|
|
1025
|
+
*/
|
|
1015
1026
|
getItem(key) {
|
|
1016
1027
|
return null;
|
|
1017
1028
|
},
|
|
1018
|
-
// eslint-disable-line no-unused-vars
|
|
1019
1029
|
/**
|
|
1020
1030
|
* @param {string} key
|
|
1021
1031
|
* @param {string} value
|
|
@@ -1025,7 +1035,7 @@ var globalThisShim2 = {
|
|
|
1025
1035
|
// eslint-disable-line no-unused-vars
|
|
1026
1036
|
/**
|
|
1027
1037
|
* @param {string} key
|
|
1028
|
-
|
|
1038
|
+
*/
|
|
1029
1039
|
removeItem(key) {
|
|
1030
1040
|
}
|
|
1031
1041
|
// eslint-disable-line no-unused-vars
|
|
@@ -1446,7 +1456,9 @@ var processor = {
|
|
|
1446
1456
|
for (const [expression, part] of parts) {
|
|
1447
1457
|
if (part instanceof InnerTemplatePart) {
|
|
1448
1458
|
if (!part.directive) {
|
|
1449
|
-
const directive = DirectiveNames.find(
|
|
1459
|
+
const directive = DirectiveNames.find(
|
|
1460
|
+
(n) => part.template.hasAttribute(n)
|
|
1461
|
+
);
|
|
1450
1462
|
if (directive) {
|
|
1451
1463
|
part.directive = directive;
|
|
1452
1464
|
part.expression = part.template.getAttribute(directive);
|
|
@@ -1459,11 +1471,7 @@ var processor = {
|
|
|
1459
1471
|
if (value instanceof PartialTemplate) {
|
|
1460
1472
|
if (templates.get(part) !== value.template) {
|
|
1461
1473
|
templates.set(part, value.template);
|
|
1462
|
-
value = new TemplateInstance(
|
|
1463
|
-
value.template,
|
|
1464
|
-
value.state,
|
|
1465
|
-
processor
|
|
1466
|
-
);
|
|
1474
|
+
value = new TemplateInstance(value.template, value.state, processor);
|
|
1467
1475
|
part.value = value;
|
|
1468
1476
|
templateInstances.set(part, value);
|
|
1469
1477
|
} else {
|
|
@@ -1741,7 +1749,10 @@ var MediaThemeElement = class extends GlobalThis.HTMLElement {
|
|
|
1741
1749
|
attributes: true,
|
|
1742
1750
|
subtree: true
|
|
1743
1751
|
});
|
|
1744
|
-
this.addEventListener(
|
|
1752
|
+
this.addEventListener(
|
|
1753
|
+
MediaStateChangeEvents.BREAKPOINTS_COMPUTED,
|
|
1754
|
+
this.render
|
|
1755
|
+
);
|
|
1745
1756
|
__privateMethod(this, _upgradeProperty, upgradeProperty_fn).call(this, "template");
|
|
1746
1757
|
}
|
|
1747
1758
|
/** @type {HTMLElement & { breakpointsComputed?: boolean }} */
|
|
@@ -1760,9 +1771,11 @@ var MediaThemeElement = class extends GlobalThis.HTMLElement {
|
|
|
1760
1771
|
get props() {
|
|
1761
1772
|
var _a2, _b2, _c;
|
|
1762
1773
|
const observedAttributes = [
|
|
1763
|
-
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
1764
|
-
|
|
1765
|
-
|
|
1774
|
+
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
1775
|
+
({ name }) => {
|
|
1776
|
+
return observedMediaAttributes[name] || name.startsWith("breakpoint");
|
|
1777
|
+
}
|
|
1778
|
+
),
|
|
1766
1779
|
...Array.from(this.attributes)
|
|
1767
1780
|
];
|
|
1768
1781
|
const props = {};
|
|
@@ -1864,7 +1877,9 @@ function isValidUrl(url) {
|
|
|
1864
1877
|
async function request(resource) {
|
|
1865
1878
|
const response = await fetch(resource);
|
|
1866
1879
|
if (response.status !== 200) {
|
|
1867
|
-
throw new Error(
|
|
1880
|
+
throw new Error(
|
|
1881
|
+
`Failed to load resource: the server responded with a status of ${response.status}`
|
|
1882
|
+
);
|
|
1868
1883
|
}
|
|
1869
1884
|
return response.text();
|
|
1870
1885
|
}
|
|
@@ -111,15 +111,27 @@ var gerwig_default = `<template id="media-theme-gerwig">
|
|
|
111
111
|
* 0.433s is the transition duration for VTT Regions.
|
|
112
112
|
* Borrowed here, so the captions don't move too fast.
|
|
113
113
|
*/
|
|
114
|
-
media-controller
|
|
114
|
+
media-controller {
|
|
115
115
|
--media-webkit-text-track-transform: translateY(0) scale(0.98);
|
|
116
116
|
--media-webkit-text-track-transition: transform 0.433s ease-out 0.3s;
|
|
117
117
|
}
|
|
118
|
-
media-controller:is([mediapaused], :not([userinactive]))
|
|
118
|
+
media-controller:is([mediapaused], :not([userinactive])) {
|
|
119
119
|
--media-webkit-text-track-transform: translateY(-50px) scale(0.98);
|
|
120
120
|
--media-webkit-text-track-transition: transform 0.15s ease;
|
|
121
121
|
}
|
|
122
122
|
|
|
123
|
+
/*
|
|
124
|
+
* CSS specific to iOS devices.
|
|
125
|
+
* See: https://stackoverflow.com/questions/30102792/css-media-query-to-target-only-ios-devices/60220757#60220757
|
|
126
|
+
*/
|
|
127
|
+
@supports (-webkit-touch-callout: none) {
|
|
128
|
+
/* Disable subtitle adjusting for iOS Safari */
|
|
129
|
+
media-controller[mediaisfullscreen] {
|
|
130
|
+
--media-webkit-text-track-transform: unset;
|
|
131
|
+
--media-webkit-text-track-transition: unset;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
123
135
|
media-time-range {
|
|
124
136
|
--media-box-padding-left: 6px;
|
|
125
137
|
--media-box-padding-right: 6px;
|
|
@@ -1235,7 +1247,6 @@ var documentShim = {
|
|
|
1235
1247
|
dispatchEvent(event) {
|
|
1236
1248
|
return false;
|
|
1237
1249
|
}
|
|
1238
|
-
// eslint-disable-line no-unused-vars
|
|
1239
1250
|
};
|
|
1240
1251
|
var globalThisShim2 = {
|
|
1241
1252
|
ResizeObserver,
|
|
@@ -1257,11 +1268,10 @@ var globalThisShim2 = {
|
|
|
1257
1268
|
/**
|
|
1258
1269
|
* @param {string} key
|
|
1259
1270
|
* @returns {string|null}
|
|
1260
|
-
|
|
1271
|
+
*/
|
|
1261
1272
|
getItem(key) {
|
|
1262
1273
|
return null;
|
|
1263
1274
|
},
|
|
1264
|
-
// eslint-disable-line no-unused-vars
|
|
1265
1275
|
/**
|
|
1266
1276
|
* @param {string} key
|
|
1267
1277
|
* @param {string} value
|
|
@@ -1271,7 +1281,7 @@ var globalThisShim2 = {
|
|
|
1271
1281
|
// eslint-disable-line no-unused-vars
|
|
1272
1282
|
/**
|
|
1273
1283
|
* @param {string} key
|
|
1274
|
-
|
|
1284
|
+
*/
|
|
1275
1285
|
removeItem(key) {
|
|
1276
1286
|
}
|
|
1277
1287
|
// eslint-disable-line no-unused-vars
|
|
@@ -1692,7 +1702,9 @@ var processor = {
|
|
|
1692
1702
|
for (const [expression, part] of parts) {
|
|
1693
1703
|
if (part instanceof InnerTemplatePart) {
|
|
1694
1704
|
if (!part.directive) {
|
|
1695
|
-
const directive = DirectiveNames.find(
|
|
1705
|
+
const directive = DirectiveNames.find(
|
|
1706
|
+
(n) => part.template.hasAttribute(n)
|
|
1707
|
+
);
|
|
1696
1708
|
if (directive) {
|
|
1697
1709
|
part.directive = directive;
|
|
1698
1710
|
part.expression = part.template.getAttribute(directive);
|
|
@@ -1705,11 +1717,7 @@ var processor = {
|
|
|
1705
1717
|
if (value instanceof PartialTemplate) {
|
|
1706
1718
|
if (templates.get(part) !== value.template) {
|
|
1707
1719
|
templates.set(part, value.template);
|
|
1708
|
-
value = new TemplateInstance(
|
|
1709
|
-
value.template,
|
|
1710
|
-
value.state,
|
|
1711
|
-
processor
|
|
1712
|
-
);
|
|
1720
|
+
value = new TemplateInstance(value.template, value.state, processor);
|
|
1713
1721
|
part.value = value;
|
|
1714
1722
|
templateInstances.set(part, value);
|
|
1715
1723
|
} else {
|
|
@@ -1987,7 +1995,10 @@ var MediaThemeElement = class extends GlobalThis.HTMLElement {
|
|
|
1987
1995
|
attributes: true,
|
|
1988
1996
|
subtree: true
|
|
1989
1997
|
});
|
|
1990
|
-
this.addEventListener(
|
|
1998
|
+
this.addEventListener(
|
|
1999
|
+
MediaStateChangeEvents.BREAKPOINTS_COMPUTED,
|
|
2000
|
+
this.render
|
|
2001
|
+
);
|
|
1991
2002
|
__privateMethod(this, _upgradeProperty, upgradeProperty_fn).call(this, "template");
|
|
1992
2003
|
}
|
|
1993
2004
|
/** @type {HTMLElement & { breakpointsComputed?: boolean }} */
|
|
@@ -2006,9 +2017,11 @@ var MediaThemeElement = class extends GlobalThis.HTMLElement {
|
|
|
2006
2017
|
get props() {
|
|
2007
2018
|
var _a2, _b2, _c;
|
|
2008
2019
|
const observedAttributes = [
|
|
2009
|
-
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
2010
|
-
|
|
2011
|
-
|
|
2020
|
+
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
2021
|
+
({ name }) => {
|
|
2022
|
+
return observedMediaAttributes[name] || name.startsWith("breakpoint");
|
|
2023
|
+
}
|
|
2024
|
+
),
|
|
2012
2025
|
...Array.from(this.attributes)
|
|
2013
2026
|
];
|
|
2014
2027
|
const props = {};
|
|
@@ -2110,7 +2123,9 @@ function isValidUrl(url) {
|
|
|
2110
2123
|
async function request(resource) {
|
|
2111
2124
|
const response = await fetch(resource);
|
|
2112
2125
|
if (response.status !== 200) {
|
|
2113
|
-
throw new Error(
|
|
2126
|
+
throw new Error(
|
|
2127
|
+
`Failed to load resource: the server responded with a status of ${response.status}`
|
|
2128
|
+
);
|
|
2114
2129
|
}
|
|
2115
2130
|
return response.text();
|
|
2116
2131
|
}
|
|
@@ -111,15 +111,27 @@ var mediaThemeGerwig = (() => {
|
|
|
111
111
|
* 0.433s is the transition duration for VTT Regions.
|
|
112
112
|
* Borrowed here, so the captions don't move too fast.
|
|
113
113
|
*/
|
|
114
|
-
media-controller
|
|
114
|
+
media-controller {
|
|
115
115
|
--media-webkit-text-track-transform: translateY(0) scale(0.98);
|
|
116
116
|
--media-webkit-text-track-transition: transform 0.433s ease-out 0.3s;
|
|
117
117
|
}
|
|
118
|
-
media-controller:is([mediapaused], :not([userinactive]))
|
|
118
|
+
media-controller:is([mediapaused], :not([userinactive])) {
|
|
119
119
|
--media-webkit-text-track-transform: translateY(-50px) scale(0.98);
|
|
120
120
|
--media-webkit-text-track-transition: transform 0.15s ease;
|
|
121
121
|
}
|
|
122
122
|
|
|
123
|
+
/*
|
|
124
|
+
* CSS specific to iOS devices.
|
|
125
|
+
* See: https://stackoverflow.com/questions/30102792/css-media-query-to-target-only-ios-devices/60220757#60220757
|
|
126
|
+
*/
|
|
127
|
+
@supports (-webkit-touch-callout: none) {
|
|
128
|
+
/* Disable subtitle adjusting for iOS Safari */
|
|
129
|
+
media-controller[mediaisfullscreen] {
|
|
130
|
+
--media-webkit-text-track-transform: unset;
|
|
131
|
+
--media-webkit-text-track-transition: unset;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
123
135
|
media-time-range {
|
|
124
136
|
--media-box-padding-left: 6px;
|
|
125
137
|
--media-box-padding-right: 6px;
|
|
@@ -1235,7 +1247,6 @@ var mediaThemeGerwig = (() => {
|
|
|
1235
1247
|
dispatchEvent(event) {
|
|
1236
1248
|
return false;
|
|
1237
1249
|
}
|
|
1238
|
-
// eslint-disable-line no-unused-vars
|
|
1239
1250
|
};
|
|
1240
1251
|
var globalThisShim2 = {
|
|
1241
1252
|
ResizeObserver,
|
|
@@ -1257,11 +1268,10 @@ var mediaThemeGerwig = (() => {
|
|
|
1257
1268
|
/**
|
|
1258
1269
|
* @param {string} key
|
|
1259
1270
|
* @returns {string|null}
|
|
1260
|
-
|
|
1271
|
+
*/
|
|
1261
1272
|
getItem(key) {
|
|
1262
1273
|
return null;
|
|
1263
1274
|
},
|
|
1264
|
-
// eslint-disable-line no-unused-vars
|
|
1265
1275
|
/**
|
|
1266
1276
|
* @param {string} key
|
|
1267
1277
|
* @param {string} value
|
|
@@ -1271,7 +1281,7 @@ var mediaThemeGerwig = (() => {
|
|
|
1271
1281
|
// eslint-disable-line no-unused-vars
|
|
1272
1282
|
/**
|
|
1273
1283
|
* @param {string} key
|
|
1274
|
-
|
|
1284
|
+
*/
|
|
1275
1285
|
removeItem(key) {
|
|
1276
1286
|
}
|
|
1277
1287
|
// eslint-disable-line no-unused-vars
|
|
@@ -1692,7 +1702,9 @@ var mediaThemeGerwig = (() => {
|
|
|
1692
1702
|
for (const [expression, part] of parts) {
|
|
1693
1703
|
if (part instanceof InnerTemplatePart) {
|
|
1694
1704
|
if (!part.directive) {
|
|
1695
|
-
const directive = DirectiveNames.find(
|
|
1705
|
+
const directive = DirectiveNames.find(
|
|
1706
|
+
(n) => part.template.hasAttribute(n)
|
|
1707
|
+
);
|
|
1696
1708
|
if (directive) {
|
|
1697
1709
|
part.directive = directive;
|
|
1698
1710
|
part.expression = part.template.getAttribute(directive);
|
|
@@ -1705,11 +1717,7 @@ var mediaThemeGerwig = (() => {
|
|
|
1705
1717
|
if (value instanceof PartialTemplate) {
|
|
1706
1718
|
if (templates.get(part) !== value.template) {
|
|
1707
1719
|
templates.set(part, value.template);
|
|
1708
|
-
value = new TemplateInstance(
|
|
1709
|
-
value.template,
|
|
1710
|
-
value.state,
|
|
1711
|
-
processor
|
|
1712
|
-
);
|
|
1720
|
+
value = new TemplateInstance(value.template, value.state, processor);
|
|
1713
1721
|
part.value = value;
|
|
1714
1722
|
templateInstances.set(part, value);
|
|
1715
1723
|
} else {
|
|
@@ -1987,7 +1995,10 @@ var mediaThemeGerwig = (() => {
|
|
|
1987
1995
|
attributes: true,
|
|
1988
1996
|
subtree: true
|
|
1989
1997
|
});
|
|
1990
|
-
this.addEventListener(
|
|
1998
|
+
this.addEventListener(
|
|
1999
|
+
MediaStateChangeEvents.BREAKPOINTS_COMPUTED,
|
|
2000
|
+
this.render
|
|
2001
|
+
);
|
|
1991
2002
|
__privateMethod(this, _upgradeProperty, upgradeProperty_fn).call(this, "template");
|
|
1992
2003
|
}
|
|
1993
2004
|
/** @type {HTMLElement & { breakpointsComputed?: boolean }} */
|
|
@@ -2006,9 +2017,11 @@ var mediaThemeGerwig = (() => {
|
|
|
2006
2017
|
get props() {
|
|
2007
2018
|
var _a2, _b2, _c;
|
|
2008
2019
|
const observedAttributes = [
|
|
2009
|
-
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
2010
|
-
|
|
2011
|
-
|
|
2020
|
+
...Array.from((_b2 = (_a2 = this.mediaController) == null ? void 0 : _a2.attributes) != null ? _b2 : []).filter(
|
|
2021
|
+
({ name }) => {
|
|
2022
|
+
return observedMediaAttributes[name] || name.startsWith("breakpoint");
|
|
2023
|
+
}
|
|
2024
|
+
),
|
|
2012
2025
|
...Array.from(this.attributes)
|
|
2013
2026
|
];
|
|
2014
2027
|
const props = {};
|
|
@@ -2110,7 +2123,9 @@ var mediaThemeGerwig = (() => {
|
|
|
2110
2123
|
async function request(resource) {
|
|
2111
2124
|
const response = await fetch(resource);
|
|
2112
2125
|
if (response.status !== 200) {
|
|
2113
|
-
throw new Error(
|
|
2126
|
+
throw new Error(
|
|
2127
|
+
`Failed to load resource: the server responded with a status of ${response.status}`
|
|
2128
|
+
);
|
|
2114
2129
|
}
|
|
2115
2130
|
return response.text();
|
|
2116
2131
|
}
|