@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/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); // canPlayType isn't reliable across all iOS verion / device combinations, so also check user agent
3150
-
3151
- const isSafari = /^((?!chrome|android|X11|Linux).)*(safari|iPad|iPhone|Version)/i.test(navigator.userAgent); // ref: https://stackoverflow.com/a/12905122/4578017
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 matched = sourceOptions.find(source => !preferManifestType || matchType(source, preferManifestType));
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.0";
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: preferManifestType,
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$getSubtitles;
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
- if (player.getTextTracks) {
7795
- return player.getTextTracks().map(track => {
7796
- var _track$label;
7797
-
7798
- return {
7799
- label: ((_track$label = track.label) === null || _track$label === void 0 ? void 0 : _track$label.trim()) || track.language,
7800
- language: track.language,
7801
- enabled: player.isTextTrackVisible() ? track.active : false,
7802
- id: track.id
7803
- };
7804
- }).filter(track => track.label !== 'unknown' && track.language && !track.language.startsWith('unk'));
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.enabled) || 'off';
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
- const getAudioTracks = (_, _ref12) => {
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$label2, _result$id;
7971
+ var _track$label;
7893
7972
 
7894
- const label = ((_track$label2 = track.label) === null || _track$label2 === void 0 ? void 0 : _track$label2.trim()) || track.language;
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$q(_objectSpread$q({}, track), {}, {
7897
- language: track.language,
7975
+ result[id] = result[id] || _objectSpread$p(_objectSpread$p({}, track), {}, {
7976
+ type: 'audio',
7898
7977
  label,
7899
- enabled: ((_result$id = result[id]) === null || _result$id === void 0 ? void 0 : _result$id.enabled) || track.active
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
- return Object.values(all);
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, _ref13) => {
7996
+ const getCurrentAudioTrack = (media, _ref3) => {
7907
7997
  let {
7908
7998
  player
7909
- } = _ref13;
7999
+ } = _ref3;
7910
8000
  return getAudioTracks(media, {
7911
8001
  player
7912
- }).find(track => track.enabled);
7913
- }; // assume unique labels as defined in spec
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 setAudioTrack = (_, _ref14, next) => {
8025
+ const getDefault = (section, _ref4) => {
7917
8026
  let {
8027
+ preferred,
7918
8028
  player
7919
- } = _ref14;
7920
- if (!next) return;
8029
+ } = _ref4;
7921
8030
 
7922
- try {
7923
- const tracks = getAudioTracks({}, {
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
- const activeTrack = tracks.find(track => track.language === next.language && track.label === next.label) || tracks.find(track => track.language === next.language && track.label === next.language);
8161
+ }
7927
8162
 
7928
- if (activeTrack !== null && activeTrack !== void 0 && activeTrack.enabled) {
7929
- return;
7930
- }
8163
+ return {
8164
+ sections,
8165
+ values
8166
+ };
8167
+ };
7931
8168
 
7932
- player.selectAudioLanguage(activeTrack.language);
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
- if (activeTrack.label) {
7935
- player.selectVariantsByLabel(activeTrack.label);
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
- } catch (error) {
7938
- console.warn('Unable to set audio', error, next);
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$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; }
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$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; }
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$p({
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$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; }
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$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; }
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$o(_objectSpread$o({
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$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; }
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$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; }
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$n(_objectSpread$n(_objectSpread$n({}, tooltipStyle), position), {}, {
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$n(_objectSpread$n({
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$n(_objectSpread$n({
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$n({
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$n({
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$n(_objectSpread$n({
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$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; }
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$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; }
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$m({
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$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; }
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$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; }
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$l(_objectSpread$l({}, displayStyles.hidden), {}, {
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$l(_objectSpread$l({}, displayStyles.shown), {}, {
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$l(_objectSpread$l({
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$l(_objectSpread$l({
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$l({
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$l({
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$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; }
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$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; }
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$k(_objectSpread$k({}, state.currentPosition), state.pendingMove));
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$k(_objectSpread$k({}, state.currentPosition), state.lastMove));
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$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; }
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$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; }
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$j({
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$j({
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$j({
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$j(_objectSpread$j({
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$j(_objectSpread$j({}, orientation === 'vertical' && {
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$j(_objectSpread$j({
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$j({
12708
+ children: [jsx(slots.Rail, _objectSpread$i({
12458
12709
  style: railStyle,
12459
12710
  className: classes.rail
12460
- }, slotProps.rail)), secondaryTrackValue && jsx(slots.Track, _objectSpread$j({
12461
- style: _objectSpread$j(_objectSpread$j({}, trackStyle), {}, {
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$j({
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$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; }
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$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; }
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$i(_objectSpread$i({}, state), {}, {
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$i(_objectSpread$i({}, state), {}, {
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$i(_objectSpread$i({}, state), {}, {
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$i(_objectSpread$i({}, state), {}, {
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$i(_objectSpread$i(_objectSpread$i({
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$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; }
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$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; }
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$h(_objectSpread$h({}, props), {}, {
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$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; }
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$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; }
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$g(_objectSpread$g({}, style), styles.overlay),
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$g(_objectSpread$g(_objectSpread$g({
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$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; }
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$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; }
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$f(_objectSpread$f({}, ulReset), {}, {
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$f(_objectSpread$f({}, mobileStyle$1.container), {}, {
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$f(_objectSpread$f({}, mobileStyle$1.head), {}, {
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$f(_objectSpread$f({}, mobileStyle$1.row), {}, {
13504
+ row: _objectSpread$e(_objectSpread$e({}, mobileStyle$1.row), {}, {
13254
13505
  background: 'rgba(22, 28, 36, 0.8)',
13255
- '::after': _objectSpread$f(_objectSpread$f({
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$f({
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$f(_objectSpread$f({
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$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; }
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$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; }
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$e(_objectSpread$e({
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$e(_objectSpread$e({
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
- width: '1em',
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lbnVJdGVtLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCSSIsImZpbGUiOiJNZW51SXRlbS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IGljb24gZnJvbSAnc3R5bGUvaWNvbidcblxuY29uc3QgbWVudUl0ZW1TdHlsZSA9IHtcbiAgcGFkZGluZzogJ3ZhcigtLW1lbnUtaXRlbS1wYWRkaW5nLCAwLjVlbSAxZW0pICcsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG5cbiAgY29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuNiknLFxuICBiYWNrZ3JvdW5kOiAndmFyKC0tbWVudS1pdGVtLWJhY2tncm91bmQsIHJnYmEoMjU1LCAyNTUsIDI1NSwgMC4wOCkpJyxcbn1cblxuY29uc3QgbWVudUl0ZW1TZWxlY3RlZFN0eWxlID0ge1xuICBjb2xvcjogJyNGRkYnLFxuICBmb250V2VpZ2h0OiAnNjAwJyxcbiAgJzo6YWZ0ZXInOiB7XG4gICAgY29udGVudDogJ1wiIFwiJyxcbiAgICBkaXNwbGF5OiAnaW5saW5lLWJsb2NrJyxcbiAgICB3aWR0aDogJzFlbScsXG4gICAgaGVpZ2h0OiAnMWVtJyxcbiAgICBtYXJnaW5MZWZ0OiAnMC41ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXNldHRpbmctY2hlY2staWNvbi1jb2xvciwgI2ZmZiknLFxuICAgIG1hc2tTaXplOiAnY29udGFpbicsXG4gICAgbWFza0ltYWdlOiBgdXJsKCR7aWNvbi5jaGVja30pYCxcbiAgfSxcbn1cblxuY29uc3QgTWVudUl0ZW0gPSAoe2xhYmVsLCBzZWxlY3RlZCwgb25DbGlja30pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W21lbnVJdGVtU3R5bGUsIHNlbGVjdGVkICYmIG1lbnVJdGVtU2VsZWN0ZWRTdHlsZV19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgPlxuICAgIHtsYWJlbH1cbiAgPC9kaXY+XG4pXG5cbmV4cG9ydCBkZWZhdWx0IE1lbnVJdGVtXG4iXX0= */"],
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: label
13892
+ children: jsx("div", {
13893
+ children: label
13894
+ })
13636
13895
  });
13637
13896
  };
13638
13897
 
13639
- var MenuItem$1 = MenuItem;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; }
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$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; }
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxhbmd1YWdlTWVudS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2R0kiLCJmaWxlIjoiTGFuZ3VhZ2VNZW51LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHtCdXR0b259IGZyb20gJy4vYnV0dG9ucydcbmltcG9ydCBNZW51SXRlbSBmcm9tICcuL01lbnVJdGVtJ1xuXG5jb25zdCBsYW5kc2NhcGVTdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBmbGV4V3JhcDogJ3dyYXAnLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxuICAnPiBkaXYnOiB7XG4gICAgYm94U2l6aW5nOiAnYm9yZGVyLWJveCcsXG4gICAgZmxleDogJzAgMCA1MCUnLFxuICB9LFxuICAnPiBkaXY6bm90KDpmaXJzdC1vZi10eXBlKSc6IHtcbiAgICBtYXJnaW5Ub3A6IDAsXG4gICAgZmxleDogJzAgMCBjYWxjKDUwJSAtIDFweCknLFxuICB9LFxuICBocjoge1xuICAgIGhlaWdodDogJ2F1dG8nLFxuICAgIGJvcmRlckxlZnQ6ICcxcHggc29saWQgdHJhbnNwYXJlbnQnLFxuICB9LFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxNnB4JyxcbiAgYmFja2dyb3VuZDogJyMyNjI2MjYnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgaDM6IHtcbiAgICBtYXJnaW46IDAsXG4gICAgJ21hcmdpbi1ibG9jay1zdGFydCc6IDAsXG4gICAgJ21hcmdpbi1ibG9jay1lbmQnOiAwLFxuICAgIHBhZGRpbmc6ICcwLjZlbSAxZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBib3JkZXJSYWRpdXM6ICc0cHggNHB4IDAgMCcsXG4gICAgZm9udFNpemU6ICcxN3B4JyxcbiAgICBidXR0b246IHtcbiAgICAgIGZvbnRTaXplOiAnMC42ZW0nLFxuICAgICAgbWFyZ2luUmlnaHQ6ICcwLjVlbScsXG4gICAgfSxcbiAgfSxcbn1cblxuY29uc3QgdHdvQ29sdW1uU3R5bGUgPSB7XG4gIGhyOiB7XG4gICAgYm9yZGVyOiAnbm9uZScsXG4gIH0sXG4gICc+IGRpdiAnOiB7XG4gICAgJz4gZGl2Om5vdCg6Zmlyc3Qtb2YtdHlwZSknOiB7XG4gICAgICBtYXJnaW5Ub3A6ICcwLjY2ZW0nLFxuICAgIH0sXG4gICAgJ0BtZWRpYSAob3JpZW50YXRpb246IGxhbmRzY2FwZSknOiBsYW5kc2NhcGVTdHlsZSxcbiAgfSxcbiAgJz4gZGl2ID4gZGl2ID4gZGl2OmZpcnN0LW9mLXR5cGUnOiB7XG4gICAgcGFkZGluZzogJzAuNmVtIDEuMWVtJyxcbiAgICBmb250U2l6ZTogJzE0cHgnLFxuICAgIGNvbG9yOiAnI2FhYWViNScsXG4gICAgYmFja2dyb3VuZDogJ3ZhcigtLW1lbnUtaXRlbS1iYWNrZ3JvdW5kLCAjMjYyNjI2KScsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgIHRleHRPdmVyZmxvdzogJ2VsbGlwc2lzJyxcbiAgfSxcbn1cblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwYWRkaW5nQm90dG9tOiAnMS41ZW0nLFxuICB3aWR0aDogJzM0ZW0nLFxuICBtaW5IZWlnaHQ6ICczMC41JScsXG4gIG1heEhlaWdodDogJzYzLjUlJyxcbiAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgYmFja2dyb3VuZDogJ3JnYmEoMCwgMCwgMCwgMC42MCknLFxuICAnLS1tZW51LWl0ZW0tYmFja2dyb3VuZCc6ICd0cmFuc3BhcmVudCcsXG4gICctLW1lbnUtaXRlbS1wYWRkaW5nJzogJzAuNjZlbSAxLjVlbScsXG4gIGgzOiB7XG4gICAgcGFkZGluZzogJzAuNjZlbSAxLjVlbScsXG4gICAgZm9udFNpemU6ICcxNnB4JyxcbiAgICBjb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC42MCknLFxuICAgIGJhY2tncm91bmQ6ICdyZ2JhKDAsIDAsIDAsIDAuODApJyxcbiAgfSxcbn1cblxuY29uc3QgZGVza3RvcDJDb2x1bW5TdHlsZSA9IHtcbiAgJz4gZGl2JzogbGFuZHNjYXBlU3R5bGUsXG4gICc+IGRpdiBocic6IHtcbiAgICBmb250U2l6ZTogJzE1MCUnLFxuICAgIGJvcmRlckxlZnQ6ICcxcHggc29saWQgIHJnYmEoMjU1LCAyNTUsIDI1NSwgMC4yMCknLFxuICB9LFxuICAnPiBkaXYgPiBkaXYnOiB7XG4gICAgcGFkZGluZzogJzAgMWVtJyxcbiAgfSxcbiAgJz4gZGl2ID4gZGl2ID4gZGl2OmZpcnN0LW9mLXR5cGUnOiB7XG4gICAgcGFkZGluZzogJzAuNjZlbSAwLjVlbScsXG4gICAgY29sb3I6ICcjZmZmJyxcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIGZvbnRXZWlnaHQ6ICc2MDAnLFxuICB9LFxufVxuXG5jb25zdCBjbG9zZU1lbnUgPSBldmVudCA9PlxuICBldmVudC5jdXJyZW50VGFyZ2V0LmRpc3BhdGNoRXZlbnQoXG4gICAgbmV3IEN1c3RvbUV2ZW50KCdjbG9zZS1tZW51Jywge2J1YmJsZXM6IHRydWV9KVxuICApXG5cbmNvbnN0IExhbmd1YWdlTWVudSA9ICh7XG4gIHVpVHlwZSA9ICdtb2JpbGUnLFxuICB0aXRsZSA9ICfpn7Plo7Ag44O7IOWtl+W5lScsXG4gIHNlY3Rpb25zID0gWyfpn7Plo7AnLCAn5a2X5bmVJ10sXG4gIHNlY3Rpb25PcHRpb25zID0gW10sXG4gIG9uQ2hhbmdlLFxufSkgPT4gKFxuICA8ZGl2XG4gICAgY3NzPXtbXG4gICAgICBjb250YWluZXJTdHlsZSxcbiAgICAgIHR3b0NvbHVtblN0eWxlLFxuICAgICAgdWlUeXBlID09PSAnZGVza3RvcCcgJiYgW2Rlc2t0b3BDb250YWluZXJTdHlsZSwgZGVza3RvcDJDb2x1bW5TdHlsZV0sXG4gICAgXX1cbiAgPlxuICAgIDxoMz5cbiAgICAgIHt1aVR5cGUgIT09ICdkZXNrdG9wJyAmJiA8QnV0dG9uIHN0YXJ0SWNvbj1cImNsb3NlXCIgb25DbGljaz17Y2xvc2VNZW51fSAvPn1cbiAgICAgIHt0aXRsZX1cbiAgICA8L2gzPlxuICAgIDxkaXY+XG4gICAgICA8ZGl2PlxuICAgICAgICA8ZGl2PntzZWN0aW9uc1swXX08L2Rpdj5cbiAgICAgICAge3NlY3Rpb25PcHRpb25zWzBdLm1hcChvcHRpb24gPT4gKFxuICAgICAgICAgIDxNZW51SXRlbSB7Li4ub3B0aW9ufSBvbkNsaWNrPXtldmVudCA9PiBvbkNoYW5nZShldmVudCwgb3B0aW9uKX0gLz5cbiAgICAgICAgKSl9XG4gICAgICA8L2Rpdj5cbiAgICAgIDxociAvPlxuICAgICAgPGRpdj5cbiAgICAgICAgPGRpdj57c2VjdGlvbnNbMV19PC9kaXY+XG4gICAgICAgIHtzZWN0aW9uT3B0aW9uc1sxXS5tYXAob3B0aW9uID0+IChcbiAgICAgICAgICA8TWVudUl0ZW0gey4uLm9wdGlvbn0gb25DbGljaz17ZXZlbnQgPT4gb25DaGFuZ2UoZXZlbnQsIG9wdGlvbil9IC8+XG4gICAgICAgICkpfVxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuKVxuXG5MYW5ndWFnZU1lbnUuc3R5bGVzID0gY29udGFpbmVyU3R5bGVcbkxhbmd1YWdlTWVudS5kZXNrdG9wU3R5bGVzID0gZGVza3RvcENvbnRhaW5lclN0eWxlXG5cbmV4cG9ydCBkZWZhdWx0IExhbmd1YWdlTWVudVxuIl19 */"],
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$d(_objectSpread$d({}, option), {}, {
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$d(_objectSpread$d({}, option), {}, {
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$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; }
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$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; }
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$c({
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$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; }
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$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; }
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$b(_objectSpread$b({
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$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; }
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$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; }
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$a({
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$a(_objectSpread$a({}, drm === null || drm === void 0 ? void 0 : drm.widevine), {}, {
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$a(_objectSpread$a({}, drm === null || drm === void 0 ? void 0 : drm.widevine), {}, {
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$a(_objectSpread$a({}, (_sourceInfo$drm = sourceInfo.drm) === null || _sourceInfo$drm === void 0 ? void 0 : _sourceInfo$drm.widevine), {}, {
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$a(_objectSpread$a(_objectSpread$a({
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$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; }
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$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; }
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$9({
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$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; }
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$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; }
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$8({
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$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; }
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$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; }
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$7(_objectSpread$7({}, config), {}, {
16237
- manifest: _objectSpread$7({
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$7(_objectSpread$7({
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
- }, needNativeHls() && {
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 (needNativeHls()) {
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$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; }
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$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; }
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$6({
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;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; }
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, subtitleTracks],
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(_objectSpread$2({
17642
- uiType: uiType
17643
- }, getLanguageOptions(settings)), {}, {
17644
- onChange: (_event, item) => changeSettings(item.section, item.value)
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", () => 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