@kkcompany/player 2.25.0-canary.1 → 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/react.mjs CHANGED
@@ -1,4 +1,5 @@
1
1
  import React, { useRef, useState, useEffect, useContext, cloneElement, createContext, useReducer, useMemo, useCallback, useLayoutEffect, useImperativeHandle } from 'react';
2
+ import { keyframes as keyframes$1, css as css$1 } from '@emotion/css';
2
3
  import useDimensions from 'react-cool-dimensions';
3
4
  import { ResizeObserver as ResizeObserver$1 } from '@juggle/resize-observer';
4
5
  import UAParser from 'ua-parser-js';
@@ -8,9 +9,7 @@ import { css, keyframes } from '@emotion/react';
8
9
  import { jsx as jsx$1, jsxs, Fragment } from '@emotion/react/jsx-runtime';
9
10
  import { createPortal } from 'react-dom';
10
11
  import useOnclickOutside from 'react-cool-onclickoutside';
11
- import { keyframes as keyframes$1 } from '@emotion/css';
12
12
  import mitt from 'mitt';
13
- import axios from 'axios';
14
13
 
15
14
  const on = (target, name, handler, ...rest) => {
16
15
  target.addEventListener(name, handler, ...rest);
@@ -297,7 +296,7 @@ function convertToSeconds(timeString) {
297
296
  function getVersion() {
298
297
  try {
299
298
  // eslint-disable-next-line no-undef
300
- return "2.25.0-canary.1";
299
+ return "2.25.0-canary.2";
301
300
  } catch (e) {
302
301
  return undefined;
303
302
  }
@@ -323,6 +322,8 @@ const nearest = (items, diff) => {
323
322
  return items.reduce((a, b) => Math.abs(diff(a)) > Math.abs(diff(b)) ? b : a, items[0]);
324
323
  };
325
324
 
325
+ /* eslint-disable no-param-reassign */
326
+
326
327
  const matchAll = (input, pattern) => {
327
328
  const flags = [pattern.global && 'g', pattern.ignoreCase && 'i', pattern.multiline && 'm'].filter(Boolean).join('');
328
329
  const clone = new RegExp(pattern, flags);
@@ -341,11 +342,6 @@ const matchAll = (input, pattern) => {
341
342
  }());
342
343
  };
343
344
 
344
- const meetRestriction = (quality, {
345
- minHeight,
346
- maxHeight
347
- } = {}) => !(quality.height < minHeight || quality.height > maxHeight);
348
-
349
345
  const getHlsQualityOptions = manifest => {
350
346
  const resolutionList = matchAll(manifest, /RESOLUTION=\d+x(\d+)/g);
351
347
  return Array.from(new Set(resolutionList.map(([, height]) => ({
@@ -353,16 +349,11 @@ const getHlsQualityOptions = manifest => {
353
349
  })))).sort((a, b) => b.height - a.height);
354
350
  };
355
351
 
356
- const selectRestrictedQuality = (availableQualities, {
357
- suggested,
358
- restrictions
359
- }) => {
360
- if (meetRestriction(suggested, restrictions)) {
361
- return suggested.id;
362
- }
363
-
364
- const allowed = availableQualities.filter(quality => meetRestriction(quality, restrictions));
365
- return (nearest(allowed, item => item.height - suggested.height) || suggested).id;
352
+ const selectVideoResolution = (_media, {
353
+ player
354
+ }, restrictions) => {
355
+ player.preferredSettings.videoResolution = restrictions;
356
+ player.configure('abr.restrictions', restrictions);
366
357
  };
367
358
  // for unit test
368
359
 
@@ -547,7 +538,7 @@ const tryPatchHlsVideoQualities = async (player, hlsUrl) => {
547
538
  const videoQualities = getHlsQualityOptions(manifest);
548
539
 
549
540
  if (videoQualities) {
550
- player.getAvailableVideoQualities = () => videoQualities;
541
+ player.getVariantTracks = () => videoQualities;
551
542
  }
552
543
  };
553
544
 
@@ -700,7 +691,7 @@ const load = async (media, {
700
691
  loadStartTime = merged.startTime;
701
692
  }
702
693
 
703
- if (merged.type === 'application/x-mpegurl') {
694
+ if (needNativeHls() && merged.type === 'application/x-mpegurl') {
704
695
  await tryPatchHlsVideoQualities(player, merged.src);
705
696
  }
706
697
 
@@ -827,44 +818,28 @@ const setPlaybackRate = (media, {
827
818
  media.playbackRate = rate;
828
819
  };
829
820
 
830
- const setQuality = (_, {
831
- player
832
- }, restrictions) => {
833
- var _player$setAdaptation, _player$setQuality;
834
-
835
- // For Bitmovin
836
- (_player$setAdaptation = player.setAdaptationHandler) === null || _player$setAdaptation === void 0 ? void 0 : _player$setAdaptation.call(player, ({
837
- availableQualities,
838
- suggested
839
- }) => selectRestrictedQuality(availableQualities, {
840
- suggested,
841
- restrictions
842
- })); // For Shaka
843
-
844
- (_player$setQuality = player.setQuality) === null || _player$setQuality === void 0 ? void 0 : _player$setQuality.call(player, restrictions);
845
- };
846
-
847
821
  const getTextTracks = (_, {
848
822
  player
849
823
  }) => {
850
- var _player$getSubtitles;
824
+ var _player$getTextTracks;
851
825
 
852
826
  if (!player) return [];
827
+ return (((_player$getTextTracks = player.getTextTracks) === null || _player$getTextTracks === void 0 ? void 0 : _player$getTextTracks.call(player)) || []).map(track => {
828
+ var _track$label;
853
829
 
854
- if (player.getTextTracks) {
855
- return player.getTextTracks().map(track => {
856
- var _track$label;
857
-
858
- return {
859
- label: ((_track$label = track.label) === null || _track$label === void 0 ? void 0 : _track$label.trim()) || track.language,
860
- language: track.language,
861
- enabled: player.isTextTrackVisible() ? track.active : false,
862
- id: track.id
863
- };
864
- }).filter(track => track.label !== 'unknown' && track.language && !track.language.startsWith('unk'));
865
- }
866
-
867
- 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)) || [];
830
+ const label = ((_track$label = track.label) === null || _track$label === void 0 ? void 0 : _track$label.trim()) || track.language;
831
+ const id = `${track.language}:${label}`;
832
+ return { ...track,
833
+ label,
834
+ type: 'subtitles',
835
+ selected: player.isTextTrackVisible() ? track.active : false,
836
+ value: {
837
+ id,
838
+ label,
839
+ language: track.language
840
+ }
841
+ };
842
+ }).filter(track => track.label !== 'unknown' && track.language && !/^un/i.test(track.language));
868
843
  };
869
844
 
870
845
  const textTrackLabel = 'playcraft-text-track';
@@ -929,33 +904,7 @@ const syncTextTrack = (media, {
929
904
  player.setTextTrackVisibility(false);
930
905
  }
931
906
  });
932
- };
933
-
934
- const getAudioTracks = (_, {
935
- player
936
- }) => {
937
- if (!player) return []; // Bitmovin support is omitted as it is not needed in near future
938
-
939
- const all = player.getVariantTracks().reduce((result, track) => {
940
- var _track$label2, _result$id;
941
-
942
- const label = ((_track$label2 = track.label) === null || _track$label2 === void 0 ? void 0 : _track$label2.trim()) || track.language;
943
- const id = `${track.language}:${label}`;
944
- result[id] = { ...track,
945
- language: track.language,
946
- label,
947
- enabled: ((_result$id = result[id]) === null || _result$id === void 0 ? void 0 : _result$id.enabled) || track.active
948
- };
949
- return result;
950
- }, {});
951
- return Object.values(all);
952
- };
953
-
954
- const getCurrentAudioTrack = (media, {
955
- player
956
- }) => getAudioTracks(media, {
957
- player
958
- }).find(track => track.enabled); // assume unique labels as defined in spec
907
+ }; // assume unique labels as defined in spec
959
908
 
960
909
 
961
910
  const setAudioTrack = (_, {
@@ -964,19 +913,10 @@ const setAudioTrack = (_, {
964
913
  if (!next) return;
965
914
 
966
915
  try {
967
- const tracks = getAudioTracks({}, {
968
- player
969
- });
970
- const activeTrack = tracks.find(track => track.language === next.language && track.label === next.label) || tracks.find(track => track.language === next.language && track.label === next.language);
971
-
972
- if (activeTrack !== null && activeTrack !== void 0 && activeTrack.enabled) {
973
- return;
974
- }
916
+ player.selectAudioLanguage(next.language);
975
917
 
976
- player.selectAudioLanguage(activeTrack.language);
977
-
978
- if (activeTrack.label) {
979
- player.selectVariantsByLabel(activeTrack.label);
918
+ if (next.label) {
919
+ player.selectVariantsByLabel(next.label);
980
920
  }
981
921
  } catch (error) {
982
922
  console.warn('Unable to set audio', error, next);
@@ -2494,6 +2434,7 @@ var icon = {
2494
2434
  volumeLow: 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPSczNicgaGVpZ2h0PSczNicgdmlld0JveD0nMCAwIDM2IDM2Jz4gPGcgZmlsbD0nbm9uZScgZmlsbC1ydWxlPSdldmVub2RkJz4gPHBhdGggZD0nTTAgMGgzNnYzNkgweicgb3BhY2l0eT0nLjUnLz4gPHBhdGggZmlsbD0nI0ZGRicgZD0nTTI2LjUyMyAxNy41NDdjMCAxLjY2Mi0uNDIzIDMuMTY1LTEuMjcgNC41MWE4LjQ1MyA4LjQ1MyAwIDAgMS0zLjQ0NSAzLjEwNlY5LjkzYzEuNDUuNzI1IDIuNiAxLjc2IDMuNDQ1IDMuMTA1Ljg0NyAxLjM0NSAxLjI3IDIuODQ4IDEuMjcgNC41MXpNMSAxMS44OGg3LjUyNUwxOCAyLjQwNXYzMC4yODNsLTkuNDc1LTkuNDc1SDF6Jy8+IDwvZz4gPC9zdmc+',
2495
2435
  mute: 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPSczNicgaGVpZ2h0PSczNicgdmlld0JveD0nMCAwIDM2IDM2Jz4gPGcgZmlsbD0nbm9uZScgZmlsbC1ydWxlPSdldmVub2RkJz4gPHBhdGggZD0nTTAgMGgzNnYzNkgweicgb3BhY2l0eT0nLjUnLz4gPHBhdGggZmlsbD0nI0ZGRicgZD0nTTEgMTEuODhoNy41MjVMMTggMi40MDV2MzAuMjgzbC05LjQ3NS05LjQ3NUgxeicvPiA8ZyBmaWxsLXJ1bGU9J25vbnplcm8nPiA8cGF0aCBkPSdNMjAgMTFoMTR2MTRIMjB6Jy8+IDxwYXRoIGZpbGw9JyNGRkYnIGQ9J00zMS45NCAxMC45NGwyLjEyIDIuMTItMTIgMTItMi4xMi0yLjEyeicvPiA8cGF0aCBmaWxsPScjRkZGJyBkPSdNMTkuOTQgMTMuMDZsMi4xMi0yLjEyIDEyIDEyLTIuMTIgMi4xMnonLz4gPC9nPiA8L2c+IDwvc3ZnPg==',
2496
2436
  setting: 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDgiIGhlaWdodD0iNDgiIHZpZXdCb3g9IjAgMCA0OCA0OCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTI0LjM5MjQgNDYuMDJDMjIuNzU5NSA0Ni4wMiAyMS4xMTY5IDQ1LjkzMiAxOS40OTM3IDQ1Ljc1NkMxOC45MDcxIDQ1LjY5NzMgMTguNDI3OSA0NS4yODY3IDE4LjI1MTkgNDQuNzI5M0wxNi42Nzc3IDM5LjY1NDZDMTYuMzM1NSAzOS40ODg0IDE2LjAwMyAzOS4zMTI0IDE1LjY4MDQgMzkuMTE2OEMxNS42NjA4IDM5LjEwNyAxNS42NDEyIDM5LjA5NzMgMTUuNjIxNyAzOS4wNzc3QzE1LjMxODYgMzguOTAxNyAxNS4wMTU1IDM4LjcxNTkgMTQuNzIyMSAzOC41MTA2TDkuNTMwMDcgMzkuNjgzOUM4Ljk2Mjk1IDM5LjgxMTEgOC4zNjY1IDM5LjU4NjIgOC4wMjQyNyAzOS4xMTY4QzYuMDk4MDMgMzYuNDc2OCA0LjQ0NTU3IDMzLjYyMTcgMy4xMjU1NiAzMC42Mjk2QzIuODkwODkgMzAuMDkxOCAyLjk4ODY3IDI5LjQ2NjEgMy4zODk1NiAyOS4wNDU2TDcuMDE3MTUgMjUuMTI0N0M2Ljk2ODI2IDI0LjM4MTYgNi45NjgyNiAyMy42Mzg0IDcuMDE3MTUgMjIuODk1M0wzLjM5OTM0IDE4Ljk3NDRDMi45OTg0NCAxOC41NDQyIDIuOTAwNjcgMTcuOTE4NCAzLjEzNTM0IDE3LjM4MDZDNC40NjUxMyAxNC4zODg2IDYuMTA3ODEgMTEuNTMzNCA4LjAzNDA1IDguOTAzMThDOC4zNzYyOCA4LjQzMzg0IDguOTcyNzMgOC4yMDg5NSA5LjUzOTg0IDguMzM2MDZMMTQuNzUxNSA5LjUwOTQxQzE1LjM2NzUgOS4wOTg3NCAxNi4wMTI4IDguNzI3MTggMTYuNjg3NSA4LjM5NDczTDE4LjI3MTUgMy4yOTA2OEMxOC40NDc1IDIuNzMzMzQgMTguOTM2NCAyLjMzMjQ1IDE5LjUxMzMgMi4yNjRDMjIuNzY5MyAxLjkxMiAyNi4wNjQ1IDEuOTEyIDI5LjMxMDcgMi4yNjRDMjkuODk3NCAyLjMyMjY3IDMwLjM3NjUgMi43MzMzNCAzMC41NTI1IDMuMjkwNjhMMzIuMTI2NyA4LjM2NTRDMzIuODAxNCA4LjY5Nzg1IDMzLjQ2NjMgOS4wNzkxOCAzNC4wOTIxIDkuNDk5NjNMMzkuMjc0NCA4LjMyNjI5QzM5Ljg1MTMgOC4xOTkxNyA0MC40Mzc5IDguNDI0MDYgNDAuNzgwMiA4Ljg5MzRDNDIuNzA2NCAxMS41MzM0IDQ0LjM1ODkgMTQuMzg4NiA0NS42Nzg5IDE3LjM4MDZDNDUuOTEzNSAxNy45MTg0IDQ1LjgxNTggMTguNTM0NCA0NS40MTQ5IDE4Ljk2NDZMNDEuNzg3MyAyMi44ODU1QzQxLjgzNjIgMjMuNjI4NyA0MS44MzYyIDI0LjM3MTggNDEuNzg3MyAyNS4xMTQ5TDQ1LjQwNTEgMjkuMDM1OEM0NS44MDYgMjkuNDY2MSA0NS45MDM4IDMwLjA5MTggNDUuNjY5MSAzMC42Mjk2QzQ1LjAwNDIgMzIuMTE1OSA0NC4yNjExIDMzLjU5MjMgNDMuNDQ5NSAzNS4wMDAzQzQyLjYzOCAzNi40MDgzIDQxLjczODQgMzcuNzk2OCA0MC43NzA0IDM5LjEwN0M0MC40MjgyIDM5LjU3NjQgMzkuODMxNyAzOS44MDEzIDM5LjI2NDYgMzkuNjc0MkwzNC4wNjI4IDM4LjUwMDhDMzMuNDQ2OCAzOC45MTE1IDMyLjgwMTQgMzkuMjgzIDMyLjEyNjcgMzkuNjE1NUwzMC41NDI3IDQ0LjcwOThDMzAuMzY2NyA0NS4yNjcxIDI5Ljg3NzggNDUuNjY4IDI5LjMwMDkgNDUuNzM2NEMyNy42Nzc4IDQ1LjkxMjQgMjYuMDM1MSA0Ni4wMDA0IDI0LjQwMjIgNDYuMDAwNEwyNC4zOTI0IDQ2LjAyWk0yMC43NjQ4IDQyLjkzMDJDMjMuMTggNDMuMTM1NSAyNS42MTQ3IDQzLjEzNTUgMjguMDI5OCA0Mi45MzAyTDI5LjUxNiAzOC4xNDg4QzI5LjY0MzIgMzcuNzQ3OSAyOS45MzY1IDM3LjQxNTUgMzAuMzE3OCAzNy4yNDkyQzMxLjIxNzQgMzYuODQ4NCAzMi4wODc2IDM2LjM0OTcgMzIuODg5NCAzNS43NjNDMzMuMjMxNiAzNS41MTg2IDMzLjY2MTkgMzUuNDMwNiAzNC4wNzI1IDM1LjUxODZMMzguOTUxNyAzNi42MjM1QzM5LjY0NTkgMzUuNjI2MSA0MC4zMDEgMzQuNTk5NCA0MC44OTc1IDMzLjU1MzJDNDEuNTAzNyAzMi41MDcgNDIuMDYxMSAzMS40MzE0IDQyLjU3OTMgMzAuMzM2M0wzOS4xODY0IDI2LjY1OThDMzguOTAyOCAyNi4zNDY5IDM4Ljc2NTkgMjUuOTM2MiAzOC44MDUgMjUuNTE1OEMzOC45MDI4IDI0LjUyODIgMzguOTAyOCAyMy41MjExIDM4LjgwNSAyMi41NDMzQzM4Ljc2NTkgMjIuMTIyOSAzOC45MDI4IDIxLjcwMjQgMzkuMTg2NCAyMS4zOTkzTDQyLjU4OTEgMTcuNzEzQzQxLjU2MjQgMTUuNTIyOCA0MC4zNDAyIDEzLjQxMDggMzguOTYxNSAxMS40MjU5TDM0LjEwMTkgMTIuNTIxQzMzLjY5MTIgMTIuNjE4OCAzMy4yNjEgMTIuNTIxIDMyLjkxODcgMTIuMjc2NUMzMi4xMDcyIDExLjY4OTkgMzEuMjI3MiAxMS4xODE0IDMwLjMxNzggMTAuNzcwOEMyOS45MzY1IDEwLjU5NDggMjkuNjQzMiAxMC4yNzIxIDI5LjUxNiA5Ljg2MTQxTDI4LjAzOTYgNS4wOTk1OUMyNS42MjQ1IDQuODk0MjUgMjMuMTg5OCA0Ljg5NDI1IDIwLjc3NDYgNS4wOTk1OUwxOS4yODg0IDkuODkwNzVDMTkuMTYxMyAxMC4yOTE2IDE4Ljg2NzkgMTAuNjI0MSAxOC40ODY2IDEwLjc5MDNDMTcuNTc3MyAxMS4xOTEyIDE2LjcxNjggMTEuNjg5OSAxNS45MTUgMTIuMjc2NUMxNS41NzI4IDEyLjUyMSAxNS4xNDI2IDEyLjYwOSAxNC43MzE5IDEyLjUyMUw5Ljg0Mjk2IDExLjQxNjFDOC40NjQyOCAxMy40MDEgNy4yNDIwNCAxNS41MTMgNi4yMTUzNyAxNy43MDMzTDkuNjA4MjkgMjEuMzc5OEM5Ljg5MTg1IDIxLjY5MjYgMTAuMDI4NyAyMi4xMDMzIDkuOTg5NjMgMjIuNTIzOEM5Ljg5MTg1IDIzLjUxMTMgOS44OTE4NSAyNC41MDg3IDkuOTg5NjMgMjUuNDk2MkMxMC4wMjg3IDI1LjkxNjcgOS44OTE4NSAyNi4zMzcxIDkuNjA4MjkgMjYuNjVMNi4yMDU1OSAzMC4zMzYzQzcuMjMyMjcgMzIuNTI2NSA4LjQ1NDUgMzQuNjM4NiA5LjgzMzE4IDM2LjYyMzVMMTQuNzAyNiAzNS41MjgzQzE1LjExMzIgMzUuNDMwNiAxNS41NDM1IDM1LjUyODMgMTUuODg1NyAzNS43NzI4QzE2LjI5NjQgMzYuMDY2MSAxNi43MjY2IDM2LjM0OTcgMTcuMTU2OCAzNi41OTQxQzE3LjE3NjQgMzYuNjAzOSAxNy4xOTU5IDM2LjYxMzcgMTcuMjA1NyAzNi42MjM1QzE3LjYyNjEgMzYuODU4MSAxOC4wNTY0IDM3LjA4MyAxOC40OTY0IDM3LjI3ODZDMTguODc3NyAzNy40NTQ2IDE5LjE3MTEgMzcuNzc3MyAxOS4yOTgyIDM4LjE3ODFMMjAuNzc0NiA0Mi45NEwyMC43NjQ4IDQyLjkzMDJaTTI0LjM4MjcgMzIuMzMxQzIyLjk0NTMgMzIuMzMxIDIxLjUxNzcgMzEuOTQ5NiAyMC4yMzY4IDMxLjIxNjNDMTYuMjg2NiAyOC45MzgxIDE0LjkxNzcgMjMuODkyNyAxNy4xNTY4IDE5LjkzMjZDMTcuMTY2NiAxOS45MTMxIDE3LjE3NjQgMTkuODgzNyAxNy4xOTU5IDE5Ljg2NDJDMTguMzAwOCAxNy45Mzc5IDIwLjEgMTYuNTY5IDIyLjI0MTMgMTUuOTkyMUMyNC4zODI3IDE1LjQxNTIgMjYuNjIxOCAxNS43MDg2IDI4LjU0OCAxNi44MjMzQzMwLjQ3NDMgMTcuOTM3OSAzMS44NDMyIDE5LjcyNzMgMzIuNDIwMSAyMS44Njg2QzMyLjk5NyAyNC4wMSAzMi43MDM2IDI2LjI0OTEgMzEuNTg5IDI4LjE3NTRDMzAuNDg0MSAzMC4xMDE2IDI4LjY4NDkgMzEuNDcwNSAyNi41NDM2IDMyLjA0NzRDMjUuODI5OCAzMi4yNDMgMjUuMTA2MiAzMi4zMzEgMjQuMzgyNyAzMi4zMzFaTTE5Ljc2NzUgMjEuMjcyMkMxOS43Njc1IDIxLjI3MjIgMTkuNzQ3OSAyMS4zMTEzIDE5LjczODIgMjEuMzMwOUMxOC4yNTE5IDIzLjkwMjQgMTkuMTQxNyAyNy4xOTc2IDIxLjcwMzUgMjguNjc0QzIyLjk0NTMgMjkuMzg3OCAyNC4zOTI0IDI5LjU4MzQgMjUuNzgwOSAyOS4yMTE4QzI3LjE2OTQgMjguODQwMyAyOC4zMzI5IDI3Ljk1MDUgMjkuMDQ2NyAyNi43MDg3QzI5Ljc2MDUgMjUuNDY2OSAyOS45NTYxIDI0LjAxOTggMjkuNTg0NSAyMi42MzEzQzI5LjIxMjkgMjEuMjQyOSAyOC4zMjMxIDIwLjA4OTEgMjcuMDgxNCAxOS4zNjU1QzI1LjgzOTYgMTguNjQxOSAyNC4zODI3IDE4LjQ1NjIgMjMuMDA0IDE4LjgyNzdDMjEuNjM1MSAxOS4xODk1IDIwLjQ5MTEgMjAuMDU5NyAxOS43Njc1IDIxLjI4MlYyMS4yNzIyWiIgZmlsbD0id2hpdGUiLz4KPC9zdmc+Cg==',
2437
+ subtitle: 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzNiIgaGVpZ2h0PSIzNiIgZmlsbD0ibm9uZSI+CiAgPHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1vcGFjaXR5PSIuOCIgZD0iTTExLjMgMzIuOWMuOCAwIDEuMzQtLjQxIDIuMzItMS4zbDQuODYtNC4zNUgyN2M0LjQ3IDAgNi44LTIuNDEgNi44LTYuOFY5LjljMC00LjQtMi4zMy02LjgtNi44LTYuOEg5Yy00LjQ2IDAtNi44IDIuNC02LjggNi44djEwLjU1YzAgNC4zOSAyLjM0IDYuOCA2LjggNi44aC41MnYzLjZjMCAxLjI2LjY0IDIuMDYgMS43OCAyLjA2bS42Ny0yLjk3di00LjA4YzAtLjg4LS4zMi0xLjIxLTEuMjEtMS4yMUg5Yy0yLjkyIDAtNC4xOS0xLjQtNC4xOS00LjE5VjkuOWMwLTIuNzggMS4yNy00LjE3IDQuMTktNC4xN2gxOGMyLjkyIDAgNC4yIDEuNCA0LjIgNC4xN3YxMC41NWMwIDIuOC0xLjI4IDQuMTktNC4yIDQuMTloLTguNjZjLS44NyAwLTEuMzMuMTMtMS45Ljc0eiIvPgogIDxwYXRoIGZpbGw9IiNmZmYiIGZpbGwtb3BhY2l0eT0iLjgiIGZpbGwtcnVsZT0iZXZlbm9kZCIgZD0iTTEzLjc1IDMxLjc1Yy0uOTcuODgtMS41NyAxLjM1LTIuNDUgMS4zNXEtLjk0IDAtMS40Ny0uNjItLjUtLjYyLS41LTEuNjJ2LTMuNDFIOXEtMy40MS0uMDEtNS4yMi0xLjgyUTIgMjMuODEgMiAyMC40NVY5LjljMC0yLjIzLjYtMy45OSAxLjc4LTUuMTlRNS41OCAyLjkxIDkgMi45aDE4cTMuNDEgMCA1LjIyIDEuODFDMzMuNCA1LjkxIDM0IDcuNjcgMzQgOS45djEwLjU1YzAgMi4yMy0uNiAzLjk5LTEuNzggNS4xOHEtMS44IDEuODEtNS4yMiAxLjgyaC04LjQ0em0tLjEzLS4xNWMtLjk4Ljg5LTEuNTIgMS4zLTIuMzIgMS4zLTEuMTQgMC0xLjc4LS43OS0xLjc4LTIuMDR2LTMuNjFIOWMtNC40NiAwLTYuOC0yLjQxLTYuOC02LjhWOS45YzAtNC40IDIuMzQtNi44IDYuOC02LjhoMThjNC40NiAwIDYuOCAyLjQgNi44IDYuOHYxMC41NWMwIDQuMzktMi4zNCA2LjgtNi44IDYuOGgtOC41MnptLTEuNjUtNS43NWMwLS44OC0uMzMtMS4yMS0xLjIxLTEuMjFIOWMtMi45MiAwLTQuMi0xLjQtNC4yLTQuMTlWOS45YzAtMi43OCAxLjI4LTQuMTcgNC4yLTQuMTdoMThjMi45MiAwIDQuMiAxLjQgNC4yIDQuMTd2MTAuNTVjMCAyLjgtMS4yOCA0LjE5LTQuMiA0LjE5aC04LjY2Yy0uODcgMC0xLjMzLjEzLTEuOS43NGwtNC40NyA0LjU1em0uMiAzLjZ2LTMuNmMwLS40Ni0uMDgtLjgzLS4zMy0xLjA4cy0uNjItLjMzLTEuMDgtLjMzSDljLTEuNDMgMC0yLjQyLS4zNC0zLjA1LS45OXEtLjk0LS45NS0uOTQtM1Y5LjlxLS4wMS0yLjAzLjk0LTMgLjkyLS45NyAzLjA1LS45OWgxOHEyLjEzLjAyIDMuMDUuOTkuOTQuOTYuOTQgMi45OXYxMC41NXEuMDEgMi4wNS0uOTQgMy0uOTMuOTktMy4wNSAxaC04LjY2cS0uNjYtLjAyLTEuMTMuMTQtLjQ5LjE4LS45Mi42NnoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPgogIDxwYXRoIGZpbGw9IiNmZmYiIGZpbGwtb3BhY2l0eT0iLjgiIGQ9Ik05LjI5IDE2LjgyaDUuNjVhLjkuOSAwIDAgMCAuOTEtLjkyLjkuOSAwIDAgMC0uOS0uOUg5LjI4YS45LjkgMCAwIDAtLjkxLjljMCAuNTIuNC45Mi45LjkybTguNDggMGg4LjkyYS45LjkgMCAwIDAgLjkzLS45MmMwLS41LS40LS45LS45My0uOWgtOC45MmEuOS45IDAgMCAwLS45LjljMCAuNTIuNC45Mi45LjkyTTkuMyAyMC43aDIuMzdjLjUgMCAuOS0uNDIuOS0uOTNhLjkuOSAwIDAgMC0uOS0uOTJIOS4zYS45LjkgMCAwIDAtLjkxLjkyYzAgLjUuNC45My45LjkzbTUuMiAwaDYuOThjLjUgMCAuOS0uNDIuOS0uOTNhLjkuOSAwIDAgMC0uOS0uOTJIMTQuNWMtLjUgMC0uOS40LS45LjkyIDAgLjUuNC45My45LjkzbTkuOCAwaDIuNGMuNTMgMCAuOTMtLjQyLjkzLS45M2EuOS45IDAgMCAwLS45My0uOTJoLTIuNGEuOS45IDAgMCAwLS45Mi45MmMwIC41LjQuOTMuOTEuOTMiLz4KPC9zdmc+',
2497
2438
  check: 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPScyMCcgaGVpZ2h0PScyMCcgdmlld0JveD0nMCAwIDIwIDIwJz48cGF0aCBmaWxsPScjRkZGJyBmaWxsLXJ1bGU9J25vbnplcm8nIGQ9J00yLjkwMiA5LjI2MWExLjA4NyAxLjA4NyAwIDAgMC0xLjU3NiAwIDEuMTgzIDEuMTgzIDAgMCAwIDAgMS42MzJsNS41NzEgNS43NjljLjQzNS40NSAxLjE0LjQ1IDEuNTc2IDBsMTEuMi0xMS42OTJhMS4xODMgMS4xODMgMCAwIDAgMC0xLjYzMiAxLjA4NyAxLjA4NyAwIDAgMC0xLjU3NSAwTDcuNjg1IDE0LjIxNCAyLjkwMiA5LjI2MXonLz48L3N2Zz4K',
2498
2439
  fullscreen: 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDgiIGhlaWdodD0iNDgiIHZpZXdCb3g9IjAgMCA0OCA0OCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwXzExNTlfMTE4KSI+CjxwYXRoIGQ9Ik0xMC4wMDAyIDYuMDAwMkM3LjgxNDA3IDYuMDAwMiA2LjAwMDIgNy44MTQwNyA2LjAwMDIgMTAuMDAwMlYxNi4wMDAyQzUuOTk2NDUgMTYuMjY1MiA2LjA0NTQxIDE2LjUyODMgNi4xNDQyNCAxNi43NzQzQzYuMjQzMDcgMTcuMDIwMiA2LjM4OTc5IDE3LjI0NDEgNi41NzU4OCAxNy40MzI4QzYuNzYxOTcgMTcuNjIxNSA2Ljk4MzcxIDE3Ljc3MTQgNy4yMjgyMyAxNy44NzM3QzcuNDcyNzQgMTcuOTc2IDcuNzM1MTUgMTguMDI4NyA4LjAwMDIgMTguMDI4N0M4LjI2NTI1IDE4LjAyODcgOC41Mjc2NiAxNy45NzYgOC43NzIxNyAxNy44NzM3QzkuMDE2NjkgMTcuNzcxNCA5LjIzODQzIDE3LjYyMTUgOS40MjQ1MiAxNy40MzI4QzkuNjEwNjEgMTcuMjQ0MSA5Ljc1NzMzIDE3LjAyMDIgOS44NTYxNiAxNi43NzQzQzkuOTU0OTkgMTYuNTI4MyAxMC4wMDM5IDE2LjI2NTIgMTAuMDAwMiAxNi4wMDAyVjEwLjAwMDJIMTYuMDAwMkMxNi4yNjUyIDEwLjAwMzkgMTYuNTI4MyA5Ljk1NDk5IDE2Ljc3NDMgOS44NTYxNkMxNy4wMjAyIDkuNzU3MzMgMTcuMjQ0MSA5LjYxMDYxIDE3LjQzMjggOS40MjQ1MkMxNy42MjE1IDkuMjM4NDMgMTcuNzcxNCA5LjAxNjY5IDE3Ljg3MzcgOC43NzIxN0MxNy45NzYgOC41Mjc2NiAxOC4wMjg3IDguMjY1MjUgMTguMDI4NyA4LjAwMDJDMTguMDI4NyA3LjczNTE1IDE3Ljk3NiA3LjQ3Mjc0IDE3Ljg3MzcgNy4yMjgyM0MxNy43NzE0IDYuOTgzNzEgMTcuNjIxNSA2Ljc2MTk3IDE3LjQzMjggNi41NzU4OEMxNy4yNDQxIDYuMzg5NzkgMTcuMDIwMiA2LjI0MzA3IDE2Ljc3NDMgNi4xNDQyNEMxNi41MjgzIDYuMDQ1NDEgMTYuMjY1MiA1Ljk5NjQ1IDE2LjAwMDIgNi4wMDAySDEwLjAwMDJaTTMyLjAwMDIgNi4wMDAyQzMxLjczNTIgNS45OTY0NSAzMS40NzIxIDYuMDQ1NDEgMzEuMjI2MSA2LjE0NDI0QzMwLjk4MDIgNi4yNDMwNyAzMC43NTYzIDYuMzg5NzkgMzAuNTY3NiA2LjU3NTg4QzMwLjM3ODkgNi43NjE5NyAzMC4yMjkgNi45ODM3MSAzMC4xMjY3IDcuMjI4MjNDMzAuMDI0NCA3LjQ3Mjc0IDI5Ljk3MTcgNy43MzUxNSAyOS45NzE3IDguMDAwMkMyOS45NzE3IDguMjY1MjUgMzAuMDI0NCA4LjUyNzY2IDMwLjEyNjcgOC43NzIxN0MzMC4yMjkgOS4wMTY2OSAzMC4zNzg5IDkuMjM4NDMgMzAuNTY3NiA5LjQyNDUyQzMwLjc1NjMgOS42MTA2MSAzMC45ODAyIDkuNzU3MzMgMzEuMjI2MSA5Ljg1NjE2QzMxLjQ3MjEgOS45NTQ5OSAzMS43MzUyIDEwLjAwMzkgMzIuMDAwMiAxMC4wMDAySDM4LjAwMDJWMTYuMDAwMkMzNy45OTY1IDE2LjI2NTIgMzguMDQ1NCAxNi41MjgzIDM4LjE0NDIgMTYuNzc0M0MzOC4yNDMxIDE3LjAyMDIgMzguMzg5OCAxNy4yNDQxIDM4LjU3NTkgMTcuNDMyOEMzOC43NjIgMTcuNjIxNSAzOC45ODM3IDE3Ljc3MTQgMzkuMjI4MiAxNy44NzM3QzM5LjQ3MjcgMTcuOTc2IDM5LjczNTEgMTguMDI4NyA0MC4wMDAyIDE4LjAyODdDNDAuMjY1MiAxOC4wMjg3IDQwLjUyNzcgMTcuOTc2IDQwLjc3MjIgMTcuODczN0M0MS4wMTY3IDE3Ljc3MTQgNDEuMjM4NCAxNy42MjE1IDQxLjQyNDUgMTcuNDMyOEM0MS42MTA2IDE3LjI0NDEgNDEuNzU3MyAxNy4wMjAyIDQxLjg1NjIgMTYuNzc0M0M0MS45NTUgMTYuNTI4MyA0Mi4wMDM5IDE2LjI2NTIgNDIuMDAwMiAxNi4wMDAyVjEwLjAwMDJDNDIuMDAwMiA3LjgxNDA3IDQwLjE4NjMgNi4wMDAyIDM4LjAwMDIgNi4wMDAySDMyLjAwMDJaTTcuOTY4OTUgMjkuOTcyOUM3LjQzOTIgMjkuOTgxMSA2LjkzNDM4IDMwLjE5OTMgNi41NjUyNyAzMC41NzkzQzYuMTk2MTcgMzAuOTU5NCA1Ljk5Mjk1IDMxLjQ3MDQgNi4wMDAyIDMyLjAwMDJWMzguMDAwMkM2LjAwMDIgNDAuMTg2MyA3LjgxNDA3IDQyLjAwMDIgMTAuMDAwMiA0Mi4wMDAySDE2LjAwMDJDMTYuMjY1MiA0Mi4wMDM5IDE2LjUyODMgNDEuOTU1IDE2Ljc3NDMgNDEuODU2MkMxNy4wMjAyIDQxLjc1NzMgMTcuMjQ0MSA0MS42MTA2IDE3LjQzMjggNDEuNDI0NUMxNy42MjE1IDQxLjIzODQgMTcuNzcxNCA0MS4wMTY3IDE3Ljg3MzcgNDAuNzcyMkMxNy45NzYgNDAuNTI3NyAxOC4wMjg3IDQwLjI2NTIgMTguMDI4NyA0MC4wMDAyQzE4LjAyODcgMzkuNzM1MSAxNy45NzYgMzkuNDcyNyAxNy44NzM3IDM5LjIyODJDMTcuNzcxNCAzOC45ODM3IDE3LjYyMTUgMzguNzYyIDE3LjQzMjggMzguNTc1OUMxNy4yNDQxIDM4LjM4OTggMTcuMDIwMiAzOC4yNDMxIDE2Ljc3NDMgMzguMTQ0MkMxNi41MjgzIDM4LjA0NTQgMTYuMjY1MiAzNy45OTY1IDE2LjAwMDIgMzguMDAwMkgxMC4wMDAyVjMyLjAwMDJDMTAuMDAzOSAzMS43MzI2IDkuOTUzOCAzMS40NjcgOS44NTI5NyAzMS4yMTkxQzkuNzUyMTMgMzAuOTcxMyA5LjYwMjU5IDMwLjc0NjEgOS40MTMxOCAzMC41NTcxQzkuMjIzNzcgMzAuMzY4MSA4Ljk5ODM2IDMwLjIxODkgOC43NTAyOCAzMC4xMTg2QzguNTAyMjEgMzAuMDE4MiA4LjIzNjUyIDI5Ljk2ODcgNy45Njg5NSAyOS45NzI5Wk0zOS45Njg5IDI5Ljk3MjlDMzkuNDM5MiAyOS45ODExIDM4LjkzNDQgMzAuMTk5MyAzOC41NjUzIDMwLjU3OTNDMzguMTk2MiAzMC45NTk0IDM3Ljk5MjkgMzEuNDcwNCAzOC4wMDAyIDMyLjAwMDJWMzguMDAwMkgzMi4wMDAyQzMxLjczNTIgMzcuOTk2NSAzMS40NzIxIDM4LjA0NTQgMzEuMjI2MSAzOC4xNDQyQzMwLjk4MDIgMzguMjQzMSAzMC43NTYzIDM4LjM4OTggMzAuNTY3NiAzOC41NzU5QzMwLjM3ODkgMzguNzYyIDMwLjIyOSAzOC45ODM3IDMwLjEyNjcgMzkuMjI4MkMzMC4wMjQ0IDM5LjQ3MjcgMjkuOTcxNyAzOS43MzUxIDI5Ljk3MTcgNDAuMDAwMkMyOS45NzE3IDQwLjI2NTIgMzAuMDI0NCA0MC41Mjc3IDMwLjEyNjcgNDAuNzcyMkMzMC4yMjkgNDEuMDE2NyAzMC4zNzg5IDQxLjIzODQgMzAuNTY3NiA0MS40MjQ1QzMwLjc1NjMgNDEuNjEwNiAzMC45ODAyIDQxLjc1NzMgMzEuMjI2MSA0MS44NTYyQzMxLjQ3MjEgNDEuOTU1IDMxLjczNTIgNDIuMDAzOSAzMi4wMDAyIDQyLjAwMDJIMzguMDAwMkM0MC4xODYzIDQyLjAwMDIgNDIuMDAwMiA0MC4xODYzIDQyLjAwMDIgMzguMDAwMlYzMi4wMDAyQzQyLjAwMzkgMzEuNzMyNiA0MS45NTM4IDMxLjQ2NyA0MS44NTMgMzEuMjE5MUM0MS43NTIxIDMwLjk3MTMgNDEuNjAyNiAzMC43NDYxIDQxLjQxMzIgMzAuNTU3MUM0MS4yMjM4IDMwLjM2ODEgNDAuOTk4NCAzMC4yMTg5IDQwLjc1MDMgMzAuMTE4NkM0MC41MDIyIDMwLjAxODIgNDAuMjM2NSAyOS45Njg3IDM5Ljk2ODkgMjkuOTcyOVoiIGZpbGw9IndoaXRlIi8+CjwvZz4KPGRlZnM+CjxjbGlwUGF0aCBpZD0iY2xpcDBfMTE1OV8xMTgiPgo8cmVjdCB3aWR0aD0iNDgiIGhlaWdodD0iNDgiIGZpbGw9IndoaXRlIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+Cg==',
2499
2440
  'exit-fullscreen': 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDgiIGhlaWdodD0iNDgiIHZpZXdCb3g9IjAgMCA0OCA0OCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwXzExNTlfMTMyKSI+CjxwYXRoIGQ9Ik0xNi45NzA3IDUuOTcyNjZDMTYuNDQwNiA1Ljk4MDQyIDE1LjkzNTMgNi4xOTgzMiAxNS41NjU3IDYuNTc4NDZDMTUuMTk2MiA2Ljk1ODYxIDE0Ljk5MjcgNy40Njk5IDE1IDhMMTQuOTk4IDEzLjVDMTQuOTk4IDE0LjM0NTQgMTQuMzQzNCAxNSAxMy40OTggMTVINy45OTgwM0M3LjczMyAxNC45OTYzIDcuNDY5ODggMTUuMDQ1MiA3LjIyMzk0IDE1LjE0NEM2Ljk3ODAxIDE1LjI0MjkgNi43NTQxNiAxNS4zODk2IDYuNTY1NDIgMTUuNTc1N0M2LjM3NjY4IDE1Ljc2MTggNi4yMjY4MSAxNS45ODM1IDYuMTI0NTIgMTYuMjI4QzYuMDIyMjIgMTYuNDcyNSA1Ljk2OTU0IDE2LjczNDkgNS45Njk1NCAxN0M1Ljk2OTU0IDE3LjI2NSA2LjAyMjIyIDE3LjUyNzUgNi4xMjQ1MiAxNy43NzJDNi4yMjY4MSAxOC4wMTY1IDYuMzc2NjggMTguMjM4MiA2LjU2NTQyIDE4LjQyNDNDNi43NTQxNiAxOC42MTA0IDYuOTc4MDEgMTguNzU3MSA3LjIyMzk0IDE4Ljg1NkM3LjQ2OTg4IDE4Ljk1NDggNy43MzMgMTkuMDAzNyA3Ljk5ODAzIDE5SDEzLjQ5OEMxNi41MTI3IDE5IDE4Ljk5OCAxNi41MTQ2IDE4Ljk5OCAxMy41TDE5IDhDMTkuMDAzNiA3LjczMjU5IDE4Ljk1MzYgNy40NjcxNiAxOC44NTI5IDcuMjE5NDFDMTguNzUyMiA2Ljk3MTY2IDE4LjYwMjggNi43NDY2MiAxOC40MTM2IDYuNTU3NjFDMTguMjI0NCA2LjM2ODU5IDE3Ljk5OTMgNi4yMTk0NCAxNy43NTE0IDYuMTE4OTZDMTcuNTAzNiA2LjAxODQ5IDE3LjIzODEgNS45Njg3NCAxNi45NzA3IDUuOTcyNjZaTTMwLjk3MDcgNS45NzI2NkMzMC40NDA5IDUuOTgwOTQgMjkuOTM2MSA2LjE5OTA2IDI5LjU2NyA2LjU3OTE0QzI5LjE5NzkgNi45NTkyMyAyOC45OTQ3IDcuNDcwMjMgMjkuMDAxOSA4TDI5IDEzLjVDMjkgMTYuNTE0NiAzMS40ODU0IDE5IDM0LjUgMTlINDBDNDAuMjY1IDE5LjAwMzcgNDAuNTI4MSAxOC45NTQ4IDQwLjc3NDEgMTguODU2QzQxLjAyIDE4Ljc1NzEgNDEuMjQzOSAxOC42MTA0IDQxLjQzMjYgMTguNDI0M0M0MS42MjEzIDE4LjIzODIgNDEuNzcxMiAxOC4wMTY1IDQxLjg3MzUgMTcuNzcyQzQxLjk3NTggMTcuNTI3NSA0Mi4wMjg1IDE3LjI2NSA0Mi4wMjg1IDE3QzQyLjAyODUgMTYuNzM0OSA0MS45NzU4IDE2LjQ3MjUgNDEuODczNSAxNi4yMjhDNDEuNzcxMiAxNS45ODM1IDQxLjYyMTMgMTUuNzYxOCA0MS40MzI2IDE1LjU3NTdDNDEuMjQzOSAxNS4zODk2IDQxLjAyIDE1LjI0MjkgNDAuNzc0MSAxNS4xNDRDNDAuNTI4MSAxNS4wNDUyIDQwLjI2NSAxNC45OTYzIDQwIDE1SDM0LjVDMzMuNjU0NiAxNSAzMyAxNC4zNDU0IDMzIDEzLjVMMzMuMDAxOSA4QzMzLjAwNTYgNy43MzI0MiAzMi45NTU1IDcuNDY2ODMgMzIuODU0NyA3LjIxODk1QzMyLjc1MzkgNi45NzEwNyAzMi42MDQzIDYuNzQ1OTQgMzIuNDE0OSA2LjU1NjlDMzIuMjI1NSA2LjM2Nzg1IDMyLjAwMDEgNi4yMTg3NCAzMS43NTIgNi4xMTgzOUMzMS41MDM5IDYuMDE4MDMgMzEuMjM4MyA1Ljk2ODQ4IDMwLjk3MDcgNS45NzI2NlpNNy45OTk5OCAyOUM3LjczNDk2IDI4Ljk5NjIgNy40NzE4MyAyOS4wNDUyIDcuMjI1OSAyOS4xNDRDNi45Nzk5NiAyOS4yNDI5IDYuNzU2MTIgMjkuMzg5NiA2LjU2NzM4IDI5LjU3NTdDNi4zNzg2NCAyOS43NjE4IDYuMjI4NzcgMjkuOTgzNSA2LjEyNjQ3IDMwLjIyOEM2LjAyNDE3IDMwLjQ3MjUgNS45NzE1IDMwLjczNDkgNS45NzE1IDMxQzUuOTcxNSAzMS4yNjUgNi4wMjQxNyAzMS41Mjc1IDYuMTI2NDcgMzEuNzcyQzYuMjI4NzcgMzIuMDE2NSA2LjM3ODY0IDMyLjIzODIgNi41NjczOCAzMi40MjQzQzYuNzU2MTIgMzIuNjEwNCA2Ljk3OTk2IDMyLjc1NzEgNy4yMjU5IDMyLjg1NkM3LjQ3MTgzIDMyLjk1NDggNy43MzQ5NiAzMy4wMDM3IDcuOTk5OTggMzNIMTMuNUMxNC4zNDU0IDMzIDE1IDMzLjY1NDYgMTUgMzQuNVY0MEMxNC45OTYyIDQwLjI2NSAxNS4wNDUyIDQwLjUyODEgMTUuMTQ0IDQwLjc3NDFDMTUuMjQyOSA0MS4wMiAxNS4zODk2IDQxLjI0MzkgMTUuNTc1NyA0MS40MzI2QzE1Ljc2MTggNDEuNjIxMyAxNS45ODM1IDQxLjc3MTIgMTYuMjI4IDQxLjg3MzVDMTYuNDcyNSA0MS45NzU4IDE2LjczNDkgNDIuMDI4NSAxNyA0Mi4wMjg1QzE3LjI2NSA0Mi4wMjg1IDE3LjUyNzQgNDEuOTc1OCAxNy43NzIgNDEuODczNUMxOC4wMTY1IDQxLjc3MTIgMTguMjM4MiA0MS42MjEzIDE4LjQyNDMgNDEuNDMyNkMxOC42MTA0IDQxLjI0MzkgMTguNzU3MSA0MS4wMiAxOC44NTU5IDQwLjc3NDFDMTguOTU0OCA0MC41MjgxIDE5LjAwMzcgNDAuMjY1IDE5IDQwVjM0LjVDMTkgMzEuNDg1NCAxNi41MTQ2IDI5IDEzLjUgMjlINy45OTk5OFpNMzQuNSAyOUMzMS40ODU0IDI5IDI5IDMxLjQ4NTQgMjkgMzQuNVY0MEMyOC45OTYyIDQwLjI2NSAyOS4wNDUyIDQwLjUyODEgMjkuMTQ0IDQwLjc3NDFDMjkuMjQyOSA0MS4wMiAyOS4zODk2IDQxLjI0MzkgMjkuNTc1NyA0MS40MzI2QzI5Ljc2MTggNDEuNjIxMyAyOS45ODM1IDQxLjc3MTIgMzAuMjI4IDQxLjg3MzVDMzAuNDcyNSA0MS45NzU4IDMwLjczNDkgNDIuMDI4NSAzMSA0Mi4wMjg1QzMxLjI2NSA0Mi4wMjg1IDMxLjUyNzQgNDEuOTc1OCAzMS43NzIgNDEuODczNUMzMi4wMTY1IDQxLjc3MTIgMzIuMjM4MiA0MS42MjEzIDMyLjQyNDMgNDEuNDMyNkMzMi42MTA0IDQxLjI0MzkgMzIuNzU3MSA0MS4wMiAzMi44NTU5IDQwLjc3NDFDMzIuOTU0OCA0MC41MjgxIDMzLjAwMzcgNDAuMjY1IDMzIDQwVjM0LjVDMzMgMzMuNjU0NiAzMy42NTQ2IDMzIDM0LjUgMzNINDBDNDAuMjY1IDMzLjAwMzcgNDAuNTI4MSAzMi45NTQ4IDQwLjc3NDEgMzIuODU2QzQxLjAyIDMyLjc1NzEgNDEuMjQzOSAzMi42MTA0IDQxLjQzMjYgMzIuNDI0M0M0MS42MjEzIDMyLjIzODIgNDEuNzcxMiAzMi4wMTY1IDQxLjg3MzUgMzEuNzcyQzQxLjk3NTggMzEuNTI3NSA0Mi4wMjg1IDMxLjI2NSA0Mi4wMjg1IDMxQzQyLjAyODUgMzAuNzM0OSA0MS45NzU4IDMwLjQ3MjUgNDEuODczNSAzMC4yMjhDNDEuNzcxMiAyOS45ODM1IDQxLjYyMTMgMjkuNzYxOCA0MS40MzI2IDI5LjU3NTdDNDEuMjQzOSAyOS4zODk2IDQxLjAyIDI5LjI0MjkgNDAuNzc0MSAyOS4xNDRDNDAuNTI4MSAyOS4wNDUyIDQwLjI2NSAyOC45OTYyIDQwIDI5SDM0LjVaIiBmaWxsPSJ3aGl0ZSIvPgo8L2c+CjxkZWZzPgo8Y2xpcFBhdGggaWQ9ImNsaXAwXzExNTlfMTMyIj4KPHJlY3Qgd2lkdGg9IjQ4IiBoZWlnaHQ9IjQ4IiBmaWxsPSJ3aGl0ZSIvPgo8L2NsaXBQYXRoPgo8L2RlZnM+Cjwvc3ZnPgo=',
@@ -3050,7 +2991,7 @@ const invisible = hiddenArea => ({
3050
2991
  visibility: `var(${hiddenArea}, visible)`
3051
2992
  });
3052
2993
 
3053
- const containerStyle$4 = {
2994
+ const containerStyle$6 = {
3054
2995
  '--spacing': '0.5em',
3055
2996
  '--center-pointer-events': 'auto',
3056
2997
  width: '100%',
@@ -3373,7 +3314,7 @@ const DefaultLayout = ({
3373
3314
  '--player-bottom-ui-top': controlsDisplay === 'shown' ? `-${bottomUiTop(containerRef.current)}px` : '-8px',
3374
3315
  '--player-bottom-ui-height': type === 'desktop' && controlsDisplay === 'shown' ? '3.5rem' : '0'
3375
3316
  },
3376
- css: [containerStyle$4, videoContainerStyle, responsiveStyles[size], type === 'desktop' && desktopStyle$2, adStatus && {
3317
+ css: [containerStyle$6, videoContainerStyle, responsiveStyles[size], type === 'desktop' && desktopStyle$2, adStatus && {
3377
3318
  '--bottom-spacing': 0
3378
3319
  }, nativeTextStyle, customTextStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:DefaultLayout;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DefaultLayout.js"],"names":[],"mappings":"AAiWM","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"]} */"],
3379
3320
  ref: containerRef,
@@ -3608,7 +3549,7 @@ const pointerHandlers = ({
3608
3549
  };
3609
3550
 
3610
3551
  /* eslint-disable no-param-reassign */
3611
- const containerStyle$3 = {
3552
+ const containerStyle$5 = {
3612
3553
  position: 'relative',
3613
3554
  width: '100%',
3614
3555
  height: '100%',
@@ -3857,7 +3798,7 @@ const SimpleSlider = ({
3857
3798
  };
3858
3799
  return jsxs("div", {
3859
3800
  className: className,
3860
- css: [containerStyle$3, disabled && disabledStyle, process.env.NODE_ENV === "production" ? "" : ";label:SimpleSlider;", process.env.NODE_ENV === "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"]} */"],
3801
+ css: [containerStyle$5, disabled && disabledStyle, process.env.NODE_ENV === "production" ? "" : ";label:SimpleSlider;", process.env.NODE_ENV === "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"]} */"],
3861
3802
  style: { ...(orientation === 'vertical' && {
3862
3803
  flexDirection: 'column',
3863
3804
  '--slider-thumb-y': `${thumbPosition * 100}%`
@@ -4153,6 +4094,7 @@ const reducePointer = (state, {
4153
4094
  const SeekbarRail = () => '';
4154
4095
 
4155
4096
  const segmentedTrackStyle = {
4097
+ boxSizing: 'border-box',
4156
4098
  position: 'relative',
4157
4099
  margin: '0 2px',
4158
4100
  height: '24px',
@@ -4186,7 +4128,7 @@ const SeekbarTrack = ({
4186
4128
  current,
4187
4129
  buffered
4188
4130
  }) => jsxs("div", {
4189
- css: [style, segmentedTrackStyle, process.env.NODE_ENV === "production" ? "" : ";label:SeekbarTrack;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0ZNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICBtYXJnaW46ICcwIDJweCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBib3JkZXJUb3A6ICdjYWxjKDEycHggLSAwLjNlbSkgc29saWQgdHJhbnNwYXJlbnQnLFxuICBib3JkZXJCb3R0b206ICdjYWxjKDEycHggLSAwLjNlbSkgc29saWQgdHJhbnNwYXJlbnQnLFxuICBiYWNrZ3JvdW5kOiAndHJhbnNwYXJlbnQnLFxuICAnJjpob3Zlcic6IHtcbiAgICB0cmFuc2Zvcm06ICdzY2FsZSgxLCAxLjUpJyxcbiAgfSxcbiAgJz4gZGl2Jzoge1xuICAgIGhlaWdodDogJzAuNmVtJyxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMiknLFxuICAgICcmOm5vdCg6Zmlyc3Qtb2YtdHlwZSknOiB7XG4gICAgICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgICAgIHRvcDogJzAnLFxuICAgIH0sXG4gIH0sXG4gICc+IGRpdjpudGgtb2YtdHlwZSgyKSc6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMyknLFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMyknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxufVxuXG5jb25zdCBTZWVrYmFyVHJhY2sgPSAoe3NlZ21lbnRzLCBzdHlsZX0pID0+XG4gIHNlZ21lbnRzLm1hcCgoe2xlbmd0aCwgY3VycmVudCwgYnVmZmVyZWR9KSA9PiAoXG4gICAgPGRpdlxuICAgICAgY3NzPXtbc3R5bGUsIHNlZ21lbnRlZFRyYWNrU3R5bGVdfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgZmxleDogYDAgJHtsZW5ndGggKiAxMDB9JWAsXG4gICAgICAgIHdpZHRoOiBgY2FsYygke2xlbmd0aCAqIDEwMH0lIC0gNHB4KWAsXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogJzEwMCUnfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7YnVmZmVyZWQgKiAxMDB9JWB9fSAvPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiBgJHtjdXJyZW50ICogMTAwfSVgfX0gLz5cbiAgICA8L2Rpdj5cbiAgKSlcblxuLy8gVE9ETyB1c2UgY2xhc3NOYW1lIGluc3RlYWQgb2YgY2xhc3NlcyA/XG5jb25zdCBTZWVrYmFyID0gKHtcbiAgc3R5bGUsXG4gIGNsYXNzZXMsXG4gIHN0YXJ0VGltZSA9IDAsXG4gIGN1cnJlbnRUaW1lLFxuICBidWZmZXJUaW1lLFxuICBkdXJhdGlvbixcbiAgY2hhcHRlcnMgPSBbXSxcbiAgbWFya3MsXG4gIHRpbWVEaXNwbGF5ID0gZmFsc2UsIC8vIFRPRE8gbW9yZSBzY2FsYWJsZSB3YXk/XG4gIG9uQ2hhbmdlLFxuICBvbkNoYW5nZUNvbW1pdHRlZCxcbiAgY2hpbGRyZW4sXG4gIG9uUG9pbnRlck1vdmUsXG4gIG9uUG9pbnRlckxlYXZlLFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IFtwb2ludGVyU3RhdGUsIGRpc3BhdGNoUG9pbnRlcl0gPSB1c2VSZWR1Y2VyKHJlZHVjZVBvaW50ZXIsIHt9KVxuICBjb25zdCBwb2ludGVyQWN0aXZlID0gcG9pbnRlclN0YXRlLmhvdmVyIHx8IHBvaW50ZXJTdGF0ZS5mb2N1c2VkXG4gIC8vIHRvIHJlZmxlY3QgYm91bmRhcnkgd2hlbiBjb250YWluZXIgcmVzaXplZFxuICBjb25zdCB7b2JzZXJ2ZX0gPSB1c2VEaW1lbnNpb25zKClcbiAgY29uc3QgcmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVjdCA9IHJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKVxuICBjb25zdCBoYW5kbGVycyA9IG9uQ2hhbmdlQ29tbWl0dGVkICYmIHtcbiAgICBvblBvaW50ZXJNb3ZlOiAoZXZlbnQsIHt2YWx1ZSwgeH0pID0+IHtcbiAgICAgIG9uUG9pbnRlck1vdmU/LihldmVudCwge3ZhbHVlLCB4fSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ21vdmUnLCB2YWx1ZSwgeH0pXG4gICAgfSxcbiAgICBvblBvaW50ZXJMZWF2ZTogZXZlbnQgPT4ge1xuICAgICAgb25Qb2ludGVyTGVhdmU/LihldmVudClcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2xlYXZlJ30pXG4gICAgfSxcbiAgICBvbkNoYW5nZTogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4odmFsdWUpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdjaGFuZ2UnLCB2YWx1ZX0pXG4gICAgfSxcbiAgICBvbkNoYW5nZUNvbW1pdHRlZDogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ3JlbGVhc2UnLCB2YWx1ZX0pXG4gICAgICBvbkNoYW5nZUNvbW1pdHRlZD8uKHZhbHVlKVxuICAgIH0sXG4gIH1cbiAgY29uc3QgZW5kVGltZSA9IHN0YXJ0VGltZSArIGR1cmF0aW9uXG4gIGNvbnN0IHNlZ21lbnRzID0gZ2V0VGltZWxpbmVTZWdtZW50cyhjaGFwdGVycywge1xuICAgIHN0YXJ0VGltZSxcbiAgICBjdXJyZW50OiBwb2ludGVyU3RhdGUuZm9jdXNlZCA/IHBvaW50ZXJTdGF0ZS52YWx1ZSA6IGN1cnJlbnRUaW1lLFxuICAgIGJ1ZmZlcmVkOiBidWZmZXJUaW1lLFxuICAgIGR1cmF0aW9uLFxuICB9KVxuXG4gIHJldHVybiAhKGR1cmF0aW9uID4gMCkgPyAoXG4gICAgPGRpdiAvPlxuICApIDogKFxuICAgIDxkaXZcbiAgICAgIHJlZj17ZWxlbWVudCA9PiB7XG4gICAgICAgIG9ic2VydmUoZWxlbWVudClcbiAgICAgICAgcmVmLmN1cnJlbnQgPSBlbGVtZW50XG4gICAgICB9fVxuICAgICAgY3NzPXtbc2Vla2JhclN0eWxlLCBzdHlsZV19XG4gICAgICBzdHlsZT17XG4gICAgICAgIHJlY3QgJiYge1xuICAgICAgICAgICctLXNlZWtiYXItbGVmdCc6IGAke3JlY3QubGVmdH1weGAsXG4gICAgICAgICAgJy0tc2Vla2Jhci1yaWdodCc6IGAke3JlY3QucmlnaHR9cHhgLFxuICAgICAgICAgICctLXBvaW50ZXIteCc6IGAke3BvaW50ZXJTdGF0ZS54fXB4YCxcbiAgICAgICAgfVxuICAgICAgfVxuICAgID5cbiAgICAgIHshdGltZURpc3BsYXkgPyAoXG4gICAgICAgICcnXG4gICAgICApIDogcG9pbnRlckFjdGl2ZSA/IChcbiAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17cG9pbnRlclN0YXRlLnZhbHVlfSAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17TWF0aC5taW4oTWF0aC5tYXgoMCwgY3VycmVudFRpbWUpLCBkdXJhdGlvbil9IC8+XG4gICAgICApfVxuICAgICAgPFNpbXBsZVNsaWRlclxuICAgICAgICBjc3M9e1tzbGlkZXJTdHlsZSwgdGltZURpc3BsYXkgJiYge21hcmdpbjogJzAgMWVtJ31dfVxuICAgICAgICBjbGFzc2VzPXtjbGFzc2VzfVxuICAgICAgICBkaXNhYmxlZD17IW9uQ2hhbmdlQ29tbWl0dGVkfVxuICAgICAgICAvLyBkaXNwbGF5IGZpbGxlZCB3aGVuIHNlZWsgaGFuZGxlciBpcyBub3QgcHJvdmlkZWQsIGZyb20gUGxheUJveSBiZWhhdmlvclxuICAgICAgICB2YWx1ZT17b25DaGFuZ2VDb21taXR0ZWQgPyBjdXJyZW50VGltZSA6IGVuZFRpbWV9XG4gICAgICAgIG1pbj17c3RhcnRUaW1lfVxuICAgICAgICBtYXg9e2VuZFRpbWV9XG4gICAgICAgIG1hcmtzPXttYXJrc31cbiAgICAgICAgey4uLmhhbmRsZXJzfVxuICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgc2xvdHM9e3tSYWlsOiBTZWVrYmFyUmFpbCwgVHJhY2s6IFNlZWtiYXJUcmFja319XG4gICAgICAgIHNsb3RQcm9wcz17e3RyYWNrOiB7c2VnbWVudHN9fX1cbiAgICAgIC8+XG4gICAgICB7dGltZURpc3BsYXkgJiYgPEZvcm1hdHRlZFRpbWUgdGltZT17ZHVyYXRpb259IC8+fVxuICAgICAge2NoaWxkcmVuICYmXG4gICAgICAgIFtdXG4gICAgICAgICAgLmNvbmNhdChjaGlsZHJlbilcbiAgICAgICAgICAubWFwKGNoaWxkID0+XG4gICAgICAgICAgICBjbG9uZUVsZW1lbnQoY2hpbGQsIHt0aW1lOiBwb2ludGVyQWN0aXZlICYmIHBvaW50ZXJTdGF0ZS52YWx1ZX0pXG4gICAgICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTZWVrYmFyXG4iXX0= */"],
4131
+ css: [style, segmentedTrackStyle, process.env.NODE_ENV === "production" ? "" : ";label:SeekbarTrack;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUZNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
4190
4132
  style: {
4191
4133
  flex: `0 ${length * 100}%`,
4192
4134
  width: `calc(${length * 100}% - 4px)`
@@ -4287,7 +4229,7 @@ const Seekbar$2 = ({
4287
4229
  observe(element);
4288
4230
  ref.current = element;
4289
4231
  },
4290
- css: [seekbarStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEpNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICBtYXJnaW46ICcwIDJweCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBib3JkZXJUb3A6ICdjYWxjKDEycHggLSAwLjNlbSkgc29saWQgdHJhbnNwYXJlbnQnLFxuICBib3JkZXJCb3R0b206ICdjYWxjKDEycHggLSAwLjNlbSkgc29saWQgdHJhbnNwYXJlbnQnLFxuICBiYWNrZ3JvdW5kOiAndHJhbnNwYXJlbnQnLFxuICAnJjpob3Zlcic6IHtcbiAgICB0cmFuc2Zvcm06ICdzY2FsZSgxLCAxLjUpJyxcbiAgfSxcbiAgJz4gZGl2Jzoge1xuICAgIGhlaWdodDogJzAuNmVtJyxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMiknLFxuICAgICcmOm5vdCg6Zmlyc3Qtb2YtdHlwZSknOiB7XG4gICAgICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgICAgIHRvcDogJzAnLFxuICAgIH0sXG4gIH0sXG4gICc+IGRpdjpudGgtb2YtdHlwZSgyKSc6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMyknLFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMyknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxufVxuXG5jb25zdCBTZWVrYmFyVHJhY2sgPSAoe3NlZ21lbnRzLCBzdHlsZX0pID0+XG4gIHNlZ21lbnRzLm1hcCgoe2xlbmd0aCwgY3VycmVudCwgYnVmZmVyZWR9KSA9PiAoXG4gICAgPGRpdlxuICAgICAgY3NzPXtbc3R5bGUsIHNlZ21lbnRlZFRyYWNrU3R5bGVdfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgZmxleDogYDAgJHtsZW5ndGggKiAxMDB9JWAsXG4gICAgICAgIHdpZHRoOiBgY2FsYygke2xlbmd0aCAqIDEwMH0lIC0gNHB4KWAsXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogJzEwMCUnfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7YnVmZmVyZWQgKiAxMDB9JWB9fSAvPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiBgJHtjdXJyZW50ICogMTAwfSVgfX0gLz5cbiAgICA8L2Rpdj5cbiAgKSlcblxuLy8gVE9ETyB1c2UgY2xhc3NOYW1lIGluc3RlYWQgb2YgY2xhc3NlcyA/XG5jb25zdCBTZWVrYmFyID0gKHtcbiAgc3R5bGUsXG4gIGNsYXNzZXMsXG4gIHN0YXJ0VGltZSA9IDAsXG4gIGN1cnJlbnRUaW1lLFxuICBidWZmZXJUaW1lLFxuICBkdXJhdGlvbixcbiAgY2hhcHRlcnMgPSBbXSxcbiAgbWFya3MsXG4gIHRpbWVEaXNwbGF5ID0gZmFsc2UsIC8vIFRPRE8gbW9yZSBzY2FsYWJsZSB3YXk/XG4gIG9uQ2hhbmdlLFxuICBvbkNoYW5nZUNvbW1pdHRlZCxcbiAgY2hpbGRyZW4sXG4gIG9uUG9pbnRlck1vdmUsXG4gIG9uUG9pbnRlckxlYXZlLFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IFtwb2ludGVyU3RhdGUsIGRpc3BhdGNoUG9pbnRlcl0gPSB1c2VSZWR1Y2VyKHJlZHVjZVBvaW50ZXIsIHt9KVxuICBjb25zdCBwb2ludGVyQWN0aXZlID0gcG9pbnRlclN0YXRlLmhvdmVyIHx8IHBvaW50ZXJTdGF0ZS5mb2N1c2VkXG4gIC8vIHRvIHJlZmxlY3QgYm91bmRhcnkgd2hlbiBjb250YWluZXIgcmVzaXplZFxuICBjb25zdCB7b2JzZXJ2ZX0gPSB1c2VEaW1lbnNpb25zKClcbiAgY29uc3QgcmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVjdCA9IHJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKVxuICBjb25zdCBoYW5kbGVycyA9IG9uQ2hhbmdlQ29tbWl0dGVkICYmIHtcbiAgICBvblBvaW50ZXJNb3ZlOiAoZXZlbnQsIHt2YWx1ZSwgeH0pID0+IHtcbiAgICAgIG9uUG9pbnRlck1vdmU/LihldmVudCwge3ZhbHVlLCB4fSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ21vdmUnLCB2YWx1ZSwgeH0pXG4gICAgfSxcbiAgICBvblBvaW50ZXJMZWF2ZTogZXZlbnQgPT4ge1xuICAgICAgb25Qb2ludGVyTGVhdmU/LihldmVudClcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2xlYXZlJ30pXG4gICAgfSxcbiAgICBvbkNoYW5nZTogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4odmFsdWUpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdjaGFuZ2UnLCB2YWx1ZX0pXG4gICAgfSxcbiAgICBvbkNoYW5nZUNvbW1pdHRlZDogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ3JlbGVhc2UnLCB2YWx1ZX0pXG4gICAgICBvbkNoYW5nZUNvbW1pdHRlZD8uKHZhbHVlKVxuICAgIH0sXG4gIH1cbiAgY29uc3QgZW5kVGltZSA9IHN0YXJ0VGltZSArIGR1cmF0aW9uXG4gIGNvbnN0IHNlZ21lbnRzID0gZ2V0VGltZWxpbmVTZWdtZW50cyhjaGFwdGVycywge1xuICAgIHN0YXJ0VGltZSxcbiAgICBjdXJyZW50OiBwb2ludGVyU3RhdGUuZm9jdXNlZCA/IHBvaW50ZXJTdGF0ZS52YWx1ZSA6IGN1cnJlbnRUaW1lLFxuICAgIGJ1ZmZlcmVkOiBidWZmZXJUaW1lLFxuICAgIGR1cmF0aW9uLFxuICB9KVxuXG4gIHJldHVybiAhKGR1cmF0aW9uID4gMCkgPyAoXG4gICAgPGRpdiAvPlxuICApIDogKFxuICAgIDxkaXZcbiAgICAgIHJlZj17ZWxlbWVudCA9PiB7XG4gICAgICAgIG9ic2VydmUoZWxlbWVudClcbiAgICAgICAgcmVmLmN1cnJlbnQgPSBlbGVtZW50XG4gICAgICB9fVxuICAgICAgY3NzPXtbc2Vla2JhclN0eWxlLCBzdHlsZV19XG4gICAgICBzdHlsZT17XG4gICAgICAgIHJlY3QgJiYge1xuICAgICAgICAgICctLXNlZWtiYXItbGVmdCc6IGAke3JlY3QubGVmdH1weGAsXG4gICAgICAgICAgJy0tc2Vla2Jhci1yaWdodCc6IGAke3JlY3QucmlnaHR9cHhgLFxuICAgICAgICAgICctLXBvaW50ZXIteCc6IGAke3BvaW50ZXJTdGF0ZS54fXB4YCxcbiAgICAgICAgfVxuICAgICAgfVxuICAgID5cbiAgICAgIHshdGltZURpc3BsYXkgPyAoXG4gICAgICAgICcnXG4gICAgICApIDogcG9pbnRlckFjdGl2ZSA/IChcbiAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17cG9pbnRlclN0YXRlLnZhbHVlfSAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17TWF0aC5taW4oTWF0aC5tYXgoMCwgY3VycmVudFRpbWUpLCBkdXJhdGlvbil9IC8+XG4gICAgICApfVxuICAgICAgPFNpbXBsZVNsaWRlclxuICAgICAgICBjc3M9e1tzbGlkZXJTdHlsZSwgdGltZURpc3BsYXkgJiYge21hcmdpbjogJzAgMWVtJ31dfVxuICAgICAgICBjbGFzc2VzPXtjbGFzc2VzfVxuICAgICAgICBkaXNhYmxlZD17IW9uQ2hhbmdlQ29tbWl0dGVkfVxuICAgICAgICAvLyBkaXNwbGF5IGZpbGxlZCB3aGVuIHNlZWsgaGFuZGxlciBpcyBub3QgcHJvdmlkZWQsIGZyb20gUGxheUJveSBiZWhhdmlvclxuICAgICAgICB2YWx1ZT17b25DaGFuZ2VDb21taXR0ZWQgPyBjdXJyZW50VGltZSA6IGVuZFRpbWV9XG4gICAgICAgIG1pbj17c3RhcnRUaW1lfVxuICAgICAgICBtYXg9e2VuZFRpbWV9XG4gICAgICAgIG1hcmtzPXttYXJrc31cbiAgICAgICAgey4uLmhhbmRsZXJzfVxuICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgc2xvdHM9e3tSYWlsOiBTZWVrYmFyUmFpbCwgVHJhY2s6IFNlZWtiYXJUcmFja319XG4gICAgICAgIHNsb3RQcm9wcz17e3RyYWNrOiB7c2VnbWVudHN9fX1cbiAgICAgIC8+XG4gICAgICB7dGltZURpc3BsYXkgJiYgPEZvcm1hdHRlZFRpbWUgdGltZT17ZHVyYXRpb259IC8+fVxuICAgICAge2NoaWxkcmVuICYmXG4gICAgICAgIFtdXG4gICAgICAgICAgLmNvbmNhdChjaGlsZHJlbilcbiAgICAgICAgICAubWFwKGNoaWxkID0+XG4gICAgICAgICAgICBjbG9uZUVsZW1lbnQoY2hpbGQsIHt0aW1lOiBwb2ludGVyQWN0aXZlICYmIHBvaW50ZXJTdGF0ZS52YWx1ZX0pXG4gICAgICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTZWVrYmFyXG4iXX0= */"],
4232
+ css: [seekbarStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkpNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
4291
4233
  style: rect && {
4292
4234
  '--seekbar-left': `${rect.left}px`,
4293
4235
  '--seekbar-right': `${rect.right}px`,
@@ -4300,7 +4242,7 @@ const Seekbar$2 = ({
4300
4242
  }), jsx$1(SimpleSlider, {
4301
4243
  css: [sliderStyle$1, timeDisplay && {
4302
4244
  margin: '0 1em'
4303
- }, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMktRIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICBtYXJnaW46ICcwIDJweCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBib3JkZXJUb3A6ICdjYWxjKDEycHggLSAwLjNlbSkgc29saWQgdHJhbnNwYXJlbnQnLFxuICBib3JkZXJCb3R0b206ICdjYWxjKDEycHggLSAwLjNlbSkgc29saWQgdHJhbnNwYXJlbnQnLFxuICBiYWNrZ3JvdW5kOiAndHJhbnNwYXJlbnQnLFxuICAnJjpob3Zlcic6IHtcbiAgICB0cmFuc2Zvcm06ICdzY2FsZSgxLCAxLjUpJyxcbiAgfSxcbiAgJz4gZGl2Jzoge1xuICAgIGhlaWdodDogJzAuNmVtJyxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMiknLFxuICAgICcmOm5vdCg6Zmlyc3Qtb2YtdHlwZSknOiB7XG4gICAgICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgICAgIHRvcDogJzAnLFxuICAgIH0sXG4gIH0sXG4gICc+IGRpdjpudGgtb2YtdHlwZSgyKSc6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICdyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMyknLFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMyknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxufVxuXG5jb25zdCBTZWVrYmFyVHJhY2sgPSAoe3NlZ21lbnRzLCBzdHlsZX0pID0+XG4gIHNlZ21lbnRzLm1hcCgoe2xlbmd0aCwgY3VycmVudCwgYnVmZmVyZWR9KSA9PiAoXG4gICAgPGRpdlxuICAgICAgY3NzPXtbc3R5bGUsIHNlZ21lbnRlZFRyYWNrU3R5bGVdfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgZmxleDogYDAgJHtsZW5ndGggKiAxMDB9JWAsXG4gICAgICAgIHdpZHRoOiBgY2FsYygke2xlbmd0aCAqIDEwMH0lIC0gNHB4KWAsXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogJzEwMCUnfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7YnVmZmVyZWQgKiAxMDB9JWB9fSAvPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiBgJHtjdXJyZW50ICogMTAwfSVgfX0gLz5cbiAgICA8L2Rpdj5cbiAgKSlcblxuLy8gVE9ETyB1c2UgY2xhc3NOYW1lIGluc3RlYWQgb2YgY2xhc3NlcyA/XG5jb25zdCBTZWVrYmFyID0gKHtcbiAgc3R5bGUsXG4gIGNsYXNzZXMsXG4gIHN0YXJ0VGltZSA9IDAsXG4gIGN1cnJlbnRUaW1lLFxuICBidWZmZXJUaW1lLFxuICBkdXJhdGlvbixcbiAgY2hhcHRlcnMgPSBbXSxcbiAgbWFya3MsXG4gIHRpbWVEaXNwbGF5ID0gZmFsc2UsIC8vIFRPRE8gbW9yZSBzY2FsYWJsZSB3YXk/XG4gIG9uQ2hhbmdlLFxuICBvbkNoYW5nZUNvbW1pdHRlZCxcbiAgY2hpbGRyZW4sXG4gIG9uUG9pbnRlck1vdmUsXG4gIG9uUG9pbnRlckxlYXZlLFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IFtwb2ludGVyU3RhdGUsIGRpc3BhdGNoUG9pbnRlcl0gPSB1c2VSZWR1Y2VyKHJlZHVjZVBvaW50ZXIsIHt9KVxuICBjb25zdCBwb2ludGVyQWN0aXZlID0gcG9pbnRlclN0YXRlLmhvdmVyIHx8IHBvaW50ZXJTdGF0ZS5mb2N1c2VkXG4gIC8vIHRvIHJlZmxlY3QgYm91bmRhcnkgd2hlbiBjb250YWluZXIgcmVzaXplZFxuICBjb25zdCB7b2JzZXJ2ZX0gPSB1c2VEaW1lbnNpb25zKClcbiAgY29uc3QgcmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVjdCA9IHJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKVxuICBjb25zdCBoYW5kbGVycyA9IG9uQ2hhbmdlQ29tbWl0dGVkICYmIHtcbiAgICBvblBvaW50ZXJNb3ZlOiAoZXZlbnQsIHt2YWx1ZSwgeH0pID0+IHtcbiAgICAgIG9uUG9pbnRlck1vdmU/LihldmVudCwge3ZhbHVlLCB4fSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ21vdmUnLCB2YWx1ZSwgeH0pXG4gICAgfSxcbiAgICBvblBvaW50ZXJMZWF2ZTogZXZlbnQgPT4ge1xuICAgICAgb25Qb2ludGVyTGVhdmU/LihldmVudClcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2xlYXZlJ30pXG4gICAgfSxcbiAgICBvbkNoYW5nZTogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4odmFsdWUpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdjaGFuZ2UnLCB2YWx1ZX0pXG4gICAgfSxcbiAgICBvbkNoYW5nZUNvbW1pdHRlZDogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ3JlbGVhc2UnLCB2YWx1ZX0pXG4gICAgICBvbkNoYW5nZUNvbW1pdHRlZD8uKHZhbHVlKVxuICAgIH0sXG4gIH1cbiAgY29uc3QgZW5kVGltZSA9IHN0YXJ0VGltZSArIGR1cmF0aW9uXG4gIGNvbnN0IHNlZ21lbnRzID0gZ2V0VGltZWxpbmVTZWdtZW50cyhjaGFwdGVycywge1xuICAgIHN0YXJ0VGltZSxcbiAgICBjdXJyZW50OiBwb2ludGVyU3RhdGUuZm9jdXNlZCA/IHBvaW50ZXJTdGF0ZS52YWx1ZSA6IGN1cnJlbnRUaW1lLFxuICAgIGJ1ZmZlcmVkOiBidWZmZXJUaW1lLFxuICAgIGR1cmF0aW9uLFxuICB9KVxuXG4gIHJldHVybiAhKGR1cmF0aW9uID4gMCkgPyAoXG4gICAgPGRpdiAvPlxuICApIDogKFxuICAgIDxkaXZcbiAgICAgIHJlZj17ZWxlbWVudCA9PiB7XG4gICAgICAgIG9ic2VydmUoZWxlbWVudClcbiAgICAgICAgcmVmLmN1cnJlbnQgPSBlbGVtZW50XG4gICAgICB9fVxuICAgICAgY3NzPXtbc2Vla2JhclN0eWxlLCBzdHlsZV19XG4gICAgICBzdHlsZT17XG4gICAgICAgIHJlY3QgJiYge1xuICAgICAgICAgICctLXNlZWtiYXItbGVmdCc6IGAke3JlY3QubGVmdH1weGAsXG4gICAgICAgICAgJy0tc2Vla2Jhci1yaWdodCc6IGAke3JlY3QucmlnaHR9cHhgLFxuICAgICAgICAgICctLXBvaW50ZXIteCc6IGAke3BvaW50ZXJTdGF0ZS54fXB4YCxcbiAgICAgICAgfVxuICAgICAgfVxuICAgID5cbiAgICAgIHshdGltZURpc3BsYXkgPyAoXG4gICAgICAgICcnXG4gICAgICApIDogcG9pbnRlckFjdGl2ZSA/IChcbiAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17cG9pbnRlclN0YXRlLnZhbHVlfSAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17TWF0aC5taW4oTWF0aC5tYXgoMCwgY3VycmVudFRpbWUpLCBkdXJhdGlvbil9IC8+XG4gICAgICApfVxuICAgICAgPFNpbXBsZVNsaWRlclxuICAgICAgICBjc3M9e1tzbGlkZXJTdHlsZSwgdGltZURpc3BsYXkgJiYge21hcmdpbjogJzAgMWVtJ31dfVxuICAgICAgICBjbGFzc2VzPXtjbGFzc2VzfVxuICAgICAgICBkaXNhYmxlZD17IW9uQ2hhbmdlQ29tbWl0dGVkfVxuICAgICAgICAvLyBkaXNwbGF5IGZpbGxlZCB3aGVuIHNlZWsgaGFuZGxlciBpcyBub3QgcHJvdmlkZWQsIGZyb20gUGxheUJveSBiZWhhdmlvclxuICAgICAgICB2YWx1ZT17b25DaGFuZ2VDb21taXR0ZWQgPyBjdXJyZW50VGltZSA6IGVuZFRpbWV9XG4gICAgICAgIG1pbj17c3RhcnRUaW1lfVxuICAgICAgICBtYXg9e2VuZFRpbWV9XG4gICAgICAgIG1hcmtzPXttYXJrc31cbiAgICAgICAgey4uLmhhbmRsZXJzfVxuICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgc2xvdHM9e3tSYWlsOiBTZWVrYmFyUmFpbCwgVHJhY2s6IFNlZWtiYXJUcmFja319XG4gICAgICAgIHNsb3RQcm9wcz17e3RyYWNrOiB7c2VnbWVudHN9fX1cbiAgICAgIC8+XG4gICAgICB7dGltZURpc3BsYXkgJiYgPEZvcm1hdHRlZFRpbWUgdGltZT17ZHVyYXRpb259IC8+fVxuICAgICAge2NoaWxkcmVuICYmXG4gICAgICAgIFtdXG4gICAgICAgICAgLmNvbmNhdChjaGlsZHJlbilcbiAgICAgICAgICAubWFwKGNoaWxkID0+XG4gICAgICAgICAgICBjbG9uZUVsZW1lbnQoY2hpbGQsIHt0aW1lOiBwb2ludGVyQWN0aXZlICYmIHBvaW50ZXJTdGF0ZS52YWx1ZX0pXG4gICAgICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTZWVrYmFyXG4iXX0= */"],
4245
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEtRIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
4304
4246
  classes: classes,
4305
4247
  disabled: !onChangeCommitted // display filled when seek handler is not provided, from PlayBoy behavior
4306
4248
  ,
@@ -4667,17 +4609,13 @@ const MenuItemText = ({
4667
4609
  })
4668
4610
  });
4669
4611
 
4670
- MenuItemText.propTypes = {
4671
- text: PropTypes.string
4672
- };
4673
-
4674
4612
  const LoopSwitch = ({
4675
4613
  style,
4676
4614
  checked,
4677
4615
  onChange
4678
4616
  }) => jsxs("li", {
4679
4617
  role: "menuitem",
4680
- css: [style, "::before{display:none;}::after{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:LoopSwitch;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Settings.js"],"names":[],"mappings":"AAmLI","file":"Settings.js","sourcesContent":["/* @jsxImportSource @emotion/react */\n/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport {useState, useEffect} from 'react'\nimport PropTypes from 'prop-types'\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\nMenuItemText.propTypes = {\n  text: PropTypes.string,\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,\n  type: uiType,\n  closeBy,\n  buttonPosition,\n  slots = {\n    root: uiType === 'desktop' ? DesktopContainer : SwipeableDrawer,\n  },\n  onChange,\n  onOpen,\n  onClose,\n  controller,\n}) => {\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 (controller !== 'sender' && 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            event.stopPropagation()\n            onOpen(event)\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\nSettings.propTypes = {\n  open: PropTypes.bool,\n  values: PropTypes.object,\n  sections: PropTypes.array,\n  type: PropTypes.string,\n  onChange: PropTypes.func,\n  onClose: PropTypes.func,\n}\n\nexport default Settings\n"]} */"],
4618
+ css: [style, "::before{display:none;}::after{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:LoopSwitch;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Settings.js"],"names":[],"mappings":"AA8KI","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"]} */"],
4681
4619
  onClick: () => {
4682
4620
  onChange({
4683
4621
  name: 'loop',
@@ -4701,14 +4639,14 @@ const CloseButton = props => jsx$1("button", {
4701
4639
  ...props
4702
4640
  });
4703
4641
 
4704
- const DesktopContainer = ({
4642
+ const DesktopContainer$1 = ({
4705
4643
  open,
4706
4644
  style,
4707
4645
  children,
4708
4646
  onClose,
4709
4647
  ...rest
4710
4648
  }) => jsx$1("div", {
4711
- css: [style, open && desktopStyle$1.open, process.env.NODE_ENV === "production" ? "" : ";label:DesktopContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Settings.js"],"names":[],"mappings":"AAwMO","file":"Settings.js","sourcesContent":["/* @jsxImportSource @emotion/react */\n/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport {useState, useEffect} from 'react'\nimport PropTypes from 'prop-types'\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\nMenuItemText.propTypes = {\n  text: PropTypes.string,\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,\n  type: uiType,\n  closeBy,\n  buttonPosition,\n  slots = {\n    root: uiType === 'desktop' ? DesktopContainer : SwipeableDrawer,\n  },\n  onChange,\n  onOpen,\n  onClose,\n  controller,\n}) => {\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 (controller !== 'sender' && 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            event.stopPropagation()\n            onOpen(event)\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\nSettings.propTypes = {\n  open: PropTypes.bool,\n  values: PropTypes.object,\n  sections: PropTypes.array,\n  type: PropTypes.string,\n  onChange: PropTypes.func,\n  onClose: PropTypes.func,\n}\n\nexport default Settings\n"]} */"],
4649
+ css: [style, open && desktopStyle$1.open, process.env.NODE_ENV === "production" ? "" : ";label:DesktopContainer;", process.env.NODE_ENV === "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"]} */"],
4712
4650
  ...rest,
4713
4651
  children: children
4714
4652
  });
@@ -4722,18 +4660,25 @@ const matchValue = (a, b) => {
4722
4660
  const Settings = ({
4723
4661
  open,
4724
4662
  values,
4725
- sections,
4663
+ sections: originalSections,
4726
4664
  type: uiType,
4727
4665
  closeBy,
4728
4666
  buttonPosition,
4667
+ enabledSettingSections = {
4668
+ audio: true,
4669
+ subtitles: true,
4670
+ quality: true,
4671
+ speed: true,
4672
+ loop: true
4673
+ },
4729
4674
  slots = {
4730
- root: uiType === 'desktop' ? DesktopContainer : SwipeableDrawer$1
4675
+ root: uiType === 'desktop' ? DesktopContainer$1 : SwipeableDrawer$1
4731
4676
  },
4732
4677
  onChange,
4733
4678
  onOpen,
4734
- onClose,
4735
- controller
4679
+ onClose
4736
4680
  }) => {
4681
+ const sections = originalSections.filter(section => enabledSettingSections[section.name]);
4737
4682
  const Container = slots.root;
4738
4683
  const ButtonWrap = buttonPosition === 'top-right' ? TitleBarExtension : FunctionBarExtension;
4739
4684
  const commonStyle = uiType === 'desktop' ? desktopStyle$1 : mobileStyle$1;
@@ -4744,7 +4689,7 @@ const Settings = ({
4744
4689
  }
4745
4690
  }, [open]);
4746
4691
  const ref = useOnclickOutside(() => {
4747
- if (controller !== 'sender' && open && uiType === 'desktop') {
4692
+ if (open && uiType === 'desktop') {
4748
4693
  onClose();
4749
4694
  }
4750
4695
  }, {
@@ -4789,10 +4734,7 @@ const Settings = ({
4789
4734
  children: jsx$1(Button, {
4790
4735
  startIcon: "setting",
4791
4736
  title: "KKS.SETTING",
4792
- onClick: event => {
4793
- event.stopPropagation();
4794
- onOpen(event);
4795
- }
4737
+ onClick: event => setTimeout(() => open ? onClose(event) : onOpen(event), 1)
4796
4738
  })
4797
4739
  }), jsx$1(Container, {
4798
4740
  style: commonStyle.overlay,
@@ -4830,7 +4772,7 @@ const Settings = ({
4830
4772
  }) : jsxs("li", {
4831
4773
  role: link ? 'menuitem' : 'menuitemradio',
4832
4774
  "aria-checked": checked,
4833
- css: [commonStyle.row, link && commonStyle.hasOptions, checked && commonStyle.selected, process.env.NODE_ENV === "production" ? "" : ";label:Settings;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Settings.js"],"names":[],"mappings":"AAkTgB","file":"Settings.js","sourcesContent":["/* @jsxImportSource @emotion/react */\n/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport {useState, useEffect} from 'react'\nimport PropTypes from 'prop-types'\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\nMenuItemText.propTypes = {\n  text: PropTypes.string,\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,\n  type: uiType,\n  closeBy,\n  buttonPosition,\n  slots = {\n    root: uiType === 'desktop' ? DesktopContainer : SwipeableDrawer,\n  },\n  onChange,\n  onOpen,\n  onClose,\n  controller,\n}) => {\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 (controller !== 'sender' && 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            event.stopPropagation()\n            onOpen(event)\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\nSettings.propTypes = {\n  open: PropTypes.bool,\n  values: PropTypes.object,\n  sections: PropTypes.array,\n  type: PropTypes.string,\n  onChange: PropTypes.func,\n  onClose: PropTypes.func,\n}\n\nexport default Settings\n"]} */"],
4775
+ css: [commonStyle.row, link && commonStyle.hasOptions, checked && commonStyle.selected, process.env.NODE_ENV === "production" ? "" : ";label:Settings;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Settings.js"],"names":[],"mappings":"AAmTgB","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"]} */"],
4834
4776
  onClick: () => link ? navigate(link) : onChange({
4835
4777
  name: currentSection.name,
4836
4778
  value: data
@@ -4848,14 +4790,279 @@ const Settings = ({
4848
4790
  });
4849
4791
  };
4850
4792
 
4851
- Settings.propTypes = {
4852
- open: PropTypes.bool,
4853
- values: PropTypes.object,
4854
- sections: PropTypes.array,
4855
- type: PropTypes.string,
4856
- onChange: PropTypes.func,
4857
- onClose: PropTypes.func
4793
+ /* eslint-disable jsx-a11y/no-static-element-interactions */
4794
+ const containerStyle$4 = {
4795
+ position: 'absolute',
4796
+ zIndex: '2',
4797
+ top: '0',
4798
+ width: '100%',
4799
+ height: '100%',
4800
+ transform: 'translateY(-150vh)',
4801
+ opacity: '0',
4802
+ transition: 'opacity 0.5s ease, transform 0s 0.5s linear'
4803
+ };
4804
+ const openStyle$2 = {
4805
+ transform: 'translateY(0)',
4806
+ opacity: '1',
4807
+ transition: 'opacity 0.5s ease'
4808
+ };
4809
+
4810
+ const DefaultContainer = ({
4811
+ open,
4812
+ containerRef,
4813
+ children
4814
+ }) => jsx$1("div", {
4815
+ css: [containerStyle$4, open && openStyle$2, process.env.NODE_ENV === "production" ? "" : ";label:DefaultContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QkkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC41cyBlYXNlLCB0cmFuc2Zvcm0gMHMgMC41cyBsaW5lYXInLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5cbmNvbnN0IERlZmF1bHRDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW59KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tjb250YWluZXJTdHlsZSwgb3BlbiAmJiBvcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAnMScsXG4gIGJvdHRvbTogJ2NhbGMoNWVtICsgdmFyKC0tYm90dG9tLXNwYWNpbmcsIDByZW0pKScsXG4gIHJpZ2h0OiAnMXJlbScsXG4gIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gIG91dGxpbmU6ICdub25lJyxcbiAgb3BhY2l0eTogJzAnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC0xMDB2aCknLFxuICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcyBsaW5lYXIgMC4ycycsXG59XG5cbmNvbnN0IERlc2t0b3BPcGVuU3R5bGUgPSB7XG4gIG9wYWNpdHk6ICcxJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSgwKScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzJyxcbn1cblxuY29uc3QgRGVza3RvcENvbnRhaW5lciA9ICh7b3BlbiwgY29udGFpbmVyUmVmLCBjaGlsZHJlbiwgb25DbG9zZSwgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W2Rlc2t0b3BDb250YWluZXJTdHlsZSwgb3BlbiAmJiBEZXNrdG9wT3BlblN0eWxlXX1cbiAgICByZWY9e2NvbnRhaW5lclJlZn1cbiAgICBvbkNsaWNrPXtldmVudCA9PiBldmVudC5zdG9wUHJvcGFnYXRpb24oKX1cbiAgICB7Li4ucmVzdH1cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9kaXY+XG4pXG5cbmNvbnN0IE92ZXJsYXlQYW5lbCA9ICh7XG4gIGJ1dHRvbkljb24sXG4gIHVpVHlwZSA9IGlzRGVza3RvcCgpID8gJ2Rlc2t0b3AnIDogJ21vYmlsZScsXG4gIGNoaWxkcmVuLFxuICBzbG90cyA9IHtcbiAgICByb290OiB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IERlc2t0b3BDb250YWluZXIgOiBEZWZhdWx0Q29udGFpbmVyLFxuICB9LFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IGNvbXBvbmVudHMgPSB7XG4gICAgcm9vdDogc2xvdHMucm9vdCxcbiAgfVxuICBjb25zdCBCdXR0b25XcmFwID1cbiAgICB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IEZ1bmN0aW9uQmFyRXh0ZW5zaW9uIDogVGl0bGVCYXJFeHRlbnNpb25cbiAgY29uc3QgW29wZW4sIHNldE9wZW5dID0gdXNlU3RhdGUoZmFsc2UpXG4gIGNvbnN0IG9uQnV0dG9uQ2xpY2sgPSAoKSA9PiBzZXRUaW1lb3V0KCgpID0+IHNldE9wZW4oIW9wZW4pLCAxKVxuICBjb25zdCBvbkNsb3NlID0gKCkgPT4gc2V0T3BlbihmYWxzZSlcbiAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVmID0gdXNlT25jbGlja091dHNpZGUoXG4gICAgKCkgPT4ge1xuICAgICAgaWYgKG9wZW4gJiYgdWlUeXBlID09PSAnZGVza3RvcCcpIHtcbiAgICAgICAgb25DbG9zZSgpXG4gICAgICB9XG4gICAgfSxcbiAgICB7ZXZlbnRUeXBlczogWydjbGljayddfVxuICApXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmVmKGNvbnRhaW5lclJlZi5jdXJyZW50KVxuICAgIHJldHVybiBvbihjb250YWluZXJSZWYuY3VycmVudCwgJ2Nsb3NlLW1lbnUnLCBvbkNsb3NlKVxuICB9LCBbXSlcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8QnV0dG9uV3JhcCBwb3NpdGlvbj1cInJpZ2h0XCI+XG4gICAgICAgIDxCdXR0b24gc3RhcnRJY29uPXtidXR0b25JY29ufSBvbkNsaWNrPXtvbkJ1dHRvbkNsaWNrfSAvPlxuICAgICAgPC9CdXR0b25XcmFwPlxuICAgICAgPGNvbXBvbmVudHMucm9vdFxuICAgICAgICBjb250YWluZXJSZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgb3Blbj17b3Blbn1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvY29tcG9uZW50cy5yb290PlxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IE92ZXJsYXlQYW5lbFxuIl19 */"],
4816
+ ref: containerRef,
4817
+ onClick: event => event.stopPropagation(),
4818
+ children: children
4819
+ });
4820
+
4821
+ const desktopContainerStyle$1 = {
4822
+ position: 'absolute',
4823
+ zIndex: '1',
4824
+ bottom: 'calc(5em + var(--bottom-spacing, 0rem))',
4825
+ right: '1rem',
4826
+ background: 'transparent',
4827
+ outline: 'none',
4828
+ opacity: '0',
4829
+ transform: 'translateY(-100vh)',
4830
+ transition: 'opacity 0.2s ease, transform 0s linear 0.2s'
4831
+ };
4832
+ const DesktopOpenStyle = {
4833
+ opacity: '1',
4834
+ transform: 'translateY(0)',
4835
+ transition: 'opacity 0.2s ease, transform 0s'
4836
+ };
4837
+
4838
+ const DesktopContainer = ({
4839
+ open,
4840
+ containerRef,
4841
+ children,
4842
+ onClose,
4843
+ ...rest
4844
+ }) => jsx$1("div", {
4845
+ css: [desktopContainerStyle$1, open && DesktopOpenStyle, process.env.NODE_ENV === "production" ? "" : ";label:DesktopContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3REkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC41cyBlYXNlLCB0cmFuc2Zvcm0gMHMgMC41cyBsaW5lYXInLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5cbmNvbnN0IERlZmF1bHRDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW59KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tjb250YWluZXJTdHlsZSwgb3BlbiAmJiBvcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAnMScsXG4gIGJvdHRvbTogJ2NhbGMoNWVtICsgdmFyKC0tYm90dG9tLXNwYWNpbmcsIDByZW0pKScsXG4gIHJpZ2h0OiAnMXJlbScsXG4gIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gIG91dGxpbmU6ICdub25lJyxcbiAgb3BhY2l0eTogJzAnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC0xMDB2aCknLFxuICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcyBsaW5lYXIgMC4ycycsXG59XG5cbmNvbnN0IERlc2t0b3BPcGVuU3R5bGUgPSB7XG4gIG9wYWNpdHk6ICcxJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSgwKScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzJyxcbn1cblxuY29uc3QgRGVza3RvcENvbnRhaW5lciA9ICh7b3BlbiwgY29udGFpbmVyUmVmLCBjaGlsZHJlbiwgb25DbG9zZSwgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W2Rlc2t0b3BDb250YWluZXJTdHlsZSwgb3BlbiAmJiBEZXNrdG9wT3BlblN0eWxlXX1cbiAgICByZWY9e2NvbnRhaW5lclJlZn1cbiAgICBvbkNsaWNrPXtldmVudCA9PiBldmVudC5zdG9wUHJvcGFnYXRpb24oKX1cbiAgICB7Li4ucmVzdH1cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9kaXY+XG4pXG5cbmNvbnN0IE92ZXJsYXlQYW5lbCA9ICh7XG4gIGJ1dHRvbkljb24sXG4gIHVpVHlwZSA9IGlzRGVza3RvcCgpID8gJ2Rlc2t0b3AnIDogJ21vYmlsZScsXG4gIGNoaWxkcmVuLFxuICBzbG90cyA9IHtcbiAgICByb290OiB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IERlc2t0b3BDb250YWluZXIgOiBEZWZhdWx0Q29udGFpbmVyLFxuICB9LFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IGNvbXBvbmVudHMgPSB7XG4gICAgcm9vdDogc2xvdHMucm9vdCxcbiAgfVxuICBjb25zdCBCdXR0b25XcmFwID1cbiAgICB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IEZ1bmN0aW9uQmFyRXh0ZW5zaW9uIDogVGl0bGVCYXJFeHRlbnNpb25cbiAgY29uc3QgW29wZW4sIHNldE9wZW5dID0gdXNlU3RhdGUoZmFsc2UpXG4gIGNvbnN0IG9uQnV0dG9uQ2xpY2sgPSAoKSA9PiBzZXRUaW1lb3V0KCgpID0+IHNldE9wZW4oIW9wZW4pLCAxKVxuICBjb25zdCBvbkNsb3NlID0gKCkgPT4gc2V0T3BlbihmYWxzZSlcbiAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVmID0gdXNlT25jbGlja091dHNpZGUoXG4gICAgKCkgPT4ge1xuICAgICAgaWYgKG9wZW4gJiYgdWlUeXBlID09PSAnZGVza3RvcCcpIHtcbiAgICAgICAgb25DbG9zZSgpXG4gICAgICB9XG4gICAgfSxcbiAgICB7ZXZlbnRUeXBlczogWydjbGljayddfVxuICApXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmVmKGNvbnRhaW5lclJlZi5jdXJyZW50KVxuICAgIHJldHVybiBvbihjb250YWluZXJSZWYuY3VycmVudCwgJ2Nsb3NlLW1lbnUnLCBvbkNsb3NlKVxuICB9LCBbXSlcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8QnV0dG9uV3JhcCBwb3NpdGlvbj1cInJpZ2h0XCI+XG4gICAgICAgIDxCdXR0b24gc3RhcnRJY29uPXtidXR0b25JY29ufSBvbkNsaWNrPXtvbkJ1dHRvbkNsaWNrfSAvPlxuICAgICAgPC9CdXR0b25XcmFwPlxuICAgICAgPGNvbXBvbmVudHMucm9vdFxuICAgICAgICBjb250YWluZXJSZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgb3Blbj17b3Blbn1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvY29tcG9uZW50cy5yb290PlxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IE92ZXJsYXlQYW5lbFxuIl19 */"],
4846
+ ref: containerRef,
4847
+ onClick: event => event.stopPropagation(),
4848
+ ...rest,
4849
+ children: children
4850
+ });
4851
+
4852
+ const OverlayPanel = ({
4853
+ buttonIcon,
4854
+ uiType = isDesktop() ? 'desktop' : 'mobile',
4855
+ children,
4856
+ slots = {
4857
+ root: uiType === 'desktop' ? DesktopContainer : DefaultContainer
4858
+ },
4859
+ ...rest
4860
+ }) => {
4861
+ const components = {
4862
+ root: slots.root
4863
+ };
4864
+ const ButtonWrap = uiType === 'desktop' ? FunctionBarExtension : TitleBarExtension;
4865
+ const [open, setOpen] = useState(false);
4866
+
4867
+ const onButtonClick = () => setTimeout(() => setOpen(!open), 1);
4868
+
4869
+ const onClose = () => setOpen(false);
4870
+
4871
+ const containerRef = useRef();
4872
+ const ref = useOnclickOutside(() => {
4873
+ if (open && uiType === 'desktop') {
4874
+ onClose();
4875
+ }
4876
+ }, {
4877
+ eventTypes: ['click']
4878
+ });
4879
+ useEffect(() => {
4880
+ ref(containerRef.current);
4881
+ return on(containerRef.current, 'close-menu', onClose);
4882
+ }, []);
4883
+ return jsxs(Fragment, {
4884
+ children: [jsx$1(ButtonWrap, {
4885
+ position: "right",
4886
+ children: jsx$1(Button, {
4887
+ startIcon: buttonIcon,
4888
+ onClick: onButtonClick
4889
+ })
4890
+ }), jsx$1(components.root, {
4891
+ containerRef: containerRef,
4892
+ open: open,
4893
+ ...rest,
4894
+ children: children
4895
+ })]
4896
+ });
4897
+ };
4898
+
4899
+ /* eslint-disable jsx-a11y/no-static-element-interactions */
4900
+ const menuItemStyle = {
4901
+ padding: 'var(--menu-item-padding, 0.5em 1em) ',
4902
+ display: 'flex',
4903
+ alignItems: 'center',
4904
+ minWidth: 0,
4905
+ color: 'rgba(255, 255, 255, 0.6)',
4906
+ background: 'var(--menu-item-background, rgba(255, 255, 255, 0.08))',
4907
+ '> div': {
4908
+ overflow: 'hidden',
4909
+ whiteSpace: 'nowrap',
4910
+ textOverflow: 'ellipsis'
4911
+ }
4912
+ };
4913
+ const menuItemSelectedStyle = {
4914
+ color: '#FFF',
4915
+ fontWeight: '600',
4916
+ '::after': {
4917
+ content: '" "',
4918
+ display: 'inline-block',
4919
+ flex: '0 0 1em',
4920
+ height: '1em',
4921
+ marginLeft: '0.5em',
4922
+ backgroundColor: 'var(--setting-check-icon-color, #fff)',
4923
+ maskSize: 'contain',
4924
+ maskImage: `url(${icon.check})`
4925
+ }
4926
+ };
4927
+
4928
+ const MenuItem = ({
4929
+ label,
4930
+ selected,
4931
+ onClick
4932
+ }) => jsx$1("div", {
4933
+ css: [menuItemStyle, selected && menuItemSelectedStyle, process.env.NODE_ENV === "production" ? "" : ";label:MenuItem;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lbnVJdGVtLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DSSIsImZpbGUiOiJNZW51SXRlbS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IGljb24gZnJvbSAnc3R5bGUvaWNvbidcblxuY29uc3QgbWVudUl0ZW1TdHlsZSA9IHtcbiAgcGFkZGluZzogJ3ZhcigtLW1lbnUtaXRlbS1wYWRkaW5nLCAwLjVlbSAxZW0pICcsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAwLFxuICBjb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC42KScsXG4gIGJhY2tncm91bmQ6ICd2YXIoLS1tZW51LWl0ZW0tYmFja2dyb3VuZCwgcmdiYSgyNTUsIDI1NSwgMjU1LCAwLjA4KSknLCBcbiAgJz4gZGl2Jzoge1xuICAgIG92ZXJmbG93OiAnaGlkZGVuJyxcbiAgICB3aGl0ZVNwYWNlOiAnbm93cmFwJyxcbiAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gIH1cbn1cblxuY29uc3QgbWVudUl0ZW1TZWxlY3RlZFN0eWxlID0ge1xuICBjb2xvcjogJyNGRkYnLFxuICBmb250V2VpZ2h0OiAnNjAwJyxcbiAgJzo6YWZ0ZXInOiB7XG4gICAgY29udGVudDogJ1wiIFwiJyxcbiAgICBkaXNwbGF5OiAnaW5saW5lLWJsb2NrJyxcbiAgICBmbGV4OiAnMCAwIDFlbScsXG4gICAgaGVpZ2h0OiAnMWVtJyxcbiAgICBtYXJnaW5MZWZ0OiAnMC41ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXNldHRpbmctY2hlY2staWNvbi1jb2xvciwgI2ZmZiknLFxuICAgIG1hc2tTaXplOiAnY29udGFpbicsXG4gICAgbWFza0ltYWdlOiBgdXJsKCR7aWNvbi5jaGVja30pYCxcbiAgfSxcbn1cblxuY29uc3QgTWVudUl0ZW0gPSAoe2xhYmVsLCBzZWxlY3RlZCwgb25DbGlja30pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W21lbnVJdGVtU3R5bGUsIHNlbGVjdGVkICYmIG1lbnVJdGVtU2VsZWN0ZWRTdHlsZV19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgPlxuICAgIDxkaXY+e2xhYmVsfTwvZGl2PlxuICA8L2Rpdj5cbilcblxuZXhwb3J0IGRlZmF1bHQgTWVudUl0ZW1cbiJdfQ== */"],
4934
+ onClick: onClick,
4935
+ children: jsx$1("div", {
4936
+ children: label
4937
+ })
4938
+ });
4939
+
4940
+ /* @jsxImportSource @emotion/react */
4941
+ const landscapeStyle = {
4942
+ display: 'flex',
4943
+ flexWrap: 'wrap',
4944
+ justifyContent: 'space-between',
4945
+ '> div': {
4946
+ boxSizing: 'border-box',
4947
+ flex: '0 0 50%',
4948
+ minWidth: 0
4949
+ },
4950
+ '> div:not(:first-of-type)': {
4951
+ marginTop: 0,
4952
+ flex: '0 0 calc(50% - 1px)'
4953
+ },
4954
+ hr: {
4955
+ height: 'auto',
4956
+ borderLeft: '1px solid transparent'
4957
+ }
4958
+ };
4959
+ const containerStyle$3 = {
4960
+ fontSize: '16px',
4961
+ background: '#262626',
4962
+ height: '100%',
4963
+ h3: {
4964
+ margin: 0,
4965
+ 'margin-block-start': 0,
4966
+ 'margin-block-end': 0,
4967
+ padding: '0.6em 1em',
4968
+ display: 'flex',
4969
+ alignItems: 'center',
4970
+ borderRadius: '4px 4px 0 0',
4971
+ fontSize: '17px',
4972
+ button: {
4973
+ fontSize: '0.6em',
4974
+ marginRight: '0.5em'
4975
+ }
4976
+ }
4977
+ };
4978
+ const twoColumnStyle = {
4979
+ hr: {
4980
+ border: 'none'
4981
+ },
4982
+ '> div ': {
4983
+ '> div:not(:first-of-type)': {
4984
+ marginTop: '0.66em'
4985
+ },
4986
+ '@media (orientation: landscape)': landscapeStyle
4987
+ },
4988
+ '> div > div > div:first-of-type': {
4989
+ padding: '0.6em 1.1em',
4990
+ fontSize: '14px',
4991
+ color: '#aaaeb5',
4992
+ background: 'var(--menu-item-background, #262626)',
4993
+ overflow: 'hidden',
4994
+ textOverflow: 'ellipsis'
4995
+ }
4996
+ };
4997
+ const desktopContainerStyle = {
4998
+ paddingBottom: '1.5em',
4999
+ width: '34em',
5000
+ minHeight: '30.5%',
5001
+ maxHeight: '63.5%',
5002
+ borderRadius: '4px',
5003
+ background: 'rgba(0, 0, 0, 0.60)',
5004
+ '--menu-item-background': 'transparent',
5005
+ '--menu-item-padding': '0.66em 1.5em',
5006
+ h3: {
5007
+ padding: '0.66em 1.5em',
5008
+ fontSize: '16px',
5009
+ color: 'rgba(255, 255, 255, 0.60)',
5010
+ background: 'rgba(0, 0, 0, 0.80)'
5011
+ }
4858
5012
  };
5013
+ const desktop2ColumnStyle = {
5014
+ '> div': landscapeStyle,
5015
+ '> div hr': {
5016
+ fontSize: '150%',
5017
+ borderLeft: '1px solid rgba(255, 255, 255, 0.20)'
5018
+ },
5019
+ '> div > div': {
5020
+ padding: '0 1em'
5021
+ },
5022
+ '> div > div > div:first-of-type': {
5023
+ padding: '0.66em 0.5em',
5024
+ color: '#fff',
5025
+ fontSize: '16px',
5026
+ fontWeight: '600'
5027
+ }
5028
+ };
5029
+
5030
+ const closeMenu = event => event.currentTarget.dispatchEvent(new CustomEvent('close-menu', {
5031
+ bubbles: true
5032
+ }));
5033
+
5034
+ const LanguageMenu = ({
5035
+ uiType = 'mobile',
5036
+ title = '音声 ・ 字幕',
5037
+ sections = ['音声', '字幕'],
5038
+ sectionOptions = [],
5039
+ onChange
5040
+ }) => jsxs("div", {
5041
+ css: [containerStyle$3, twoColumnStyle, uiType === 'desktop' && [desktopContainerStyle, desktop2ColumnStyle], process.env.NODE_ENV === "production" ? "" : ";label:LanguageMenu;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxhbmd1YWdlTWVudS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4R0kiLCJmaWxlIjoiTGFuZ3VhZ2VNZW51LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHtCdXR0b259IGZyb20gJy4vYnV0dG9ucydcbmltcG9ydCBNZW51SXRlbSBmcm9tICcuL01lbnVJdGVtJ1xuXG5jb25zdCBsYW5kc2NhcGVTdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBmbGV4V3JhcDogJ3dyYXAnLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxuICAnPiBkaXYnOiB7XG4gICAgYm94U2l6aW5nOiAnYm9yZGVyLWJveCcsXG4gICAgZmxleDogJzAgMCA1MCUnLFxuICAgIG1pbldpZHRoOiAwLFxuICB9LFxuICAnPiBkaXY6bm90KDpmaXJzdC1vZi10eXBlKSc6IHtcbiAgICBtYXJnaW5Ub3A6IDAsXG4gICAgZmxleDogJzAgMCBjYWxjKDUwJSAtIDFweCknLFxuICB9LFxuICBocjoge1xuICAgIGhlaWdodDogJ2F1dG8nLFxuICAgIGJvcmRlckxlZnQ6ICcxcHggc29saWQgdHJhbnNwYXJlbnQnLFxuICB9LFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxNnB4JyxcbiAgYmFja2dyb3VuZDogJyMyNjI2MjYnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgaDM6IHtcbiAgICBtYXJnaW46IDAsXG4gICAgJ21hcmdpbi1ibG9jay1zdGFydCc6IDAsXG4gICAgJ21hcmdpbi1ibG9jay1lbmQnOiAwLFxuICAgIHBhZGRpbmc6ICcwLjZlbSAxZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBib3JkZXJSYWRpdXM6ICc0cHggNHB4IDAgMCcsXG4gICAgZm9udFNpemU6ICcxN3B4JyxcbiAgICBidXR0b246IHtcbiAgICAgIGZvbnRTaXplOiAnMC42ZW0nLFxuICAgICAgbWFyZ2luUmlnaHQ6ICcwLjVlbScsXG4gICAgfSxcbiAgfSxcbn1cblxuY29uc3QgdHdvQ29sdW1uU3R5bGUgPSB7XG4gIGhyOiB7XG4gICAgYm9yZGVyOiAnbm9uZScsXG4gIH0sXG4gICc+IGRpdiAnOiB7XG4gICAgJz4gZGl2Om5vdCg6Zmlyc3Qtb2YtdHlwZSknOiB7XG4gICAgICBtYXJnaW5Ub3A6ICcwLjY2ZW0nLFxuICAgIH0sXG4gICAgJ0BtZWRpYSAob3JpZW50YXRpb246IGxhbmRzY2FwZSknOiBsYW5kc2NhcGVTdHlsZSxcbiAgfSxcbiAgJz4gZGl2ID4gZGl2ID4gZGl2OmZpcnN0LW9mLXR5cGUnOiB7XG4gICAgcGFkZGluZzogJzAuNmVtIDEuMWVtJyxcbiAgICBmb250U2l6ZTogJzE0cHgnLFxuICAgIGNvbG9yOiAnI2FhYWViNScsXG4gICAgYmFja2dyb3VuZDogJ3ZhcigtLW1lbnUtaXRlbS1iYWNrZ3JvdW5kLCAjMjYyNjI2KScsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgIHRleHRPdmVyZmxvdzogJ2VsbGlwc2lzJyxcbiAgfSxcbn1cblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwYWRkaW5nQm90dG9tOiAnMS41ZW0nLFxuICB3aWR0aDogJzM0ZW0nLFxuICBtaW5IZWlnaHQ6ICczMC41JScsXG4gIG1heEhlaWdodDogJzYzLjUlJyxcbiAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgYmFja2dyb3VuZDogJ3JnYmEoMCwgMCwgMCwgMC42MCknLFxuICAnLS1tZW51LWl0ZW0tYmFja2dyb3VuZCc6ICd0cmFuc3BhcmVudCcsXG4gICctLW1lbnUtaXRlbS1wYWRkaW5nJzogJzAuNjZlbSAxLjVlbScsXG4gIGgzOiB7XG4gICAgcGFkZGluZzogJzAuNjZlbSAxLjVlbScsXG4gICAgZm9udFNpemU6ICcxNnB4JyxcbiAgICBjb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC42MCknLFxuICAgIGJhY2tncm91bmQ6ICdyZ2JhKDAsIDAsIDAsIDAuODApJyxcbiAgfSxcbn1cblxuY29uc3QgZGVza3RvcDJDb2x1bW5TdHlsZSA9IHtcbiAgJz4gZGl2JzogbGFuZHNjYXBlU3R5bGUsXG4gICc+IGRpdiBocic6IHtcbiAgICBmb250U2l6ZTogJzE1MCUnLFxuICAgIGJvcmRlckxlZnQ6ICcxcHggc29saWQgIHJnYmEoMjU1LCAyNTUsIDI1NSwgMC4yMCknLFxuICB9LFxuICAnPiBkaXYgPiBkaXYnOiB7XG4gICAgcGFkZGluZzogJzAgMWVtJyxcbiAgfSxcbiAgJz4gZGl2ID4gZGl2ID4gZGl2OmZpcnN0LW9mLXR5cGUnOiB7XG4gICAgcGFkZGluZzogJzAuNjZlbSAwLjVlbScsXG4gICAgY29sb3I6ICcjZmZmJyxcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIGZvbnRXZWlnaHQ6ICc2MDAnLFxuICB9LFxufVxuXG5jb25zdCBjbG9zZU1lbnUgPSBldmVudCA9PlxuICBldmVudC5jdXJyZW50VGFyZ2V0LmRpc3BhdGNoRXZlbnQoXG4gICAgbmV3IEN1c3RvbUV2ZW50KCdjbG9zZS1tZW51Jywge2J1YmJsZXM6IHRydWV9KVxuICApXG5cbmNvbnN0IExhbmd1YWdlTWVudSA9ICh7XG4gIHVpVHlwZSA9ICdtb2JpbGUnLFxuICB0aXRsZSA9ICfpn7Plo7Ag44O7IOWtl+W5lScsXG4gIHNlY3Rpb25zID0gWyfpn7Plo7AnLCAn5a2X5bmVJ10sXG4gIHNlY3Rpb25PcHRpb25zID0gW10sXG4gIG9uQ2hhbmdlLFxufSkgPT4gKFxuICA8ZGl2XG4gICAgY3NzPXtbXG4gICAgICBjb250YWluZXJTdHlsZSxcbiAgICAgIHR3b0NvbHVtblN0eWxlLFxuICAgICAgdWlUeXBlID09PSAnZGVza3RvcCcgJiYgW2Rlc2t0b3BDb250YWluZXJTdHlsZSwgZGVza3RvcDJDb2x1bW5TdHlsZV0sXG4gICAgXX1cbiAgPlxuICAgIDxoMz5cbiAgICAgIHt1aVR5cGUgIT09ICdkZXNrdG9wJyAmJiA8QnV0dG9uIHN0YXJ0SWNvbj1cImNsb3NlXCIgb25DbGljaz17Y2xvc2VNZW51fSAvPn1cbiAgICAgIHt0aXRsZX1cbiAgICA8L2gzPlxuICAgIDxkaXY+XG4gICAgICA8ZGl2PlxuICAgICAgICA8ZGl2PntzZWN0aW9uc1swXX08L2Rpdj5cbiAgICAgICAge3NlY3Rpb25PcHRpb25zWzBdLm1hcChvcHRpb24gPT4gKFxuICAgICAgICAgIDxNZW51SXRlbSB7Li4ub3B0aW9ufSBvbkNsaWNrPXtldmVudCA9PiBvbkNoYW5nZShldmVudCwgb3B0aW9uKX0gLz5cbiAgICAgICAgKSl9XG4gICAgICA8L2Rpdj5cbiAgICAgIDxociAvPlxuICAgICAgPGRpdj5cbiAgICAgICAgPGRpdj57c2VjdGlvbnNbMV19PC9kaXY+XG4gICAgICAgIHtzZWN0aW9uT3B0aW9uc1sxXS5tYXAob3B0aW9uID0+IChcbiAgICAgICAgICA8TWVudUl0ZW0gey4uLm9wdGlvbn0gb25DbGljaz17ZXZlbnQgPT4gb25DaGFuZ2UoZXZlbnQsIG9wdGlvbil9IC8+XG4gICAgICAgICkpfVxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuKVxuXG5MYW5ndWFnZU1lbnUuc3R5bGVzID0gY29udGFpbmVyU3R5bGVcbkxhbmd1YWdlTWVudS5kZXNrdG9wU3R5bGVzID0gZGVza3RvcENvbnRhaW5lclN0eWxlXG5cbmV4cG9ydCBkZWZhdWx0IExhbmd1YWdlTWVudVxuIl19 */"],
5042
+ children: [jsxs("h3", {
5043
+ children: [uiType !== 'desktop' && jsx$1(Button, {
5044
+ startIcon: "close",
5045
+ onClick: closeMenu
5046
+ }), title]
5047
+ }), jsxs("div", {
5048
+ children: [jsxs("div", {
5049
+ children: [jsx$1("div", {
5050
+ children: sections[0]
5051
+ }), sectionOptions[0].map(option => jsx$1(MenuItem, { ...option,
5052
+ onClick: event => onChange(event, option)
5053
+ }))]
5054
+ }), jsx$1("hr", {}), jsxs("div", {
5055
+ children: [jsx$1("div", {
5056
+ children: sections[1]
5057
+ }), sectionOptions[1].map(option => jsx$1(MenuItem, { ...option,
5058
+ onClick: event => onChange(event, option)
5059
+ }))]
5060
+ })]
5061
+ })]
5062
+ });
5063
+
5064
+ LanguageMenu.styles = containerStyle$3;
5065
+ LanguageMenu.desktopStyles = desktopContainerStyle;
4859
5066
 
4860
5067
  function _EMOTION_STRINGIFIED_CSS_ERROR__$4() { 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)."; }
4861
5068
  const panelStyle = {
@@ -5527,9 +5734,9 @@ const switchTracks = ({
5527
5734
  audio,
5528
5735
  subtitles
5529
5736
  }) => {
5530
- var _getMediaSession4;
5737
+ var _getMediaSession4, _getMediaSession4$edi;
5531
5738
 
5532
- return window.cast && ((_getMediaSession4 = getMediaSession()) === null || _getMediaSession4 === void 0 ? void 0 : _getMediaSession4.editTracksInfo(new chrome.cast.media.EditTracksInfoRequest([audio, subtitles].filter(id => id !== 'off'))));
5739
+ return window.cast && ((_getMediaSession4 = getMediaSession()) === null || _getMediaSession4 === void 0 ? void 0 : (_getMediaSession4$edi = _getMediaSession4.editTracksInfo) === null || _getMediaSession4$edi === void 0 ? void 0 : _getMediaSession4$edi.call(_getMediaSession4, new chrome.cast.media.EditTracksInfoRequest([audio, subtitles].filter(id => id !== 'off'))));
5533
5740
  };
5534
5741
 
5535
5742
  const subscribeCastState = handleStateChange => {
@@ -7767,11 +7974,6 @@ const loadShaka = async (videoElement, config = {}, options = {}) => {
7767
7974
  },
7768
7975
  getPlaybackSpeed: () => videoElement.playbackRate,
7769
7976
  getVideoElement: () => videoElement,
7770
- setQuality: restrictions => {
7771
- if (!restrictions) return; // FIXME: Setting restrictions to {} cannot enable abr.
7772
-
7773
- player.configure('abr.restrictions', restrictions);
7774
- },
7775
7977
  getVideoQuality,
7776
7978
  getAvailableVideoQualities,
7777
7979
  isAlive: () => player.getLoadMode() !== shaka.Player.LoadMode.DESTROYED,
@@ -7820,7 +8022,8 @@ const loadPlayer = async (videoElement, {
7820
8022
 
7821
8023
  reloadOnLiveStall(videoElement, {
7822
8024
  reload: () => player.reload()
7823
- }); // TODO load built-in modules here
8025
+ });
8026
+ player.preferredSettings = {}; // TODO load built-in modules here
7824
8027
 
7825
8028
  player.modules = {};
7826
8029
  return player;
@@ -7850,8 +8053,8 @@ const Video = ({
7850
8053
  playbackState: targetState,
7851
8054
  currentTime: targetTime,
7852
8055
  playbackRate,
8056
+ videoResolution,
7853
8057
  textTracks = emptyArray,
7854
- quality,
7855
8058
  textTrack,
7856
8059
  audio = {},
7857
8060
  liveResume,
@@ -7965,12 +8168,12 @@ const Video = ({
7965
8168
  }, playbackRate);
7966
8169
  }, [playbackRate, playbackState === 'playing']);
7967
8170
  useEffect(() => {
7968
- if (player !== null && player !== void 0 && player.isAlive()) {
7969
- setQuality(videoElement.current, {
8171
+ if (player) {
8172
+ selectVideoResolution(videoElement.current, {
7970
8173
  player
7971
- }, quality);
8174
+ }, videoResolution);
7972
8175
  }
7973
- }, [quality, player]);
8176
+ }, [videoResolution, player]);
7974
8177
  useEffect(() => {
7975
8178
  setAudioTrack(videoElement.current, {
7976
8179
  player
@@ -7989,7 +8192,7 @@ const Video = ({
7989
8192
  ref: videoContainer,
7990
8193
  css: /*#__PURE__*/css({
7991
8194
  video: baseVideoStyle
7992
- }, process.env.NODE_ENV === "production" ? "" : ";label:Video;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlZpZGVvLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtLOEIiLCJmaWxlIjoiVmlkZW8uanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHt1c2VFZmZlY3QsIHVzZUxheW91dEVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5cbmltcG9ydCBtdWx0aVJlZiBmcm9tICd1dGlsL211bHRpUmVmJ1xuaW1wb3J0IGxvYWRQbGF5ZXIgZnJvbSAncGxheWVyQ29yZS9sb2FkUGxheWVyJ1xuaW1wb3J0IHtcbiAgZ2V0TWVkaWFUaW1lLFxuICBzdWJzY3JpYmVQbGF5YmFja1N0YXRlLFxuICBsb2FkLFxuICBzeW5jUGxheWJhY2tTdGF0ZSxcbiAgc2VlayxcbiAgc2V0UGxheWJhY2tSYXRlLFxuICBzZXRRdWFsaXR5LFxuICBzZXRBdWRpb1RyYWNrLFxuICBzeW5jVGV4dFRyYWNrLFxufSBmcm9tICdwbGF5ZXJDb3JlL21lZGlhQmluZGluZ3MnXG5cbmNvbnN0IGJhc2VWaWRlb1N0eWxlID0ge1xuICBvYmplY3RGaXQ6ICdjb250YWluJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgbWF4SGVpZ2h0OiAnMTAwJScsXG4gICcmOmZ1bGxzY3JlZW4nOiB7XG4gICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIHJpZ2h0OiAwLFxuICB9LFxuICAnfiAuc2hha2EtdGV4dC1jb250YWluZXInOiB7XG4gICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgaGVpZ2h0OiAnMTAwJScsXG4gICAgd2lkdGg6ICcxMDAlJyxcbiAgfSxcbn1cblxuY29uc3QgZW1wdHlBcnJheSA9IFtdXG5cbmNvbnN0IFZpZGVvID0gKHtcbiAgc291cmNlLFxuICBwbGF5YmFja1N0YXRlOiB0YXJnZXRTdGF0ZSxcbiAgY3VycmVudFRpbWU6IHRhcmdldFRpbWUsXG4gIHBsYXliYWNrUmF0ZSxcbiAgdGV4dFRyYWNrcyA9IGVtcHR5QXJyYXksXG4gIHF1YWxpdHksXG4gIHRleHRUcmFjayxcbiAgYXVkaW8gPSB7fSxcbiAgbGl2ZVJlc3VtZSxcbiAgaU9TRnVsbHNjcmVlbkRldGVjdFRocmVzaG9sZCwgLy8gVE9ETyBvcmdhbml6ZSBwcm9wc1xuICBwbHVnaW5zID0gW10sXG4gIHNoYWthLFxuICBiaXRtb3ZpbixcbiAgbGljZW5zZSxcbiAgdmFsaWRhdGlvbkhvc3QsXG4gIHZpZGVvUmVmLFxuICBwbGF5ZXJSZWYsXG4gIG9uUGxheWVyTG9hZGVkLFxuICBvblBsYXliYWNrU3RhdGVDaGFuZ2UsXG4gIG9uQmxvY2tlZEF1dG9wbGF5LFxuICBvblBsYXlsb2dGaXJlZCxcbiAgLi4udmlkZW9BdHRyaWJ1dGVzXG59KSA9PiB7XG4gIGNvbnN0IGhhbmRsZXJzID0gdXNlUmVmKClcbiAgaGFuZGxlcnMuY3VycmVudCA9IHtvblBsYXliYWNrU3RhdGVDaGFuZ2UsIG9uQmxvY2tlZEF1dG9wbGF5fVxuICBjb25zdCB2aWRlb0NvbnRhaW5lciA9IHVzZVJlZigpXG4gIGNvbnN0IHZpZGVvRWxlbWVudCA9IHVzZVJlZigpXG4gIGNvbnN0IFtwbGF5YmFja1N0YXRlLCBzZXRQbGF5YmFja1N0YXRlXSA9IHVzZVN0YXRlKCcnKVxuICBjb25zdCBbcGxheWVyLCBzZXRQbGF5ZXJdID0gdXNlU3RhdGUoKVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgbG9hZFRhc2sgPSBsb2FkUGxheWVyKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7XG4gICAgICBjb250YWluZXI6IHZpZGVvQ29udGFpbmVyLmN1cnJlbnQsXG4gICAgICBzb3VyY2UsXG4gICAgICBzaGFrYSxcbiAgICAgIGJpdG1vdmluLFxuICAgIH0pLnRoZW4oYmFzZVBsYXllciA9PiB7XG4gICAgICBzZXRQbGF5ZXIoYmFzZVBsYXllcilcbiAgICAgIG9uUGxheWVyTG9hZGVkPy4oYmFzZVBsYXllcilcbiAgICAgIGlmIChwbGF5ZXJSZWYpIHtcbiAgICAgICAgcGxheWVyUmVmLmN1cnJldCA9IGJhc2VQbGF5ZXJcbiAgICAgIH1cbiAgICAgIHJldHVybiBiYXNlUGxheWVyXG4gICAgfSlcbiAgICBjb25zdCBvZmZQbGF5YmFja1N0YXRlID0gc3Vic2NyaWJlUGxheWJhY2tTdGF0ZShcbiAgICAgIHZpZGVvRWxlbWVudC5jdXJyZW50LFxuICAgICAgKGV2ZW50LCBzdGF0ZSkgPT4ge1xuICAgICAgICBoYW5kbGVycy5jdXJyZW50Lm9uUGxheWJhY2tTdGF0ZUNoYW5nZT8uKGV2ZW50LCBzdGF0ZSlcbiAgICAgICAgLy8gZXh0ZXJuYWwgbG9naWMgbWF5IHdhbnQgdG8gY2hhbmdlIHRhcmdldFN0YXRlLCBob2xkIHBsYXliYWNrU3RhdGUgdXBkYXRlXG4gICAgICAgIC8vIHRvIHByZXZlbnQgdW53YW50ZWQgc3luY1BsYXliYWNrU3RhdGVcbiAgICAgICAgcmVxdWVzdEFuaW1hdGlvbkZyYW1lKCgpID0+IHNldFBsYXliYWNrU3RhdGUoc3RhdGUpKVxuICAgICAgfSxcbiAgICAgIHtpT1NGdWxsc2NyZWVuRGV0ZWN0VGhyZXNob2xkfVxuICAgIClcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgb2ZmUGxheWJhY2tTdGF0ZSgpXG4gICAgICBsb2FkVGFzay50aGVuKGN1cnJlbnRQbGF5ZXIgPT4gY3VycmVudFBsYXllcj8uZGVzdHJveSgpKVxuICAgIH1cbiAgfSwgW10pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKFxuICAgICAgc291cmNlICYmXG4gICAgICAoc291cmNlLmxlbmd0aCA+IDAgfHwgc291cmNlLnNyYyB8fCBzb3VyY2UuaGxzIHx8IHNvdXJjZS5kYXNoKSAmJlxuICAgICAgcGxheWVyPy5pc0FsaXZlKClcbiAgICApIHtcbiAgICAgIFByb21pc2UucmVzb2x2ZShmYWxzZSlcbiAgICAgICAgLnRoZW4oKCkgPT5cbiAgICAgICAgICBsb2FkKFxuICAgICAgICAgICAgdmlkZW9FbGVtZW50LmN1cnJlbnQsXG4gICAgICAgICAgICB7cGxheWVyLCBwbHVnaW5zLCBzdGFydFRpbWU6IHRhcmdldFRpbWV9LFxuICAgICAgICAgICAgc291cmNlXG4gICAgICAgICAgKVxuICAgICAgICApXG4gICAgICAgIC5jYXRjaChlcnJvciA9PiBjb25zb2xlLndhcm4oZXJyb3IpKVxuICAgIH1cbiAgICBpZiAoKCFzb3VyY2UgfHwgc291cmNlLmxlbmd0aCA9PT0gMCkgJiYgcGxheWVyKSB7XG4gICAgICBwbGF5ZXIudW5sb2FkKClcbiAgICAgIHBsYXllci5sYXN0U3JjID0gJydcbiAgICB9XG4gIH0sIFtwbGF5ZXIsIHNvdXJjZV0pXG5cbiAgLy8gdXNlRWZmZWN0IGlzIHRvbyBsYXRlIHRvIHVubG9jayBwbGF5IG9uIFNhZmFyaVxuICAvLyBUT0RPIGNoZWNrIGlmIHRoaXMgd29yayBhZnRlciB1cGdyYWRpbmcgUmVhY3QgMThcbiAgdXNlTGF5b3V0RWZmZWN0KCgpID0+IHtcbiAgICBpZiAocGxheWVyPy5pc0FsaXZlKCkpIHtcbiAgICAgIHN5bmNQbGF5YmFja1N0YXRlKFxuICAgICAgICB2aWRlb0VsZW1lbnQuY3VycmVudCxcbiAgICAgICAge3BsYXllciwgcGx1Z2lucywgbGl2ZVJlc3VtZX0sXG4gICAgICAgIHRhcmdldFN0YXRlXG4gICAgICApPy5jYXRjaChlcnJvciA9PiB7XG4gICAgICAgIGhhbmRsZXJzLmN1cnJlbnQub25CbG9ja2VkQXV0b3BsYXk/LihlcnJvcilcbiAgICAgIH0pXG4gICAgfVxuICB9LCBbcGxheWVyICYmIHRhcmdldFN0YXRlXSlcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCB7Y3VycmVudFRpbWV9ID0gZ2V0TWVkaWFUaW1lKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyLCBwbHVnaW5zfSlcbiAgICBpZiAocGxheWVyPy5pc0FsaXZlKCkgJiYgTWF0aC5hYnMoY3VycmVudFRpbWUgLSB0YXJnZXRUaW1lKSA+IDAuNSkge1xuICAgICAgLy8gc2Vla2luZyB1bmF2YWlsYWJsZSBjYXNlcyBhcmUgaGFuZGxlZCBieSBzZWVrIGZ1bmN0aW9uXG4gICAgICBzZWVrKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyLCBwbHVnaW5zfSwgdGFyZ2V0VGltZSlcbiAgICB9XG4gIH0sIFtwbGF5ZXIgJiYgdGFyZ2V0VGltZV0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgc2V0UGxheWJhY2tSYXRlKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyfSwgcGxheWJhY2tSYXRlKVxuICB9LCBbcGxheWJhY2tSYXRlLCBwbGF5YmFja1N0YXRlID09PSAncGxheWluZyddKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChwbGF5ZXI/LmlzQWxpdmUoKSkge1xuICAgICAgc2V0UXVhbGl0eSh2aWRlb0VsZW1lbnQuY3VycmVudCwge3BsYXllcn0sIHF1YWxpdHkpXG4gICAgfVxuICB9LCBbcXVhbGl0eSwgcGxheWVyXSlcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXRBdWRpb1RyYWNrKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyfSwgYXVkaW8pXG4gIH0sIFthdWRpbz8uaWQgfHwgYCR7YXVkaW8ubGFuZ3VhZ2UgfHwgJ3Vuayd9OiR7YXVkaW8ubGFiZWwgfHwgJyd9YCwgcGxheWVyXSlcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAodGV4dFRyYWNrcz8ubGVuZ3RoID4gMCB8fCB0ZXh0VHJhY2spIHtcbiAgICAgIHJldHVybiBzeW5jVGV4dFRyYWNrKFxuICAgICAgICB2aWRlb0VsZW1lbnQuY3VycmVudCxcbiAgICAgICAge3BsYXllcn0sXG4gICAgICAgIHRleHRUcmFja3M/Lmxlbmd0aCA+IDAgPyB7dGV4dFRyYWNrc30gOiB0ZXh0VHJhY2tcbiAgICAgIClcbiAgICB9XG4gIH0sIFt2aWRlb0VsZW1lbnQuY3VycmVudD8ucmVhZHlTdGF0ZSA+PSAyICYmIHRleHRUcmFja3MsIHRleHRUcmFja10pXG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IHJlZj17dmlkZW9Db250YWluZXJ9IGNzcz17e3ZpZGVvOiBiYXNlVmlkZW9TdHlsZX19PlxuICAgICAgPHZpZGVvIC8vIGVzbGludC1kaXNhYmxlLWxpbmUganN4LWExMXkvbWVkaWEtaGFzLWNhcHRpb25cbiAgICAgICAgcmVmPXttdWx0aVJlZih2aWRlb1JlZiwgdmlkZW9FbGVtZW50KX1cbiAgICAgICAgcGxheXNJbmxpbmVcbiAgICAgICAgey4uLnZpZGVvQXR0cmlidXRlc31cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgVmlkZW9cbiJdfQ== */"),
8195
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Video;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlZpZGVvLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtLOEIiLCJmaWxlIjoiVmlkZW8uanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHt1c2VFZmZlY3QsIHVzZUxheW91dEVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5cbmltcG9ydCBtdWx0aVJlZiBmcm9tICd1dGlsL211bHRpUmVmJ1xuaW1wb3J0IGxvYWRQbGF5ZXIgZnJvbSAncGxheWVyQ29yZS9sb2FkUGxheWVyJ1xuaW1wb3J0IHtcbiAgZ2V0TWVkaWFUaW1lLFxuICBzdWJzY3JpYmVQbGF5YmFja1N0YXRlLFxuICBsb2FkLFxuICBzeW5jUGxheWJhY2tTdGF0ZSxcbiAgc2VlayxcbiAgc2V0UGxheWJhY2tSYXRlLFxuICBzZXRBdWRpb1RyYWNrLFxuICBzeW5jVGV4dFRyYWNrLFxufSBmcm9tICdwbGF5ZXJDb3JlL21lZGlhQmluZGluZ3MnXG5pbXBvcnQge3NlbGVjdFZpZGVvUmVzb2x1dGlvbn0gZnJvbSAncGxheWVyQ29yZS9hZGFwdGF0aW9uJ1xuXG5jb25zdCBiYXNlVmlkZW9TdHlsZSA9IHtcbiAgb2JqZWN0Rml0OiAnY29udGFpbicsXG4gIHdpZHRoOiAnMTAwJScsXG4gIG1heEhlaWdodDogJzEwMCUnLFxuICAnJjpmdWxsc2NyZWVuJzoge1xuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIHRvcDogMCxcbiAgICBsZWZ0OiAwLFxuICAgIGJvdHRvbTogMCxcbiAgICByaWdodDogMCxcbiAgfSxcbiAgJ34gLnNoYWthLXRleHQtY29udGFpbmVyJzoge1xuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIGhlaWdodDogJzEwMCUnLFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH0sXG59XG5cbmNvbnN0IGVtcHR5QXJyYXkgPSBbXVxuXG5jb25zdCBWaWRlbyA9ICh7XG4gIHNvdXJjZSxcbiAgcGxheWJhY2tTdGF0ZTogdGFyZ2V0U3RhdGUsXG4gIGN1cnJlbnRUaW1lOiB0YXJnZXRUaW1lLFxuICBwbGF5YmFja1JhdGUsXG4gIHZpZGVvUmVzb2x1dGlvbixcbiAgdGV4dFRyYWNrcyA9IGVtcHR5QXJyYXksXG4gIHRleHRUcmFjayxcbiAgYXVkaW8gPSB7fSxcbiAgbGl2ZVJlc3VtZSxcbiAgaU9TRnVsbHNjcmVlbkRldGVjdFRocmVzaG9sZCwgLy8gVE9ETyBvcmdhbml6ZSBwcm9wc1xuICBwbHVnaW5zID0gW10sXG4gIHNoYWthLFxuICBiaXRtb3ZpbixcbiAgbGljZW5zZSxcbiAgdmFsaWRhdGlvbkhvc3QsXG4gIHZpZGVvUmVmLFxuICBwbGF5ZXJSZWYsXG4gIG9uUGxheWVyTG9hZGVkLFxuICBvblBsYXliYWNrU3RhdGVDaGFuZ2UsXG4gIG9uQmxvY2tlZEF1dG9wbGF5LFxuICBvblBsYXlsb2dGaXJlZCxcbiAgLi4udmlkZW9BdHRyaWJ1dGVzXG59KSA9PiB7XG4gIGNvbnN0IGhhbmRsZXJzID0gdXNlUmVmKClcbiAgaGFuZGxlcnMuY3VycmVudCA9IHtvblBsYXliYWNrU3RhdGVDaGFuZ2UsIG9uQmxvY2tlZEF1dG9wbGF5fVxuICBjb25zdCB2aWRlb0NvbnRhaW5lciA9IHVzZVJlZigpXG4gIGNvbnN0IHZpZGVvRWxlbWVudCA9IHVzZVJlZigpXG4gIGNvbnN0IFtwbGF5YmFja1N0YXRlLCBzZXRQbGF5YmFja1N0YXRlXSA9IHVzZVN0YXRlKCcnKVxuICBjb25zdCBbcGxheWVyLCBzZXRQbGF5ZXJdID0gdXNlU3RhdGUoKVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgbG9hZFRhc2sgPSBsb2FkUGxheWVyKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7XG4gICAgICBjb250YWluZXI6IHZpZGVvQ29udGFpbmVyLmN1cnJlbnQsXG4gICAgICBzb3VyY2UsXG4gICAgICBzaGFrYSxcbiAgICAgIGJpdG1vdmluLFxuICAgIH0pLnRoZW4oYmFzZVBsYXllciA9PiB7XG4gICAgICBzZXRQbGF5ZXIoYmFzZVBsYXllcilcbiAgICAgIG9uUGxheWVyTG9hZGVkPy4oYmFzZVBsYXllcilcbiAgICAgIGlmIChwbGF5ZXJSZWYpIHtcbiAgICAgICAgcGxheWVyUmVmLmN1cnJldCA9IGJhc2VQbGF5ZXJcbiAgICAgIH1cbiAgICAgIHJldHVybiBiYXNlUGxheWVyXG4gICAgfSlcbiAgICBjb25zdCBvZmZQbGF5YmFja1N0YXRlID0gc3Vic2NyaWJlUGxheWJhY2tTdGF0ZShcbiAgICAgIHZpZGVvRWxlbWVudC5jdXJyZW50LFxuICAgICAgKGV2ZW50LCBzdGF0ZSkgPT4ge1xuICAgICAgICBoYW5kbGVycy5jdXJyZW50Lm9uUGxheWJhY2tTdGF0ZUNoYW5nZT8uKGV2ZW50LCBzdGF0ZSlcbiAgICAgICAgLy8gZXh0ZXJuYWwgbG9naWMgbWF5IHdhbnQgdG8gY2hhbmdlIHRhcmdldFN0YXRlLCBob2xkIHBsYXliYWNrU3RhdGUgdXBkYXRlXG4gICAgICAgIC8vIHRvIHByZXZlbnQgdW53YW50ZWQgc3luY1BsYXliYWNrU3RhdGVcbiAgICAgICAgcmVxdWVzdEFuaW1hdGlvbkZyYW1lKCgpID0+IHNldFBsYXliYWNrU3RhdGUoc3RhdGUpKVxuICAgICAgfSxcbiAgICAgIHtpT1NGdWxsc2NyZWVuRGV0ZWN0VGhyZXNob2xkfVxuICAgIClcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgb2ZmUGxheWJhY2tTdGF0ZSgpXG4gICAgICBsb2FkVGFzay50aGVuKGN1cnJlbnRQbGF5ZXIgPT4gY3VycmVudFBsYXllcj8uZGVzdHJveSgpKVxuICAgIH1cbiAgfSwgW10pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKFxuICAgICAgc291cmNlICYmXG4gICAgICAoc291cmNlLmxlbmd0aCA+IDAgfHwgc291cmNlLnNyYyB8fCBzb3VyY2UuaGxzIHx8IHNvdXJjZS5kYXNoKSAmJlxuICAgICAgcGxheWVyPy5pc0FsaXZlKClcbiAgICApIHtcbiAgICAgIFByb21pc2UucmVzb2x2ZShmYWxzZSlcbiAgICAgICAgLnRoZW4oKCkgPT5cbiAgICAgICAgICBsb2FkKFxuICAgICAgICAgICAgdmlkZW9FbGVtZW50LmN1cnJlbnQsXG4gICAgICAgICAgICB7cGxheWVyLCBwbHVnaW5zLCBzdGFydFRpbWU6IHRhcmdldFRpbWV9LFxuICAgICAgICAgICAgc291cmNlXG4gICAgICAgICAgKVxuICAgICAgICApXG4gICAgICAgIC5jYXRjaChlcnJvciA9PiBjb25zb2xlLndhcm4oZXJyb3IpKVxuICAgIH1cbiAgICBpZiAoKCFzb3VyY2UgfHwgc291cmNlLmxlbmd0aCA9PT0gMCkgJiYgcGxheWVyKSB7XG4gICAgICBwbGF5ZXIudW5sb2FkKClcbiAgICAgIHBsYXllci5sYXN0U3JjID0gJydcbiAgICB9XG4gIH0sIFtwbGF5ZXIsIHNvdXJjZV0pXG5cbiAgLy8gdXNlRWZmZWN0IGlzIHRvbyBsYXRlIHRvIHVubG9jayBwbGF5IG9uIFNhZmFyaVxuICAvLyBUT0RPIGNoZWNrIGlmIHRoaXMgd29yayBhZnRlciB1cGdyYWRpbmcgUmVhY3QgMThcbiAgdXNlTGF5b3V0RWZmZWN0KCgpID0+IHtcbiAgICBpZiAocGxheWVyPy5pc0FsaXZlKCkpIHtcbiAgICAgIHN5bmNQbGF5YmFja1N0YXRlKFxuICAgICAgICB2aWRlb0VsZW1lbnQuY3VycmVudCxcbiAgICAgICAge3BsYXllciwgcGx1Z2lucywgbGl2ZVJlc3VtZX0sXG4gICAgICAgIHRhcmdldFN0YXRlXG4gICAgICApPy5jYXRjaChlcnJvciA9PiB7XG4gICAgICAgIGhhbmRsZXJzLmN1cnJlbnQub25CbG9ja2VkQXV0b3BsYXk/LihlcnJvcilcbiAgICAgIH0pXG4gICAgfVxuICB9LCBbcGxheWVyICYmIHRhcmdldFN0YXRlXSlcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCB7Y3VycmVudFRpbWV9ID0gZ2V0TWVkaWFUaW1lKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyLCBwbHVnaW5zfSlcbiAgICBpZiAocGxheWVyPy5pc0FsaXZlKCkgJiYgTWF0aC5hYnMoY3VycmVudFRpbWUgLSB0YXJnZXRUaW1lKSA+IDAuNSkge1xuICAgICAgLy8gc2Vla2luZyB1bmF2YWlsYWJsZSBjYXNlcyBhcmUgaGFuZGxlZCBieSBzZWVrIGZ1bmN0aW9uXG4gICAgICBzZWVrKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyLCBwbHVnaW5zfSwgdGFyZ2V0VGltZSlcbiAgICB9XG4gIH0sIFtwbGF5ZXIgJiYgdGFyZ2V0VGltZV0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgc2V0UGxheWJhY2tSYXRlKHZpZGVvRWxlbWVudC5jdXJyZW50LCB7cGxheWVyfSwgcGxheWJhY2tSYXRlKVxuICB9LCBbcGxheWJhY2tSYXRlLCBwbGF5YmFja1N0YXRlID09PSAncGxheWluZyddKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChwbGF5ZXIpIHtcbiAgICAgIHNlbGVjdFZpZGVvUmVzb2x1dGlvbih2aWRlb0VsZW1lbnQuY3VycmVudCwge3BsYXllcn0sIHZpZGVvUmVzb2x1dGlvbilcbiAgICB9XG4gIH0sIFt2aWRlb1Jlc29sdXRpb24sIHBsYXllcl0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgc2V0QXVkaW9UcmFjayh2aWRlb0VsZW1lbnQuY3VycmVudCwge3BsYXllcn0sIGF1ZGlvKVxuICB9LCBbYXVkaW8/LmlkIHx8IGAke2F1ZGlvLmxhbmd1YWdlIHx8ICd1bmsnfToke2F1ZGlvLmxhYmVsIHx8ICcnfWAsIHBsYXllcl0pXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHRleHRUcmFja3M/Lmxlbmd0aCA+IDAgfHwgdGV4dFRyYWNrKSB7XG4gICAgICByZXR1cm4gc3luY1RleHRUcmFjayhcbiAgICAgICAgdmlkZW9FbGVtZW50LmN1cnJlbnQsXG4gICAgICAgIHtwbGF5ZXJ9LFxuICAgICAgICB0ZXh0VHJhY2tzPy5sZW5ndGggPiAwID8ge3RleHRUcmFja3N9IDogdGV4dFRyYWNrXG4gICAgICApXG4gICAgfVxuICB9LCBbdmlkZW9FbGVtZW50LmN1cnJlbnQ/LnJlYWR5U3RhdGUgPj0gMiAmJiB0ZXh0VHJhY2tzLCB0ZXh0VHJhY2tdKVxuXG4gIHJldHVybiAoXG4gICAgPGRpdiByZWY9e3ZpZGVvQ29udGFpbmVyfSBjc3M9e3t2aWRlbzogYmFzZVZpZGVvU3R5bGV9fT5cbiAgICAgIDx2aWRlbyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIGpzeC1hMTF5L21lZGlhLWhhcy1jYXB0aW9uXG4gICAgICAgIHJlZj17bXVsdGlSZWYodmlkZW9SZWYsIHZpZGVvRWxlbWVudCl9XG4gICAgICAgIHBsYXlzSW5saW5lXG4gICAgICAgIHsuLi52aWRlb0F0dHJpYnV0ZXN9XG4gICAgICAvPlxuICAgIDwvZGl2PlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFZpZGVvXG4iXX0= */"),
7993
8196
  children: jsx$1("video", {
7994
8197
  // eslint-disable-line jsx-a11y/media-has-caption
7995
8198
  ref: multiRef(videoRef, videoElement),
@@ -8001,6 +8204,8 @@ const Video = ({
8001
8204
 
8002
8205
  var Video$1 = Video;
8003
8206
 
8207
+ /* eslint-disable no-param-reassign */
8208
+
8004
8209
  const getSpeedItems = items => items.map(value => ({
8005
8210
  label: `${value}x`,
8006
8211
  value
@@ -8044,17 +8249,57 @@ const getQualitySettings = (options, player) => {
8044
8249
  // With native HLS, manifest rewrite is required to enable quality setting
8045
8250
  // TODO let this covered by test, maybe refactor?
8046
8251
  const items = isSafari() && !options.rewriteManifest ? [] : options.items || getQualityItemsFromManifest(player);
8252
+
8253
+ const getDefault = (preferred = options.default || items[0].value) => {
8254
+ const maxHeight = preferred || items[0].value;
8255
+ return (nearest(items.filter(item => (item.height || item.value) <= maxHeight), item => (item.height || item.value) - maxHeight) || items[0]).value;
8256
+ };
8257
+
8047
8258
  return items.length > 0 && items[0] && {
8048
8259
  name: 'quality',
8049
8260
  title: 'KKS.QUALITY',
8050
8261
  items,
8051
- getDefault: (preferred = options.default || items[0].value) => {
8052
- const maxHeight = preferred || items[0].value;
8053
- return (nearest(items.filter(item => (item.height || item.value) <= maxHeight), item => (item.height || item.value) - maxHeight) || items[0]).value;
8054
- }
8262
+ getDefault
8055
8263
  };
8056
8264
  };
8057
8265
 
8266
+ const getAudioTracks = (_, {
8267
+ player
8268
+ }) => {
8269
+ if (!player) return []; // Bitmovin support is omitted as it is not needed in near future
8270
+
8271
+ const all = player.getVariantTracks().reduce((result, track) => {
8272
+ var _track$label;
8273
+
8274
+ const label = ((_track$label = track.label) === null || _track$label === void 0 ? void 0 : _track$label.trim()) || track.language;
8275
+ const id = `${track.language}:${label}`;
8276
+ result[id] = result[id] || { ...track,
8277
+ type: 'audio',
8278
+ label,
8279
+ value: {
8280
+ id,
8281
+ label,
8282
+ language: track.language
8283
+ }
8284
+ };
8285
+
8286
+ if (track.active) {
8287
+ result[id].selected = true;
8288
+ }
8289
+
8290
+ return result;
8291
+ }, {});
8292
+ const allTracks = Object.values(all);
8293
+ const namedTracks = allTracks.filter(track => !/^un/i.test(track.language || ''));
8294
+ return Object.values(namedTracks.length > 0 ? namedTracks : allTracks);
8295
+ };
8296
+
8297
+ const getCurrentAudioTrack = (media, {
8298
+ player
8299
+ }) => getAudioTracks(media, {
8300
+ player
8301
+ }).find(track => track.selected);
8302
+
8058
8303
  const getSelectedAudioName = player => {
8059
8304
  const track = getCurrentAudioTrack({}, {
8060
8305
  player
@@ -8116,8 +8361,6 @@ const shouldProvideSettingSection = ({
8116
8361
  player,
8117
8362
  loop
8118
8363
  }) => {
8119
- // TODO keep special section
8120
- // name === 'audio' || name === 'subtitles'
8121
8364
  if (name === 'loop') {
8122
8365
  return !(player !== null && player !== void 0 && player.isLive()) && loop !== 'disabled';
8123
8366
  }
@@ -8126,6 +8369,10 @@ const shouldProvideSettingSection = ({
8126
8369
  return !(player !== null && player !== void 0 && player.isLive());
8127
8370
  }
8128
8371
 
8372
+ if (name === 'subtitles' || name === 'audio') {
8373
+ return true;
8374
+ }
8375
+
8129
8376
  return (items === null || items === void 0 ? void 0 : items.length) > 1;
8130
8377
  };
8131
8378
 
@@ -8136,45 +8383,30 @@ const getSettingsData = ({
8136
8383
  quality = {},
8137
8384
  speedItems = [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2],
8138
8385
  loop,
8139
- preferred = {},
8140
- otherSections = []
8386
+ preferred = {}
8141
8387
  }) => {
8142
8388
  // TODO extract base player specific things
8143
8389
  const audioItems = getAudioTracks({}, {
8144
8390
  player
8145
- }).filter(track => track.language && track.language !== 'und').map(track => ({
8146
- label: track.label || track.language,
8147
- value: {
8148
- language: track.language,
8149
- label: track.label,
8150
- id: [track.language, track.label].join(':')
8151
- }
8152
- })) || [];
8391
+ });
8153
8392
  const selectedSource = getSource(source, {
8154
8393
  preferManifestType: 'platform'
8155
8394
  }) || {};
8156
8395
  const currentSpeedItems = getSpeedItems(speedItems);
8157
- const sections = [].concat(otherSections).concat([quality && getQualitySettings({ ...quality,
8396
+ const sections = [].concat([quality && getQualitySettings({ ...quality,
8158
8397
  items: selectedSource.qualityOptions
8159
8398
  }, player), {
8160
8399
  name: 'subtitles',
8161
8400
  title: 'KKS.SUBTITLES',
8162
- items: [...getTextTracks({}, {
8401
+ items: [].concat(getTextTracks({}, {
8163
8402
  player
8164
- }).map(track => ({
8165
- label: track.label || track.language,
8166
- value: {
8167
- language: track.language,
8168
- label: track.label,
8169
- id: [track.language, track.label].join(':')
8170
- }
8171
- })), {
8403
+ }), {
8172
8404
  label: 'OFF',
8173
8405
  value: {
8174
8406
  language: 'off',
8175
8407
  id: 'off'
8176
8408
  }
8177
- }]
8409
+ })
8178
8410
  }, {
8179
8411
  name: 'audio',
8180
8412
  title: 'KKS.AUDIO',
@@ -8226,6 +8458,30 @@ const getSettingsData = ({
8226
8458
  };
8227
8459
  };
8228
8460
 
8461
+ 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;
8462
+
8463
+ const getLanguageOptions = (player, info) => {
8464
+ const audioTracks = player && getAudioTracks({}, {
8465
+ player
8466
+ });
8467
+ const textTracks = getTextTracks({}, {
8468
+ player
8469
+ });
8470
+ const textOptions = [].concat(textTracks, {
8471
+ type: 'subtitles',
8472
+ label: 'OFF',
8473
+ selected: !textTracks.some(track => track.selected),
8474
+ value: {
8475
+ language: 'off',
8476
+ id: 'off'
8477
+ }
8478
+ });
8479
+ return {
8480
+ audioTracks: matchTracks(audioTracks, info.audioTracks),
8481
+ textTracks: matchTracks(textOptions, info.textTracks)
8482
+ };
8483
+ };
8484
+
8229
8485
  const parseVTT = data => {
8230
8486
  const lines = data.split(/\n\n/g).slice(1); // may replace with async parser to prevent blocking render
8231
8487
 
@@ -8342,11 +8598,11 @@ const SeekPreview = ({
8342
8598
 
8343
8599
  if (thumbnailsUrl) {
8344
8600
  // TODO replace with fetch
8345
- fetch(thumbnailsUrl).then(response => response.text()).then(data => {
8601
+ fetch(thumbnailsUrl).then(response => response.text()).then(data => parseThumbnails(data, thumbnailsUrl)).then(parsed => {
8346
8602
  if (!cancel) {
8347
- setThumbnails(parseThumbnails(data, thumbnailsUrl));
8603
+ setThumbnails(parsed);
8348
8604
  }
8349
- });
8605
+ }).catch(error => console.debug('Thumbnail', error));
8350
8606
  }
8351
8607
 
8352
8608
  return () => {
@@ -8403,7 +8659,40 @@ const defaultSettings = {};
8403
8659
  const shouldPause = ({
8404
8660
  userFocus,
8405
8661
  uiType
8406
- }) => uiType === 'mobile' && /settings|chapter-list/.test(userFocus) || /blocking|seekbar|share-inner/.test(userFocus);
8662
+ }) => uiType === 'mobile' && /settings|chapter-list/.test(userFocus) || /blocking|seekbar|share-inner/.test(userFocus); // TODO extract to somewhere else
8663
+
8664
+
8665
+ const menuClasses = {
8666
+ default: /*#__PURE__*/css$1(LanguageMenu.styles, process.env.NODE_ENV === "production" ? "" : ";label:default;", process.env.NODE_ENV === "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"]} */"),
8667
+ desktop: /*#__PURE__*/css$1(LanguageMenu.styles, LanguageMenu.desktopStyles, process.env.NODE_ENV === "production" ? "" : ";label:desktop;", process.env.NODE_ENV === "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"]} */")
8668
+ };
8669
+
8670
+ const LanguageSettings = ({
8671
+ uiType,
8672
+ audioTracks = [],
8673
+ subtitleTracks = [],
8674
+ getPlayer,
8675
+ onChange,
8676
+ slots = {
8677
+ LanguageMenu
8678
+ },
8679
+ ...rest
8680
+ }) => {
8681
+ const options = getLanguageOptions(getPlayer(), {
8682
+ audioTracks,
8683
+ subtitleTracks
8684
+ });
8685
+ return /*#__PURE__*/jsx(OverlayPanel, {
8686
+ buttonIcon: "subtitle",
8687
+ children: /*#__PURE__*/jsx(slots.LanguageMenu, {
8688
+ uiType: uiType,
8689
+ classes: menuClasses,
8690
+ sectionOptions: [options.audioTracks, options.textTracks],
8691
+ onChange: onChange,
8692
+ ...rest
8693
+ })
8694
+ });
8695
+ };
8407
8696
 
8408
8697
  const PremiumPlayer = ({
8409
8698
  source,
@@ -8570,8 +8859,7 @@ const PremiumPlayer = ({
8570
8859
  quality,
8571
8860
  speedItems,
8572
8861
  loop,
8573
- preferred: current.preferred,
8574
- otherSections: appSettings.sections
8862
+ preferred: current.preferred
8575
8863
  });
8576
8864
  return {
8577
8865
  preferred: current.preferred,
@@ -8887,7 +9175,7 @@ const PremiumPlayer = ({
8887
9175
  muted: appVolume <= 0
8888
9176
  }),
8889
9177
  playbackRate: settings.values.speed,
8890
- quality: qualityOptions,
9178
+ videoResolution: qualityOptions,
8891
9179
  audio: settings.values.audio,
8892
9180
  textTrack: settings.values.subtitles,
8893
9181
  loop: settings.values.loop,
@@ -8949,6 +9237,11 @@ const PremiumPlayer = ({
8949
9237
  onChange: uiHandlers.onChangeSettings,
8950
9238
  ...(slotProps === null || slotProps === void 0 ? void 0 : slotProps.settings),
8951
9239
  onClose: uiHandlers.onCloseSettings
9240
+ }), /*#__PURE__*/jsx(LanguageSettings, {
9241
+ uiType: uiType,
9242
+ getPlayer: () => playerRef.current,
9243
+ onChange: (_event, item) => changeSettings(item.type, item.value),
9244
+ ...slotProps.languageSettings
8952
9245
  }), /*#__PURE__*/jsx(Backdrop, {
8953
9246
  open: !playbackState || playbackState === 'loading',
8954
9247
  children: /*#__PURE__*/jsx(LoadingSpinner, {})
@@ -10171,43 +10464,16 @@ const preload = (cache, playbackApi, preloadList) => preloadList.reduce(async (l
10171
10464
  });
10172
10465
  }, Promise.resolve());
10173
10466
 
10174
- const getSourceTypeSettings = (sources = [], initialType = '') => {
10175
- const data = sources.reduce((options, source) => {
10176
- const value = source.subdub || source.type || ''; // take only first for every version/type
10177
-
10178
- if (!(value in options)) {
10179
- // eslint-disable-next-line no-param-reassign
10180
- options[value] = value.toUpperCase();
10181
- }
10182
-
10183
- return options;
10184
- }, {});
10185
- const items = Object.entries(data).map(([value, label]) => ({
10186
- value,
10187
- label
10188
- }));
10189
-
10190
- const getDefault = (preferred = initialType) => (items.find(item => item.value === preferred) || items[0] || {}).value;
10191
-
10192
- return items.length > 1 && {
10193
- name: 'source-type',
10194
- title: 'KKS.SETTING.VERSION',
10195
- items,
10196
- getDefault
10197
- };
10198
- };
10199
-
10200
10467
  /* eslint-disable no-param-reassign */
10201
-
10202
10468
  const waitMs = time => new Promise(resolve => {
10203
10469
  setTimeout(resolve, time);
10204
10470
  });
10205
10471
 
10206
- const handleRequestError = (result, {
10472
+ const handleRequestError = (request, {
10207
10473
  onError,
10208
10474
  retryTimes = 0
10209
- }) => result.catch(error => onError(error, {
10210
- retry: () => handleRequestError(axios(error.config), {
10475
+ }) => request().catch(error => onError(error, {
10476
+ retry: () => handleRequestError(request, {
10211
10477
  onError,
10212
10478
  retryTimes: retryTimes + 1
10213
10479
  }),
@@ -10262,28 +10528,26 @@ const createApi = (config, {
10262
10528
 
10263
10529
  const request = (url, {
10264
10530
  method
10265
- } = {}) => handleRequestError(axios(url, {
10531
+ } = {}) => handleRequestError(() => fetch(`${url}?${new URLSearchParams(params).toString()}`, {
10266
10532
  method,
10267
- headers: getHeaders(),
10268
- params
10269
- }), {
10533
+ headers: getHeaders()
10534
+ }).then(response => response.json()), {
10270
10535
  onError
10271
- }).then(response => response.data);
10536
+ });
10272
10537
 
10273
10538
  const sessionRequest = (path, {
10274
10539
  method = 'POST',
10275
10540
  type,
10276
10541
  id,
10277
10542
  token
10278
- }) => handleRequestError(axios(`${host}/sessions/${type}/${id}/playback/${deviceId}/${path}`, {
10543
+ }) => handleRequestError(() => fetch(`${host}/sessions/${type}/${id}/playback/${deviceId}/${path}?${new URLSearchParams({ ...params,
10544
+ playback_token: token
10545
+ }).toString()}`, {
10279
10546
  method,
10280
- headers: getHeaders(),
10281
- params: { ...params,
10282
- playback_token: token
10283
- }
10284
- }), {
10547
+ headers: getHeaders()
10548
+ }).then(response => response.json()), {
10285
10549
  onError
10286
- }).then(response => response === null || response === void 0 ? void 0 : response.data);
10550
+ });
10287
10551
 
10288
10552
  return {
10289
10553
  config,
@@ -10815,7 +11079,7 @@ const PremiumPlusPlayer = ({
10815
11079
  playbackState: appPlaybackState,
10816
11080
  ...rest
10817
11081
  }) => {
10818
- var _videoRef$current;
11082
+ var _playbackInfo$sources, _playbackInfo$sources2, _videoRef$current;
10819
11083
 
10820
11084
  const videoRef = useRef();
10821
11085
  const corePlayerRef = useRef();
@@ -10891,7 +11155,7 @@ const PremiumPlusPlayer = ({
10891
11155
  const restPlayerName = ['shaka', 'bitmovin'].find(name => name in rest);
10892
11156
  logTarget.current = mapLogEvents({
10893
11157
  playerName: restPlayerName || 'shaka',
10894
- version: "2.25.0-canary.1",
11158
+ version: "2.25.0-canary.2",
10895
11159
  video: videoRef.current,
10896
11160
  getPlaybackStatus: () => getMediaTime(videoRef.current, {
10897
11161
  player: corePlayerRef.current,
@@ -11004,6 +11268,14 @@ const PremiumPlusPlayer = ({
11004
11268
  useEffect(() => setupLicenseServerOverride(), []);
11005
11269
  const [sourceType, setSourceType] = useState(appSourceType);
11006
11270
  useEffect(() => setSourceType(appSourceType), [appSourceType]);
11271
+
11272
+ const handleSourceTypeChange = (name, value) => {
11273
+ if (name === 'source-type') {
11274
+ onSourceTypeChange === null || onSourceTypeChange === void 0 ? void 0 : onSourceTypeChange(value);
11275
+ setSourceType(value);
11276
+ }
11277
+ };
11278
+
11007
11279
  const source = useMemo(() => !contentData.end && getStreamInfo(playbackInfo.sources, {
11008
11280
  type: sourceType,
11009
11281
  licenseUri: playbackInfo.drmPortalUrl,
@@ -11029,13 +11301,11 @@ const PremiumPlusPlayer = ({
11029
11301
  apiConfig: api.config,
11030
11302
  sourceType
11031
11303
  }), [contentId, contentType, api.config, sourceType]);
11032
- const settings = useMemo(() => ({
11033
- sections: [getSourceTypeSettings(playbackInfo.sources, appSourceType)],
11034
- ...(contentType === 'lives' && {
11304
+ const settings = useMemo(() => ({ ...(contentType === 'lives' && {
11035
11305
  speedItems: []
11036
11306
  }),
11037
11307
  ...appSettings
11038
- }), [contentType, appSourceType, appSettings, playbackInfo.sources]);
11308
+ }), [contentType, appSettings]);
11039
11309
  return jsxs(PremiumPlayer, {
11040
11310
  source: playbackState !== 'error' && source,
11041
11311
  currentTime: preferAppTime.current ? currentTime : contentData.startTime,
@@ -11085,15 +11355,6 @@ const PremiumPlusPlayer = ({
11085
11355
  },
11086
11356
  onChangeNext: contentData.next && (() => onChange === null || onChange === void 0 ? void 0 : onChange(contentData.next)),
11087
11357
  onChangePrevious: contentData.previous && (() => onChange === null || onChange === void 0 ? void 0 : onChange(contentData.previous)),
11088
- onChangeSettings: ({
11089
- name,
11090
- value
11091
- }) => {
11092
- if (name === 'source-type') {
11093
- onSourceTypeChange === null || onSourceTypeChange === void 0 ? void 0 : onSourceTypeChange(value);
11094
- setSourceType(value);
11095
- }
11096
- },
11097
11358
  uiElements: { ...uiElements,
11098
11359
  ...(uiState.ad.total > 0 && getAdUi(uiState.ad, plugins, videoRef.current))
11099
11360
  },
@@ -11109,12 +11370,22 @@ const PremiumPlusPlayer = ({
11109
11370
  seekbar: {
11110
11371
  timeDisplay: true
11111
11372
  },
11112
- settings: !isDesktop() && {
11113
- buttonPosition: 'top-right',
11114
- closeBy: 'button',
11115
- slots: {
11116
- root: ClassicSettingsContainer
11117
- }
11373
+ settings: {
11374
+ enabledSettingSections: {
11375
+ quality: true,
11376
+ speed: true
11377
+ },
11378
+ ...(!isDesktop() && {
11379
+ buttonPosition: 'top-right',
11380
+ closeBy: 'button',
11381
+ slots: {
11382
+ root: ClassicSettingsContainer
11383
+ }
11384
+ })
11385
+ },
11386
+ languageSettings: ((_playbackInfo$sources = playbackInfo.sources) === null || _playbackInfo$sources === void 0 ? void 0 : _playbackInfo$sources.length) === 2 && {
11387
+ value: sourceType || ((_playbackInfo$sources2 = playbackInfo.sources[0]) === null || _playbackInfo$sources2 === void 0 ? void 0 : _playbackInfo$sources2.type),
11388
+ onChange: handleSourceTypeChange
11118
11389
  }
11119
11390
  },
11120
11391
  playbackState: targetPlaybackState,
@@ -12084,4 +12355,4 @@ const CastSessionControl = props => {
12084
12355
  });
12085
12356
  };
12086
12357
 
12087
- export { Addons, AutoplayPrompt, Backdrop, Button, CastButton$1 as CastButton, CastSender, CastSessionControl, ClassicSettingsContainer, CoverImage, DEBUG_OPTIONS, FunctionBarExtension, InfoBarExtension, LiveEnd, PremiumPlayer, PremiumPlusPlayer, RecommendationPanel, SkipButton, TitleBarExtension, Video$1 as Video, setupDebugOption, setupLicenseServerOverride };
12358
+ export { Addons, AutoplayPrompt, Backdrop, Button, CastButton$1 as CastButton, CastSender, CastSessionControl, ClassicSettingsContainer, CoverImage, DEBUG_OPTIONS, FunctionBarExtension, InfoBarExtension, LiveEnd, MenuItem, PremiumPlayer, PremiumPlusPlayer, RecommendationPanel, SkipButton, TitleBarExtension, Video$1 as Video, setupDebugOption, setupLicenseServerOverride };