@kkcompany/player 2.25.0-canary.0 → 2.25.0-canary.2
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/CHANGELOG.md +15 -7
- package/dist/core.mjs +14 -14
- package/dist/index.js +439 -431
- package/dist/index.mjs +335 -326
- package/dist/modules.mjs +11 -10
- package/dist/react.mjs +150 -141
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -3143,15 +3143,15 @@ function getDevice() {
|
|
|
3143
3143
|
if (device.type === undefined && osName === 'Android') device.type = 'tablet';
|
|
3144
3144
|
return device;
|
|
3145
3145
|
}
|
|
3146
|
+
|
|
3147
|
+
const isSafari = () => /^((?!chrome|android|X11|Linux).)*(safari|iPad|iPhone|Version)/i.test(navigator.userAgent);
|
|
3148
|
+
|
|
3146
3149
|
function needNativeHls() {
|
|
3147
3150
|
// Don't let Android phones play HLS, even if some of them report supported
|
|
3148
3151
|
// This covers Samsung & OPPO special cases
|
|
3149
|
-
const isAndroid = /android|X11|Linux/i.test(navigator.userAgent);
|
|
3150
|
-
|
|
3151
|
-
|
|
3152
|
-
// none of our supported browsers other than Safari response to this
|
|
3153
|
-
|
|
3154
|
-
return isAndroid || /firefox/i.test(navigator.userAgent) ? '' : isSafari ? 'maybe' : document.createElement('video').canPlayType('application/vnd.apple.mpegURL');
|
|
3152
|
+
const isAndroid = /android|X11|Linux/i.test(navigator.userAgent);
|
|
3153
|
+
return isAndroid || /firefox/i.test(navigator.userAgent) ? '' : // canPlayType isn't reliable across all iOS verion / device combinations, so also check user agent
|
|
3154
|
+
isSafari() ? 'maybe' : document.createElement('video').canPlayType('application/vnd.apple.mpegURL');
|
|
3155
3155
|
}
|
|
3156
3156
|
|
|
3157
3157
|
const isDesktop = () => !getDevice().type; // TODO solve lint error:
|
|
@@ -3206,7 +3206,6 @@ const retryRequest = function (url) {
|
|
|
3206
3206
|
};function ownKeys$s(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
3207
3207
|
|
|
3208
3208
|
function _objectSpread$s(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$s(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$s(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
3209
|
-
|
|
3210
3209
|
const protocolExtensions = {
|
|
3211
3210
|
hls: 'm3u8',
|
|
3212
3211
|
dash: 'mpd'
|
|
@@ -3244,7 +3243,7 @@ const getDrmOptions$1 = fallbackDrm => {
|
|
|
3244
3243
|
* @typedef {{hls: string, dash: string}} SourceObjectAlt backward compatiable form
|
|
3245
3244
|
*
|
|
3246
3245
|
* @param {SourceObject[]|SourceObject|SourceObjectAlt|string} sourceOptions
|
|
3247
|
-
* @param {{preferManifestType?: ('dash'|'hls')}} options
|
|
3246
|
+
* @param {{preferManifestType?: ('dash'|'hls'|'platform')}} options
|
|
3248
3247
|
* @return {{src: string, type: string, drm: Object}}
|
|
3249
3248
|
*/
|
|
3250
3249
|
|
|
@@ -3289,7 +3288,8 @@ const getSource = function (sourceOptions) {
|
|
|
3289
3288
|
});
|
|
3290
3289
|
}
|
|
3291
3290
|
|
|
3292
|
-
const
|
|
3291
|
+
const targetType = preferManifestType !== 'platform' ? preferManifestType : isSafari() ? 'hls' : 'dash';
|
|
3292
|
+
const matched = sourceOptions.find(source => matchType(source, targetType));
|
|
3293
3293
|
const selected = matched || sourceOptions[0];
|
|
3294
3294
|
|
|
3295
3295
|
if (!selected) {
|
|
@@ -7242,7 +7242,7 @@ $$2({ target: 'Array', proto: true, forced: FORCED }, {
|
|
|
7242
7242
|
function getVersion() {
|
|
7243
7243
|
try {
|
|
7244
7244
|
// eslint-disable-next-line no-undef
|
|
7245
|
-
return "2.25.0-canary.
|
|
7245
|
+
return "2.25.0-canary.2";
|
|
7246
7246
|
} catch (e) {
|
|
7247
7247
|
return undefined;
|
|
7248
7248
|
}
|
|
@@ -7553,9 +7553,8 @@ const load = async (media, _ref4, source) => {
|
|
|
7553
7553
|
startTime,
|
|
7554
7554
|
plugins = []
|
|
7555
7555
|
} = _ref4;
|
|
7556
|
-
const preferManifestType = needNativeHls() ? 'hls' : 'dash';
|
|
7557
7556
|
const preferred = getSource(source, {
|
|
7558
|
-
preferManifestType
|
|
7557
|
+
preferManifestType: 'platform'
|
|
7559
7558
|
}); // There's no use case that changing DRM options without changing manifest URL, just skip
|
|
7560
7559
|
|
|
7561
7560
|
if (player.lastSrc === (preferred === null || preferred === void 0 ? void 0 : preferred.src)) {
|
|
@@ -7575,7 +7574,7 @@ const load = async (media, _ref4, source) => {
|
|
|
7575
7574
|
player,
|
|
7576
7575
|
source: currentSource,
|
|
7577
7576
|
startTime,
|
|
7578
|
-
streamFormat:
|
|
7577
|
+
streamFormat: source.type,
|
|
7579
7578
|
reload: async () => {
|
|
7580
7579
|
// Bitmovin unexpectedly restores muted state, so save to restore
|
|
7581
7580
|
const restoreMuted = player.isMuted && {
|
|
@@ -7784,27 +7783,28 @@ const setPlaybackRate = (media, _ref8, rate) => {
|
|
|
7784
7783
|
};
|
|
7785
7784
|
|
|
7786
7785
|
const getTextTracks = (_, _ref9) => {
|
|
7787
|
-
var _player$
|
|
7786
|
+
var _player$getTextTracks;
|
|
7788
7787
|
|
|
7789
7788
|
let {
|
|
7790
7789
|
player
|
|
7791
7790
|
} = _ref9;
|
|
7792
7791
|
if (!player) return [];
|
|
7792
|
+
return (((_player$getTextTracks = player.getTextTracks) === null || _player$getTextTracks === void 0 ? void 0 : _player$getTextTracks.call(player)) || []).map(track => {
|
|
7793
|
+
var _track$label;
|
|
7793
7794
|
|
|
7794
|
-
|
|
7795
|
-
|
|
7796
|
-
|
|
7797
|
-
|
|
7798
|
-
|
|
7799
|
-
|
|
7800
|
-
|
|
7801
|
-
|
|
7802
|
-
|
|
7803
|
-
|
|
7804
|
-
|
|
7805
|
-
|
|
7806
|
-
|
|
7807
|
-
return (player === null || player === void 0 ? void 0 : (_player$getSubtitles = player.getSubtitles()) === null || _player$getSubtitles === void 0 ? void 0 : _player$getSubtitles.filter(track => !/un(d|k)/i.test(track.value || '') && track.label)) || [];
|
|
7795
|
+
const label = ((_track$label = track.label) === null || _track$label === void 0 ? void 0 : _track$label.trim()) || track.language;
|
|
7796
|
+
const id = "".concat(track.language, ":").concat(label);
|
|
7797
|
+
return _objectSpread$q(_objectSpread$q({}, track), {}, {
|
|
7798
|
+
label,
|
|
7799
|
+
type: 'subtitles',
|
|
7800
|
+
selected: player.isTextTrackVisible() ? track.active : false,
|
|
7801
|
+
value: {
|
|
7802
|
+
id,
|
|
7803
|
+
label,
|
|
7804
|
+
language: track.language
|
|
7805
|
+
}
|
|
7806
|
+
});
|
|
7807
|
+
}).filter(track => track.label !== 'unknown' && track.language && !/^un/i.test(track.language));
|
|
7808
7808
|
};
|
|
7809
7809
|
|
|
7810
7810
|
const getCurrentSubtitle = (_, _ref10) => {
|
|
@@ -7813,7 +7813,7 @@ const getCurrentSubtitle = (_, _ref10) => {
|
|
|
7813
7813
|
} = _ref10;
|
|
7814
7814
|
return getTextTracks({}, {
|
|
7815
7815
|
player
|
|
7816
|
-
}).find(track => track.
|
|
7816
|
+
}).find(track => track.selected) || 'off';
|
|
7817
7817
|
};
|
|
7818
7818
|
|
|
7819
7819
|
const textTrackLabel = 'playcraft-text-track';
|
|
@@ -7880,63 +7880,314 @@ const syncTextTrack = (media, _ref11, selected) => {
|
|
|
7880
7880
|
player.setTextTrackVisibility(false);
|
|
7881
7881
|
}
|
|
7882
7882
|
});
|
|
7883
|
-
};
|
|
7883
|
+
}; // assume unique labels as defined in spec
|
|
7884
7884
|
|
|
7885
|
-
|
|
7885
|
+
|
|
7886
|
+
const setAudioTrack = (_, _ref12, next) => {
|
|
7886
7887
|
let {
|
|
7887
7888
|
player
|
|
7888
7889
|
} = _ref12;
|
|
7890
|
+
if (!next) return;
|
|
7891
|
+
|
|
7892
|
+
try {
|
|
7893
|
+
player.selectAudioLanguage(next.language);
|
|
7894
|
+
|
|
7895
|
+
if (next.label) {
|
|
7896
|
+
player.selectVariantsByLabel(next.label);
|
|
7897
|
+
}
|
|
7898
|
+
} catch (error) {
|
|
7899
|
+
console.warn('Unable to set audio', error, next);
|
|
7900
|
+
}
|
|
7901
|
+
};function ownKeys$p(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
7902
|
+
|
|
7903
|
+
function _objectSpread$p(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$p(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$p(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
7904
|
+
|
|
7905
|
+
const getSpeedItems = items => items.map(value => ({
|
|
7906
|
+
label: "".concat(value, "x"),
|
|
7907
|
+
value
|
|
7908
|
+
}));
|
|
7909
|
+
|
|
7910
|
+
const getQualityOptions = _ref => {
|
|
7911
|
+
var _sections$find, _sections$find$items$;
|
|
7912
|
+
|
|
7913
|
+
let {
|
|
7914
|
+
sections,
|
|
7915
|
+
values: {
|
|
7916
|
+
quality
|
|
7917
|
+
}
|
|
7918
|
+
} = _ref;
|
|
7919
|
+
return (_sections$find = sections.find(item => item.name === 'quality')) === null || _sections$find === void 0 ? void 0 : (_sections$find$items$ = _sections$find.items.find(item => item.value === quality)) === null || _sections$find$items$ === void 0 ? void 0 : _sections$find$items$.options;
|
|
7920
|
+
};
|
|
7921
|
+
|
|
7922
|
+
const autoQualityOption = {
|
|
7923
|
+
label: "Auto",
|
|
7924
|
+
options: {
|
|
7925
|
+
maxHeight: Infinity,
|
|
7926
|
+
minHeight: 0
|
|
7927
|
+
},
|
|
7928
|
+
value: 'auto'
|
|
7929
|
+
};
|
|
7930
|
+
|
|
7931
|
+
const getQualityItemsFromManifest = player => {
|
|
7932
|
+
var _player$getAvailableV;
|
|
7933
|
+
|
|
7934
|
+
return [autoQualityOption].concat(((player === null || player === void 0 ? void 0 : (_player$getAvailableV = player.getAvailableVideoQualities) === null || _player$getAvailableV === void 0 ? void 0 : _player$getAvailableV.call(player)) || []).filter(q => q.height > 0).sort((a, b) => b.height - a.height).map(q => ({
|
|
7935
|
+
label: "".concat(q.height, "p"),
|
|
7936
|
+
// Set the min/max height to the same value to fix the quality.
|
|
7937
|
+
options: {
|
|
7938
|
+
maxHeight: q.height,
|
|
7939
|
+
minHeight: q.height
|
|
7940
|
+
},
|
|
7941
|
+
value: q.height
|
|
7942
|
+
})));
|
|
7943
|
+
};
|
|
7944
|
+
|
|
7945
|
+
const getQualitySettings = (options, player) => {
|
|
7946
|
+
// With native HLS, manifest rewrite is required to enable quality setting
|
|
7947
|
+
// TODO let this covered by test, maybe refactor?
|
|
7948
|
+
const items = isSafari() && !options.rewriteManifest ? [] : options.items || getQualityItemsFromManifest(player);
|
|
7949
|
+
|
|
7950
|
+
const getDefault = function () {
|
|
7951
|
+
let preferred = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : options.default || items[0].value;
|
|
7952
|
+
const maxHeight = preferred || items[0].value;
|
|
7953
|
+
return (nearest(items.filter(item => (item.height || item.value) <= maxHeight), item => (item.height || item.value) - maxHeight) || items[0]).value;
|
|
7954
|
+
};
|
|
7955
|
+
|
|
7956
|
+
return items.length > 0 && items[0] && {
|
|
7957
|
+
name: 'quality',
|
|
7958
|
+
title: 'KKS.QUALITY',
|
|
7959
|
+
items,
|
|
7960
|
+
getDefault
|
|
7961
|
+
};
|
|
7962
|
+
};
|
|
7963
|
+
|
|
7964
|
+
const getAudioTracks = (_, _ref2) => {
|
|
7965
|
+
let {
|
|
7966
|
+
player
|
|
7967
|
+
} = _ref2;
|
|
7889
7968
|
if (!player) return []; // Bitmovin support is omitted as it is not needed in near future
|
|
7890
7969
|
|
|
7891
7970
|
const all = player.getVariantTracks().reduce((result, track) => {
|
|
7892
|
-
var _track$
|
|
7971
|
+
var _track$label;
|
|
7893
7972
|
|
|
7894
|
-
const label = ((_track$
|
|
7973
|
+
const label = ((_track$label = track.label) === null || _track$label === void 0 ? void 0 : _track$label.trim()) || track.language;
|
|
7895
7974
|
const id = "".concat(track.language, ":").concat(label);
|
|
7896
|
-
result[id] = _objectSpread$
|
|
7897
|
-
|
|
7975
|
+
result[id] = result[id] || _objectSpread$p(_objectSpread$p({}, track), {}, {
|
|
7976
|
+
type: 'audio',
|
|
7898
7977
|
label,
|
|
7899
|
-
|
|
7978
|
+
value: {
|
|
7979
|
+
id,
|
|
7980
|
+
label,
|
|
7981
|
+
language: track.language
|
|
7982
|
+
}
|
|
7900
7983
|
});
|
|
7984
|
+
|
|
7985
|
+
if (track.active) {
|
|
7986
|
+
result[id].selected = true;
|
|
7987
|
+
}
|
|
7988
|
+
|
|
7901
7989
|
return result;
|
|
7902
7990
|
}, {});
|
|
7903
|
-
|
|
7991
|
+
const allTracks = Object.values(all);
|
|
7992
|
+
const namedTracks = allTracks.filter(track => !/^un/i.test(track.language || ''));
|
|
7993
|
+
return Object.values(namedTracks.length > 0 ? namedTracks : allTracks);
|
|
7904
7994
|
};
|
|
7905
7995
|
|
|
7906
|
-
const getCurrentAudioTrack = (media,
|
|
7996
|
+
const getCurrentAudioTrack = (media, _ref3) => {
|
|
7907
7997
|
let {
|
|
7908
7998
|
player
|
|
7909
|
-
} =
|
|
7999
|
+
} = _ref3;
|
|
7910
8000
|
return getAudioTracks(media, {
|
|
7911
8001
|
player
|
|
7912
|
-
}).find(track => track.
|
|
7913
|
-
};
|
|
8002
|
+
}).find(track => track.selected);
|
|
8003
|
+
};
|
|
8004
|
+
|
|
8005
|
+
const getSelectedAudioName = player => {
|
|
8006
|
+
const track = getCurrentAudioTrack({}, {
|
|
8007
|
+
player
|
|
8008
|
+
});
|
|
8009
|
+
/*
|
|
8010
|
+
Sometimes, HLS manifest doesn't describe the default audio track.
|
|
8011
|
+
Get current audio track information is undefined even though the player still has audio streaming.
|
|
8012
|
+
For this case, we select first audio track.
|
|
8013
|
+
More detail please refer to OTP-3450.
|
|
8014
|
+
*/
|
|
7914
8015
|
|
|
8016
|
+
const audioList = getAudioTracks({}, {
|
|
8017
|
+
player
|
|
8018
|
+
});
|
|
8019
|
+
const currentAudio = track !== undefined ? track : audioList === null || audioList === void 0 ? void 0 : audioList[0];
|
|
8020
|
+
return currentAudio && _objectSpread$p(_objectSpread$p({}, currentAudio), {}, {
|
|
8021
|
+
id: [currentAudio.language, currentAudio.label].join(':')
|
|
8022
|
+
});
|
|
8023
|
+
};
|
|
7915
8024
|
|
|
7916
|
-
const
|
|
8025
|
+
const getDefault = (section, _ref4) => {
|
|
7917
8026
|
let {
|
|
8027
|
+
preferred,
|
|
7918
8028
|
player
|
|
7919
|
-
} =
|
|
7920
|
-
if (!next) return;
|
|
8029
|
+
} = _ref4;
|
|
7921
8030
|
|
|
7922
|
-
|
|
7923
|
-
|
|
8031
|
+
if (typeof section.getDefault === 'function') {
|
|
8032
|
+
return section.getDefault(preferred);
|
|
8033
|
+
}
|
|
8034
|
+
|
|
8035
|
+
if (section.name === 'audio') {
|
|
8036
|
+
return preferred !== null && preferred !== void 0 ? preferred : getSelectedAudioName(player);
|
|
8037
|
+
}
|
|
8038
|
+
|
|
8039
|
+
if (section.name === 'subtitles') {
|
|
8040
|
+
var _ref5;
|
|
8041
|
+
|
|
8042
|
+
return ((_ref5 = section.items.find(track => {
|
|
8043
|
+
var _track$value, _track$value2;
|
|
8044
|
+
|
|
8045
|
+
return ((_track$value = track.value) === null || _track$value === void 0 ? void 0 : _track$value.label) === (preferred === null || preferred === void 0 ? void 0 : preferred.label) && ((_track$value2 = track.value) === null || _track$value2 === void 0 ? void 0 : _track$value2.language) === (preferred === null || preferred === void 0 ? void 0 : preferred.language);
|
|
8046
|
+
}) || section.items.find(track => {
|
|
8047
|
+
var _track$value3;
|
|
8048
|
+
|
|
8049
|
+
return ((_track$value3 = track.value) === null || _track$value3 === void 0 ? void 0 : _track$value3.language) === (preferred === null || preferred === void 0 ? void 0 : preferred.language);
|
|
8050
|
+
})) === null || _ref5 === void 0 ? void 0 : _ref5.value) || {
|
|
8051
|
+
language: 'off',
|
|
8052
|
+
id: 'off'
|
|
8053
|
+
};
|
|
8054
|
+
}
|
|
8055
|
+
|
|
8056
|
+
if (section.name === 'speed') {
|
|
8057
|
+
return preferred !== null && preferred !== void 0 ? preferred : 1;
|
|
8058
|
+
}
|
|
8059
|
+
};
|
|
8060
|
+
|
|
8061
|
+
const shouldProvideSettingSection = (_ref6, _ref7) => {
|
|
8062
|
+
let {
|
|
8063
|
+
name,
|
|
8064
|
+
items
|
|
8065
|
+
} = _ref6;
|
|
8066
|
+
let {
|
|
8067
|
+
player,
|
|
8068
|
+
loop
|
|
8069
|
+
} = _ref7;
|
|
8070
|
+
|
|
8071
|
+
if (name === 'loop') {
|
|
8072
|
+
return !(player !== null && player !== void 0 && player.isLive()) && loop !== 'disabled';
|
|
8073
|
+
}
|
|
8074
|
+
|
|
8075
|
+
if (name === 'speed') {
|
|
8076
|
+
return !(player !== null && player !== void 0 && player.isLive());
|
|
8077
|
+
}
|
|
8078
|
+
|
|
8079
|
+
if (name === 'subtitles' || name === 'audio') {
|
|
8080
|
+
return true;
|
|
8081
|
+
}
|
|
8082
|
+
|
|
8083
|
+
return (items === null || items === void 0 ? void 0 : items.length) > 1;
|
|
8084
|
+
};
|
|
8085
|
+
|
|
8086
|
+
const getSettingsData = _ref8 => {
|
|
8087
|
+
let {
|
|
8088
|
+
media,
|
|
8089
|
+
player,
|
|
8090
|
+
source = [],
|
|
8091
|
+
quality = {},
|
|
8092
|
+
speedItems = [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2],
|
|
8093
|
+
loop,
|
|
8094
|
+
preferred = {}
|
|
8095
|
+
} = _ref8;
|
|
8096
|
+
// TODO extract base player specific things
|
|
8097
|
+
const audioItems = getAudioTracks({}, {
|
|
8098
|
+
player
|
|
8099
|
+
});
|
|
8100
|
+
const selectedSource = getSource(source, {
|
|
8101
|
+
preferManifestType: 'platform'
|
|
8102
|
+
}) || {};
|
|
8103
|
+
const currentSpeedItems = getSpeedItems(speedItems);
|
|
8104
|
+
const sections = [].concat([quality && getQualitySettings(_objectSpread$p(_objectSpread$p({}, quality), {}, {
|
|
8105
|
+
items: selectedSource.qualityOptions
|
|
8106
|
+
}), player), {
|
|
8107
|
+
name: 'subtitles',
|
|
8108
|
+
title: 'KKS.SUBTITLES',
|
|
8109
|
+
items: [].concat(getTextTracks({}, {
|
|
7924
8110
|
player
|
|
8111
|
+
}), {
|
|
8112
|
+
label: 'OFF',
|
|
8113
|
+
value: {
|
|
8114
|
+
language: 'off',
|
|
8115
|
+
id: 'off'
|
|
8116
|
+
}
|
|
8117
|
+
})
|
|
8118
|
+
}, {
|
|
8119
|
+
name: 'audio',
|
|
8120
|
+
title: 'KKS.AUDIO',
|
|
8121
|
+
items: audioItems
|
|
8122
|
+
}, {
|
|
8123
|
+
name: 'speed',
|
|
8124
|
+
title: 'KKS.SETTING.SPEED',
|
|
8125
|
+
items: currentSpeedItems
|
|
8126
|
+
}, {
|
|
8127
|
+
type: 'switch',
|
|
8128
|
+
name: 'loop',
|
|
8129
|
+
title: 'KKS.SETTING.LOOP'
|
|
8130
|
+
}]).filter(section => shouldProvideSettingSection(section, {
|
|
8131
|
+
player,
|
|
8132
|
+
loop,
|
|
8133
|
+
quality
|
|
8134
|
+
}));
|
|
8135
|
+
const values = sections.reduce((result, section) => {
|
|
8136
|
+
// TODO take fallback option if preferred is not available
|
|
8137
|
+
// eslint-disable-next-line no-param-reassign
|
|
8138
|
+
result[section.name] = getDefault(section, {
|
|
8139
|
+
preferred: preferred[section.name],
|
|
8140
|
+
player,
|
|
8141
|
+
media
|
|
8142
|
+
}) || preferred[section.name];
|
|
8143
|
+
return result;
|
|
8144
|
+
}, // TODO forced subtitles?
|
|
8145
|
+
{
|
|
8146
|
+
audio: getSelectedAudioName(player),
|
|
8147
|
+
subtitles: 'off'
|
|
8148
|
+
});
|
|
8149
|
+
|
|
8150
|
+
if (!values.speed && (media === null || media === void 0 ? void 0 : media.playbackRate) > 0) {
|
|
8151
|
+
values.speed = media.playbackRate;
|
|
8152
|
+
}
|
|
8153
|
+
|
|
8154
|
+
if (typeof preferred.loop === 'boolean') {
|
|
8155
|
+
values.loop = preferred.loop;
|
|
8156
|
+
} else {
|
|
8157
|
+
values.loop = loop === 'disabled' ? false : Boolean(loop);
|
|
8158
|
+
dispatchCustomEvent(media, 'loopChange', {
|
|
8159
|
+
loop: values.loop
|
|
7925
8160
|
});
|
|
7926
|
-
|
|
8161
|
+
}
|
|
7927
8162
|
|
|
7928
|
-
|
|
7929
|
-
|
|
7930
|
-
|
|
8163
|
+
return {
|
|
8164
|
+
sections,
|
|
8165
|
+
values
|
|
8166
|
+
};
|
|
8167
|
+
};
|
|
7931
8168
|
|
|
7932
|
-
|
|
8169
|
+
const matchTracks = (tracks, info) => (info === null || info === void 0 ? void 0 : info.map(track => tracks.find(t => t.language === track.language && t.label === track.label)).filter(Boolean)) || tracks;
|
|
7933
8170
|
|
|
7934
|
-
|
|
7935
|
-
|
|
8171
|
+
const getLanguageOptions = (player, info) => {
|
|
8172
|
+
const audioTracks = player && getAudioTracks({}, {
|
|
8173
|
+
player
|
|
8174
|
+
});
|
|
8175
|
+
const textTracks = getTextTracks({}, {
|
|
8176
|
+
player
|
|
8177
|
+
});
|
|
8178
|
+
const textOptions = [].concat(textTracks, {
|
|
8179
|
+
type: 'subtitles',
|
|
8180
|
+
label: 'OFF',
|
|
8181
|
+
selected: !textTracks.some(track => track.selected),
|
|
8182
|
+
value: {
|
|
8183
|
+
language: 'off',
|
|
8184
|
+
id: 'off'
|
|
7936
8185
|
}
|
|
7937
|
-
}
|
|
7938
|
-
|
|
7939
|
-
|
|
8186
|
+
});
|
|
8187
|
+
return {
|
|
8188
|
+
audioTracks: matchTracks(audioTracks, info.audioTracks),
|
|
8189
|
+
textTracks: matchTracks(textOptions, info.textTracks)
|
|
8190
|
+
};
|
|
7940
8191
|
};const vendors = {
|
|
7941
8192
|
change: ['fullscreenchange', 'webkitfullscreenchange', 'MSFullscreenChange'],
|
|
7942
8193
|
element: ['fullscreenElement', 'webkitFullscreenElement', 'msFullscreenElement'],
|
|
@@ -11093,9 +11344,9 @@ function jsxs(type, props, key) {
|
|
|
11093
11344
|
return jsxRuntime.exports.jsxs(Emotion, createEmotionProps(type, props), key);
|
|
11094
11345
|
}const _excluded$f = ["type"];
|
|
11095
11346
|
|
|
11096
|
-
function ownKeys$
|
|
11347
|
+
function ownKeys$o(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
11097
11348
|
|
|
11098
|
-
function _objectSpread$
|
|
11349
|
+
function _objectSpread$o(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$o(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$o(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
11099
11350
|
|
|
11100
11351
|
const Icon = _ref => {
|
|
11101
11352
|
let {
|
|
@@ -11103,7 +11354,7 @@ const Icon = _ref => {
|
|
|
11103
11354
|
} = _ref,
|
|
11104
11355
|
others = _objectWithoutProperties(_ref, _excluded$f);
|
|
11105
11356
|
|
|
11106
|
-
return jsx("div", _objectSpread$
|
|
11357
|
+
return jsx("div", _objectSpread$o({
|
|
11107
11358
|
css: /*#__PURE__*/css({
|
|
11108
11359
|
width: '1.5em',
|
|
11109
11360
|
height: '1.5em',
|
|
@@ -11122,9 +11373,9 @@ Icon.propTypes = {
|
|
|
11122
11373
|
};
|
|
11123
11374
|
var Icon$1 = Icon;const _excluded$e = ["open", "style", "renderAt", "children", "onClick"];
|
|
11124
11375
|
|
|
11125
|
-
function ownKeys$
|
|
11376
|
+
function ownKeys$n(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
11126
11377
|
|
|
11127
|
-
function _objectSpread$
|
|
11378
|
+
function _objectSpread$n(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$n(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$n(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
11128
11379
|
|
|
11129
11380
|
/* eslint-disable jsx-a11y/no-static-element-interactions */
|
|
11130
11381
|
|
|
@@ -11165,7 +11416,7 @@ const Backdrop = _ref => {
|
|
|
11165
11416
|
} = _ref,
|
|
11166
11417
|
rest = _objectWithoutProperties(_ref, _excluded$e);
|
|
11167
11418
|
|
|
11168
|
-
return jsx("div", _objectSpread$
|
|
11419
|
+
return jsx("div", _objectSpread$n(_objectSpread$n({
|
|
11169
11420
|
css: [backdropStyle, open && backdropOpenStyle, style, "production" === "production" ? "" : ";label:Backdrop;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJhY2tkcm9wLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDSSIsImZpbGUiOiJCYWNrZHJvcC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuXG5jb25zdCBiYWNrZHJvcFN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAzLFxuICB0b3A6IDAsXG4gIGxlZnQ6IDAsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgZmxleFdyYXA6ICd3cmFwJyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIGFsaWduQ29udGVudDogJ2NlbnRlcicsXG4gIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHdpZHRoOiAnMTAwJScsXG4gIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMCwgMCwgMCwgMCknLFxuICBjb2xvcjogJ3doaXRlJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtMTAwJSknLFxuICB0cmFuc2l0aW9uOiAnYmFja2dyb3VuZC1jb2xvciAwLjVzIGVhc2UsIHRyYW5zZm9ybSAwcyAwLjVzJyxcbn1cblxuY29uc3QgYmFja2Ryb3BPcGVuU3R5bGUgPSB7XG4gIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMCwgMCwgMCwgMC42KScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICB0cmFuc2l0aW9uOiAnYmFja2dyb3VuZC1jb2xvciAwLjVzIGVhc2UnLFxuICAnfiAub3ZlcmxheS1iYWNrZHJvcCc6IHtcbiAgICBkaXNwbGF5OiAnbm9uZScsXG4gIH0sXG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9wcm9wLXR5cGVzXG5jb25zdCBCYWNrZHJvcCA9ICh7b3Blbiwgc3R5bGUsIHJlbmRlckF0LCBjaGlsZHJlbiwgb25DbGljaywgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W2JhY2tkcm9wU3R5bGUsIG9wZW4gJiYgYmFja2Ryb3BPcGVuU3R5bGUsIHN0eWxlXX1cbiAgICBjbGFzc05hbWU9XCJvdmVybGF5LWJhY2tkcm9wXCJcbiAgICBvbkNsaWNrPXtldmVudCA9PiB7XG4gICAgICBpZiAoZXZlbnQudGFyZ2V0ID09PSBldmVudC5jdXJyZW50VGFyZ2V0KSB7XG4gICAgICAgIG9uQ2xpY2s/LihldmVudClcbiAgICAgIH1cbiAgICB9fVxuICAgIHsuLi5yZXN0fVxuICA+XG4gICAgeyhyZW5kZXJBdCA9PT0gJ2Fsd2F5cycgfHwgb3BlbikgJiYgY2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5leHBvcnQgZGVmYXVsdCBCYWNrZHJvcFxuIl19 */"],
|
|
11170
11421
|
className: "overlay-backdrop",
|
|
11171
11422
|
onClick: event => {
|
|
@@ -11182,9 +11433,9 @@ const Backdrop = _ref => {
|
|
|
11182
11433
|
_excluded4 = ["startIcon", "title", "onClick"],
|
|
11183
11434
|
_excluded5 = ["checked"];
|
|
11184
11435
|
|
|
11185
|
-
function ownKeys$
|
|
11436
|
+
function ownKeys$m(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
11186
11437
|
|
|
11187
|
-
function _objectSpread$
|
|
11438
|
+
function _objectSpread$m(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$m(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$m(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
11188
11439
|
const styles$1 = {
|
|
11189
11440
|
// TODO keep only necessary
|
|
11190
11441
|
border: 'none',
|
|
@@ -11283,7 +11534,7 @@ const Tooltip = _ref => {
|
|
|
11283
11534
|
}, [open, position.left]);
|
|
11284
11535
|
return !title || !isDesktop() || !havePointer() ? children : jsxs(Fragment, {
|
|
11285
11536
|
children: [/*#__PURE__*/react.exports.cloneElement(children, childProps), open && /*#__PURE__*/reactDom.exports.createPortal(jsx("div", {
|
|
11286
|
-
style: _objectSpread$
|
|
11537
|
+
style: _objectSpread$m(_objectSpread$m(_objectSpread$m({}, tooltipStyle), position), {}, {
|
|
11287
11538
|
top: "calc(".concat(position.top, "px - ").concat(shiftDistance, ")")
|
|
11288
11539
|
}),
|
|
11289
11540
|
ref: tooltipRef,
|
|
@@ -11309,7 +11560,7 @@ const Button = _ref2 => {
|
|
|
11309
11560
|
title: title,
|
|
11310
11561
|
placement: placement,
|
|
11311
11562
|
disabled: rest.disabled,
|
|
11312
|
-
children: jsxs("button", _objectSpread$
|
|
11563
|
+
children: jsxs("button", _objectSpread$m(_objectSpread$m({
|
|
11313
11564
|
type: "button",
|
|
11314
11565
|
css: [styles$1, variants[variant], style, "production" === "production" ? "" : ";label:Button;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["buttons.js"],"names":[],"mappings":"AA8IM","file":"buttons.js","sourcesContent":["/* eslint-disable react/prop-types */\n/* @jsxImportSource @emotion/react */\nimport {useState, useEffect, useRef, cloneElement} from 'react'\nimport {createPortal} from 'react-dom'\nimport PropTypes from 'prop-types'\n\nimport {getPopoverPosition} from 'util/index'\nimport {getTopElement} from 'util/viewModes'\nimport {havePointer, isDesktop} from 'util/environment'\nimport {FormattedMessage, useIntl} from 'context/I18n'\nimport Icon from './Icon'\n\nconst styles = {\n  // TODO keep only necessary\n  border: 'none',\n  outline: 'none',\n  cursor: 'pointer',\n  padding: 0,\n  flexShrink: 0,\n  backgroundColor: 'transparent',\n  userSelect: 'none',\n  '> span': {\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst variants = {\n  outlined: {\n    width: '8em',\n    height: '2em',\n    border: '1px solid #fff',\n    borderRadius: '4px',\n    background: 'none',\n    color: 'inherit',\n    opacity: 0.8,\n  },\n  text: {color: 'var(--theme-color)'},\n  contained: {color: '#fff', backgroundColor: 'var(--theme-color)'},\n}\n\nconst tooltipStyle = {\n  zIndex: 7,\n  position: 'fixed',\n  padding: '0.5rem',\n  width: 'fit-content',\n  textAlign: 'center',\n  whiteSpace: 'nowrap',\n  color: 'white',\n  background: 'var(--panel-background, #161C24)',\n}\n\nconst isOverflowing = element => element.scrollWidth > element.clientWidth\n\nconst Tooltip = ({\n  title,\n  placement,\n  overflowOnly,\n  disabled,\n  children,\n  container,\n}) => {\n  const tooltipRef = useRef()\n  const boxes = useRef()\n  const defaultContainer = useRef()\n  const [open, setOpen] = useState(false)\n  const [position, setPosition] = useState(() => ({left: '100%'}))\n  const shiftDistance = placement === 'top' ? '-4.5em' : '2em'\n  const handleLeave = () => {\n    setPosition({left: '100%'})\n    setOpen(false)\n  }\n\n  const childProps = {\n    onMouseEnter: event => {\n      if (!overflowOnly || isOverflowing(event.currentTarget)) {\n        boxes.current = [\n          event.currentTarget.getBoundingClientRect(),\n          document.body.getBoundingClientRect(),\n        ]\n        defaultContainer.current = getTopElement()\n        setOpen(true)\n      }\n    },\n    onMouseLeave: handleLeave,\n    onTransitionEnd: event => {\n      if (window.getComputedStyle(event.target).getPropertyValue(\"opacity\") < 0.1) {\n        handleLeave()\n      } \n    }\n  }\n  useEffect(() => {\n    if (disabled) {\n      setOpen(false)\n    }\n  }, [disabled])\n\n  useEffect(() => {\n    if (open) {\n      const targetPosition = getPopoverPosition(\n        tooltipRef.current.getBoundingClientRect(),\n        ...boxes.current\n      )\n      targetPosition.left !== position.left && setPosition(targetPosition)\n    }\n  }, [open, position.left])\n\n  return !title || !isDesktop() || !havePointer() ? (\n    children\n  ) : (\n    <>\n      {cloneElement(children, childProps)}\n      {open &&\n        createPortal(\n          <div\n            style={{\n              ...tooltipStyle,\n              ...position,\n              top: `calc(${position.top}px - ${shiftDistance})`,\n            }}\n            ref={tooltipRef}\n          >\n            <FormattedMessage id={title} />\n          </div>,\n          container || defaultContainer.current\n        )}\n    </>\n  )\n}\n\nconst Button = ({\n  startIcon,\n  variant,\n  style,\n  title,\n  children,\n  placement = 'bottom',\n  ...rest\n}) => (\n  <Tooltip title={title} placement={placement} disabled={rest.disabled}>\n    <button\n      type=\"button\"\n      css={[styles, variants[variant], style]}\n      {...rest}\n    >\n      {typeof startIcon === 'string' ? <Icon type={startIcon} /> : startIcon}\n      {children}\n    </button>\n  </Tooltip>\n)\n\nButton.propTypes = {\n  startIcon: PropTypes.node,\n  children: PropTypes.node,\n}\n\nconst liveButtonStyle = {\n  '--spacing': 'calc(0.75em + 0.5rem)',\n  margin: '0 0.5rem',\n  height: '3em',\n  border: 'solid 1px',\n  borderRadius: '4px',\n  color: '#FFF',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '0.5em !important',\n  svg: {\n    marginRight: '0.5em',\n    width: '1.5em',\n    height: '1em',\n    color: '#E93817',\n  },\n}\n\nconst startOverStyle = {svg: {color: '#BDBDBD'}}\n\nconst LiveIcon = () => (\n  <svg\n    width=\"24\"\n    height=\"16\"\n    viewBox=\"0 0 24 16\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n  >\n    <path\n      fill=\"currentColor\"\n      d=\"M3.50071 0.00164345C3.20221 0.0180071 2.90947 0.156604 2.70384 0.408604C1.01511 2.47697 0 5.11508 0 7.98744C0 10.8598 1.01511 13.4979 2.70384 15.5663C3.1162 16.0703 3.87344 16.1161 4.33381 15.6558C4.72544 15.2641 4.76392 14.6388 4.41264 14.2112C3.01955 12.5148 2.18182 10.3471 2.18182 7.98744C2.18182 5.6278 3.01955 3.46112 4.41264 1.76585C4.76392 1.33821 4.72544 0.712882 4.33381 0.321246C4.10363 0.0910639 3.79921 -0.0147202 3.50071 0.00164345ZM20.4993 0.00164345C20.2008 -0.0147202 19.8964 0.0910639 19.6662 0.321246C19.2746 0.712882 19.2361 1.33821 19.5874 1.76585C20.9804 3.46112 21.8182 5.6278 21.8182 7.98744C21.8182 10.3471 20.9804 12.5138 19.5874 14.209C19.2361 14.6367 19.2746 15.262 19.6662 15.6536C20.1266 16.114 20.8849 16.0714 21.2962 15.5663C22.9849 13.499 24 10.8598 24 7.98744C24 5.11508 22.9849 2.47697 21.2962 0.408604C21.0905 0.156604 20.7978 0.0180071 20.4993 0.00164345ZM6.59233 3.10392C6.28974 3.12083 5.99652 3.26174 5.80398 3.52792C4.89852 4.78356 4.36364 6.32489 4.36364 7.98744C4.36364 9.64998 4.89852 11.1913 5.80398 12.447C6.18907 12.9793 6.97348 13.014 7.43821 12.5492L7.44247 12.545C7.82538 12.1621 7.85357 11.5678 7.54048 11.1259C6.9143 10.2379 6.54545 9.15471 6.54545 7.98744C6.54545 6.82017 6.9143 5.73694 7.54048 4.84894C7.85248 4.40604 7.82538 3.81282 7.44247 3.42991L7.43821 3.42565C7.20585 3.19329 6.89492 3.08701 6.59233 3.10392ZM17.4077 3.10392C17.1051 3.08701 16.7942 3.19329 16.5618 3.42565L16.5575 3.42991C16.1746 3.81282 16.1464 4.40713 16.4595 4.84894C17.0857 5.73694 17.4545 6.82017 17.4545 7.98744C17.4545 9.15471 17.0857 10.2379 16.4595 11.1259C16.1475 11.5688 16.1746 12.1621 16.5575 12.545L16.5618 12.5492C17.0265 13.014 17.812 12.9793 18.196 12.447C19.1026 11.1924 19.6364 9.64998 19.6364 7.98744C19.6364 6.32489 19.1015 4.78356 18.196 3.52792C18.0035 3.26174 17.7103 3.12083 17.4077 3.10392ZM12 4.71471C11.132 4.71471 10.2996 5.05952 9.68583 5.67327C9.07208 6.28703 8.72727 7.11946 8.72727 7.98744C8.72727 8.85542 9.07208 9.68785 9.68583 10.3016C10.2996 10.9154 11.132 11.2602 12 11.2602C12.868 11.2602 13.7004 10.9154 14.3142 10.3016C14.9279 9.68785 15.2727 8.85542 15.2727 7.98744C15.2727 7.11946 14.9279 6.28703 14.3142 5.67327C13.7004 5.05952 12.868 4.71471 12 4.71471Z\"\n    />\n  </svg>\n)\n\nconst LiveButton = ({usingStartOver, ...rest}) => (\n  <Button\n    css={[liveButtonStyle, usingStartOver && startOverStyle]}\n    startIcon={<LiveIcon />}\n    {...rest}\n  >\n    <FormattedMessage id=\"LIVE\" />\n  </Button>\n)\n\nconst PlayButton = ({\n  playbackState,\n  ended,\n  hidden,\n  variant,\n  onClick,\n  ...rest\n}) => (\n  <Button\n    style={hidden && {opacity: 0}}\n    className=\"play-button\"\n    startIcon={\n      variant ||\n      (ended ? 'replay' : playbackState === 'playing' ? 'pause' : 'play')\n    }\n    title={`KKS.PLAYER.${\n      ended ? 'REPLAY' : playbackState === 'playing' ? 'PAUSE' : 'PLAY'\n    }`}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nPlayButton.propTypes = {\n  ended: PropTypes.bool,\n  onClick: PropTypes.func,\n}\n\nconst ForwardButton = ({startIcon, title, onClick, ...rest}) => (\n  <Button\n    style={rest.disabled && {opacity: 0.2, display: 'block'}}\n    startIcon={startIcon}\n    title={title}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nForwardButton.propTypes = {\n  onClick: PropTypes.func,\n}\n\nconst FullscreenButton = ({viewMode, onClick}) => {\n  const icon = viewMode === 'fullscreen' ? 'exit-fullscreen' : 'fullscreen'\n  const text = useIntl().formatMessage(\n    viewMode === 'fullscreen'\n      ? 'KKS.PLAYER.FULLSCREEN.EXIT'\n      : 'KKS.PLAYER.FULLSCREEN'\n  )\n\n  return (\n    <Button\n      startIcon={icon}\n      title={text}\n      style={!isDesktop() && {order: 'var(--fullscreen-button-order, initial)'}}\n      onClick={onClick}\n    />\n  )\n}\n\nconst skipStyles = {\n  display: 'flex',\n  alignItems: 'center',\n  padding: '0.5rem',\n  border: '1px solid #fff',\n  color: '#fff',\n  background: 'rgba(0, 0, 0, 0.4)',\n  fontSize: '24px',\n  opacity: 0.8,\n  '&:disabled': {\n    opacity: 0.5,\n  },\n  '> div': {\n    marginLeft: '0.5rem',\n    width: '1.5rem',\n    height: '1.5rem',\n  },\n}\n\nconst SkipButton = ({waitTime, onClick}) => (\n  <button\n    type=\"button\"\n    css={skipStyles}\n    disabled={waitTime > 0}\n    onClick={onClick}\n  >\n    {waitTime > 0 ? (\n      <>\n        {Math.ceil(waitTime)} <FormattedMessage id=\"KKS.SSAI.SECONDS\" />\n      </>\n    ) : (\n      <FormattedMessage id=\"KKS.SSAI.SKIP.AD\" />\n    )}\n    <Icon type=\"nextEpisode\" />\n  </button>\n)\n\nconst ShareButton = ({title, onClick}) => (\n  <Button\n    startIcon=\"share\"\n    title=\"KKS.PLAYER.SHARE\"\n    onClick={async () => {\n      if (isDesktop()) {\n        // TODO: use customize UI\n        console.log('hi')\n        return\n      }\n\n      onClick()\n      if (navigator.share) {\n        try {\n          await navigator.share({\n            title,\n            url: window.location.href,\n          })\n        } catch (error) {\n          console.error(error)\n        }\n      }\n    }}\n  />\n)\n\nconst switchStyle = {\n  padding: '0 0.2rem',\n  width: '2.4rem',\n  height: '1.2rem',\n  display: 'flex',\n  alignItems: 'center',\n  background: '#555',\n  borderRadius: '1rem',\n  transition: 'background 0.5s ease-in-out',\n}\n\nconst checkedStyle = {\n  background: 'var(--theme-color, #0E78F4)',\n  '> div': {\n    transform: 'translateX(1rem)',\n  },\n}\n\nconst thumbStyle = {\n  width: '1rem',\n  height: '1rem',\n  display: 'flex',\n  background: '#F9FAFB',\n  borderRadius: '1rem',\n  transition: 'transform 0.2s ease-in-out',\n}\n\nconst Switch = ({checked, ...rest}) => (\n  <div css={[switchStyle, checked && checkedStyle]} {...rest}>\n    <div css={thumbStyle} />\n  </div>\n)\n\nconst Close = ({...rest}) => <Button startIcon=\"close\" {...rest} />\n\nconst btnStyle = {\n  width: '4em',\n  height: '2em',\n  borderRadius: '8px',\n}\n\nconst Copy = ({...rest}) => (\n  <Button style={btnStyle} {...rest}>\n    Copy\n  </Button>\n)\n\nexport {\n  Button,\n  PlayButton,\n  FullscreenButton,\n  SkipButton,\n  ShareButton,\n  ForwardButton,\n  LiveButton,\n  Switch,\n  Close,\n  Copy\n}\n"]} */"]
|
|
11315
11566
|
}, rest), {}, {
|
|
@@ -11366,7 +11617,7 @@ const LiveButton = _ref3 => {
|
|
|
11366
11617
|
} = _ref3,
|
|
11367
11618
|
rest = _objectWithoutProperties(_ref3, _excluded2$4);
|
|
11368
11619
|
|
|
11369
|
-
return jsx(Button, _objectSpread$
|
|
11620
|
+
return jsx(Button, _objectSpread$m(_objectSpread$m({
|
|
11370
11621
|
css: [liveButtonStyle, usingStartOver && startOverStyle, "production" === "production" ? "" : ";label:LiveButton;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["buttons.js"],"names":[],"mappings":"AAkMI","file":"buttons.js","sourcesContent":["/* eslint-disable react/prop-types */\n/* @jsxImportSource @emotion/react */\nimport {useState, useEffect, useRef, cloneElement} from 'react'\nimport {createPortal} from 'react-dom'\nimport PropTypes from 'prop-types'\n\nimport {getPopoverPosition} from 'util/index'\nimport {getTopElement} from 'util/viewModes'\nimport {havePointer, isDesktop} from 'util/environment'\nimport {FormattedMessage, useIntl} from 'context/I18n'\nimport Icon from './Icon'\n\nconst styles = {\n  // TODO keep only necessary\n  border: 'none',\n  outline: 'none',\n  cursor: 'pointer',\n  padding: 0,\n  flexShrink: 0,\n  backgroundColor: 'transparent',\n  userSelect: 'none',\n  '> span': {\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst variants = {\n  outlined: {\n    width: '8em',\n    height: '2em',\n    border: '1px solid #fff',\n    borderRadius: '4px',\n    background: 'none',\n    color: 'inherit',\n    opacity: 0.8,\n  },\n  text: {color: 'var(--theme-color)'},\n  contained: {color: '#fff', backgroundColor: 'var(--theme-color)'},\n}\n\nconst tooltipStyle = {\n  zIndex: 7,\n  position: 'fixed',\n  padding: '0.5rem',\n  width: 'fit-content',\n  textAlign: 'center',\n  whiteSpace: 'nowrap',\n  color: 'white',\n  background: 'var(--panel-background, #161C24)',\n}\n\nconst isOverflowing = element => element.scrollWidth > element.clientWidth\n\nconst Tooltip = ({\n  title,\n  placement,\n  overflowOnly,\n  disabled,\n  children,\n  container,\n}) => {\n  const tooltipRef = useRef()\n  const boxes = useRef()\n  const defaultContainer = useRef()\n  const [open, setOpen] = useState(false)\n  const [position, setPosition] = useState(() => ({left: '100%'}))\n  const shiftDistance = placement === 'top' ? '-4.5em' : '2em'\n  const handleLeave = () => {\n    setPosition({left: '100%'})\n    setOpen(false)\n  }\n\n  const childProps = {\n    onMouseEnter: event => {\n      if (!overflowOnly || isOverflowing(event.currentTarget)) {\n        boxes.current = [\n          event.currentTarget.getBoundingClientRect(),\n          document.body.getBoundingClientRect(),\n        ]\n        defaultContainer.current = getTopElement()\n        setOpen(true)\n      }\n    },\n    onMouseLeave: handleLeave,\n    onTransitionEnd: event => {\n      if (window.getComputedStyle(event.target).getPropertyValue(\"opacity\") < 0.1) {\n        handleLeave()\n      } \n    }\n  }\n  useEffect(() => {\n    if (disabled) {\n      setOpen(false)\n    }\n  }, [disabled])\n\n  useEffect(() => {\n    if (open) {\n      const targetPosition = getPopoverPosition(\n        tooltipRef.current.getBoundingClientRect(),\n        ...boxes.current\n      )\n      targetPosition.left !== position.left && setPosition(targetPosition)\n    }\n  }, [open, position.left])\n\n  return !title || !isDesktop() || !havePointer() ? (\n    children\n  ) : (\n    <>\n      {cloneElement(children, childProps)}\n      {open &&\n        createPortal(\n          <div\n            style={{\n              ...tooltipStyle,\n              ...position,\n              top: `calc(${position.top}px - ${shiftDistance})`,\n            }}\n            ref={tooltipRef}\n          >\n            <FormattedMessage id={title} />\n          </div>,\n          container || defaultContainer.current\n        )}\n    </>\n  )\n}\n\nconst Button = ({\n  startIcon,\n  variant,\n  style,\n  title,\n  children,\n  placement = 'bottom',\n  ...rest\n}) => (\n  <Tooltip title={title} placement={placement} disabled={rest.disabled}>\n    <button\n      type=\"button\"\n      css={[styles, variants[variant], style]}\n      {...rest}\n    >\n      {typeof startIcon === 'string' ? <Icon type={startIcon} /> : startIcon}\n      {children}\n    </button>\n  </Tooltip>\n)\n\nButton.propTypes = {\n  startIcon: PropTypes.node,\n  children: PropTypes.node,\n}\n\nconst liveButtonStyle = {\n  '--spacing': 'calc(0.75em + 0.5rem)',\n  margin: '0 0.5rem',\n  height: '3em',\n  border: 'solid 1px',\n  borderRadius: '4px',\n  color: '#FFF',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '0.5em !important',\n  svg: {\n    marginRight: '0.5em',\n    width: '1.5em',\n    height: '1em',\n    color: '#E93817',\n  },\n}\n\nconst startOverStyle = {svg: {color: '#BDBDBD'}}\n\nconst LiveIcon = () => (\n  <svg\n    width=\"24\"\n    height=\"16\"\n    viewBox=\"0 0 24 16\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n  >\n    <path\n      fill=\"currentColor\"\n      d=\"M3.50071 0.00164345C3.20221 0.0180071 2.90947 0.156604 2.70384 0.408604C1.01511 2.47697 0 5.11508 0 7.98744C0 10.8598 1.01511 13.4979 2.70384 15.5663C3.1162 16.0703 3.87344 16.1161 4.33381 15.6558C4.72544 15.2641 4.76392 14.6388 4.41264 14.2112C3.01955 12.5148 2.18182 10.3471 2.18182 7.98744C2.18182 5.6278 3.01955 3.46112 4.41264 1.76585C4.76392 1.33821 4.72544 0.712882 4.33381 0.321246C4.10363 0.0910639 3.79921 -0.0147202 3.50071 0.00164345ZM20.4993 0.00164345C20.2008 -0.0147202 19.8964 0.0910639 19.6662 0.321246C19.2746 0.712882 19.2361 1.33821 19.5874 1.76585C20.9804 3.46112 21.8182 5.6278 21.8182 7.98744C21.8182 10.3471 20.9804 12.5138 19.5874 14.209C19.2361 14.6367 19.2746 15.262 19.6662 15.6536C20.1266 16.114 20.8849 16.0714 21.2962 15.5663C22.9849 13.499 24 10.8598 24 7.98744C24 5.11508 22.9849 2.47697 21.2962 0.408604C21.0905 0.156604 20.7978 0.0180071 20.4993 0.00164345ZM6.59233 3.10392C6.28974 3.12083 5.99652 3.26174 5.80398 3.52792C4.89852 4.78356 4.36364 6.32489 4.36364 7.98744C4.36364 9.64998 4.89852 11.1913 5.80398 12.447C6.18907 12.9793 6.97348 13.014 7.43821 12.5492L7.44247 12.545C7.82538 12.1621 7.85357 11.5678 7.54048 11.1259C6.9143 10.2379 6.54545 9.15471 6.54545 7.98744C6.54545 6.82017 6.9143 5.73694 7.54048 4.84894C7.85248 4.40604 7.82538 3.81282 7.44247 3.42991L7.43821 3.42565C7.20585 3.19329 6.89492 3.08701 6.59233 3.10392ZM17.4077 3.10392C17.1051 3.08701 16.7942 3.19329 16.5618 3.42565L16.5575 3.42991C16.1746 3.81282 16.1464 4.40713 16.4595 4.84894C17.0857 5.73694 17.4545 6.82017 17.4545 7.98744C17.4545 9.15471 17.0857 10.2379 16.4595 11.1259C16.1475 11.5688 16.1746 12.1621 16.5575 12.545L16.5618 12.5492C17.0265 13.014 17.812 12.9793 18.196 12.447C19.1026 11.1924 19.6364 9.64998 19.6364 7.98744C19.6364 6.32489 19.1015 4.78356 18.196 3.52792C18.0035 3.26174 17.7103 3.12083 17.4077 3.10392ZM12 4.71471C11.132 4.71471 10.2996 5.05952 9.68583 5.67327C9.07208 6.28703 8.72727 7.11946 8.72727 7.98744C8.72727 8.85542 9.07208 9.68785 9.68583 10.3016C10.2996 10.9154 11.132 11.2602 12 11.2602C12.868 11.2602 13.7004 10.9154 14.3142 10.3016C14.9279 9.68785 15.2727 8.85542 15.2727 7.98744C15.2727 7.11946 14.9279 6.28703 14.3142 5.67327C13.7004 5.05952 12.868 4.71471 12 4.71471Z\"\n    />\n  </svg>\n)\n\nconst LiveButton = ({usingStartOver, ...rest}) => (\n  <Button\n    css={[liveButtonStyle, usingStartOver && startOverStyle]}\n    startIcon={<LiveIcon />}\n    {...rest}\n  >\n    <FormattedMessage id=\"LIVE\" />\n  </Button>\n)\n\nconst PlayButton = ({\n  playbackState,\n  ended,\n  hidden,\n  variant,\n  onClick,\n  ...rest\n}) => (\n  <Button\n    style={hidden && {opacity: 0}}\n    className=\"play-button\"\n    startIcon={\n      variant ||\n      (ended ? 'replay' : playbackState === 'playing' ? 'pause' : 'play')\n    }\n    title={`KKS.PLAYER.${\n      ended ? 'REPLAY' : playbackState === 'playing' ? 'PAUSE' : 'PLAY'\n    }`}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nPlayButton.propTypes = {\n  ended: PropTypes.bool,\n  onClick: PropTypes.func,\n}\n\nconst ForwardButton = ({startIcon, title, onClick, ...rest}) => (\n  <Button\n    style={rest.disabled && {opacity: 0.2, display: 'block'}}\n    startIcon={startIcon}\n    title={title}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nForwardButton.propTypes = {\n  onClick: PropTypes.func,\n}\n\nconst FullscreenButton = ({viewMode, onClick}) => {\n  const icon = viewMode === 'fullscreen' ? 'exit-fullscreen' : 'fullscreen'\n  const text = useIntl().formatMessage(\n    viewMode === 'fullscreen'\n      ? 'KKS.PLAYER.FULLSCREEN.EXIT'\n      : 'KKS.PLAYER.FULLSCREEN'\n  )\n\n  return (\n    <Button\n      startIcon={icon}\n      title={text}\n      style={!isDesktop() && {order: 'var(--fullscreen-button-order, initial)'}}\n      onClick={onClick}\n    />\n  )\n}\n\nconst skipStyles = {\n  display: 'flex',\n  alignItems: 'center',\n  padding: '0.5rem',\n  border: '1px solid #fff',\n  color: '#fff',\n  background: 'rgba(0, 0, 0, 0.4)',\n  fontSize: '24px',\n  opacity: 0.8,\n  '&:disabled': {\n    opacity: 0.5,\n  },\n  '> div': {\n    marginLeft: '0.5rem',\n    width: '1.5rem',\n    height: '1.5rem',\n  },\n}\n\nconst SkipButton = ({waitTime, onClick}) => (\n  <button\n    type=\"button\"\n    css={skipStyles}\n    disabled={waitTime > 0}\n    onClick={onClick}\n  >\n    {waitTime > 0 ? (\n      <>\n        {Math.ceil(waitTime)} <FormattedMessage id=\"KKS.SSAI.SECONDS\" />\n      </>\n    ) : (\n      <FormattedMessage id=\"KKS.SSAI.SKIP.AD\" />\n    )}\n    <Icon type=\"nextEpisode\" />\n  </button>\n)\n\nconst ShareButton = ({title, onClick}) => (\n  <Button\n    startIcon=\"share\"\n    title=\"KKS.PLAYER.SHARE\"\n    onClick={async () => {\n      if (isDesktop()) {\n        // TODO: use customize UI\n        console.log('hi')\n        return\n      }\n\n      onClick()\n      if (navigator.share) {\n        try {\n          await navigator.share({\n            title,\n            url: window.location.href,\n          })\n        } catch (error) {\n          console.error(error)\n        }\n      }\n    }}\n  />\n)\n\nconst switchStyle = {\n  padding: '0 0.2rem',\n  width: '2.4rem',\n  height: '1.2rem',\n  display: 'flex',\n  alignItems: 'center',\n  background: '#555',\n  borderRadius: '1rem',\n  transition: 'background 0.5s ease-in-out',\n}\n\nconst checkedStyle = {\n  background: 'var(--theme-color, #0E78F4)',\n  '> div': {\n    transform: 'translateX(1rem)',\n  },\n}\n\nconst thumbStyle = {\n  width: '1rem',\n  height: '1rem',\n  display: 'flex',\n  background: '#F9FAFB',\n  borderRadius: '1rem',\n  transition: 'transform 0.2s ease-in-out',\n}\n\nconst Switch = ({checked, ...rest}) => (\n  <div css={[switchStyle, checked && checkedStyle]} {...rest}>\n    <div css={thumbStyle} />\n  </div>\n)\n\nconst Close = ({...rest}) => <Button startIcon=\"close\" {...rest} />\n\nconst btnStyle = {\n  width: '4em',\n  height: '2em',\n  borderRadius: '8px',\n}\n\nconst Copy = ({...rest}) => (\n  <Button style={btnStyle} {...rest}>\n    Copy\n  </Button>\n)\n\nexport {\n  Button,\n  PlayButton,\n  FullscreenButton,\n  SkipButton,\n  ShareButton,\n  ForwardButton,\n  LiveButton,\n  Switch,\n  Close,\n  Copy\n}\n"]} */"],
|
|
11371
11622
|
startIcon: jsx(LiveIcon, {})
|
|
11372
11623
|
}, rest), {}, {
|
|
@@ -11386,7 +11637,7 @@ const PlayButton = _ref4 => {
|
|
|
11386
11637
|
} = _ref4,
|
|
11387
11638
|
rest = _objectWithoutProperties(_ref4, _excluded3);
|
|
11388
11639
|
|
|
11389
|
-
return jsx(Button, _objectSpread$
|
|
11640
|
+
return jsx(Button, _objectSpread$m({
|
|
11390
11641
|
style: hidden && {
|
|
11391
11642
|
opacity: 0
|
|
11392
11643
|
},
|
|
@@ -11410,7 +11661,7 @@ const ForwardButton = _ref5 => {
|
|
|
11410
11661
|
} = _ref5,
|
|
11411
11662
|
rest = _objectWithoutProperties(_ref5, _excluded4);
|
|
11412
11663
|
|
|
11413
|
-
return jsx(Button, _objectSpread$
|
|
11664
|
+
return jsx(Button, _objectSpread$m({
|
|
11414
11665
|
style: rest.disabled && {
|
|
11415
11666
|
opacity: 0.2,
|
|
11416
11667
|
display: 'block'
|
|
@@ -11473,16 +11724,16 @@ const Switch = _ref9 => {
|
|
|
11473
11724
|
} = _ref9,
|
|
11474
11725
|
rest = _objectWithoutProperties(_ref9, _excluded5);
|
|
11475
11726
|
|
|
11476
|
-
return jsx("div", _objectSpread$
|
|
11727
|
+
return jsx("div", _objectSpread$m(_objectSpread$m({
|
|
11477
11728
|
css: [switchStyle, checked && checkedStyle, "production" === "production" ? "" : ";label:Switch;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["buttons.js"],"names":[],"mappings":"AAiWO","file":"buttons.js","sourcesContent":["/* eslint-disable react/prop-types */\n/* @jsxImportSource @emotion/react */\nimport {useState, useEffect, useRef, cloneElement} from 'react'\nimport {createPortal} from 'react-dom'\nimport PropTypes from 'prop-types'\n\nimport {getPopoverPosition} from 'util/index'\nimport {getTopElement} from 'util/viewModes'\nimport {havePointer, isDesktop} from 'util/environment'\nimport {FormattedMessage, useIntl} from 'context/I18n'\nimport Icon from './Icon'\n\nconst styles = {\n  // TODO keep only necessary\n  border: 'none',\n  outline: 'none',\n  cursor: 'pointer',\n  padding: 0,\n  flexShrink: 0,\n  backgroundColor: 'transparent',\n  userSelect: 'none',\n  '> span': {\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst variants = {\n  outlined: {\n    width: '8em',\n    height: '2em',\n    border: '1px solid #fff',\n    borderRadius: '4px',\n    background: 'none',\n    color: 'inherit',\n    opacity: 0.8,\n  },\n  text: {color: 'var(--theme-color)'},\n  contained: {color: '#fff', backgroundColor: 'var(--theme-color)'},\n}\n\nconst tooltipStyle = {\n  zIndex: 7,\n  position: 'fixed',\n  padding: '0.5rem',\n  width: 'fit-content',\n  textAlign: 'center',\n  whiteSpace: 'nowrap',\n  color: 'white',\n  background: 'var(--panel-background, #161C24)',\n}\n\nconst isOverflowing = element => element.scrollWidth > element.clientWidth\n\nconst Tooltip = ({\n  title,\n  placement,\n  overflowOnly,\n  disabled,\n  children,\n  container,\n}) => {\n  const tooltipRef = useRef()\n  const boxes = useRef()\n  const defaultContainer = useRef()\n  const [open, setOpen] = useState(false)\n  const [position, setPosition] = useState(() => ({left: '100%'}))\n  const shiftDistance = placement === 'top' ? '-4.5em' : '2em'\n  const handleLeave = () => {\n    setPosition({left: '100%'})\n    setOpen(false)\n  }\n\n  const childProps = {\n    onMouseEnter: event => {\n      if (!overflowOnly || isOverflowing(event.currentTarget)) {\n        boxes.current = [\n          event.currentTarget.getBoundingClientRect(),\n          document.body.getBoundingClientRect(),\n        ]\n        defaultContainer.current = getTopElement()\n        setOpen(true)\n      }\n    },\n    onMouseLeave: handleLeave,\n    onTransitionEnd: event => {\n      if (window.getComputedStyle(event.target).getPropertyValue(\"opacity\") < 0.1) {\n        handleLeave()\n      } \n    }\n  }\n  useEffect(() => {\n    if (disabled) {\n      setOpen(false)\n    }\n  }, [disabled])\n\n  useEffect(() => {\n    if (open) {\n      const targetPosition = getPopoverPosition(\n        tooltipRef.current.getBoundingClientRect(),\n        ...boxes.current\n      )\n      targetPosition.left !== position.left && setPosition(targetPosition)\n    }\n  }, [open, position.left])\n\n  return !title || !isDesktop() || !havePointer() ? (\n    children\n  ) : (\n    <>\n      {cloneElement(children, childProps)}\n      {open &&\n        createPortal(\n          <div\n            style={{\n              ...tooltipStyle,\n              ...position,\n              top: `calc(${position.top}px - ${shiftDistance})`,\n            }}\n            ref={tooltipRef}\n          >\n            <FormattedMessage id={title} />\n          </div>,\n          container || defaultContainer.current\n        )}\n    </>\n  )\n}\n\nconst Button = ({\n  startIcon,\n  variant,\n  style,\n  title,\n  children,\n  placement = 'bottom',\n  ...rest\n}) => (\n  <Tooltip title={title} placement={placement} disabled={rest.disabled}>\n    <button\n      type=\"button\"\n      css={[styles, variants[variant], style]}\n      {...rest}\n    >\n      {typeof startIcon === 'string' ? <Icon type={startIcon} /> : startIcon}\n      {children}\n    </button>\n  </Tooltip>\n)\n\nButton.propTypes = {\n  startIcon: PropTypes.node,\n  children: PropTypes.node,\n}\n\nconst liveButtonStyle = {\n  '--spacing': 'calc(0.75em + 0.5rem)',\n  margin: '0 0.5rem',\n  height: '3em',\n  border: 'solid 1px',\n  borderRadius: '4px',\n  color: '#FFF',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '0.5em !important',\n  svg: {\n    marginRight: '0.5em',\n    width: '1.5em',\n    height: '1em',\n    color: '#E93817',\n  },\n}\n\nconst startOverStyle = {svg: {color: '#BDBDBD'}}\n\nconst LiveIcon = () => (\n  <svg\n    width=\"24\"\n    height=\"16\"\n    viewBox=\"0 0 24 16\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n  >\n    <path\n      fill=\"currentColor\"\n      d=\"M3.50071 0.00164345C3.20221 0.0180071 2.90947 0.156604 2.70384 0.408604C1.01511 2.47697 0 5.11508 0 7.98744C0 10.8598 1.01511 13.4979 2.70384 15.5663C3.1162 16.0703 3.87344 16.1161 4.33381 15.6558C4.72544 15.2641 4.76392 14.6388 4.41264 14.2112C3.01955 12.5148 2.18182 10.3471 2.18182 7.98744C2.18182 5.6278 3.01955 3.46112 4.41264 1.76585C4.76392 1.33821 4.72544 0.712882 4.33381 0.321246C4.10363 0.0910639 3.79921 -0.0147202 3.50071 0.00164345ZM20.4993 0.00164345C20.2008 -0.0147202 19.8964 0.0910639 19.6662 0.321246C19.2746 0.712882 19.2361 1.33821 19.5874 1.76585C20.9804 3.46112 21.8182 5.6278 21.8182 7.98744C21.8182 10.3471 20.9804 12.5138 19.5874 14.209C19.2361 14.6367 19.2746 15.262 19.6662 15.6536C20.1266 16.114 20.8849 16.0714 21.2962 15.5663C22.9849 13.499 24 10.8598 24 7.98744C24 5.11508 22.9849 2.47697 21.2962 0.408604C21.0905 0.156604 20.7978 0.0180071 20.4993 0.00164345ZM6.59233 3.10392C6.28974 3.12083 5.99652 3.26174 5.80398 3.52792C4.89852 4.78356 4.36364 6.32489 4.36364 7.98744C4.36364 9.64998 4.89852 11.1913 5.80398 12.447C6.18907 12.9793 6.97348 13.014 7.43821 12.5492L7.44247 12.545C7.82538 12.1621 7.85357 11.5678 7.54048 11.1259C6.9143 10.2379 6.54545 9.15471 6.54545 7.98744C6.54545 6.82017 6.9143 5.73694 7.54048 4.84894C7.85248 4.40604 7.82538 3.81282 7.44247 3.42991L7.43821 3.42565C7.20585 3.19329 6.89492 3.08701 6.59233 3.10392ZM17.4077 3.10392C17.1051 3.08701 16.7942 3.19329 16.5618 3.42565L16.5575 3.42991C16.1746 3.81282 16.1464 4.40713 16.4595 4.84894C17.0857 5.73694 17.4545 6.82017 17.4545 7.98744C17.4545 9.15471 17.0857 10.2379 16.4595 11.1259C16.1475 11.5688 16.1746 12.1621 16.5575 12.545L16.5618 12.5492C17.0265 13.014 17.812 12.9793 18.196 12.447C19.1026 11.1924 19.6364 9.64998 19.6364 7.98744C19.6364 6.32489 19.1015 4.78356 18.196 3.52792C18.0035 3.26174 17.7103 3.12083 17.4077 3.10392ZM12 4.71471C11.132 4.71471 10.2996 5.05952 9.68583 5.67327C9.07208 6.28703 8.72727 7.11946 8.72727 7.98744C8.72727 8.85542 9.07208 9.68785 9.68583 10.3016C10.2996 10.9154 11.132 11.2602 12 11.2602C12.868 11.2602 13.7004 10.9154 14.3142 10.3016C14.9279 9.68785 15.2727 8.85542 15.2727 7.98744C15.2727 7.11946 14.9279 6.28703 14.3142 5.67327C13.7004 5.05952 12.868 4.71471 12 4.71471Z\"\n    />\n  </svg>\n)\n\nconst LiveButton = ({usingStartOver, ...rest}) => (\n  <Button\n    css={[liveButtonStyle, usingStartOver && startOverStyle]}\n    startIcon={<LiveIcon />}\n    {...rest}\n  >\n    <FormattedMessage id=\"LIVE\" />\n  </Button>\n)\n\nconst PlayButton = ({\n  playbackState,\n  ended,\n  hidden,\n  variant,\n  onClick,\n  ...rest\n}) => (\n  <Button\n    style={hidden && {opacity: 0}}\n    className=\"play-button\"\n    startIcon={\n      variant ||\n      (ended ? 'replay' : playbackState === 'playing' ? 'pause' : 'play')\n    }\n    title={`KKS.PLAYER.${\n      ended ? 'REPLAY' : playbackState === 'playing' ? 'PAUSE' : 'PLAY'\n    }`}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nPlayButton.propTypes = {\n  ended: PropTypes.bool,\n  onClick: PropTypes.func,\n}\n\nconst ForwardButton = ({startIcon, title, onClick, ...rest}) => (\n  <Button\n    style={rest.disabled && {opacity: 0.2, display: 'block'}}\n    startIcon={startIcon}\n    title={title}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nForwardButton.propTypes = {\n  onClick: PropTypes.func,\n}\n\nconst FullscreenButton = ({viewMode, onClick}) => {\n  const icon = viewMode === 'fullscreen' ? 'exit-fullscreen' : 'fullscreen'\n  const text = useIntl().formatMessage(\n    viewMode === 'fullscreen'\n      ? 'KKS.PLAYER.FULLSCREEN.EXIT'\n      : 'KKS.PLAYER.FULLSCREEN'\n  )\n\n  return (\n    <Button\n      startIcon={icon}\n      title={text}\n      style={!isDesktop() && {order: 'var(--fullscreen-button-order, initial)'}}\n      onClick={onClick}\n    />\n  )\n}\n\nconst skipStyles = {\n  display: 'flex',\n  alignItems: 'center',\n  padding: '0.5rem',\n  border: '1px solid #fff',\n  color: '#fff',\n  background: 'rgba(0, 0, 0, 0.4)',\n  fontSize: '24px',\n  opacity: 0.8,\n  '&:disabled': {\n    opacity: 0.5,\n  },\n  '> div': {\n    marginLeft: '0.5rem',\n    width: '1.5rem',\n    height: '1.5rem',\n  },\n}\n\nconst SkipButton = ({waitTime, onClick}) => (\n  <button\n    type=\"button\"\n    css={skipStyles}\n    disabled={waitTime > 0}\n    onClick={onClick}\n  >\n    {waitTime > 0 ? (\n      <>\n        {Math.ceil(waitTime)} <FormattedMessage id=\"KKS.SSAI.SECONDS\" />\n      </>\n    ) : (\n      <FormattedMessage id=\"KKS.SSAI.SKIP.AD\" />\n    )}\n    <Icon type=\"nextEpisode\" />\n  </button>\n)\n\nconst ShareButton = ({title, onClick}) => (\n  <Button\n    startIcon=\"share\"\n    title=\"KKS.PLAYER.SHARE\"\n    onClick={async () => {\n      if (isDesktop()) {\n        // TODO: use customize UI\n        console.log('hi')\n        return\n      }\n\n      onClick()\n      if (navigator.share) {\n        try {\n          await navigator.share({\n            title,\n            url: window.location.href,\n          })\n        } catch (error) {\n          console.error(error)\n        }\n      }\n    }}\n  />\n)\n\nconst switchStyle = {\n  padding: '0 0.2rem',\n  width: '2.4rem',\n  height: '1.2rem',\n  display: 'flex',\n  alignItems: 'center',\n  background: '#555',\n  borderRadius: '1rem',\n  transition: 'background 0.5s ease-in-out',\n}\n\nconst checkedStyle = {\n  background: 'var(--theme-color, #0E78F4)',\n  '> div': {\n    transform: 'translateX(1rem)',\n  },\n}\n\nconst thumbStyle = {\n  width: '1rem',\n  height: '1rem',\n  display: 'flex',\n  background: '#F9FAFB',\n  borderRadius: '1rem',\n  transition: 'transform 0.2s ease-in-out',\n}\n\nconst Switch = ({checked, ...rest}) => (\n  <div css={[switchStyle, checked && checkedStyle]} {...rest}>\n    <div css={thumbStyle} />\n  </div>\n)\n\nconst Close = ({...rest}) => <Button startIcon=\"close\" {...rest} />\n\nconst btnStyle = {\n  width: '4em',\n  height: '2em',\n  borderRadius: '8px',\n}\n\nconst Copy = ({...rest}) => (\n  <Button style={btnStyle} {...rest}>\n    Copy\n  </Button>\n)\n\nexport {\n  Button,\n  PlayButton,\n  FullscreenButton,\n  SkipButton,\n  ShareButton,\n  ForwardButton,\n  LiveButton,\n  Switch,\n  Close,\n  Copy\n}\n"]} */"]
|
|
11478
11729
|
}, rest), {}, {
|
|
11479
11730
|
children: jsx("div", {
|
|
11480
11731
|
css: thumbStyle$1
|
|
11481
11732
|
})
|
|
11482
11733
|
}));
|
|
11483
|
-
};function ownKeys$
|
|
11734
|
+
};function ownKeys$l(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
11484
11735
|
|
|
11485
|
-
function _objectSpread$
|
|
11736
|
+
function _objectSpread$l(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$l(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$l(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
11486
11737
|
const iconStyle$1 = {
|
|
11487
11738
|
width: '78px',
|
|
11488
11739
|
height: '78px'
|
|
@@ -11505,7 +11756,7 @@ const Error$1 = _ref => {
|
|
|
11505
11756
|
} = _ref;
|
|
11506
11757
|
const intl = useIntl();
|
|
11507
11758
|
|
|
11508
|
-
const values = _objectSpread$
|
|
11759
|
+
const values = _objectSpread$l({
|
|
11509
11760
|
CODE: error.code || 0,
|
|
11510
11761
|
code: error.code || 0
|
|
11511
11762
|
}, error.data);
|
|
@@ -11604,9 +11855,9 @@ const bottomUiTop = container => {
|
|
|
11604
11855
|
|
|
11605
11856
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
11606
11857
|
|
|
11607
|
-
function ownKeys$
|
|
11858
|
+
function ownKeys$k(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
11608
11859
|
|
|
11609
|
-
function _objectSpread$
|
|
11860
|
+
function _objectSpread$k(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$k(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$k(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
11610
11861
|
const hidden = {
|
|
11611
11862
|
display: 'none'
|
|
11612
11863
|
};
|
|
@@ -11708,13 +11959,13 @@ const displayStyles = {
|
|
|
11708
11959
|
}
|
|
11709
11960
|
};
|
|
11710
11961
|
const controlsDisplayStyles = {
|
|
11711
|
-
hidden: _objectSpread$
|
|
11962
|
+
hidden: _objectSpread$k(_objectSpread$k({}, displayStyles.hidden), {}, {
|
|
11712
11963
|
'~ div:not(.pinned)': displayStyles.hidden
|
|
11713
11964
|
}),
|
|
11714
11965
|
'seekbar-only': {
|
|
11715
11966
|
'> div:first-of-type ~ *': displayStyles.hidden
|
|
11716
11967
|
},
|
|
11717
|
-
shown: _objectSpread$
|
|
11968
|
+
shown: _objectSpread$k(_objectSpread$k({}, displayStyles.shown), {}, {
|
|
11718
11969
|
'~ div': displayStyles.shown
|
|
11719
11970
|
})
|
|
11720
11971
|
}; // TODO: transform into sample object instead of function
|
|
@@ -11785,7 +12036,7 @@ const infoStyle = {
|
|
|
11785
12036
|
},
|
|
11786
12037
|
'> div': textEllipsis
|
|
11787
12038
|
},
|
|
11788
|
-
h1: _objectSpread$
|
|
12039
|
+
h1: _objectSpread$k(_objectSpread$k({
|
|
11789
12040
|
margin: 0,
|
|
11790
12041
|
fontSize: '1.66em',
|
|
11791
12042
|
fontWeight: '500'
|
|
@@ -11928,7 +12179,7 @@ const DefaultLayout = _ref2 => {
|
|
|
11928
12179
|
rest = _objectWithoutProperties(_ref2, _excluded$c);
|
|
11929
12180
|
|
|
11930
12181
|
const slotRef = react.exports.useRef({});
|
|
11931
|
-
return jsxs("div", _objectSpread$
|
|
12182
|
+
return jsxs("div", _objectSpread$k(_objectSpread$k({
|
|
11932
12183
|
style: {
|
|
11933
12184
|
'--player-bottom-ui-top': controlsDisplay === 'shown' ? "-".concat(bottomUiTop(containerRef.current), "px") : '-8px',
|
|
11934
12185
|
'--player-bottom-ui-height': type === 'desktop' && controlsDisplay === 'shown' ? '3.5rem' : '0'
|
|
@@ -11974,7 +12225,7 @@ const DefaultLayout = _ref2 => {
|
|
|
11974
12225
|
}, "production" === "production" ? "" : ";label:DefaultLayout;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DefaultLayout.js"],"names":[],"mappings":"AAqZQ","file":"DefaultLayout.js","sourcesContent":["/* eslint-disable no-param-reassign */\n/* @jsxImportSource @emotion/react */\n/* eslint-disable react/prop-types */\nimport {useRef} from 'react'\nimport {SlotProvider} from './uiExtensions'\nimport {nativeTextStyle, customTextStyle, bottomUiTop} from './subtitles'\n\nconst hidden = {display: 'none'}\nconst invisible = hiddenArea => ({\n  visibility: `var(${hiddenArea}, visible)`,\n})\nconst containerStyle = {\n  '--spacing': '0.5em',\n  '--center-pointer-events': 'auto',\n  width: '100%',\n  height: '100%',\n  fontSize: '16px',\n  boxSizing: 'border-box',\n  display: 'flex',\n  flexDirection: 'column',\n  overflow: 'hidden',\n  color: 'white',\n  background: '#000',\n  // prevent animation glich(afterimage) of descendant elements\n  transform: 'translateX(0)',\n  userSelect: 'none',\n  'a, a:link, a:visited': {\n    color: '#fff',\n    opacity: 0.8,\n    textDecoration: 'none',\n  },\n  button: {\n    fontSize: 'inherit',\n    '> *': {\n      pointerEvents: 'none',\n    },\n  },\n  '--thumbnail-width': '160', // height 90\n  '--theme-color': 'var(--primary-highlight, red)',\n}\n\nconst videoContainerStyle = {\n  '> div:first-of-type': {\n    position: 'absolute',\n    zIndex: '-1',\n    display: 'flex',\n    alignItems: 'center',\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst drop = {\n  backgroundImage: `linear-gradient(\n    0deg,\n    rgba(0,0,0,0.5) 0,\n    rgba(0,0,0,0) var(--player-ui-drop-shadow-size, 30%) calc(100% - var(--player-ui-drop-shadow-size, 30%)),\n    rgba(0,0,0,0.5) 100%\n  )`,\n  backgroundColor: `rgba(0, 0, 0, 0.3)`,\n}\n\nconst dropTop = {\n  backgroundImage: `linear-gradient(\n    0deg,\n    rgba(0,0,0,0) 0,\n    rgba(0,0,0,0) 8rem calc(100% - 8rem),\n    rgba(0,0,0,0.5) 100%\n  )`,\n}\n\nconst responsiveStyles = {\n  desktop: {\n    fontSize: '24px',\n  }, // add if necessary: big-desktop\n}\n\nconst rowStyle = {\n  boxSizing: 'border-box',\n  width: '100%',\n  padding: '1em',\n  display: 'flex',\n  alignItems: 'center',\n  '> button, > div > button': {\n    padding: '0.5rem',\n  },\n}\n\n/* \n  Hint:\n    displayStyles specificity is higher then controlsStyle\n    Need to pay attention when we revise these styles.\n*/\n\nconst displayHidden = {\n  '> div:not(.pinned), > button:not(.pinned), > img:not(.pinned)': {\n    opacity: 0,\n    transform: 'translate(-200vw, 0)',\n    transition: 'opacity 0.8s var(--autohide-delay, 0s) ease-out, transform 0s calc(0.8s + var(--autohide-delay, 0s))',\n    'button': {\n      opacity: 0, // extra transition to hide tooltip for Safari\n      transition: 'opacity 0s calc(0.8s + var(--autohide-delay, 0s)) ease-out',\n    }\n  },\n}\n\nconst displayStyles = {\n  hidden: displayHidden,\n  'seekbar-only': displayHidden,\n  shown: {\n    '> div:not(.pinned), > button:not(.pinned), > img:not(.pinned)': {\n      zIndex: 1,\n      pointerEvents: 'auto',\n      transition: 'opacity 0.3s ease-out, transform 0s 0s',\n    },\n  },\n}\n\nconst controlsDisplayStyles = {\n  hidden: {\n    ...displayStyles.hidden,\n    '~ div:not(.pinned)': displayStyles.hidden,\n  },\n  'seekbar-only': {\n    '> div:first-of-type ~ *': displayStyles.hidden,\n  },\n  shown: {\n    ...displayStyles.shown,\n    '~ div': displayStyles.shown,\n  },\n}\n\n// TODO: transform into sample object instead of function\nconst controlsStyle = type => ({\n  position: 'absolute',\n  zIndex: '2',\n  width: '100%',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '1.5em',\n  '> button': {\n    padding: '0.75em 0.5em',\n    '&:disabled': {\n      opacity: 0,\n      pointerEvents: 'none',\n    },\n    '&.play-button': {\n      padding: '0.75rem 0.5rem',\n      fontSize: 'var(--play-button-size, 1em)',\n    },\n    '&.firstplay-button':\n      type === 'mobile'\n        ? {fontSize: '200%', padding: '4em 10em', marginBottom: '1em'}\n        : {fontSize: '400%'},\n  },\n})\n\n// Remove the height for imporving tapping effect at current, and this height was used for fixed region before.\nconst infoBarSlotStyle = {\n  display: 'flex',\n  order: -1,\n  alignItems: 'center',\n  flex: '1 60%',\n}\n\nconst desktopInfoBarStyle = {\n  marginLeft: 'var(--spacing, 0.5em)',\n  order: 'initial',\n  flex: '1 0%',\n}\n\nconst textEllipsis = {\n  overflow: 'hidden',\n  whiteSpace: 'nowrap',\n  textOverflow: 'ellipsis',\n}\n\nconst infoStyle = {\n  zIndex: 1,\n  overflow: 'visible',\n  pointerEvents: 'none',\n  padding: '0 calc(2em - 20px)',\n  marginBottom: 'calc(0.5em + var(--bottom-spacing, 0))',\n  flex: '3em 0',\n  '> div:first-of-type, > div:nth-of-type(2), > button': {\n    minWidth: 0,\n  },\n  '> div:nth-of-type(2)': {\n    // title and channel title\n    margin: '0 calc(var(--spacing, 0.5em) / 2)',\n    flex: 1,\n    fontSize: '0.75em',\n    visibility: 'var(--player-title-visibility, visible)',\n    span: {\n      marginRight: 'var(--spacing, 0.5em)',\n    },\n    '> div': textEllipsis,\n  },\n  h1: {\n    margin: 0,\n    fontSize: '1.66em',\n    fontWeight: '500',\n    ...textEllipsis,\n    flex: 1,\n    '&:not(:only-child)': {\n      marginTop: '0.5em',\n    },\n  },\n  img: {\n    display: 'block',\n    width: '2em',\n    height: '2em',\n    borderRadius: '0.25em',\n    objectFit: 'cover',\n  },\n}\n\nconst backStyle = {\n  position: 'absolute',\n  zIndex: 0,\n  width: '100%',\n  height: '100%',\n  // move DAI UI slightly up to avoid stacking\n  paddingBottom: 'calc(var(--spacing) * 4)',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  '> iframe': {pointerEvents: 'auto'},\n}\n\nconst skipStyle = {\n  position: 'absolute',\n  right: 0,\n  bottom: '9rem',\n  textAlign: 'right',\n  button: {\n    width: 'auto',\n    height: 'auto',\n  },\n}\n\nconst desktopStyle = {\n  '--spacing': '0.75em',\n  '--center-pointer-events': 'none',\n  '> div button': {\n    margin: '0 calc(var(--spacing, 0.75em) - 0.5em)',\n  },\n  '--thumbnail-width': '288', // height 162\n}\n\nconst desktopControls = {\n  '> div:first-of-type': {\n    flex: '100%',\n    marginBottom: '0.4em',\n  },\n  '> button': {\n    '&[disabled]': {\n    display: 'none',\n    },\n    '&.play-button': {\n      fontSize: '1em',\n    },\n    '&.firstplay-button': {\n      fontSize: '400%'\n    },\n  },\n}\n\nconst seekbarStyles = {\n  flex: '1 var(--seekbar-flex-basis, 100%)',\n  '&:not(:empty)': {\n    margin: '0 calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)',\n  },\n}\n\nconst adContainerStyle = {\n  flexGrow: 1,\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  pointerEvents: 'var(--center-pointer-events)',\n  button: {pointerEvents: 'auto'},\n  zIndex: 0,\n}\n\nconst ControlsBlock = ({\n  order = 'mobile',\n  liveButton,\n  playButton,\n  rewindButton = '',\n  forwardButton = '',\n  previousEpisodeButton = '',\n  nextEpisodeButton = '',\n}) =>\n  order === 'desktop' ? (\n    <>\n      {liveButton}\n      {previousEpisodeButton}\n      {playButton}\n      {nextEpisodeButton}\n      {rewindButton}\n      {forwardButton}\n    </>\n  ) : (\n    <>\n      {rewindButton}\n      {previousEpisodeButton}\n      {playButton}\n      {nextEpisodeButton}\n      {forwardButton}\n    </>\n  )\n\nconst DefaultLayout = ({\n  type = 'mobile',\n  style,\n  display,\n  liveButton,\n  controlsDisplay = display,\n  size,\n  title = '',\n  channelTitle = '',\n  video,\n  haveBottomItem,\n  seekbar = '',\n  displayTime,\n  controlButtons,\n  volumeControl,\n  fullscreenButton,\n  backButton = '',\n  adStatus = '',\n  adLink = '',\n  adSkipButton,\n  backItems,\n  children,\n  containerRef,\n  backRef,\n  adContainerRef,\n  ...rest\n}) => {\n  const slotRef = useRef({})\n\n  return (\n    <div\n      style={{\n        '--player-bottom-ui-top':\n          controlsDisplay === 'shown'\n            ? `-${bottomUiTop(containerRef.current)}px`\n            : '-8px',\n        '--player-bottom-ui-height':\n          type === 'desktop' && controlsDisplay === 'shown' ? '3.5rem' : '0',\n      }}\n      css={[\n        containerStyle,\n        videoContainerStyle,\n        responsiveStyles[size],\n        type === 'desktop' && desktopStyle,\n        adStatus && {'--bottom-spacing': 0},\n        nativeTextStyle,\n        customTextStyle,\n        style,\n      ]}\n      ref={containerRef}\n      {...rest}\n    >\n      {video}\n      <div\n        ref={backRef}\n        css={[\n          backStyle,\n          display !== 'hidden' && (haveBottomItem ? dropTop : drop),\n          invisible('--controller-middle-area'),\n        ]}\n      >\n        {type !== 'mobile' && backItems}\n        {adSkipButton && <div css={skipStyle}>{adSkipButton}</div>}\n      </div>\n      <div\n        css={[\n          rowStyle,\n          infoStyle,\n          displayStyles[display],\n          invisible('--controller-top-area'),\n        ]}\n      >\n        {backButton}\n        <div\n          ref={element => {\n            slotRef.current.titleBarLeft = element\n          }}\n        />\n        <div>\n          <h1>{title}</h1>\n          {channelTitle && <div>{channelTitle}</div>}\n        </div>\n        <div\n          ref={element => {\n            slotRef.current.titleBarRight = element\n          }}\n        />\n        {adLink && <div className=\"pinned\">{adLink}</div>}\n      </div>\n      <div\n        ref={adContainerRef}\n        css={[\n          adContainerStyle,\n          // this container covers Google DAI iframe UI, left some space for user to click \"skip ad\"\n          // see https://kkvideo.atlassian.net/browse/CPT-4535 for detail\n          adStatus && {margin: 'calc(var(--spacing) * 6) 0'},\n        ]}\n      >\n        {type === 'mobile' && (\n          <div\n            css={[\n              controlsStyle(type),\n              displayStyles[controlsDisplay],\n              invisible('--controller-middle-area'),\n            ]}\n          >\n            <ControlsBlock order=\"mobile\" {...controlButtons} />\n          </div>\n        )}\n      </div>\n      <div\n        css={[\n          rowStyle,\n          {\n            marginTop: '1em',\n            paddingTop: 0,\n            paddingBottom: 'calc(1em - var(--bottom-spacing, 0) / 5)',\n            flexWrap: 'wrap',\n            '> div:first-of-type': seekbarStyles,\n          },\n          type === 'desktop' && desktopControls,\n          controlsDisplayStyles[controlsDisplay],\n          invisible('--controller-down-area'),\n        ]}\n      >\n        {seekbar || <div />}\n        {type === 'desktop' && (\n          <ControlsBlock\n            order=\"desktop\"\n            liveButton={liveButton}\n            {...controlButtons}\n          />\n        )}\n        {type === 'desktop' ? (\n          <div css={[displayStyles[controlsDisplay]]}>{displayTime}</div>\n        ) : (\n          <>\n            {liveButton}\n            <div\n              css={{\n                '&:not(:empty)': {\n                  flex: 1,\n                  marginLeft: 'calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)',\n                },\n              }}\n            >\n              {displayTime}\n            </div>\n          </>\n        )}\n        {adStatus && (\n          <div\n            className=\"pinned\"\n            css={[infoBarSlotStyle, type === 'desktop' && desktopInfoBarStyle]}\n          >\n            {adStatus}\n          </div>\n        )}\n        <div\n          css={\n            !adStatus && [\n              infoBarSlotStyle,\n              type === 'desktop' && desktopInfoBarStyle,\n            ]\n          }\n          ref={element => {\n            slotRef.current.infoBar = element\n          }}\n        />\n        {volumeControl}\n        <div\n          css={adStatus && hidden}\n          ref={element => {\n            slotRef.current.functionBar = element\n          }}\n        />\n        {fullscreenButton}\n      </div>\n      <SlotProvider slotRef={slotRef}>{children}</SlotProvider>\n    </div>\n  )\n}\n\nexport default DefaultLayout\n"]} */"],
|
|
11975
12226
|
children: type === 'mobile' && jsx("div", {
|
|
11976
12227
|
css: [controlsStyle(type), displayStyles[controlsDisplay], invisible('--controller-middle-area'), "production" === "production" ? "" : ";label:DefaultLayout;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DefaultLayout.js"],"names":[],"mappings":"AA8ZY","file":"DefaultLayout.js","sourcesContent":["/* eslint-disable no-param-reassign */\n/* @jsxImportSource @emotion/react */\n/* eslint-disable react/prop-types */\nimport {useRef} from 'react'\nimport {SlotProvider} from './uiExtensions'\nimport {nativeTextStyle, customTextStyle, bottomUiTop} from './subtitles'\n\nconst hidden = {display: 'none'}\nconst invisible = hiddenArea => ({\n  visibility: `var(${hiddenArea}, visible)`,\n})\nconst containerStyle = {\n  '--spacing': '0.5em',\n  '--center-pointer-events': 'auto',\n  width: '100%',\n  height: '100%',\n  fontSize: '16px',\n  boxSizing: 'border-box',\n  display: 'flex',\n  flexDirection: 'column',\n  overflow: 'hidden',\n  color: 'white',\n  background: '#000',\n  // prevent animation glich(afterimage) of descendant elements\n  transform: 'translateX(0)',\n  userSelect: 'none',\n  'a, a:link, a:visited': {\n    color: '#fff',\n    opacity: 0.8,\n    textDecoration: 'none',\n  },\n  button: {\n    fontSize: 'inherit',\n    '> *': {\n      pointerEvents: 'none',\n    },\n  },\n  '--thumbnail-width': '160', // height 90\n  '--theme-color': 'var(--primary-highlight, red)',\n}\n\nconst videoContainerStyle = {\n  '> div:first-of-type': {\n    position: 'absolute',\n    zIndex: '-1',\n    display: 'flex',\n    alignItems: 'center',\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst drop = {\n  backgroundImage: `linear-gradient(\n    0deg,\n    rgba(0,0,0,0.5) 0,\n    rgba(0,0,0,0) var(--player-ui-drop-shadow-size, 30%) calc(100% - var(--player-ui-drop-shadow-size, 30%)),\n    rgba(0,0,0,0.5) 100%\n  )`,\n  backgroundColor: `rgba(0, 0, 0, 0.3)`,\n}\n\nconst dropTop = {\n  backgroundImage: `linear-gradient(\n    0deg,\n    rgba(0,0,0,0) 0,\n    rgba(0,0,0,0) 8rem calc(100% - 8rem),\n    rgba(0,0,0,0.5) 100%\n  )`,\n}\n\nconst responsiveStyles = {\n  desktop: {\n    fontSize: '24px',\n  }, // add if necessary: big-desktop\n}\n\nconst rowStyle = {\n  boxSizing: 'border-box',\n  width: '100%',\n  padding: '1em',\n  display: 'flex',\n  alignItems: 'center',\n  '> button, > div > button': {\n    padding: '0.5rem',\n  },\n}\n\n/* \n  Hint:\n    displayStyles specificity is higher then controlsStyle\n    Need to pay attention when we revise these styles.\n*/\n\nconst displayHidden = {\n  '> div:not(.pinned), > button:not(.pinned), > img:not(.pinned)': {\n    opacity: 0,\n    transform: 'translate(-200vw, 0)',\n    transition: 'opacity 0.8s var(--autohide-delay, 0s) ease-out, transform 0s calc(0.8s + var(--autohide-delay, 0s))',\n    'button': {\n      opacity: 0, // extra transition to hide tooltip for Safari\n      transition: 'opacity 0s calc(0.8s + var(--autohide-delay, 0s)) ease-out',\n    }\n  },\n}\n\nconst displayStyles = {\n  hidden: displayHidden,\n  'seekbar-only': displayHidden,\n  shown: {\n    '> div:not(.pinned), > button:not(.pinned), > img:not(.pinned)': {\n      zIndex: 1,\n      pointerEvents: 'auto',\n      transition: 'opacity 0.3s ease-out, transform 0s 0s',\n    },\n  },\n}\n\nconst controlsDisplayStyles = {\n  hidden: {\n    ...displayStyles.hidden,\n    '~ div:not(.pinned)': displayStyles.hidden,\n  },\n  'seekbar-only': {\n    '> div:first-of-type ~ *': displayStyles.hidden,\n  },\n  shown: {\n    ...displayStyles.shown,\n    '~ div': displayStyles.shown,\n  },\n}\n\n// TODO: transform into sample object instead of function\nconst controlsStyle = type => ({\n  position: 'absolute',\n  zIndex: '2',\n  width: '100%',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '1.5em',\n  '> button': {\n    padding: '0.75em 0.5em',\n    '&:disabled': {\n      opacity: 0,\n      pointerEvents: 'none',\n    },\n    '&.play-button': {\n      padding: '0.75rem 0.5rem',\n      fontSize: 'var(--play-button-size, 1em)',\n    },\n    '&.firstplay-button':\n      type === 'mobile'\n        ? {fontSize: '200%', padding: '4em 10em', marginBottom: '1em'}\n        : {fontSize: '400%'},\n  },\n})\n\n// Remove the height for imporving tapping effect at current, and this height was used for fixed region before.\nconst infoBarSlotStyle = {\n  display: 'flex',\n  order: -1,\n  alignItems: 'center',\n  flex: '1 60%',\n}\n\nconst desktopInfoBarStyle = {\n  marginLeft: 'var(--spacing, 0.5em)',\n  order: 'initial',\n  flex: '1 0%',\n}\n\nconst textEllipsis = {\n  overflow: 'hidden',\n  whiteSpace: 'nowrap',\n  textOverflow: 'ellipsis',\n}\n\nconst infoStyle = {\n  zIndex: 1,\n  overflow: 'visible',\n  pointerEvents: 'none',\n  padding: '0 calc(2em - 20px)',\n  marginBottom: 'calc(0.5em + var(--bottom-spacing, 0))',\n  flex: '3em 0',\n  '> div:first-of-type, > div:nth-of-type(2), > button': {\n    minWidth: 0,\n  },\n  '> div:nth-of-type(2)': {\n    // title and channel title\n    margin: '0 calc(var(--spacing, 0.5em) / 2)',\n    flex: 1,\n    fontSize: '0.75em',\n    visibility: 'var(--player-title-visibility, visible)',\n    span: {\n      marginRight: 'var(--spacing, 0.5em)',\n    },\n    '> div': textEllipsis,\n  },\n  h1: {\n    margin: 0,\n    fontSize: '1.66em',\n    fontWeight: '500',\n    ...textEllipsis,\n    flex: 1,\n    '&:not(:only-child)': {\n      marginTop: '0.5em',\n    },\n  },\n  img: {\n    display: 'block',\n    width: '2em',\n    height: '2em',\n    borderRadius: '0.25em',\n    objectFit: 'cover',\n  },\n}\n\nconst backStyle = {\n  position: 'absolute',\n  zIndex: 0,\n  width: '100%',\n  height: '100%',\n  // move DAI UI slightly up to avoid stacking\n  paddingBottom: 'calc(var(--spacing) * 4)',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  '> iframe': {pointerEvents: 'auto'},\n}\n\nconst skipStyle = {\n  position: 'absolute',\n  right: 0,\n  bottom: '9rem',\n  textAlign: 'right',\n  button: {\n    width: 'auto',\n    height: 'auto',\n  },\n}\n\nconst desktopStyle = {\n  '--spacing': '0.75em',\n  '--center-pointer-events': 'none',\n  '> div button': {\n    margin: '0 calc(var(--spacing, 0.75em) - 0.5em)',\n  },\n  '--thumbnail-width': '288', // height 162\n}\n\nconst desktopControls = {\n  '> div:first-of-type': {\n    flex: '100%',\n    marginBottom: '0.4em',\n  },\n  '> button': {\n    '&[disabled]': {\n    display: 'none',\n    },\n    '&.play-button': {\n      fontSize: '1em',\n    },\n    '&.firstplay-button': {\n      fontSize: '400%'\n    },\n  },\n}\n\nconst seekbarStyles = {\n  flex: '1 var(--seekbar-flex-basis, 100%)',\n  '&:not(:empty)': {\n    margin: '0 calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)',\n  },\n}\n\nconst adContainerStyle = {\n  flexGrow: 1,\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  pointerEvents: 'var(--center-pointer-events)',\n  button: {pointerEvents: 'auto'},\n  zIndex: 0,\n}\n\nconst ControlsBlock = ({\n  order = 'mobile',\n  liveButton,\n  playButton,\n  rewindButton = '',\n  forwardButton = '',\n  previousEpisodeButton = '',\n  nextEpisodeButton = '',\n}) =>\n  order === 'desktop' ? (\n    <>\n      {liveButton}\n      {previousEpisodeButton}\n      {playButton}\n      {nextEpisodeButton}\n      {rewindButton}\n      {forwardButton}\n    </>\n  ) : (\n    <>\n      {rewindButton}\n      {previousEpisodeButton}\n      {playButton}\n      {nextEpisodeButton}\n      {forwardButton}\n    </>\n  )\n\nconst DefaultLayout = ({\n  type = 'mobile',\n  style,\n  display,\n  liveButton,\n  controlsDisplay = display,\n  size,\n  title = '',\n  channelTitle = '',\n  video,\n  haveBottomItem,\n  seekbar = '',\n  displayTime,\n  controlButtons,\n  volumeControl,\n  fullscreenButton,\n  backButton = '',\n  adStatus = '',\n  adLink = '',\n  adSkipButton,\n  backItems,\n  children,\n  containerRef,\n  backRef,\n  adContainerRef,\n  ...rest\n}) => {\n  const slotRef = useRef({})\n\n  return (\n    <div\n      style={{\n        '--player-bottom-ui-top':\n          controlsDisplay === 'shown'\n            ? `-${bottomUiTop(containerRef.current)}px`\n            : '-8px',\n        '--player-bottom-ui-height':\n          type === 'desktop' && controlsDisplay === 'shown' ? '3.5rem' : '0',\n      }}\n      css={[\n        containerStyle,\n        videoContainerStyle,\n        responsiveStyles[size],\n        type === 'desktop' && desktopStyle,\n        adStatus && {'--bottom-spacing': 0},\n        nativeTextStyle,\n        customTextStyle,\n        style,\n      ]}\n      ref={containerRef}\n      {...rest}\n    >\n      {video}\n      <div\n        ref={backRef}\n        css={[\n          backStyle,\n          display !== 'hidden' && (haveBottomItem ? dropTop : drop),\n          invisible('--controller-middle-area'),\n        ]}\n      >\n        {type !== 'mobile' && backItems}\n        {adSkipButton && <div css={skipStyle}>{adSkipButton}</div>}\n      </div>\n      <div\n        css={[\n          rowStyle,\n          infoStyle,\n          displayStyles[display],\n          invisible('--controller-top-area'),\n        ]}\n      >\n        {backButton}\n        <div\n          ref={element => {\n            slotRef.current.titleBarLeft = element\n          }}\n        />\n        <div>\n          <h1>{title}</h1>\n          {channelTitle && <div>{channelTitle}</div>}\n        </div>\n        <div\n          ref={element => {\n            slotRef.current.titleBarRight = element\n          }}\n        />\n        {adLink && <div className=\"pinned\">{adLink}</div>}\n      </div>\n      <div\n        ref={adContainerRef}\n        css={[\n          adContainerStyle,\n          // this container covers Google DAI iframe UI, left some space for user to click \"skip ad\"\n          // see https://kkvideo.atlassian.net/browse/CPT-4535 for detail\n          adStatus && {margin: 'calc(var(--spacing) * 6) 0'},\n        ]}\n      >\n        {type === 'mobile' && (\n          <div\n            css={[\n              controlsStyle(type),\n              displayStyles[controlsDisplay],\n              invisible('--controller-middle-area'),\n            ]}\n          >\n            <ControlsBlock order=\"mobile\" {...controlButtons} />\n          </div>\n        )}\n      </div>\n      <div\n        css={[\n          rowStyle,\n          {\n            marginTop: '1em',\n            paddingTop: 0,\n            paddingBottom: 'calc(1em - var(--bottom-spacing, 0) / 5)',\n            flexWrap: 'wrap',\n            '> div:first-of-type': seekbarStyles,\n          },\n          type === 'desktop' && desktopControls,\n          controlsDisplayStyles[controlsDisplay],\n          invisible('--controller-down-area'),\n        ]}\n      >\n        {seekbar || <div />}\n        {type === 'desktop' && (\n          <ControlsBlock\n            order=\"desktop\"\n            liveButton={liveButton}\n            {...controlButtons}\n          />\n        )}\n        {type === 'desktop' ? (\n          <div css={[displayStyles[controlsDisplay]]}>{displayTime}</div>\n        ) : (\n          <>\n            {liveButton}\n            <div\n              css={{\n                '&:not(:empty)': {\n                  flex: 1,\n                  marginLeft: 'calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)',\n                },\n              }}\n            >\n              {displayTime}\n            </div>\n          </>\n        )}\n        {adStatus && (\n          <div\n            className=\"pinned\"\n            css={[infoBarSlotStyle, type === 'desktop' && desktopInfoBarStyle]}\n          >\n            {adStatus}\n          </div>\n        )}\n        <div\n          css={\n            !adStatus && [\n              infoBarSlotStyle,\n              type === 'desktop' && desktopInfoBarStyle,\n            ]\n          }\n          ref={element => {\n            slotRef.current.infoBar = element\n          }}\n        />\n        {volumeControl}\n        <div\n          css={adStatus && hidden}\n          ref={element => {\n            slotRef.current.functionBar = element\n          }}\n        />\n        {fullscreenButton}\n      </div>\n      <SlotProvider slotRef={slotRef}>{children}</SlotProvider>\n    </div>\n  )\n}\n\nexport default DefaultLayout\n"]} */"],
|
|
11977
|
-
children: jsx(ControlsBlock, _objectSpread$
|
|
12228
|
+
children: jsx(ControlsBlock, _objectSpread$k({
|
|
11978
12229
|
order: "mobile"
|
|
11979
12230
|
}, controlButtons))
|
|
11980
12231
|
})
|
|
@@ -11986,7 +12237,7 @@ const DefaultLayout = _ref2 => {
|
|
|
11986
12237
|
flexWrap: 'wrap',
|
|
11987
12238
|
'> div:first-of-type': seekbarStyles
|
|
11988
12239
|
}, type === 'desktop' && desktopControls, controlsDisplayStyles[controlsDisplay], invisible('--controller-down-area'), "production" === "production" ? "" : ";label:DefaultLayout;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DefaultLayout.js"],"names":[],"mappings":"AAyaQ","file":"DefaultLayout.js","sourcesContent":["/* eslint-disable no-param-reassign */\n/* @jsxImportSource @emotion/react */\n/* eslint-disable react/prop-types */\nimport {useRef} from 'react'\nimport {SlotProvider} from './uiExtensions'\nimport {nativeTextStyle, customTextStyle, bottomUiTop} from './subtitles'\n\nconst hidden = {display: 'none'}\nconst invisible = hiddenArea => ({\n  visibility: `var(${hiddenArea}, visible)`,\n})\nconst containerStyle = {\n  '--spacing': '0.5em',\n  '--center-pointer-events': 'auto',\n  width: '100%',\n  height: '100%',\n  fontSize: '16px',\n  boxSizing: 'border-box',\n  display: 'flex',\n  flexDirection: 'column',\n  overflow: 'hidden',\n  color: 'white',\n  background: '#000',\n  // prevent animation glich(afterimage) of descendant elements\n  transform: 'translateX(0)',\n  userSelect: 'none',\n  'a, a:link, a:visited': {\n    color: '#fff',\n    opacity: 0.8,\n    textDecoration: 'none',\n  },\n  button: {\n    fontSize: 'inherit',\n    '> *': {\n      pointerEvents: 'none',\n    },\n  },\n  '--thumbnail-width': '160', // height 90\n  '--theme-color': 'var(--primary-highlight, red)',\n}\n\nconst videoContainerStyle = {\n  '> div:first-of-type': {\n    position: 'absolute',\n    zIndex: '-1',\n    display: 'flex',\n    alignItems: 'center',\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst drop = {\n  backgroundImage: `linear-gradient(\n    0deg,\n    rgba(0,0,0,0.5) 0,\n    rgba(0,0,0,0) var(--player-ui-drop-shadow-size, 30%) calc(100% - var(--player-ui-drop-shadow-size, 30%)),\n    rgba(0,0,0,0.5) 100%\n  )`,\n  backgroundColor: `rgba(0, 0, 0, 0.3)`,\n}\n\nconst dropTop = {\n  backgroundImage: `linear-gradient(\n    0deg,\n    rgba(0,0,0,0) 0,\n    rgba(0,0,0,0) 8rem calc(100% - 8rem),\n    rgba(0,0,0,0.5) 100%\n  )`,\n}\n\nconst responsiveStyles = {\n  desktop: {\n    fontSize: '24px',\n  }, // add if necessary: big-desktop\n}\n\nconst rowStyle = {\n  boxSizing: 'border-box',\n  width: '100%',\n  padding: '1em',\n  display: 'flex',\n  alignItems: 'center',\n  '> button, > div > button': {\n    padding: '0.5rem',\n  },\n}\n\n/* \n  Hint:\n    displayStyles specificity is higher then controlsStyle\n    Need to pay attention when we revise these styles.\n*/\n\nconst displayHidden = {\n  '> div:not(.pinned), > button:not(.pinned), > img:not(.pinned)': {\n    opacity: 0,\n    transform: 'translate(-200vw, 0)',\n    transition: 'opacity 0.8s var(--autohide-delay, 0s) ease-out, transform 0s calc(0.8s + var(--autohide-delay, 0s))',\n    'button': {\n      opacity: 0, // extra transition to hide tooltip for Safari\n      transition: 'opacity 0s calc(0.8s + var(--autohide-delay, 0s)) ease-out',\n    }\n  },\n}\n\nconst displayStyles = {\n  hidden: displayHidden,\n  'seekbar-only': displayHidden,\n  shown: {\n    '> div:not(.pinned), > button:not(.pinned), > img:not(.pinned)': {\n      zIndex: 1,\n      pointerEvents: 'auto',\n      transition: 'opacity 0.3s ease-out, transform 0s 0s',\n    },\n  },\n}\n\nconst controlsDisplayStyles = {\n  hidden: {\n    ...displayStyles.hidden,\n    '~ div:not(.pinned)': displayStyles.hidden,\n  },\n  'seekbar-only': {\n    '> div:first-of-type ~ *': displayStyles.hidden,\n  },\n  shown: {\n    ...displayStyles.shown,\n    '~ div': displayStyles.shown,\n  },\n}\n\n// TODO: transform into sample object instead of function\nconst controlsStyle = type => ({\n  position: 'absolute',\n  zIndex: '2',\n  width: '100%',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '1.5em',\n  '> button': {\n    padding: '0.75em 0.5em',\n    '&:disabled': {\n      opacity: 0,\n      pointerEvents: 'none',\n    },\n    '&.play-button': {\n      padding: '0.75rem 0.5rem',\n      fontSize: 'var(--play-button-size, 1em)',\n    },\n    '&.firstplay-button':\n      type === 'mobile'\n        ? {fontSize: '200%', padding: '4em 10em', marginBottom: '1em'}\n        : {fontSize: '400%'},\n  },\n})\n\n// Remove the height for imporving tapping effect at current, and this height was used for fixed region before.\nconst infoBarSlotStyle = {\n  display: 'flex',\n  order: -1,\n  alignItems: 'center',\n  flex: '1 60%',\n}\n\nconst desktopInfoBarStyle = {\n  marginLeft: 'var(--spacing, 0.5em)',\n  order: 'initial',\n  flex: '1 0%',\n}\n\nconst textEllipsis = {\n  overflow: 'hidden',\n  whiteSpace: 'nowrap',\n  textOverflow: 'ellipsis',\n}\n\nconst infoStyle = {\n  zIndex: 1,\n  overflow: 'visible',\n  pointerEvents: 'none',\n  padding: '0 calc(2em - 20px)',\n  marginBottom: 'calc(0.5em + var(--bottom-spacing, 0))',\n  flex: '3em 0',\n  '> div:first-of-type, > div:nth-of-type(2), > button': {\n    minWidth: 0,\n  },\n  '> div:nth-of-type(2)': {\n    // title and channel title\n    margin: '0 calc(var(--spacing, 0.5em) / 2)',\n    flex: 1,\n    fontSize: '0.75em',\n    visibility: 'var(--player-title-visibility, visible)',\n    span: {\n      marginRight: 'var(--spacing, 0.5em)',\n    },\n    '> div': textEllipsis,\n  },\n  h1: {\n    margin: 0,\n    fontSize: '1.66em',\n    fontWeight: '500',\n    ...textEllipsis,\n    flex: 1,\n    '&:not(:only-child)': {\n      marginTop: '0.5em',\n    },\n  },\n  img: {\n    display: 'block',\n    width: '2em',\n    height: '2em',\n    borderRadius: '0.25em',\n    objectFit: 'cover',\n  },\n}\n\nconst backStyle = {\n  position: 'absolute',\n  zIndex: 0,\n  width: '100%',\n  height: '100%',\n  // move DAI UI slightly up to avoid stacking\n  paddingBottom: 'calc(var(--spacing) * 4)',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  '> iframe': {pointerEvents: 'auto'},\n}\n\nconst skipStyle = {\n  position: 'absolute',\n  right: 0,\n  bottom: '9rem',\n  textAlign: 'right',\n  button: {\n    width: 'auto',\n    height: 'auto',\n  },\n}\n\nconst desktopStyle = {\n  '--spacing': '0.75em',\n  '--center-pointer-events': 'none',\n  '> div button': {\n    margin: '0 calc(var(--spacing, 0.75em) - 0.5em)',\n  },\n  '--thumbnail-width': '288', // height 162\n}\n\nconst desktopControls = {\n  '> div:first-of-type': {\n    flex: '100%',\n    marginBottom: '0.4em',\n  },\n  '> button': {\n    '&[disabled]': {\n    display: 'none',\n    },\n    '&.play-button': {\n      fontSize: '1em',\n    },\n    '&.firstplay-button': {\n      fontSize: '400%'\n    },\n  },\n}\n\nconst seekbarStyles = {\n  flex: '1 var(--seekbar-flex-basis, 100%)',\n  '&:not(:empty)': {\n    margin: '0 calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)',\n  },\n}\n\nconst adContainerStyle = {\n  flexGrow: 1,\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  pointerEvents: 'var(--center-pointer-events)',\n  button: {pointerEvents: 'auto'},\n  zIndex: 0,\n}\n\nconst ControlsBlock = ({\n  order = 'mobile',\n  liveButton,\n  playButton,\n  rewindButton = '',\n  forwardButton = '',\n  previousEpisodeButton = '',\n  nextEpisodeButton = '',\n}) =>\n  order === 'desktop' ? (\n    <>\n      {liveButton}\n      {previousEpisodeButton}\n      {playButton}\n      {nextEpisodeButton}\n      {rewindButton}\n      {forwardButton}\n    </>\n  ) : (\n    <>\n      {rewindButton}\n      {previousEpisodeButton}\n      {playButton}\n      {nextEpisodeButton}\n      {forwardButton}\n    </>\n  )\n\nconst DefaultLayout = ({\n  type = 'mobile',\n  style,\n  display,\n  liveButton,\n  controlsDisplay = display,\n  size,\n  title = '',\n  channelTitle = '',\n  video,\n  haveBottomItem,\n  seekbar = '',\n  displayTime,\n  controlButtons,\n  volumeControl,\n  fullscreenButton,\n  backButton = '',\n  adStatus = '',\n  adLink = '',\n  adSkipButton,\n  backItems,\n  children,\n  containerRef,\n  backRef,\n  adContainerRef,\n  ...rest\n}) => {\n  const slotRef = useRef({})\n\n  return (\n    <div\n      style={{\n        '--player-bottom-ui-top':\n          controlsDisplay === 'shown'\n            ? `-${bottomUiTop(containerRef.current)}px`\n            : '-8px',\n        '--player-bottom-ui-height':\n          type === 'desktop' && controlsDisplay === 'shown' ? '3.5rem' : '0',\n      }}\n      css={[\n        containerStyle,\n        videoContainerStyle,\n        responsiveStyles[size],\n        type === 'desktop' && desktopStyle,\n        adStatus && {'--bottom-spacing': 0},\n        nativeTextStyle,\n        customTextStyle,\n        style,\n      ]}\n      ref={containerRef}\n      {...rest}\n    >\n      {video}\n      <div\n        ref={backRef}\n        css={[\n          backStyle,\n          display !== 'hidden' && (haveBottomItem ? dropTop : drop),\n          invisible('--controller-middle-area'),\n        ]}\n      >\n        {type !== 'mobile' && backItems}\n        {adSkipButton && <div css={skipStyle}>{adSkipButton}</div>}\n      </div>\n      <div\n        css={[\n          rowStyle,\n          infoStyle,\n          displayStyles[display],\n          invisible('--controller-top-area'),\n        ]}\n      >\n        {backButton}\n        <div\n          ref={element => {\n            slotRef.current.titleBarLeft = element\n          }}\n        />\n        <div>\n          <h1>{title}</h1>\n          {channelTitle && <div>{channelTitle}</div>}\n        </div>\n        <div\n          ref={element => {\n            slotRef.current.titleBarRight = element\n          }}\n        />\n        {adLink && <div className=\"pinned\">{adLink}</div>}\n      </div>\n      <div\n        ref={adContainerRef}\n        css={[\n          adContainerStyle,\n          // this container covers Google DAI iframe UI, left some space for user to click \"skip ad\"\n          // see https://kkvideo.atlassian.net/browse/CPT-4535 for detail\n          adStatus && {margin: 'calc(var(--spacing) * 6) 0'},\n        ]}\n      >\n        {type === 'mobile' && (\n          <div\n            css={[\n              controlsStyle(type),\n              displayStyles[controlsDisplay],\n              invisible('--controller-middle-area'),\n            ]}\n          >\n            <ControlsBlock order=\"mobile\" {...controlButtons} />\n          </div>\n        )}\n      </div>\n      <div\n        css={[\n          rowStyle,\n          {\n            marginTop: '1em',\n            paddingTop: 0,\n            paddingBottom: 'calc(1em - var(--bottom-spacing, 0) / 5)',\n            flexWrap: 'wrap',\n            '> div:first-of-type': seekbarStyles,\n          },\n          type === 'desktop' && desktopControls,\n          controlsDisplayStyles[controlsDisplay],\n          invisible('--controller-down-area'),\n        ]}\n      >\n        {seekbar || <div />}\n        {type === 'desktop' && (\n          <ControlsBlock\n            order=\"desktop\"\n            liveButton={liveButton}\n            {...controlButtons}\n          />\n        )}\n        {type === 'desktop' ? (\n          <div css={[displayStyles[controlsDisplay]]}>{displayTime}</div>\n        ) : (\n          <>\n            {liveButton}\n            <div\n              css={{\n                '&:not(:empty)': {\n                  flex: 1,\n                  marginLeft: 'calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)',\n                },\n              }}\n            >\n              {displayTime}\n            </div>\n          </>\n        )}\n        {adStatus && (\n          <div\n            className=\"pinned\"\n            css={[infoBarSlotStyle, type === 'desktop' && desktopInfoBarStyle]}\n          >\n            {adStatus}\n          </div>\n        )}\n        <div\n          css={\n            !adStatus && [\n              infoBarSlotStyle,\n              type === 'desktop' && desktopInfoBarStyle,\n            ]\n          }\n          ref={element => {\n            slotRef.current.infoBar = element\n          }}\n        />\n        {volumeControl}\n        <div\n          css={adStatus && hidden}\n          ref={element => {\n            slotRef.current.functionBar = element\n          }}\n        />\n        {fullscreenButton}\n      </div>\n      <SlotProvider slotRef={slotRef}>{children}</SlotProvider>\n    </div>\n  )\n}\n\nexport default DefaultLayout\n"]} */"],
|
|
11989
|
-
children: [seekbar || jsx("div", {}), type === 'desktop' && jsx(ControlsBlock, _objectSpread$
|
|
12240
|
+
children: [seekbar || jsx("div", {}), type === 'desktop' && jsx(ControlsBlock, _objectSpread$k({
|
|
11990
12241
|
order: "desktop",
|
|
11991
12242
|
liveButton: liveButton
|
|
11992
12243
|
}, controlButtons)), type === 'desktop' ? jsx("div", {
|
|
@@ -12017,9 +12268,9 @@ const DefaultLayout = _ref2 => {
|
|
|
12017
12268
|
children: children
|
|
12018
12269
|
})]
|
|
12019
12270
|
}));
|
|
12020
|
-
};function ownKeys$
|
|
12271
|
+
};function ownKeys$j(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
12021
12272
|
|
|
12022
|
-
function _objectSpread$
|
|
12273
|
+
function _objectSpread$j(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$j(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$j(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
12023
12274
|
|
|
12024
12275
|
/* eslint-disable no-param-reassign */
|
|
12025
12276
|
const getPointerData = event => {
|
|
@@ -12076,11 +12327,11 @@ const scheduleUpdate = (state, _ref) => {
|
|
|
12076
12327
|
state.scheduledUpdate = true;
|
|
12077
12328
|
requestAnimationFrame(() => {
|
|
12078
12329
|
if (state.pendingMove) {
|
|
12079
|
-
onMove === null || onMove === void 0 ? void 0 : onMove(_objectSpread$
|
|
12330
|
+
onMove === null || onMove === void 0 ? void 0 : onMove(_objectSpread$j(_objectSpread$j({}, state.currentPosition), state.pendingMove));
|
|
12080
12331
|
}
|
|
12081
12332
|
|
|
12082
12333
|
if (!state.down) {
|
|
12083
|
-
onLeave === null || onLeave === void 0 ? void 0 : onLeave(_objectSpread$
|
|
12334
|
+
onLeave === null || onLeave === void 0 ? void 0 : onLeave(_objectSpread$j(_objectSpread$j({}, state.currentPosition), state.lastMove));
|
|
12084
12335
|
}
|
|
12085
12336
|
|
|
12086
12337
|
state.lastMove = state.pendingMove;
|
|
@@ -12167,9 +12418,9 @@ const pointerHandlers = _ref2 => {
|
|
|
12167
12418
|
};const _excluded$b = ["orientation", "style"],
|
|
12168
12419
|
_excluded2$3 = ["value", "orientation", "style"];
|
|
12169
12420
|
|
|
12170
|
-
function ownKeys$
|
|
12421
|
+
function ownKeys$i(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
12171
12422
|
|
|
12172
|
-
function _objectSpread$
|
|
12423
|
+
function _objectSpread$i(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$i(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$i(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
12173
12424
|
const containerStyle$4 = {
|
|
12174
12425
|
position: 'relative',
|
|
12175
12426
|
width: '100%',
|
|
@@ -12258,7 +12509,7 @@ const debouncedPointerHandlers = _ref2 => {
|
|
|
12258
12509
|
var _event$touches;
|
|
12259
12510
|
|
|
12260
12511
|
const type = event.buttons > 0 || ((_event$touches = event.touches) === null || _event$touches === void 0 ? void 0 : _event$touches.length) > 0 ? 'change' : 'move';
|
|
12261
|
-
Object.assign(state, _objectSpread$
|
|
12512
|
+
Object.assign(state, _objectSpread$i({
|
|
12262
12513
|
event,
|
|
12263
12514
|
type
|
|
12264
12515
|
}, getPointerData(event)));
|
|
@@ -12304,7 +12555,7 @@ const SliderRail = _ref4 => {
|
|
|
12304
12555
|
} = _ref4,
|
|
12305
12556
|
rest = _objectWithoutProperties(_ref4, _excluded$b);
|
|
12306
12557
|
|
|
12307
|
-
return jsx("div", _objectSpread$
|
|
12558
|
+
return jsx("div", _objectSpread$i({
|
|
12308
12559
|
css: [style, orientation !== 'horizontal' && {
|
|
12309
12560
|
borderRadius: '0.2em',
|
|
12310
12561
|
alignSelf: 'normal'
|
|
@@ -12320,7 +12571,7 @@ const SliderTrack = _ref5 => {
|
|
|
12320
12571
|
} = _ref5,
|
|
12321
12572
|
rest = _objectWithoutProperties(_ref5, _excluded2$3);
|
|
12322
12573
|
|
|
12323
|
-
return jsx("div", _objectSpread$
|
|
12574
|
+
return jsx("div", _objectSpread$i({
|
|
12324
12575
|
css: [style, orientation === 'vertical' ? {
|
|
12325
12576
|
bottom: '0',
|
|
12326
12577
|
height: "".concat(value * 100, "%")
|
|
@@ -12432,17 +12683,17 @@ const SimpleSlider = _ref6 => {
|
|
|
12432
12683
|
bottom: "calc(var(--slider-thumb-y) - 0.35em)",
|
|
12433
12684
|
left: "calc(var(--slider-thumb-x) - 0.25em)"
|
|
12434
12685
|
};
|
|
12435
|
-
return jsxs("div", _objectSpread$
|
|
12686
|
+
return jsxs("div", _objectSpread$i(_objectSpread$i({
|
|
12436
12687
|
className: className,
|
|
12437
12688
|
css: [containerStyle$4, disabled && disabledStyle, "production" === "production" ? "" : ";label:SimpleSlider;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SimpleSlider.jsx"],"names":[],"mappings":"AAwMM","file":"SimpleSlider.jsx","sourcesContent":["/* eslint-disable no-param-reassign */\n/* eslint-disable jsx-a11y/no-static-element-interactions */\n/* eslint-disable jsx-a11y/click-events-have-key-events */\n/* @jsxImportSource @emotion/react */\nimport {useState, useRef} from 'react'\n\nimport {getPointerData} from 'util/gestures'\n\nconst containerStyle = {\n  position: 'relative',\n  width: '100%',\n  height: '100%',\n  display: 'flex',\n  alignItems: 'center',\n  cursor: 'pointer',\n  userSelect: 'none',\n  touchAction: 'none',\n}\n\nconst disabledStyle = {\n  pointerEvents: 'none',\n}\n\nconst railStyle = {\n  flex: '100%',\n  background: 'rgba(255, 255, 255, 0.2)',\n}\n\nconst trackStyle = {\n  position: 'absolute',\n  width: '4px',\n  height: '100%',\n  backgroundColor: 'var(--sender-seekbar-background, #fff)',\n}\n\nconst markStyle = {\n  position: 'absolute',\n  height: railStyle.height,\n  width: '4px',\n  transform: 'translateX(-50%)',\n  backgroundColor: '#ff9835',\n}\n\nconst thumbStyle = {\n  position: 'absolute',\n  height: '0.66em',\n  width: '0.66em',\n  borderRadius: '100%',\n  backgroundColor: '#fff',\n  boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',\n  transform: 'translateY(calc(var(--slider-thumb-y) - 0.35em))',\n}\n\nconst getPointerValue = ({orientation, x, y, left, bottom, height, width}) =>\n  Math.max(\n    0,\n    orientation === 'vertical'\n      ? Math.min((bottom - y) / height, 1)\n      : Math.min((x - left) / width, 1),\n  )\n\nconst debouncedPointerHandlers = ({state, onMove, onLeave}) => {\n  const emit = () => {\n    if (!state.scheduled) {\n      return\n    }\n    if (state.type === 'leave') {\n      onLeave?.(state.event, state)\n    } else {\n      onMove(state.event, state)\n    }\n    state.scheduled = false\n  }\n  const schedule = () => {\n    if (state.scheduled) {\n      return\n    }\n    state.scheduled = true\n    requestAnimationFrame(emit)\n  }\n\n  return {\n    onPointerMove: event => {\n      const type =\n        event.buttons > 0 || event.touches?.length > 0 ? 'change' : 'move'\n      Object.assign(state, {event, type, ...getPointerData(event)})\n      schedule()\n    },\n    onPointerLeave: event => {\n      const type = 'leave'\n      Object.assign(state, {event, type})\n      schedule()\n    },\n    emit,\n  }\n}\n\nconst eventHandlers = ({\n  onPointerDown,\n  onPointerMove,\n  onPointerLeave,\n  onPointerUp,\n}) => ({\n  onPointerDown,\n  onPointerMove,\n  onPointerLeave,\n  onPointerUp,\n  onTouchStart: onPointerDown,\n  onTouchMove: onPointerMove,\n  onTouchEnd: event => {\n    onPointerLeave(event)\n    onPointerUp(event)\n  },\n})\n\nconst SliderRail = ({orientation, style, ...rest}) => (\n  <div\n    css={[style, orientation !== 'horizontal' && {borderRadius: '0.2em', alignSelf: 'normal'}]}\n    {...rest}\n  />\n)\n\nconst SliderTrack = ({value, orientation, style, ...rest}) => (\n  <div\n    css={[\n      style,\n      orientation === 'vertical'\n        ? {bottom: '0', height: `${value * 100}%`}\n        : {width: `${value * 100}%`},\n    ]}\n    {...rest}\n  />\n)\n\nconst defaultSlots = {\n  Rail: SliderRail,\n  Track: SliderTrack,\n}\n\n// TODO align with material ui more, move special handling of pointer events\nconst SimpleSlider = ({\n  min = 0,\n  max = 100,\n  value,\n  secondaryTrackValue, // TODO a better name\n  marks = [],\n  className = '',\n  classes = {},\n  disabled,\n  onPointerMove,\n  onPointerLeave,\n  onPointerDown,\n  onChange,\n  onChangeCommitted,\n  orientation = 'horizontal',\n  slots = defaultSlots,\n  slotProps = {},\n}) => {\n  const pointerState = useRef({})\n  const [focusValue, setFocusValue] = useState(-Infinity)\n  const thumbPosition =\n    ((focusValue >= min ? focusValue : value) - min) / (max - min)\n  const subTrackPosition = (secondaryTrackValue - min) / (max - min)\n  const pointerHandlers = debouncedPointerHandlers({\n    state: pointerState.current,\n    onMove: (event, {type, x, y, width, left, height, bottom}) => {\n      const pointerData = {orientation, x, y, left, bottom, width, height}\n      const pointerValue = min + (max - min) * getPointerValue(pointerData)\n\n      onPointerMove?.(event, {value: pointerValue, x, y})\n      if (type === 'change') {\n        setFocusValue(pointerValue)\n        onChange?.(event, {value: pointerValue, x, y})\n      }\n    },\n    onLeave: () => onPointerLeave?.(),\n  })\n  const handlePointerUp = event => {\n    if (event.pointerId) {\n      event.currentTarget.releasePointerCapture(event.pointerId)\n    }\n    const {x, y, width, left, height, bottom} = getPointerData(event)\n    const pointerValue =\n      min +\n      (max - min) *\n        getPointerValue({orientation, x, y, left, bottom, width, height})\n\n    pointerHandlers.emit()\n    onChangeCommitted?.(event, {value: pointerValue})\n    setFocusValue()\n  }\n\n  const thumbPositionStyle = {\n    bottom: `calc(var(--slider-thumb-y) - 0.35em)`,\n    left: `calc(var(--slider-thumb-x) - 0.25em)`,\n  }\n\n  return (\n    <div\n      className={className}\n      css={[containerStyle, disabled && disabledStyle]}\n      style={{\n        ...(orientation === 'vertical' && {\n          flexDirection: 'column',\n          '--slider-thumb-y': `${thumbPosition * 100}%`,\n        }),\n        ...(orientation === 'horizontal' && {\n          '--slider-thumb-x': `${thumbPosition * 100}%`,\n        }),\n      }}\n      onClick={event => event.stopPropagation()}\n      {...eventHandlers({\n        onPointerDown: event => {\n          if (event.type === 'pointerdown') {\n            event.currentTarget.setPointerCapture(event.pointerId)\n            onPointerDown?.()\n          }\n          pointerHandlers.onPointerMove(event)\n        },\n        ...pointerHandlers,\n        onPointerUp: handlePointerUp,\n      })}\n    >\n      <slots.Rail style={railStyle} className={classes.rail} {...slotProps.rail} />\n      {secondaryTrackValue && (\n        <slots.Track\n          style={{...trackStyle, backgroundColor: 'rgba(255, 255, 255, 0.3)'}}\n          orientation={orientation}\n          value={subTrackPosition}\n          {...slotProps.track}\n        />\n      )}\n      <slots.Track\n        className={classes.track}\n        style={trackStyle}\n        orientation={orientation}\n        value={thumbPosition}\n        {...slotProps.track}\n      />\n      {marks.map(position => (\n        <div\n          key={position}\n          css={markStyle}\n          className={classes.marked}\n          style={{left: `${(position / max) * 100}%`}}\n        />\n      ))}\n      {onChange && !disabled ? (\n        <div\n          css={thumbStyle}\n          className={classes.thumb}\n          style={thumbPositionStyle}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nexport default SimpleSlider\n"]} */"],
|
|
12438
|
-
style: _objectSpread$
|
|
12689
|
+
style: _objectSpread$i(_objectSpread$i({}, orientation === 'vertical' && {
|
|
12439
12690
|
flexDirection: 'column',
|
|
12440
12691
|
'--slider-thumb-y': "".concat(thumbPosition * 100, "%")
|
|
12441
12692
|
}), orientation === 'horizontal' && {
|
|
12442
12693
|
'--slider-thumb-x': "".concat(thumbPosition * 100, "%")
|
|
12443
12694
|
}),
|
|
12444
12695
|
onClick: event => event.stopPropagation()
|
|
12445
|
-
}, eventHandlers(_objectSpread$
|
|
12696
|
+
}, eventHandlers(_objectSpread$i(_objectSpread$i({
|
|
12446
12697
|
onPointerDown: event => {
|
|
12447
12698
|
if (event.type === 'pointerdown') {
|
|
12448
12699
|
event.currentTarget.setPointerCapture(event.pointerId);
|
|
@@ -12454,16 +12705,16 @@ const SimpleSlider = _ref6 => {
|
|
|
12454
12705
|
}, pointerHandlers), {}, {
|
|
12455
12706
|
onPointerUp: handlePointerUp
|
|
12456
12707
|
}))), {}, {
|
|
12457
|
-
children: [jsx(slots.Rail, _objectSpread$
|
|
12708
|
+
children: [jsx(slots.Rail, _objectSpread$i({
|
|
12458
12709
|
style: railStyle,
|
|
12459
12710
|
className: classes.rail
|
|
12460
|
-
}, slotProps.rail)), secondaryTrackValue && jsx(slots.Track, _objectSpread$
|
|
12461
|
-
style: _objectSpread$
|
|
12711
|
+
}, slotProps.rail)), secondaryTrackValue && jsx(slots.Track, _objectSpread$i({
|
|
12712
|
+
style: _objectSpread$i(_objectSpread$i({}, trackStyle), {}, {
|
|
12462
12713
|
backgroundColor: 'rgba(255, 255, 255, 0.3)'
|
|
12463
12714
|
}),
|
|
12464
12715
|
orientation: orientation,
|
|
12465
12716
|
value: subTrackPosition
|
|
12466
|
-
}, slotProps.track)), jsx(slots.Track, _objectSpread$
|
|
12717
|
+
}, slotProps.track)), jsx(slots.Track, _objectSpread$i({
|
|
12467
12718
|
className: classes.track,
|
|
12468
12719
|
style: trackStyle,
|
|
12469
12720
|
orientation: orientation,
|
|
@@ -12546,9 +12797,9 @@ const getTimelineSegments = (chapters, _ref4) => {
|
|
|
12546
12797
|
});
|
|
12547
12798
|
};const _excluded$a = ["style", "classes", "startTime", "currentTime", "bufferTime", "duration", "chapters", "marks", "timeDisplay", "onChange", "onChangeCommitted", "children", "onPointerMove", "onPointerLeave"];
|
|
12548
12799
|
|
|
12549
|
-
function ownKeys$
|
|
12800
|
+
function ownKeys$h(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
12550
12801
|
|
|
12551
|
-
function _objectSpread$
|
|
12802
|
+
function _objectSpread$h(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$h(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$h(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
12552
12803
|
const seekbarStyle = {
|
|
12553
12804
|
position: 'relative',
|
|
12554
12805
|
display: 'flex',
|
|
@@ -12587,26 +12838,26 @@ const reducePointer = (state, _ref) => {
|
|
|
12587
12838
|
|
|
12588
12839
|
switch (type) {
|
|
12589
12840
|
case 'move':
|
|
12590
|
-
return _objectSpread$
|
|
12841
|
+
return _objectSpread$h(_objectSpread$h({}, state), {}, {
|
|
12591
12842
|
hover: true,
|
|
12592
12843
|
value,
|
|
12593
12844
|
x
|
|
12594
12845
|
});
|
|
12595
12846
|
|
|
12596
12847
|
case 'change':
|
|
12597
|
-
return _objectSpread$
|
|
12848
|
+
return _objectSpread$h(_objectSpread$h({}, state), {}, {
|
|
12598
12849
|
focused: true,
|
|
12599
12850
|
value
|
|
12600
12851
|
});
|
|
12601
12852
|
|
|
12602
12853
|
case 'release':
|
|
12603
|
-
return _objectSpread$
|
|
12854
|
+
return _objectSpread$h(_objectSpread$h({}, state), {}, {
|
|
12604
12855
|
focused: false,
|
|
12605
12856
|
value
|
|
12606
12857
|
});
|
|
12607
12858
|
|
|
12608
12859
|
case 'leave':
|
|
12609
|
-
return _objectSpread$
|
|
12860
|
+
return _objectSpread$h(_objectSpread$h({}, state), {}, {
|
|
12610
12861
|
hover: false
|
|
12611
12862
|
});
|
|
12612
12863
|
|
|
@@ -12774,7 +13025,7 @@ const Seekbar = _ref4 => {
|
|
|
12774
13025
|
time: pointerState.value
|
|
12775
13026
|
}) : jsx(FormattedTime, {
|
|
12776
13027
|
time: Math.min(Math.max(0, currentTime), duration)
|
|
12777
|
-
}), jsx(SimpleSlider, _objectSpread$
|
|
13028
|
+
}), jsx(SimpleSlider, _objectSpread$h(_objectSpread$h(_objectSpread$h({
|
|
12778
13029
|
css: [sliderStyle, timeDisplay && {
|
|
12779
13030
|
margin: '0 1em'
|
|
12780
13031
|
}, "production" === "production" ? "" : ";label:Seekbar;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEtRIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
|
|
@@ -12835,9 +13086,9 @@ DisplayTime.propTypes = {
|
|
|
12835
13086
|
|
|
12836
13087
|
var _templateObject$2;
|
|
12837
13088
|
|
|
12838
|
-
function ownKeys$
|
|
13089
|
+
function ownKeys$g(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
12839
13090
|
|
|
12840
|
-
function _objectSpread$
|
|
13091
|
+
function _objectSpread$g(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$g(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$g(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
12841
13092
|
const rotateInfinite = keyframes(_templateObject$2 || (_templateObject$2 = _taggedTemplateLiteral(["\n 0% {\n transform: translate(-50%, -50%) rotate(0deg);\n }\n 100% {\n transform: translate(-50%, -50%) rotate(360deg); \n }\n"])));
|
|
12842
13093
|
const defaultLoadingIcon = "<svg width=\"24\" height=\"24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<path d=\"M11.76 22a.8.8 0 0 1 0-1.6A8.4 8.4 0 1 0 4.5 7.8.8.8 0 0 1 3.1 7a10 10 0 1 1 8.66 15Z\" fill=\"url(#a)\" />\n<defs>\n <linearGradient id=\"a\" x1=\".96\" y1=\"3.67\" x2=\"30.54\" y2=\"33.25\" gradientUnits=\"userSpaceOnUse\">\n <stop stop-color=\"#fff\" stop-opacity=\"0\" />\n <stop offset=\".73\" stop-color=\"#fff\" />\n <stop offset=\"1\" stop-color=\"#fff\" />\n </linearGradient>\n</defs>\n</svg>";
|
|
12843
13094
|
const style$1 = {
|
|
@@ -12878,7 +13129,7 @@ const LoadingSpinner = _ref => {
|
|
|
12878
13129
|
props = _objectWithoutProperties(_ref, _excluded$9);
|
|
12879
13130
|
|
|
12880
13131
|
const current = useDeferredActive(active);
|
|
12881
|
-
return jsx("div", _objectSpread$
|
|
13132
|
+
return jsx("div", _objectSpread$g(_objectSpread$g({}, props), {}, {
|
|
12882
13133
|
css: [style$1, !current && hiddenStyle$1, "production" === "production" ? "" : ";label:LoadingSpinner;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxvYWRpbmdTcGlubmVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREeUIiLCJmaWxlIjoiTG9hZGluZ1NwaW5uZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2tleWZyYW1lc30gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0J1xuXG5jb25zdCByb3RhdGVJbmZpbml0ZSA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIC01MCUpIHJvdGF0ZSgwZGVnKTtcbiAgfVxuICAxMDAlICB7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoLTUwJSwgLTUwJSkgcm90YXRlKDM2MGRlZyk7IFxuICB9XG5gXG5cbmNvbnN0IGRlZmF1bHRMb2FkaW5nSWNvbiA9IGA8c3ZnIHdpZHRoPVwiMjRcIiBoZWlnaHQ9XCIyNFwiIGZpbGw9XCJub25lXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuPHBhdGggZD1cIk0xMS43NiAyMmEuOC44IDAgMCAxIDAtMS42QTguNCA4LjQgMCAxIDAgNC41IDcuOC44LjggMCAwIDEgMy4xIDdhMTAgMTAgMCAxIDEgOC42NiAxNVpcIiBmaWxsPVwidXJsKCNhKVwiIC8+XG48ZGVmcz5cbiAgPGxpbmVhckdyYWRpZW50IGlkPVwiYVwiIHgxPVwiLjk2XCIgeTE9XCIzLjY3XCIgeDI9XCIzMC41NFwiIHkyPVwiMzMuMjVcIiBncmFkaWVudFVuaXRzPVwidXNlclNwYWNlT25Vc2VcIj5cbiAgICA8c3RvcCBzdG9wLWNvbG9yPVwiI2ZmZlwiIHN0b3Atb3BhY2l0eT1cIjBcIiAvPlxuICAgIDxzdG9wIG9mZnNldD1cIi43M1wiIHN0b3AtY29sb3I9XCIjZmZmXCIgLz5cbiAgICA8c3RvcCBvZmZzZXQ9XCIxXCIgc3RvcC1jb2xvcj1cIiNmZmZcIiAvPlxuICA8L2xpbmVhckdyYWRpZW50PlxuPC9kZWZzPlxuPC9zdmc+YFxuXG5jb25zdCBzdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICBkaXNwbGF5OiAnYmxvY2snLFxuICBoZWlnaHQ6ICczZW0nLFxuICB3aWR0aDogJzNlbScsXG4gIGJhY2tncm91bmRQb3NpdGlvbjogJ2NlbnRlcicsXG4gIGJhY2tncm91bmRTaXplOiAnY292ZXInLFxuICBiYWNrZ3JvdW5kSW1hZ2U6IGB2YXIoLS1pY29uLWxvYWRpbmcsIHVybChkYXRhOmltYWdlL3N2Zyt4bWw7YmFzZTY0LCR7YnRvYShcbiAgICBkZWZhdWx0TG9hZGluZ0ljb25cbiAgKX0pKWAsXG4gIGFuaW1hdGlvbjogYCR7cm90YXRlSW5maW5pdGV9IDEuMnMgbGluZWFyIGluZmluaXRlYCxcbiAgcG9pbnRlckV2ZW50czogJ25vbmUnLFxufVxuXG5jb25zdCBoaWRkZW5TdHlsZSA9IHtcbiAgb3BhY2l0eTogMCxcbn1cblxuY29uc3QgdXNlRGVmZXJyZWRBY3RpdmUgPSBhY3RpdmUgPT4ge1xuICBjb25zdCBbc3RhdHVzLCBzZXRTdGF0dXNdID0gdXNlU3RhdGUoJ2luaXQnKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmICghYWN0aXZlKSB7XG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgc2V0U3RhdHVzKGN1cnJlbnQgPT4gKGN1cnJlbnQgPT09ICdpbml0JyA/ICdyZWFkeScgOiAncGVuZGluZycpKVxuICAgIGNvbnN0IHRpbWVyID0gc2V0VGltZW91dCgoKSA9PiBzZXRTdGF0dXMoJ3JlYWR5JyksIDEwMDApXG4gICAgcmV0dXJuICgpID0+IGNsZWFyVGltZW91dCh0aW1lcilcbiAgfSwgW2FjdGl2ZV0pXG5cbiAgcmV0dXJuIHN0YXR1cyA9PT0gJ3JlYWR5JyAmJiBhY3RpdmVcbn1cblxuY29uc3QgTG9hZGluZ1NwaW5uZXIgPSAoe2FjdGl2ZSwgLi4ucHJvcHN9KSA9PiB7XG4gIGNvbnN0IGN1cnJlbnQgPSB1c2VEZWZlcnJlZEFjdGl2ZShhY3RpdmUpXG4gIHJldHVybiA8ZGl2IHsuLi5wcm9wc30gY3NzPXtbc3R5bGUsICFjdXJyZW50ICYmIGhpZGRlblN0eWxlXX0gLz5cbn1cblxuZXhwb3J0IGRlZmF1bHQgTG9hZGluZ1NwaW5uZXJcbiJdfQ== */"]
|
|
12883
13134
|
}));
|
|
12884
13135
|
};var canUsePassiveEvents = (function () {
|
|
@@ -13018,9 +13269,9 @@ var useOnclickOutside = function useOnclickOutside(callback, _temp) {
|
|
|
13018
13269
|
return ref;
|
|
13019
13270
|
};const _excluded$8 = ["open", "component", "style", "hysteresis", "minFlingVelocity", "children", "onClose"];
|
|
13020
13271
|
|
|
13021
|
-
function ownKeys$
|
|
13272
|
+
function ownKeys$f(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13022
13273
|
|
|
13023
|
-
function _objectSpread$
|
|
13274
|
+
function _objectSpread$f(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$f(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$f(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
13024
13275
|
const styles = {
|
|
13025
13276
|
overlay: {
|
|
13026
13277
|
position: 'fixed',
|
|
@@ -13105,14 +13356,14 @@ const SwipeableDrawer = _ref => {
|
|
|
13105
13356
|
document.body.style.overflow = open ? 'hidden' : 'auto';
|
|
13106
13357
|
}, [open]);
|
|
13107
13358
|
return /*#__PURE__*/reactDom.exports.createPortal(jsx(Backdrop, {
|
|
13108
|
-
style: _objectSpread$
|
|
13359
|
+
style: _objectSpread$f(_objectSpread$f({}, style), styles.overlay),
|
|
13109
13360
|
renderAt: "always",
|
|
13110
13361
|
open: open,
|
|
13111
13362
|
onClick: event => {
|
|
13112
13363
|
event.stopPropagation();
|
|
13113
13364
|
onClose(event);
|
|
13114
13365
|
},
|
|
13115
|
-
children: jsxs(Component, _objectSpread$
|
|
13366
|
+
children: jsxs(Component, _objectSpread$f(_objectSpread$f(_objectSpread$f({
|
|
13116
13367
|
style: {
|
|
13117
13368
|
'--slide-position': "".concat(swipePosition, "px")
|
|
13118
13369
|
} // start swipping after moving far enough, and lock scrolling
|
|
@@ -13129,9 +13380,9 @@ const SwipeableDrawer = _ref => {
|
|
|
13129
13380
|
|
|
13130
13381
|
var SwipeableDrawer$1 = SwipeableDrawer;const _excluded$7 = ["open", "style", "children", "onClose"];
|
|
13131
13382
|
|
|
13132
|
-
function ownKeys$
|
|
13383
|
+
function ownKeys$e(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13133
13384
|
|
|
13134
|
-
function _objectSpread$
|
|
13385
|
+
function _objectSpread$e(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$e(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$e(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
13135
13386
|
const ulReset = {
|
|
13136
13387
|
marginBlockStart: 0,
|
|
13137
13388
|
marginBlockEnd: 0,
|
|
@@ -13164,7 +13415,7 @@ const mobileStyle$1 = {
|
|
|
13164
13415
|
maxHeight: 'calc(100% - var(--setting-ui-vertical-padding, 2rem))'
|
|
13165
13416
|
}
|
|
13166
13417
|
},
|
|
13167
|
-
container: _objectSpread$
|
|
13418
|
+
container: _objectSpread$e(_objectSpread$e({}, ulReset), {}, {
|
|
13168
13419
|
// TODO use dvh once we may drop iOS 14
|
|
13169
13420
|
maxHeight: 'calc(90vh - var(--setting-ui-vertical-padding, 2rem))',
|
|
13170
13421
|
color: '#ccc',
|
|
@@ -13242,17 +13493,17 @@ const desktopStyle$1 = {
|
|
|
13242
13493
|
transform: 'translateY(0)',
|
|
13243
13494
|
transition: 'opacity 0.2s ease, transform 0s'
|
|
13244
13495
|
},
|
|
13245
|
-
container: _objectSpread$
|
|
13496
|
+
container: _objectSpread$e(_objectSpread$e({}, mobileStyle$1.container), {}, {
|
|
13246
13497
|
flex: '0 var(--setting-ui-width, calc(100% - 2rem))',
|
|
13247
13498
|
maxHeight: '100%'
|
|
13248
13499
|
}),
|
|
13249
|
-
head: _objectSpread$
|
|
13500
|
+
head: _objectSpread$e(_objectSpread$e({}, mobileStyle$1.head), {}, {
|
|
13250
13501
|
color: 'var(--setting-head-color, inherit)',
|
|
13251
13502
|
background: 'var(--setting-head-background, rgba(22, 28, 36, 0.8))'
|
|
13252
13503
|
}),
|
|
13253
|
-
row: _objectSpread$
|
|
13504
|
+
row: _objectSpread$e(_objectSpread$e({}, mobileStyle$1.row), {}, {
|
|
13254
13505
|
background: 'rgba(22, 28, 36, 0.8)',
|
|
13255
|
-
'::after': _objectSpread$
|
|
13506
|
+
'::after': _objectSpread$e(_objectSpread$e({
|
|
13256
13507
|
order: 'var(--setting-check-icon-order, 0)'
|
|
13257
13508
|
}, mobileStyle$1.row['::after']), {}, {
|
|
13258
13509
|
marginLeft: '0',
|
|
@@ -13315,7 +13566,7 @@ const LoopSwitch = _ref2 => {
|
|
|
13315
13566
|
});
|
|
13316
13567
|
};
|
|
13317
13568
|
|
|
13318
|
-
const CloseButton = props => jsx("button", _objectSpread$
|
|
13569
|
+
const CloseButton = props => jsx("button", _objectSpread$e({
|
|
13319
13570
|
type: "button",
|
|
13320
13571
|
"aria-label": "Close Settings",
|
|
13321
13572
|
css: mobileStyle$1.dismiss
|
|
@@ -13330,7 +13581,7 @@ const DesktopContainer$1 = _ref3 => {
|
|
|
13330
13581
|
} = _ref3,
|
|
13331
13582
|
rest = _objectWithoutProperties(_ref3, _excluded$7);
|
|
13332
13583
|
|
|
13333
|
-
return jsx("div", _objectSpread$
|
|
13584
|
+
return jsx("div", _objectSpread$e(_objectSpread$e({
|
|
13334
13585
|
css: [style, open && desktopStyle$1.open, "production" === "production" ? "" : ";label:DesktopContainer;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Settings.js"],"names":[],"mappings":"AAmMO","file":"Settings.js","sourcesContent":["/* @jsxImportSource @emotion/react */\n/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport {useState, useEffect} from 'react'\nimport useOnclickOutside from 'react-cool-onclickoutside'\n\nimport icon from 'style/icon'\nimport {FormattedMessage} from 'context/I18n'\nimport {Button, Switch} from './buttons'\nimport SwipeableDrawer from './SwipeableDrawer'\nimport {FunctionBarExtension, TitleBarExtension} from './uiExtensions'\n\nconst ulReset = {\n  marginBlockStart: 0,\n  marginBlockEnd: 0,\n  paddingInlineStart: 0,\n}\n\nconst mobileStyle = {\n  head: {\n    position: 'sticky',\n    zIndex: '1',\n    top: '0',\n    display: 'flex',\n    alignItems: 'center',\n    padding: '1rem 1.5rem',\n    color: 'white',\n    background: '#161C24',\n    fontSize: '16px',\n    fontWeight: 'bold',\n    button: {\n      marginRight: '1rem',\n      padding: '0',\n      width: '1.5rem',\n      height: '1.5rem',\n      border: 'none',\n    },\n  },\n  overlay: {\n    '> div': {\n      // drawer container\n      background: 'var(--setting-ui-background, #161C24)',\n      maxHeight: 'calc(100% - var(--setting-ui-vertical-padding, 2rem))',\n    },\n  },\n  container: {\n    ...ulReset,\n    // TODO use dvh once we may drop iOS 14\n    maxHeight: 'calc(90vh - var(--setting-ui-vertical-padding, 2rem))',\n    color: '#ccc',\n    whiteSpace: 'nowrap',\n    borderRadius: '4px',\n    userSelect: 'none',\n    overflow: 'auto',\n    overscrollBehavior: 'contain',\n  },\n  title: {\n    padding: '12px 18px',\n  },\n  dismiss: {\n    background: `center / 1rem no-repeat url(${icon.close}), transparent`,\n  },\n  back: {\n    background: '#ccc',\n    maskImage: `var(--icon-setting-back, url(\"${icon.back}\"))`,\n    maskSize: 'contain',\n  },\n  row: {\n    cursor: 'pointer',\n    display: 'flex',\n    position: 'relative',\n    padding: '1rem 1.5rem',\n    fontSize: '16px',\n    background: '#161C24',\n    '::after': {\n      content: '\" \"',\n      marginLeft: '1rem',\n      width: '20px',\n      height: '20px',\n      display: 'inline-block',\n      color: 'white',\n      backgroundPosition: 'center',\n      backgroundSize: 'cover',\n    },\n  },\n  space: {\n    flex: '1',\n  },\n  hasOptions: {\n    '::after': {\n      backgroundImage: `url(${icon.arrowTop})`,\n      transform: 'rotate(90deg)',\n    },\n  },\n  selected: {\n    color: 'white',\n    fontWeight: 'bold',\n    '::after': {\n      backgroundColor: 'var(--setting-check-icon-color, var(--primary-highlight, white))',\n      maskImage: `url(${icon.check})`,\n    },\n  },\n}\n\n// TODO some of styles are for older version UI design, can be simplified\nconst desktopStyle = {\n  overlay: {\n    position: 'absolute',\n    zIndex: '1',\n    bottom: 'calc(5em + var(--bottom-spacing, 0rem))',\n    right: '1rem',\n    display: 'flex',\n    alignItems: 'flex-end',\n    width: '18rem',\n    height: 'calc(100% - 8rem - var(--bottom-spacing, 0rem))',\n    outline: 'none',\n    opacity: '1',\n    transform: 'translateY(-100vh)',\n  },\n  open: {\n    position: 'fixed',\n    opacity: '1',\n    transform: 'translateY(0)',\n    transition: 'opacity 0.2s ease, transform 0s',\n  },\n  container: {\n    ...mobileStyle.container,\n    flex: '0 var(--setting-ui-width, calc(100% - 2rem))',\n    maxHeight: '100%',\n  },\n  head: {\n    ...mobileStyle.head,\n    color: 'var(--setting-head-color, inherit)',\n    background: 'var(--setting-head-background, rgba(22, 28, 36, 0.8))',\n  },\n  row: {\n    ...mobileStyle.row,\n    background: 'rgba(22, 28, 36, 0.8)',\n    '::after': {\n      order: 'var(--setting-check-icon-order, 0)',\n      ...mobileStyle.row['::after'],\n      marginLeft: '0',\n      marginRight: '0.5em',\n    },\n  },\n  hasOptions: {\n    '::after': {\n      order: '0',\n      backgroundImage: `url(${icon.arrowTop})`,\n      transform: 'rotate(90deg)',\n    },\n  },\n  selected: {\n    color: 'white',\n    fontWeight: 'bold',\n    '::after': {\n      backgroundColor:\n        'var(--setting-check-icon-color, var(--primary-highlight, white))',\n      maskImage: `url(${icon.check})`,\n    },\n  },\n}\n\nconst MenuItemText = ({text = ''}) => (\n  <FormattedMessage\n    id={text}\n    defaultMessage={\n      <FormattedMessage id={`KKS.SETTING.${text}`} defaultMessage={text} />\n    }\n  />\n)\n\nconst LoopSwitch = ({style, checked, onChange}) => (\n  <li\n    role=\"menuitem\"\n    css={[style, {'::before': {display: 'none'}, '::after': {display: 'none'}}]}\n    onClick={() => {\n      onChange({name: 'loop', value: !checked, keepOpen: true})\n    }}\n  >\n    <MenuItemText text=\"KKS.PLAYER.LOOP\" />\n    <div css={mobileStyle.space} />\n    <Switch checked={checked} />\n  </li>\n)\n\nconst CloseButton = props => (\n  <button\n    type=\"button\"\n    aria-label=\"Close Settings\"\n    css={mobileStyle.dismiss}\n    {...props}\n  />\n)\n\nconst DesktopContainer = ({open, style, children, onClose, ...rest}) => (\n  <div css={[style, open && desktopStyle.open]} {...rest}>\n    {children}\n  </div>\n)\n\nconst matchValue = (a, b) => a === b || (a?.id ?? a) === (b?.id ?? b)\n\nconst Settings = ({\n  open,\n  values,\n  sections: originalSections,\n  type: uiType,\n  closeBy,\n  buttonPosition,\n  enabledSettingSections = {\n    audio: true,\n    subtitles: true,\n    quality: true,\n    speed: true,\n    loop: true,\n  }, \n  slots = {\n    root: uiType === 'desktop' ? DesktopContainer : SwipeableDrawer,\n  },\n  onChange,\n  onOpen,\n  onClose,\n}) => {\n  const sections = originalSections.filter(section => enabledSettingSections[section.name])\n  const Container = slots.root\n  const ButtonWrap =\n    buttonPosition === 'top-right' ? TitleBarExtension : FunctionBarExtension\n  const commonStyle = uiType === 'desktop' ? desktopStyle : mobileStyle\n  const [path, setPath] = useState('/')\n  useEffect(() => {\n    if (!open) {\n      setPath('/')\n    }\n  }, [open])\n\n  const ref = useOnclickOutside(\n    () => {\n      if (open && uiType === 'desktop') {\n        onClose()\n      }\n    },\n    {eventTypes: ['click']}\n  )\n  const currentSection = sections.find(it => path === `/${it.name}`)\n  const menu =\n    path === '/'\n      ? {\n          title: 'KKS.SETTING',\n          items: sections.map(({type, name, title, items = []}) => ({\n            type,\n            link: `/${name}`,\n            label: title,\n            value:\n              items.find(item => matchValue(item.value, values[name]))?.label ||\n              values[name],\n          })),\n        }\n      : {\n          title: currentSection.title,\n          items: currentSection.items.map(({value, label}) => ({\n            label,\n            checked: matchValue(values[currentSection.name], value),\n            data: value,\n          })),\n          previous: '/',\n        }\n  const navigate = dest => requestAnimationFrame(() => setPath(dest))\n  return (\n    sections.length > 0 && (\n    <>\n      <ButtonWrap position=\"right\">\n        <Button\n          startIcon=\"setting\"\n          title=\"KKS.SETTING\"\n            onClick={event =>\n              setTimeout(() => (open ? onClose(event) : onOpen(event)), 1)\n            }\n        />\n      </ButtonWrap>\n      <Container style={commonStyle.overlay} open={open} onClose={onClose}>\n        <ul role=\"menu\" ref={ref} css={commonStyle.container}>\n          <div css={commonStyle.head}>\n            {menu.previous ? (\n              <Button startIcon=\"back1\" onClick={() => navigate('/')} />\n            ) : (\n              uiType !== 'desktop' &&\n              closeBy === 'button' && <CloseButton onClick={onClose} />\n            )}\n            <FormattedMessage id={menu.title} />\n          </div>\n          {menu.items.map(({type, label, link, value, data, checked}) =>\n            type === 'switch' ? (\n              <LoopSwitch\n                style={commonStyle.row}\n                checked={values.loop}\n                onChange={() =>\n                    onChange({\n                      name: 'loop',\n                      value: !values.loop,\n                      keepOpen: true,\n                    })\n                }\n              />\n            ) : (\n              <li\n                role={link ? 'menuitem' : 'menuitemradio'}\n                aria-checked={checked}\n                css={[\n                  commonStyle.row,\n                  link && commonStyle.hasOptions,\n                  checked && commonStyle.selected,\n                ]}\n                onClick={() =>\n                  link\n                    ? navigate(link)\n                    : onChange({name: currentSection.name, value: data})\n                }\n              >\n                <MenuItemText text={label} />\n                <div css={mobileStyle.space} />\n                {value && <MenuItemText text={value.toString()} />}\n              </li>\n            )\n          )}\n        </ul>\n      </Container>\n    </>\n    )\n  )\n}\n\nexport default Settings\n"]} */"]
|
|
13335
13586
|
}, rest), {}, {
|
|
13336
13587
|
children: children
|
|
@@ -13485,9 +13736,9 @@ const Settings = _ref4 => {
|
|
|
13485
13736
|
};const _excluded$6 = ["open", "containerRef", "children", "onClose"],
|
|
13486
13737
|
_excluded2$2 = ["buttonIcon", "uiType", "children", "slots"];
|
|
13487
13738
|
|
|
13488
|
-
function ownKeys$
|
|
13739
|
+
function ownKeys$d(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13489
13740
|
|
|
13490
|
-
function _objectSpread$
|
|
13741
|
+
function _objectSpread$d(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$d(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$d(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
13491
13742
|
const containerStyle$3 = {
|
|
13492
13743
|
position: 'absolute',
|
|
13493
13744
|
zIndex: '2',
|
|
@@ -13544,7 +13795,7 @@ const DesktopContainer = _ref2 => {
|
|
|
13544
13795
|
} = _ref2,
|
|
13545
13796
|
rest = _objectWithoutProperties(_ref2, _excluded$6);
|
|
13546
13797
|
|
|
13547
|
-
return jsx("div", _objectSpread$
|
|
13798
|
+
return jsx("div", _objectSpread$d(_objectSpread$d({
|
|
13548
13799
|
css: [desktopContainerStyle$1, open && DesktopOpenStyle, "production" === "production" ? "" : ";label:DesktopContainer;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3REkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC41cyBlYXNlLCB0cmFuc2Zvcm0gMHMgMC41cyBsaW5lYXInLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5cbmNvbnN0IERlZmF1bHRDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW59KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tjb250YWluZXJTdHlsZSwgb3BlbiAmJiBvcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAnMScsXG4gIGJvdHRvbTogJ2NhbGMoNWVtICsgdmFyKC0tYm90dG9tLXNwYWNpbmcsIDByZW0pKScsXG4gIHJpZ2h0OiAnMXJlbScsXG4gIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gIG91dGxpbmU6ICdub25lJyxcbiAgb3BhY2l0eTogJzAnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC0xMDB2aCknLFxuICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcyBsaW5lYXIgMC4ycycsXG59XG5cbmNvbnN0IERlc2t0b3BPcGVuU3R5bGUgPSB7XG4gIG9wYWNpdHk6ICcxJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSgwKScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzJyxcbn1cblxuY29uc3QgRGVza3RvcENvbnRhaW5lciA9ICh7b3BlbiwgY29udGFpbmVyUmVmLCBjaGlsZHJlbiwgb25DbG9zZSwgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W2Rlc2t0b3BDb250YWluZXJTdHlsZSwgb3BlbiAmJiBEZXNrdG9wT3BlblN0eWxlXX1cbiAgICByZWY9e2NvbnRhaW5lclJlZn1cbiAgICBvbkNsaWNrPXtldmVudCA9PiBldmVudC5zdG9wUHJvcGFnYXRpb24oKX1cbiAgICB7Li4ucmVzdH1cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9kaXY+XG4pXG5cbmNvbnN0IE92ZXJsYXlQYW5lbCA9ICh7XG4gIGJ1dHRvbkljb24sXG4gIHVpVHlwZSA9IGlzRGVza3RvcCgpID8gJ2Rlc2t0b3AnIDogJ21vYmlsZScsXG4gIGNoaWxkcmVuLFxuICBzbG90cyA9IHtcbiAgICByb290OiB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IERlc2t0b3BDb250YWluZXIgOiBEZWZhdWx0Q29udGFpbmVyLFxuICB9LFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IGNvbXBvbmVudHMgPSB7XG4gICAgcm9vdDogc2xvdHMucm9vdCxcbiAgfVxuICBjb25zdCBCdXR0b25XcmFwID1cbiAgICB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IEZ1bmN0aW9uQmFyRXh0ZW5zaW9uIDogVGl0bGVCYXJFeHRlbnNpb25cbiAgY29uc3QgW29wZW4sIHNldE9wZW5dID0gdXNlU3RhdGUoZmFsc2UpXG4gIGNvbnN0IG9uQnV0dG9uQ2xpY2sgPSAoKSA9PiBzZXRUaW1lb3V0KCgpID0+IHNldE9wZW4oIW9wZW4pLCAxKVxuICBjb25zdCBvbkNsb3NlID0gKCkgPT4gc2V0T3BlbihmYWxzZSlcbiAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVmID0gdXNlT25jbGlja091dHNpZGUoXG4gICAgKCkgPT4ge1xuICAgICAgaWYgKG9wZW4gJiYgdWlUeXBlID09PSAnZGVza3RvcCcpIHtcbiAgICAgICAgb25DbG9zZSgpXG4gICAgICB9XG4gICAgfSxcbiAgICB7ZXZlbnRUeXBlczogWydjbGljayddfVxuICApXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmVmKGNvbnRhaW5lclJlZi5jdXJyZW50KVxuICAgIHJldHVybiBvbihjb250YWluZXJSZWYuY3VycmVudCwgJ2Nsb3NlLW1lbnUnLCBvbkNsb3NlKVxuICB9LCBbXSlcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8QnV0dG9uV3JhcCBwb3NpdGlvbj1cInJpZ2h0XCI+XG4gICAgICAgIDxCdXR0b24gc3RhcnRJY29uPXtidXR0b25JY29ufSBvbkNsaWNrPXtvbkJ1dHRvbkNsaWNrfSAvPlxuICAgICAgPC9CdXR0b25XcmFwPlxuICAgICAgPGNvbXBvbmVudHMucm9vdFxuICAgICAgICBjb250YWluZXJSZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgb3Blbj17b3Blbn1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvY29tcG9uZW50cy5yb290PlxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IE92ZXJsYXlQYW5lbFxuIl19 */"],
|
|
13549
13800
|
ref: containerRef,
|
|
13550
13801
|
onClick: event => event.stopPropagation()
|
|
@@ -13593,7 +13844,7 @@ const OverlayPanel = _ref3 => {
|
|
|
13593
13844
|
startIcon: buttonIcon,
|
|
13594
13845
|
onClick: onButtonClick
|
|
13595
13846
|
})
|
|
13596
|
-
}), jsx(components.root, _objectSpread$
|
|
13847
|
+
}), jsx(components.root, _objectSpread$d(_objectSpread$d({
|
|
13597
13848
|
containerRef: containerRef,
|
|
13598
13849
|
open: open
|
|
13599
13850
|
}, rest), {}, {
|
|
@@ -13605,8 +13856,14 @@ const menuItemStyle = {
|
|
|
13605
13856
|
padding: 'var(--menu-item-padding, 0.5em 1em) ',
|
|
13606
13857
|
display: 'flex',
|
|
13607
13858
|
alignItems: 'center',
|
|
13859
|
+
minWidth: 0,
|
|
13608
13860
|
color: 'rgba(255, 255, 255, 0.6)',
|
|
13609
|
-
background: 'var(--menu-item-background, rgba(255, 255, 255, 0.08))'
|
|
13861
|
+
background: 'var(--menu-item-background, rgba(255, 255, 255, 0.08))',
|
|
13862
|
+
'> div': {
|
|
13863
|
+
overflow: 'hidden',
|
|
13864
|
+
whiteSpace: 'nowrap',
|
|
13865
|
+
textOverflow: 'ellipsis'
|
|
13866
|
+
}
|
|
13610
13867
|
};
|
|
13611
13868
|
const menuItemSelectedStyle = {
|
|
13612
13869
|
color: '#FFF',
|
|
@@ -13614,7 +13871,7 @@ const menuItemSelectedStyle = {
|
|
|
13614
13871
|
'::after': {
|
|
13615
13872
|
content: '" "',
|
|
13616
13873
|
display: 'inline-block',
|
|
13617
|
-
|
|
13874
|
+
flex: '0 0 1em',
|
|
13618
13875
|
height: '1em',
|
|
13619
13876
|
marginLeft: '0.5em',
|
|
13620
13877
|
backgroundColor: 'var(--setting-check-icon-color, #fff)',
|
|
@@ -13630,22 +13887,25 @@ const MenuItem = _ref => {
|
|
|
13630
13887
|
onClick
|
|
13631
13888
|
} = _ref;
|
|
13632
13889
|
return jsx("div", {
|
|
13633
|
-
css: [menuItemStyle, selected && menuItemSelectedStyle, "production" === "production" ? "" : ";label:MenuItem;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13890
|
+
css: [menuItemStyle, selected && menuItemSelectedStyle, "production" === "production" ? "" : ";label:MenuItem;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lbnVJdGVtLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DSSIsImZpbGUiOiJNZW51SXRlbS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IGljb24gZnJvbSAnc3R5bGUvaWNvbidcblxuY29uc3QgbWVudUl0ZW1TdHlsZSA9IHtcbiAgcGFkZGluZzogJ3ZhcigtLW1lbnUtaXRlbS1wYWRkaW5nLCAwLjVlbSAxZW0pICcsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAwLFxuICBjb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC42KScsXG4gIGJhY2tncm91bmQ6ICd2YXIoLS1tZW51LWl0ZW0tYmFja2dyb3VuZCwgcmdiYSgyNTUsIDI1NSwgMjU1LCAwLjA4KSknLCBcbiAgJz4gZGl2Jzoge1xuICAgIG92ZXJmbG93OiAnaGlkZGVuJyxcbiAgICB3aGl0ZVNwYWNlOiAnbm93cmFwJyxcbiAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gIH1cbn1cblxuY29uc3QgbWVudUl0ZW1TZWxlY3RlZFN0eWxlID0ge1xuICBjb2xvcjogJyNGRkYnLFxuICBmb250V2VpZ2h0OiAnNjAwJyxcbiAgJzo6YWZ0ZXInOiB7XG4gICAgY29udGVudDogJ1wiIFwiJyxcbiAgICBkaXNwbGF5OiAnaW5saW5lLWJsb2NrJyxcbiAgICBmbGV4OiAnMCAwIDFlbScsXG4gICAgaGVpZ2h0OiAnMWVtJyxcbiAgICBtYXJnaW5MZWZ0OiAnMC41ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXNldHRpbmctY2hlY2staWNvbi1jb2xvciwgI2ZmZiknLFxuICAgIG1hc2tTaXplOiAnY29udGFpbicsXG4gICAgbWFza0ltYWdlOiBgdXJsKCR7aWNvbi5jaGVja30pYCxcbiAgfSxcbn1cblxuY29uc3QgTWVudUl0ZW0gPSAoe2xhYmVsLCBzZWxlY3RlZCwgb25DbGlja30pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W21lbnVJdGVtU3R5bGUsIHNlbGVjdGVkICYmIG1lbnVJdGVtU2VsZWN0ZWRTdHlsZV19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgPlxuICAgIDxkaXY+e2xhYmVsfTwvZGl2PlxuICA8L2Rpdj5cbilcblxuZXhwb3J0IGRlZmF1bHQgTWVudUl0ZW1cbiJdfQ== */"],
|
|
13634
13891
|
onClick: onClick,
|
|
13635
|
-
children:
|
|
13892
|
+
children: jsx("div", {
|
|
13893
|
+
children: label
|
|
13894
|
+
})
|
|
13636
13895
|
});
|
|
13637
13896
|
};
|
|
13638
13897
|
|
|
13639
|
-
var MenuItem$1 = MenuItem;function ownKeys$
|
|
13898
|
+
var MenuItem$1 = MenuItem;function ownKeys$c(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13640
13899
|
|
|
13641
|
-
function _objectSpread$
|
|
13900
|
+
function _objectSpread$c(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$c(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$c(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
13642
13901
|
const landscapeStyle = {
|
|
13643
13902
|
display: 'flex',
|
|
13644
13903
|
flexWrap: 'wrap',
|
|
13645
13904
|
justifyContent: 'space-between',
|
|
13646
13905
|
'> div': {
|
|
13647
13906
|
boxSizing: 'border-box',
|
|
13648
|
-
flex: '0 0 50%'
|
|
13907
|
+
flex: '0 0 50%',
|
|
13908
|
+
minWidth: 0
|
|
13649
13909
|
},
|
|
13650
13910
|
'> div:not(:first-of-type)': {
|
|
13651
13911
|
marginTop: 0,
|
|
@@ -13740,7 +14000,7 @@ const LanguageMenu = _ref => {
|
|
|
13740
14000
|
onChange
|
|
13741
14001
|
} = _ref;
|
|
13742
14002
|
return jsxs("div", {
|
|
13743
|
-
css: [containerStyle$2, twoColumnStyle, uiType === 'desktop' && [desktopContainerStyle, desktop2ColumnStyle], "production" === "production" ? "" : ";label:LanguageMenu;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14003
|
+
css: [containerStyle$2, twoColumnStyle, uiType === 'desktop' && [desktopContainerStyle, desktop2ColumnStyle], "production" === "production" ? "" : ";label:LanguageMenu;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxhbmd1YWdlTWVudS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4R0kiLCJmaWxlIjoiTGFuZ3VhZ2VNZW51LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHtCdXR0b259IGZyb20gJy4vYnV0dG9ucydcbmltcG9ydCBNZW51SXRlbSBmcm9tICcuL01lbnVJdGVtJ1xuXG5jb25zdCBsYW5kc2NhcGVTdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBmbGV4V3JhcDogJ3dyYXAnLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxuICAnPiBkaXYnOiB7XG4gICAgYm94U2l6aW5nOiAnYm9yZGVyLWJveCcsXG4gICAgZmxleDogJzAgMCA1MCUnLFxuICAgIG1pbldpZHRoOiAwLFxuICB9LFxuICAnPiBkaXY6bm90KDpmaXJzdC1vZi10eXBlKSc6IHtcbiAgICBtYXJnaW5Ub3A6IDAsXG4gICAgZmxleDogJzAgMCBjYWxjKDUwJSAtIDFweCknLFxuICB9LFxuICBocjoge1xuICAgIGhlaWdodDogJ2F1dG8nLFxuICAgIGJvcmRlckxlZnQ6ICcxcHggc29saWQgdHJhbnNwYXJlbnQnLFxuICB9LFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxNnB4JyxcbiAgYmFja2dyb3VuZDogJyMyNjI2MjYnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgaDM6IHtcbiAgICBtYXJnaW46IDAsXG4gICAgJ21hcmdpbi1ibG9jay1zdGFydCc6IDAsXG4gICAgJ21hcmdpbi1ibG9jay1lbmQnOiAwLFxuICAgIHBhZGRpbmc6ICcwLjZlbSAxZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBib3JkZXJSYWRpdXM6ICc0cHggNHB4IDAgMCcsXG4gICAgZm9udFNpemU6ICcxN3B4JyxcbiAgICBidXR0b246IHtcbiAgICAgIGZvbnRTaXplOiAnMC42ZW0nLFxuICAgICAgbWFyZ2luUmlnaHQ6ICcwLjVlbScsXG4gICAgfSxcbiAgfSxcbn1cblxuY29uc3QgdHdvQ29sdW1uU3R5bGUgPSB7XG4gIGhyOiB7XG4gICAgYm9yZGVyOiAnbm9uZScsXG4gIH0sXG4gICc+IGRpdiAnOiB7XG4gICAgJz4gZGl2Om5vdCg6Zmlyc3Qtb2YtdHlwZSknOiB7XG4gICAgICBtYXJnaW5Ub3A6ICcwLjY2ZW0nLFxuICAgIH0sXG4gICAgJ0BtZWRpYSAob3JpZW50YXRpb246IGxhbmRzY2FwZSknOiBsYW5kc2NhcGVTdHlsZSxcbiAgfSxcbiAgJz4gZGl2ID4gZGl2ID4gZGl2OmZpcnN0LW9mLXR5cGUnOiB7XG4gICAgcGFkZGluZzogJzAuNmVtIDEuMWVtJyxcbiAgICBmb250U2l6ZTogJzE0cHgnLFxuICAgIGNvbG9yOiAnI2FhYWViNScsXG4gICAgYmFja2dyb3VuZDogJ3ZhcigtLW1lbnUtaXRlbS1iYWNrZ3JvdW5kLCAjMjYyNjI2KScsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgIHRleHRPdmVyZmxvdzogJ2VsbGlwc2lzJyxcbiAgfSxcbn1cblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwYWRkaW5nQm90dG9tOiAnMS41ZW0nLFxuICB3aWR0aDogJzM0ZW0nLFxuICBtaW5IZWlnaHQ6ICczMC41JScsXG4gIG1heEhlaWdodDogJzYzLjUlJyxcbiAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgYmFja2dyb3VuZDogJ3JnYmEoMCwgMCwgMCwgMC42MCknLFxuICAnLS1tZW51LWl0ZW0tYmFja2dyb3VuZCc6ICd0cmFuc3BhcmVudCcsXG4gICctLW1lbnUtaXRlbS1wYWRkaW5nJzogJzAuNjZlbSAxLjVlbScsXG4gIGgzOiB7XG4gICAgcGFkZGluZzogJzAuNjZlbSAxLjVlbScsXG4gICAgZm9udFNpemU6ICcxNnB4JyxcbiAgICBjb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC42MCknLFxuICAgIGJhY2tncm91bmQ6ICdyZ2JhKDAsIDAsIDAsIDAuODApJyxcbiAgfSxcbn1cblxuY29uc3QgZGVza3RvcDJDb2x1bW5TdHlsZSA9IHtcbiAgJz4gZGl2JzogbGFuZHNjYXBlU3R5bGUsXG4gICc+IGRpdiBocic6IHtcbiAgICBmb250U2l6ZTogJzE1MCUnLFxuICAgIGJvcmRlckxlZnQ6ICcxcHggc29saWQgIHJnYmEoMjU1LCAyNTUsIDI1NSwgMC4yMCknLFxuICB9LFxuICAnPiBkaXYgPiBkaXYnOiB7XG4gICAgcGFkZGluZzogJzAgMWVtJyxcbiAgfSxcbiAgJz4gZGl2ID4gZGl2ID4gZGl2OmZpcnN0LW9mLXR5cGUnOiB7XG4gICAgcGFkZGluZzogJzAuNjZlbSAwLjVlbScsXG4gICAgY29sb3I6ICcjZmZmJyxcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIGZvbnRXZWlnaHQ6ICc2MDAnLFxuICB9LFxufVxuXG5jb25zdCBjbG9zZU1lbnUgPSBldmVudCA9PlxuICBldmVudC5jdXJyZW50VGFyZ2V0LmRpc3BhdGNoRXZlbnQoXG4gICAgbmV3IEN1c3RvbUV2ZW50KCdjbG9zZS1tZW51Jywge2J1YmJsZXM6IHRydWV9KVxuICApXG5cbmNvbnN0IExhbmd1YWdlTWVudSA9ICh7XG4gIHVpVHlwZSA9ICdtb2JpbGUnLFxuICB0aXRsZSA9ICfpn7Plo7Ag44O7IOWtl+W5lScsXG4gIHNlY3Rpb25zID0gWyfpn7Plo7AnLCAn5a2X5bmVJ10sXG4gIHNlY3Rpb25PcHRpb25zID0gW10sXG4gIG9uQ2hhbmdlLFxufSkgPT4gKFxuICA8ZGl2XG4gICAgY3NzPXtbXG4gICAgICBjb250YWluZXJTdHlsZSxcbiAgICAgIHR3b0NvbHVtblN0eWxlLFxuICAgICAgdWlUeXBlID09PSAnZGVza3RvcCcgJiYgW2Rlc2t0b3BDb250YWluZXJTdHlsZSwgZGVza3RvcDJDb2x1bW5TdHlsZV0sXG4gICAgXX1cbiAgPlxuICAgIDxoMz5cbiAgICAgIHt1aVR5cGUgIT09ICdkZXNrdG9wJyAmJiA8QnV0dG9uIHN0YXJ0SWNvbj1cImNsb3NlXCIgb25DbGljaz17Y2xvc2VNZW51fSAvPn1cbiAgICAgIHt0aXRsZX1cbiAgICA8L2gzPlxuICAgIDxkaXY+XG4gICAgICA8ZGl2PlxuICAgICAgICA8ZGl2PntzZWN0aW9uc1swXX08L2Rpdj5cbiAgICAgICAge3NlY3Rpb25PcHRpb25zWzBdLm1hcChvcHRpb24gPT4gKFxuICAgICAgICAgIDxNZW51SXRlbSB7Li4ub3B0aW9ufSBvbkNsaWNrPXtldmVudCA9PiBvbkNoYW5nZShldmVudCwgb3B0aW9uKX0gLz5cbiAgICAgICAgKSl9XG4gICAgICA8L2Rpdj5cbiAgICAgIDxociAvPlxuICAgICAgPGRpdj5cbiAgICAgICAgPGRpdj57c2VjdGlvbnNbMV19PC9kaXY+XG4gICAgICAgIHtzZWN0aW9uT3B0aW9uc1sxXS5tYXAob3B0aW9uID0+IChcbiAgICAgICAgICA8TWVudUl0ZW0gey4uLm9wdGlvbn0gb25DbGljaz17ZXZlbnQgPT4gb25DaGFuZ2UoZXZlbnQsIG9wdGlvbil9IC8+XG4gICAgICAgICkpfVxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuKVxuXG5MYW5ndWFnZU1lbnUuc3R5bGVzID0gY29udGFpbmVyU3R5bGVcbkxhbmd1YWdlTWVudS5kZXNrdG9wU3R5bGVzID0gZGVza3RvcENvbnRhaW5lclN0eWxlXG5cbmV4cG9ydCBkZWZhdWx0IExhbmd1YWdlTWVudVxuIl19 */"],
|
|
13744
14004
|
children: [jsxs("h3", {
|
|
13745
14005
|
children: [uiType !== 'desktop' && jsx(Button, {
|
|
13746
14006
|
startIcon: "close",
|
|
@@ -13750,13 +14010,13 @@ const LanguageMenu = _ref => {
|
|
|
13750
14010
|
children: [jsxs("div", {
|
|
13751
14011
|
children: [jsx("div", {
|
|
13752
14012
|
children: sections[0]
|
|
13753
|
-
}), sectionOptions[0].map(option => jsx(MenuItem$1, _objectSpread$
|
|
14013
|
+
}), sectionOptions[0].map(option => jsx(MenuItem$1, _objectSpread$c(_objectSpread$c({}, option), {}, {
|
|
13754
14014
|
onClick: event => onChange(event, option)
|
|
13755
14015
|
})))]
|
|
13756
14016
|
}), jsx("hr", {}), jsxs("div", {
|
|
13757
14017
|
children: [jsx("div", {
|
|
13758
14018
|
children: sections[1]
|
|
13759
|
-
}), sectionOptions[1].map(option => jsx(MenuItem$1, _objectSpread$
|
|
14019
|
+
}), sectionOptions[1].map(option => jsx(MenuItem$1, _objectSpread$c(_objectSpread$c({}, option), {}, {
|
|
13760
14020
|
onClick: event => onChange(event, option)
|
|
13761
14021
|
})))]
|
|
13762
14022
|
})]
|
|
@@ -13767,9 +14027,9 @@ const LanguageMenu = _ref => {
|
|
|
13767
14027
|
LanguageMenu.styles = containerStyle$2;
|
|
13768
14028
|
LanguageMenu.desktopStyles = desktopContainerStyle;const _excluded$5 = ["style", "animation", "onClick"];
|
|
13769
14029
|
|
|
13770
|
-
function ownKeys$
|
|
14030
|
+
function ownKeys$b(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13771
14031
|
|
|
13772
|
-
function _objectSpread$
|
|
14032
|
+
function _objectSpread$b(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$b(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$b(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
13773
14033
|
|
|
13774
14034
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
13775
14035
|
const panelStyle = {
|
|
@@ -13816,7 +14076,7 @@ const PlayPanel = _ref => {
|
|
|
13816
14076
|
} = _ref,
|
|
13817
14077
|
rest = _objectWithoutProperties(_ref, _excluded$5);
|
|
13818
14078
|
|
|
13819
|
-
return jsx("div", _objectSpread$
|
|
14079
|
+
return jsx("div", _objectSpread$b({
|
|
13820
14080
|
style: {
|
|
13821
14081
|
'--animation-name': fadeout[animation],
|
|
13822
14082
|
'--center-icon': animation ? "url(".concat(iconUrls["".concat(animation, "Circle")], ")") : ''
|
|
@@ -13911,9 +14171,9 @@ const linkMediaVolume = getOptions => {
|
|
|
13911
14171
|
|
|
13912
14172
|
const getSliderOrientation = slider => slider && isDesktop() && !isIOS() && (slider === 'horizontal' ? slider : 'vertical');const _excluded$4 = ["slider", "style", "subscribe", "onChange", "toggleMute", "onAudioMuteSettingChange"];
|
|
13913
14173
|
|
|
13914
|
-
function ownKeys$
|
|
14174
|
+
function ownKeys$a(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13915
14175
|
|
|
13916
|
-
function _objectSpread$
|
|
14176
|
+
function _objectSpread$a(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$a(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$a(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
13917
14177
|
const baseStyles = {
|
|
13918
14178
|
padding: '0 0.5em',
|
|
13919
14179
|
display: 'flex',
|
|
@@ -13977,7 +14237,7 @@ const VolumeControl = _ref => {
|
|
|
13977
14237
|
react.exports.useEffect(() => subscribe(setState), []);
|
|
13978
14238
|
const iconName = volume === 0 || muted ? 'mute' : volume < 0.5 ? 'volumeLow' : 'volumeHigh'; // TODO: consider the condition in larger screen (in vertical style)
|
|
13979
14239
|
|
|
13980
|
-
return jsxs("div", _objectSpread$
|
|
14240
|
+
return jsxs("div", _objectSpread$a(_objectSpread$a({
|
|
13981
14241
|
css: [baseStyles, sliderOrientation && {
|
|
13982
14242
|
'> div': sliderStyles[sliderOrientation]
|
|
13983
14243
|
}, sliderOrientation === 'vertical' && {
|
|
@@ -14022,9 +14282,9 @@ const VolumeControl = _ref => {
|
|
|
14022
14282
|
document.body.appendChild(script);
|
|
14023
14283
|
});const _excluded2$1 = ["onChange"];
|
|
14024
14284
|
|
|
14025
|
-
function ownKeys$
|
|
14285
|
+
function ownKeys$9(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
14026
14286
|
|
|
14027
|
-
function _objectSpread$
|
|
14287
|
+
function _objectSpread$9(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$9(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$9(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
14028
14288
|
const SENDER_URL = 'https://www.gstatic.com/cv/js/sender/v1/cast_sender.js?loadCastFramework=1';
|
|
14029
14289
|
|
|
14030
14290
|
const getContext = () => {
|
|
@@ -14040,7 +14300,7 @@ const getCastReceiverState = () => {
|
|
|
14040
14300
|
const castState = context.getCastState();
|
|
14041
14301
|
const currentSession = context.getCurrentSession();
|
|
14042
14302
|
const mediaTitle = (_currentSession$getMe = currentSession.getMediaSession()) === null || _currentSession$getMe === void 0 ? void 0 : _currentSession$getMe.media.metadata.title;
|
|
14043
|
-
return _objectSpread$
|
|
14303
|
+
return _objectSpread$9({
|
|
14044
14304
|
castState,
|
|
14045
14305
|
deviceName: castState === 'CONNECTED' && currentSession.getCastDevice().friendlyName,
|
|
14046
14306
|
mediaTitle
|
|
@@ -14128,7 +14388,7 @@ const getMediaInfo = _ref18 => {
|
|
|
14128
14388
|
modulesConfig
|
|
14129
14389
|
} = values;
|
|
14130
14390
|
const customData = {
|
|
14131
|
-
drm: _objectSpread$
|
|
14391
|
+
drm: _objectSpread$9(_objectSpread$9({}, drm === null || drm === void 0 ? void 0 : drm.widevine), {}, {
|
|
14132
14392
|
licenseUrl: drm === null || drm === void 0 ? void 0 : (_drm$widevine = drm.widevine) === null || _drm$widevine === void 0 ? void 0 : _drm$widevine.licenseUri
|
|
14133
14393
|
}),
|
|
14134
14394
|
locale,
|
|
@@ -14183,7 +14443,7 @@ const startCastVideo = async (source, onLoad, _ref19) => {
|
|
|
14183
14443
|
drm
|
|
14184
14444
|
} = source || {};
|
|
14185
14445
|
const customData = {
|
|
14186
|
-
drm: _objectSpread$
|
|
14446
|
+
drm: _objectSpread$9(_objectSpread$9({}, drm === null || drm === void 0 ? void 0 : drm.widevine), {}, {
|
|
14187
14447
|
licenseUrl: drm === null || drm === void 0 ? void 0 : (_drm$widevine2 = drm.widevine) === null || _drm$widevine2 === void 0 ? void 0 : _drm$widevine2.licenseUri
|
|
14188
14448
|
}),
|
|
14189
14449
|
locale,
|
|
@@ -14244,14 +14504,14 @@ const loadMedia = _ref20 => {
|
|
|
14244
14504
|
const sourceInfo = source && getSource(source);
|
|
14245
14505
|
const contentId = paramContentId || (sourceInfo === null || sourceInfo === void 0 ? void 0 : sourceInfo.src);
|
|
14246
14506
|
|
|
14247
|
-
const drm = (sourceInfo === null || sourceInfo === void 0 ? void 0 : sourceInfo.drm) && _objectSpread$
|
|
14507
|
+
const drm = (sourceInfo === null || sourceInfo === void 0 ? void 0 : sourceInfo.drm) && _objectSpread$9(_objectSpread$9({}, (_sourceInfo$drm = sourceInfo.drm) === null || _sourceInfo$drm === void 0 ? void 0 : _sourceInfo$drm.widevine), {}, {
|
|
14248
14508
|
licenseUrl: (_sourceInfo$drm2 = sourceInfo.drm) === null || _sourceInfo$drm2 === void 0 ? void 0 : (_sourceInfo$drm2$wide = _sourceInfo$drm2.widevine) === null || _sourceInfo$drm2$wide === void 0 ? void 0 : _sourceInfo$drm2$wide.licenseUri
|
|
14249
14509
|
});
|
|
14250
14510
|
|
|
14251
14511
|
const request = new chrome.cast.media.LoadRequest(Object.assign(new chrome.cast.media.MediaInfo(contentId), {
|
|
14252
14512
|
contentId,
|
|
14253
14513
|
contentID: contentId,
|
|
14254
|
-
customData: _objectSpread$
|
|
14514
|
+
customData: _objectSpread$9(_objectSpread$9(_objectSpread$9({
|
|
14255
14515
|
itemType: contentType
|
|
14256
14516
|
}, apiConfig), {}, {
|
|
14257
14517
|
customHeaders: apiConfig === null || apiConfig === void 0 ? void 0 : apiConfig.headers,
|
|
@@ -14290,9 +14550,9 @@ const linkCast = _ref21 => {
|
|
|
14290
14550
|
|
|
14291
14551
|
var _templateObject$1;
|
|
14292
14552
|
|
|
14293
|
-
function ownKeys$
|
|
14553
|
+
function ownKeys$8(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
14294
14554
|
|
|
14295
|
-
function _objectSpread$
|
|
14555
|
+
function _objectSpread$8(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$8(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$8(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
14296
14556
|
const mainStyle = {
|
|
14297
14557
|
background: '#fff',
|
|
14298
14558
|
maskImage: "var(--icon-castConntecting0, url(\"".concat(iconUrls.cast, "\"))"),
|
|
@@ -14324,7 +14584,7 @@ const CastButton$1 = _ref => {
|
|
|
14324
14584
|
setState(connectionState);
|
|
14325
14585
|
onChange === null || onChange === void 0 ? void 0 : onChange(connectionState);
|
|
14326
14586
|
}), [onChange]);
|
|
14327
|
-
return jsx(Button, _objectSpread$
|
|
14587
|
+
return jsx(Button, _objectSpread$8({
|
|
14328
14588
|
style: state === 'NO_DEVICES_AVAILABLE' && {
|
|
14329
14589
|
display: 'none'
|
|
14330
14590
|
},
|
|
@@ -14489,9 +14749,9 @@ const CastOverlay = _ref => {
|
|
|
14489
14749
|
CastOverlay.propTypes = {
|
|
14490
14750
|
onBack: PropTypes.func
|
|
14491
14751
|
};
|
|
14492
|
-
var CastOverlay$1 = CastOverlay;function ownKeys$
|
|
14752
|
+
var CastOverlay$1 = CastOverlay;function ownKeys$7(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
14493
14753
|
|
|
14494
|
-
function _objectSpread$
|
|
14754
|
+
function _objectSpread$7(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$7(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$7(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
14495
14755
|
|
|
14496
14756
|
const CastUi = _ref => {
|
|
14497
14757
|
let {
|
|
@@ -14522,7 +14782,7 @@ const CastUi = _ref => {
|
|
|
14522
14782
|
};
|
|
14523
14783
|
|
|
14524
14784
|
return jsxs(Fragment, {
|
|
14525
|
-
children: [connectionState === CastState.CONNECTED && jsx(CastOverlay$1, _objectSpread$
|
|
14785
|
+
children: [connectionState === CastState.CONNECTED && jsx(CastOverlay$1, _objectSpread$7({
|
|
14526
14786
|
onBack: onBack
|
|
14527
14787
|
}, castContent)), jsx(FunctionBarExtension, {
|
|
14528
14788
|
children: jsx(slots.CastButton, {
|
|
@@ -16146,9 +16406,9 @@ class UITextDisplayer {
|
|
|
16146
16406
|
}
|
|
16147
16407
|
}
|
|
16148
16408
|
|
|
16149
|
-
}function ownKeys$
|
|
16409
|
+
}function ownKeys$6(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
16150
16410
|
|
|
16151
|
-
function _objectSpread$
|
|
16411
|
+
function _objectSpread$6(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$6(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$6(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
16152
16412
|
|
|
16153
16413
|
const getQualityItem = track => ({
|
|
16154
16414
|
id: track.originalVideoId,
|
|
@@ -16233,8 +16493,8 @@ const loadShaka = async function (videoElement) {
|
|
|
16233
16493
|
}
|
|
16234
16494
|
});
|
|
16235
16495
|
player.attach(videoElement);
|
|
16236
|
-
player.configure(_objectSpread$
|
|
16237
|
-
manifest: _objectSpread$
|
|
16496
|
+
player.configure(_objectSpread$6(_objectSpread$6({}, config), {}, {
|
|
16497
|
+
manifest: _objectSpread$6({
|
|
16238
16498
|
dash: {
|
|
16239
16499
|
ignoreSuggestedPresentationDelay: true
|
|
16240
16500
|
},
|
|
@@ -16242,13 +16502,13 @@ const loadShaka = async function (videoElement) {
|
|
|
16242
16502
|
maxAttempts: 6
|
|
16243
16503
|
}
|
|
16244
16504
|
}, config.manifest),
|
|
16245
|
-
streaming: _objectSpread$
|
|
16505
|
+
streaming: _objectSpread$6(_objectSpread$6({
|
|
16246
16506
|
autoLowLatencyMode: true,
|
|
16247
16507
|
// To reduce the unseekable range at the start of the manifests.
|
|
16248
16508
|
// See: https://github.com/shaka-project/shaka-player/issues/3526
|
|
16249
16509
|
safeSeekOffset: 0,
|
|
16250
16510
|
rebufferingGoal: 0
|
|
16251
|
-
},
|
|
16511
|
+
}, isSafari() && {
|
|
16252
16512
|
preferNativeHls: true
|
|
16253
16513
|
}), config.streaming)
|
|
16254
16514
|
}, options.container && document.fullscreenEnabled && {
|
|
@@ -16336,7 +16596,7 @@ const loadShaka = async function (videoElement) {
|
|
|
16336
16596
|
responseHandlers: [rewriteDashManifest]
|
|
16337
16597
|
};
|
|
16338
16598
|
|
|
16339
|
-
if (
|
|
16599
|
+
if (isSafari()) {
|
|
16340
16600
|
setupKKFariplay(player, extensionOptions);
|
|
16341
16601
|
}
|
|
16342
16602
|
|
|
@@ -16453,9 +16713,9 @@ const loadShaka = async function (videoElement) {
|
|
|
16453
16713
|
return player;
|
|
16454
16714
|
};const _excluded$2 = ["source", "playbackState", "currentTime", "playbackRate", "videoResolution", "textTracks", "textTrack", "audio", "liveResume", "iOSFullscreenDetectThreshold", "plugins", "shaka", "bitmovin", "license", "validationHost", "videoRef", "playerRef", "onPlayerLoaded", "onPlaybackStateChange", "onBlockedAutoplay", "onPlaylogFired"];
|
|
16455
16715
|
|
|
16456
|
-
function ownKeys$
|
|
16716
|
+
function ownKeys$5(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
16457
16717
|
|
|
16458
|
-
function _objectSpread$
|
|
16718
|
+
function _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$5(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
16459
16719
|
const baseVideoStyle = {
|
|
16460
16720
|
objectFit: 'contain',
|
|
16461
16721
|
width: '100%',
|
|
@@ -16622,7 +16882,7 @@ const Video = _ref => {
|
|
|
16622
16882
|
css: /*#__PURE__*/css({
|
|
16623
16883
|
video: baseVideoStyle
|
|
16624
16884
|
}, "production" === "production" ? "" : ";label:Video;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlZpZGVvLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtLOEIiLCJmaWxlIjoiVmlkZW8uanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHt1c2VFZmZlY3QsIHVzZUxheW91dEVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5cbmltcG9ydCBtdWx0aVJlZiBmcm9tICd1dGlsL211bHRpUmVmJ1xuaW1wb3J0IGxvYWRQbGF5ZXIgZnJvbSAncGxheWVyQ29yZS9sb2FkUGxheWVyJ1xuaW1wb3J0IHtcbiAgZ2V0TWVkaWFUaW1lLFxuICBzdWJzY3JpYmVQbGF5YmFja1N0YXRlLFxuICBsb2FkLFxuICBzeW5jUGxheWJhY2tTdGF0ZSxcbiAgc2VlayxcbiAgc2V0UGxheWJhY2tSYXRlLFxuICBzZXRBdWRpb1RyYWNrLFxuICBzeW5jVGV4dFRyYWNrLFxufSBmcm9tICdwbGF5ZXJDb3JlL21lZGlhQmluZGluZ3MnXG5pbXBvcnQge3NlbGVjdFZpZGVvUmVzb2x1dGlvbn0gZnJvbSAncGxheWVyQ29yZS9hZGFwdGF0aW9uJ1xuXG5jb25zdCBiYXNlVmlkZW9TdHlsZSA9IHtcbiAgb2JqZWN0Rml0OiAnY29udGFpbicsXG4gIHdpZHRoOiAnMTAwJScsXG4gIG1heEhlaWdodDogJzEwMCUnLFxuICAnJjpmdWxsc2NyZWVuJzoge1xuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIHRvcDogMCxcbiAgICBsZWZ0OiAwLFxuICAgIGJvdHRvbTogMCxcbiAgICByaWdodDogMCxcbiAgfSxcbiAgJ34gLnNoYWthLXRleHQtY29udGFpbmVyJzoge1xuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIGhlaWdodDogJzEwMCUnLFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH0sXG59XG5cbmNvbnN0IGVtcHR5QXJyYXkgPSBbXVxuXG5jb25zdCBWaWRlbyA9ICh7XG4gIHNvdXJjZSxcbiAgcGxheWJhY2tTdGF0ZTogdGFyZ2V0U3RhdGUsXG4gIGN1cnJlbnRUaW1lOiB0YXJnZXRUaW1lLFxuICBwbGF5YmFja1JhdGUsXG4gIHZpZGVvUmVzb2x1dGlvbixcbiAgdGV4dFRyYWNrcyA9IGVtcHR5QXJyYXksXG4gIHRleHRUcmFjayxcbiAgYXVkaW8gPSB7fSxcbiAgbGl2ZVJlc3VtZSxcbiAgaU9TRnVsbHNjcmVlbkRldGVjdFRocmVzaG9sZCwgLy8gVE9ETyBvcmdhbml6ZSBwcm9wc1xuICBwbHVnaW5zID0gW10sXG4gIHNoYWthLFxuICBiaXRtb3ZpbixcbiAgbGljZW5zZSxcbiAgdmFsaWRhdGlvbkhvc3QsXG4gIHZpZGVvUmVmLFxuICBwbGF5ZXJSZWYsXG4gIG9uUGxheWVyTG9hZGVkLFxuICBvblBsYXliYWNrU3RhdGVDaGFuZ2UsXG4gIG9uQmxvY2tlZEF1dG9wbGF5LFxuICBvblBsYXlsb2dGaXJlZCxcbiAgLi4udmlkZW9BdHRyaWJ1dGVzXG59KSA9PiB7XG4gIGNvbnN0IGhhbmRsZXJzID0gdXNlUmVmKClcbiAgaGFuZGxlcnMuY3VycmVudCA9IHtvblBsYXliYWNrU3RhdGVDaGFuZ2UsIG9uQmxvY2tlZEF1dG9wbGF5fVxuICBjb25zdCB2aWRlb0NvbnRhaW5lciA9IHVzZVJlZigpXG4gIGNvbnN0IHZpZGVvRWxlbWVudCA9IHVzZVJlZigpXG4gIGNvbnN0IFtwbGF5YmFja1N0YXRlLCBzZXRQbGF5YmFja1N0YXRlXSA9IHVzZVN0YXRlKCcnKVxuICBjb25zdCBbcGxheWVyLCBzZXRQbGF5ZXJdID0gdXNlU3RhdGUoKVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgbG9hZFRhc2sgPSBsb2FkUGxheWVyKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7XG4gICAgICBjb250YWluZXI6IHZpZGVvQ29udGFpbmVyLmN1cnJlbnQsXG4gICAgICBzb3VyY2UsXG4gICAgICBzaGFrYSxcbiAgICAgIGJpdG1vdmluLFxuICAgIH0pLnRoZW4oYmFzZVBsYXllciA9PiB7XG4gICAgICBzZXRQbGF5ZXIoYmFzZVBsYXllcilcbiAgICAgIG9uUGxheWVyTG9hZGVkPy4oYmFzZVBsYXllcilcbiAgICAgIGlmIChwbGF5ZXJSZWYpIHtcbiAgICAgICAgcGxheWVyUmVmLmN1cnJldCA9IGJhc2VQbGF5ZXJcbiAgICAgIH1cbiAgICAgIHJldHVybiBiYXNlUGxheWVyXG4gICAgfSlcbiAgICBjb25zdCBvZmZQbGF5YmFja1N0YXRlID0gc3Vic2NyaWJlUGxheWJhY2tTdGF0ZShcbiAgICAgIHZpZGVvRWxlbWVudC5jdXJyZW50LFxuICAgICAgKGV2ZW50LCBzdGF0ZSkgPT4ge1xuICAgICAgICBoYW5kbGVycy5jdXJyZW50Lm9uUGxheWJhY2tTdGF0ZUNoYW5nZT8uKGV2ZW50LCBzdGF0ZSlcbiAgICAgICAgLy8gZXh0ZXJuYWwgbG9naWMgbWF5IHdhbnQgdG8gY2hhbmdlIHRhcmdldFN0YXRlLCBob2xkIHBsYXliYWNrU3RhdGUgdXBkYXRlXG4gICAgICAgIC8vIHRvIHByZXZlbnQgdW53YW50ZWQgc3luY1BsYXliYWNrU3RhdGVcbiAgICAgICAgcmVxdWVzdEFuaW1hdGlvbkZyYW1lKCgpID0+IHNldFBsYXliYWNrU3RhdGUoc3RhdGUpKVxuICAgICAgfSxcbiAgICAgIHtpT1NGdWxsc2NyZWVuRGV0ZWN0VGhyZXNob2xkfVxuICAgIClcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgb2ZmUGxheWJhY2tTdGF0ZSgpXG4gICAgICBsb2FkVGFzay50aGVuKGN1cnJlbnRQbGF5ZXIgPT4gY3VycmVudFBsYXllcj8uZGVzdHJveSgpKVxuICAgIH1cbiAgfSwgW10pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKFxuICAgICAgc291cmNlICYmXG4gICAgICAoc291cmNlLmxlbmd0aCA+IDAgfHwgc291cmNlLnNyYyB8fCBzb3VyY2UuaGxzIHx8IHNvdXJjZS5kYXNoKSAmJlxuICAgICAgcGxheWVyPy5pc0FsaXZlKClcbiAgICApIHtcbiAgICAgIFByb21pc2UucmVzb2x2ZShmYWxzZSlcbiAgICAgICAgLnRoZW4oKCkgPT5cbiAgICAgICAgICBsb2FkKFxuICAgICAgICAgICAgdmlkZW9FbGVtZW50LmN1cnJlbnQsXG4gICAgICAgICAgICB7cGxheWVyLCBwbHVnaW5zLCBzdGFydFRpbWU6IHRhcmdldFRpbWV9LFxuICAgICAgICAgICAgc291cmNlXG4gICAgICAgICAgKVxuICAgICAgICApXG4gICAgICAgIC5jYXRjaChlcnJvciA9PiBjb25zb2xlLndhcm4oZXJyb3IpKVxuICAgIH1cbiAgICBpZiAoKCFzb3VyY2UgfHwgc291cmNlLmxlbmd0aCA9PT0gMCkgJiYgcGxheWVyKSB7XG4gICAgICBwbGF5ZXIudW5sb2FkKClcbiAgICAgIHBsYXllci5sYXN0U3JjID0gJydcbiAgICB9XG4gIH0sIFtwbGF5ZXIsIHNvdXJjZV0pXG5cbiAgLy8gdXNlRWZmZWN0IGlzIHRvbyBsYXRlIHRvIHVubG9jayBwbGF5IG9uIFNhZmFyaVxuICAvLyBUT0RPIGNoZWNrIGlmIHRoaXMgd29yayBhZnRlciB1cGdyYWRpbmcgUmVhY3QgMThcbiAgdXNlTGF5b3V0RWZmZWN0KCgpID0+IHtcbiAgICBpZiAocGxheWVyPy5pc0FsaXZlKCkpIHtcbiAgICAgIHN5bmNQbGF5YmFja1N0YXRlKFxuICAgICAgICB2aWRlb0VsZW1lbnQuY3VycmVudCxcbiAgICAgICAge3BsYXllciwgcGx1Z2lucywgbGl2ZVJlc3VtZX0sXG4gICAgICAgIHRhcmdldFN0YXRlXG4gICAgICApPy5jYXRjaChlcnJvciA9PiB7XG4gICAgICAgIGhhbmRsZXJzLmN1cnJlbnQub25CbG9ja2VkQXV0b3BsYXk/LihlcnJvcilcbiAgICAgIH0pXG4gICAgfVxuICB9LCBbcGxheWVyICYmIHRhcmdldFN0YXRlXSlcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCB7Y3VycmVudFRpbWV9ID0gZ2V0TWVkaWFUaW1lKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyLCBwbHVnaW5zfSlcbiAgICBpZiAocGxheWVyPy5pc0FsaXZlKCkgJiYgTWF0aC5hYnMoY3VycmVudFRpbWUgLSB0YXJnZXRUaW1lKSA+IDAuNSkge1xuICAgICAgLy8gc2Vla2luZyB1bmF2YWlsYWJsZSBjYXNlcyBhcmUgaGFuZGxlZCBieSBzZWVrIGZ1bmN0aW9uXG4gICAgICBzZWVrKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyLCBwbHVnaW5zfSwgdGFyZ2V0VGltZSlcbiAgICB9XG4gIH0sIFtwbGF5ZXIgJiYgdGFyZ2V0VGltZV0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgc2V0UGxheWJhY2tSYXRlKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyfSwgcGxheWJhY2tSYXRlKVxuICB9LCBbcGxheWJhY2tSYXRlLCBwbGF5YmFja1N0YXRlID09PSAncGxheWluZyddKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChwbGF5ZXIpIHtcbiAgICAgIHNlbGVjdFZpZGVvUmVzb2x1dGlvbih2aWRlb0VsZW1lbnQuY3VycmVudCwge3BsYXllcn0sIHZpZGVvUmVzb2x1dGlvbilcbiAgICB9XG4gIH0sIFt2aWRlb1Jlc29sdXRpb24sIHBsYXllcl0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgc2V0QXVkaW9UcmFjayh2aWRlb0VsZW1lbnQuY3VycmVudCwge3BsYXllcn0sIGF1ZGlvKVxuICB9LCBbYXVkaW8/LmlkIHx8IGAke2F1ZGlvLmxhbmd1YWdlIHx8ICd1bmsnfToke2F1ZGlvLmxhYmVsIHx8ICcnfWAsIHBsYXllcl0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHRleHRUcmFja3M/Lmxlbmd0aCA+IDAgfHwgdGV4dFRyYWNrKSB7XG4gICAgICByZXR1cm4gc3luY1RleHRUcmFjayhcbiAgICAgICAgdmlkZW9FbGVtZW50LmN1cnJlbnQsXG4gICAgICAgIHtwbGF5ZXJ9LFxuICAgICAgICB0ZXh0VHJhY2tzPy5sZW5ndGggPiAwID8ge3RleHRUcmFja3N9IDogdGV4dFRyYWNrXG4gICAgICApXG4gICAgfVxuICB9LCBbdmlkZW9FbGVtZW50LmN1cnJlbnQ/LnJlYWR5U3RhdGUgPj0gMiAmJiB0ZXh0VHJhY2tzLCB0ZXh0VHJhY2tdKVxuXG4gIHJldHVybiAoXG4gICAgPGRpdiByZWY9e3ZpZGVvQ29udGFpbmVyfSBjc3M9e3t2aWRlbzogYmFzZVZpZGVvU3R5bGV9fT5cbiAgICAgIDx2aWRlbyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIGpzeC1hMTF5L21lZGlhLWhhcy1jYXB0aW9uXG4gICAgICAgIHJlZj17bXVsdGlSZWYodmlkZW9SZWYsIHZpZGVvRWxlbWVudCl9XG4gICAgICAgIHBsYXlzSW5saW5lXG4gICAgICAgIHsuLi52aWRlb0F0dHJpYnV0ZXN9XG4gICAgICAvPlxuICAgIDwvZGl2PlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFZpZGVvXG4iXX0= */"),
|
|
16625
|
-
children: jsx("video", _objectSpread$
|
|
16885
|
+
children: jsx("video", _objectSpread$5({
|
|
16626
16886
|
// eslint-disable-line jsx-a11y/media-has-caption
|
|
16627
16887
|
ref: multiRef(videoRef, videoElement),
|
|
16628
16888
|
playsInline: true
|
|
@@ -16630,243 +16890,7 @@ const Video = _ref => {
|
|
|
16630
16890
|
});
|
|
16631
16891
|
};
|
|
16632
16892
|
|
|
16633
|
-
var Video$1 = Video;
|
|
16634
|
-
|
|
16635
|
-
function _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$5(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
16636
|
-
|
|
16637
|
-
const getSpeedItems = items => items.map(value => ({
|
|
16638
|
-
label: "".concat(value, "x"),
|
|
16639
|
-
value
|
|
16640
|
-
}));
|
|
16641
|
-
|
|
16642
|
-
const getQualityOptions = _ref => {
|
|
16643
|
-
var _sections$find, _sections$find$items$;
|
|
16644
|
-
|
|
16645
|
-
let {
|
|
16646
|
-
sections,
|
|
16647
|
-
values: {
|
|
16648
|
-
quality
|
|
16649
|
-
}
|
|
16650
|
-
} = _ref;
|
|
16651
|
-
return (_sections$find = sections.find(item => item.name === 'quality')) === null || _sections$find === void 0 ? void 0 : (_sections$find$items$ = _sections$find.items.find(item => item.value === quality)) === null || _sections$find$items$ === void 0 ? void 0 : _sections$find$items$.options;
|
|
16652
|
-
};
|
|
16653
|
-
|
|
16654
|
-
const autoQualityOption = {
|
|
16655
|
-
label: "Auto",
|
|
16656
|
-
options: {
|
|
16657
|
-
maxHeight: Infinity,
|
|
16658
|
-
minHeight: 0
|
|
16659
|
-
},
|
|
16660
|
-
value: 'auto'
|
|
16661
|
-
};
|
|
16662
|
-
|
|
16663
|
-
const getQualityItemsFromManifest = player => {
|
|
16664
|
-
var _player$getAvailableV;
|
|
16665
|
-
|
|
16666
|
-
return [autoQualityOption].concat(((player === null || player === void 0 ? void 0 : (_player$getAvailableV = player.getAvailableVideoQualities) === null || _player$getAvailableV === void 0 ? void 0 : _player$getAvailableV.call(player)) || []).filter(q => q.height > 0).sort((a, b) => b.height - a.height).map(q => ({
|
|
16667
|
-
label: "".concat(q.height, "p"),
|
|
16668
|
-
// Set the min/max height to the same value to fix the quality.
|
|
16669
|
-
options: {
|
|
16670
|
-
maxHeight: q.height,
|
|
16671
|
-
minHeight: q.height
|
|
16672
|
-
},
|
|
16673
|
-
value: q.height
|
|
16674
|
-
})));
|
|
16675
|
-
};
|
|
16676
|
-
|
|
16677
|
-
const getQualitySettings = (options, player) => {
|
|
16678
|
-
// With native HLS, manifest rewrite is required to enable quality setting
|
|
16679
|
-
// TODO let this covered by test, maybe refactor?
|
|
16680
|
-
const items = needNativeHls() && !options.rewriteManifest ? [] : options.items || getQualityItemsFromManifest(player);
|
|
16681
|
-
return items.length > 0 && items[0] && {
|
|
16682
|
-
name: 'quality',
|
|
16683
|
-
title: 'KKS.QUALITY',
|
|
16684
|
-
items,
|
|
16685
|
-
getDefault: function () {
|
|
16686
|
-
let preferred = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : options.default || items[0].value;
|
|
16687
|
-
const maxHeight = preferred || items[0].value;
|
|
16688
|
-
return (nearest(items.filter(item => (item.height || item.value) <= maxHeight), item => (item.height || item.value) - maxHeight) || items[0]).value;
|
|
16689
|
-
}
|
|
16690
|
-
};
|
|
16691
|
-
};
|
|
16692
|
-
|
|
16693
|
-
const getSelectedAudioName = player => {
|
|
16694
|
-
const track = getCurrentAudioTrack({}, {
|
|
16695
|
-
player
|
|
16696
|
-
});
|
|
16697
|
-
/*
|
|
16698
|
-
Sometimes, HLS manifest doesn't describe the default audio track.
|
|
16699
|
-
Get current audio track information is undefined even though the player still has audio streaming.
|
|
16700
|
-
For this case, we select first audio track.
|
|
16701
|
-
More detail please refer to OTP-3450.
|
|
16702
|
-
*/
|
|
16703
|
-
|
|
16704
|
-
const audioList = getAudioTracks({}, {
|
|
16705
|
-
player
|
|
16706
|
-
});
|
|
16707
|
-
const currentAudio = track !== undefined ? track : audioList === null || audioList === void 0 ? void 0 : audioList[0];
|
|
16708
|
-
return currentAudio && _objectSpread$5(_objectSpread$5({}, currentAudio), {}, {
|
|
16709
|
-
id: [currentAudio.language, currentAudio.label].join(':')
|
|
16710
|
-
});
|
|
16711
|
-
};
|
|
16712
|
-
|
|
16713
|
-
const getDefault = (section, _ref2) => {
|
|
16714
|
-
let {
|
|
16715
|
-
preferred,
|
|
16716
|
-
player
|
|
16717
|
-
} = _ref2;
|
|
16718
|
-
|
|
16719
|
-
if (typeof section.getDefault === 'function') {
|
|
16720
|
-
return section.getDefault(preferred);
|
|
16721
|
-
}
|
|
16722
|
-
|
|
16723
|
-
if (section.name === 'audio') {
|
|
16724
|
-
return preferred !== null && preferred !== void 0 ? preferred : getSelectedAudioName(player);
|
|
16725
|
-
}
|
|
16726
|
-
|
|
16727
|
-
if (section.name === 'subtitles') {
|
|
16728
|
-
var _ref3;
|
|
16729
|
-
|
|
16730
|
-
return ((_ref3 = section.items.find(track => {
|
|
16731
|
-
var _track$value, _track$value2;
|
|
16732
|
-
|
|
16733
|
-
return ((_track$value = track.value) === null || _track$value === void 0 ? void 0 : _track$value.label) === (preferred === null || preferred === void 0 ? void 0 : preferred.label) && ((_track$value2 = track.value) === null || _track$value2 === void 0 ? void 0 : _track$value2.language) === (preferred === null || preferred === void 0 ? void 0 : preferred.language);
|
|
16734
|
-
}) || section.items.find(track => {
|
|
16735
|
-
var _track$value3;
|
|
16736
|
-
|
|
16737
|
-
return ((_track$value3 = track.value) === null || _track$value3 === void 0 ? void 0 : _track$value3.language) === (preferred === null || preferred === void 0 ? void 0 : preferred.language);
|
|
16738
|
-
})) === null || _ref3 === void 0 ? void 0 : _ref3.value) || {
|
|
16739
|
-
language: 'off',
|
|
16740
|
-
id: 'off'
|
|
16741
|
-
};
|
|
16742
|
-
}
|
|
16743
|
-
|
|
16744
|
-
if (section.name === 'speed') {
|
|
16745
|
-
return preferred !== null && preferred !== void 0 ? preferred : 1;
|
|
16746
|
-
}
|
|
16747
|
-
};
|
|
16748
|
-
|
|
16749
|
-
const shouldProvideSettingSection = (_ref4, _ref5) => {
|
|
16750
|
-
let {
|
|
16751
|
-
name,
|
|
16752
|
-
items
|
|
16753
|
-
} = _ref4;
|
|
16754
|
-
let {
|
|
16755
|
-
player,
|
|
16756
|
-
loop
|
|
16757
|
-
} = _ref5;
|
|
16758
|
-
|
|
16759
|
-
if (name === 'loop') {
|
|
16760
|
-
return !(player !== null && player !== void 0 && player.isLive()) && loop !== 'disabled';
|
|
16761
|
-
}
|
|
16762
|
-
|
|
16763
|
-
if (name === 'speed') {
|
|
16764
|
-
return !(player !== null && player !== void 0 && player.isLive());
|
|
16765
|
-
}
|
|
16766
|
-
|
|
16767
|
-
if (name === 'subtitles' || name === 'audio') {
|
|
16768
|
-
return true;
|
|
16769
|
-
}
|
|
16770
|
-
|
|
16771
|
-
return (items === null || items === void 0 ? void 0 : items.length) > 1;
|
|
16772
|
-
};
|
|
16773
|
-
|
|
16774
|
-
const getSettingsData = _ref6 => {
|
|
16775
|
-
let {
|
|
16776
|
-
media,
|
|
16777
|
-
player,
|
|
16778
|
-
source = [],
|
|
16779
|
-
quality = {},
|
|
16780
|
-
speedItems = [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2],
|
|
16781
|
-
loop,
|
|
16782
|
-
preferred = {}
|
|
16783
|
-
} = _ref6;
|
|
16784
|
-
// TODO extract base player specific things
|
|
16785
|
-
const audioItems = getAudioTracks({}, {
|
|
16786
|
-
player
|
|
16787
|
-
}).filter(track => track.language && track.language !== 'und').map(track => ({
|
|
16788
|
-
label: track.label || track.language,
|
|
16789
|
-
value: {
|
|
16790
|
-
language: track.language,
|
|
16791
|
-
label: track.label,
|
|
16792
|
-
id: [track.language, track.label].join(':')
|
|
16793
|
-
}
|
|
16794
|
-
})) || [];
|
|
16795
|
-
const selectedSource = getSource(source, {
|
|
16796
|
-
preferManifestType: needNativeHls() ? 'hls' : 'dash'
|
|
16797
|
-
}) || {};
|
|
16798
|
-
const currentSpeedItems = getSpeedItems(speedItems);
|
|
16799
|
-
const sections = [].concat([quality && getQualitySettings(_objectSpread$5(_objectSpread$5({}, quality), {}, {
|
|
16800
|
-
items: selectedSource.qualityOptions
|
|
16801
|
-
}), player), {
|
|
16802
|
-
name: 'subtitles',
|
|
16803
|
-
title: 'KKS.SUBTITLES',
|
|
16804
|
-
items: [...getTextTracks({}, {
|
|
16805
|
-
player
|
|
16806
|
-
}).map(track => ({
|
|
16807
|
-
label: track.label || track.language,
|
|
16808
|
-
value: {
|
|
16809
|
-
language: track.language,
|
|
16810
|
-
label: track.label,
|
|
16811
|
-
id: [track.language, track.label].join(':')
|
|
16812
|
-
}
|
|
16813
|
-
})), {
|
|
16814
|
-
label: 'OFF',
|
|
16815
|
-
value: {
|
|
16816
|
-
language: 'off',
|
|
16817
|
-
id: 'off'
|
|
16818
|
-
}
|
|
16819
|
-
}]
|
|
16820
|
-
}, {
|
|
16821
|
-
name: 'audio',
|
|
16822
|
-
title: 'KKS.AUDIO',
|
|
16823
|
-
items: audioItems
|
|
16824
|
-
}, {
|
|
16825
|
-
name: 'speed',
|
|
16826
|
-
title: 'KKS.SETTING.SPEED',
|
|
16827
|
-
items: currentSpeedItems
|
|
16828
|
-
}, {
|
|
16829
|
-
type: 'switch',
|
|
16830
|
-
name: 'loop',
|
|
16831
|
-
title: 'KKS.SETTING.LOOP'
|
|
16832
|
-
}]).filter(section => shouldProvideSettingSection(section, {
|
|
16833
|
-
player,
|
|
16834
|
-
loop,
|
|
16835
|
-
quality
|
|
16836
|
-
}));
|
|
16837
|
-
const values = sections.reduce((result, section) => {
|
|
16838
|
-
// TODO take fallback option if preferred is not available
|
|
16839
|
-
// eslint-disable-next-line no-param-reassign
|
|
16840
|
-
result[section.name] = getDefault(section, {
|
|
16841
|
-
preferred: preferred[section.name],
|
|
16842
|
-
player,
|
|
16843
|
-
media
|
|
16844
|
-
}) || preferred[section.name];
|
|
16845
|
-
return result;
|
|
16846
|
-
}, // TODO forced subtitles?
|
|
16847
|
-
{
|
|
16848
|
-
audio: getSelectedAudioName(player),
|
|
16849
|
-
subtitles: 'off'
|
|
16850
|
-
});
|
|
16851
|
-
|
|
16852
|
-
if (!values.speed && (media === null || media === void 0 ? void 0 : media.playbackRate) > 0) {
|
|
16853
|
-
values.speed = media.playbackRate;
|
|
16854
|
-
}
|
|
16855
|
-
|
|
16856
|
-
if (typeof preferred.loop === 'boolean') {
|
|
16857
|
-
values.loop = preferred.loop;
|
|
16858
|
-
} else {
|
|
16859
|
-
values.loop = loop === 'disabled' ? false : Boolean(loop);
|
|
16860
|
-
dispatchCustomEvent(media, 'loopChange', {
|
|
16861
|
-
loop: values.loop
|
|
16862
|
-
});
|
|
16863
|
-
}
|
|
16864
|
-
|
|
16865
|
-
return {
|
|
16866
|
-
sections,
|
|
16867
|
-
values
|
|
16868
|
-
};
|
|
16869
|
-
};const parseVTT = data => {
|
|
16893
|
+
var Video$1 = Video;const parseVTT = data => {
|
|
16870
16894
|
const lines = data.split(/\n\n/g).slice(1); // may replace with async parser to prevent blocking render
|
|
16871
16895
|
|
|
16872
16896
|
return Promise.resolve(lines.map(line => {
|
|
@@ -17004,7 +17028,7 @@ const SeekPreview = _ref => {
|
|
|
17004
17028
|
}, currentThumbnail.position));
|
|
17005
17029
|
};
|
|
17006
17030
|
|
|
17007
|
-
var SeekPreview$1 = SeekPreview;const _excluded$1 = ["uiType", "audioTracks", "subtitleTracks", "onChange", "slots"],
|
|
17031
|
+
var SeekPreview$1 = SeekPreview;const _excluded$1 = ["uiType", "audioTracks", "subtitleTracks", "getPlayer", "onChange", "slots"],
|
|
17008
17032
|
_excluded2 = ["source", "startTime", "quality", "title", "metadata", "channelTitle", "chapters", "playbackState", "currentTime", "playbackRate", "loop", "volume", "thumbnailsUrl", "controls", "marks", "intl", "settings", "blocking", "plugins", "modulesConfig", "uiType", "style", "children", "uiMode", "cast", "slots", "slotProps", "onError", "onPlaybackStateChange", "onBack", "onCast", "onChangeNext", "onChangePrevious", "onOpenSettings", "onChangeSettings", "onPlayerLoaded", "onBlockedAutoplay", "onPlaylogFired"];
|
|
17009
17033
|
|
|
17010
17034
|
function ownKeys$2(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
@@ -17044,33 +17068,12 @@ const shouldPause = _ref => {
|
|
|
17044
17068
|
uiType
|
|
17045
17069
|
} = _ref;
|
|
17046
17070
|
return uiType === 'mobile' && /settings|chapter-list/.test(userFocus) || /blocking|seekbar|share-inner/.test(userFocus);
|
|
17047
|
-
};
|
|
17048
|
-
|
|
17049
|
-
const getLanguageOptions = settingState => {
|
|
17050
|
-
var _settingState$values$, _settingState$section, _settingState$section2, _settingState$values$2, _settingState$section3, _settingState$section4;
|
|
17051
|
-
|
|
17052
|
-
const selectedAudio = settingState === null || settingState === void 0 ? void 0 : (_settingState$values$ = settingState.values.audio) === null || _settingState$values$ === void 0 ? void 0 : _settingState$values$.id;
|
|
17053
|
-
const audioTracks = ((settingState === null || settingState === void 0 ? void 0 : (_settingState$section = settingState.sections) === null || _settingState$section === void 0 ? void 0 : (_settingState$section2 = _settingState$section.find(section => section.name === 'audio')) === null || _settingState$section2 === void 0 ? void 0 : _settingState$section2.items) || []).map(item => _objectSpread$2(_objectSpread$2({
|
|
17054
|
-
section: 'audio'
|
|
17055
|
-
}, item), item.value.id === selectedAudio && {
|
|
17056
|
-
selected: true
|
|
17057
|
-
}));
|
|
17058
|
-
const selectedSubtitle = settingState === null || settingState === void 0 ? void 0 : (_settingState$values$2 = settingState.values.subtitles) === null || _settingState$values$2 === void 0 ? void 0 : _settingState$values$2.id;
|
|
17059
|
-
const subtitleTracks = ((settingState === null || settingState === void 0 ? void 0 : (_settingState$section3 = settingState.sections) === null || _settingState$section3 === void 0 ? void 0 : (_settingState$section4 = _settingState$section3.find(section => section.name === 'subtitles')) === null || _settingState$section4 === void 0 ? void 0 : _settingState$section4.items) || []).map(item => _objectSpread$2(_objectSpread$2({
|
|
17060
|
-
section: 'subtitles'
|
|
17061
|
-
}, item), item.value.id === selectedSubtitle && {
|
|
17062
|
-
selected: true
|
|
17063
|
-
}));
|
|
17064
|
-
return {
|
|
17065
|
-
audioTracks,
|
|
17066
|
-
subtitleTracks
|
|
17067
|
-
};
|
|
17068
17071
|
}; // TODO extract to somewhere else
|
|
17069
17072
|
|
|
17070
17073
|
|
|
17071
17074
|
const menuClasses = {
|
|
17072
|
-
default: /*#__PURE__*/css$1(LanguageMenu.styles, "production" === "production" ? "" : ";label:default;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AA6FW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {havePointer, isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\nconst getLanguageOptions = settingState => {\n  const selectedAudio = settingState?.values.audio?.id\n  const audioTracks = (\n    settingState?.sections?.find(section => section.name === 'audio')?.items ||\n    []\n  ).map(item => ({\n    section: 'audio',\n    ...item,\n    ...(item.value.id === selectedAudio && {selected: true}),\n  }))\n  const selectedSubtitle = settingState?.values.subtitles?.id\n  const subtitleTracks = (\n    settingState?.sections?.find(section => section.name === 'subtitles')\n      ?.items || []\n  ).map(item => ({\n    section: 'subtitles',\n    ...item,\n    ...(item.value.id === selectedSubtitle && {selected: true}),\n  }))\n  return {audioTracks, subtitleTracks}\n}\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  subtitleTracks = [],\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => (\n  <OverlayPanel buttonIcon=\"subtitle\">\n    <slots.LanguageMenu\n      uiType={uiType}\n      classes={menuClasses}\n      sectionOptions={[audioTracks, subtitleTracks]}\n      onChange={onChange}\n      {...rest}\n    />\n  </OverlayPanel>\n)\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus\n  const havePlayPanel =\n    !blocking &&\n    havePointer() &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n    }\n  }, [shouldHidePanels])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    !isEnd &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audio={settings.values.audio}\n            textTrack={settings.values.subtitles}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          {...getLanguageOptions(settings)}\n          onChange={(_event, item) => changeSettings(item.section, item.value)}\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */"),
|
|
17073
|
-
desktop: /*#__PURE__*/css$1(LanguageMenu.styles, LanguageMenu.desktopStyles, "production" === "production" ? "" : ";label:desktop;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AA8FW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {havePointer, isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\nconst getLanguageOptions = settingState => {\n  const selectedAudio = settingState?.values.audio?.id\n  const audioTracks = (\n    settingState?.sections?.find(section => section.name === 'audio')?.items ||\n    []\n  ).map(item => ({\n    section: 'audio',\n    ...item,\n    ...(item.value.id === selectedAudio && {selected: true}),\n  }))\n  const selectedSubtitle = settingState?.values.subtitles?.id\n  const subtitleTracks = (\n    settingState?.sections?.find(section => section.name === 'subtitles')\n      ?.items || []\n  ).map(item => ({\n    section: 'subtitles',\n    ...item,\n    ...(item.value.id === selectedSubtitle && {selected: true}),\n  }))\n  return {audioTracks, subtitleTracks}\n}\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  subtitleTracks = [],\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => (\n  <OverlayPanel buttonIcon=\"subtitle\">\n    <slots.LanguageMenu\n      uiType={uiType}\n      classes={menuClasses}\n      sectionOptions={[audioTracks, subtitleTracks]}\n      onChange={onChange}\n      {...rest}\n    />\n  </OverlayPanel>\n)\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus\n  const havePlayPanel =\n    !blocking &&\n    havePointer() &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n    }\n  }, [shouldHidePanels])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    !isEnd &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audio={settings.values.audio}\n            textTrack={settings.values.subtitles}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          {...getLanguageOptions(settings)}\n          onChange={(_event, item) => changeSettings(item.section, item.value)}\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */")
|
|
17075
|
+
default: /*#__PURE__*/css$1(LanguageMenu.styles, "production" === "production" ? "" : ";label:default;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AAuEW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {havePointer, isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getLanguageOptions, getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  subtitleTracks = [],\n  getPlayer,\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => {\n  const options = getLanguageOptions(getPlayer(), {audioTracks, subtitleTracks})\n  return (\n    <OverlayPanel buttonIcon=\"subtitle\">\n      <slots.LanguageMenu\n        uiType={uiType}\n        classes={menuClasses}\n        sectionOptions={[options.audioTracks, options.textTracks]}\n        onChange={onChange}\n        {...rest}\n      />\n    </OverlayPanel>\n  )\n}\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus\n  const havePlayPanel =\n    !blocking &&\n    havePointer() &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n    }\n  }, [shouldHidePanels])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    !isEnd &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audio={settings.values.audio}\n            textTrack={settings.values.subtitles}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          getPlayer={() => playerRef.current}\n          onChange={(_event, item) => changeSettings(item.type, item.value)}\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */"),
|
|
17076
|
+
desktop: /*#__PURE__*/css$1(LanguageMenu.styles, LanguageMenu.desktopStyles, "production" === "production" ? "" : ";label:desktop;", "production" === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AAwEW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {havePointer, isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getLanguageOptions, getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  subtitleTracks = [],\n  getPlayer,\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => {\n  const options = getLanguageOptions(getPlayer(), {audioTracks, subtitleTracks})\n  return (\n    <OverlayPanel buttonIcon=\"subtitle\">\n      <slots.LanguageMenu\n        uiType={uiType}\n        classes={menuClasses}\n        sectionOptions={[options.audioTracks, options.textTracks]}\n        onChange={onChange}\n        {...rest}\n      />\n    </OverlayPanel>\n  )\n}\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus\n  const havePlayPanel =\n    !blocking &&\n    havePointer() &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n    }\n  }, [shouldHidePanels])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    !isEnd &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audio={settings.values.audio}\n            textTrack={settings.values.subtitles}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          getPlayer={() => playerRef.current}\n          onChange={(_event, item) => changeSettings(item.type, item.value)}\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */")
|
|
17074
17077
|
};
|
|
17075
17078
|
|
|
17076
17079
|
const LanguageSettings = _ref2 => {
|
|
@@ -17078,6 +17081,7 @@ const LanguageSettings = _ref2 => {
|
|
|
17078
17081
|
uiType,
|
|
17079
17082
|
audioTracks = [],
|
|
17080
17083
|
subtitleTracks = [],
|
|
17084
|
+
getPlayer,
|
|
17081
17085
|
onChange,
|
|
17082
17086
|
slots = {
|
|
17083
17087
|
LanguageMenu
|
|
@@ -17085,12 +17089,16 @@ const LanguageSettings = _ref2 => {
|
|
|
17085
17089
|
} = _ref2,
|
|
17086
17090
|
rest = _objectWithoutProperties(_ref2, _excluded$1);
|
|
17087
17091
|
|
|
17092
|
+
const options = getLanguageOptions(getPlayer(), {
|
|
17093
|
+
audioTracks,
|
|
17094
|
+
subtitleTracks
|
|
17095
|
+
});
|
|
17088
17096
|
return /*#__PURE__*/jsxRuntime.exports.jsx(OverlayPanel, {
|
|
17089
17097
|
buttonIcon: "subtitle",
|
|
17090
17098
|
children: /*#__PURE__*/jsxRuntime.exports.jsx(slots.LanguageMenu, _objectSpread$2({
|
|
17091
17099
|
uiType: uiType,
|
|
17092
17100
|
classes: menuClasses,
|
|
17093
|
-
sectionOptions: [audioTracks,
|
|
17101
|
+
sectionOptions: [options.audioTracks, options.textTracks],
|
|
17094
17102
|
onChange: onChange
|
|
17095
17103
|
}, rest))
|
|
17096
17104
|
});
|
|
@@ -17638,10 +17646,10 @@ const PremiumPlayer = _ref3 => {
|
|
|
17638
17646
|
onChange: uiHandlers.onChangeSettings
|
|
17639
17647
|
}, slotProps === null || slotProps === void 0 ? void 0 : slotProps.settings), {}, {
|
|
17640
17648
|
onClose: uiHandlers.onCloseSettings
|
|
17641
|
-
})), /*#__PURE__*/jsxRuntime.exports.jsx(LanguageSettings, _objectSpread$2(
|
|
17642
|
-
uiType: uiType
|
|
17643
|
-
|
|
17644
|
-
onChange: (_event, item) => changeSettings(item.
|
|
17649
|
+
})), /*#__PURE__*/jsxRuntime.exports.jsx(LanguageSettings, _objectSpread$2({
|
|
17650
|
+
uiType: uiType,
|
|
17651
|
+
getPlayer: () => playerRef.current,
|
|
17652
|
+
onChange: (_event, item) => changeSettings(item.type, item.value)
|
|
17645
17653
|
}, slotProps.languageSettings)), /*#__PURE__*/jsxRuntime.exports.jsx(Backdrop, {
|
|
17646
17654
|
open: !playbackState || playbackState === 'loading',
|
|
17647
17655
|
children: /*#__PURE__*/jsxRuntime.exports.jsx(LoadingSpinner, {})
|
|
@@ -18296,9 +18304,9 @@ class Player {
|
|
|
18296
18304
|
player: this.player
|
|
18297
18305
|
}) || []);
|
|
18298
18306
|
|
|
18299
|
-
_defineProperty(this, "getCurrentAudioTrack", () =>
|
|
18307
|
+
_defineProperty(this, "getCurrentAudioTrack", () => getAudioTracks({}, {
|
|
18300
18308
|
player: this.player
|
|
18301
|
-
}));
|
|
18309
|
+
}).find(track => track.selected));
|
|
18302
18310
|
|
|
18303
18311
|
_defineProperty(this, "setAudioTrack", track => {
|
|
18304
18312
|
// TODO also accept Track, name: setTextTrack
|