@kkcompany/player 2.9.444 → 2.25.0-canary.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  import _defineProperty from '@babel/runtime/helpers/defineProperty';
2
- import React, { useState, useRef, useEffect, useContext, cloneElement, createContext, useReducer, useMemo, useCallback, useLayoutEffect, forwardRef } from 'react';
2
+ import React, { useRef, useState, useEffect, useContext, cloneElement, createContext, useReducer, useMemo, useCallback, useLayoutEffect } from 'react';
3
3
  import ReactDom, { createPortal } from 'react-dom';
4
4
  import mitt from 'mitt';
5
5
  import UAParser from 'ua-parser-js';
@@ -7,11 +7,10 @@ import useDimensions from 'react-cool-dimensions';
7
7
  import { ResizeObserver as ResizeObserver$1 } from '@juggle/resize-observer';
8
8
  import require$$0 from 'react-is';
9
9
  import { jsx, jsxs as jsxs$1, Fragment as Fragment$1 } from 'react/jsx-runtime';
10
- import { css, ClassNames, keyframes } from '@emotion/react';
10
+ import { css, keyframes } from '@emotion/react';
11
11
  import { jsx as jsx$1, jsxs, Fragment } from '@emotion/react/jsx-runtime';
12
12
  import useOnclickOutside from 'react-cool-onclickoutside';
13
13
  import { keyframes as keyframes$1 } from '@emotion/css';
14
- import axios from 'axios';
15
14
  import { selectHlsQualities } from 'playcraft/modules';
16
15
  import { CastSender } from 'playcraft/react';
17
16
 
@@ -55,10 +54,6 @@ const LanguageCode$1 = {
55
54
  JA: 'ja',
56
55
  ZHTW: 'zh-TW'
57
56
  };
58
- const SeekOrigin = {
59
- START: 'START',
60
- CURRENT: 'CURRENT'
61
- };
62
57
  const CastState = {
63
58
  NO_DEVICES_AVAILABLE: 'NO_DEVICES_AVAILABLE',
64
59
  CONNECTED: 'CONNECTED',
@@ -81,31 +76,15 @@ function getDevice() {
81
76
  if (device.type === undefined && osName === 'Android') device.type = 'tablet';
82
77
  return device;
83
78
  }
84
- function getBrowser() {
85
- return parser.getBrowser();
86
- }
79
+
80
+ const isSafari = () => /^((?!chrome|android|X11|Linux).)*(safari|iPad|iPhone|Version)/i.test(navigator.userAgent);
81
+
87
82
  function needNativeHls() {
88
83
  // Don't let Android phones play HLS, even if some of them report supported
89
84
  // This covers Samsung & OPPO special cases
90
- const isAndroid = /android|X11|Linux/i.test(navigator.userAgent); // canPlayType isn't reliable across all iOS verion / device combinations, so also check user agent
91
-
92
- const isSafari = /^((?!chrome|android|X11|Linux).)*(safari|iPad|iPhone|Version)/i.test(navigator.userAgent); // ref: https://stackoverflow.com/a/12905122/4578017
93
- // none of our supported browsers other than Safari response to this
94
-
95
- const isFirefox = /firefox/i.test(navigator.userAgent);
96
- const isEdge = /edg/i.test(navigator.userAgent);
97
- const isChrome = /chrome/i.test(navigator.userAgent) && !isEdge; // ref: https://stackoverflow.com/a/12905122/4578017
98
- // none of our supported browsers other than Safari response to this
99
-
100
- if (isAndroid || isFirefox || isEdge || isChrome) {
101
- return "";
102
- }
103
-
104
- if (isSafari) {
105
- return 'maybe';
106
- }
107
-
108
- return document.createElement('video').canPlayType('application/vnd.apple.mpegURL');
85
+ const isAndroid = /android|X11|Linux/i.test(navigator.userAgent);
86
+ return isAndroid || /firefox/i.test(navigator.userAgent) ? '' : // canPlayType isn't reliable across all iOS verion / device combinations, so also check user agent
87
+ isSafari() ? 'maybe' : document.createElement('video').canPlayType('application/vnd.apple.mpegURL');
109
88
  }
110
89
 
111
90
  const isDesktop = () => !getDevice().type; // TODO solve lint error:
@@ -195,7 +174,7 @@ const getDrmOptions$1 = fallbackDrm => {
195
174
  * @typedef {{hls: string, dash: string}} SourceObjectAlt backward compatiable form
196
175
  *
197
176
  * @param {SourceObject[]|SourceObject|SourceObjectAlt|string} sourceOptions
198
- * @param {{preferManifestType?: ('dash'|'hls')}} options
177
+ * @param {{preferManifestType?: ('dash'|'hls'|'platform')}} options
199
178
  * @return {{src: string, type: string, drm: Object}}
200
179
  */
201
180
 
@@ -238,7 +217,8 @@ const getSource = (sourceOptions, {
238
217
  });
239
218
  }
240
219
 
241
- const matched = sourceOptions.find(source => !preferManifestType || matchType(source, preferManifestType));
220
+ const targetType = preferManifestType !== 'platform' ? preferManifestType : isSafari() ? 'hls' : 'dash';
221
+ const matched = sourceOptions.find(source => matchType(source, targetType));
242
222
  const selected = matched || sourceOptions[0];
243
223
 
244
224
  if (!selected) {
@@ -315,7 +295,7 @@ function convertToSeconds(timeString) {
315
295
  function getVersion() {
316
296
  try {
317
297
  // eslint-disable-next-line no-undef
318
- return "2.9.444";
298
+ return "2.25.0-canary.1";
319
299
  } catch (e) {
320
300
  return undefined;
321
301
  }
@@ -569,7 +549,7 @@ const tryPatchHlsVideoQualities = async (player, hlsUrl) => {
569
549
  }
570
550
  };
571
551
 
572
- const seek$1 = async (media, {
552
+ const seek = async (media, {
573
553
  player,
574
554
  plugins = []
575
555
  }, time, issuer) => {
@@ -624,9 +604,8 @@ const load = async (media, {
624
604
  startTime,
625
605
  plugins = []
626
606
  }, source) => {
627
- const preferManifestType = needNativeHls() ? 'hls' : 'dash';
628
607
  const preferred = getSource(source, {
629
- preferManifestType
608
+ preferManifestType: 'platform'
630
609
  }); // There's no use case that changing DRM options without changing manifest URL, just skip
631
610
 
632
611
  if (player.lastSrc === (preferred === null || preferred === void 0 ? void 0 : preferred.src)) {
@@ -646,7 +625,7 @@ const load = async (media, {
646
625
  player,
647
626
  source: currentSource,
648
627
  startTime,
649
- streamFormat: preferManifestType,
628
+ streamFormat: source.type,
650
629
  reload: async () => {
651
630
  // Bitmovin unexpectedly restores muted state, so save to restore
652
631
  const restoreMuted = player.isMuted && {
@@ -685,7 +664,7 @@ const load = async (media, {
685
664
  const seekToStart = (delay = 1) => {
686
665
  if (merged.startTime > 0 || merged.startTime < 0) {
687
666
  // Safari may glitch if seek immediately, so wait a little bit
688
- setTimeout(() => seek$1(media, {
667
+ setTimeout(() => seek(media, {
689
668
  player,
690
669
  plugins
691
670
  }, merged.startTime), delay);
@@ -802,7 +781,7 @@ const syncPlaybackState = async (media, {
802
781
  await waitMediaReady(media);
803
782
 
804
783
  if (isEnded(media)) {
805
- seek$1(media, {
784
+ seek(media, {
806
785
  player
807
786
  }, 0);
808
787
  }
@@ -820,7 +799,7 @@ const syncPlaybackState = async (media, {
820
799
  });
821
800
 
822
801
  if (streamType === 'live' && (liveResume || player.shouldPlayFromEdge || duration === 0) && currentTime < 0) {
823
- seek$1(media, {
802
+ seek(media, {
824
803
  player
825
804
  }, 0); // resume to latest for non-start-over live, or paused at live edge
826
805
  }
@@ -1152,33 +1131,6 @@ const multiRef = (...refs) => element => {
1152
1131
  }
1153
1132
  };
1154
1133
 
1155
- /*
1156
- Rules:
1157
- 1 Set `true` immediately in first time (For loadstart event)
1158
- 2. Set `true` to waiting lazily but update waiting to `false` immediately
1159
- */
1160
-
1161
- const useLazyWaiting = waiting => {
1162
- const [first, setFirst] = useState(true);
1163
- const [state, dispatch] = useState(waiting);
1164
- const timer = useRef();
1165
- useEffect(() => {
1166
- clearTimeout(timer.current);
1167
-
1168
- if (waiting && !first) {
1169
- timer.current = setTimeout(() => {
1170
- dispatch(waiting);
1171
- }, 1000);
1172
- } else {
1173
- dispatch(waiting);
1174
- setFirst(false);
1175
- }
1176
-
1177
- return () => clearTimeout(timer.current);
1178
- }, [waiting]);
1179
- return state;
1180
- };
1181
-
1182
1134
  const useAutoHide = ({
1183
1135
  hideTimeMs = 3000,
1184
1136
  pinned,
@@ -2599,6 +2551,7 @@ const Icon = ({
2599
2551
  Icon.propTypes = {
2600
2552
  type: PropTypes.string
2601
2553
  };
2554
+ var Icon$1 = Icon;
2602
2555
 
2603
2556
  /* eslint-disable jsx-a11y/no-static-element-interactions */
2604
2557
 
@@ -2649,7 +2602,7 @@ const Backdrop = ({
2649
2602
  });
2650
2603
 
2651
2604
  /* eslint-disable react/prop-types */
2652
- const styles$3 = {
2605
+ const styles$1 = {
2653
2606
  // TODO keep only necessary
2654
2607
  border: 'none',
2655
2608
  outline: 'none',
@@ -2772,9 +2725,9 @@ const Button = ({
2772
2725
  disabled: rest.disabled,
2773
2726
  children: jsxs("button", {
2774
2727
  type: "button",
2775
- css: [styles$3, variants[variant], style, process.env.NODE_ENV === "production" ? "" : ";label:Button;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["buttons.js"],"names":[],"mappings":"AA8IM","file":"buttons.js","sourcesContent":["/* eslint-disable react/prop-types */\n/* @jsxImportSource @emotion/react */\nimport {useState, useEffect, useRef, cloneElement} from 'react'\nimport {createPortal} from 'react-dom'\nimport PropTypes from 'prop-types'\n\nimport {getPopoverPosition} from 'util/index'\nimport {getTopElement} from 'util/viewModes'\nimport {havePointer, isDesktop} from 'util/environment'\nimport {FormattedMessage, useIntl} from 'context/I18n'\nimport Icon from './Icon'\n\nconst styles = {\n  // TODO keep only necessary\n  border: 'none',\n  outline: 'none',\n  cursor: 'pointer',\n  padding: 0,\n  flexShrink: 0,\n  backgroundColor: 'transparent',\n  userSelect: 'none',\n  '> span': {\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst variants = {\n  outlined: {\n    width: '8em',\n    height: '2em',\n    border: '1px solid #fff',\n    borderRadius: '4px',\n    background: 'none',\n    color: 'inherit',\n    opacity: 0.8,\n  },\n  text: {color: 'var(--theme-color)'},\n  contained: {color: '#fff', backgroundColor: 'var(--theme-color)'},\n}\n\nconst tooltipStyle = {\n  zIndex: 7,\n  position: 'fixed',\n  padding: '0.5rem',\n  width: 'fit-content',\n  textAlign: 'center',\n  whiteSpace: 'nowrap',\n  color: 'white',\n  background: 'var(--panel-background, #161C24)',\n}\n\nconst isOverflowing = element => element.scrollWidth > element.clientWidth\n\nconst Tooltip = ({\n  title,\n  placement,\n  overflowOnly,\n  disabled,\n  children,\n  container,\n}) => {\n  const tooltipRef = useRef()\n  const boxes = useRef()\n  const defaultContainer = useRef()\n  const [open, setOpen] = useState(false)\n  const [position, setPosition] = useState(() => ({left: '100%'}))\n  const shiftDistance = placement === 'top' ? '-4.5em' : '2em'\n  const handleLeave = () => {\n    setPosition({left: '100%'})\n    setOpen(false)\n  }\n\n  const childProps = {\n    onMouseEnter: event => {\n      if (!overflowOnly || isOverflowing(event.currentTarget)) {\n        boxes.current = [\n          event.currentTarget.getBoundingClientRect(),\n          document.body.getBoundingClientRect(),\n        ]\n        defaultContainer.current = getTopElement()\n        setOpen(true)\n      }\n    },\n    onMouseLeave: handleLeave,\n    onTransitionEnd: event => {\n      if (window.getComputedStyle(event.target).getPropertyValue(\"opacity\") < 0.1) {\n        handleLeave()\n      } \n    }\n  }\n  useEffect(() => {\n    if (disabled) {\n      setOpen(false)\n    }\n  }, [disabled])\n\n  useEffect(() => {\n    if (open) {\n      const targetPosition = getPopoverPosition(\n        tooltipRef.current.getBoundingClientRect(),\n        ...boxes.current\n      )\n      targetPosition.left !== position.left && setPosition(targetPosition)\n    }\n  }, [open, position.left])\n\n  return !title || !isDesktop() || !havePointer() ? (\n    children\n  ) : (\n    <>\n      {cloneElement(children, childProps)}\n      {open &&\n        createPortal(\n          <div\n            style={{\n              ...tooltipStyle,\n              ...position,\n              top: `calc(${position.top}px - ${shiftDistance})`,\n            }}\n            ref={tooltipRef}\n          >\n            <FormattedMessage id={title} />\n          </div>,\n          container || defaultContainer.current\n        )}\n    </>\n  )\n}\n\nconst Button = ({\n  startIcon,\n  variant,\n  style,\n  title,\n  children,\n  placement = 'bottom',\n  ...rest\n}) => (\n  <Tooltip title={title} placement={placement} disabled={rest.disabled}>\n    <button\n      type=\"button\"\n      css={[styles, variants[variant], style]}\n      {...rest}\n    >\n      {typeof startIcon === 'string' ? <Icon type={startIcon} /> : startIcon}\n      {children}\n    </button>\n  </Tooltip>\n)\n\nButton.propTypes = {\n  startIcon: PropTypes.node,\n  children: PropTypes.node,\n}\n\nconst liveButtonStyle = {\n  '--spacing': 'calc(0.75em + 0.5rem)',\n  margin: '0 0.5rem',\n  height: '3em',\n  border: 'solid 1px',\n  borderRadius: '4px',\n  color: '#FFF',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '0.5em !important',\n  svg: {\n    marginRight: '0.5em',\n    width: '1.5em',\n    height: '1em',\n    color: '#E93817',\n  },\n}\n\nconst startOverStyle = {svg: {color: '#BDBDBD'}}\n\nconst LiveIcon = () => (\n  <svg\n    width=\"24\"\n    height=\"16\"\n    viewBox=\"0 0 24 16\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n  >\n    <path\n      fill=\"currentColor\"\n      d=\"M3.50071 0.00164345C3.20221 0.0180071 2.90947 0.156604 2.70384 0.408604C1.01511 2.47697 0 5.11508 0 7.98744C0 10.8598 1.01511 13.4979 2.70384 15.5663C3.1162 16.0703 3.87344 16.1161 4.33381 15.6558C4.72544 15.2641 4.76392 14.6388 4.41264 14.2112C3.01955 12.5148 2.18182 10.3471 2.18182 7.98744C2.18182 5.6278 3.01955 3.46112 4.41264 1.76585C4.76392 1.33821 4.72544 0.712882 4.33381 0.321246C4.10363 0.0910639 3.79921 -0.0147202 3.50071 0.00164345ZM20.4993 0.00164345C20.2008 -0.0147202 19.8964 0.0910639 19.6662 0.321246C19.2746 0.712882 19.2361 1.33821 19.5874 1.76585C20.9804 3.46112 21.8182 5.6278 21.8182 7.98744C21.8182 10.3471 20.9804 12.5138 19.5874 14.209C19.2361 14.6367 19.2746 15.262 19.6662 15.6536C20.1266 16.114 20.8849 16.0714 21.2962 15.5663C22.9849 13.499 24 10.8598 24 7.98744C24 5.11508 22.9849 2.47697 21.2962 0.408604C21.0905 0.156604 20.7978 0.0180071 20.4993 0.00164345ZM6.59233 3.10392C6.28974 3.12083 5.99652 3.26174 5.80398 3.52792C4.89852 4.78356 4.36364 6.32489 4.36364 7.98744C4.36364 9.64998 4.89852 11.1913 5.80398 12.447C6.18907 12.9793 6.97348 13.014 7.43821 12.5492L7.44247 12.545C7.82538 12.1621 7.85357 11.5678 7.54048 11.1259C6.9143 10.2379 6.54545 9.15471 6.54545 7.98744C6.54545 6.82017 6.9143 5.73694 7.54048 4.84894C7.85248 4.40604 7.82538 3.81282 7.44247 3.42991L7.43821 3.42565C7.20585 3.19329 6.89492 3.08701 6.59233 3.10392ZM17.4077 3.10392C17.1051 3.08701 16.7942 3.19329 16.5618 3.42565L16.5575 3.42991C16.1746 3.81282 16.1464 4.40713 16.4595 4.84894C17.0857 5.73694 17.4545 6.82017 17.4545 7.98744C17.4545 9.15471 17.0857 10.2379 16.4595 11.1259C16.1475 11.5688 16.1746 12.1621 16.5575 12.545L16.5618 12.5492C17.0265 13.014 17.812 12.9793 18.196 12.447C19.1026 11.1924 19.6364 9.64998 19.6364 7.98744C19.6364 6.32489 19.1015 4.78356 18.196 3.52792C18.0035 3.26174 17.7103 3.12083 17.4077 3.10392ZM12 4.71471C11.132 4.71471 10.2996 5.05952 9.68583 5.67327C9.07208 6.28703 8.72727 7.11946 8.72727 7.98744C8.72727 8.85542 9.07208 9.68785 9.68583 10.3016C10.2996 10.9154 11.132 11.2602 12 11.2602C12.868 11.2602 13.7004 10.9154 14.3142 10.3016C14.9279 9.68785 15.2727 8.85542 15.2727 7.98744C15.2727 7.11946 14.9279 6.28703 14.3142 5.67327C13.7004 5.05952 12.868 4.71471 12 4.71471Z\"\n    />\n  </svg>\n)\n\nconst LiveButton = ({usingStartOver, ...rest}) => (\n  <Button\n    css={[liveButtonStyle, usingStartOver && startOverStyle]}\n    startIcon={<LiveIcon />}\n    {...rest}\n  >\n    <FormattedMessage id=\"LIVE\" />\n  </Button>\n)\n\nconst PlayButton = ({\n  playbackState,\n  ended,\n  hidden,\n  variant,\n  onClick,\n  ...rest\n}) => (\n  <Button\n    style={hidden && {opacity: 0}}\n    className=\"play-button\"\n    startIcon={\n      variant ||\n      (ended ? 'replay' : playbackState === 'playing' ? 'pause' : 'play')\n    }\n    title={`KKS.PLAYER.${\n      ended ? 'REPLAY' : playbackState === 'playing' ? 'PAUSE' : 'PLAY'\n    }`}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nPlayButton.propTypes = {\n  ended: PropTypes.bool,\n  onClick: PropTypes.func,\n}\n\nconst ForwardButton = ({startIcon, title, onClick, ...rest}) => (\n  <Button\n    style={rest.disabled && {opacity: 0.2, display: 'block'}}\n    startIcon={startIcon}\n    title={title}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nForwardButton.propTypes = {\n  onClick: PropTypes.func,\n}\n\nconst FullscreenButton = ({viewMode, onClick}) => {\n  const icon = viewMode === 'fullscreen' ? 'exit-fullscreen' : 'fullscreen'\n  const text = useIntl().formatMessage(\n    viewMode === 'fullscreen'\n      ? 'KKS.PLAYER.FULLSCREEN.EXIT'\n      : 'KKS.PLAYER.FULLSCREEN'\n  )\n\n  return (\n    <Button\n      startIcon={icon}\n      title={text}\n      style={!isDesktop() && {order: 'var(--fullscreen-button-order, initial)'}}\n      onClick={onClick}\n    />\n  )\n}\n\nconst skipStyles = {\n  display: 'flex',\n  alignItems: 'center',\n  padding: '0.5rem',\n  border: '1px solid #fff',\n  color: '#fff',\n  background: 'rgba(0, 0, 0, 0.4)',\n  fontSize: '24px',\n  opacity: 0.8,\n  '&:disabled': {\n    opacity: 0.5,\n  },\n  '> div': {\n    marginLeft: '0.5rem',\n    width: '1.5rem',\n    height: '1.5rem',\n  },\n}\n\nconst SkipButton = ({waitTime, onClick}) => (\n  <button\n    type=\"button\"\n    css={skipStyles}\n    disabled={waitTime > 0}\n    onClick={onClick}\n  >\n    {waitTime > 0 ? (\n      <>\n        {Math.ceil(waitTime)} <FormattedMessage id=\"KKS.SSAI.SECONDS\" />\n      </>\n    ) : (\n      <FormattedMessage id=\"KKS.SSAI.SKIP.AD\" />\n    )}\n    <Icon type=\"nextEpisode\" />\n  </button>\n)\n\nconst ShareButton = ({title, onClick}) => (\n  <Button\n    startIcon=\"share\"\n    title=\"KKS.PLAYER.SHARE\"\n    onClick={async () => {\n      if (isDesktop()) {\n        // TODO: use customize UI\n        console.log('hi')\n        return\n      }\n\n      onClick()\n      if (navigator.share) {\n        try {\n          await navigator.share({\n            title,\n            url: window.location.href,\n          })\n        } catch (error) {\n          console.error(error)\n        }\n      }\n    }}\n  />\n)\n\nconst switchStyle = {\n  padding: '0 0.2rem',\n  width: '2.4rem',\n  height: '1.2rem',\n  display: 'flex',\n  alignItems: 'center',\n  background: '#555',\n  borderRadius: '1rem',\n  transition: 'background 0.5s ease-in-out',\n}\n\nconst checkedStyle = {\n  background: 'var(--theme-color, #0E78F4)',\n  '> div': {\n    transform: 'translateX(1rem)',\n  },\n}\n\nconst thumbStyle = {\n  width: '1rem',\n  height: '1rem',\n  display: 'flex',\n  background: '#F9FAFB',\n  borderRadius: '1rem',\n  transition: 'transform 0.2s ease-in-out',\n}\n\nconst Switch = ({checked, ...rest}) => (\n  <div css={[switchStyle, checked && checkedStyle]} {...rest}>\n    <div css={thumbStyle} />\n  </div>\n)\n\nconst Close = ({...rest}) => <Button startIcon=\"close\" {...rest} />\n\nconst btnStyle = {\n  width: '4em',\n  height: '2em',\n  borderRadius: '8px',\n}\n\nconst Copy = ({...rest}) => (\n  <Button style={btnStyle} {...rest}>\n    Copy\n  </Button>\n)\n\nexport {\n  Button,\n  PlayButton,\n  FullscreenButton,\n  SkipButton,\n  ShareButton,\n  ForwardButton,\n  LiveButton,\n  Switch,\n  Close,\n  Copy\n}\n"]} */"],
2728
+ css: [styles$1, variants[variant], style, process.env.NODE_ENV === "production" ? "" : ";label:Button;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["buttons.js"],"names":[],"mappings":"AA8IM","file":"buttons.js","sourcesContent":["/* eslint-disable react/prop-types */\n/* @jsxImportSource @emotion/react */\nimport {useState, useEffect, useRef, cloneElement} from 'react'\nimport {createPortal} from 'react-dom'\nimport PropTypes from 'prop-types'\n\nimport {getPopoverPosition} from 'util/index'\nimport {getTopElement} from 'util/viewModes'\nimport {havePointer, isDesktop} from 'util/environment'\nimport {FormattedMessage, useIntl} from 'context/I18n'\nimport Icon from './Icon'\n\nconst styles = {\n  // TODO keep only necessary\n  border: 'none',\n  outline: 'none',\n  cursor: 'pointer',\n  padding: 0,\n  flexShrink: 0,\n  backgroundColor: 'transparent',\n  userSelect: 'none',\n  '> span': {\n    width: '100%',\n    height: '100%',\n  },\n}\n\nconst variants = {\n  outlined: {\n    width: '8em',\n    height: '2em',\n    border: '1px solid #fff',\n    borderRadius: '4px',\n    background: 'none',\n    color: 'inherit',\n    opacity: 0.8,\n  },\n  text: {color: 'var(--theme-color)'},\n  contained: {color: '#fff', backgroundColor: 'var(--theme-color)'},\n}\n\nconst tooltipStyle = {\n  zIndex: 7,\n  position: 'fixed',\n  padding: '0.5rem',\n  width: 'fit-content',\n  textAlign: 'center',\n  whiteSpace: 'nowrap',\n  color: 'white',\n  background: 'var(--panel-background, #161C24)',\n}\n\nconst isOverflowing = element => element.scrollWidth > element.clientWidth\n\nconst Tooltip = ({\n  title,\n  placement,\n  overflowOnly,\n  disabled,\n  children,\n  container,\n}) => {\n  const tooltipRef = useRef()\n  const boxes = useRef()\n  const defaultContainer = useRef()\n  const [open, setOpen] = useState(false)\n  const [position, setPosition] = useState(() => ({left: '100%'}))\n  const shiftDistance = placement === 'top' ? '-4.5em' : '2em'\n  const handleLeave = () => {\n    setPosition({left: '100%'})\n    setOpen(false)\n  }\n\n  const childProps = {\n    onMouseEnter: event => {\n      if (!overflowOnly || isOverflowing(event.currentTarget)) {\n        boxes.current = [\n          event.currentTarget.getBoundingClientRect(),\n          document.body.getBoundingClientRect(),\n        ]\n        defaultContainer.current = getTopElement()\n        setOpen(true)\n      }\n    },\n    onMouseLeave: handleLeave,\n    onTransitionEnd: event => {\n      if (window.getComputedStyle(event.target).getPropertyValue(\"opacity\") < 0.1) {\n        handleLeave()\n      } \n    }\n  }\n  useEffect(() => {\n    if (disabled) {\n      setOpen(false)\n    }\n  }, [disabled])\n\n  useEffect(() => {\n    if (open) {\n      const targetPosition = getPopoverPosition(\n        tooltipRef.current.getBoundingClientRect(),\n        ...boxes.current\n      )\n      targetPosition.left !== position.left && setPosition(targetPosition)\n    }\n  }, [open, position.left])\n\n  return !title || !isDesktop() || !havePointer() ? (\n    children\n  ) : (\n    <>\n      {cloneElement(children, childProps)}\n      {open &&\n        createPortal(\n          <div\n            style={{\n              ...tooltipStyle,\n              ...position,\n              top: `calc(${position.top}px - ${shiftDistance})`,\n            }}\n            ref={tooltipRef}\n          >\n            <FormattedMessage id={title} />\n          </div>,\n          container || defaultContainer.current\n        )}\n    </>\n  )\n}\n\nconst Button = ({\n  startIcon,\n  variant,\n  style,\n  title,\n  children,\n  placement = 'bottom',\n  ...rest\n}) => (\n  <Tooltip title={title} placement={placement} disabled={rest.disabled}>\n    <button\n      type=\"button\"\n      css={[styles, variants[variant], style]}\n      {...rest}\n    >\n      {typeof startIcon === 'string' ? <Icon type={startIcon} /> : startIcon}\n      {children}\n    </button>\n  </Tooltip>\n)\n\nButton.propTypes = {\n  startIcon: PropTypes.node,\n  children: PropTypes.node,\n}\n\nconst liveButtonStyle = {\n  '--spacing': 'calc(0.75em + 0.5rem)',\n  margin: '0 0.5rem',\n  height: '3em',\n  border: 'solid 1px',\n  borderRadius: '4px',\n  color: '#FFF',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-evenly',\n  fontSize: '0.5em !important',\n  svg: {\n    marginRight: '0.5em',\n    width: '1.5em',\n    height: '1em',\n    color: '#E93817',\n  },\n}\n\nconst startOverStyle = {svg: {color: '#BDBDBD'}}\n\nconst LiveIcon = () => (\n  <svg\n    width=\"24\"\n    height=\"16\"\n    viewBox=\"0 0 24 16\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n  >\n    <path\n      fill=\"currentColor\"\n      d=\"M3.50071 0.00164345C3.20221 0.0180071 2.90947 0.156604 2.70384 0.408604C1.01511 2.47697 0 5.11508 0 7.98744C0 10.8598 1.01511 13.4979 2.70384 15.5663C3.1162 16.0703 3.87344 16.1161 4.33381 15.6558C4.72544 15.2641 4.76392 14.6388 4.41264 14.2112C3.01955 12.5148 2.18182 10.3471 2.18182 7.98744C2.18182 5.6278 3.01955 3.46112 4.41264 1.76585C4.76392 1.33821 4.72544 0.712882 4.33381 0.321246C4.10363 0.0910639 3.79921 -0.0147202 3.50071 0.00164345ZM20.4993 0.00164345C20.2008 -0.0147202 19.8964 0.0910639 19.6662 0.321246C19.2746 0.712882 19.2361 1.33821 19.5874 1.76585C20.9804 3.46112 21.8182 5.6278 21.8182 7.98744C21.8182 10.3471 20.9804 12.5138 19.5874 14.209C19.2361 14.6367 19.2746 15.262 19.6662 15.6536C20.1266 16.114 20.8849 16.0714 21.2962 15.5663C22.9849 13.499 24 10.8598 24 7.98744C24 5.11508 22.9849 2.47697 21.2962 0.408604C21.0905 0.156604 20.7978 0.0180071 20.4993 0.00164345ZM6.59233 3.10392C6.28974 3.12083 5.99652 3.26174 5.80398 3.52792C4.89852 4.78356 4.36364 6.32489 4.36364 7.98744C4.36364 9.64998 4.89852 11.1913 5.80398 12.447C6.18907 12.9793 6.97348 13.014 7.43821 12.5492L7.44247 12.545C7.82538 12.1621 7.85357 11.5678 7.54048 11.1259C6.9143 10.2379 6.54545 9.15471 6.54545 7.98744C6.54545 6.82017 6.9143 5.73694 7.54048 4.84894C7.85248 4.40604 7.82538 3.81282 7.44247 3.42991L7.43821 3.42565C7.20585 3.19329 6.89492 3.08701 6.59233 3.10392ZM17.4077 3.10392C17.1051 3.08701 16.7942 3.19329 16.5618 3.42565L16.5575 3.42991C16.1746 3.81282 16.1464 4.40713 16.4595 4.84894C17.0857 5.73694 17.4545 6.82017 17.4545 7.98744C17.4545 9.15471 17.0857 10.2379 16.4595 11.1259C16.1475 11.5688 16.1746 12.1621 16.5575 12.545L16.5618 12.5492C17.0265 13.014 17.812 12.9793 18.196 12.447C19.1026 11.1924 19.6364 9.64998 19.6364 7.98744C19.6364 6.32489 19.1015 4.78356 18.196 3.52792C18.0035 3.26174 17.7103 3.12083 17.4077 3.10392ZM12 4.71471C11.132 4.71471 10.2996 5.05952 9.68583 5.67327C9.07208 6.28703 8.72727 7.11946 8.72727 7.98744C8.72727 8.85542 9.07208 9.68785 9.68583 10.3016C10.2996 10.9154 11.132 11.2602 12 11.2602C12.868 11.2602 13.7004 10.9154 14.3142 10.3016C14.9279 9.68785 15.2727 8.85542 15.2727 7.98744C15.2727 7.11946 14.9279 6.28703 14.3142 5.67327C13.7004 5.05952 12.868 4.71471 12 4.71471Z\"\n    />\n  </svg>\n)\n\nconst LiveButton = ({usingStartOver, ...rest}) => (\n  <Button\n    css={[liveButtonStyle, usingStartOver && startOverStyle]}\n    startIcon={<LiveIcon />}\n    {...rest}\n  >\n    <FormattedMessage id=\"LIVE\" />\n  </Button>\n)\n\nconst PlayButton = ({\n  playbackState,\n  ended,\n  hidden,\n  variant,\n  onClick,\n  ...rest\n}) => (\n  <Button\n    style={hidden && {opacity: 0}}\n    className=\"play-button\"\n    startIcon={\n      variant ||\n      (ended ? 'replay' : playbackState === 'playing' ? 'pause' : 'play')\n    }\n    title={`KKS.PLAYER.${\n      ended ? 'REPLAY' : playbackState === 'playing' ? 'PAUSE' : 'PLAY'\n    }`}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nPlayButton.propTypes = {\n  ended: PropTypes.bool,\n  onClick: PropTypes.func,\n}\n\nconst ForwardButton = ({startIcon, title, onClick, ...rest}) => (\n  <Button\n    style={rest.disabled && {opacity: 0.2, display: 'block'}}\n    startIcon={startIcon}\n    title={title}\n    onClick={onClick}\n    {...rest}\n  />\n)\n\nForwardButton.propTypes = {\n  onClick: PropTypes.func,\n}\n\nconst FullscreenButton = ({viewMode, onClick}) => {\n  const icon = viewMode === 'fullscreen' ? 'exit-fullscreen' : 'fullscreen'\n  const text = useIntl().formatMessage(\n    viewMode === 'fullscreen'\n      ? 'KKS.PLAYER.FULLSCREEN.EXIT'\n      : 'KKS.PLAYER.FULLSCREEN'\n  )\n\n  return (\n    <Button\n      startIcon={icon}\n      title={text}\n      style={!isDesktop() && {order: 'var(--fullscreen-button-order, initial)'}}\n      onClick={onClick}\n    />\n  )\n}\n\nconst skipStyles = {\n  display: 'flex',\n  alignItems: 'center',\n  padding: '0.5rem',\n  border: '1px solid #fff',\n  color: '#fff',\n  background: 'rgba(0, 0, 0, 0.4)',\n  fontSize: '24px',\n  opacity: 0.8,\n  '&:disabled': {\n    opacity: 0.5,\n  },\n  '> div': {\n    marginLeft: '0.5rem',\n    width: '1.5rem',\n    height: '1.5rem',\n  },\n}\n\nconst SkipButton = ({waitTime, onClick}) => (\n  <button\n    type=\"button\"\n    css={skipStyles}\n    disabled={waitTime > 0}\n    onClick={onClick}\n  >\n    {waitTime > 0 ? (\n      <>\n        {Math.ceil(waitTime)} <FormattedMessage id=\"KKS.SSAI.SECONDS\" />\n      </>\n    ) : (\n      <FormattedMessage id=\"KKS.SSAI.SKIP.AD\" />\n    )}\n    <Icon type=\"nextEpisode\" />\n  </button>\n)\n\nconst ShareButton = ({title, onClick}) => (\n  <Button\n    startIcon=\"share\"\n    title=\"KKS.PLAYER.SHARE\"\n    onClick={async () => {\n      if (isDesktop()) {\n        // TODO: use customize UI\n        console.log('hi')\n        return\n      }\n\n      onClick()\n      if (navigator.share) {\n        try {\n          await navigator.share({\n            title,\n            url: window.location.href,\n          })\n        } catch (error) {\n          console.error(error)\n        }\n      }\n    }}\n  />\n)\n\nconst switchStyle = {\n  padding: '0 0.2rem',\n  width: '2.4rem',\n  height: '1.2rem',\n  display: 'flex',\n  alignItems: 'center',\n  background: '#555',\n  borderRadius: '1rem',\n  transition: 'background 0.5s ease-in-out',\n}\n\nconst checkedStyle = {\n  background: 'var(--theme-color, #0E78F4)',\n  '> div': {\n    transform: 'translateX(1rem)',\n  },\n}\n\nconst thumbStyle = {\n  width: '1rem',\n  height: '1rem',\n  display: 'flex',\n  background: '#F9FAFB',\n  borderRadius: '1rem',\n  transition: 'transform 0.2s ease-in-out',\n}\n\nconst Switch = ({checked, ...rest}) => (\n  <div css={[switchStyle, checked && checkedStyle]} {...rest}>\n    <div css={thumbStyle} />\n  </div>\n)\n\nconst Close = ({...rest}) => <Button startIcon=\"close\" {...rest} />\n\nconst btnStyle = {\n  width: '4em',\n  height: '2em',\n  borderRadius: '8px',\n}\n\nconst Copy = ({...rest}) => (\n  <Button style={btnStyle} {...rest}>\n    Copy\n  </Button>\n)\n\nexport {\n  Button,\n  PlayButton,\n  FullscreenButton,\n  SkipButton,\n  ShareButton,\n  ForwardButton,\n  LiveButton,\n  Switch,\n  Close,\n  Copy\n}\n"]} */"],
2776
2729
  ...rest,
2777
- children: [typeof startIcon === 'string' ? jsx$1(Icon, {
2730
+ children: [typeof startIcon === 'string' ? jsx$1(Icon$1, {
2778
2731
  type: startIcon
2779
2732
  }) : startIcon, children]
2780
2733
  })
@@ -2927,31 +2880,12 @@ const Switch = ({
2927
2880
  })
2928
2881
  });
2929
2882
 
2930
- const Close = ({ ...rest
2931
- }) => jsx$1(Button, {
2932
- startIcon: "close",
2933
- ...rest
2934
- });
2935
-
2936
- const btnStyle = {
2937
- width: '4em',
2938
- height: '2em',
2939
- borderRadius: '8px'
2940
- };
2941
-
2942
- const Copy = ({ ...rest
2943
- }) => jsx$1(Button, {
2944
- style: btnStyle,
2945
- ...rest,
2946
- children: "Copy"
2947
- });
2948
-
2949
2883
  /* @jsxImportSource @emotion/react */
2950
2884
  const iconStyle$1 = {
2951
2885
  width: '78px',
2952
2886
  height: '78px'
2953
2887
  };
2954
- const style$4 = {
2888
+ const style$2 = {
2955
2889
  display: 'flex',
2956
2890
  justifyContent: 'center',
2957
2891
  flex: '100%',
@@ -2975,11 +2909,11 @@ const Error$1 = ({
2975
2909
  const messageKey = [error.code, (_error$data = error.data) === null || _error$data === void 0 ? void 0 : _error$data.reason].filter(Boolean).join('.');
2976
2910
  return jsxs(Backdrop, {
2977
2911
  open: true,
2978
- children: [jsx$1(Icon, {
2912
+ children: [jsx$1(Icon$1, {
2979
2913
  type: "warning",
2980
2914
  style: iconStyle$1
2981
2915
  }), jsx$1("div", {
2982
- css: style$4,
2916
+ css: style$2,
2983
2917
  children: [error.name === 'PlaycraftApiError' ? `KKS.ERROR.PLAYCRAFT.${messageKey}` : `KKS.ERROR.${messageKey}`, `KKS.ERROR.${error.code}`, `KKS.ERROR.${error.name}`, error.message, error.name, `KKS.ERROR`].reduceRight((last, id) => intl.formatMessage({
2984
2918
  id,
2985
2919
  defaultMessage: last
@@ -3069,7 +3003,7 @@ const bottomUiTop = container => {
3069
3003
  return Math.max(0, 72 * scale - bottomSpace);
3070
3004
  };
3071
3005
 
3072
- function _EMOTION_STRINGIFIED_CSS_ERROR__$3() { 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)."; }
3006
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
3073
3007
  const hidden = {
3074
3008
  display: 'none'
3075
3009
  };
@@ -3300,7 +3234,7 @@ const skipStyle = {
3300
3234
  height: 'auto'
3301
3235
  }
3302
3236
  };
3303
- const desktopStyle$3 = {
3237
+ const desktopStyle$2 = {
3304
3238
  '--spacing': '0.75em',
3305
3239
  '--center-pointer-events': 'none',
3306
3240
  '> div button': {
@@ -3358,14 +3292,14 @@ const ControlsBlock = ({
3358
3292
  children: [rewindButton, previousEpisodeButton, playButton, nextEpisodeButton, forwardButton]
3359
3293
  });
3360
3294
 
3361
- var _ref$2 = process.env.NODE_ENV === "production" ? {
3295
+ var _ref$1 = process.env.NODE_ENV === "production" ? {
3362
3296
  name: "1xad53r",
3363
3297
  styles: "&:not(:empty){flex:1;margin-left:calc(var(--spacing, 0.75em) - 0.5em + 0.5rem);}"
3364
3298
  } : {
3365
3299
  name: "9zffum-DefaultLayout",
3366
3300
  styles: "&:not(:empty){flex:1;margin-left:calc(var(--spacing, 0.75em) - 0.5em + 0.5rem);};label:DefaultLayout;",
3367
3301
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DefaultLayout.js"],"names":[],"mappings":"AAqcc","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"]} */",
3368
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
3302
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
3369
3303
  };
3370
3304
 
3371
3305
  const DefaultLayout = ({
@@ -3401,7 +3335,7 @@ const DefaultLayout = ({
3401
3335
  '--player-bottom-ui-top': controlsDisplay === 'shown' ? `-${bottomUiTop(containerRef.current)}px` : '-8px',
3402
3336
  '--player-bottom-ui-height': type === 'desktop' && controlsDisplay === 'shown' ? '3.5rem' : '0'
3403
3337
  },
3404
- css: [containerStyle$3, videoContainerStyle, responsiveStyles[size], type === 'desktop' && desktopStyle$3, adStatus && {
3338
+ css: [containerStyle$3, videoContainerStyle, responsiveStyles[size], type === 'desktop' && desktopStyle$2, adStatus && {
3405
3339
  '--bottom-spacing': 0
3406
3340
  }, 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"]} */"],
3407
3341
  ref: containerRef,
@@ -3464,7 +3398,7 @@ const DefaultLayout = ({
3464
3398
  children: displayTime
3465
3399
  }) : jsxs(Fragment, {
3466
3400
  children: [liveButton, jsx$1("div", {
3467
- css: _ref$2,
3401
+ css: _ref$1,
3468
3402
  children: displayTime
3469
3403
  })]
3470
3404
  }), adStatus && jsx$1("div", {
@@ -3635,8 +3569,10 @@ const pointerHandlers = ({
3635
3569
  };
3636
3570
  };
3637
3571
 
3638
- const style$3 = {
3572
+ /* eslint-disable no-param-reassign */
3573
+ const containerStyle$2 = {
3639
3574
  position: 'relative',
3575
+ width: '100%',
3640
3576
  height: '100%',
3641
3577
  display: 'flex',
3642
3578
  alignItems: 'center',
@@ -3644,90 +3580,47 @@ const style$3 = {
3644
3580
  userSelect: 'none',
3645
3581
  touchAction: 'none'
3646
3582
  };
3647
- const disabledStyle$1 = {
3583
+ const disabledStyle = {
3648
3584
  pointerEvents: 'none'
3649
3585
  };
3650
- const railStyle$1 = {
3651
- position: 'relative',
3586
+ const railStyle = {
3652
3587
  flex: '100%',
3653
- height: '1em',
3654
- overflow: 'hidden',
3655
- display: 'flex',
3656
- alignItems: 'center'
3588
+ background: 'rgba(255, 255, 255, 0.2)'
3657
3589
  };
3658
- const segmentStyle = {
3659
- height: '0.66em',
3660
- '&:hover': {
3661
- height: '1em'
3662
- },
3663
- marginRight: '2px',
3664
- background: 'rgba(255, 255, 255, 0.2)',
3665
- position: 'relative',
3666
- '> div': {
3667
- height: '100%',
3668
- position: 'absolute',
3669
- left: '0',
3670
- top: '0'
3671
- }
3590
+ const trackStyle = {
3591
+ position: 'absolute',
3592
+ width: '4px',
3593
+ height: '100%',
3594
+ backgroundColor: 'var(--sender-seekbar-background, #fff)'
3672
3595
  };
3673
- const markStyle$1 = {
3596
+ const markStyle = {
3674
3597
  position: 'absolute',
3675
- height: railStyle$1.height,
3598
+ height: railStyle.height,
3676
3599
  width: '4px',
3677
3600
  transform: 'translateX(-50%)',
3678
3601
  backgroundColor: '#ff9835'
3679
3602
  };
3680
- const horizontalThumbStyle = {
3603
+ const thumbStyle = {
3681
3604
  position: 'absolute',
3682
- top: '50%',
3683
- height: '14px',
3684
- width: '14px',
3605
+ height: '0.66em',
3606
+ width: '0.66em',
3685
3607
  borderRadius: '100%',
3686
3608
  backgroundColor: '#fff',
3687
3609
  boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',
3688
- transform: 'translate(-50%, -50%)'
3610
+ transform: 'translateY(calc(var(--slider-thumb-y) - 0.35em))'
3689
3611
  };
3690
3612
 
3691
- const between = (min, max, value) => value >= min && value < max;
3692
-
3693
- const getHorizontalSliderValue = ({
3613
+ const getPointerValue = ({
3614
+ orientation,
3694
3615
  x,
3616
+ y,
3695
3617
  left,
3618
+ bottom,
3619
+ height,
3696
3620
  width
3697
- }) => Math.max(0, Math.min((x - left) / width, 1));
3698
-
3699
- const calculatePercentage = (value, segment) => {
3700
- const percentage = value >= segment.endTime ? 100 : (value - segment.startTime) / segment.duration * 100;
3701
- return `${percentage}%`;
3702
- };
3703
-
3704
- const getSegments = (chapters, {
3705
- max,
3706
- min
3707
- }) => {
3708
- // Handle no chapters and DVR cases.
3709
- if (!Array.isArray(chapters) || chapters.length === 0) {
3710
- return [{
3711
- startTime: min,
3712
- endTime: max,
3713
- duration: Math.abs(max - min),
3714
- width: '100%'
3715
- }];
3716
- }
3717
-
3718
- const lastIndex = chapters.length - 1;
3719
- return chapters.map((c, index) => {
3720
- const duration = lastIndex !== index ? chapters[index + 1].startTime - c.startTime - 1 : max - c.startTime;
3721
- return {
3722
- startTime: c.startTime,
3723
- endTime: c.startTime + duration,
3724
- duration,
3725
- width: `${duration / max * 100}%`
3726
- };
3727
- });
3728
- };
3621
+ }) => Math.max(0, orientation === 'vertical' ? Math.min((bottom - y) / height, 1) : Math.min((x - left) / width, 1));
3729
3622
 
3730
- const debouncedPointerHandlers$1 = ({
3623
+ const debouncedPointerHandlers = ({
3731
3624
  state,
3732
3625
  onMove,
3733
3626
  onLeave
@@ -3737,36 +3630,16 @@ const debouncedPointerHandlers$1 = ({
3737
3630
  return;
3738
3631
  }
3739
3632
 
3740
- state.scheduled = false;
3741
-
3742
3633
  if (state.type === 'leave') {
3743
3634
  onLeave === null || onLeave === void 0 ? void 0 : onLeave(state.event, state);
3744
- state.gestureStatus = 'none';
3745
3635
  } else {
3746
3636
  onMove(state.event, state);
3747
3637
  }
3748
- };
3749
-
3750
- const schedule = update => {
3751
- if (update.type === 'change') {
3752
- state.gestureStatus = 'active';
3753
- }
3754
-
3755
- const shouldDispatchImmediately = state.type === 'change' && update.type !== 'change';
3756
- Object.assign(state, update);
3757
-
3758
- if (shouldDispatchImmediately) {
3759
- state.type = 'leave';
3760
3638
 
3761
- if (state.gestureStatus === 'active') {
3762
- state.gestureStatus = 'releasing';
3763
- }
3764
-
3765
- state.scheduled = true;
3766
- emit();
3767
- return;
3768
- }
3639
+ state.scheduled = false;
3640
+ };
3769
3641
 
3642
+ const schedule = () => {
3770
3643
  if (state.scheduled) {
3771
3644
  return;
3772
3645
  }
@@ -3779,22 +3652,27 @@ const debouncedPointerHandlers$1 = ({
3779
3652
  onPointerMove: event => {
3780
3653
  var _event$touches;
3781
3654
 
3782
- const type = event.type === 'pointerdown' || event.buttons > 0 || ((_event$touches = event.touches) === null || _event$touches === void 0 ? void 0 : _event$touches.length) > 0 ? 'change' : 'move';
3783
- schedule({
3655
+ const type = event.buttons > 0 || ((_event$touches = event.touches) === null || _event$touches === void 0 ? void 0 : _event$touches.length) > 0 ? 'change' : 'move';
3656
+ Object.assign(state, {
3784
3657
  event,
3785
3658
  type,
3786
3659
  ...getPointerData(event)
3787
3660
  });
3661
+ schedule();
3662
+ },
3663
+ onPointerLeave: event => {
3664
+ const type = 'leave';
3665
+ Object.assign(state, {
3666
+ event,
3667
+ type
3668
+ });
3669
+ schedule();
3788
3670
  },
3789
- onPointerLeave: event => schedule({
3790
- type: 'leave',
3791
- event
3792
- }),
3793
3671
  emit
3794
3672
  };
3795
3673
  };
3796
3674
 
3797
- const eventHandlers$1 = ({
3675
+ const eventHandlers = ({
3798
3676
  onPointerDown,
3799
3677
  onPointerMove,
3800
3678
  onPointerLeave,
@@ -3810,17 +3688,47 @@ const eventHandlers$1 = ({
3810
3688
  onPointerLeave(event);
3811
3689
  onPointerUp(event);
3812
3690
  }
3813
- }); // TODO align with material ui more, move special handling of pointer events
3691
+ });
3692
+
3693
+ const SliderRail = ({
3694
+ orientation,
3695
+ style,
3696
+ ...rest
3697
+ }) => jsx$1("div", {
3698
+ css: [style, orientation !== 'horizontal' && {
3699
+ borderRadius: '0.2em',
3700
+ alignSelf: 'normal'
3701
+ }, process.env.NODE_ENV === "production" ? "" : ";label:SliderRail;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SimpleSlider.jsx"],"names":[],"mappings":"AAqHI","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"]} */"],
3702
+ ...rest
3703
+ });
3704
+
3705
+ const SliderTrack = ({
3706
+ value,
3707
+ orientation,
3708
+ style,
3709
+ ...rest
3710
+ }) => jsx$1("div", {
3711
+ css: [style, orientation === 'vertical' ? {
3712
+ bottom: '0',
3713
+ height: `${value * 100}%`
3714
+ } : {
3715
+ width: `${value * 100}%`
3716
+ }, process.env.NODE_ENV === "production" ? "" : ";label:SliderTrack;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SimpleSlider.jsx"],"names":[],"mappings":"AA4HI","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"]} */"],
3717
+ ...rest
3718
+ });
3814
3719
 
3720
+ const defaultSlots = {
3721
+ Rail: SliderRail,
3722
+ Track: SliderTrack
3723
+ }; // TODO align with material ui more, move special handling of pointer events
3815
3724
 
3816
- const ChaptersSlider = ({
3725
+ const SimpleSlider = ({
3817
3726
  min = 0,
3818
3727
  max = 100,
3819
3728
  value,
3820
3729
  secondaryTrackValue,
3821
3730
  // TODO a better name
3822
3731
  marks = [],
3823
- chapters,
3824
3732
  className = '',
3825
3733
  classes = {},
3826
3734
  disabled,
@@ -3828,58 +3736,36 @@ const ChaptersSlider = ({
3828
3736
  onPointerLeave,
3829
3737
  onPointerDown,
3830
3738
  onChange,
3831
- onChangeCommitted
3739
+ onChangeCommitted,
3740
+ orientation = 'horizontal',
3741
+ slots = defaultSlots,
3742
+ slotProps = {}
3832
3743
  }) => {
3833
3744
  const pointerState = useRef({});
3834
3745
  const [focusValue, setFocusValue] = useState(-Infinity);
3835
3746
  const thumbPosition = ((focusValue >= min ? focusValue : value) - min) / (max - min);
3836
- const checkSliderValue = getHorizontalSliderValue;
3837
-
3838
- const handlePointerUp = (event, handlers) => {
3839
- if (event.pointerId) {
3840
- var _event$currentTarget;
3841
-
3842
- (_event$currentTarget = event.currentTarget) === null || _event$currentTarget === void 0 ? void 0 : _event$currentTarget.releasePointerCapture(event.pointerId);
3843
- }
3844
-
3845
- if (!/active|releasing/.test(pointerState.current.gestureStatus)) {
3846
- return;
3847
- }
3848
-
3849
- const {
3850
- x,
3851
- width,
3852
- left
3853
- } = getPointerData(event);
3854
- const checkPointerValue = {
3855
- x,
3856
- width,
3857
- left
3858
- };
3859
- const pointerValue = (max - min) * checkSliderValue(checkPointerValue) + min;
3860
- handlers.emit();
3861
- pointerState.current.gestureStatus = 'none';
3862
- onChangeCommitted === null || onChangeCommitted === void 0 ? void 0 : onChangeCommitted(event, {
3863
- value: pointerValue
3864
- });
3865
- setFocusValue();
3866
- };
3867
-
3868
- const pointerHandlers = debouncedPointerHandlers$1({
3747
+ const subTrackPosition = (secondaryTrackValue - min) / (max - min);
3748
+ const pointerHandlers = debouncedPointerHandlers({
3869
3749
  state: pointerState.current,
3870
3750
  onMove: (event, {
3871
3751
  type,
3872
3752
  x,
3873
3753
  y,
3874
3754
  width,
3875
- left
3755
+ left,
3756
+ height,
3757
+ bottom
3876
3758
  }) => {
3877
- const checkPointerValue = {
3759
+ const pointerData = {
3760
+ orientation,
3878
3761
  x,
3762
+ y,
3763
+ left,
3764
+ bottom,
3879
3765
  width,
3880
- left
3766
+ height
3881
3767
  };
3882
- const pointerValue = (max - min) * checkSliderValue(checkPointerValue) + min;
3768
+ const pointerValue = min + (max - min) * getPointerValue(pointerData);
3883
3769
  onPointerMove === null || onPointerMove === void 0 ? void 0 : onPointerMove(event, {
3884
3770
  value: pointerValue,
3885
3771
  x,
@@ -3895,25 +3781,55 @@ const ChaptersSlider = ({
3895
3781
  });
3896
3782
  }
3897
3783
  },
3898
- onLeave: event => {
3899
- onPointerLeave === null || onPointerLeave === void 0 ? void 0 : onPointerLeave(event);
3900
- handlePointerUp(event, pointerHandlers);
3901
- }
3784
+ onLeave: () => onPointerLeave === null || onPointerLeave === void 0 ? void 0 : onPointerLeave()
3902
3785
  });
3903
- const thumbStyle = horizontalThumbStyle;
3904
- const trackValue = Number.isFinite(focusValue) ? focusValue : value;
3905
- const trackLowestPoint = {
3906
- left: `calc(${thumbPosition * 100}%)`
3786
+
3787
+ const handlePointerUp = event => {
3788
+ if (event.pointerId) {
3789
+ event.currentTarget.releasePointerCapture(event.pointerId);
3790
+ }
3791
+
3792
+ const {
3793
+ x,
3794
+ y,
3795
+ width,
3796
+ left,
3797
+ height,
3798
+ bottom
3799
+ } = getPointerData(event);
3800
+ const pointerValue = min + (max - min) * getPointerValue({
3801
+ orientation,
3802
+ x,
3803
+ y,
3804
+ left,
3805
+ bottom,
3806
+ width,
3807
+ height
3808
+ });
3809
+ pointerHandlers.emit();
3810
+ onChangeCommitted === null || onChangeCommitted === void 0 ? void 0 : onChangeCommitted(event, {
3811
+ value: pointerValue
3812
+ });
3813
+ setFocusValue();
3814
+ };
3815
+
3816
+ const thumbPositionStyle = {
3817
+ bottom: `calc(var(--slider-thumb-y) - 0.35em)`,
3818
+ left: `calc(var(--slider-thumb-x) - 0.25em)`
3907
3819
  };
3908
- const segments = getSegments(chapters, {
3909
- max,
3910
- min
3911
- });
3912
3820
  return jsxs("div", {
3913
3821
  className: className,
3914
- css: [style$3, disabled && disabledStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:ChaptersSlider;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ChaptersSlider.jsx"],"names":[],"mappings":"AAmPM","file":"ChaptersSlider.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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\n  position: 'relative',\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  position: 'relative',\n  flex: '100%',\n  height: '1em',\n  overflow: 'hidden',\n  display: 'flex',\n  alignItems: 'center',\n}\n\nconst segmentStyle = {\n  height: '0.66em',\n  '&:hover': {\n    height: '1em',\n  },\n  marginRight: '2px',\n  background: 'rgba(255, 255, 255, 0.2)',\n  position: 'relative',\n  '> div': {\n    height: '100%',\n    position: 'absolute',\n    left: '0',\n    top: '0',\n  },\n}\n\nconst markStyle = {\n  position: 'absolute',\n  height: railStyle.height,\n  width: '4px',\n  transform: 'translateX(-50%)',\n  backgroundColor: '#ff9835',\n}\n\nconst horizontalThumbStyle = {\n  position: 'absolute',\n  top: '50%',\n  height: '14px',\n  width: '14px',\n  borderRadius: '100%',\n  backgroundColor: '#fff',\n  boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',\n  transform: 'translate(-50%, -50%)',\n}\n\nconst between = (min, max, value) => value >= min && value < max\n\nconst getHorizontalSliderValue = ({x, left, width}) =>\n  Math.max(0, Math.min((x - left) / width, 1))\n\nconst calculatePercentage = (value, segment) => {\n  const percentage =\n    value >= segment.endTime\n      ? 100\n      : ((value - segment.startTime) / segment.duration) * 100\n  return `${percentage}%`\n}\n\nconst getSegments = (chapters, {max, min}) => {\n  // Handle no chapters and DVR cases.\n  if (!Array.isArray(chapters) || chapters.length === 0) {\n    return [\n      {\n        startTime: min,\n        endTime: max,\n        duration: Math.abs(max - min),\n        width: '100%',\n      },\n    ]\n  }\n  const lastIndex = chapters.length - 1\n  return chapters.map((c, index) => {\n    const duration =\n      lastIndex !== index\n        ? chapters[index + 1].startTime - c.startTime - 1\n        : max - c.startTime\n    return {\n      startTime: c.startTime,\n      endTime: c.startTime + duration,\n      duration,\n      width: `${(duration / max) * 100}%`,\n    }\n  })\n}\n\nconst debouncedPointerHandlers = ({state, onMove, onLeave}) => {\n  const emit = () => {\n    if (!state.scheduled) {\n      return\n    }\n    state.scheduled = false\n    if (state.type === 'leave') {\n      onLeave?.(state.event, state)\n      state.gestureStatus = 'none'\n    } else {\n      onMove(state.event, state)\n    }\n  }\n  const schedule = update => {\n    if (update.type === 'change') {\n      state.gestureStatus = 'active'\n    }\n    const shouldDispatchImmediately =\n      state.type === 'change' && update.type !== 'change'\n    Object.assign(state, update)\n    if (shouldDispatchImmediately) {\n      state.type = 'leave'\n      if (state.gestureStatus === 'active') {\n        state.gestureStatus = 'releasing'\n      }\n      state.scheduled = true\n      emit()\n      return\n    }\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.type === 'pointerdown' ||\n        event.buttons > 0 ||\n        event.touches?.length > 0\n          ? 'change'\n          : 'move'\n      schedule({event, type, ...getPointerData(event)})\n    },\n    onPointerLeave: event => \n      schedule({type: 'leave', event})\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\n// TODO align with material ui more, move special handling of pointer events\nconst ChaptersSlider = ({\n  min = 0,\n  max = 100,\n  value,\n  secondaryTrackValue, // TODO a better name\n  marks = [],\n  chapters,\n  className = '',\n  classes = {},\n  disabled,\n  onPointerMove,\n  onPointerLeave,\n  onPointerDown,\n  onChange,\n  onChangeCommitted,\n}) => {\n  const pointerState = useRef({})\n  const [focusValue, setFocusValue] = useState(-Infinity)\n  const thumbPosition =\n    ((focusValue >= min ? focusValue : value) - min) / (max - min)\n  const checkSliderValue = getHorizontalSliderValue\n  const handlePointerUp = (event, handlers) => {\n    if (event.pointerId) {\n      event.currentTarget?.releasePointerCapture(event.pointerId)\n    }\n    if (!/active|releasing/.test(pointerState.current.gestureStatus)) {\n      return\n    }\n    const {x, width, left} = getPointerData(event)\n    const checkPointerValue = {x, width, left}\n    const pointerValue = (max - min) * checkSliderValue(checkPointerValue) + min\n\n    handlers.emit()\n    pointerState.current.gestureStatus = 'none'\n    onChangeCommitted?.(event, {value: pointerValue})\n    setFocusValue()\n  }\n  const pointerHandlers = debouncedPointerHandlers({\n    state: pointerState.current,\n    onMove: (event, {type, x, y, width, left}) => {\n      const checkPointerValue = {x, width, left}\n      const pointerValue =\n        (max - min) * checkSliderValue(checkPointerValue) + min\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: event => {\n      onPointerLeave?.(event)\n      handlePointerUp(event, pointerHandlers)\n    },\n  })\n\n  const thumbStyle = horizontalThumbStyle\n  const trackValue = Number.isFinite(focusValue) ? focusValue : value\n  const trackLowestPoint = {left: `calc(${thumbPosition * 100}%)`}\n  const segments = getSegments(chapters, {max, min})\n\n  return (\n    <div\n      className={className}\n      css={[style, disabled && disabledStyle]}\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: event => handlePointerUp(event, pointerHandlers),\n      })}\n    >\n      <div className={classes.rail} css={railStyle}>\n        {segments.map((segment, index) => (\n          <div\n            className={index}\n            key={index}\n            css={[\n              segmentStyle,\n              {\n                width: segment.width,\n                height: between(segment.startTime, segment.endTime, focusValue)\n                  ? '1em'\n                  : '0.66em',\n              },\n            ]}\n          >\n            {secondaryTrackValue > segment.startTime && (\n              <div\n                css={{\n                  backgroundColor: 'rgba(255, 255, 255, 0.3)',\n                  width: calculatePercentage(secondaryTrackValue, segment),\n                }}\n              />\n            )}\n            <div\n              css={{\n                width: calculatePercentage(trackValue, segment),\n              }}\n              className={classes.track}\n            />\n          </div>\n        ))}\n      </div>\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={trackLowestPoint}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nChaptersSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default ChaptersSlider\n"]} */"],
3822
+ css: [containerStyle$2, 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"]} */"],
3823
+ style: { ...(orientation === 'vertical' && {
3824
+ flexDirection: 'column',
3825
+ '--slider-thumb-y': `${thumbPosition * 100}%`
3826
+ }),
3827
+ ...(orientation === 'horizontal' && {
3828
+ '--slider-thumb-x': `${thumbPosition * 100}%`
3829
+ })
3830
+ },
3915
3831
  onClick: event => event.stopPropagation(),
3916
- ...eventHandlers$1({
3832
+ ...eventHandlers({
3917
3833
  onPointerDown: event => {
3918
3834
  if (event.type === 'pointerdown') {
3919
3835
  event.currentTarget.setPointerCapture(event.pointerId);
@@ -3923,31 +3839,27 @@ const ChaptersSlider = ({
3923
3839
  pointerHandlers.onPointerMove(event);
3924
3840
  },
3925
3841
  ...pointerHandlers,
3926
- onPointerUp: event => handlePointerUp(event, pointerHandlers)
3842
+ onPointerUp: handlePointerUp
3927
3843
  }),
3928
- children: [jsx$1("div", {
3844
+ children: [jsx$1(slots.Rail, {
3845
+ style: railStyle,
3929
3846
  className: classes.rail,
3930
- css: railStyle$1,
3931
- children: segments.map((segment, index) => jsxs("div", {
3932
- className: index,
3933
- css: [segmentStyle, {
3934
- width: segment.width,
3935
- height: between(segment.startTime, segment.endTime, focusValue) ? '1em' : '0.66em'
3936
- }, process.env.NODE_ENV === "production" ? "" : ";label:ChaptersSlider;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ChaptersSlider.jsx"],"names":[],"mappings":"AAsQY","file":"ChaptersSlider.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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\n  position: 'relative',\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  position: 'relative',\n  flex: '100%',\n  height: '1em',\n  overflow: 'hidden',\n  display: 'flex',\n  alignItems: 'center',\n}\n\nconst segmentStyle = {\n  height: '0.66em',\n  '&:hover': {\n    height: '1em',\n  },\n  marginRight: '2px',\n  background: 'rgba(255, 255, 255, 0.2)',\n  position: 'relative',\n  '> div': {\n    height: '100%',\n    position: 'absolute',\n    left: '0',\n    top: '0',\n  },\n}\n\nconst markStyle = {\n  position: 'absolute',\n  height: railStyle.height,\n  width: '4px',\n  transform: 'translateX(-50%)',\n  backgroundColor: '#ff9835',\n}\n\nconst horizontalThumbStyle = {\n  position: 'absolute',\n  top: '50%',\n  height: '14px',\n  width: '14px',\n  borderRadius: '100%',\n  backgroundColor: '#fff',\n  boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',\n  transform: 'translate(-50%, -50%)',\n}\n\nconst between = (min, max, value) => value >= min && value < max\n\nconst getHorizontalSliderValue = ({x, left, width}) =>\n  Math.max(0, Math.min((x - left) / width, 1))\n\nconst calculatePercentage = (value, segment) => {\n  const percentage =\n    value >= segment.endTime\n      ? 100\n      : ((value - segment.startTime) / segment.duration) * 100\n  return `${percentage}%`\n}\n\nconst getSegments = (chapters, {max, min}) => {\n  // Handle no chapters and DVR cases.\n  if (!Array.isArray(chapters) || chapters.length === 0) {\n    return [\n      {\n        startTime: min,\n        endTime: max,\n        duration: Math.abs(max - min),\n        width: '100%',\n      },\n    ]\n  }\n  const lastIndex = chapters.length - 1\n  return chapters.map((c, index) => {\n    const duration =\n      lastIndex !== index\n        ? chapters[index + 1].startTime - c.startTime - 1\n        : max - c.startTime\n    return {\n      startTime: c.startTime,\n      endTime: c.startTime + duration,\n      duration,\n      width: `${(duration / max) * 100}%`,\n    }\n  })\n}\n\nconst debouncedPointerHandlers = ({state, onMove, onLeave}) => {\n  const emit = () => {\n    if (!state.scheduled) {\n      return\n    }\n    state.scheduled = false\n    if (state.type === 'leave') {\n      onLeave?.(state.event, state)\n      state.gestureStatus = 'none'\n    } else {\n      onMove(state.event, state)\n    }\n  }\n  const schedule = update => {\n    if (update.type === 'change') {\n      state.gestureStatus = 'active'\n    }\n    const shouldDispatchImmediately =\n      state.type === 'change' && update.type !== 'change'\n    Object.assign(state, update)\n    if (shouldDispatchImmediately) {\n      state.type = 'leave'\n      if (state.gestureStatus === 'active') {\n        state.gestureStatus = 'releasing'\n      }\n      state.scheduled = true\n      emit()\n      return\n    }\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.type === 'pointerdown' ||\n        event.buttons > 0 ||\n        event.touches?.length > 0\n          ? 'change'\n          : 'move'\n      schedule({event, type, ...getPointerData(event)})\n    },\n    onPointerLeave: event => \n      schedule({type: 'leave', event})\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\n// TODO align with material ui more, move special handling of pointer events\nconst ChaptersSlider = ({\n  min = 0,\n  max = 100,\n  value,\n  secondaryTrackValue, // TODO a better name\n  marks = [],\n  chapters,\n  className = '',\n  classes = {},\n  disabled,\n  onPointerMove,\n  onPointerLeave,\n  onPointerDown,\n  onChange,\n  onChangeCommitted,\n}) => {\n  const pointerState = useRef({})\n  const [focusValue, setFocusValue] = useState(-Infinity)\n  const thumbPosition =\n    ((focusValue >= min ? focusValue : value) - min) / (max - min)\n  const checkSliderValue = getHorizontalSliderValue\n  const handlePointerUp = (event, handlers) => {\n    if (event.pointerId) {\n      event.currentTarget?.releasePointerCapture(event.pointerId)\n    }\n    if (!/active|releasing/.test(pointerState.current.gestureStatus)) {\n      return\n    }\n    const {x, width, left} = getPointerData(event)\n    const checkPointerValue = {x, width, left}\n    const pointerValue = (max - min) * checkSliderValue(checkPointerValue) + min\n\n    handlers.emit()\n    pointerState.current.gestureStatus = 'none'\n    onChangeCommitted?.(event, {value: pointerValue})\n    setFocusValue()\n  }\n  const pointerHandlers = debouncedPointerHandlers({\n    state: pointerState.current,\n    onMove: (event, {type, x, y, width, left}) => {\n      const checkPointerValue = {x, width, left}\n      const pointerValue =\n        (max - min) * checkSliderValue(checkPointerValue) + min\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: event => {\n      onPointerLeave?.(event)\n      handlePointerUp(event, pointerHandlers)\n    },\n  })\n\n  const thumbStyle = horizontalThumbStyle\n  const trackValue = Number.isFinite(focusValue) ? focusValue : value\n  const trackLowestPoint = {left: `calc(${thumbPosition * 100}%)`}\n  const segments = getSegments(chapters, {max, min})\n\n  return (\n    <div\n      className={className}\n      css={[style, disabled && disabledStyle]}\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: event => handlePointerUp(event, pointerHandlers),\n      })}\n    >\n      <div className={classes.rail} css={railStyle}>\n        {segments.map((segment, index) => (\n          <div\n            className={index}\n            key={index}\n            css={[\n              segmentStyle,\n              {\n                width: segment.width,\n                height: between(segment.startTime, segment.endTime, focusValue)\n                  ? '1em'\n                  : '0.66em',\n              },\n            ]}\n          >\n            {secondaryTrackValue > segment.startTime && (\n              <div\n                css={{\n                  backgroundColor: 'rgba(255, 255, 255, 0.3)',\n                  width: calculatePercentage(secondaryTrackValue, segment),\n                }}\n              />\n            )}\n            <div\n              css={{\n                width: calculatePercentage(trackValue, segment),\n              }}\n              className={classes.track}\n            />\n          </div>\n        ))}\n      </div>\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={trackLowestPoint}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nChaptersSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default ChaptersSlider\n"]} */"],
3937
- children: [secondaryTrackValue > segment.startTime && jsx$1("div", {
3938
- css: /*#__PURE__*/css({
3939
- backgroundColor: 'rgba(255, 255, 255, 0.3)',
3940
- width: calculatePercentage(secondaryTrackValue, segment)
3941
- }, process.env.NODE_ENV === "production" ? "" : ";label:ChaptersSlider;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ChaptersSlider.jsx"],"names":[],"mappings":"AAkRgB","file":"ChaptersSlider.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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\n  position: 'relative',\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  position: 'relative',\n  flex: '100%',\n  height: '1em',\n  overflow: 'hidden',\n  display: 'flex',\n  alignItems: 'center',\n}\n\nconst segmentStyle = {\n  height: '0.66em',\n  '&:hover': {\n    height: '1em',\n  },\n  marginRight: '2px',\n  background: 'rgba(255, 255, 255, 0.2)',\n  position: 'relative',\n  '> div': {\n    height: '100%',\n    position: 'absolute',\n    left: '0',\n    top: '0',\n  },\n}\n\nconst markStyle = {\n  position: 'absolute',\n  height: railStyle.height,\n  width: '4px',\n  transform: 'translateX(-50%)',\n  backgroundColor: '#ff9835',\n}\n\nconst horizontalThumbStyle = {\n  position: 'absolute',\n  top: '50%',\n  height: '14px',\n  width: '14px',\n  borderRadius: '100%',\n  backgroundColor: '#fff',\n  boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',\n  transform: 'translate(-50%, -50%)',\n}\n\nconst between = (min, max, value) => value >= min && value < max\n\nconst getHorizontalSliderValue = ({x, left, width}) =>\n  Math.max(0, Math.min((x - left) / width, 1))\n\nconst calculatePercentage = (value, segment) => {\n  const percentage =\n    value >= segment.endTime\n      ? 100\n      : ((value - segment.startTime) / segment.duration) * 100\n  return `${percentage}%`\n}\n\nconst getSegments = (chapters, {max, min}) => {\n  // Handle no chapters and DVR cases.\n  if (!Array.isArray(chapters) || chapters.length === 0) {\n    return [\n      {\n        startTime: min,\n        endTime: max,\n        duration: Math.abs(max - min),\n        width: '100%',\n      },\n    ]\n  }\n  const lastIndex = chapters.length - 1\n  return chapters.map((c, index) => {\n    const duration =\n      lastIndex !== index\n        ? chapters[index + 1].startTime - c.startTime - 1\n        : max - c.startTime\n    return {\n      startTime: c.startTime,\n      endTime: c.startTime + duration,\n      duration,\n      width: `${(duration / max) * 100}%`,\n    }\n  })\n}\n\nconst debouncedPointerHandlers = ({state, onMove, onLeave}) => {\n  const emit = () => {\n    if (!state.scheduled) {\n      return\n    }\n    state.scheduled = false\n    if (state.type === 'leave') {\n      onLeave?.(state.event, state)\n      state.gestureStatus = 'none'\n    } else {\n      onMove(state.event, state)\n    }\n  }\n  const schedule = update => {\n    if (update.type === 'change') {\n      state.gestureStatus = 'active'\n    }\n    const shouldDispatchImmediately =\n      state.type === 'change' && update.type !== 'change'\n    Object.assign(state, update)\n    if (shouldDispatchImmediately) {\n      state.type = 'leave'\n      if (state.gestureStatus === 'active') {\n        state.gestureStatus = 'releasing'\n      }\n      state.scheduled = true\n      emit()\n      return\n    }\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.type === 'pointerdown' ||\n        event.buttons > 0 ||\n        event.touches?.length > 0\n          ? 'change'\n          : 'move'\n      schedule({event, type, ...getPointerData(event)})\n    },\n    onPointerLeave: event => \n      schedule({type: 'leave', event})\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\n// TODO align with material ui more, move special handling of pointer events\nconst ChaptersSlider = ({\n  min = 0,\n  max = 100,\n  value,\n  secondaryTrackValue, // TODO a better name\n  marks = [],\n  chapters,\n  className = '',\n  classes = {},\n  disabled,\n  onPointerMove,\n  onPointerLeave,\n  onPointerDown,\n  onChange,\n  onChangeCommitted,\n}) => {\n  const pointerState = useRef({})\n  const [focusValue, setFocusValue] = useState(-Infinity)\n  const thumbPosition =\n    ((focusValue >= min ? focusValue : value) - min) / (max - min)\n  const checkSliderValue = getHorizontalSliderValue\n  const handlePointerUp = (event, handlers) => {\n    if (event.pointerId) {\n      event.currentTarget?.releasePointerCapture(event.pointerId)\n    }\n    if (!/active|releasing/.test(pointerState.current.gestureStatus)) {\n      return\n    }\n    const {x, width, left} = getPointerData(event)\n    const checkPointerValue = {x, width, left}\n    const pointerValue = (max - min) * checkSliderValue(checkPointerValue) + min\n\n    handlers.emit()\n    pointerState.current.gestureStatus = 'none'\n    onChangeCommitted?.(event, {value: pointerValue})\n    setFocusValue()\n  }\n  const pointerHandlers = debouncedPointerHandlers({\n    state: pointerState.current,\n    onMove: (event, {type, x, y, width, left}) => {\n      const checkPointerValue = {x, width, left}\n      const pointerValue =\n        (max - min) * checkSliderValue(checkPointerValue) + min\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: event => {\n      onPointerLeave?.(event)\n      handlePointerUp(event, pointerHandlers)\n    },\n  })\n\n  const thumbStyle = horizontalThumbStyle\n  const trackValue = Number.isFinite(focusValue) ? focusValue : value\n  const trackLowestPoint = {left: `calc(${thumbPosition * 100}%)`}\n  const segments = getSegments(chapters, {max, min})\n\n  return (\n    <div\n      className={className}\n      css={[style, disabled && disabledStyle]}\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: event => handlePointerUp(event, pointerHandlers),\n      })}\n    >\n      <div className={classes.rail} css={railStyle}>\n        {segments.map((segment, index) => (\n          <div\n            className={index}\n            key={index}\n            css={[\n              segmentStyle,\n              {\n                width: segment.width,\n                height: between(segment.startTime, segment.endTime, focusValue)\n                  ? '1em'\n                  : '0.66em',\n              },\n            ]}\n          >\n            {secondaryTrackValue > segment.startTime && (\n              <div\n                css={{\n                  backgroundColor: 'rgba(255, 255, 255, 0.3)',\n                  width: calculatePercentage(secondaryTrackValue, segment),\n                }}\n              />\n            )}\n            <div\n              css={{\n                width: calculatePercentage(trackValue, segment),\n              }}\n              className={classes.track}\n            />\n          </div>\n        ))}\n      </div>\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={trackLowestPoint}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nChaptersSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default ChaptersSlider\n"]} */")
3942
- }), jsx$1("div", {
3943
- css: /*#__PURE__*/css({
3944
- width: calculatePercentage(trackValue, segment)
3945
- }, process.env.NODE_ENV === "production" ? "" : ";label:ChaptersSlider;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ChaptersSlider.jsx"],"names":[],"mappings":"AAyRc","file":"ChaptersSlider.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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\n  position: 'relative',\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  position: 'relative',\n  flex: '100%',\n  height: '1em',\n  overflow: 'hidden',\n  display: 'flex',\n  alignItems: 'center',\n}\n\nconst segmentStyle = {\n  height: '0.66em',\n  '&:hover': {\n    height: '1em',\n  },\n  marginRight: '2px',\n  background: 'rgba(255, 255, 255, 0.2)',\n  position: 'relative',\n  '> div': {\n    height: '100%',\n    position: 'absolute',\n    left: '0',\n    top: '0',\n  },\n}\n\nconst markStyle = {\n  position: 'absolute',\n  height: railStyle.height,\n  width: '4px',\n  transform: 'translateX(-50%)',\n  backgroundColor: '#ff9835',\n}\n\nconst horizontalThumbStyle = {\n  position: 'absolute',\n  top: '50%',\n  height: '14px',\n  width: '14px',\n  borderRadius: '100%',\n  backgroundColor: '#fff',\n  boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',\n  transform: 'translate(-50%, -50%)',\n}\n\nconst between = (min, max, value) => value >= min && value < max\n\nconst getHorizontalSliderValue = ({x, left, width}) =>\n  Math.max(0, Math.min((x - left) / width, 1))\n\nconst calculatePercentage = (value, segment) => {\n  const percentage =\n    value >= segment.endTime\n      ? 100\n      : ((value - segment.startTime) / segment.duration) * 100\n  return `${percentage}%`\n}\n\nconst getSegments = (chapters, {max, min}) => {\n  // Handle no chapters and DVR cases.\n  if (!Array.isArray(chapters) || chapters.length === 0) {\n    return [\n      {\n        startTime: min,\n        endTime: max,\n        duration: Math.abs(max - min),\n        width: '100%',\n      },\n    ]\n  }\n  const lastIndex = chapters.length - 1\n  return chapters.map((c, index) => {\n    const duration =\n      lastIndex !== index\n        ? chapters[index + 1].startTime - c.startTime - 1\n        : max - c.startTime\n    return {\n      startTime: c.startTime,\n      endTime: c.startTime + duration,\n      duration,\n      width: `${(duration / max) * 100}%`,\n    }\n  })\n}\n\nconst debouncedPointerHandlers = ({state, onMove, onLeave}) => {\n  const emit = () => {\n    if (!state.scheduled) {\n      return\n    }\n    state.scheduled = false\n    if (state.type === 'leave') {\n      onLeave?.(state.event, state)\n      state.gestureStatus = 'none'\n    } else {\n      onMove(state.event, state)\n    }\n  }\n  const schedule = update => {\n    if (update.type === 'change') {\n      state.gestureStatus = 'active'\n    }\n    const shouldDispatchImmediately =\n      state.type === 'change' && update.type !== 'change'\n    Object.assign(state, update)\n    if (shouldDispatchImmediately) {\n      state.type = 'leave'\n      if (state.gestureStatus === 'active') {\n        state.gestureStatus = 'releasing'\n      }\n      state.scheduled = true\n      emit()\n      return\n    }\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.type === 'pointerdown' ||\n        event.buttons > 0 ||\n        event.touches?.length > 0\n          ? 'change'\n          : 'move'\n      schedule({event, type, ...getPointerData(event)})\n    },\n    onPointerLeave: event => \n      schedule({type: 'leave', event})\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\n// TODO align with material ui more, move special handling of pointer events\nconst ChaptersSlider = ({\n  min = 0,\n  max = 100,\n  value,\n  secondaryTrackValue, // TODO a better name\n  marks = [],\n  chapters,\n  className = '',\n  classes = {},\n  disabled,\n  onPointerMove,\n  onPointerLeave,\n  onPointerDown,\n  onChange,\n  onChangeCommitted,\n}) => {\n  const pointerState = useRef({})\n  const [focusValue, setFocusValue] = useState(-Infinity)\n  const thumbPosition =\n    ((focusValue >= min ? focusValue : value) - min) / (max - min)\n  const checkSliderValue = getHorizontalSliderValue\n  const handlePointerUp = (event, handlers) => {\n    if (event.pointerId) {\n      event.currentTarget?.releasePointerCapture(event.pointerId)\n    }\n    if (!/active|releasing/.test(pointerState.current.gestureStatus)) {\n      return\n    }\n    const {x, width, left} = getPointerData(event)\n    const checkPointerValue = {x, width, left}\n    const pointerValue = (max - min) * checkSliderValue(checkPointerValue) + min\n\n    handlers.emit()\n    pointerState.current.gestureStatus = 'none'\n    onChangeCommitted?.(event, {value: pointerValue})\n    setFocusValue()\n  }\n  const pointerHandlers = debouncedPointerHandlers({\n    state: pointerState.current,\n    onMove: (event, {type, x, y, width, left}) => {\n      const checkPointerValue = {x, width, left}\n      const pointerValue =\n        (max - min) * checkSliderValue(checkPointerValue) + min\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: event => {\n      onPointerLeave?.(event)\n      handlePointerUp(event, pointerHandlers)\n    },\n  })\n\n  const thumbStyle = horizontalThumbStyle\n  const trackValue = Number.isFinite(focusValue) ? focusValue : value\n  const trackLowestPoint = {left: `calc(${thumbPosition * 100}%)`}\n  const segments = getSegments(chapters, {max, min})\n\n  return (\n    <div\n      className={className}\n      css={[style, disabled && disabledStyle]}\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: event => handlePointerUp(event, pointerHandlers),\n      })}\n    >\n      <div className={classes.rail} css={railStyle}>\n        {segments.map((segment, index) => (\n          <div\n            className={index}\n            key={index}\n            css={[\n              segmentStyle,\n              {\n                width: segment.width,\n                height: between(segment.startTime, segment.endTime, focusValue)\n                  ? '1em'\n                  : '0.66em',\n              },\n            ]}\n          >\n            {secondaryTrackValue > segment.startTime && (\n              <div\n                css={{\n                  backgroundColor: 'rgba(255, 255, 255, 0.3)',\n                  width: calculatePercentage(secondaryTrackValue, segment),\n                }}\n              />\n            )}\n            <div\n              css={{\n                width: calculatePercentage(trackValue, segment),\n              }}\n              className={classes.track}\n            />\n          </div>\n        ))}\n      </div>\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={trackLowestPoint}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nChaptersSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default ChaptersSlider\n"]} */"),
3946
- className: classes.track
3947
- })]
3948
- }, index))
3847
+ ...slotProps.rail
3848
+ }), secondaryTrackValue && jsx$1(slots.Track, {
3849
+ style: { ...trackStyle,
3850
+ backgroundColor: 'rgba(255, 255, 255, 0.3)'
3851
+ },
3852
+ orientation: orientation,
3853
+ value: subTrackPosition,
3854
+ ...slotProps.track
3855
+ }), jsx$1(slots.Track, {
3856
+ className: classes.track,
3857
+ style: trackStyle,
3858
+ orientation: orientation,
3859
+ value: thumbPosition,
3860
+ ...slotProps.track
3949
3861
  }), marks.map(position => jsx$1("div", {
3950
- css: markStyle$1,
3862
+ css: markStyle,
3951
3863
  className: classes.marked,
3952
3864
  style: {
3953
3865
  left: `${position / max * 100}%`
@@ -3955,59 +3867,102 @@ const ChaptersSlider = ({
3955
3867
  }, position)), onChange && !disabled ? jsx$1("div", {
3956
3868
  css: thumbStyle,
3957
3869
  className: classes.thumb,
3958
- style: trackLowestPoint
3870
+ style: thumbPositionStyle
3959
3871
  }) : jsx$1("div", {})]
3960
3872
  });
3961
3873
  };
3962
3874
 
3963
- ChaptersSlider.propTypes = {
3964
- min: PropTypes.number,
3965
- max: PropTypes.number,
3966
- value: PropTypes.number,
3967
- secondaryTrackValue: PropTypes.number,
3968
- marks: PropTypes.array,
3969
- className: PropTypes.string,
3970
- classes: PropTypes.object,
3971
- disabled: PropTypes.bool,
3972
- onPointerMove: PropTypes.func,
3973
- onPointerLeave: PropTypes.func,
3974
- onChange: PropTypes.func,
3975
- onChangeCommitted: PropTypes.func
3976
- };
3875
+ const getChapterIndex = (chapters, time) => chapters.reduce((currentIndex, chapter, index) => time >= chapter.startTime && chapter.startTime > chapters[currentIndex].startTime ? index : currentIndex, 0);
3977
3876
 
3978
- /* @jsxImportSource @emotion/react */
3979
- const seekbarStyle = {
3980
- position: 'relative',
3981
- display: 'flex',
3982
- alignItems: 'center',
3983
- height: '24px',
3984
- fontSize: '75%',
3985
- letterSpacing: '1px',
3986
- color: '#fff'
3987
- };
3988
- const sliderStyle = {
3989
- flex: 1,
3990
- '@media (hover: hover), screen and (-ms-high-contrast: active), (-ms-high-contrast: none)': {
3991
- '> div:last-of-type': {
3992
- opacity: 0,
3993
- transition: 'opacity 0.2s ease-out'
3877
+ const dispatchChapterEvents = ({
3878
+ media,
3879
+ chapters = [],
3880
+ getTime
3881
+ }) => {
3882
+ const state = {};
3883
+
3884
+ const updateChapter = event => {
3885
+ if (media.webkitDisplayingFullscreen) {
3886
+ return; // in iOS fullscreen UI updates are not possible, so skip
3994
3887
  }
3995
- },
3996
- '&:hover > div:last-of-type': {
3997
- opacity: 1
3998
- }
3999
- };
4000
3888
 
4001
- const getSliderStyle = css => ({
4002
- thumb: css({
4003
- width: '1.33em',
4004
- height: '1.33em',
4005
- backgroundColor: 'var(--theme-color)'
4006
- }),
4007
- track: css({
4008
- backgroundColor: 'var(--theme-color)'
4009
- })
4010
- });
3889
+ const next = getChapterIndex(chapters, getTime());
3890
+
3891
+ if (next !== state.currentChapterIndex) {
3892
+ media.dispatchEvent(Object.assign(new CustomEvent('chapterChange'), {
3893
+ action: /seek/.test(event === null || event === void 0 ? void 0 : event.type) ? 'seek' : '',
3894
+ chapterIndex: next,
3895
+ chapter: chapters[next]
3896
+ }));
3897
+ }
3898
+
3899
+ state.currentChapterIndex = next;
3900
+ };
3901
+
3902
+ const listeners = [on(media, 'seeking', updateChapter), on(media, 'timeupdate', updateChapter), on(media, 'seeked', updateChapter), on(media, 'webkitendfullscreen', updateChapter)];
3903
+ const checkInterval = setInterval(() => {
3904
+ var _chapters;
3905
+
3906
+ const timeToNext = (((_chapters = chapters[state.currentChapterIndex + 1]) === null || _chapters === void 0 ? void 0 : _chapters.startTime) - getTime() + 0.05) / media.playbackRate;
3907
+
3908
+ if (timeToNext >= 0 && timeToNext <= 1) {
3909
+ state.timerId = setTimeout(updateChapter, timeToNext * 1000);
3910
+ }
3911
+ }, 1000);
3912
+ return () => {
3913
+ clearInterval(checkInterval);
3914
+ clearInterval(state.timerId);
3915
+ listeners.forEach(removeListener => removeListener());
3916
+ };
3917
+ };
3918
+
3919
+ const getTimelineSegments = (chapters, {
3920
+ startTime,
3921
+ current,
3922
+ buffered,
3923
+ duration
3924
+ }) => (chapters.length === 0 ? [{
3925
+ startTime
3926
+ }] : chapters).map((chapter, index) => {
3927
+ var _chapters2;
3928
+
3929
+ const length = (((_chapters2 = chapters[index + 1]) === null || _chapters2 === void 0 ? void 0 : _chapters2.startTime) || duration) - chapter.startTime;
3930
+ return {
3931
+ length: length / duration,
3932
+ current: Math.min(Math.max(0, (current - chapter.startTime) / length), 1),
3933
+ buffered: Math.min(Math.max(0, (buffered - chapter.startTime) / length), 1)
3934
+ };
3935
+ });
3936
+
3937
+ /* @jsxImportSource @emotion/react */
3938
+ const seekbarStyle = {
3939
+ position: 'relative',
3940
+ display: 'flex',
3941
+ alignItems: 'center',
3942
+ minWidth: '0',
3943
+ height: '24px',
3944
+ fontSize: '75%',
3945
+ letterSpacing: '1px',
3946
+ color: '#fff'
3947
+ };
3948
+ const sliderStyle = {
3949
+ minWidth: '0',
3950
+ flex: 1,
3951
+ '@media (hover: hover), screen and (-ms-high-contrast: active), (-ms-high-contrast: none)': {
3952
+ '> div:last-of-type': {
3953
+ opacity: 0,
3954
+ transition: 'opacity 0.2s ease-out'
3955
+ }
3956
+ },
3957
+ '> div:last-of-type': {
3958
+ width: '1.2em',
3959
+ height: '1.2em',
3960
+ background: 'var(--theme-color, red)'
3961
+ },
3962
+ '&:hover > div:last-of-type': {
3963
+ opacity: 1
3964
+ }
3965
+ };
4011
3966
 
4012
3967
  const reducePointer = (state, {
4013
3968
  type,
@@ -4042,7 +3997,63 @@ const reducePointer = (state, {
4042
3997
  default:
4043
3998
  return state;
4044
3999
  }
4045
- }; // TODO use className instead of classes ?
4000
+ };
4001
+
4002
+ const SeekbarRail = () => '';
4003
+
4004
+ const segmentedTrackStyle = {
4005
+ position: 'relative',
4006
+ margin: '0 2px',
4007
+ height: '24px',
4008
+ borderTop: 'calc(12px - 0.3em) solid transparent',
4009
+ borderBottom: 'calc(12px - 0.3em) solid transparent',
4010
+ background: 'transparent',
4011
+ '&:hover': {
4012
+ transform: 'scale(1, 1.5)'
4013
+ },
4014
+ '> div': {
4015
+ height: '0.6em',
4016
+ backgroundColor: 'rgba(255, 255, 255, 0.2)',
4017
+ '&:not(:first-of-type)': {
4018
+ position: 'absolute',
4019
+ top: '0'
4020
+ }
4021
+ },
4022
+ '> div:nth-of-type(2)': {
4023
+ backgroundColor: 'rgba(255, 255, 255, 0.3)'
4024
+ },
4025
+ '> div:nth-of-type(3)': {
4026
+ backgroundColor: 'var(--theme-color, red)'
4027
+ }
4028
+ };
4029
+
4030
+ const SeekbarTrack = ({
4031
+ segments,
4032
+ style
4033
+ }) => segments.map(({
4034
+ length,
4035
+ current,
4036
+ buffered
4037
+ }) => jsxs("div", {
4038
+ 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= */"],
4039
+ style: {
4040
+ flex: `0 ${length * 100}%`,
4041
+ width: `calc(${length * 100}% - 4px)`
4042
+ },
4043
+ children: [jsx$1("div", {
4044
+ style: {
4045
+ width: '100%'
4046
+ }
4047
+ }), jsx$1("div", {
4048
+ style: {
4049
+ width: `${buffered * 100}%`
4050
+ }
4051
+ }), jsx$1("div", {
4052
+ style: {
4053
+ width: `${current * 100}%`
4054
+ }
4055
+ })]
4056
+ })); // TODO use className instead of classes ?
4046
4057
 
4047
4058
 
4048
4059
  const Seekbar = ({
@@ -4052,7 +4063,7 @@ const Seekbar = ({
4052
4063
  currentTime,
4053
4064
  bufferTime,
4054
4065
  duration,
4055
- chapters,
4066
+ chapters = [],
4056
4067
  marks,
4057
4068
  timeDisplay = false,
4058
4069
  // TODO more scalable way?
@@ -4114,12 +4125,18 @@ const Seekbar = ({
4114
4125
  }
4115
4126
  };
4116
4127
  const endTime = startTime + duration;
4128
+ const segments = getTimelineSegments(chapters, {
4129
+ startTime,
4130
+ current: pointerState.focused ? pointerState.value : currentTime,
4131
+ buffered: bufferTime,
4132
+ duration
4133
+ });
4117
4134
  return !(duration > 0) ? jsx$1("div", {}) : jsxs("div", {
4118
4135
  ref: element => {
4119
4136
  observe(element);
4120
4137
  ref.current = element;
4121
4138
  },
4122
- css: [seekbarStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEdNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB7Q2xhc3NOYW1lc30gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnXG5pbXBvcnQgdXNlRGltZW5zaW9ucyBmcm9tICdyZWFjdC1jb29sLWRpbWVuc2lvbnMnXG5pbXBvcnQgQ2hhcHRlcnNTbGlkZXIgZnJvbSAncGxheWVyVWkvQ2hhcHRlcnNTbGlkZXInXG5pbXBvcnQge0Zvcm1hdHRlZFRpbWV9IGZyb20gJ2NvbnRleHQvSTE4bidcblxuY29uc3Qgc2Vla2JhclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgaGVpZ2h0OiAnMjRweCcsXG4gIGZvbnRTaXplOiAnNzUlJyxcbiAgbGV0dGVyU3BhY2luZzogJzFweCcsXG4gIGNvbG9yOiAnI2ZmZicsXG59XG5cbmNvbnN0IHNsaWRlclN0eWxlID0ge1xuICBmbGV4OiAxLFxuICAnQG1lZGlhIChob3ZlcjogaG92ZXIpLCBzY3JlZW4gYW5kICgtbXMtaGlnaC1jb250cmFzdDogYWN0aXZlKSwgKC1tcy1oaWdoLWNvbnRyYXN0OiBub25lKSc6XG4gICAge1xuICAgICAgJz4gZGl2Omxhc3Qtb2YtdHlwZSc6IHtcbiAgICAgICAgb3BhY2l0eTogMCxcbiAgICAgICAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4ycyBlYXNlLW91dCcsXG4gICAgICB9LFxuICAgIH0sXG4gICcmOmhvdmVyID4gZGl2Omxhc3Qtb2YtdHlwZSc6IHtcbiAgICBvcGFjaXR5OiAxLFxuICB9LFxufVxuXG5jb25zdCBnZXRTbGlkZXJTdHlsZSA9IGNzcyA9PiAoe1xuICB0aHVtYjogY3NzKHtcbiAgICB3aWR0aDogJzEuMzNlbScsXG4gICAgaGVpZ2h0OiAnMS4zM2VtJyxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICd2YXIoLS10aGVtZS1jb2xvciknLFxuICB9KSxcbiAgdHJhY2s6IGNzcyh7YmFja2dyb3VuZENvbG9yOiAndmFyKC0tdGhlbWUtY29sb3IpJ30pLFxufSlcblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG4vLyBUT0RPIHVzZSBjbGFzc05hbWUgaW5zdGVhZCBvZiBjbGFzc2VzID9cbmNvbnN0IFNlZWtiYXIgPSAoe1xuICBzdHlsZSxcbiAgY2xhc3NlcyxcbiAgc3RhcnRUaW1lID0gMCxcbiAgY3VycmVudFRpbWUsXG4gIGJ1ZmZlclRpbWUsXG4gIGR1cmF0aW9uLFxuICBjaGFwdGVycyxcbiAgbWFya3MsXG4gIHRpbWVEaXNwbGF5ID0gZmFsc2UsIC8vIFRPRE8gbW9yZSBzY2FsYWJsZSB3YXk/XG4gIG9uQ2hhbmdlLFxuICBvbkNoYW5nZUNvbW1pdHRlZCxcbiAgY2hpbGRyZW4sXG4gIG9uUG9pbnRlck1vdmUsXG4gIG9uUG9pbnRlckxlYXZlLFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IFtwb2ludGVyU3RhdGUsIGRpc3BhdGNoUG9pbnRlcl0gPSB1c2VSZWR1Y2VyKHJlZHVjZVBvaW50ZXIsIHt9KVxuICBjb25zdCBwb2ludGVyQWN0aXZlID0gcG9pbnRlclN0YXRlLmhvdmVyIHx8IHBvaW50ZXJTdGF0ZS5mb2N1c2VkXG4gIC8vIHRvIHJlZmxlY3QgYm91bmRhcnkgd2hlbiBjb250YWluZXIgcmVzaXplZFxuICBjb25zdCB7b2JzZXJ2ZX0gPSB1c2VEaW1lbnNpb25zKClcbiAgY29uc3QgcmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVjdCA9IHJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKVxuICBjb25zdCBoYW5kbGVycyA9IG9uQ2hhbmdlQ29tbWl0dGVkICYmIHtcbiAgICBvblBvaW50ZXJNb3ZlOiAoZXZlbnQsIHt2YWx1ZSwgeH0pID0+IHtcbiAgICAgIG9uUG9pbnRlck1vdmU/LihldmVudCwge3ZhbHVlLCB4fSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ21vdmUnLCB2YWx1ZSwgeH0pXG4gICAgfSxcbiAgICBvblBvaW50ZXJMZWF2ZTogZXZlbnQgPT4ge1xuICAgICAgb25Qb2ludGVyTGVhdmU/LihldmVudClcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2xlYXZlJ30pXG4gICAgfSxcbiAgICBvbkNoYW5nZTogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4odmFsdWUpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdjaGFuZ2UnLCB2YWx1ZX0pXG4gICAgfSxcbiAgICBvbkNoYW5nZUNvbW1pdHRlZDogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ3JlbGVhc2UnLCB2YWx1ZX0pXG4gICAgICBvbkNoYW5nZUNvbW1pdHRlZD8uKHZhbHVlKVxuICAgIH0sXG4gIH1cbiAgY29uc3QgZW5kVGltZSA9IHN0YXJ0VGltZSArIGR1cmF0aW9uXG5cbiAgcmV0dXJuICEoZHVyYXRpb24gPiAwKSA/IChcbiAgICA8ZGl2IC8+XG4gICkgOiAoXG4gICAgPGRpdlxuICAgICAgcmVmPXtlbGVtZW50ID0+IHtcbiAgICAgICAgb2JzZXJ2ZShlbGVtZW50KVxuICAgICAgICByZWYuY3VycmVudCA9IGVsZW1lbnRcbiAgICAgIH19XG4gICAgICBjc3M9e1tzZWVrYmFyU3R5bGUsIHN0eWxlXX1cbiAgICAgIHN0eWxlPXtcbiAgICAgICAgcmVjdCAmJiB7XG4gICAgICAgICAgJy0tc2Vla2Jhci1sZWZ0JzogYCR7cmVjdC5sZWZ0fXB4YCxcbiAgICAgICAgICAnLS1zZWVrYmFyLXJpZ2h0JzogYCR7cmVjdC5yaWdodH1weGAsXG4gICAgICAgICAgJy0tcG9pbnRlci14JzogYCR7cG9pbnRlclN0YXRlLnh9cHhgLFxuICAgICAgICB9XG4gICAgICB9XG4gICAgPlxuICAgICAgeyF0aW1lRGlzcGxheSA/IChcbiAgICAgICAgJydcbiAgICAgICkgOiBwb2ludGVyQWN0aXZlID8gKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtwb2ludGVyU3RhdGUudmFsdWV9IC8+XG4gICAgICApIDogKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtNYXRoLm1pbihNYXRoLm1heCgwLCBjdXJyZW50VGltZSksIGR1cmF0aW9uKX0gLz5cbiAgICAgICl9XG4gICAgICA8Q2xhc3NOYW1lcz5cbiAgICAgICAgeyh7Y3NzfSkgPT4gKFxuICAgICAgICAgIDxDaGFwdGVyc1NsaWRlclxuICAgICAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgICAgIGNsYXNzZXM9e3tcbiAgICAgICAgICAgICAgLi4uZ2V0U2xpZGVyU3R5bGUoY3NzKSxcbiAgICAgICAgICAgICAgLi4uY2xhc3NlcyxcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBkaXNhYmxlZD17IW9uQ2hhbmdlQ29tbWl0dGVkfVxuICAgICAgICAgICAgc2Vjb25kYXJ5VHJhY2tWYWx1ZT17YnVmZmVyVGltZX1cbiAgICAgICAgICAgIC8vIGRpc3BsYXkgZmlsbGVkIHdoZW4gc2VlayBoYW5kbGVyIGlzIG5vdCBwcm92aWRlZCwgZnJvbSBQbGF5Qm95IGJlaGF2aW9yXG4gICAgICAgICAgICB2YWx1ZT17b25DaGFuZ2VDb21taXR0ZWQgPyBjdXJyZW50VGltZSA6IGVuZFRpbWV9XG4gICAgICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgICAgIG1heD17ZW5kVGltZX1cbiAgICAgICAgICAgIG1hcmtzPXttYXJrc31cbiAgICAgICAgICAgIGNoYXB0ZXJzPXtjaGFwdGVyc31cbiAgICAgICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAgIC8+XG4gICAgICAgICl9XG4gICAgICA8L0NsYXNzTmFtZXM+XG4gICAgICB7dGltZURpc3BsYXkgJiYgPEZvcm1hdHRlZFRpbWUgdGltZT17ZHVyYXRpb259IC8+fVxuICAgICAge2NoaWxkcmVuICYmXG4gICAgICAgIFtdXG4gICAgICAgICAgLmNvbmNhdChjaGlsZHJlbilcbiAgICAgICAgICAubWFwKGNoaWxkID0+XG4gICAgICAgICAgICBjbG9uZUVsZW1lbnQoY2hpbGQsIHt0aW1lOiBwb2ludGVyQWN0aXZlICYmIHBvaW50ZXJTdGF0ZS52YWx1ZX0pXG4gICAgICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5TZWVrYmFyLnByb3BUeXBlcyA9IHtcbiAgc3R5bGU6IFByb3BUeXBlcy5vYmplY3QsXG4gIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QsXG4gIGN1cnJlbnRUaW1lOiBQcm9wVHlwZXMubnVtYmVyLFxuICBidWZmZXJUaW1lOiBQcm9wVHlwZXMubnVtYmVyLFxuICBkdXJhdGlvbjogUHJvcFR5cGVzLm51bWJlcixcbiAgbWFya3M6IFByb3BUeXBlcy5hcnJheSxcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufVxuXG5leHBvcnQgZGVmYXVsdCBTZWVrYmFyXG4iXX0= */"],
4139
+ 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= */"],
4123
4140
  style: rect && {
4124
4141
  '--seekbar-left': `${rect.left}px`,
4125
4142
  '--seekbar-right': `${rect.right}px`,
@@ -4129,27 +4146,28 @@ const Seekbar = ({
4129
4146
  time: pointerState.value
4130
4147
  }) : jsx$1(FormattedTime, {
4131
4148
  time: Math.min(Math.max(0, currentTime), duration)
4132
- }), jsx$1(ClassNames, {
4133
- children: ({
4134
- css
4135
- }) => jsx$1(ChaptersSlider, {
4136
- css: [sliderStyle, timeDisplay && {
4137
- margin: '0 1em'
4138
- }, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0hZIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB7Q2xhc3NOYW1lc30gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnXG5pbXBvcnQgdXNlRGltZW5zaW9ucyBmcm9tICdyZWFjdC1jb29sLWRpbWVuc2lvbnMnXG5pbXBvcnQgQ2hhcHRlcnNTbGlkZXIgZnJvbSAncGxheWVyVWkvQ2hhcHRlcnNTbGlkZXInXG5pbXBvcnQge0Zvcm1hdHRlZFRpbWV9IGZyb20gJ2NvbnRleHQvSTE4bidcblxuY29uc3Qgc2Vla2JhclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgaGVpZ2h0OiAnMjRweCcsXG4gIGZvbnRTaXplOiAnNzUlJyxcbiAgbGV0dGVyU3BhY2luZzogJzFweCcsXG4gIGNvbG9yOiAnI2ZmZicsXG59XG5cbmNvbnN0IHNsaWRlclN0eWxlID0ge1xuICBmbGV4OiAxLFxuICAnQG1lZGlhIChob3ZlcjogaG92ZXIpLCBzY3JlZW4gYW5kICgtbXMtaGlnaC1jb250cmFzdDogYWN0aXZlKSwgKC1tcy1oaWdoLWNvbnRyYXN0OiBub25lKSc6XG4gICAge1xuICAgICAgJz4gZGl2Omxhc3Qtb2YtdHlwZSc6IHtcbiAgICAgICAgb3BhY2l0eTogMCxcbiAgICAgICAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4ycyBlYXNlLW91dCcsXG4gICAgICB9LFxuICAgIH0sXG4gICcmOmhvdmVyID4gZGl2Omxhc3Qtb2YtdHlwZSc6IHtcbiAgICBvcGFjaXR5OiAxLFxuICB9LFxufVxuXG5jb25zdCBnZXRTbGlkZXJTdHlsZSA9IGNzcyA9PiAoe1xuICB0aHVtYjogY3NzKHtcbiAgICB3aWR0aDogJzEuMzNlbScsXG4gICAgaGVpZ2h0OiAnMS4zM2VtJyxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICd2YXIoLS10aGVtZS1jb2xvciknLFxuICB9KSxcbiAgdHJhY2s6IGNzcyh7YmFja2dyb3VuZENvbG9yOiAndmFyKC0tdGhlbWUtY29sb3IpJ30pLFxufSlcblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG4vLyBUT0RPIHVzZSBjbGFzc05hbWUgaW5zdGVhZCBvZiBjbGFzc2VzID9cbmNvbnN0IFNlZWtiYXIgPSAoe1xuICBzdHlsZSxcbiAgY2xhc3NlcyxcbiAgc3RhcnRUaW1lID0gMCxcbiAgY3VycmVudFRpbWUsXG4gIGJ1ZmZlclRpbWUsXG4gIGR1cmF0aW9uLFxuICBjaGFwdGVycyxcbiAgbWFya3MsXG4gIHRpbWVEaXNwbGF5ID0gZmFsc2UsIC8vIFRPRE8gbW9yZSBzY2FsYWJsZSB3YXk/XG4gIG9uQ2hhbmdlLFxuICBvbkNoYW5nZUNvbW1pdHRlZCxcbiAgY2hpbGRyZW4sXG4gIG9uUG9pbnRlck1vdmUsXG4gIG9uUG9pbnRlckxlYXZlLFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IFtwb2ludGVyU3RhdGUsIGRpc3BhdGNoUG9pbnRlcl0gPSB1c2VSZWR1Y2VyKHJlZHVjZVBvaW50ZXIsIHt9KVxuICBjb25zdCBwb2ludGVyQWN0aXZlID0gcG9pbnRlclN0YXRlLmhvdmVyIHx8IHBvaW50ZXJTdGF0ZS5mb2N1c2VkXG4gIC8vIHRvIHJlZmxlY3QgYm91bmRhcnkgd2hlbiBjb250YWluZXIgcmVzaXplZFxuICBjb25zdCB7b2JzZXJ2ZX0gPSB1c2VEaW1lbnNpb25zKClcbiAgY29uc3QgcmVmID0gdXNlUmVmKClcbiAgY29uc3QgcmVjdCA9IHJlZi5jdXJyZW50Py5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKVxuICBjb25zdCBoYW5kbGVycyA9IG9uQ2hhbmdlQ29tbWl0dGVkICYmIHtcbiAgICBvblBvaW50ZXJNb3ZlOiAoZXZlbnQsIHt2YWx1ZSwgeH0pID0+IHtcbiAgICAgIG9uUG9pbnRlck1vdmU/LihldmVudCwge3ZhbHVlLCB4fSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ21vdmUnLCB2YWx1ZSwgeH0pXG4gICAgfSxcbiAgICBvblBvaW50ZXJMZWF2ZTogZXZlbnQgPT4ge1xuICAgICAgb25Qb2ludGVyTGVhdmU/LihldmVudClcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2xlYXZlJ30pXG4gICAgfSxcbiAgICBvbkNoYW5nZTogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIG9uQ2hhbmdlPy4odmFsdWUpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdjaGFuZ2UnLCB2YWx1ZX0pXG4gICAgfSxcbiAgICBvbkNoYW5nZUNvbW1pdHRlZDogKF8sIHt2YWx1ZX0pID0+IHtcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ3JlbGVhc2UnLCB2YWx1ZX0pXG4gICAgICBvbkNoYW5nZUNvbW1pdHRlZD8uKHZhbHVlKVxuICAgIH0sXG4gIH1cbiAgY29uc3QgZW5kVGltZSA9IHN0YXJ0VGltZSArIGR1cmF0aW9uXG5cbiAgcmV0dXJuICEoZHVyYXRpb24gPiAwKSA/IChcbiAgICA8ZGl2IC8+XG4gICkgOiAoXG4gICAgPGRpdlxuICAgICAgcmVmPXtlbGVtZW50ID0+IHtcbiAgICAgICAgb2JzZXJ2ZShlbGVtZW50KVxuICAgICAgICByZWYuY3VycmVudCA9IGVsZW1lbnRcbiAgICAgIH19XG4gICAgICBjc3M9e1tzZWVrYmFyU3R5bGUsIHN0eWxlXX1cbiAgICAgIHN0eWxlPXtcbiAgICAgICAgcmVjdCAmJiB7XG4gICAgICAgICAgJy0tc2Vla2Jhci1sZWZ0JzogYCR7cmVjdC5sZWZ0fXB4YCxcbiAgICAgICAgICAnLS1zZWVrYmFyLXJpZ2h0JzogYCR7cmVjdC5yaWdodH1weGAsXG4gICAgICAgICAgJy0tcG9pbnRlci14JzogYCR7cG9pbnRlclN0YXRlLnh9cHhgLFxuICAgICAgICB9XG4gICAgICB9XG4gICAgPlxuICAgICAgeyF0aW1lRGlzcGxheSA/IChcbiAgICAgICAgJydcbiAgICAgICkgOiBwb2ludGVyQWN0aXZlID8gKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtwb2ludGVyU3RhdGUudmFsdWV9IC8+XG4gICAgICApIDogKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtNYXRoLm1pbihNYXRoLm1heCgwLCBjdXJyZW50VGltZSksIGR1cmF0aW9uKX0gLz5cbiAgICAgICl9XG4gICAgICA8Q2xhc3NOYW1lcz5cbiAgICAgICAgeyh7Y3NzfSkgPT4gKFxuICAgICAgICAgIDxDaGFwdGVyc1NsaWRlclxuICAgICAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgICAgIGNsYXNzZXM9e3tcbiAgICAgICAgICAgICAgLi4uZ2V0U2xpZGVyU3R5bGUoY3NzKSxcbiAgICAgICAgICAgICAgLi4uY2xhc3NlcyxcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBkaXNhYmxlZD17IW9uQ2hhbmdlQ29tbWl0dGVkfVxuICAgICAgICAgICAgc2Vjb25kYXJ5VHJhY2tWYWx1ZT17YnVmZmVyVGltZX1cbiAgICAgICAgICAgIC8vIGRpc3BsYXkgZmlsbGVkIHdoZW4gc2VlayBoYW5kbGVyIGlzIG5vdCBwcm92aWRlZCwgZnJvbSBQbGF5Qm95IGJlaGF2aW9yXG4gICAgICAgICAgICB2YWx1ZT17b25DaGFuZ2VDb21taXR0ZWQgPyBjdXJyZW50VGltZSA6IGVuZFRpbWV9XG4gICAgICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgICAgIG1heD17ZW5kVGltZX1cbiAgICAgICAgICAgIG1hcmtzPXttYXJrc31cbiAgICAgICAgICAgIGNoYXB0ZXJzPXtjaGFwdGVyc31cbiAgICAgICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgICAgIHsuLi5yZXN0fVxuICAgICAgICAgIC8+XG4gICAgICAgICl9XG4gICAgICA8L0NsYXNzTmFtZXM+XG4gICAgICB7dGltZURpc3BsYXkgJiYgPEZvcm1hdHRlZFRpbWUgdGltZT17ZHVyYXRpb259IC8+fVxuICAgICAge2NoaWxkcmVuICYmXG4gICAgICAgIFtdXG4gICAgICAgICAgLmNvbmNhdChjaGlsZHJlbilcbiAgICAgICAgICAubWFwKGNoaWxkID0+XG4gICAgICAgICAgICBjbG9uZUVsZW1lbnQoY2hpbGQsIHt0aW1lOiBwb2ludGVyQWN0aXZlICYmIHBvaW50ZXJTdGF0ZS52YWx1ZX0pXG4gICAgICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5TZWVrYmFyLnByb3BUeXBlcyA9IHtcbiAgc3R5bGU6IFByb3BUeXBlcy5vYmplY3QsXG4gIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QsXG4gIGN1cnJlbnRUaW1lOiBQcm9wVHlwZXMubnVtYmVyLFxuICBidWZmZXJUaW1lOiBQcm9wVHlwZXMubnVtYmVyLFxuICBkdXJhdGlvbjogUHJvcFR5cGVzLm51bWJlcixcbiAgbWFya3M6IFByb3BUeXBlcy5hcnJheSxcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufVxuXG5leHBvcnQgZGVmYXVsdCBTZWVrYmFyXG4iXX0= */"],
4139
- classes: { ...getSliderStyle(css),
4140
- ...classes
4141
- },
4142
- disabled: !onChangeCommitted,
4143
- secondaryTrackValue: bufferTime // display filled when seek handler is not provided, from PlayBoy behavior
4144
- ,
4145
- value: onChangeCommitted ? currentTime : endTime,
4146
- min: startTime,
4147
- max: endTime,
4148
- marks: marks,
4149
- chapters: chapters,
4150
- ...handlers,
4151
- ...rest
4152
- })
4149
+ }), jsx$1(SimpleSlider, {
4150
+ css: [sliderStyle, timeDisplay && {
4151
+ margin: '0 1em'
4152
+ }, 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= */"],
4153
+ classes: classes,
4154
+ disabled: !onChangeCommitted // display filled when seek handler is not provided, from PlayBoy behavior
4155
+ ,
4156
+ value: onChangeCommitted ? currentTime : endTime,
4157
+ min: startTime,
4158
+ max: endTime,
4159
+ marks: marks,
4160
+ ...handlers,
4161
+ ...rest,
4162
+ slots: {
4163
+ Rail: SeekbarRail,
4164
+ Track: SeekbarTrack
4165
+ },
4166
+ slotProps: {
4167
+ track: {
4168
+ segments
4169
+ }
4170
+ }
4153
4171
  }), timeDisplay && jsx$1(FormattedTime, {
4154
4172
  time: duration
4155
4173
  }), children && [].concat(children).map(child => /*#__PURE__*/cloneElement(child, {
@@ -4158,16 +4176,6 @@ const Seekbar = ({
4158
4176
  });
4159
4177
  };
4160
4178
 
4161
- Seekbar.propTypes = {
4162
- style: PropTypes.object,
4163
- classes: PropTypes.object,
4164
- currentTime: PropTypes.number,
4165
- bufferTime: PropTypes.number,
4166
- duration: PropTypes.number,
4167
- marks: PropTypes.array,
4168
- children: PropTypes.node
4169
- };
4170
-
4171
4179
  const DisplayTime = ({
4172
4180
  startTime,
4173
4181
  currentTime,
@@ -4206,7 +4214,7 @@ const defaultLoadingIcon = `<svg width="24" height="24" fill="none" xmlns="http:
4206
4214
  </linearGradient>
4207
4215
  </defs>
4208
4216
  </svg>`;
4209
- const style$2 = {
4217
+ const style$1 = {
4210
4218
  position: 'absolute',
4211
4219
  top: '50%',
4212
4220
  left: '50%',
@@ -4219,13 +4227,36 @@ const style$2 = {
4219
4227
  animation: `${rotateInfinite} 1.2s linear infinite`,
4220
4228
  pointerEvents: 'none'
4221
4229
  };
4230
+ const hiddenStyle$1 = {
4231
+ opacity: 0
4232
+ };
4222
4233
 
4223
- const LoadingSpinner = props => jsx$1("div", { ...props,
4224
- css: style$2
4225
- });
4234
+ const useDeferredActive = active => {
4235
+ const [status, setStatus] = useState('init');
4236
+ useEffect(() => {
4237
+ if (!active) {
4238
+ return;
4239
+ }
4240
+
4241
+ setStatus(current => current === 'init' ? 'ready' : 'pending');
4242
+ const timer = setTimeout(() => setStatus('ready'), 1000);
4243
+ return () => clearTimeout(timer);
4244
+ }, [active]);
4245
+ return status === 'ready' && active;
4246
+ };
4247
+
4248
+ const LoadingSpinner = ({
4249
+ active,
4250
+ ...props
4251
+ }) => {
4252
+ const current = useDeferredActive(active);
4253
+ return jsx$1("div", { ...props,
4254
+ css: [style$1, !current && hiddenStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:LoadingSpinner;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxvYWRpbmdTcGlubmVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREeUIiLCJmaWxlIjoiTG9hZGluZ1NwaW5uZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2tleWZyYW1lc30gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0J1xuXG5jb25zdCByb3RhdGVJbmZpbml0ZSA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIC01MCUpIHJvdGF0ZSgwZGVnKTtcbiAgfVxuICAxMDAlICB7XG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoLTUwJSwgLTUwJSkgcm90YXRlKDM2MGRlZyk7IFxuICB9XG5gXG5cbmNvbnN0IGRlZmF1bHRMb2FkaW5nSWNvbiA9IGA8c3ZnIHdpZHRoPVwiMjRcIiBoZWlnaHQ9XCIyNFwiIGZpbGw9XCJub25lXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuPHBhdGggZD1cIk0xMS43NiAyMmEuOC44IDAgMCAxIDAtMS42QTguNCA4LjQgMCAxIDAgNC41IDcuOC44LjggMCAwIDEgMy4xIDdhMTAgMTAgMCAxIDEgOC42NiAxNVpcIiBmaWxsPVwidXJsKCNhKVwiIC8+XG48ZGVmcz5cbiAgPGxpbmVhckdyYWRpZW50IGlkPVwiYVwiIHgxPVwiLjk2XCIgeTE9XCIzLjY3XCIgeDI9XCIzMC41NFwiIHkyPVwiMzMuMjVcIiBncmFkaWVudFVuaXRzPVwidXNlclNwYWNlT25Vc2VcIj5cbiAgICA8c3RvcCBzdG9wLWNvbG9yPVwiI2ZmZlwiIHN0b3Atb3BhY2l0eT1cIjBcIiAvPlxuICAgIDxzdG9wIG9mZnNldD1cIi43M1wiIHN0b3AtY29sb3I9XCIjZmZmXCIgLz5cbiAgICA8c3RvcCBvZmZzZXQ9XCIxXCIgc3RvcC1jb2xvcj1cIiNmZmZcIiAvPlxuICA8L2xpbmVhckdyYWRpZW50PlxuPC9kZWZzPlxuPC9zdmc+YFxuXG5jb25zdCBzdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICBkaXNwbGF5OiAnYmxvY2snLFxuICBoZWlnaHQ6ICczZW0nLFxuICB3aWR0aDogJzNlbScsXG4gIGJhY2tncm91bmRQb3NpdGlvbjogJ2NlbnRlcicsXG4gIGJhY2tncm91bmRTaXplOiAnY292ZXInLFxuICBiYWNrZ3JvdW5kSW1hZ2U6IGB2YXIoLS1pY29uLWxvYWRpbmcsIHVybChkYXRhOmltYWdlL3N2Zyt4bWw7YmFzZTY0LCR7YnRvYShcbiAgICBkZWZhdWx0TG9hZGluZ0ljb25cbiAgKX0pKWAsXG4gIGFuaW1hdGlvbjogYCR7cm90YXRlSW5maW5pdGV9IDEuMnMgbGluZWFyIGluZmluaXRlYCxcbiAgcG9pbnRlckV2ZW50czogJ25vbmUnLFxufVxuXG5jb25zdCBoaWRkZW5TdHlsZSA9IHtcbiAgb3BhY2l0eTogMCxcbn1cblxuY29uc3QgdXNlRGVmZXJyZWRBY3RpdmUgPSBhY3RpdmUgPT4ge1xuICBjb25zdCBbc3RhdHVzLCBzZXRTdGF0dXNdID0gdXNlU3RhdGUoJ2luaXQnKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmICghYWN0aXZlKSB7XG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgc2V0U3RhdHVzKGN1cnJlbnQgPT4gKGN1cnJlbnQgPT09ICdpbml0JyA/ICdyZWFkeScgOiAncGVuZGluZycpKVxuICAgIGNvbnN0IHRpbWVyID0gc2V0VGltZW91dCgoKSA9PiBzZXRTdGF0dXMoJ3JlYWR5JyksIDEwMDApXG4gICAgcmV0dXJuICgpID0+IGNsZWFyVGltZW91dCh0aW1lcilcbiAgfSwgW2FjdGl2ZV0pXG5cbiAgcmV0dXJuIHN0YXR1cyA9PT0gJ3JlYWR5JyAmJiBhY3RpdmVcbn1cblxuY29uc3QgTG9hZGluZ1NwaW5uZXIgPSAoe2FjdGl2ZSwgLi4ucHJvcHN9KSA9PiB7XG4gIGNvbnN0IGN1cnJlbnQgPSB1c2VEZWZlcnJlZEFjdGl2ZShhY3RpdmUpXG4gIHJldHVybiA8ZGl2IHsuLi5wcm9wc30gY3NzPXtbc3R5bGUsICFjdXJyZW50ICYmIGhpZGRlblN0eWxlXX0gLz5cbn1cblxuZXhwb3J0IGRlZmF1bHQgTG9hZGluZ1NwaW5uZXJcbiJdfQ== */"]
4255
+ });
4256
+ };
4226
4257
 
4227
4258
  /* eslint-disable react/jsx-props-no-spreading */
4228
- const styles$2 = {
4259
+ const styles = {
4229
4260
  overlay: {
4230
4261
  position: 'fixed',
4231
4262
  right: 0,
@@ -4304,7 +4335,7 @@ const SwipeableDrawer = ({
4304
4335
  }, [open]);
4305
4336
  return /*#__PURE__*/createPortal(jsx$1(Backdrop, {
4306
4337
  style: { ...style,
4307
- ...styles$2.overlay
4338
+ ...styles.overlay
4308
4339
  },
4309
4340
  renderAt: "always",
4310
4341
  open: open,
@@ -4317,12 +4348,12 @@ const SwipeableDrawer = ({
4317
4348
  '--slide-position': `${swipePosition}px`
4318
4349
  } // start swipping after moving far enough, and lock scrolling
4319
4350
  ,
4320
- css: [styles$2.container, open && styles$2.slideUp, swipePosition > 23 && styles$2.swipping, process.env.NODE_ENV === "production" ? "" : ";label:SwipeableDrawer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN3aXBlYWJsZURyYXdlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtR1EiLCJmaWxlIjoiU3dpcGVhYmxlRHJhd2VyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHt1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVN0YXRlfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7Y3JlYXRlUG9ydGFsfSBmcm9tICdyZWFjdC1kb20nXG5pbXBvcnQge2dldFRvcEVsZW1lbnR9IGZyb20gJ3V0aWwvdmlld01vZGVzJ1xuaW1wb3J0IHtwb2ludGVySGFuZGxlcnN9IGZyb20gJ3V0aWwvZ2VzdHVyZXMnXG5pbXBvcnQgQmFja2Ryb3AgZnJvbSAnLi9CYWNrZHJvcCdcblxuY29uc3Qgc3R5bGVzID0ge1xuICBvdmVybGF5OiB7XG4gICAgcG9zaXRpb246ICdmaXhlZCcsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIGFsaWduQ29udGVudDogJ2ZsZXgtZW5kJyxcbiAgICB0b3VjaEFjdGlvbjogJ25vbmUnLFxuICB9LFxuICBjb250YWluZXI6IHtcbiAgICBmbGV4OiAnMCBjYWxjKDEwMCUgLSAycmVtKScsXG4gICAgZm9udFNpemU6ICcxcmVtJyxcbiAgICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKDEwMCUpJyxcbiAgICB0cmFuc2l0aW9uOiAndHJhbnNmb3JtIDAuMnMgZWFzZS1vdXQnLFxuICAgICc+IConOiB7XG4gICAgICB0b3VjaEFjdGlvbjogJ3Bhbi15JyxcbiAgICB9LFxuICB9LFxuICBzbGlkZVVwOiB7XG4gICAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSh2YXIoLS1zbGlkZS1wb3NpdGlvbikpJyxcbiAgfSxcbiAgc3dpcHBpbmc6IHtcbiAgICB0cmFuc2l0aW9uOiAnbm9uZScsXG4gICAgJz4gKic6IHtcbiAgICAgIG92ZXJmbG93OiAnaGlkZGVuJywgLy8gbG9jayBzY3JvbGxpbmcgYWZ0ZXIgZmlyc3QgdG91Y2gvcG9pbnRlciBldmVudFxuICAgIH1cbiAgfSxcbiAgcHVsbGVyOiB7XG4gICAgcG9zaXRpb246ICdzdGlja3knLFxuICAgIHRvcDogJzAnLFxuICAgIGhlaWdodDogJzFyZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnZW5kJyxcbiAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgYmFja2dyb3VuZDogJ2luaGVyaXQnLFxuICAgICcmOjpiZWZvcmUnOiB7XG4gICAgICBjb250ZW50OiAnXCIgXCInLFxuICAgICAgZmxleDogJzAgM3JlbScsXG4gICAgICBoZWlnaHQ6ICc2cHgnLFxuICAgICAgYm9yZGVyUmFkaXVzOiAnNnB4JyxcbiAgICAgIGJhY2tncm91bmQ6ICcjNjM3MzgxJyxcbiAgICB9XG4gIH1cbn1cblxuY29uc3QgU3dpcGVhYmxlRHJhd2VyID0gKHtcbiAgb3BlbixcbiAgY29tcG9uZW50OiBDb21wb25lbnQgPSAnZGl2JyxcbiAgc3R5bGUsXG4gIGh5c3RlcmVzaXMgPSAwLjUyLFxuICBtaW5GbGluZ1ZlbG9jaXR5ID0gNDUwLFxuICBjaGlsZHJlbixcbiAgb25DbG9zZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbc3dpcGVQb3NpdGlvbiwgc2V0U3dpcGVQb3NpdGlvbl0gPSB1c2VTdGF0ZSgwKVxuICBjb25zdCBoYW5kbGVycyA9IHVzZU1lbW8oXG4gICAgKCkgPT5cbiAgICAgIHBvaW50ZXJIYW5kbGVycyh7XG4gICAgICAgIC8vIFRPRE8gYWxsb3cgc2Nyb2xsaW5nXG4gICAgICAgIG9uTW92ZTogKHttb3ZlWX0pID0+IHNldFN3aXBlUG9zaXRpb24oTWF0aC5tYXgoMCwgbW92ZVkpKSxcbiAgICAgICAgb25MZWF2ZTogKHttb3ZlWSwgdmVsb2NpdHlZLCBoZWlnaHR9ID0ge30pID0+IHtcbiAgICAgICAgICBzZXRTd2lwZVBvc2l0aW9uKDApXG4gICAgICAgICAgY29uc3Qgc2hvdWxkQ2xvc2UgPVxuICAgICAgICAgICAgbW92ZVkgPiBoZWlnaHQgKiBoeXN0ZXJlc2lzIHx8IHZlbG9jaXR5WSA+IG1pbkZsaW5nVmVsb2NpdHlcbiAgICAgICAgICBpZiAoc2hvdWxkQ2xvc2UpIHtcbiAgICAgICAgICAgIG9uQ2xvc2UoKVxuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgIFtdXG4gIClcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBkb2N1bWVudC5ib2R5LnN0eWxlLm92ZXJmbG93ID0gb3BlbiA/ICdoaWRkZW4nIDogJ2F1dG8nXG4gIH0sIFtvcGVuXSlcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxCYWNrZHJvcFxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgLi4uc3R5bGUsXG4gICAgICAgIC4uLnN0eWxlcy5vdmVybGF5LFxuICAgICAgfX1cbiAgICAgIHJlbmRlckF0PVwiYWx3YXlzXCJcbiAgICAgIG9wZW49e29wZW59XG4gICAgICBvbkNsaWNrPXtldmVudCA9PiB7XG4gICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgICAgIG9uQ2xvc2UoZXZlbnQpXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxDb21wb25lbnRcbiAgICAgICAgc3R5bGU9e3snLS1zbGlkZS1wb3NpdGlvbic6IGAke3N3aXBlUG9zaXRpb259cHhgfX1cbiAgICAgICAgLy8gc3RhcnQgc3dpcHBpbmcgYWZ0ZXIgbW92aW5nIGZhciBlbm91Z2gsIGFuZCBsb2NrIHNjcm9sbGluZ1xuICAgICAgICBjc3M9e1tzdHlsZXMuY29udGFpbmVyLCBvcGVuICYmIHN0eWxlcy5zbGlkZVVwLCBzd2lwZVBvc2l0aW9uID4gMjMgJiYgc3R5bGVzLnN3aXBwaW5nXX1cbiAgICAgICAgb25DbGljaz17ZXZlbnQgPT4gZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCl9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgICB7Li4uaGFuZGxlcnN9XG4gICAgICA+XG4gICAgICAgIDxkaXYgY3NzPXtzdHlsZXMucHVsbGVyfSAvPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0NvbXBvbmVudD5cbiAgICA8L0JhY2tkcm9wPixcbiAgICBnZXRUb3BFbGVtZW50KClcbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTd2lwZWFibGVEcmF3ZXJcbiJdfQ== */"],
4351
+ css: [styles.container, open && styles.slideUp, swipePosition > 23 && styles.swipping, process.env.NODE_ENV === "production" ? "" : ";label:SwipeableDrawer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN3aXBlYWJsZURyYXdlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtR1EiLCJmaWxlIjoiU3dpcGVhYmxlRHJhd2VyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuLyogQGpzeEltcG9ydFNvdXJjZSBAZW1vdGlvbi9yZWFjdCAqL1xuaW1wb3J0IHt1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVN0YXRlfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7Y3JlYXRlUG9ydGFsfSBmcm9tICdyZWFjdC1kb20nXG5pbXBvcnQge2dldFRvcEVsZW1lbnR9IGZyb20gJ3V0aWwvdmlld01vZGVzJ1xuaW1wb3J0IHtwb2ludGVySGFuZGxlcnN9IGZyb20gJ3V0aWwvZ2VzdHVyZXMnXG5pbXBvcnQgQmFja2Ryb3AgZnJvbSAnLi9CYWNrZHJvcCdcblxuY29uc3Qgc3R5bGVzID0ge1xuICBvdmVybGF5OiB7XG4gICAgcG9zaXRpb246ICdmaXhlZCcsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIGFsaWduQ29udGVudDogJ2ZsZXgtZW5kJyxcbiAgICB0b3VjaEFjdGlvbjogJ25vbmUnLFxuICB9LFxuICBjb250YWluZXI6IHtcbiAgICBmbGV4OiAnMCBjYWxjKDEwMCUgLSAycmVtKScsXG4gICAgZm9udFNpemU6ICcxcmVtJyxcbiAgICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKDEwMCUpJyxcbiAgICB0cmFuc2l0aW9uOiAndHJhbnNmb3JtIDAuMnMgZWFzZS1vdXQnLFxuICAgICc+IConOiB7XG4gICAgICB0b3VjaEFjdGlvbjogJ3Bhbi15JyxcbiAgICB9LFxuICB9LFxuICBzbGlkZVVwOiB7XG4gICAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSh2YXIoLS1zbGlkZS1wb3NpdGlvbikpJyxcbiAgfSxcbiAgc3dpcHBpbmc6IHtcbiAgICB0cmFuc2l0aW9uOiAnbm9uZScsXG4gICAgJz4gKic6IHtcbiAgICAgIG92ZXJmbG93OiAnaGlkZGVuJywgLy8gbG9jayBzY3JvbGxpbmcgYWZ0ZXIgZmlyc3QgdG91Y2gvcG9pbnRlciBldmVudFxuICAgIH1cbiAgfSxcbiAgcHVsbGVyOiB7XG4gICAgcG9zaXRpb246ICdzdGlja3knLFxuICAgIHRvcDogJzAnLFxuICAgIGhlaWdodDogJzFyZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnZW5kJyxcbiAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgYmFja2dyb3VuZDogJ2luaGVyaXQnLFxuICAgICcmOjpiZWZvcmUnOiB7XG4gICAgICBjb250ZW50OiAnXCIgXCInLFxuICAgICAgZmxleDogJzAgM3JlbScsXG4gICAgICBoZWlnaHQ6ICc2cHgnLFxuICAgICAgYm9yZGVyUmFkaXVzOiAnNnB4JyxcbiAgICAgIGJhY2tncm91bmQ6ICcjNjM3MzgxJyxcbiAgICB9XG4gIH1cbn1cblxuY29uc3QgU3dpcGVhYmxlRHJhd2VyID0gKHtcbiAgb3BlbixcbiAgY29tcG9uZW50OiBDb21wb25lbnQgPSAnZGl2JyxcbiAgc3R5bGUsXG4gIGh5c3RlcmVzaXMgPSAwLjUyLFxuICBtaW5GbGluZ1ZlbG9jaXR5ID0gNDUwLFxuICBjaGlsZHJlbixcbiAgb25DbG9zZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbc3dpcGVQb3NpdGlvbiwgc2V0U3dpcGVQb3NpdGlvbl0gPSB1c2VTdGF0ZSgwKVxuICBjb25zdCBoYW5kbGVycyA9IHVzZU1lbW8oXG4gICAgKCkgPT5cbiAgICAgIHBvaW50ZXJIYW5kbGVycyh7XG4gICAgICAgIC8vIFRPRE8gYWxsb3cgc2Nyb2xsaW5nXG4gICAgICAgIG9uTW92ZTogKHttb3ZlWX0pID0+IHNldFN3aXBlUG9zaXRpb24oTWF0aC5tYXgoMCwgbW92ZVkpKSxcbiAgICAgICAgb25MZWF2ZTogKHttb3ZlWSwgdmVsb2NpdHlZLCBoZWlnaHR9ID0ge30pID0+IHtcbiAgICAgICAgICBzZXRTd2lwZVBvc2l0aW9uKDApXG4gICAgICAgICAgY29uc3Qgc2hvdWxkQ2xvc2UgPVxuICAgICAgICAgICAgbW92ZVkgPiBoZWlnaHQgKiBoeXN0ZXJlc2lzIHx8IHZlbG9jaXR5WSA+IG1pbkZsaW5nVmVsb2NpdHlcbiAgICAgICAgICBpZiAoc2hvdWxkQ2xvc2UpIHtcbiAgICAgICAgICAgIG9uQ2xvc2UoKVxuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgIFtdXG4gIClcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBkb2N1bWVudC5ib2R5LnN0eWxlLm92ZXJmbG93ID0gb3BlbiA/ICdoaWRkZW4nIDogJ2F1dG8nXG4gIH0sIFtvcGVuXSlcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxCYWNrZHJvcFxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgLi4uc3R5bGUsXG4gICAgICAgIC4uLnN0eWxlcy5vdmVybGF5LFxuICAgICAgfX1cbiAgICAgIHJlbmRlckF0PVwiYWx3YXlzXCJcbiAgICAgIG9wZW49e29wZW59XG4gICAgICBvbkNsaWNrPXtldmVudCA9PiB7XG4gICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXG4gICAgICAgIG9uQ2xvc2UoZXZlbnQpXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxDb21wb25lbnRcbiAgICAgICAgc3R5bGU9e3snLS1zbGlkZS1wb3NpdGlvbic6IGAke3N3aXBlUG9zaXRpb259cHhgfX1cbiAgICAgICAgLy8gc3RhcnQgc3dpcHBpbmcgYWZ0ZXIgbW92aW5nIGZhciBlbm91Z2gsIGFuZCBsb2NrIHNjcm9sbGluZ1xuICAgICAgICBjc3M9e1tzdHlsZXMuY29udGFpbmVyLCBvcGVuICYmIHN0eWxlcy5zbGlkZVVwLCBzd2lwZVBvc2l0aW9uID4gMjMgJiYgc3R5bGVzLnN3aXBwaW5nXX1cbiAgICAgICAgb25DbGljaz17ZXZlbnQgPT4gZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCl9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgICB7Li4uaGFuZGxlcnN9XG4gICAgICA+XG4gICAgICAgIDxkaXYgY3NzPXtzdHlsZXMucHVsbGVyfSAvPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0NvbXBvbmVudD5cbiAgICA8L0JhY2tkcm9wPixcbiAgICBnZXRUb3BFbGVtZW50KClcbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTd2lwZWFibGVEcmF3ZXJcbiJdfQ== */"],
4321
4352
  onClick: event => event.stopPropagation(),
4322
4353
  ...rest,
4323
4354
  ...handlers,
4324
4355
  children: [jsx$1("div", {
4325
- css: styles$2.puller
4356
+ css: styles.puller
4326
4357
  }), children]
4327
4358
  })
4328
4359
  }), getTopElement());
@@ -4421,7 +4452,7 @@ const mobileStyle$1 = {
4421
4452
  }
4422
4453
  }; // TODO some of styles are for older version UI design, can be simplified
4423
4454
 
4424
- const desktopStyle$2 = {
4455
+ const desktopStyle$1 = {
4425
4456
  overlay: {
4426
4457
  position: 'absolute',
4427
4458
  zIndex: '1',
@@ -4475,7 +4506,7 @@ const desktopStyle$2 = {
4475
4506
  }
4476
4507
  };
4477
4508
 
4478
- const MenuItemText$1 = ({
4509
+ const MenuItemText = ({
4479
4510
  text = ''
4480
4511
  }) => jsx$1(FormattedMessage, {
4481
4512
  id: text,
@@ -4485,7 +4516,7 @@ const MenuItemText$1 = ({
4485
4516
  })
4486
4517
  });
4487
4518
 
4488
- MenuItemText$1.propTypes = {
4519
+ MenuItemText.propTypes = {
4489
4520
  text: PropTypes.string
4490
4521
  };
4491
4522
 
@@ -4503,7 +4534,7 @@ const LoopSwitch = ({
4503
4534
  keepOpen: true
4504
4535
  });
4505
4536
  },
4506
- children: [jsx$1(MenuItemText$1, {
4537
+ children: [jsx$1(MenuItemText, {
4507
4538
  text: "KKS.PLAYER.LOOP"
4508
4539
  }), jsx$1("div", {
4509
4540
  css: mobileStyle$1.space
@@ -4519,14 +4550,14 @@ const CloseButton = props => jsx$1("button", {
4519
4550
  ...props
4520
4551
  });
4521
4552
 
4522
- const DesktopContainer$1 = ({
4553
+ const DesktopContainer = ({
4523
4554
  open,
4524
4555
  style,
4525
4556
  children,
4526
4557
  onClose,
4527
4558
  ...rest
4528
4559
  }) => jsx$1("div", {
4529
- css: [style, open && desktopStyle$2.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"]} */"],
4560
+ 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"]} */"],
4530
4561
  ...rest,
4531
4562
  children: children
4532
4563
  });
@@ -4545,7 +4576,7 @@ const Settings = ({
4545
4576
  closeBy,
4546
4577
  buttonPosition,
4547
4578
  slots = {
4548
- root: uiType === 'desktop' ? DesktopContainer$1 : SwipeableDrawer$1
4579
+ root: uiType === 'desktop' ? DesktopContainer : SwipeableDrawer$1
4549
4580
  },
4550
4581
  onChange,
4551
4582
  onOpen,
@@ -4554,7 +4585,7 @@ const Settings = ({
4554
4585
  }) => {
4555
4586
  const Container = slots.root;
4556
4587
  const ButtonWrap = buttonPosition === 'top-right' ? TitleBarExtension : FunctionBarExtension;
4557
- const commonStyle = uiType === 'desktop' ? desktopStyle$2 : mobileStyle$1;
4588
+ const commonStyle = uiType === 'desktop' ? desktopStyle$1 : mobileStyle$1;
4558
4589
  const [path, setPath] = useState('/');
4559
4590
  useEffect(() => {
4560
4591
  if (!open) {
@@ -4653,11 +4684,11 @@ const Settings = ({
4653
4684
  name: currentSection.name,
4654
4685
  value: data
4655
4686
  }),
4656
- children: [jsx$1(MenuItemText$1, {
4687
+ children: [jsx$1(MenuItemText, {
4657
4688
  text: label
4658
4689
  }), jsx$1("div", {
4659
4690
  css: mobileStyle$1.space
4660
- }), value && jsx$1(MenuItemText$1, {
4691
+ }), value && jsx$1(MenuItemText, {
4661
4692
  text: value.toString()
4662
4693
  })]
4663
4694
  }))]
@@ -4675,13 +4706,17 @@ Settings.propTypes = {
4675
4706
  onClose: PropTypes.func
4676
4707
  };
4677
4708
 
4678
- function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4709
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4679
4710
  const panelStyle = {
4680
4711
  position: 'absolute',
4681
4712
  zIndex: 0,
4682
4713
  width: '100%',
4683
4714
  height: '100%'
4684
4715
  };
4716
+ const hiddenStyle = {
4717
+ opacity: 0,
4718
+ pointerEvents: 'none'
4719
+ };
4685
4720
  const fadeout = {
4686
4721
  playing: /*#__PURE__*/keyframes$1(process.env.NODE_ENV === "production" ? {
4687
4722
  name: "b7sms7",
@@ -4689,8 +4724,8 @@ const fadeout = {
4689
4724
  } : {
4690
4725
  name: "1r8yar7-playing",
4691
4726
  styles: "0%{transform:scale(1),;}100%{transform:scale(1.2);opacity:0;};label:playing;",
4692
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYXlQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNvQiIsImZpbGUiOiJQbGF5UGFuZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L3Byb3AtdHlwZXMgKi9cbi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuaW1wb3J0IHtrZXlmcmFtZXN9IGZyb20gJ0BlbW90aW9uL2NzcydcbmltcG9ydCBpY29uIGZyb20gJ3N0eWxlL2ljb24nXG5cbmNvbnN0IHBhbmVsU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICB6SW5kZXg6IDAsXG4gIHdpZHRoOiAnMTAwJScsXG4gIGhlaWdodDogJzEwMCUnLFxufVxuXG5jb25zdCBmYWRlb3V0ID0ge1xuICBwbGF5aW5nOiBrZXlmcmFtZXNgXG4gIDAlIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEpLFxuICB9XG4gIDEwMCUge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICBvcGFjaXR5OiAwO1xuICB9YCxcbiAgcGF1c2VkOiBrZXlmcmFtZXNgXG4wJSB7XG4gIHRyYW5zZm9ybTogc2NhbGUoMSksXG59XG4xMDAlIHtcbiAgdHJhbnNmb3JtOiBzY2FsZSgxLjEpO1xuICBvcGFjaXR5OiAwO1xufWAsXG59XG5cbmNvbnN0IGFuaW1hdGVTdHlsZSA9IHtcbiAgYmFja2dyb3VuZDogJ3ZhcigtLWNlbnRlci1pY29uKSBjZW50ZXIvN2VtIG5vLXJlcGVhdCcsXG4gIGFuaW1hdGlvbjogJ3ZhcigtLWFuaW1hdGlvbi1uYW1lKSAwLjM1cyBlYXNlLW91dCBmb3J3YXJkcycsXG4gIG9wYWNpdHk6IDAuMyxcbn1cblxuY29uc3QgUGxheVBhbmVsID0gKHtzdHlsZSwgYW5pbWF0aW9uLCAgb25DbGljaywgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIHN0eWxlPXt7XG4gICAgICAnLS1hbmltYXRpb24tbmFtZSc6IGZhZGVvdXRbYW5pbWF0aW9uXSxcbiAgICAgICctLWNlbnRlci1pY29uJzogYW5pbWF0aW9uID8gYHVybCgke2ljb25bYCR7YW5pbWF0aW9ufUNpcmNsZWBdfSlgIDogJycsXG4gICAgfX1cbiAgICBjc3M9e1twYW5lbFN0eWxlLCBhbmltYXRpb24gJiYgYW5pbWF0ZVN0eWxlLCBzdHlsZV19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgICB7Li4ucmVzdH1cbiAgLz5cbilcblxuZXhwb3J0IGRlZmF1bHQgUGxheVBhbmVsXG4iXX0= */",
4693
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
4727
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYXlQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cb0IiLCJmaWxlIjoiUGxheVBhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG4vKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9wcm9wLXR5cGVzICovXG4vKiBlc2xpbnQtZGlzYWJsZSBqc3gtYTExeS9uby1zdGF0aWMtZWxlbWVudC1pbnRlcmFjdGlvbnMgKi9cbmltcG9ydCB7a2V5ZnJhbWVzfSBmcm9tICdAZW1vdGlvbi9jc3MnXG5pbXBvcnQgaWNvbiBmcm9tICdzdHlsZS9pY29uJ1xuXG5jb25zdCBwYW5lbFN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbn1cblxuY29uc3QgaGlkZGVuU3R5bGUgPSB7XG4gIG9wYWNpdHk6IDAsXG4gIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbn1cblxuY29uc3QgZmFkZW91dCA9IHtcbiAgcGxheWluZzoga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgdHJhbnNmb3JtOiBzY2FsZSgxKSxcbiAgfVxuICAxMDAlIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gICAgb3BhY2l0eTogMDtcbiAgfWAsXG4gIHBhdXNlZDoga2V5ZnJhbWVzYFxuMCUge1xuICB0cmFuc2Zvcm06IHNjYWxlKDEpLFxufVxuMTAwJSB7XG4gIHRyYW5zZm9ybTogc2NhbGUoMS4xKTtcbiAgb3BhY2l0eTogMDtcbn1gLFxufVxuXG5jb25zdCBhbmltYXRlU3R5bGUgPSB7XG4gIGJhY2tncm91bmQ6ICd2YXIoLS1jZW50ZXItaWNvbikgY2VudGVyLzdlbSBuby1yZXBlYXQnLFxuICBhbmltYXRpb246ICd2YXIoLS1hbmltYXRpb24tbmFtZSkgMC4zNXMgZWFzZS1vdXQgZm9yd2FyZHMnLFxuICBvcGFjaXR5OiAwLjMsXG59XG5cbmNvbnN0IFBsYXlQYW5lbCA9ICh7c3R5bGUsIGFuaW1hdGlvbiwgb25DbGljaywgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIHN0eWxlPXt7XG4gICAgICAnLS1hbmltYXRpb24tbmFtZSc6IGZhZGVvdXRbYW5pbWF0aW9uXSxcbiAgICAgICctLWNlbnRlci1pY29uJzogYW5pbWF0aW9uID8gYHVybCgke2ljb25bYCR7YW5pbWF0aW9ufUNpcmNsZWBdfSlgIDogJycsXG4gICAgfX1cbiAgICBjc3M9e1tcbiAgICAgIHBhbmVsU3R5bGUsXG4gICAgICBhbmltYXRpb24gJiYgYW5pbWF0ZVN0eWxlLFxuICAgICAgIW9uQ2xpY2sgJiYgaGlkZGVuU3R5bGUsXG4gICAgICBzdHlsZSxcbiAgICBdfVxuICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgey4uLnJlc3R9XG4gIC8+XG4pXG5cbmV4cG9ydCBkZWZhdWx0IFBsYXlQYW5lbFxuIl19 */",
4728
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
4694
4729
  }),
4695
4730
  paused: /*#__PURE__*/keyframes$1(process.env.NODE_ENV === "production" ? {
4696
4731
  name: "1nw7c0f",
@@ -4698,8 +4733,8 @@ const fadeout = {
4698
4733
  } : {
4699
4734
  name: "8m6ch-paused",
4700
4735
  styles: "0%{transform:scale(1),;}100%{transform:scale(1.1);opacity:0;};label:paused;",
4701
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYXlQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCbUIiLCJmaWxlIjoiUGxheVBhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG4vKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9wcm9wLXR5cGVzICovXG4vKiBlc2xpbnQtZGlzYWJsZSBqc3gtYTExeS9uby1zdGF0aWMtZWxlbWVudC1pbnRlcmFjdGlvbnMgKi9cbmltcG9ydCB7a2V5ZnJhbWVzfSBmcm9tICdAZW1vdGlvbi9jc3MnXG5pbXBvcnQgaWNvbiBmcm9tICdzdHlsZS9pY29uJ1xuXG5jb25zdCBwYW5lbFN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbn1cblxuY29uc3QgZmFkZW91dCA9IHtcbiAgcGxheWluZzoga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgdHJhbnNmb3JtOiBzY2FsZSgxKSxcbiAgfVxuICAxMDAlIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gICAgb3BhY2l0eTogMDtcbiAgfWAsXG4gIHBhdXNlZDoga2V5ZnJhbWVzYFxuMCUge1xuICB0cmFuc2Zvcm06IHNjYWxlKDEpLFxufVxuMTAwJSB7XG4gIHRyYW5zZm9ybTogc2NhbGUoMS4xKTtcbiAgb3BhY2l0eTogMDtcbn1gLFxufVxuXG5jb25zdCBhbmltYXRlU3R5bGUgPSB7XG4gIGJhY2tncm91bmQ6ICd2YXIoLS1jZW50ZXItaWNvbikgY2VudGVyLzdlbSBuby1yZXBlYXQnLFxuICBhbmltYXRpb246ICd2YXIoLS1hbmltYXRpb24tbmFtZSkgMC4zNXMgZWFzZS1vdXQgZm9yd2FyZHMnLFxuICBvcGFjaXR5OiAwLjMsXG59XG5cbmNvbnN0IFBsYXlQYW5lbCA9ICh7c3R5bGUsIGFuaW1hdGlvbiwgIG9uQ2xpY2ssIC4uLnJlc3R9KSA9PiAoXG4gIDxkaXZcbiAgICBzdHlsZT17e1xuICAgICAgJy0tYW5pbWF0aW9uLW5hbWUnOiBmYWRlb3V0W2FuaW1hdGlvbl0sXG4gICAgICAnLS1jZW50ZXItaWNvbic6IGFuaW1hdGlvbiA/IGB1cmwoJHtpY29uW2Ake2FuaW1hdGlvbn1DaXJjbGVgXX0pYCA6ICcnLFxuICAgIH19XG4gICAgY3NzPXtbcGFuZWxTdHlsZSwgYW5pbWF0aW9uICYmIGFuaW1hdGVTdHlsZSwgc3R5bGVdfVxuICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgey4uLnJlc3R9XG4gIC8+XG4pXG5cbmV4cG9ydCBkZWZhdWx0IFBsYXlQYW5lbFxuIl19 */",
4702
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
4736
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYXlQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCbUIiLCJmaWxlIjoiUGxheVBhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG4vKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9wcm9wLXR5cGVzICovXG4vKiBlc2xpbnQtZGlzYWJsZSBqc3gtYTExeS9uby1zdGF0aWMtZWxlbWVudC1pbnRlcmFjdGlvbnMgKi9cbmltcG9ydCB7a2V5ZnJhbWVzfSBmcm9tICdAZW1vdGlvbi9jc3MnXG5pbXBvcnQgaWNvbiBmcm9tICdzdHlsZS9pY29uJ1xuXG5jb25zdCBwYW5lbFN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbn1cblxuY29uc3QgaGlkZGVuU3R5bGUgPSB7XG4gIG9wYWNpdHk6IDAsXG4gIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbn1cblxuY29uc3QgZmFkZW91dCA9IHtcbiAgcGxheWluZzoga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgdHJhbnNmb3JtOiBzY2FsZSgxKSxcbiAgfVxuICAxMDAlIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gICAgb3BhY2l0eTogMDtcbiAgfWAsXG4gIHBhdXNlZDoga2V5ZnJhbWVzYFxuMCUge1xuICB0cmFuc2Zvcm06IHNjYWxlKDEpLFxufVxuMTAwJSB7XG4gIHRyYW5zZm9ybTogc2NhbGUoMS4xKTtcbiAgb3BhY2l0eTogMDtcbn1gLFxufVxuXG5jb25zdCBhbmltYXRlU3R5bGUgPSB7XG4gIGJhY2tncm91bmQ6ICd2YXIoLS1jZW50ZXItaWNvbikgY2VudGVyLzdlbSBuby1yZXBlYXQnLFxuICBhbmltYXRpb246ICd2YXIoLS1hbmltYXRpb24tbmFtZSkgMC4zNXMgZWFzZS1vdXQgZm9yd2FyZHMnLFxuICBvcGFjaXR5OiAwLjMsXG59XG5cbmNvbnN0IFBsYXlQYW5lbCA9ICh7c3R5bGUsIGFuaW1hdGlvbiwgb25DbGljaywgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIHN0eWxlPXt7XG4gICAgICAnLS1hbmltYXRpb24tbmFtZSc6IGZhZGVvdXRbYW5pbWF0aW9uXSxcbiAgICAgICctLWNlbnRlci1pY29uJzogYW5pbWF0aW9uID8gYHVybCgke2ljb25bYCR7YW5pbWF0aW9ufUNpcmNsZWBdfSlgIDogJycsXG4gICAgfX1cbiAgICBjc3M9e1tcbiAgICAgIHBhbmVsU3R5bGUsXG4gICAgICBhbmltYXRpb24gJiYgYW5pbWF0ZVN0eWxlLFxuICAgICAgIW9uQ2xpY2sgJiYgaGlkZGVuU3R5bGUsXG4gICAgICBzdHlsZSxcbiAgICBdfVxuICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgey4uLnJlc3R9XG4gIC8+XG4pXG5cbmV4cG9ydCBkZWZhdWx0IFBsYXlQYW5lbFxuIl19 */",
4737
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
4703
4738
  })
4704
4739
  };
4705
4740
  const animateStyle = {
@@ -4718,391 +4753,59 @@ const PlayPanel = ({
4718
4753
  '--animation-name': fadeout[animation],
4719
4754
  '--center-icon': animation ? `url(${iconUrls[`${animation}Circle`]})` : ''
4720
4755
  },
4721
- css: [panelStyle, animation && animateStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:PlayPanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYXlQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDSSIsImZpbGUiOiJQbGF5UGFuZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L3Byb3AtdHlwZXMgKi9cbi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuaW1wb3J0IHtrZXlmcmFtZXN9IGZyb20gJ0BlbW90aW9uL2NzcydcbmltcG9ydCBpY29uIGZyb20gJ3N0eWxlL2ljb24nXG5cbmNvbnN0IHBhbmVsU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICB6SW5kZXg6IDAsXG4gIHdpZHRoOiAnMTAwJScsXG4gIGhlaWdodDogJzEwMCUnLFxufVxuXG5jb25zdCBmYWRlb3V0ID0ge1xuICBwbGF5aW5nOiBrZXlmcmFtZXNgXG4gIDAlIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEpLFxuICB9XG4gIDEwMCUge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICBvcGFjaXR5OiAwO1xuICB9YCxcbiAgcGF1c2VkOiBrZXlmcmFtZXNgXG4wJSB7XG4gIHRyYW5zZm9ybTogc2NhbGUoMSksXG59XG4xMDAlIHtcbiAgdHJhbnNmb3JtOiBzY2FsZSgxLjEpO1xuICBvcGFjaXR5OiAwO1xufWAsXG59XG5cbmNvbnN0IGFuaW1hdGVTdHlsZSA9IHtcbiAgYmFja2dyb3VuZDogJ3ZhcigtLWNlbnRlci1pY29uKSBjZW50ZXIvN2VtIG5vLXJlcGVhdCcsXG4gIGFuaW1hdGlvbjogJ3ZhcigtLWFuaW1hdGlvbi1uYW1lKSAwLjM1cyBlYXNlLW91dCBmb3J3YXJkcycsXG4gIG9wYWNpdHk6IDAuMyxcbn1cblxuY29uc3QgUGxheVBhbmVsID0gKHtzdHlsZSwgYW5pbWF0aW9uLCAgb25DbGljaywgLi4ucmVzdH0pID0+IChcbiAgPGRpdlxuICAgIHN0eWxlPXt7XG4gICAgICAnLS1hbmltYXRpb24tbmFtZSc6IGZhZGVvdXRbYW5pbWF0aW9uXSxcbiAgICAgICctLWNlbnRlci1pY29uJzogYW5pbWF0aW9uID8gYHVybCgke2ljb25bYCR7YW5pbWF0aW9ufUNpcmNsZWBdfSlgIDogJycsXG4gICAgfX1cbiAgICBjc3M9e1twYW5lbFN0eWxlLCBhbmltYXRpb24gJiYgYW5pbWF0ZVN0eWxlLCBzdHlsZV19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgICB7Li4ucmVzdH1cbiAgLz5cbilcblxuZXhwb3J0IGRlZmF1bHQgUGxheVBhbmVsXG4iXX0= */"],
4756
+ css: [panelStyle, animation && animateStyle, !onClick && hiddenStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:PlayPanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYXlQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlESSIsImZpbGUiOiJQbGF5UGFuZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L3Byb3AtdHlwZXMgKi9cbi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuaW1wb3J0IHtrZXlmcmFtZXN9IGZyb20gJ0BlbW90aW9uL2NzcydcbmltcG9ydCBpY29uIGZyb20gJ3N0eWxlL2ljb24nXG5cbmNvbnN0IHBhbmVsU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICB6SW5kZXg6IDAsXG4gIHdpZHRoOiAnMTAwJScsXG4gIGhlaWdodDogJzEwMCUnLFxufVxuXG5jb25zdCBoaWRkZW5TdHlsZSA9IHtcbiAgb3BhY2l0eTogMCxcbiAgcG9pbnRlckV2ZW50czogJ25vbmUnLFxufVxuXG5jb25zdCBmYWRlb3V0ID0ge1xuICBwbGF5aW5nOiBrZXlmcmFtZXNgXG4gIDAlIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEpLFxuICB9XG4gIDEwMCUge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMS4yKTtcbiAgICBvcGFjaXR5OiAwO1xuICB9YCxcbiAgcGF1c2VkOiBrZXlmcmFtZXNgXG4wJSB7XG4gIHRyYW5zZm9ybTogc2NhbGUoMSksXG59XG4xMDAlIHtcbiAgdHJhbnNmb3JtOiBzY2FsZSgxLjEpO1xuICBvcGFjaXR5OiAwO1xufWAsXG59XG5cbmNvbnN0IGFuaW1hdGVTdHlsZSA9IHtcbiAgYmFja2dyb3VuZDogJ3ZhcigtLWNlbnRlci1pY29uKSBjZW50ZXIvN2VtIG5vLXJlcGVhdCcsXG4gIGFuaW1hdGlvbjogJ3ZhcigtLWFuaW1hdGlvbi1uYW1lKSAwLjM1cyBlYXNlLW91dCBmb3J3YXJkcycsXG4gIG9wYWNpdHk6IDAuMyxcbn1cblxuY29uc3QgUGxheVBhbmVsID0gKHtzdHlsZSwgYW5pbWF0aW9uLCBvbkNsaWNrLCAuLi5yZXN0fSkgPT4gKFxuICA8ZGl2XG4gICAgc3R5bGU9e3tcbiAgICAgICctLWFuaW1hdGlvbi1uYW1lJzogZmFkZW91dFthbmltYXRpb25dLFxuICAgICAgJy0tY2VudGVyLWljb24nOiBhbmltYXRpb24gPyBgdXJsKCR7aWNvbltgJHthbmltYXRpb259Q2lyY2xlYF19KWAgOiAnJyxcbiAgICB9fVxuICAgIGNzcz17W1xuICAgICAgcGFuZWxTdHlsZSxcbiAgICAgIGFuaW1hdGlvbiAmJiBhbmltYXRlU3R5bGUsXG4gICAgICAhb25DbGljayAmJiBoaWRkZW5TdHlsZSxcbiAgICAgIHN0eWxlLFxuICAgIF19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgICB7Li4ucmVzdH1cbiAgLz5cbilcblxuZXhwb3J0IGRlZmF1bHQgUGxheVBhbmVsXG4iXX0= */"],
4722
4757
  onClick: onClick,
4723
4758
  ...rest
4724
4759
  });
4725
4760
 
4726
- /* @jsxImportSource @emotion/react */
4727
- const styles$1 = {
4728
- position: 'absolute',
4729
- zIndex: 2,
4730
- height: '100%',
4731
- display: 'flex',
4732
- alignItems: 'center',
4733
- fontSize: '200%',
4734
- justifyContent: 'center',
4735
- alignSelf: 'center'
4736
- };
4761
+ const volumeStorageKey = 'KKSPlayback-volume';
4737
4762
 
4738
- const FisrtPlay = ({
4739
- type,
4740
- children
4741
- }) => jsx$1("div", {
4742
- css: [styles$1, type === 'desktop' && {
4743
- fontSize: '400%'
4744
- }, process.env.NODE_ENV === "production" ? "" : ";label:FisrtPlay;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpcnN0UGxheS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjTyIsImZpbGUiOiJGaXJzdFBsYXkuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5cbmNvbnN0IHN0eWxlcyA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogMixcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIGZvbnRTaXplOiAnMjAwJScsXG4gIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgYWxpZ25TZWxmOiAnY2VudGVyJyxcbn1cblxuY29uc3QgRmlzcnRQbGF5ID0gKHt0eXBlLCBjaGlsZHJlbn0pID0+IChcbiAgPGRpdiBjc3M9e1tzdHlsZXMsIHR5cGUgPT09ICdkZXNrdG9wJyAmJiB7Zm9udFNpemU6ICc0MDAlJ31dfT57Y2hpbGRyZW59PC9kaXY+XG4pXG5cbmV4cG9ydCBkZWZhdWx0IEZpc3J0UGxheVxuIl19 */"],
4745
- children: children
4746
- });
4763
+ const getDefaultVolume = () => {
4764
+ let initialVolume = 1;
4747
4765
 
4748
- function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4749
- const style$1 = {
4750
- position: 'relative',
4751
- width: '100%',
4752
- height: '100%',
4753
- display: 'flex',
4754
- alignItems: 'center',
4755
- cursor: 'pointer',
4756
- userSelect: 'none',
4757
- touchAction: 'none'
4758
- };
4759
- const disabledStyle = {
4760
- pointerEvents: 'none'
4761
- };
4762
- const railStyle = {
4763
- position: 'relative',
4764
- alignSelf: 'normal',
4765
- flex: '100%',
4766
- overflow: 'hidden',
4767
- background: 'rgba(255, 255, 255, 0.2)',
4768
- '> div': {
4769
- position: 'absolute',
4770
- top: '0',
4771
- left: '0',
4772
- width: '100%',
4773
- height: '100%',
4774
- transform: `translate(
4775
- calc(var(--slider-thumb-x, 100%) - 100%),
4776
- calc(100% - var(--slider-thumb-y, 100%))
4777
- )`
4778
- }
4779
- };
4780
- const markStyle = {
4781
- position: 'absolute',
4782
- height: railStyle.height,
4783
- width: '4px',
4784
- transform: 'translateX(-50%)',
4785
- backgroundColor: '#ff9835'
4786
- };
4787
- const thumbStyle = {
4788
- position: 'absolute',
4789
- height: '0.7em',
4790
- width: '0.7em',
4791
- borderRadius: '100%',
4792
- backgroundColor: '#fff',
4793
- boxShadow: '0 2px 2px 0 rgba(0, 0, 0, 0.5)',
4794
- transform: 'translateY(calc(var(--slider-thumb-y) - 0.35em))'
4795
- };
4766
+ try {
4767
+ var _JSON$parse, _localStorage;
4796
4768
 
4797
- const getPointerValue = ({
4798
- orientation,
4799
- x,
4800
- y,
4801
- left,
4802
- bottom,
4803
- height,
4804
- width
4805
- }) => Math.max(0, orientation === 'vertical' ? Math.min((bottom - y) / height, 1) : Math.min((x - left) / width, 1));
4769
+ initialVolume = (_JSON$parse = JSON.parse((_localStorage = localStorage) === null || _localStorage === void 0 ? void 0 : _localStorage.getItem(volumeStorageKey))) !== null && _JSON$parse !== void 0 ? _JSON$parse : 0.5; // eslint-disable-next-line no-empty
4770
+ } catch (e) {}
4806
4771
 
4807
- const debouncedPointerHandlers = ({
4808
- state,
4809
- onMove,
4810
- onLeave
4811
- }) => {
4812
- const emit = () => {
4813
- if (!state.scheduled) {
4814
- return;
4815
- }
4772
+ return initialVolume;
4773
+ };
4816
4774
 
4817
- if (state.type === 'leave') {
4818
- onLeave === null || onLeave === void 0 ? void 0 : onLeave(state.event, state);
4819
- } else {
4820
- onMove(state.event, state);
4821
- }
4775
+ const syncVolume = (video, defaultVolume) => {
4776
+ on(video, 'volumechange', () => {
4777
+ var _localStorage2;
4822
4778
 
4823
- state.scheduled = false;
4824
- };
4779
+ const volume = video.muted ? 0 : video.volume;
4780
+ (_localStorage2 = localStorage) === null || _localStorage2 === void 0 ? void 0 : _localStorage2.setItem(volumeStorageKey, volume);
4781
+ });
4782
+ setTimeout(() => setVolume(video, {}, defaultVolume !== null && defaultVolume !== void 0 ? defaultVolume : getDefaultVolume()), 1);
4783
+ };
4825
4784
 
4826
- const schedule = () => {
4827
- if (state.scheduled) {
4828
- return;
4829
- }
4785
+ const linkMediaVolume = getOptions => {
4786
+ let lastVolume = 1;
4830
4787
 
4831
- state.scheduled = true;
4832
- requestAnimationFrame(emit);
4788
+ const subscribe = handler => {
4789
+ const {
4790
+ video: media
4791
+ } = getOptions();
4792
+ handler({
4793
+ volume: media.volume,
4794
+ muted: media.muted
4795
+ });
4796
+ return on(media, 'volumechange', () => handler({
4797
+ volume: media.volume,
4798
+ muted: media.muted
4799
+ }));
4833
4800
  };
4834
4801
 
4835
- return {
4836
- onPointerMove: event => {
4837
- var _event$touches;
4838
-
4839
- const type = event.buttons > 0 || ((_event$touches = event.touches) === null || _event$touches === void 0 ? void 0 : _event$touches.length) > 0 ? 'change' : 'move';
4840
- Object.assign(state, {
4841
- event,
4842
- type,
4843
- ...getPointerData(event)
4844
- });
4845
- schedule();
4846
- },
4847
- onPointerLeave: event => {
4848
- const type = 'leave';
4849
- Object.assign(state, {
4850
- event,
4851
- type
4852
- });
4853
- schedule();
4854
- },
4855
- emit
4856
- };
4857
- };
4858
-
4859
- const eventHandlers = ({
4860
- onPointerDown,
4861
- onPointerMove,
4862
- onPointerLeave,
4863
- onPointerUp
4864
- }) => ({
4865
- onPointerDown,
4866
- onPointerMove,
4867
- onPointerLeave,
4868
- onPointerUp,
4869
- onTouchStart: onPointerDown,
4870
- onTouchMove: onPointerMove,
4871
- onTouchEnd: event => {
4872
- onPointerLeave(event);
4873
- onPointerUp(event);
4874
- }
4875
- }); // TODO align with material ui more, move special handling of pointer events
4876
-
4877
-
4878
- var _ref$1 = process.env.NODE_ENV === "production" ? {
4879
- name: "1rwj9b6",
4880
- styles: "background-color:rgba(255, 255, 255, 0.3)"
4881
- } : {
4882
- name: "1nvd7de-SimpleSlider",
4883
- styles: "background-color:rgba(255, 255, 255, 0.3);label:SimpleSlider;",
4884
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SimpleSlider.jsx"],"names":[],"mappings":"AAoNY","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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\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  position: 'relative',\n  alignSelf: 'normal',\n  flex: '100%',\n  overflow: 'hidden',\n  background: 'rgba(255, 255, 255, 0.2)',\n  '> div': {\n    position: 'absolute',\n    top: '0',\n    left: '0',\n    width: '100%',\n    height: '100%',\n    transform: `translate(\n      calc(var(--slider-thumb-x, 100%) - 100%),\n      calc(100% - var(--slider-thumb-y, 100%))\n    )`,\n  },\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.7em',\n  width: '0.7em',\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\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}) => {\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={[style, 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      <div\n        className={classes.rail}\n        css={[railStyle, orientation === 'vertical' && {borderRadius: '0.2em'}]}\n      >\n        {secondaryTrackValue && (\n          <div\n            css={{backgroundColor: 'rgba(255, 255, 255, 0.3)'}}\n            style={{\n              transform: `translateX(${subTrackPosition * 100 - 100}%)`,\n            }}\n          />\n        )}\n        <div\n          css={{backgroundColor: 'var(--sender-seekbar-background, #fff)'}}\n          className={classes.track}\n        />\n      </div>\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={[\n            thumbStyle,\n          ]}\n          className={classes.thumb}\n          style={thumbPositionStyle}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nSimpleSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default SimpleSlider\n"]} */",
4885
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
4886
- };
4887
-
4888
- var _ref2 = process.env.NODE_ENV === "production" ? {
4889
- name: "o1z5nx",
4890
- styles: "background-color:var(--sender-seekbar-background, #fff)"
4891
- } : {
4892
- name: "1y6riur-SimpleSlider",
4893
- styles: "background-color:var(--sender-seekbar-background, #fff);label:SimpleSlider;",
4894
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SimpleSlider.jsx"],"names":[],"mappings":"AA2NU","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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\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  position: 'relative',\n  alignSelf: 'normal',\n  flex: '100%',\n  overflow: 'hidden',\n  background: 'rgba(255, 255, 255, 0.2)',\n  '> div': {\n    position: 'absolute',\n    top: '0',\n    left: '0',\n    width: '100%',\n    height: '100%',\n    transform: `translate(\n      calc(var(--slider-thumb-x, 100%) - 100%),\n      calc(100% - var(--slider-thumb-y, 100%))\n    )`,\n  },\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.7em',\n  width: '0.7em',\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\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}) => {\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={[style, 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      <div\n        className={classes.rail}\n        css={[railStyle, orientation === 'vertical' && {borderRadius: '0.2em'}]}\n      >\n        {secondaryTrackValue && (\n          <div\n            css={{backgroundColor: 'rgba(255, 255, 255, 0.3)'}}\n            style={{\n              transform: `translateX(${subTrackPosition * 100 - 100}%)`,\n            }}\n          />\n        )}\n        <div\n          css={{backgroundColor: 'var(--sender-seekbar-background, #fff)'}}\n          className={classes.track}\n        />\n      </div>\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={[\n            thumbStyle,\n          ]}\n          className={classes.thumb}\n          style={thumbPositionStyle}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nSimpleSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default SimpleSlider\n"]} */",
4895
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
4896
- };
4897
-
4898
- const SimpleSlider = ({
4899
- min = 0,
4900
- max = 100,
4901
- value,
4902
- secondaryTrackValue,
4903
- // TODO a better name
4904
- marks = [],
4905
- className = '',
4906
- classes = {},
4907
- disabled,
4908
- onPointerMove,
4909
- onPointerLeave,
4910
- onPointerDown,
4911
- onChange,
4912
- onChangeCommitted,
4913
- orientation = 'horizontal'
4914
- }) => {
4915
- const pointerState = useRef({});
4916
- const [focusValue, setFocusValue] = useState(-Infinity);
4917
- const thumbPosition = ((focusValue >= min ? focusValue : value) - min) / (max - min);
4918
- const subTrackPosition = (secondaryTrackValue - min) / (max - min);
4919
- const pointerHandlers = debouncedPointerHandlers({
4920
- state: pointerState.current,
4921
- onMove: (event, {
4922
- type,
4923
- x,
4924
- y,
4925
- width,
4926
- left,
4927
- height,
4928
- bottom
4929
- }) => {
4930
- const pointerData = {
4931
- orientation,
4932
- x,
4933
- y,
4934
- left,
4935
- bottom,
4936
- width,
4937
- height
4938
- };
4939
- const pointerValue = min + (max - min) * getPointerValue(pointerData);
4940
- onPointerMove === null || onPointerMove === void 0 ? void 0 : onPointerMove(event, {
4941
- value: pointerValue,
4942
- x,
4943
- y
4944
- });
4945
-
4946
- if (type === 'change') {
4947
- setFocusValue(pointerValue);
4948
- onChange === null || onChange === void 0 ? void 0 : onChange(event, {
4949
- value: pointerValue,
4950
- x,
4951
- y
4952
- });
4953
- }
4954
- },
4955
- onLeave: () => onPointerLeave === null || onPointerLeave === void 0 ? void 0 : onPointerLeave()
4956
- });
4957
-
4958
- const handlePointerUp = event => {
4959
- if (event.pointerId) {
4960
- event.currentTarget.releasePointerCapture(event.pointerId);
4961
- }
4962
-
4963
- const {
4964
- x,
4965
- y,
4966
- width,
4967
- left,
4968
- height,
4969
- bottom
4970
- } = getPointerData(event);
4971
- const pointerValue = min + (max - min) * getPointerValue({
4972
- orientation,
4973
- x,
4974
- y,
4975
- left,
4976
- bottom,
4977
- width,
4978
- height
4979
- });
4980
- pointerHandlers.emit();
4981
- onChangeCommitted === null || onChangeCommitted === void 0 ? void 0 : onChangeCommitted(event, {
4982
- value: pointerValue
4983
- });
4984
- setFocusValue();
4985
- };
4986
-
4987
- const thumbPositionStyle = {
4988
- bottom: `calc(var(--slider-thumb-y) - 0.35em)`,
4989
- left: `calc(var(--slider-thumb-x) - 0.25em)`
4990
- };
4991
- return jsxs("div", {
4992
- className: className,
4993
- css: [style$1, 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":"AAuLM","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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\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  position: 'relative',\n  alignSelf: 'normal',\n  flex: '100%',\n  overflow: 'hidden',\n  background: 'rgba(255, 255, 255, 0.2)',\n  '> div': {\n    position: 'absolute',\n    top: '0',\n    left: '0',\n    width: '100%',\n    height: '100%',\n    transform: `translate(\n      calc(var(--slider-thumb-x, 100%) - 100%),\n      calc(100% - var(--slider-thumb-y, 100%))\n    )`,\n  },\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.7em',\n  width: '0.7em',\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\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}) => {\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={[style, 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      <div\n        className={classes.rail}\n        css={[railStyle, orientation === 'vertical' && {borderRadius: '0.2em'}]}\n      >\n        {secondaryTrackValue && (\n          <div\n            css={{backgroundColor: 'rgba(255, 255, 255, 0.3)'}}\n            style={{\n              transform: `translateX(${subTrackPosition * 100 - 100}%)`,\n            }}\n          />\n        )}\n        <div\n          css={{backgroundColor: 'var(--sender-seekbar-background, #fff)'}}\n          className={classes.track}\n        />\n      </div>\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={[\n            thumbStyle,\n          ]}\n          className={classes.thumb}\n          style={thumbPositionStyle}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nSimpleSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default SimpleSlider\n"]} */"],
4994
- style: { ...(orientation === 'vertical' && {
4995
- flexDirection: 'column',
4996
- '--slider-thumb-y': `${thumbPosition * 100}%`
4997
- }),
4998
- ...(orientation === 'horizontal' && {
4999
- '--slider-thumb-x': `${thumbPosition * 100}%`
5000
- })
5001
- },
5002
- onClick: event => event.stopPropagation(),
5003
- ...eventHandlers({
5004
- onPointerDown: event => {
5005
- if (event.type === 'pointerdown') {
5006
- event.currentTarget.setPointerCapture(event.pointerId);
5007
- onPointerDown === null || onPointerDown === void 0 ? void 0 : onPointerDown();
5008
- }
5009
-
5010
- pointerHandlers.onPointerMove(event);
5011
- },
5012
- ...pointerHandlers,
5013
- onPointerUp: handlePointerUp
5014
- }),
5015
- children: [jsxs("div", {
5016
- className: classes.rail,
5017
- css: [railStyle, orientation === 'vertical' && {
5018
- borderRadius: '0.2em'
5019
- }, 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":"AAgNQ","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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\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  position: 'relative',\n  alignSelf: 'normal',\n  flex: '100%',\n  overflow: 'hidden',\n  background: 'rgba(255, 255, 255, 0.2)',\n  '> div': {\n    position: 'absolute',\n    top: '0',\n    left: '0',\n    width: '100%',\n    height: '100%',\n    transform: `translate(\n      calc(var(--slider-thumb-x, 100%) - 100%),\n      calc(100% - var(--slider-thumb-y, 100%))\n    )`,\n  },\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.7em',\n  width: '0.7em',\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\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}) => {\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={[style, 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      <div\n        className={classes.rail}\n        css={[railStyle, orientation === 'vertical' && {borderRadius: '0.2em'}]}\n      >\n        {secondaryTrackValue && (\n          <div\n            css={{backgroundColor: 'rgba(255, 255, 255, 0.3)'}}\n            style={{\n              transform: `translateX(${subTrackPosition * 100 - 100}%)`,\n            }}\n          />\n        )}\n        <div\n          css={{backgroundColor: 'var(--sender-seekbar-background, #fff)'}}\n          className={classes.track}\n        />\n      </div>\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={[\n            thumbStyle,\n          ]}\n          className={classes.thumb}\n          style={thumbPositionStyle}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nSimpleSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default SimpleSlider\n"]} */"],
5020
- children: [secondaryTrackValue && jsx$1("div", {
5021
- css: _ref$1,
5022
- style: {
5023
- transform: `translateX(${subTrackPosition * 100 - 100}%)`
5024
- }
5025
- }), jsx$1("div", {
5026
- css: _ref2,
5027
- className: classes.track
5028
- })]
5029
- }), marks.map(position => jsx$1("div", {
5030
- css: markStyle,
5031
- className: classes.marked,
5032
- style: {
5033
- left: `${position / max * 100}%`
5034
- }
5035
- }, position)), onChange && !disabled ? jsx$1("div", {
5036
- css: [thumbStyle, 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":"AAyOU","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'\nimport PropTypes from 'prop-types'\n\nimport {getPointerData} from 'util/gestures'\n\nconst style = {\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  position: 'relative',\n  alignSelf: 'normal',\n  flex: '100%',\n  overflow: 'hidden',\n  background: 'rgba(255, 255, 255, 0.2)',\n  '> div': {\n    position: 'absolute',\n    top: '0',\n    left: '0',\n    width: '100%',\n    height: '100%',\n    transform: `translate(\n      calc(var(--slider-thumb-x, 100%) - 100%),\n      calc(100% - var(--slider-thumb-y, 100%))\n    )`,\n  },\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.7em',\n  width: '0.7em',\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\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}) => {\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={[style, 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      <div\n        className={classes.rail}\n        css={[railStyle, orientation === 'vertical' && {borderRadius: '0.2em'}]}\n      >\n        {secondaryTrackValue && (\n          <div\n            css={{backgroundColor: 'rgba(255, 255, 255, 0.3)'}}\n            style={{\n              transform: `translateX(${subTrackPosition * 100 - 100}%)`,\n            }}\n          />\n        )}\n        <div\n          css={{backgroundColor: 'var(--sender-seekbar-background, #fff)'}}\n          className={classes.track}\n        />\n      </div>\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={[\n            thumbStyle,\n          ]}\n          className={classes.thumb}\n          style={thumbPositionStyle}\n        />\n      ) : (\n        <div />\n      )}\n    </div>\n  )\n}\n\nSimpleSlider.propTypes = {\n  min: PropTypes.number,\n  max: PropTypes.number,\n  value: PropTypes.number,\n  secondaryTrackValue: PropTypes.number,\n  marks: PropTypes.array,\n  className: PropTypes.string,\n  classes: PropTypes.object,\n  disabled: PropTypes.bool,\n  onPointerMove: PropTypes.func,\n  onPointerLeave: PropTypes.func,\n  onChange: PropTypes.func,\n  onChangeCommitted: PropTypes.func,\n}\n\nexport default SimpleSlider\n"]} */"],
5037
- className: classes.thumb,
5038
- style: thumbPositionStyle
5039
- }) : jsx$1("div", {})]
5040
- });
5041
- };
5042
-
5043
- SimpleSlider.propTypes = {
5044
- min: PropTypes.number,
5045
- max: PropTypes.number,
5046
- value: PropTypes.number,
5047
- secondaryTrackValue: PropTypes.number,
5048
- marks: PropTypes.array,
5049
- className: PropTypes.string,
5050
- classes: PropTypes.object,
5051
- disabled: PropTypes.bool,
5052
- onPointerMove: PropTypes.func,
5053
- onPointerLeave: PropTypes.func,
5054
- onChange: PropTypes.func,
5055
- onChangeCommitted: PropTypes.func
5056
- };
5057
-
5058
- const volumeStorageKey = 'KKSPlayback-volume';
5059
-
5060
- const getDefaultVolume = () => {
5061
- let initialVolume = 1;
5062
-
5063
- try {
5064
- var _JSON$parse, _localStorage;
5065
-
5066
- initialVolume = (_JSON$parse = JSON.parse((_localStorage = localStorage) === null || _localStorage === void 0 ? void 0 : _localStorage.getItem(volumeStorageKey))) !== null && _JSON$parse !== void 0 ? _JSON$parse : 0.5; // eslint-disable-next-line no-empty
5067
- } catch (e) {}
5068
-
5069
- return initialVolume;
5070
- };
5071
-
5072
- const syncVolume = (video, defaultVolume) => {
5073
- on(video, 'volumechange', () => {
5074
- var _localStorage2;
5075
-
5076
- const volume = video.muted ? 0 : video.volume;
5077
- (_localStorage2 = localStorage) === null || _localStorage2 === void 0 ? void 0 : _localStorage2.setItem(volumeStorageKey, volume);
5078
- });
5079
- setTimeout(() => setVolume(video, {}, defaultVolume !== null && defaultVolume !== void 0 ? defaultVolume : getDefaultVolume()), 1);
5080
- };
5081
-
5082
- const linkMediaVolume = getOptions => {
5083
- let lastVolume = 1;
5084
-
5085
- const subscribe = handler => {
5086
- const {
5087
- video: media
5088
- } = getOptions();
5089
- handler({
5090
- volume: media.volume,
5091
- muted: media.muted
5092
- });
5093
- return on(media, 'volumechange', () => handler({
5094
- volume: media.volume,
5095
- muted: media.muted
5096
- }));
5097
- };
5098
-
5099
- const onChange = (volume, {
5100
- commit
5101
- } = {}) => {
5102
- const {
5103
- video: media,
5104
- getPlayer
5105
- } = getOptions();
4802
+ const onChange = (volume, {
4803
+ commit
4804
+ } = {}) => {
4805
+ const {
4806
+ video: media,
4807
+ getPlayer
4808
+ } = getOptions();
5106
4809
 
5107
4810
  if (commit) {
5108
4811
  dispatchCustomEvent(media, 'audioVolumeSettingChange', {
@@ -5235,551 +4938,14 @@ const VolumeControl = ({
5235
4938
  });
5236
4939
  };
5237
4940
 
5238
- /* @jsxImportSource @emotion/react */
5239
- const containerStyle$2 = {
5240
- position: 'absolute',
5241
- zIndex: 1,
5242
- top: 0,
5243
- right: 0,
5244
- width: '40%',
5245
- height: '100%',
5246
- overflow: 'auto',
5247
- background: '#161c24',
5248
- opacity: 0.9,
5249
- transition: 'transform 0.2s ease',
5250
- transform: 'translateX(100%)'
5251
- };
5252
- const openStyle = {
5253
- transform: 'translateX(0)'
5254
- };
5255
-
5256
- const SidePanel = ({
5257
- open,
5258
- style,
5259
- children,
5260
- onClose
5261
- }) => {
5262
- const ref = useOnclickOutside(() => {
5263
- if (open) {
5264
- onClose();
5265
- }
5266
- }, {
5267
- eventTypes: ['click']
5268
- });
5269
- return jsx$1("div", {
5270
- ref: ref,
5271
- css: [containerStyle$2, open && openStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:SidePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNpZGVQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ21CIiwiZmlsZSI6IlNpZGVQYW5lbC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB1c2VPbmNsaWNrT3V0c2lkZSBmcm9tICdyZWFjdC1jb29sLW9uY2xpY2tvdXRzaWRlJ1xuXG4vLyBUT0RPIHRoaXMgaXMgY3VycmVudGx5IGRlc2t0b3Agb25seSwgbWF5YmUgY2FuIGJlIG1lcmdlZCB3aXRoIFN3aXBlYWJsZURyYXdsZXI/XG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogMSxcbiAgdG9wOiAwLFxuICByaWdodDogMCxcbiAgd2lkdGg6ICc0MCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgb3ZlcmZsb3c6ICdhdXRvJyxcbiAgYmFja2dyb3VuZDogJyMxNjFjMjQnLFxuICBvcGFjaXR5OiAwLjksXG4gIHRyYW5zaXRpb246ICd0cmFuc2Zvcm0gMC4ycyBlYXNlJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgxMDAlKScsXG59XG5cbmNvbnN0IG9wZW5TdHlsZSA9IHtcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScsXG59XG5cbmNvbnN0IFNpZGVQYW5lbCA9ICh7b3Blbiwgc3R5bGUsIGNoaWxkcmVuLCBvbkNsb3NlfSkgPT4ge1xuICBjb25zdCByZWYgPSB1c2VPbmNsaWNrT3V0c2lkZShcbiAgICAoKSA9PiB7XG4gICAgICBpZiAob3Blbikge1xuICAgICAgICBvbkNsb3NlKClcbiAgICAgIH1cbiAgICB9LFxuICAgIHtldmVudFR5cGVzOiBbJ2NsaWNrJ119XG4gIClcblxuICByZXR1cm4gKFxuICAgIDxkaXYgcmVmPXtyZWZ9IGNzcz17W2NvbnRhaW5lclN0eWxlLCBvcGVuICYmIG9wZW5TdHlsZSwgc3R5bGVdfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTaWRlUGFuZWxcbiJdfQ== */"],
5272
- children: children
5273
- });
5274
- };
5275
-
5276
- var SidePanel$1 = SidePanel;
5277
-
5278
- /* eslint-disable jsx-a11y/no-noninteractive-element-interactions */
5279
- const styles = {
5280
- overlay: {
5281
- '> div': {
5282
- // drawer container
5283
- background: 'var(--setting-ui-background, #161C24)',
5284
- maxHeight: '95%'
5285
- },
5286
- h2: {
5287
- position: 'sticky',
5288
- top: 0,
5289
- marginBlockStart: 0,
5290
- marginBlockEnd: 0,
5291
- padding: '1rem 1.5rem',
5292
- background: 'inherit'
5293
- }
5294
- },
5295
- container: {
5296
- marginBlockStart: 0,
5297
- marginBlockEnd: 0,
5298
- paddingInlineStart: 0,
5299
- listStyleType: 'none',
5300
- overflow: 'auto',
5301
- maxHeight: '66vh'
5302
- },
5303
- item: {
5304
- padding: '0.75rem 1.5rem',
5305
- fontWeight: '700',
5306
- lineHeight: '1',
5307
- cursor: 'pointer',
5308
- '> div > div': {
5309
- marginTop: '0.5rem',
5310
- padding: '0.25rem 0.5rem',
5311
- width: 'fit-content',
5312
- color: '#79B5FB',
5313
- background: 'rgba(14, 120, 244, 0.16)',
5314
- fontSize: '80%',
5315
- borderRadius: '0.4rem'
5316
- },
5317
- '&:hover': {
5318
- background: 'rgba(255, 255, 255, 0.10)'
5319
- }
5320
- }
5321
- };
5322
- const activeStyle = {
5323
- background: '#334'
5324
- };
5325
-
5326
- const ChapterList = ({
5327
- open,
5328
- chapters = [],
5329
- currentTime,
5330
- seek,
5331
- onOpen,
5332
- onClose
5333
- }) => {
5334
- const Container = isDesktop() ? SidePanel$1 : SwipeableDrawer$1;
5335
- const roundedTime = Math.round(currentTime);
5336
- const currentChapterIndex = useMemo(() => {
5337
- const index = chapters.findIndex(chapter => roundedTime < chapter.startTime);
5338
- return index < 0 ? chapters.length : index - 1;
5339
- }, [roundedTime]);
5340
- return (chapters === null || chapters === void 0 ? void 0 : chapters.length) > 0 && jsxs(Fragment, {
5341
- children: [jsx$1(TitleBarExtension, {
5342
- position: "right",
5343
- children: jsx$1(Button, {
5344
- startIcon: "list",
5345
- title: "KKS.CHAPTERS",
5346
- placement: "top",
5347
- onClick: event => {
5348
- event.stopPropagation();
5349
- onOpen(event);
5350
- }
5351
- })
5352
- }), jsxs(Container, {
5353
- style: styles.overlay,
5354
- open: open,
5355
- onClose: onClose,
5356
- children: [jsx$1("h2", {
5357
- children: jsx$1(FormattedMessage, {
5358
- id: "KKS.CHAPTERS"
5359
- })
5360
- }), jsx$1("ul", {
5361
- role: "menu",
5362
- css: styles.container,
5363
- children: chapters.map((item, index) => jsxs("li", {
5364
- role: "menuitem",
5365
- css: [styles.item, index === currentChapterIndex && activeStyle, process.env.NODE_ENV === "production" ? "" : ";label:ChapterList;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXB0ZXJMaXN0LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlHZ0IiLCJmaWxlIjoiQ2hhcHRlckxpc3QuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBqc3gtYTExeS9uby1ub25pbnRlcmFjdGl2ZS1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZU1lbW99IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHtGb3JtYXR0ZWRNZXNzYWdlLCBGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2lzRGVza3RvcH0gZnJvbSAndXRpbC9lbnZpcm9ubWVudCdcbmltcG9ydCBTd2lwZWFibGVEcmF3ZXIgZnJvbSAnLi9Td2lwZWFibGVEcmF3ZXInXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtUaXRsZUJhckV4dGVuc2lvbn0gZnJvbSAnLi91aUV4dGVuc2lvbnMnXG5pbXBvcnQgU2lkZVBhbmVsIGZyb20gJy4vU2lkZVBhbmVsJ1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIG92ZXJsYXk6IHtcbiAgICAnPiBkaXYnOiB7XG4gICAgICAvLyBkcmF3ZXIgY29udGFpbmVyXG4gICAgICBiYWNrZ3JvdW5kOiAndmFyKC0tc2V0dGluZy11aS1iYWNrZ3JvdW5kLCAjMTYxQzI0KScsXG4gICAgICBtYXhIZWlnaHQ6ICc5NSUnLFxuICAgIH0sXG4gICAgaDI6IHtcbiAgICAgIHBvc2l0aW9uOiAnc3RpY2t5JyxcbiAgICAgIHRvcDogMCxcbiAgICAgIG1hcmdpbkJsb2NrU3RhcnQ6IDAsXG4gICAgICBtYXJnaW5CbG9ja0VuZDogMCxcbiAgICAgIHBhZGRpbmc6ICcxcmVtIDEuNXJlbScsXG4gICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgfSxcbiAgfSxcbiAgY29udGFpbmVyOiB7XG4gICAgbWFyZ2luQmxvY2tTdGFydDogMCxcbiAgICBtYXJnaW5CbG9ja0VuZDogMCxcbiAgICBwYWRkaW5nSW5saW5lU3RhcnQ6IDAsXG4gICAgbGlzdFN0eWxlVHlwZTogJ25vbmUnLFxuICAgIG92ZXJmbG93OiAnYXV0bycsXG4gICAgbWF4SGVpZ2h0OiAnNjZ2aCcsXG4gIH0sXG4gIGl0ZW06IHtcbiAgICBwYWRkaW5nOiAnMC43NXJlbSAxLjVyZW0nLFxuICAgIGZvbnRXZWlnaHQ6ICc3MDAnLFxuICAgIGxpbmVIZWlnaHQ6ICcxJyxcbiAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAnPiBkaXYgPiBkaXYnOiB7XG4gICAgICBtYXJnaW5Ub3A6ICcwLjVyZW0nLFxuICAgICAgcGFkZGluZzogJzAuMjVyZW0gMC41cmVtJyxcbiAgICAgIHdpZHRoOiAnZml0LWNvbnRlbnQnLFxuICAgICAgY29sb3I6ICcjNzlCNUZCJyxcbiAgICAgIGJhY2tncm91bmQ6ICdyZ2JhKDE0LCAxMjAsIDI0NCwgMC4xNiknLFxuICAgICAgZm9udFNpemU6JzgwJScsXG4gICAgICBib3JkZXJSYWRpdXM6ICcwLjRyZW0nLFxuICAgIH0sXG4gICAgJyY6aG92ZXInOiB7XG4gICAgICBiYWNrZ3JvdW5kOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjEwKScsXG4gICAgfSxcbiAgfSxcbn1cblxuY29uc3QgYWN0aXZlU3R5bGUgPSB7XG4gIGJhY2tncm91bmQ6ICcjMzM0Jyxcbn1cblxuY29uc3QgQ2hhcHRlckxpc3QgPSAoe1xuICBvcGVuLFxuICBjaGFwdGVycyA9IFtdLFxuICBjdXJyZW50VGltZSxcbiAgc2VlayxcbiAgb25PcGVuLFxuICBvbkNsb3NlLFxufSkgPT4ge1xuICBjb25zdCBDb250YWluZXIgPSBpc0Rlc2t0b3AoKSA/IFNpZGVQYW5lbCA6IFN3aXBlYWJsZURyYXdlclxuXG4gIGNvbnN0IHJvdW5kZWRUaW1lID0gTWF0aC5yb3VuZChjdXJyZW50VGltZSlcbiAgY29uc3QgY3VycmVudENoYXB0ZXJJbmRleCA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGNvbnN0IGluZGV4ID0gY2hhcHRlcnMuZmluZEluZGV4KGNoYXB0ZXIgPT4gcm91bmRlZFRpbWUgPCBjaGFwdGVyLnN0YXJ0VGltZSlcbiAgICByZXR1cm4gaW5kZXggPCAwID8gY2hhcHRlcnMubGVuZ3RoIDogaW5kZXggLSAxXG4gIH0sIFtyb3VuZGVkVGltZV0pXG5cbiAgcmV0dXJuIChcbiAgICBjaGFwdGVycz8ubGVuZ3RoID4gMCAmJiAoXG4gICAgICA8PlxuICAgICAgICA8VGl0bGVCYXJFeHRlbnNpb24gcG9zaXRpb249XCJyaWdodFwiPlxuICAgICAgICAgIDxCdXR0b25cbiAgICAgICAgICAgIHN0YXJ0SWNvbj1cImxpc3RcIlxuICAgICAgICAgICAgdGl0bGU9XCJLS1MuQ0hBUFRFUlNcIlxuICAgICAgICAgICAgcGxhY2VtZW50PVwidG9wXCJcbiAgICAgICAgICAgIG9uQ2xpY2s9e2V2ZW50ID0+IHtcbiAgICAgICAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcbiAgICAgICAgICAgICAgb25PcGVuKGV2ZW50KVxuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L1RpdGxlQmFyRXh0ZW5zaW9uPlxuICAgICAgICA8Q29udGFpbmVyIHN0eWxlPXtzdHlsZXMub3ZlcmxheX0gb3Blbj17b3Blbn0gb25DbG9zZT17b25DbG9zZX0+XG4gICAgICAgICAgPGgyPlxuICAgICAgICAgICAgPEZvcm1hdHRlZE1lc3NhZ2UgaWQ9XCJLS1MuQ0hBUFRFUlNcIiAvPlxuICAgICAgICAgIDwvaDI+XG4gICAgICAgICAgPHVsIHJvbGU9XCJtZW51XCIgY3NzPXtzdHlsZXMuY29udGFpbmVyfT5cbiAgICAgICAgICAgIHtjaGFwdGVycy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxsaVxuICAgICAgICAgICAgICAgIHJvbGU9XCJtZW51aXRlbVwiXG4gICAgICAgICAgICAgICAgY3NzPXtbXG4gICAgICAgICAgICAgICAgICBzdHlsZXMuaXRlbSxcbiAgICAgICAgICAgICAgICAgIGluZGV4ID09PSBjdXJyZW50Q2hhcHRlckluZGV4ICYmIGFjdGl2ZVN0eWxlLFxuICAgICAgICAgICAgICAgIF19XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgc2VlayhpdGVtLnN0YXJ0VGltZSlcbiAgICAgICAgICAgICAgICAgIGlmICghaXNEZXNrdG9wKCkpIHtcbiAgICAgICAgICAgICAgICAgICAgb25DbG9zZSgpXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtpdGVtLmltYWdlVXJsICYmIDxpbWcgYWx0PXtpdGVtLm5hbWV9IHNyYz17aXRlbS5pbWFnZVVybH0gLz59XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgIHtpdGVtLmRpc3BsYXlOYW1lfVxuICAgICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17aXRlbS5zdGFydFRpbWV9IC8+XG4gICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgPC9saT5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvdWw+XG4gICAgICAgIDwvQ29udGFpbmVyPlxuICAgICAgPC8+XG4gICAgKVxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IENoYXB0ZXJMaXN0XG4iXX0= */"],
5366
- onClick: () => {
5367
- seek(item.startTime);
5368
-
5369
- if (!isDesktop()) {
5370
- onClose();
5371
- }
5372
- },
5373
- children: [item.imageUrl && jsx$1("img", {
5374
- alt: item.name,
5375
- src: item.imageUrl
5376
- }), jsxs("div", {
5377
- children: [item.displayName, jsx$1("div", {
5378
- children: jsx$1(FormattedTime, {
5379
- time: item.startTime
5380
- })
5381
- })]
5382
- })]
5383
- }))
5384
- })]
5385
- })]
5386
- });
5387
- };
5388
-
5389
- /* @jsxImportSource @emotion/react */
5390
- const embedDialogStyle = {
5391
- position: 'fixed',
5392
- top: 0,
5393
- left: 0,
5394
- width: '100%',
5395
- height: '100%',
5396
- backgroundColor: 'rgba(0, 0, 0, 0.5)',
5397
- zIndex: 1
5398
- };
5399
- const containerStyle$1 = {
5400
- position: 'absolute',
5401
- top: '50%',
5402
- left: '50%',
5403
- transform: 'translate(-50%, -50%)',
5404
- backgroundColor: '#161C24',
5405
- width: '60%',
5406
- height: 'auto'
5407
- };
5408
- const titleStyle$1 = {
5409
- fontSize: '1rem',
5410
- padding: '0 1.5em',
5411
- display: 'flex',
5412
- alignItems: 'center',
5413
- justifyContent: 'space-between'
5414
- };
5415
- const contentStyle = {
5416
- backgroundColor: '#212B36',
5417
- padding: '0.75em',
5418
- margin: '0.75em 1.5em 0',
5419
- '> div': {
5420
- display: '-webkit-box',
5421
- '-webkitBoxOrient': 'vertical',
5422
- '-webkitLineClamp': '3',
5423
- overflow: 'hidden'
5424
- }
5425
- };
5426
- const bottomStyle = {
5427
- display: 'flex',
5428
- justifyContent: 'flex-end',
5429
- padding: '1.5em'
5430
- };
5431
-
5432
- const EmbedPopUp = ({
5433
- embedCode,
5434
- containerRef,
5435
- onClose
5436
- }) => {
5437
- const handleCopyClick = () => {
5438
- // TODO: iOS Safari/Safari compatibility issue
5439
- navigator.clipboard.writeText(embedCode);
5440
- };
5441
-
5442
- return /*#__PURE__*/createPortal(jsx$1("div", {
5443
- css: [embedDialogStyle, process.env.NODE_ENV === "production" ? "" : ";label:EmbedPopUp;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVtYmVkUG9wVXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeURTIiwiZmlsZSI6IkVtYmVkUG9wVXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2NyZWF0ZVBvcnRhbH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHtDbG9zZSwgQ29weX0gZnJvbSAnLi9idXR0b25zJ1xuXG5jb25zdCBlbWJlZERpYWxvZ1N0eWxlID0ge1xuICBwb3NpdGlvbjogJ2ZpeGVkJyxcbiAgdG9wOiAwLFxuICBsZWZ0OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgwLCAwLCAwLCAwLjUpJyxcbiAgekluZGV4OiAxLFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGUoLTUwJSwgLTUwJSknLFxuICBiYWNrZ3JvdW5kQ29sb3I6ICcjMTYxQzI0JyxcbiAgd2lkdGg6ICc2MCUnLFxuICBoZWlnaHQ6ICdhdXRvJyxcbn1cblxuY29uc3QgdGl0bGVTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxcmVtJyxcbiAgcGFkZGluZzogJzAgMS41ZW0nLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxufVxuXG5jb25zdCBjb250ZW50U3R5bGUgPSB7XG4gIGJhY2tncm91bmRDb2xvcjogJyMyMTJCMzYnLFxuICBwYWRkaW5nOiAnMC43NWVtJyxcbiAgbWFyZ2luOiAnMC43NWVtIDEuNWVtIDAnLFxuICAnPiBkaXYnOiB7XG4gICAgZGlzcGxheTogJy13ZWJraXQtYm94JyxcbiAgICAnLXdlYmtpdEJveE9yaWVudCc6ICd2ZXJ0aWNhbCcsXG4gICAgJy13ZWJraXRMaW5lQ2xhbXAnOiAnMycsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICB9LFxufVxuXG5jb25zdCBib3R0b21TdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBqdXN0aWZ5Q29udGVudDogJ2ZsZXgtZW5kJyxcbiAgcGFkZGluZzogJzEuNWVtJyxcbn1cblxuY29uc3QgRW1iZWRQb3BVcCA9ICh7ZW1iZWRDb2RlLCBjb250YWluZXJSZWYsIG9uQ2xvc2V9KSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNvcHlDbGljayA9ICgpID0+IHtcbiAgICAvLyBUT0RPOiBpT1MgU2FmYXJpL1NhZmFyaSBjb21wYXRpYmlsaXR5IGlzc3VlXG4gICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoZW1iZWRDb2RlKVxuICB9XG5cbiAgcmV0dXJuIGNyZWF0ZVBvcnRhbChcbiAgICA8ZGl2IGNzcz17W2VtYmVkRGlhbG9nU3R5bGVdfT5cbiAgICAgIDxkaXYgY3NzPXtbY29udGFpbmVyU3R5bGVdfT5cbiAgICAgICAgPGRpdiBjc3M9e1t0aXRsZVN0eWxlXX0+XG4gICAgICAgICAgPGgzPkVtYmVkIFZpZGVvPC9oMz5cbiAgICAgICAgICA8Q2xvc2Ugb25DbGljaz17b25DbG9zZX0gLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY3NzPXtbY29udGVudFN0eWxlXX0+XG4gICAgICAgICAgPGRpdj57ZW1iZWRDb2RlfTwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjc3M9e1tib3R0b21TdHlsZV19PlxuICAgICAgICAgIDxDb3B5IHZhcmlhbnQ9XCJjb250YWluZWRcIiBvbkNsaWNrPXtoYW5kbGVDb3B5Q2xpY2t9IC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+LFxuICAgIGNvbnRhaW5lclJlZlxuICApXG59XG5leHBvcnQgZGVmYXVsdCBFbWJlZFBvcFVwXG4iXX0= */"],
5444
- children: jsxs("div", {
5445
- css: [containerStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:EmbedPopUp;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVtYmVkUG9wVXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMERXIiwiZmlsZSI6IkVtYmVkUG9wVXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2NyZWF0ZVBvcnRhbH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHtDbG9zZSwgQ29weX0gZnJvbSAnLi9idXR0b25zJ1xuXG5jb25zdCBlbWJlZERpYWxvZ1N0eWxlID0ge1xuICBwb3NpdGlvbjogJ2ZpeGVkJyxcbiAgdG9wOiAwLFxuICBsZWZ0OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgwLCAwLCAwLCAwLjUpJyxcbiAgekluZGV4OiAxLFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGUoLTUwJSwgLTUwJSknLFxuICBiYWNrZ3JvdW5kQ29sb3I6ICcjMTYxQzI0JyxcbiAgd2lkdGg6ICc2MCUnLFxuICBoZWlnaHQ6ICdhdXRvJyxcbn1cblxuY29uc3QgdGl0bGVTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxcmVtJyxcbiAgcGFkZGluZzogJzAgMS41ZW0nLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxufVxuXG5jb25zdCBjb250ZW50U3R5bGUgPSB7XG4gIGJhY2tncm91bmRDb2xvcjogJyMyMTJCMzYnLFxuICBwYWRkaW5nOiAnMC43NWVtJyxcbiAgbWFyZ2luOiAnMC43NWVtIDEuNWVtIDAnLFxuICAnPiBkaXYnOiB7XG4gICAgZGlzcGxheTogJy13ZWJraXQtYm94JyxcbiAgICAnLXdlYmtpdEJveE9yaWVudCc6ICd2ZXJ0aWNhbCcsXG4gICAgJy13ZWJraXRMaW5lQ2xhbXAnOiAnMycsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICB9LFxufVxuXG5jb25zdCBib3R0b21TdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBqdXN0aWZ5Q29udGVudDogJ2ZsZXgtZW5kJyxcbiAgcGFkZGluZzogJzEuNWVtJyxcbn1cblxuY29uc3QgRW1iZWRQb3BVcCA9ICh7ZW1iZWRDb2RlLCBjb250YWluZXJSZWYsIG9uQ2xvc2V9KSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNvcHlDbGljayA9ICgpID0+IHtcbiAgICAvLyBUT0RPOiBpT1MgU2FmYXJpL1NhZmFyaSBjb21wYXRpYmlsaXR5IGlzc3VlXG4gICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoZW1iZWRDb2RlKVxuICB9XG5cbiAgcmV0dXJuIGNyZWF0ZVBvcnRhbChcbiAgICA8ZGl2IGNzcz17W2VtYmVkRGlhbG9nU3R5bGVdfT5cbiAgICAgIDxkaXYgY3NzPXtbY29udGFpbmVyU3R5bGVdfT5cbiAgICAgICAgPGRpdiBjc3M9e1t0aXRsZVN0eWxlXX0+XG4gICAgICAgICAgPGgzPkVtYmVkIFZpZGVvPC9oMz5cbiAgICAgICAgICA8Q2xvc2Ugb25DbGljaz17b25DbG9zZX0gLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY3NzPXtbY29udGVudFN0eWxlXX0+XG4gICAgICAgICAgPGRpdj57ZW1iZWRDb2RlfTwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjc3M9e1tib3R0b21TdHlsZV19PlxuICAgICAgICAgIDxDb3B5IHZhcmlhbnQ9XCJjb250YWluZWRcIiBvbkNsaWNrPXtoYW5kbGVDb3B5Q2xpY2t9IC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+LFxuICAgIGNvbnRhaW5lclJlZlxuICApXG59XG5leHBvcnQgZGVmYXVsdCBFbWJlZFBvcFVwXG4iXX0= */"],
5446
- children: [jsxs("div", {
5447
- css: [titleStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:EmbedPopUp;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVtYmVkUG9wVXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRhIiwiZmlsZSI6IkVtYmVkUG9wVXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2NyZWF0ZVBvcnRhbH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHtDbG9zZSwgQ29weX0gZnJvbSAnLi9idXR0b25zJ1xuXG5jb25zdCBlbWJlZERpYWxvZ1N0eWxlID0ge1xuICBwb3NpdGlvbjogJ2ZpeGVkJyxcbiAgdG9wOiAwLFxuICBsZWZ0OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgwLCAwLCAwLCAwLjUpJyxcbiAgekluZGV4OiAxLFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGUoLTUwJSwgLTUwJSknLFxuICBiYWNrZ3JvdW5kQ29sb3I6ICcjMTYxQzI0JyxcbiAgd2lkdGg6ICc2MCUnLFxuICBoZWlnaHQ6ICdhdXRvJyxcbn1cblxuY29uc3QgdGl0bGVTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxcmVtJyxcbiAgcGFkZGluZzogJzAgMS41ZW0nLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxufVxuXG5jb25zdCBjb250ZW50U3R5bGUgPSB7XG4gIGJhY2tncm91bmRDb2xvcjogJyMyMTJCMzYnLFxuICBwYWRkaW5nOiAnMC43NWVtJyxcbiAgbWFyZ2luOiAnMC43NWVtIDEuNWVtIDAnLFxuICAnPiBkaXYnOiB7XG4gICAgZGlzcGxheTogJy13ZWJraXQtYm94JyxcbiAgICAnLXdlYmtpdEJveE9yaWVudCc6ICd2ZXJ0aWNhbCcsXG4gICAgJy13ZWJraXRMaW5lQ2xhbXAnOiAnMycsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICB9LFxufVxuXG5jb25zdCBib3R0b21TdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBqdXN0aWZ5Q29udGVudDogJ2ZsZXgtZW5kJyxcbiAgcGFkZGluZzogJzEuNWVtJyxcbn1cblxuY29uc3QgRW1iZWRQb3BVcCA9ICh7ZW1iZWRDb2RlLCBjb250YWluZXJSZWYsIG9uQ2xvc2V9KSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNvcHlDbGljayA9ICgpID0+IHtcbiAgICAvLyBUT0RPOiBpT1MgU2FmYXJpL1NhZmFyaSBjb21wYXRpYmlsaXR5IGlzc3VlXG4gICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoZW1iZWRDb2RlKVxuICB9XG5cbiAgcmV0dXJuIGNyZWF0ZVBvcnRhbChcbiAgICA8ZGl2IGNzcz17W2VtYmVkRGlhbG9nU3R5bGVdfT5cbiAgICAgIDxkaXYgY3NzPXtbY29udGFpbmVyU3R5bGVdfT5cbiAgICAgICAgPGRpdiBjc3M9e1t0aXRsZVN0eWxlXX0+XG4gICAgICAgICAgPGgzPkVtYmVkIFZpZGVvPC9oMz5cbiAgICAgICAgICA8Q2xvc2Ugb25DbGljaz17b25DbG9zZX0gLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY3NzPXtbY29udGVudFN0eWxlXX0+XG4gICAgICAgICAgPGRpdj57ZW1iZWRDb2RlfTwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjc3M9e1tib3R0b21TdHlsZV19PlxuICAgICAgICAgIDxDb3B5IHZhcmlhbnQ9XCJjb250YWluZWRcIiBvbkNsaWNrPXtoYW5kbGVDb3B5Q2xpY2t9IC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+LFxuICAgIGNvbnRhaW5lclJlZlxuICApXG59XG5leHBvcnQgZGVmYXVsdCBFbWJlZFBvcFVwXG4iXX0= */"],
5448
- children: [jsx$1("h3", {
5449
- children: "Embed Video"
5450
- }), jsx$1(Close, {
5451
- onClick: onClose
5452
- })]
5453
- }), jsx$1("div", {
5454
- css: [contentStyle, process.env.NODE_ENV === "production" ? "" : ";label:EmbedPopUp;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVtYmVkUG9wVXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0RhIiwiZmlsZSI6IkVtYmVkUG9wVXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2NyZWF0ZVBvcnRhbH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHtDbG9zZSwgQ29weX0gZnJvbSAnLi9idXR0b25zJ1xuXG5jb25zdCBlbWJlZERpYWxvZ1N0eWxlID0ge1xuICBwb3NpdGlvbjogJ2ZpeGVkJyxcbiAgdG9wOiAwLFxuICBsZWZ0OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgwLCAwLCAwLCAwLjUpJyxcbiAgekluZGV4OiAxLFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGUoLTUwJSwgLTUwJSknLFxuICBiYWNrZ3JvdW5kQ29sb3I6ICcjMTYxQzI0JyxcbiAgd2lkdGg6ICc2MCUnLFxuICBoZWlnaHQ6ICdhdXRvJyxcbn1cblxuY29uc3QgdGl0bGVTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxcmVtJyxcbiAgcGFkZGluZzogJzAgMS41ZW0nLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxufVxuXG5jb25zdCBjb250ZW50U3R5bGUgPSB7XG4gIGJhY2tncm91bmRDb2xvcjogJyMyMTJCMzYnLFxuICBwYWRkaW5nOiAnMC43NWVtJyxcbiAgbWFyZ2luOiAnMC43NWVtIDEuNWVtIDAnLFxuICAnPiBkaXYnOiB7XG4gICAgZGlzcGxheTogJy13ZWJraXQtYm94JyxcbiAgICAnLXdlYmtpdEJveE9yaWVudCc6ICd2ZXJ0aWNhbCcsXG4gICAgJy13ZWJraXRMaW5lQ2xhbXAnOiAnMycsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICB9LFxufVxuXG5jb25zdCBib3R0b21TdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBqdXN0aWZ5Q29udGVudDogJ2ZsZXgtZW5kJyxcbiAgcGFkZGluZzogJzEuNWVtJyxcbn1cblxuY29uc3QgRW1iZWRQb3BVcCA9ICh7ZW1iZWRDb2RlLCBjb250YWluZXJSZWYsIG9uQ2xvc2V9KSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNvcHlDbGljayA9ICgpID0+IHtcbiAgICAvLyBUT0RPOiBpT1MgU2FmYXJpL1NhZmFyaSBjb21wYXRpYmlsaXR5IGlzc3VlXG4gICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoZW1iZWRDb2RlKVxuICB9XG5cbiAgcmV0dXJuIGNyZWF0ZVBvcnRhbChcbiAgICA8ZGl2IGNzcz17W2VtYmVkRGlhbG9nU3R5bGVdfT5cbiAgICAgIDxkaXYgY3NzPXtbY29udGFpbmVyU3R5bGVdfT5cbiAgICAgICAgPGRpdiBjc3M9e1t0aXRsZVN0eWxlXX0+XG4gICAgICAgICAgPGgzPkVtYmVkIFZpZGVvPC9oMz5cbiAgICAgICAgICA8Q2xvc2Ugb25DbGljaz17b25DbG9zZX0gLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY3NzPXtbY29udGVudFN0eWxlXX0+XG4gICAgICAgICAgPGRpdj57ZW1iZWRDb2RlfTwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjc3M9e1tib3R0b21TdHlsZV19PlxuICAgICAgICAgIDxDb3B5IHZhcmlhbnQ9XCJjb250YWluZWRcIiBvbkNsaWNrPXtoYW5kbGVDb3B5Q2xpY2t9IC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+LFxuICAgIGNvbnRhaW5lclJlZlxuICApXG59XG5leHBvcnQgZGVmYXVsdCBFbWJlZFBvcFVwXG4iXX0= */"],
5455
- children: jsx$1("div", {
5456
- children: embedCode
5457
- })
5458
- }), jsx$1("div", {
5459
- css: [bottomStyle, process.env.NODE_ENV === "production" ? "" : ";label:EmbedPopUp;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVtYmVkUG9wVXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0VhIiwiZmlsZSI6IkVtYmVkUG9wVXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge2NyZWF0ZVBvcnRhbH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHtDbG9zZSwgQ29weX0gZnJvbSAnLi9idXR0b25zJ1xuXG5jb25zdCBlbWJlZERpYWxvZ1N0eWxlID0ge1xuICBwb3NpdGlvbjogJ2ZpeGVkJyxcbiAgdG9wOiAwLFxuICBsZWZ0OiAwLFxuICB3aWR0aDogJzEwMCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgwLCAwLCAwLCAwLjUpJyxcbiAgekluZGV4OiAxLFxufVxuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHRvcDogJzUwJScsXG4gIGxlZnQ6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGUoLTUwJSwgLTUwJSknLFxuICBiYWNrZ3JvdW5kQ29sb3I6ICcjMTYxQzI0JyxcbiAgd2lkdGg6ICc2MCUnLFxuICBoZWlnaHQ6ICdhdXRvJyxcbn1cblxuY29uc3QgdGl0bGVTdHlsZSA9IHtcbiAgZm9udFNpemU6ICcxcmVtJyxcbiAgcGFkZGluZzogJzAgMS41ZW0nLFxuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBqdXN0aWZ5Q29udGVudDogJ3NwYWNlLWJldHdlZW4nLFxufVxuXG5jb25zdCBjb250ZW50U3R5bGUgPSB7XG4gIGJhY2tncm91bmRDb2xvcjogJyMyMTJCMzYnLFxuICBwYWRkaW5nOiAnMC43NWVtJyxcbiAgbWFyZ2luOiAnMC43NWVtIDEuNWVtIDAnLFxuICAnPiBkaXYnOiB7XG4gICAgZGlzcGxheTogJy13ZWJraXQtYm94JyxcbiAgICAnLXdlYmtpdEJveE9yaWVudCc6ICd2ZXJ0aWNhbCcsXG4gICAgJy13ZWJraXRMaW5lQ2xhbXAnOiAnMycsXG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICB9LFxufVxuXG5jb25zdCBib3R0b21TdHlsZSA9IHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBqdXN0aWZ5Q29udGVudDogJ2ZsZXgtZW5kJyxcbiAgcGFkZGluZzogJzEuNWVtJyxcbn1cblxuY29uc3QgRW1iZWRQb3BVcCA9ICh7ZW1iZWRDb2RlLCBjb250YWluZXJSZWYsIG9uQ2xvc2V9KSA9PiB7XG4gIGNvbnN0IGhhbmRsZUNvcHlDbGljayA9ICgpID0+IHtcbiAgICAvLyBUT0RPOiBpT1MgU2FmYXJpL1NhZmFyaSBjb21wYXRpYmlsaXR5IGlzc3VlXG4gICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoZW1iZWRDb2RlKVxuICB9XG5cbiAgcmV0dXJuIGNyZWF0ZVBvcnRhbChcbiAgICA8ZGl2IGNzcz17W2VtYmVkRGlhbG9nU3R5bGVdfT5cbiAgICAgIDxkaXYgY3NzPXtbY29udGFpbmVyU3R5bGVdfT5cbiAgICAgICAgPGRpdiBjc3M9e1t0aXRsZVN0eWxlXX0+XG4gICAgICAgICAgPGgzPkVtYmVkIFZpZGVvPC9oMz5cbiAgICAgICAgICA8Q2xvc2Ugb25DbGljaz17b25DbG9zZX0gLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY3NzPXtbY29udGVudFN0eWxlXX0+XG4gICAgICAgICAgPGRpdj57ZW1iZWRDb2RlfTwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBjc3M9e1tib3R0b21TdHlsZV19PlxuICAgICAgICAgIDxDb3B5IHZhcmlhbnQ9XCJjb250YWluZWRcIiBvbkNsaWNrPXtoYW5kbGVDb3B5Q2xpY2t9IC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+LFxuICAgIGNvbnRhaW5lclJlZlxuICApXG59XG5leHBvcnQgZGVmYXVsdCBFbWJlZFBvcFVwXG4iXX0= */"],
5460
- children: jsx$1(Copy, {
5461
- variant: "contained",
5462
- onClick: handleCopyClick
5463
- })
5464
- })]
5465
- })
5466
- }), containerRef);
5467
- };
5468
-
5469
- var EmbedPopUp$1 = EmbedPopUp;
5470
-
5471
- /* @jsxImportSource @emotion/react */
5472
- const desktopStyle$1 = {
5473
- overlay: {
5474
- position: 'fixed',
5475
- zIndex: '1',
5476
- top: '2.5em',
5477
- right: '2em',
5478
- width: '15em'
5479
- },
5480
- open: {
5481
- opacity: '1',
5482
- transition: 'opacity 0.2s ease, transform 0s'
5483
- },
5484
- container: {
5485
- margin: 0,
5486
- padding: '0 1.5em 1em 1.5em',
5487
- display: 'flex',
5488
- flexDirection: 'column',
5489
- background: '#161C24',
5490
- opacity: 0.9
5491
- },
5492
- head: {
5493
- margin: '0.5em 0'
5494
- }
5495
- };
5496
- const shareItemStyle = {
5497
- padding: '0.5em 0',
5498
- display: 'grid',
5499
- gridTemplateColumns: '0.25fr 1fr'
5500
- };
5501
-
5502
- const MenuItemText = ({
5503
- text = ''
5504
- }) => jsx$1(FormattedMessage, {
5505
- id: text,
5506
- defaultMessage: jsx$1(FormattedMessage, {
5507
- id: `KKS.SETTING.${text}`,
5508
- defaultMessage: text
5509
- })
5510
- });
5511
-
5512
- const DesktopContainer = ({
5513
- open,
5514
- style,
5515
- children,
5516
- ...rest
5517
- }) => jsx$1("div", {
5518
- 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNoYXJlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtETyIsImZpbGUiOiJTaGFyZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7dXNlU3RhdGV9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0Zvcm1hdHRlZE1lc3NhZ2V9IGZyb20gJ2NvbnRleHQvSTE4bidcbmltcG9ydCB7QnV0dG9ufSBmcm9tICcuL2J1dHRvbnMnXG5pbXBvcnQge1RpdGxlQmFyRXh0ZW5zaW9ufSBmcm9tICcuL3VpRXh0ZW5zaW9ucydcbmltcG9ydCBJY29uIGZyb20gJy4vSWNvbidcbmltcG9ydCBFbWJlZFBvcFVwIGZyb20gJy4vRW1iZWRQb3BVcCdcblxuY29uc3QgZGVza3RvcFN0eWxlID0ge1xuICBvdmVybGF5OiB7XG4gICAgcG9zaXRpb246ICdmaXhlZCcsXG4gICAgekluZGV4OiAnMScsXG4gICAgdG9wOiAnMi41ZW0nLFxuICAgIHJpZ2h0OiAnMmVtJyxcbiAgICB3aWR0aDogJzE1ZW0nLFxuICB9LFxuICBvcGVuOiB7XG4gICAgb3BhY2l0eTogJzEnLFxuICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzJyxcbiAgfSxcbiAgY29udGFpbmVyOiB7XG4gICAgbWFyZ2luOiAwLFxuICAgIHBhZGRpbmc6ICcwIDEuNWVtIDFlbSAxLjVlbScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIGZsZXhEaXJlY3Rpb246ICdjb2x1bW4nLFxuICAgIGJhY2tncm91bmQ6ICcjMTYxQzI0JyxcbiAgICBvcGFjaXR5OiAwLjksXG4gIH0sXG4gIGhlYWQ6IHtcbiAgICBtYXJnaW46ICcwLjVlbSAwJyxcbiAgfSxcbn1cblxuY29uc3Qgc2hhcmVJdGVtU3R5bGUgPSB7XG4gIHBhZGRpbmc6ICcwLjVlbSAwJyxcbiAgZGlzcGxheTogJ2dyaWQnLFxuICBncmlkVGVtcGxhdGVDb2x1bW5zOiAnMC4yNWZyIDFmcicsXG59XG5cbmNvbnN0IE1lbnVJdGVtVGV4dCA9ICh7dGV4dCA9ICcnfSkgPT4gKFxuICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgIGlkPXt0ZXh0fVxuICAgIGRlZmF1bHRNZXNzYWdlPXtcbiAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlIGlkPXtgS0tTLlNFVFRJTkcuJHt0ZXh0fWB9IGRlZmF1bHRNZXNzYWdlPXt0ZXh0fSAvPlxuICAgIH1cbiAgLz5cbilcblxuY29uc3QgRGVza3RvcENvbnRhaW5lciA9ICh7b3Blbiwgc3R5bGUsIGNoaWxkcmVuLCAuLi5yZXN0fSkgPT4gKFxuICA8ZGl2IGNzcz17W3N0eWxlLCBvcGVuICYmIGRlc2t0b3BTdHlsZS5vcGVuXX0gey4uLnJlc3R9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9kaXY+XG4pXG5cbmNvbnN0IFNoYXJlID0gKHtcbiAgc2hhcmVBcnJheSxcbiAgb25JdGVtQ2xpY2ssXG4gIGNvbnRhaW5lclJlZixcbiAgb3BlbixcbiAgb25PcGVuLFxuICBvbkNsb3NlLFxufSkgPT4ge1xuICBjb25zdCBbb3BlbkRpYWxvZywgc2V0T3BlbkRpYWxvZ10gPSB1c2VTdGF0ZShmYWxzZSlcblxuICBjb25zdCBoYW5kbGVJdGVtT3BlbiA9IHNoYXJlID0+IHtcbiAgICBvbkl0ZW1DbGljaygpXG4gICAgaWYgKHNoYXJlLnBsYXRmb3JtLnRvTG93ZXJDYXNlKCkgPT09ICdlbWJlZCcpIHtcbiAgICAgIHNldE9wZW5EaWFsb2coIW9wZW5EaWFsb2cpXG4gICAgfSBlbHNlIHtcbiAgICAgIHdpbmRvdy5vcGVuKGAke3NoYXJlLnVybH1gLCBgX2JsYW5rYClcbiAgICB9XG4gIH1cblxuICBjb25zdCBlbWJlZENvZGUgPSBzaGFyZUFycmF5LmZpbmQoc2hhcmUgPT4gc2hhcmUuY29kZSk/LmNvZGVcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8VGl0bGVCYXJFeHRlbnNpb24gcG9zaXRpb249XCJyaWdodFwiPlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgc3RhcnRJY29uPVwic2hhcmVcIlxuICAgICAgICAgIHRpdGxlPVwiS0tTLlBMQVlFUi5TSEFSRVwiXG4gICAgICAgICAgcGxhY2VtZW50PVwidG9wXCJcbiAgICAgICAgICBvbkNsaWNrPXthc3luYyAoKSA9PiB7XG4gICAgICAgICAgICBpZiAoaXNEZXNrdG9wKCkpIHtcbiAgICAgICAgICAgICAgIW9wZW4gJiYgb25PcGVuKClcbiAgICAgICAgICAgICAgb3BlbiAmJiBvbkNsb3NlKClcbiAgICAgICAgICAgICAgcmV0dXJuXG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmIChuYXZpZ2F0b3Iuc2hhcmUpIHtcbiAgICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgICBhd2FpdCBuYXZpZ2F0b3Iuc2hhcmUoe1xuICAgICAgICAgICAgICAgICAgdXJsOiB3aW5kb3cubG9jYXRpb24uaHJlZixcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgPC9UaXRsZUJhckV4dGVuc2lvbj5cbiAgICAgIHtvcGVuICYmIChcbiAgICAgICAgPERlc2t0b3BDb250YWluZXJcbiAgICAgICAgICBzdHlsZT17ZGVza3RvcFN0eWxlLm92ZXJsYXl9XG4gICAgICAgICAgb3Blbj17b3Blbn1cbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBvbkNsb3NlKCl9XG4gICAgICAgID5cbiAgICAgICAgICA8ZGl2IGNzcz17ZGVza3RvcFN0eWxlLmNvbnRhaW5lcn0+XG4gICAgICAgICAgICA8aDMgY3NzPXtbZGVza3RvcFN0eWxlLmhlYWRdfT5TaGFyZTwvaDM+XG4gICAgICAgICAgICB7c2hhcmVBcnJheS5tYXAoc2hhcmUgPT4gKFxuICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgcm9sZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgdGFiSW5kZXg9ezB9XG4gICAgICAgICAgICAgICAgY3NzPXtbc2hhcmVJdGVtU3R5bGVdfVxuICAgICAgICAgICAgICAgIGtleT17c2hhcmUucGxhdGZvcm19XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4gaGFuZGxlSXRlbU9wZW4oc2hhcmUpfVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPEljb24gdHlwZT17c2hhcmUucGxhdGZvcm0/LnRvTG93ZXJDYXNlKCl9IC8+XG4gICAgICAgICAgICAgICAgPE1lbnVJdGVtVGV4dCB0ZXh0PXtzaGFyZS5wbGF0Zm9ybX0gLz5cbiAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9EZXNrdG9wQ29udGFpbmVyPlxuICAgICAgKX1cbiAgICAgIHtvcGVuRGlhbG9nICYmIChcbiAgICAgICAgPEVtYmVkUG9wVXBcbiAgICAgICAgICBlbWJlZENvZGU9e2VtYmVkQ29kZX1cbiAgICAgICAgICBjb250YWluZXJSZWY9e2NvbnRhaW5lclJlZn1cbiAgICAgICAgICBvbkNsb3NlPXsoKSA9PiB7XG4gICAgICAgICAgICBvbkNsb3NlKClcbiAgICAgICAgICAgIHNldE9wZW5EaWFsb2coIW9wZW5EaWFsb2cpXG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC8+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2hhcmVcbiJdfQ== */"],
5519
- ...rest,
5520
- children: children
5521
- });
5522
-
5523
- const Share = ({
5524
- shareArray,
5525
- onItemClick,
5526
- containerRef,
5527
- open,
5528
- onOpen,
5529
- onClose
5530
- }) => {
5531
- var _shareArray$find;
5532
-
5533
- const [openDialog, setOpenDialog] = useState(false);
5534
-
5535
- const handleItemOpen = share => {
5536
- onItemClick();
5537
-
5538
- if (share.platform.toLowerCase() === 'embed') {
5539
- setOpenDialog(!openDialog);
5540
- } else {
5541
- window.open(`${share.url}`, `_blank`);
5542
- }
5543
- };
5544
-
5545
- const embedCode = (_shareArray$find = shareArray.find(share => share.code)) === null || _shareArray$find === void 0 ? void 0 : _shareArray$find.code;
5546
- return jsxs(Fragment, {
5547
- children: [jsx$1(TitleBarExtension, {
5548
- position: "right",
5549
- children: jsx$1(Button, {
5550
- startIcon: "share",
5551
- title: "KKS.PLAYER.SHARE",
5552
- placement: "top",
5553
- onClick: async () => {
5554
- if (isDesktop()) {
5555
- !open && onOpen();
5556
- open && onClose();
5557
- return;
5558
- }
5559
-
5560
- if (navigator.share) {
5561
- try {
5562
- await navigator.share({
5563
- url: window.location.href
5564
- });
5565
- } catch (error) {
5566
- console.error(error);
5567
- }
5568
- }
5569
- }
5570
- })
5571
- }), open && jsx$1(DesktopContainer, {
5572
- style: desktopStyle$1.overlay,
5573
- open: open,
5574
- onClick: () => onClose(),
5575
- children: jsxs("div", {
5576
- css: desktopStyle$1.container,
5577
- children: [jsx$1("h3", {
5578
- css: [desktopStyle$1.head, process.env.NODE_ENV === "production" ? "" : ";label:Share;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNoYXJlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZHZ0IiLCJmaWxlIjoiU2hhcmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVN0YXRlfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7aXNEZXNrdG9wfSBmcm9tICd1dGlsL2Vudmlyb25tZW50J1xuaW1wb3J0IHtGb3JtYXR0ZWRNZXNzYWdlfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtUaXRsZUJhckV4dGVuc2lvbn0gZnJvbSAnLi91aUV4dGVuc2lvbnMnXG5pbXBvcnQgSWNvbiBmcm9tICcuL0ljb24nXG5pbXBvcnQgRW1iZWRQb3BVcCBmcm9tICcuL0VtYmVkUG9wVXAnXG5cbmNvbnN0IGRlc2t0b3BTdHlsZSA9IHtcbiAgb3ZlcmxheToge1xuICAgIHBvc2l0aW9uOiAnZml4ZWQnLFxuICAgIHpJbmRleDogJzEnLFxuICAgIHRvcDogJzIuNWVtJyxcbiAgICByaWdodDogJzJlbScsXG4gICAgd2lkdGg6ICcxNWVtJyxcbiAgfSxcbiAgb3Blbjoge1xuICAgIG9wYWNpdHk6ICcxJyxcbiAgICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcycsXG4gIH0sXG4gIGNvbnRhaW5lcjoge1xuICAgIG1hcmdpbjogMCxcbiAgICBwYWRkaW5nOiAnMCAxLjVlbSAxZW0gMS41ZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgICBiYWNrZ3JvdW5kOiAnIzE2MUMyNCcsXG4gICAgb3BhY2l0eTogMC45LFxuICB9LFxuICBoZWFkOiB7XG4gICAgbWFyZ2luOiAnMC41ZW0gMCcsXG4gIH0sXG59XG5cbmNvbnN0IHNoYXJlSXRlbVN0eWxlID0ge1xuICBwYWRkaW5nOiAnMC41ZW0gMCcsXG4gIGRpc3BsYXk6ICdncmlkJyxcbiAgZ3JpZFRlbXBsYXRlQ29sdW1uczogJzAuMjVmciAxZnInLFxufVxuXG5jb25zdCBNZW51SXRlbVRleHQgPSAoe3RleHQgPSAnJ30pID0+IChcbiAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICBpZD17dGV4dH1cbiAgICBkZWZhdWx0TWVzc2FnZT17XG4gICAgICA8Rm9ybWF0dGVkTWVzc2FnZSBpZD17YEtLUy5TRVRUSU5HLiR7dGV4dH1gfSBkZWZhdWx0TWVzc2FnZT17dGV4dH0gLz5cbiAgICB9XG4gIC8+XG4pXG5cbmNvbnN0IERlc2t0b3BDb250YWluZXIgPSAoe29wZW4sIHN0eWxlLCBjaGlsZHJlbiwgLi4ucmVzdH0pID0+IChcbiAgPGRpdiBjc3M9e1tzdHlsZSwgb3BlbiAmJiBkZXNrdG9wU3R5bGUub3Blbl19IHsuLi5yZXN0fT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5jb25zdCBTaGFyZSA9ICh7XG4gIHNoYXJlQXJyYXksXG4gIG9uSXRlbUNsaWNrLFxuICBjb250YWluZXJSZWYsXG4gIG9wZW4sXG4gIG9uT3BlbixcbiAgb25DbG9zZSxcbn0pID0+IHtcbiAgY29uc3QgW29wZW5EaWFsb2csIHNldE9wZW5EaWFsb2ddID0gdXNlU3RhdGUoZmFsc2UpXG5cbiAgY29uc3QgaGFuZGxlSXRlbU9wZW4gPSBzaGFyZSA9PiB7XG4gICAgb25JdGVtQ2xpY2soKVxuICAgIGlmIChzaGFyZS5wbGF0Zm9ybS50b0xvd2VyQ2FzZSgpID09PSAnZW1iZWQnKSB7XG4gICAgICBzZXRPcGVuRGlhbG9nKCFvcGVuRGlhbG9nKVxuICAgIH0gZWxzZSB7XG4gICAgICB3aW5kb3cub3BlbihgJHtzaGFyZS51cmx9YCwgYF9ibGFua2ApXG4gICAgfVxuICB9XG5cbiAgY29uc3QgZW1iZWRDb2RlID0gc2hhcmVBcnJheS5maW5kKHNoYXJlID0+IHNoYXJlLmNvZGUpPy5jb2RlXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPFRpdGxlQmFyRXh0ZW5zaW9uIHBvc2l0aW9uPVwicmlnaHRcIj5cbiAgICAgICAgPEJ1dHRvblxuICAgICAgICAgIHN0YXJ0SWNvbj1cInNoYXJlXCJcbiAgICAgICAgICB0aXRsZT1cIktLUy5QTEFZRVIuU0hBUkVcIlxuICAgICAgICAgIHBsYWNlbWVudD1cInRvcFwiXG4gICAgICAgICAgb25DbGljaz17YXN5bmMgKCkgPT4ge1xuICAgICAgICAgICAgaWYgKGlzRGVza3RvcCgpKSB7XG4gICAgICAgICAgICAgICFvcGVuICYmIG9uT3BlbigpXG4gICAgICAgICAgICAgIG9wZW4gJiYgb25DbG9zZSgpXG4gICAgICAgICAgICAgIHJldHVyblxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAobmF2aWdhdG9yLnNoYXJlKSB7XG4gICAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgYXdhaXQgbmF2aWdhdG9yLnNoYXJlKHtcbiAgICAgICAgICAgICAgICAgIHVybDogd2luZG93LmxvY2F0aW9uLmhyZWYsXG4gICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgIDwvVGl0bGVCYXJFeHRlbnNpb24+XG4gICAgICB7b3BlbiAmJiAoXG4gICAgICAgIDxEZXNrdG9wQ29udGFpbmVyXG4gICAgICAgICAgc3R5bGU9e2Rlc2t0b3BTdHlsZS5vdmVybGF5fVxuICAgICAgICAgIG9wZW49e29wZW59XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gb25DbG9zZSgpfVxuICAgICAgICA+XG4gICAgICAgICAgPGRpdiBjc3M9e2Rlc2t0b3BTdHlsZS5jb250YWluZXJ9PlxuICAgICAgICAgICAgPGgzIGNzcz17W2Rlc2t0b3BTdHlsZS5oZWFkXX0+U2hhcmU8L2gzPlxuICAgICAgICAgICAge3NoYXJlQXJyYXkubWFwKHNoYXJlID0+IChcbiAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgIHJvbGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgIGNzcz17W3NoYXJlSXRlbVN0eWxlXX1cbiAgICAgICAgICAgICAgICBrZXk9e3NoYXJlLnBsYXRmb3JtfVxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IGhhbmRsZUl0ZW1PcGVuKHNoYXJlKX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxJY29uIHR5cGU9e3NoYXJlLnBsYXRmb3JtPy50b0xvd2VyQ2FzZSgpfSAvPlxuICAgICAgICAgICAgICAgIDxNZW51SXRlbVRleHQgdGV4dD17c2hhcmUucGxhdGZvcm19IC8+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvRGVza3RvcENvbnRhaW5lcj5cbiAgICAgICl9XG4gICAgICB7b3BlbkRpYWxvZyAmJiAoXG4gICAgICAgIDxFbWJlZFBvcFVwXG4gICAgICAgICAgZW1iZWRDb2RlPXtlbWJlZENvZGV9XG4gICAgICAgICAgY29udGFpbmVyUmVmPXtjb250YWluZXJSZWZ9XG4gICAgICAgICAgb25DbG9zZT17KCkgPT4ge1xuICAgICAgICAgICAgb25DbG9zZSgpXG4gICAgICAgICAgICBzZXRPcGVuRGlhbG9nKCFvcGVuRGlhbG9nKVxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFNoYXJlXG4iXX0= */"],
5579
- children: "Share"
5580
- }), shareArray.map(share => {
5581
- var _share$platform;
5582
-
5583
- return jsxs("div", {
5584
- role: "button",
5585
- tabIndex: 0,
5586
- css: [shareItemStyle, process.env.NODE_ENV === "production" ? "" : ";label:Share;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNoYXJlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtIZ0IiLCJmaWxlIjoiU2hhcmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVN0YXRlfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7aXNEZXNrdG9wfSBmcm9tICd1dGlsL2Vudmlyb25tZW50J1xuaW1wb3J0IHtGb3JtYXR0ZWRNZXNzYWdlfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtUaXRsZUJhckV4dGVuc2lvbn0gZnJvbSAnLi91aUV4dGVuc2lvbnMnXG5pbXBvcnQgSWNvbiBmcm9tICcuL0ljb24nXG5pbXBvcnQgRW1iZWRQb3BVcCBmcm9tICcuL0VtYmVkUG9wVXAnXG5cbmNvbnN0IGRlc2t0b3BTdHlsZSA9IHtcbiAgb3ZlcmxheToge1xuICAgIHBvc2l0aW9uOiAnZml4ZWQnLFxuICAgIHpJbmRleDogJzEnLFxuICAgIHRvcDogJzIuNWVtJyxcbiAgICByaWdodDogJzJlbScsXG4gICAgd2lkdGg6ICcxNWVtJyxcbiAgfSxcbiAgb3Blbjoge1xuICAgIG9wYWNpdHk6ICcxJyxcbiAgICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcycsXG4gIH0sXG4gIGNvbnRhaW5lcjoge1xuICAgIG1hcmdpbjogMCxcbiAgICBwYWRkaW5nOiAnMCAxLjVlbSAxZW0gMS41ZW0nLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgICBiYWNrZ3JvdW5kOiAnIzE2MUMyNCcsXG4gICAgb3BhY2l0eTogMC45LFxuICB9LFxuICBoZWFkOiB7XG4gICAgbWFyZ2luOiAnMC41ZW0gMCcsXG4gIH0sXG59XG5cbmNvbnN0IHNoYXJlSXRlbVN0eWxlID0ge1xuICBwYWRkaW5nOiAnMC41ZW0gMCcsXG4gIGRpc3BsYXk6ICdncmlkJyxcbiAgZ3JpZFRlbXBsYXRlQ29sdW1uczogJzAuMjVmciAxZnInLFxufVxuXG5jb25zdCBNZW51SXRlbVRleHQgPSAoe3RleHQgPSAnJ30pID0+IChcbiAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICBpZD17dGV4dH1cbiAgICBkZWZhdWx0TWVzc2FnZT17XG4gICAgICA8Rm9ybWF0dGVkTWVzc2FnZSBpZD17YEtLUy5TRVRUSU5HLiR7dGV4dH1gfSBkZWZhdWx0TWVzc2FnZT17dGV4dH0gLz5cbiAgICB9XG4gIC8+XG4pXG5cbmNvbnN0IERlc2t0b3BDb250YWluZXIgPSAoe29wZW4sIHN0eWxlLCBjaGlsZHJlbiwgLi4ucmVzdH0pID0+IChcbiAgPGRpdiBjc3M9e1tzdHlsZSwgb3BlbiAmJiBkZXNrdG9wU3R5bGUub3Blbl19IHsuLi5yZXN0fT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5jb25zdCBTaGFyZSA9ICh7XG4gIHNoYXJlQXJyYXksXG4gIG9uSXRlbUNsaWNrLFxuICBjb250YWluZXJSZWYsXG4gIG9wZW4sXG4gIG9uT3BlbixcbiAgb25DbG9zZSxcbn0pID0+IHtcbiAgY29uc3QgW29wZW5EaWFsb2csIHNldE9wZW5EaWFsb2ddID0gdXNlU3RhdGUoZmFsc2UpXG5cbiAgY29uc3QgaGFuZGxlSXRlbU9wZW4gPSBzaGFyZSA9PiB7XG4gICAgb25JdGVtQ2xpY2soKVxuICAgIGlmIChzaGFyZS5wbGF0Zm9ybS50b0xvd2VyQ2FzZSgpID09PSAnZW1iZWQnKSB7XG4gICAgICBzZXRPcGVuRGlhbG9nKCFvcGVuRGlhbG9nKVxuICAgIH0gZWxzZSB7XG4gICAgICB3aW5kb3cub3BlbihgJHtzaGFyZS51cmx9YCwgYF9ibGFua2ApXG4gICAgfVxuICB9XG5cbiAgY29uc3QgZW1iZWRDb2RlID0gc2hhcmVBcnJheS5maW5kKHNoYXJlID0+IHNoYXJlLmNvZGUpPy5jb2RlXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPFRpdGxlQmFyRXh0ZW5zaW9uIHBvc2l0aW9uPVwicmlnaHRcIj5cbiAgICAgICAgPEJ1dHRvblxuICAgICAgICAgIHN0YXJ0SWNvbj1cInNoYXJlXCJcbiAgICAgICAgICB0aXRsZT1cIktLUy5QTEFZRVIuU0hBUkVcIlxuICAgICAgICAgIHBsYWNlbWVudD1cInRvcFwiXG4gICAgICAgICAgb25DbGljaz17YXN5bmMgKCkgPT4ge1xuICAgICAgICAgICAgaWYgKGlzRGVza3RvcCgpKSB7XG4gICAgICAgICAgICAgICFvcGVuICYmIG9uT3BlbigpXG4gICAgICAgICAgICAgIG9wZW4gJiYgb25DbG9zZSgpXG4gICAgICAgICAgICAgIHJldHVyblxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAobmF2aWdhdG9yLnNoYXJlKSB7XG4gICAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgYXdhaXQgbmF2aWdhdG9yLnNoYXJlKHtcbiAgICAgICAgICAgICAgICAgIHVybDogd2luZG93LmxvY2F0aW9uLmhyZWYsXG4gICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgIDwvVGl0bGVCYXJFeHRlbnNpb24+XG4gICAgICB7b3BlbiAmJiAoXG4gICAgICAgIDxEZXNrdG9wQ29udGFpbmVyXG4gICAgICAgICAgc3R5bGU9e2Rlc2t0b3BTdHlsZS5vdmVybGF5fVxuICAgICAgICAgIG9wZW49e29wZW59XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gb25DbG9zZSgpfVxuICAgICAgICA+XG4gICAgICAgICAgPGRpdiBjc3M9e2Rlc2t0b3BTdHlsZS5jb250YWluZXJ9PlxuICAgICAgICAgICAgPGgzIGNzcz17W2Rlc2t0b3BTdHlsZS5oZWFkXX0+U2hhcmU8L2gzPlxuICAgICAgICAgICAge3NoYXJlQXJyYXkubWFwKHNoYXJlID0+IChcbiAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgIHJvbGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIHRhYkluZGV4PXswfVxuICAgICAgICAgICAgICAgIGNzcz17W3NoYXJlSXRlbVN0eWxlXX1cbiAgICAgICAgICAgICAgICBrZXk9e3NoYXJlLnBsYXRmb3JtfVxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IGhhbmRsZUl0ZW1PcGVuKHNoYXJlKX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxJY29uIHR5cGU9e3NoYXJlLnBsYXRmb3JtPy50b0xvd2VyQ2FzZSgpfSAvPlxuICAgICAgICAgICAgICAgIDxNZW51SXRlbVRleHQgdGV4dD17c2hhcmUucGxhdGZvcm19IC8+XG4gICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvRGVza3RvcENvbnRhaW5lcj5cbiAgICAgICl9XG4gICAgICB7b3BlbkRpYWxvZyAmJiAoXG4gICAgICAgIDxFbWJlZFBvcFVwXG4gICAgICAgICAgZW1iZWRDb2RlPXtlbWJlZENvZGV9XG4gICAgICAgICAgY29udGFpbmVyUmVmPXtjb250YWluZXJSZWZ9XG4gICAgICAgICAgb25DbG9zZT17KCkgPT4ge1xuICAgICAgICAgICAgb25DbG9zZSgpXG4gICAgICAgICAgICBzZXRPcGVuRGlhbG9nKCFvcGVuRGlhbG9nKVxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFNoYXJlXG4iXX0= */"],
5587
- onClick: () => handleItemOpen(share),
5588
- children: [jsx$1(Icon, {
5589
- type: (_share$platform = share.platform) === null || _share$platform === void 0 ? void 0 : _share$platform.toLowerCase()
5590
- }), jsx$1(MenuItemText, {
5591
- text: share.platform
5592
- })]
5593
- }, share.platform);
5594
- })]
5595
- })
5596
- }), openDialog && jsx$1(EmbedPopUp$1, {
5597
- embedCode: embedCode,
5598
- containerRef: containerRef,
5599
- onClose: () => {
5600
- onClose();
5601
- setOpenDialog(!openDialog);
5602
- }
5603
- })]
5604
- });
5605
- };
5606
-
5607
- const WatermarkType = {
5608
- IMAGE: 'IMAGE',
5609
- TEXT: 'TEXT'
5610
- };
5611
- const WatermarkPosition = {
5612
- BOTTOM_RIGHT: 'POSITION_BOTTOM_RIGHT',
5613
- BOTTOM_MIDDLE: 'POSITION_BOTTOM_MIDDLE',
5614
- BOTTOM_LEFT: 'POSITION_BOTTOM_LEFT',
5615
- CENTER_RIGHT: 'POSITION_CENTER_RIGHT',
5616
- CENTER_LEFT: 'POSITION_CENTER_LEFT',
5617
- TOP_RIGHT: 'POSITION_TOP_RIGHT',
5618
- TOP_MIDDLE: 'POSITION_TOP_MIDDLE',
5619
- TOP_LEFT: 'POSITION_TOP_LEFT',
5620
- RANDOM: 'POSITION_RANDOM'
5621
- };
5622
- const RANDOM_POSITION_TABLE = [WatermarkPosition.TOP_LEFT, WatermarkPosition.TOP_MIDDLE, WatermarkPosition.TOP_RIGHT, WatermarkPosition.CENTER_LEFT, WatermarkPosition.CENTER_RIGHT, WatermarkPosition.BOTTOM_LEFT, WatermarkPosition.BOTTOM_MIDDLE, WatermarkPosition.BOTTOM_RIGHT];
5623
-
5624
- const getPositionStyle = position => {
5625
- switch (position) {
5626
- case WatermarkPosition.BOTTOM_LEFT:
5627
- return {
5628
- bottom: '48px',
5629
- textAlign: 'left'
5630
- };
5631
-
5632
- case WatermarkPosition.BOTTOM_MIDDLE:
5633
- return {
5634
- bottom: '48px',
5635
- textAlign: 'center'
5636
- };
5637
-
5638
- case WatermarkPosition.BOTTOM_RIGHT:
5639
- return {
5640
- bottom: '48px',
5641
- textAlign: 'right'
5642
- };
5643
-
5644
- case WatermarkPosition.CENTER_LEFT:
5645
- return {
5646
- top: '50%',
5647
- textAlign: 'left'
5648
- };
5649
-
5650
- case WatermarkPosition.CENTER_RIGHT:
5651
- return {
5652
- top: '50%',
5653
- textAlign: 'right'
5654
- };
5655
-
5656
- case WatermarkPosition.TOP_LEFT:
5657
- return {
5658
- top: '48px',
5659
- textAlign: 'left'
5660
- };
5661
-
5662
- case WatermarkPosition.TOP_MIDDLE:
5663
- return {
5664
- top: '48px',
5665
- textAlign: 'center'
5666
- };
5667
-
5668
- case WatermarkPosition.TOP_RIGHT:
5669
- return {
5670
- top: '48px',
5671
- textAlign: 'right'
5672
- };
5673
-
5674
- default:
5675
- return {
5676
- bottom: '48px',
5677
- textAlign: 'right'
5678
- };
5679
- }
5680
- };
5681
-
5682
- const Watermark = ({
5683
- data,
5684
- portalNode
5685
- }) => {
5686
- const type = data !== null && data !== void 0 && data.image_url ? WatermarkType.IMAGE : WatermarkType.TEXT;
5687
- const {
5688
- position
5689
- } = data || {};
5690
- const [positionKey, setPositionKey] = useState(position === WatermarkPosition.RANDOM ? WatermarkPosition.BOTTOM_RIGHT : position);
5691
- const [watermarkKey, setWatermarkKey] = useState(`${Date.now()}`);
5692
- const wmRef = useRef(null);
5693
- const intervalRef = useRef(null);
5694
- const inlineStyles = useMemo(() => ({
5695
- containerStyle: {
5696
- position: 'absolute',
5697
- zIndex: 1,
5698
- boxSizing: 'border-box',
5699
- padding: '0px 24px',
5700
- width: '100%',
5701
- fontSize: '12px',
5702
- // position properties
5703
- ...getPositionStyle(positionKey)
5704
- },
5705
- watermarkStyle: {
5706
- backgroundColor: 'rgba(0,0,0,0.6)',
5707
- borderRadius: '4px',
5708
- padding: '4px',
5709
- maxWidth: '100%',
5710
- boxSizing: 'border-box',
5711
- display: 'inline-block',
5712
- overflow: 'hidden',
5713
- textOverflow: 'ellipsis',
5714
- ...(type === WatermarkType.IMAGE ? {
5715
- backgroundImage: `url(${data.image_url})`,
5716
- backgroundColor: 'unset',
5717
- width: '7.5%',
5718
- aspectRatio: '16/9',
5719
- maxWidth: '90px',
5720
- maxHeight: '90px',
5721
- backgroundPosition: 'center',
5722
- backgroundSize: 'contain',
5723
- backgroundRepeat: 'no-repeat'
5724
- } : {})
5725
- }
5726
- }), [positionKey, type, data]);
5727
- useEffect(() => {
5728
- if (position === WatermarkPosition.RANDOM) {
5729
- intervalRef.current = setInterval(() => {
5730
- const randomIndex = Math.round(Math.random() * RANDOM_POSITION_TABLE.length - 1);
5731
- const randomPosition = RANDOM_POSITION_TABLE[randomIndex] || WatermarkPosition.BOTTOM_RIGHT;
5732
- setPositionKey(randomPosition);
5733
- }, 30000);
5734
- }
5735
-
5736
- return () => {
5737
- clearInterval(intervalRef.current);
5738
- };
5739
- }, [position]);
5740
- useEffect(() => {
5741
- const targetNode = portalNode || wmRef.current;
5742
- if (!(targetNode instanceof Node)) return;
5743
- const config = {
5744
- attributes: true,
5745
- childList: true,
5746
- characterData: true,
5747
- attributeOldValue: true,
5748
- subtree: true
5749
- };
5750
- const observer = new MutationObserver(mutations => {
5751
- mutations.forEach(() => {
5752
- observer.disconnect();
5753
- setWatermarkKey(`${Date.now()}`);
5754
- observer.observe(targetNode, config);
5755
- });
5756
- });
5757
- setTimeout(() => observer.observe(targetNode, config)); // eslint-disable-next-line consistent-return
5758
-
5759
- return () => {
5760
- observer.disconnect();
5761
- };
5762
- }, [portalNode]);
5763
- const renderElement = useMemo(() => /*#__PURE__*/jsx("div", {
5764
- style: inlineStyles.containerStyle,
5765
- ref: wmRef,
5766
- children: /*#__PURE__*/jsx("div", {
5767
- className: "pinned",
5768
- style: inlineStyles.watermarkStyle,
5769
- children: type === WatermarkType.TEXT && data.text
5770
- })
5771
- }, watermarkKey), [watermarkKey, inlineStyles, type, data]);
5772
- return portalNode ? /*#__PURE__*/ReactDom.createPortal(renderElement, portalNode) : renderElement;
5773
- };
5774
-
5775
- const loadScript = url => new Promise(resolve => {
5776
- const script = Object.assign(document.createElement('script'), {
5777
- async: true,
5778
- src: url
5779
- });
5780
- script.addEventListener('load', resolve);
5781
- document.body.appendChild(script);
5782
- });
4941
+ const loadScript = url => new Promise(resolve => {
4942
+ const script = Object.assign(document.createElement('script'), {
4943
+ async: true,
4944
+ src: url
4945
+ });
4946
+ script.addEventListener('load', resolve);
4947
+ document.body.appendChild(script);
4948
+ });
5783
4949
 
5784
4950
  /* eslint-disable no-empty */
5785
4951
  const SENDER_URL = 'https://www.gstatic.com/cv/js/sender/v1/cast_sender.js?loadCastFramework=1';
@@ -5807,13 +4973,6 @@ const getCastReceiverState = () => {
5807
4973
  })
5808
4974
  };
5809
4975
  };
5810
-
5811
- const getMediaSession = () => {
5812
- var _context$getCurrentSe;
5813
-
5814
- const context = getContext();
5815
- return (context === null || context === void 0 ? void 0 : (_context$getCurrentSe = context.getCurrentSession()) === null || _context$getCurrentSe === void 0 ? void 0 : _context$getCurrentSe.getMediaSession()) || {};
5816
- };
5817
4976
  /* global chrome, cast */
5818
4977
 
5819
4978
 
@@ -5854,19 +5013,6 @@ const connect = () => {
5854
5013
  });
5855
5014
  };
5856
5015
 
5857
- const seek = options => {
5858
- var _media$getEstimatedLi;
5859
-
5860
- const seconds = options.seconds || options;
5861
- const origin = options.origin || SeekOrigin.START;
5862
- const media = getMediaSession();
5863
- const startOverOffset = ((_media$getEstimatedLi = media.getEstimatedLiveSeekableRange()) === null || _media$getEstimatedLi === void 0 ? void 0 : _media$getEstimatedLi.end) || 0;
5864
- const currentTime = seconds + (origin === SeekOrigin.CURRENT ? media.getEstimatedTime() : 0) + startOverOffset;
5865
- media.seek(Object.assign(new chrome.cast.media.SeekRequest(), {
5866
- currentTime
5867
- }));
5868
- };
5869
-
5870
5016
  const subscribeCastState = handleStateChange => {
5871
5017
  const waitFramework = ensureSenderFramework().then(() => {
5872
5018
  const name = cast.framework.CastContextEventType.CAST_STATE_CHANGED;
@@ -6102,7 +5248,7 @@ const CastButton$1 = ({
6102
5248
  style: state === 'NO_DEVICES_AVAILABLE' && {
6103
5249
  display: 'none'
6104
5250
  },
6105
- startIcon: jsx$1(Icon, {
5251
+ startIcon: jsx$1(Icon$1, {
6106
5252
  type: icons$1[state],
6107
5253
  css: [mainStyle, state === 'CONNECTING' && connectingStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:CastButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhc3RCdXR0b24uanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkRVIiwiZmlsZSI6IkNhc3RCdXR0b24uanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHtrZXlmcmFtZXN9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuXG5pbXBvcnQge3N1YnNjcmliZUNhc3RTdGF0ZSwgY29ubmVjdCwgZGlzY29ubmVjdH0gZnJvbSAnY2FzdC9mcmFtZXdvcmsnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAncGxheWVyVWkvYnV0dG9ucydcbmltcG9ydCBJY29uIGZyb20gJ3BsYXllclVpL0ljb24nXG5pbXBvcnQgaWNvblVybHMgZnJvbSAnc3R5bGUvaWNvbidcblxuY29uc3QgbWFpblN0eWxlID0ge1xuICBiYWNrZ3JvdW5kOiAnI2ZmZicsXG4gIG1hc2tJbWFnZTogYHZhcigtLWljb24tY2FzdENvbm50ZWN0aW5nMCwgdXJsKFwiJHtpY29uVXJscy5jYXN0fVwiKSlgLFxuICBtYXNrU2l6ZTogJ2NvdmVyJyxcbn1cblxuY29uc3QgY29ubmVjdGluZ0FuaW1hdGlvbiA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIG1hc2staW1hZ2U6IHZhcigtLWljb24tY2FzdENvbm50ZWN0aW5nMCwgdXJsKFwiJHtpY29uVXJscy5jYXN0Q29ubnRlY3RpbmcwfVwiKSk7XG4gIH1cbiAgMzMlIHtcbiAgICBtYXNrLWltYWdlOiB2YXIoLS1pY29uLWNhc3RDb25udGVjdGluZzEsIHVybChcIiR7aWNvblVybHMuY2FzdENvbm50ZWN0aW5nMX1cIikpO1xuICB9XG4gIDY2JSB7XG4gICAgbWFzay1pbWFnZTogdmFyKC0taWNvbi1jYXN0Q29ubnRlY3RpbmcyLCB1cmwoXCIke2ljb25VcmxzLmNhc3RDb25udGVjdGluZzJ9XCIpKTtcbiAgfVxuICAxMDAlIHtcbiAgICBtYXNrLWltYWdlOiB2YXIoLS1pY29uLWNhc3RDb25udGVjdGluZzAsIHVybChcIiR7aWNvblVybHMuY2FzdENvbm50ZWN0aW5nMH1cIikpO1xuICB9XG5gXG5cbmNvbnN0IGNvbm5lY3RpbmdTdHlsZSA9IHtcbiAgYW5pbWF0aW9uOiBgJHtjb25uZWN0aW5nQW5pbWF0aW9ufSAzcyBpbmZpbml0ZWAsXG59XG5cbmNvbnN0IGljb25zID0ge1xuICBDT05ORUNURUQ6ICdjYXN0Q29ubmVjdGVkJyxcbiAgQ09OTkVDVElORzogJ2Nhc3RDb25udGVjdGluZzAnLFxuICBOT1RfQ09OTkVDVEVEOiAnY2FzdCcsXG59XG5cbmNvbnN0IENhc3RCdXR0b24gPSAoe29uQ2hhbmdlLCAuLi5wcm9wc30pID0+IHtcbiAgY29uc3QgW3N0YXRlLCBzZXRTdGF0ZV0gPSB1c2VTdGF0ZSgnTk9fREVWSUNFU19BVkFJTEFCTEUnKVxuICBjb25zdCB0b2dnbGVDb25uZWN0ID0gKCkgPT4ge1xuICAgIGlmIChzdGF0ZSA9PT0gJ0NPTk5FQ1RFRCcpIGRpc2Nvbm5lY3QoKVxuICAgIGVsc2UgY29ubmVjdCgpXG4gIH1cbiAgdXNlRWZmZWN0KFxuICAgICgpID0+XG4gICAgICBzdWJzY3JpYmVDYXN0U3RhdGUoY29ubmVjdGlvblN0YXRlID0+IHtcbiAgICAgICAgc2V0U3RhdGUoY29ubmVjdGlvblN0YXRlKVxuICAgICAgICBvbkNoYW5nZT8uKGNvbm5lY3Rpb25TdGF0ZSlcbiAgICAgIH0pLFxuICAgIFtvbkNoYW5nZV0sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxCdXR0b25cbiAgICAgIHN0eWxlPXtzdGF0ZSA9PT0gJ05PX0RFVklDRVNfQVZBSUxBQkxFJyAmJiB7ZGlzcGxheTogJ25vbmUnfX1cbiAgICAgIHN0YXJ0SWNvbj17XG4gICAgICAgIDxJY29uXG4gICAgICAgICAgdHlwZT17aWNvbnNbc3RhdGVdfVxuICAgICAgICAgIGNzcz17W21haW5TdHlsZSwgc3RhdGUgPT09ICdDT05ORUNUSU5HJyAmJiBjb25uZWN0aW5nU3R5bGVdfVxuICAgICAgICAvPlxuICAgICAgfVxuICAgICAgb25DbGljaz17dG9nZ2xlQ29ubmVjdH1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IENhc3RCdXR0b25cbiJdfQ== */"]
6108
5254
  }),
@@ -6181,7 +5327,7 @@ const CastButton = ({
6181
5327
  }, [onNextState]);
6182
5328
  return jsx$1(Button, {
6183
5329
  onClick: toggleConnect,
6184
- startIcon: jsx$1(Icon, {
5330
+ startIcon: jsx$1(Icon$1, {
6185
5331
  css: [{
6186
5332
  background: '#fff',
6187
5333
  maskImage: `var(--icon-castConntecting0, url("${iconUrls.cast}"))`,
@@ -6195,6 +5341,8 @@ const CastButton = ({
6195
5341
  });
6196
5342
  };
6197
5343
 
5344
+ var OriginCastButton = CastButton;
5345
+
6198
5346
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { 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)."; }
6199
5347
  const style = {
6200
5348
  display: 'flex',
@@ -6257,7 +5405,7 @@ const CastOverlay = ({
6257
5405
  children: [onBack && jsx$1(Button, {
6258
5406
  startIcon: "back",
6259
5407
  onClick: onBack
6260
- }), jsx$1(Icon, {
5408
+ }), jsx$1(Icon$1, {
6261
5409
  type: "castCenterIcon",
6262
5410
  style: iconStyle
6263
5411
  }), jsx$1("div", {
@@ -6286,884 +5434,43 @@ const CastUi = ({
6286
5434
  onLoad,
6287
5435
  values,
6288
5436
  slots = {
6289
- CastButton: source ? CastButton : CastButton$2
5437
+ CastButton: source ? OriginCastButton : CastButton$2
6290
5438
  }
6291
5439
  }) => {
6292
- const [castContent, setCastContent] = useState({});
6293
- const [connectionState, setConnectionState] = useState(CastState.NO_DEVICES_AVAILABLE);
6294
-
6295
- const onConnectionStateChange = nextState => {
6296
- onStateChange(nextState);
6297
- setConnectionState(nextState);
6298
- };
6299
-
6300
- const handleCastStarted = props => {
6301
- setCastContent({
6302
- device: props.deviceName,
6303
- title: props.mediaTitle
6304
- });
6305
- onCastStarted(props);
6306
- };
6307
-
6308
- return jsxs(Fragment, {
6309
- children: [connectionState === CastState.CONNECTED && jsx$1(CastOverlay$1, {
6310
- onBack: onBack,
6311
- ...castContent
6312
- }), jsx$1(FunctionBarExtension, {
6313
- children: jsx$1(slots.CastButton, {
6314
- onChange: onConnectionStateChange,
6315
- onCastStarted: handleCastStarted,
6316
- onLoad,
6317
- onStateChange: onConnectionStateChange,
6318
- playlist: [],
6319
- // not enable with empty list
6320
- playlistStartIndex: 0,
6321
- source,
6322
- values
6323
- })
6324
- })]
6325
- });
6326
- };
6327
-
6328
- /* eslint-disable no-bitwise */
6329
- const uuidv4 = () => {
6330
- const crypto = window.crypto || window.msCrypto;
6331
- return '10000000-1000-4000-8000-100000000000'.replace(/[018]/g, c => (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16));
6332
- };
6333
-
6334
- var _window, _window$localStorage;
6335
-
6336
- /**
6337
- * @typedef {{
6338
- * DRM_PROTAL_URL?: string
6339
- * }} debugOption
6340
- */
6341
-
6342
- /**
6343
- * @type {debugOption}
6344
- */
6345
- ({
6346
- DRM_PROTAL_URL: typeof window !== 'undefined' ? (_window = window) === null || _window === void 0 ? void 0 : (_window$localStorage = _window.localStorage) === null || _window$localStorage === void 0 ? void 0 : _window$localStorage.DRM_PROTAL_URL : ""
6347
- });
6348
-
6349
- /* eslint-disable no-param-reassign */
6350
-
6351
-
6352
- Promise.resolve();
6353
-
6354
- const logEventNames = {
6355
- playbackBeganLoading: 'playback_began_player_loading',
6356
- playbackBeganPlayerStartupTime: 'playback_began_player_startup_time',
6357
- playbackBeganVideoStartupTime: 'playback_began_video_startup_time',
6358
- playbackVideoBegan: 'playback_video_began',
6359
- playbackVideoPaused: 'playback_video_paused',
6360
- playbackVideoBufferingBegan: 'playback_video_buffering_began',
6361
- playbackVideoBufferingEnded: 'playback_video_buffering_ended',
6362
- playbackVideoEnded: 'playback_video_ended',
6363
- playbackSeekingBegan: 'playback_seeking_began',
6364
- playbackSeekingEnded: 'playback_seeking_ended',
6365
- playbackError: 'playback_error_occurred',
6366
- playbackSpeedChange: 'playback_speed_change',
6367
- playbackAudioVolumeChange: 'playback_audio_volume_change',
6368
- playbackAudioMuteChange: 'playback_audio_mute_change',
6369
- playbackStreamingQualityChangeDownload: 'playback_streaming_quality_change_download',
6370
- playbackStreamingQualityChangeRender: 'playback_streaming_quality_change_render',
6371
- playbackAudioTrackChange: 'playback_audio_track_change',
6372
- playbackSubtitleChange: 'playback_subtitle_change',
6373
- playbackLoopChange: 'playback_loop_change',
6374
- playing: 'play',
6375
- paused: 'pause',
6376
- seek: 'seek',
6377
- rewind: 'rewind',
6378
- forward: 'forward',
6379
- openSettings: 'setting_page_entered',
6380
- closeSettings: 'setting_page_exited',
6381
- speedSettingChange: 'speed_setting_change',
6382
- qualitySettingChange: 'quality_setting_change',
6383
- audioVolumeSettingChange: 'audio_volume_setting_change',
6384
- audioMuteSettingChange: 'audio_mute_setting_change',
6385
- audioTrackSettingChange: 'audio_track_setting_change',
6386
- subtitleSettingChange: 'subtitle_setting_change',
6387
- loopSettingChange: 'loop_setting_change'
6388
- };
6389
-
6390
- const mapLogEvents = ({
6391
- video,
6392
- version,
6393
- playerName,
6394
- getPlaybackStatus = () => video
6395
- }) => {
6396
- const emitter = mitt();
6397
- const state = {
6398
- status: 'init',
6399
- seeking: false,
6400
- volume: undefined,
6401
- muted: undefined,
6402
- loop: undefined,
6403
- lastPlaybackRate: 1,
6404
- hasEnabledSubtitle: false,
6405
- resourceType: undefined
6406
- };
6407
-
6408
- const baseProperties = () => ({
6409
- player_name: playerName,
6410
- playback_module_version: version || getVersion(),
6411
- system_time: Date.now() / 1000
6412
- });
6413
-
6414
- const commonProperties = () => ({ ...baseProperties(),
6415
- current_position: state.currentTime,
6416
- resource_type: state.resourceType
6417
- });
6418
-
6419
- const dispatchStart = () => {
6420
- if (state.status === 'started') {
6421
- return;
6422
- }
6423
-
6424
- state.status = 'started';
6425
- emitter.emit('playbackVideoBegan', commonProperties());
6426
- };
6427
-
6428
- const dispatchStop = () => {
6429
- if (state.status !== 'started') {
6430
- return;
6431
- }
6432
-
6433
- state.status = 'stopped';
6434
- emitter.emit('playbackVideoPaused', commonProperties());
6435
- };
6436
-
6437
- const handleEnd = () => {
6438
- if (state.status === 'started') {
6439
- dispatchStop();
6440
- }
6441
-
6442
- if (state.status !== 'init') {
6443
- state.status = 'init';
6444
- emitter.emit('playbackVideoEnded', commonProperties());
6445
- }
6446
- };
6447
-
6448
- const playbackEvents = [on(video, 'error', event => {
6449
- var _event$error, _event$error2, _event$error2$data;
6450
-
6451
- emitter.emit('playbackError', {
6452
- error_code: ((_event$error = event.error) === null || _event$error === void 0 ? void 0 : _event$error.code) || ((_event$error2 = event.error) === null || _event$error2 === void 0 ? void 0 : (_event$error2$data = _event$error2.data) === null || _event$error2$data === void 0 ? void 0 : _event$error2$data.code),
6453
- ...commonProperties()
6454
- });
6455
- }), on(video, 'durationchange', () => {
6456
- // duration may change when playing an ad stitched stream, take only initial value
6457
- if (!state.duration) {
6458
- state.duration = getPlaybackStatus().duration;
6459
- }
6460
- }), once(video, 'playerStarted', () => {
6461
- emitter.emit('playbackBeganLoading', baseProperties());
6462
- }), once(video, 'loadstart', () => {
6463
- emitter.emit('playbackBeganPlayerStartupTime', baseProperties());
6464
- }), once(video, 'canplay', () => {
6465
- state.status = 'began';
6466
- state.resourceType = isLiveDuration(video.duration) ? 'live' : 'vod';
6467
- emitter.emit('playbackBeganVideoStartupTime', { ...baseProperties(),
6468
- resource_type: state.resourceType
6469
- }); // sync state from video
6470
-
6471
- state.volume = video.volume;
6472
- state.muted = video.muted;
6473
- }), on(video, 'playing', dispatchStart), on(video, 'waiting', () => {
6474
- if (!state.buffering) {
6475
- emitter.emit('playbackVideoBufferingBegan', commonProperties());
6476
- state.buffering = true;
6477
- }
6478
- }), on(video, 'timeupdate', () => {
6479
- state.currentTime = getPlaybackStatus().currentTime;
6480
-
6481
- if (state.buffering) {
6482
- emitter.emit('playbackVideoBufferingEnded', commonProperties());
6483
- state.buffering = false;
6484
- }
6485
- }), on(video, 'pause', dispatchStop), on(video, 'seeking', () => {
6486
- state.seeking = true;
6487
- emitter.emit('playbackSeekingBegan', commonProperties());
6488
- }), on(video, 'seeked', () => {
6489
- if (state.seeking) {
6490
- emitter.emit('playbackSeekingEnded', commonProperties());
6491
- }
6492
-
6493
- state.seeking = false;
6494
- }), on(video, 'ratechange', () => {
6495
- /*
6496
- Monkey patch for shaka player legecy issue:
6497
- For more info plz see https://github.com/shaka-project/shaka-player/issues/951
6498
- `video.playbackRate` may be 0.
6499
- */
6500
- const {
6501
- lastPlaybackRate
6502
- } = state;
6503
- state.lastPlaybackRate = video.playbackRate || state.lastPlaybackRate;
6504
-
6505
- if (lastPlaybackRate === state.lastPlaybackRate) {
6506
- return;
6507
- }
6508
-
6509
- state.lastPlaybackRate = video.playbackRate;
6510
- emitter.emit('playbackSpeedChange', {
6511
- playback_speed: video.playbackRate,
6512
- ...commonProperties()
6513
- });
6514
- }), on(video, 'loopChange', () => {
6515
- if (video.loop === state.loop) {
6516
- return;
6517
- }
6518
-
6519
- emitter.emit('playbackLoopChange', {
6520
- loop: video.loop,
6521
- ...commonProperties()
6522
- });
6523
- state.loop = video.loop;
6524
- }), on(video, 'ended', handleEnd), on(video, 'volumechange', () => {
6525
- if (video.volume !== state.volume && state.volume !== undefined) {
6526
- emitter.emit('playbackAudioVolumeChange', {
6527
- volume: video.volume,
6528
- ...commonProperties()
6529
- });
6530
- state.volume = video.volume;
6531
- }
6532
-
6533
- if (video.muted !== state.muted && state.muted !== undefined) {
6534
- emitter.emit('playbackAudioMuteChange', {
6535
- muted: video.muted,
6536
- ...commonProperties()
6537
- });
6538
- state.muted = video.muted;
6539
- }
6540
- }), on(video, 'downloadQualityChange', event => {
6541
- emitter.emit('playbackStreamingQualityChangeDownload', { ...event.detail,
6542
- ...commonProperties()
6543
- });
6544
- }), on(video, 'audioTrackChange', event => {
6545
- emitter.emit('playbackAudioTrackChange', { ...event.detail,
6546
- ...commonProperties()
6547
- });
6548
- }), on(video, 'textTrackChange', event => {
6549
- var _event$detail$getText, _event$detail;
6550
-
6551
- const activeTrack = ((_event$detail$getText = (_event$detail = event.detail).getTextTracks) === null || _event$detail$getText === void 0 ? void 0 : _event$detail$getText.call(_event$detail).find(track => track.active)) || {
6552
- language: 'off',
6553
- name: 'off'
6554
- };
6555
-
6556
- if (!state.hasEnabledSubtitle && activeTrack.language === 'off') {
6557
- return;
6558
- }
6559
-
6560
- state.hasEnabledSubtitle = activeTrack.language !== 'off';
6561
- emitter.emit('playbackSubtitleChange', {
6562
- lang: activeTrack.language,
6563
- // TODO also add display name here
6564
- ...commonProperties()
6565
- });
6566
- }), on(video, 'resize', () => {
6567
- emitter.emit('playbackStreamingQualityChangeRender', {
6568
- height: video.videoHeight,
6569
- width: video.videoWidth,
6570
- ...commonProperties()
6571
- });
6572
- })];
6573
- const uiEvents = [on(video, 'audioVolumeSettingChange', event => {
6574
- var _event$detail2;
6575
-
6576
- emitter.emit('audioVolumeSettingChange', {
6577
- volume: (_event$detail2 = event.detail) === null || _event$detail2 === void 0 ? void 0 : _event$detail2.volume,
6578
- ...commonProperties()
6579
- });
6580
- })];
6581
- const registered = playbackEvents.concat(uiEvents);
6582
- return {
6583
- addEventListener: (name, handler) => emitter.on(name, handler),
6584
- all: handler => emitter.on('*', handler),
6585
-
6586
- /**
6587
- * @param
6588
- * @param {{currentTime?: string}}
6589
- * */
6590
- emit: (name, {
6591
- currentTime
6592
- }, properties) => {
6593
- emitter.emit(name, {
6594
- current_position: currentTime,
6595
- ...properties,
6596
- ...commonProperties()
6597
- });
6598
- },
6599
- updateContent: content => {
6600
- state.content = content;
6601
- },
6602
- getCommonProperties: () => commonProperties(),
6603
- reset: () => {
6604
- registered.forEach(off => off());
6605
- handleEnd();
6606
- }
6607
- };
6608
- };
6609
-
6610
- const ewma = halfLife => {
6611
- let alpha = Math.exp(Math.log(0.5) / halfLife);
6612
- let estimate = 0;
6613
- let totalWeight = 0;
6614
- return {
6615
- updateAlpha: newHalfLife => {
6616
- alpha = Math.exp(Math.log(0.5) / newHalfLife);
6617
- },
6618
- sample: (weight, value) => {
6619
- const adjAlpha = alpha ** weight;
6620
- const newEstimate = value * (1 - adjAlpha) + adjAlpha * estimate;
6621
-
6622
- if (!Number.isNaN(newEstimate)) {
6623
- estimate = newEstimate;
6624
- totalWeight += weight;
6625
- }
6626
- },
6627
- getEstimate: () => {
6628
- const zeroFactor = 1 - alpha ** totalWeight;
6629
- return estimate / zeroFactor;
6630
- }
6631
- };
6632
- };
6633
-
6634
- /* eslint-disable no-param-reassign */
6635
-
6636
- const getBufferedAhead = (mediaSource, video) => {
6637
- const items = needNativeHls() ? [video.buffered] : Array.from(mediaSource.sourceBuffers, item => item.buffered);
6638
-
6639
- if (items.length < 1) {
6640
- return 0;
6641
- }
6642
-
6643
- return Math.min(...items.map(buffered => Math.max(video.currentTime, ...Array.from({
6644
- length: (buffered === null || buffered === void 0 ? void 0 : buffered.length) || 0
6645
- }, (_, i) => buffered.end(i))))) - video.currentTime;
6646
- };
6647
-
6648
- const constants = {
6649
- hlsHighBufferFactor: 1.4,
6650
- dashHighBufferFactor: 1.2
6651
- };
6652
-
6653
- const getInfo = ({
6654
- video,
6655
- player,
6656
- bufferLength
6657
- }) => {
6658
- var _player$getPresentati;
6659
-
6660
- return {
6661
- systemTime: Date.now(),
6662
- playbackTime: video.currentTime + ((player === null || player === void 0 ? void 0 : (_player$getPresentati = player.getPresentationStartTimeAsDate()) === null || _player$getPresentati === void 0 ? void 0 : _player$getPresentati.getTime()) || 0),
6663
- playbackRate: video.playbackRate,
6664
- bufferedAhead: getBufferedAhead(player.mediaSource, video),
6665
- downloadSpeed: bufferLength.getEstimate()
6666
- };
6667
- };
6668
-
6669
- const manageLatencySafariNative = ({
6670
- player,
6671
- video,
6672
- bufferLength
6673
- }, options) => {
6674
- let lastBuffered;
6675
- let remainingAttempts = 2; // TODO assume no handle start-over
6676
-
6677
- const updateIntervalId = setInterval(() => {
6678
- var _options$onUpdate;
6679
-
6680
- const info = getInfo({
6681
- player,
6682
- video,
6683
- bufferLength
6684
- });
6685
- bufferLength.sample(1, Math.max(0, info.bufferedAhead));
6686
- (_options$onUpdate = options.onUpdate) === null || _options$onUpdate === void 0 ? void 0 : _options$onUpdate.call(options, { ...options,
6687
- ...info
6688
- }); // Magic numbers to be tuned further
6689
-
6690
- if (video.paused) {
6691
- remainingAttempts = 2;
6692
- } else if (info.bufferedAhead > 8) {
6693
- console.debug(`Jump`, info.bufferedAhead, lastBuffered);
6694
- video.currentTime += info.bufferedAhead;
6695
- } else if (remainingAttempts > 0 && // by default target buffer length * factor is 2.1
6696
- info.bufferedAhead > options.targetBufferLength * constants.hlsHighBufferFactor && // Safari updates seek range when a segment is completely added
6697
- info.bufferedAhead > lastBuffered + options.hlsSegmentLength / 4) {
6698
- console.debug(`Seek ahead`, info.bufferedAhead, lastBuffered);
6699
- video.currentTime += 10;
6700
- remainingAttempts -= 1;
6701
- }
6702
-
6703
- if (bufferLength.getEstimate() > options.targetBufferLength * constants.hlsHighBufferFactor) {
6704
- remainingAttempts = 2;
6705
- }
6706
-
6707
- lastBuffered = info.bufferedAhead;
6708
- }, options.updateInterval);
6709
- return () => clearInterval(updateIntervalId);
6710
- };
6711
-
6712
- const manageLatencyMse = ({
6713
- player,
6714
- video,
6715
- bufferLength
6716
- }, options) => {
6717
- let lastPlaybackTime = 0;
6718
- player.configure({
6719
- manifest: {
6720
- dash: {
6721
- ignoreSuggestedPresentationDelay: true
6722
- }
6723
- },
6724
- streaming: {
6725
- lowLatencyMode: true,
6726
- bufferingGoal: 10.0,
6727
- rebufferingGoal: 0.01,
6728
- updateIntervalSeconds: 0.2,
6729
- gapDetectionThreshold: 0.001,
6730
- inaccurateManifestTolerance: 1,
6731
- retryParameters: {
6732
- baseDelay: 50,
6733
- backoffFactor: 1.2,
6734
- fuzzFactor: 0,
6735
- maxAttempts: 66
6736
- }
6737
- }
6738
- });
6739
- const updateIntervalId = setInterval(() => {
6740
- var _options$onUpdate2;
6741
-
6742
- const info = getInfo({
6743
- player,
6744
- video,
6745
- bufferLength
6746
- });
6747
- bufferLength.sample(1, Math.max(0, info.bufferedAhead));
6748
- (_options$onUpdate2 = options.onUpdate) === null || _options$onUpdate2 === void 0 ? void 0 : _options$onUpdate2.call(options, { ...options,
6749
- ...info
6750
- });
6751
-
6752
- if (!player || !video || video.currentTime < lastPlaybackTime + 0.08) {
6753
- return;
6754
- }
6755
-
6756
- lastPlaybackTime = video.currentTime;
6757
-
6758
- if (info.bufferedAhead > 5) {
6759
- video.currentTime = video.currentTime + info.bufferedAhead - 2.5;
6760
- console.debug(`Buffer abundant, seek from ${video.currentTime} to ${video.currentTime}`);
6761
- return;
6762
- } // start speedup at 120%, stop when under 100%, to avoid frequent speed changes when near 100%
6763
-
6764
-
6765
- const bufferCap = +options.targetBufferLength * (info.playbackRate > 1 ? 1 : constants.dashHighBufferFactor);
6766
- const rate = bufferLength.getEstimate() > bufferCap && options.speedup ? +options.speedup : 0;
6767
-
6768
- if ((video === null || video === void 0 ? void 0 : video.currentTime) > 0) {
6769
- video.playbackRate = 1 + rate / 100;
6770
- }
6771
- }, options.updateInterval);
6772
- return () => clearInterval(updateIntervalId);
6773
- };
6774
-
6775
- const latencyManager = (player, video) => {
6776
- const currentOptions = {
6777
- speedup: 7,
6778
- targetBufferLength: 1.5,
6779
- hlsSegmentLength: 4,
6780
- updateInterval: 100
6781
- };
6782
- let stop; // TODO reset on updateInterval change
6783
-
6784
- const bufferLength = ewma(1500 / currentOptions.updateInterval);
6785
-
6786
- const configure = config => {
6787
- if (!config) {
6788
- return getInfo({
6789
- player,
6790
- video,
6791
- bufferLength
6792
- });
6793
- }
6794
-
6795
- if ('enabled' in config && Boolean(config.enabled) !== currentOptions.enabled) {
6796
- var _stop;
6797
-
6798
- (_stop = stop) === null || _stop === void 0 ? void 0 : _stop();
6799
-
6800
- if (config.enabled) {
6801
- stop = (needNativeHls() ? manageLatencySafariNative : manageLatencyMse)({
6802
- player,
6803
- video,
6804
- bufferLength
6805
- }, currentOptions);
6806
- }
6807
- }
6808
-
6809
- Object.assign(currentOptions, config);
6810
- if ('segmentTimestampOffset' in config) window.segmentTimestampOffset = config.segmentTimestampOffset;
6811
- };
6812
-
6813
- return {
6814
- configure
6815
- };
6816
- };
6817
-
6818
- /**
6819
- * Parses an XML duration string.
6820
- * Negative values are not supported. Years and months are treated as exactly
6821
- * 365 and 30 days respectively.
6822
- * @param {string} durationString The duration string, e.g., "PT1H3M43.2S",
6823
- * which means 1 hour, 3 minutes, and 43.2 seconds.
6824
- * @return {?number} The parsed duration in seconds on success; otherwise,
6825
- * return null.
6826
- * @see {@link http://www.datypic.com/sc/xsd/t-xsd_duration.html}
6827
- */
6828
- const parseDuration = durationString => {
6829
- if (!durationString) {
6830
- return null;
6831
- }
6832
-
6833
- const re = '^P(?:([0-9]*)Y)?(?:([0-9]*)M)?(?:([0-9]*)D)?' + '(?:T(?:([0-9]*)H)?(?:([0-9]*)M)?(?:([0-9.]*)S)?)?$';
6834
- const matches = new RegExp(re).exec(durationString);
6835
-
6836
- if (!matches) {
6837
- console.warning('Invalid duration string:', durationString);
6838
- return null;
6839
- } // Note: Number(null) == 0 but Number(undefined) == NaN.
6840
-
6841
-
6842
- const years = Number(matches[1] || null);
6843
- const months = Number(matches[2] || null);
6844
- const days = Number(matches[3] || null);
6845
- const hours = Number(matches[4] || null);
6846
- const minutes = Number(matches[5] || null);
6847
- const seconds = Number(matches[6] || null); // Assume a year always has 365 days and a month always has 30 days.
6848
-
6849
- const d = 60 * 60 * 24 * 365 * years + 60 * 60 * 24 * 30 * months + 60 * 60 * 24 * days + 60 * 60 * hours + 60 * minutes + seconds;
6850
- return Number.isFinite(d) ? d : null;
6851
- };
6852
-
6853
- const normalize = (doc, template, period) => {
6854
- const segmentDuration = parseFloat(template.getAttribute('duration'), 10);
6855
-
6856
- if (!segmentDuration) {
6857
- return;
6858
- }
6859
-
6860
- const timescale = parseFloat(template.getAttribute('timescale'), 10);
6861
- const periodDuration = parseDuration(period.getAttribute('duration'));
6862
- const item = doc.createElement('S');
6863
- item.setAttribute('d', segmentDuration);
6864
- item.setAttribute('r', Math.ceil(periodDuration * timescale / segmentDuration) - 1);
6865
- const timeline = doc.createElement('SegmentTimeline');
6866
- timeline.appendChild(item);
6867
- template.appendChild(timeline);
6868
- template.removeAttribute('duration');
6869
- };
6870
-
6871
- const fixDashManifest = (data, {
6872
- minTimeShiftBufferDepth
6873
- } = {}) => {
6874
- const doc = new DOMParser().parseFromString(data, 'text/xml'); // only dynamic manifest needs timeShiftBufferDepth
6875
-
6876
- const root = doc.children[0];
6877
-
6878
- if (root.getAttribute('type') === 'dynamic') {
6879
- if (root.getAttribute('timeShiftBufferDepth') < minTimeShiftBufferDepth) {
6880
- root.setAttribute('timeShiftBufferDepth', minTimeShiftBufferDepth);
6881
- }
6882
- } else if (root.hasAttribute('timeShiftBufferDepth')) {
6883
- root.removeAttribute('timeShiftBufferDepth');
6884
- } // workaround multi-period segment template bug, normalize to segment timelines
6885
-
6886
-
6887
- if (doc.querySelectorAll('Period').length > 1) {
6888
- Array.from(doc.querySelectorAll('Period')).forEach(period => {
6889
- Array.from(period.querySelectorAll('SegmentTemplate')).forEach(template => normalize(doc, template, period));
6890
- });
6891
- }
6892
-
6893
- window.manifestDoc = doc;
6894
- return new XMLSerializer().serializeToString(doc);
6895
- };
6896
-
6897
- const getChapterIndex = (chapters, time) => chapters.reduce((currentIndex, chapter, index) => time >= chapter.startTime && chapter.startTime > chapters[currentIndex].startTime ? index : currentIndex, 0);
6898
-
6899
- const dispatchChapterEvents = ({
6900
- media,
6901
- chapters = [],
6902
- getTime
6903
- }) => {
6904
- const state = {};
6905
-
6906
- const updateChapter = event => {
6907
- if (media.webkitDisplayingFullscreen) {
6908
- return; // in iOS fullscreen UI updates are not possible, so skip
6909
- }
6910
-
6911
- const next = getChapterIndex(chapters, getTime());
6912
-
6913
- if (next !== state.currentChapterIndex) {
6914
- media.dispatchEvent(Object.assign(new CustomEvent('chapterChange'), {
6915
- action: /seek/.test(event === null || event === void 0 ? void 0 : event.type) ? 'seek' : '',
6916
- chapterIndex: next,
6917
- chapter: chapters[next]
6918
- }));
6919
- }
6920
-
6921
- state.currentChapterIndex = next;
6922
- };
6923
-
6924
- const listeners = [on(media, 'seeking', updateChapter), on(media, 'timeupdate', updateChapter), on(media, 'seeked', updateChapter), on(media, 'webkitendfullscreen', updateChapter)];
6925
- const checkInterval = setInterval(() => {
6926
- var _chapters;
6927
-
6928
- const timeToNext = (((_chapters = chapters[state.currentChapterIndex + 1]) === null || _chapters === void 0 ? void 0 : _chapters.startTime) - getTime() + 0.05) / media.playbackRate;
6929
-
6930
- if (timeToNext >= 0 && timeToNext <= 1) {
6931
- state.timerId = setTimeout(updateChapter, timeToNext * 1000);
6932
- }
6933
- }, 1000);
6934
- return () => {
6935
- clearInterval(checkInterval);
6936
- clearInterval(state.timerId);
6937
- listeners.forEach(removeListener => removeListener());
6938
- };
6939
- };
6940
-
6941
- const waitMs = time => new Promise(resolve => {
6942
- setTimeout(resolve, time);
6943
- });
6944
-
6945
- const retryWithBackoff = async ({
6946
- fn,
6947
- maxRetries = 10,
6948
- initialDelay = 1000
6949
- }) => {
6950
- let retryDelay = initialDelay;
6951
-
6952
- for (let retry = 1; retry <= maxRetries; retry++) {
6953
- try {
6954
- return await fn();
6955
- } catch (error) {
6956
- console.error(`Retry #${retry} failed:`, error);
6957
-
6958
- if (retry === maxRetries) {
6959
- console.error('Max retries reached. Giving up.');
6960
- throw error;
6961
- }
6962
-
6963
- await waitMs(retryDelay);
6964
- retryDelay += retry * 1000;
6965
- }
6966
- }
6967
- };
6968
-
6969
- var retryWithBackoff$1 = retryWithBackoff;
6970
-
6971
- const retrieveModuleConfig = (modulesConfig, query) => {
6972
- const result = {};
6973
- Object.entries(modulesConfig).forEach(([key, value]) => {
6974
- if (key.startsWith(`${query}.`)) {
6975
- const targetKey = key.replace(`${query}.`, '');
6976
- result[targetKey] = value;
6977
- }
6978
- });
6979
- return result;
6980
- };
6981
-
6982
- /* eslint-disable camelcase */
6983
- const HEARTBEAT_INTERVAL_MS = 10000;
6984
-
6985
- const eventHeartbeat = ({
6986
- token,
6987
- resourceId,
6988
- sessionId,
6989
- userId,
6990
- deviceId,
6991
- rawData,
6992
- endpoint = process.env.BV_ONE_EVENT_HEARTBEAT_API + '/v1/events',
6993
- resourceTypes
6994
- }) => {
6995
- if (!token) {
6996
- return;
6997
- }
6998
-
6999
- const resourceType = rawData.analyticsConfig.resource_type || resourceTypes[rawData.logTarget.getCommonProperties().resource_type || 'vod'];
7000
- return setInterval(async () => {
7001
- const payload = {
7002
- event_type: 'heartbeat_log',
7003
- event_name: 'playback_player_active',
7004
- event_content: JSON.stringify({
7005
- resource_type: resourceType,
7006
- resource_id: resourceId,
7007
- session_id: sessionId,
7008
- device_id: deviceId,
7009
- user_id: userId,
7010
- ...rawData.analyticsConfig
7011
- }),
7012
- event_time: new Date().toISOString()
7013
- }; // Avoid template literals because the env variable would be replaced in the rollup
7014
-
7015
- await retryWithBackoff$1({
7016
- fn: () => axios.post(endpoint, payload, {
7017
- headers: {
7018
- 'Kks-Bv-Token': token
7019
- }
7020
- })
7021
- });
7022
- }, HEARTBEAT_INTERVAL_MS);
7023
- };
7024
-
7025
- var eventHeartbeat$1 = eventHeartbeat;
7026
-
7027
- /* eslint-disable camelcase */
7028
-
7029
- const getDeviceInfo = () => {
7030
- const browser = getBrowser();
7031
- return {
7032
- browser: `${browser.name} ${browser.version}`,
7033
- device_category: isDesktop() ? 'Desktop' : 'Mobile',
7034
- device_platform: getOS().name
7035
- };
7036
- };
7037
-
7038
- const DEVICE_ID_KEY = 'kks-device-id';
7039
-
7040
- const getDefaultDeviceId = () => {
7041
- const deviceId = window.localStorage.getItem(DEVICE_ID_KEY) || uuidv4();
7042
- window.localStorage.setItem(DEVICE_ID_KEY, deviceId);
7043
- return deviceId;
7044
- };
7045
-
7046
- const resourceTypes = {
7047
- vod: 'RESOURCE_TYPE_VOD_EVENT',
7048
- live: 'RESOURCE_TYPE_LIVE_EVENT'
7049
- };
7050
- /**
7051
- * This method creates analytics module instance and return it.
7052
- * @param createAnalyticsParameter
7053
- * @returns Analytics module instance
7054
- */
7055
-
7056
- const createAnalytics = ({
7057
- video,
7058
- onPlaylogFired,
7059
- modulesConfig
7060
- }) => {
7061
- const {
7062
- token,
7063
- eventEndpoint,
7064
- heartbeatEndpoint,
7065
- ...analyticsConfig
7066
- } = retrieveModuleConfig(modulesConfig, 'analytics');
7067
- const resourceId = analyticsConfig.resourceId || analyticsConfig.resource_id || '';
7068
- const resourceType = analyticsConfig.resourceType || analyticsConfig.resource_type || '';
7069
- const userId = analyticsConfig.userId || analyticsConfig.user_id || '';
7070
- const sessionId = analyticsConfig.sessionId || analyticsConfig.session_id || uuidv4();
7071
- const deviceId = analyticsConfig.deviceId || analyticsConfig.device_id || getDefaultDeviceId();
7072
- const eventEndpointUrl = eventEndpoint || process.env.BV_ONE_EVENT_API + '/v1/events';
7073
- const heartbeatEndpointUrl = heartbeatEndpoint || process.env.BV_ONE_EVENT_HEARTBEAT_API + '/v1/events';
7074
-
7075
- if (!resourceType) {
7076
- console.warn('Please check resource_type in your modulesConfig. Otherwise, the player will send default resource_type, ex: RESOURCE_TYPE_VOD_EVENT or RESOURCE_TYPE_LIVE_EVENT !');
7077
- } // @ts-ignore
7078
-
7079
-
7080
- const logTarget = mapLogEvents({
7081
- video,
7082
- playerName: 'shaka',
7083
- version: "2.9.444"
7084
- });
7085
- logTarget.all((type, data) => {
7086
- const payload = {
7087
- event_type: 'playback_log',
7088
- // @ts-ignore
7089
- event_name: logEventNames[type] || type,
7090
- event_content: JSON.stringify({
7091
- session_id: sessionId,
7092
- ...data,
7093
- ...getDeviceInfo(),
7094
- ...analyticsConfig,
7095
- resource_id: resourceId,
7096
- resource_type: resourceType || resourceTypes[data.resource_type || 'vod'],
7097
- user_id: userId,
7098
- device_id: deviceId
7099
- }),
7100
- event_time: new Date(data.system_time * 1000).toISOString()
7101
- };
7102
- onPlaylogFired === null || onPlaylogFired === void 0 ? void 0 : onPlaylogFired(payload.event_name, data);
7103
-
7104
- if (!token) {
7105
- return;
7106
- }
7107
-
7108
- retryWithBackoff$1({
7109
- fn: () => axios.post(eventEndpointUrl, payload, {
7110
- headers: {
7111
- 'Kks-Bv-Token': token
7112
- }
7113
- })
7114
- });
7115
- });
7116
- const heartbeatTimer = eventHeartbeat$1({
7117
- token,
7118
- sessionId,
7119
- resourceId,
7120
- userId,
7121
- deviceId,
7122
- endpoint: heartbeatEndpointUrl,
7123
- rawData: {
7124
- analyticsConfig,
7125
- // @ts-ignore
7126
- logTarget
7127
- },
7128
- resourceTypes
7129
- });
7130
- return {
7131
- sendEvent: logTarget.emit,
7132
- sendLog: logTarget.emit,
7133
- reset: () => {
7134
- logTarget.reset();
7135
- clearInterval(heartbeatTimer);
7136
- }
7137
- };
7138
- };
7139
-
7140
- const sendChangeSettingsLog = (name, value, sendLog, playbackTime) => {
7141
- switch (name) {
7142
- case 'speed':
7143
- return sendLog === null || sendLog === void 0 ? void 0 : sendLog('speedSettingChange', playbackTime, {
7144
- playback_speed: value
7145
- });
7146
-
7147
- case 'quality':
7148
- return sendLog === null || sendLog === void 0 ? void 0 : sendLog('qualitySettingChange', playbackTime, {
7149
- quality_name: value
7150
- });
5440
+ const [castContent, setCastContent] = useState({});
5441
+ const [connectionState, setConnectionState] = useState(CastState.NO_DEVICES_AVAILABLE);
7151
5442
 
7152
- case 'audio':
7153
- return sendLog === null || sendLog === void 0 ? void 0 : sendLog('audioTrackSettingChange', playbackTime, {
7154
- lang: value
7155
- });
5443
+ const onConnectionStateChange = nextState => {
5444
+ onStateChange(nextState);
5445
+ setConnectionState(nextState);
5446
+ };
7156
5447
 
7157
- case 'subtitles':
7158
- return sendLog === null || sendLog === void 0 ? void 0 : sendLog('subtitleSettingChange', playbackTime, {
7159
- lang: value
7160
- });
5448
+ const handleCastStarted = props => {
5449
+ setCastContent({
5450
+ device: props.deviceName,
5451
+ title: props.mediaTitle
5452
+ });
5453
+ onCastStarted(props);
5454
+ };
7161
5455
 
7162
- case 'loop':
7163
- return sendLog === null || sendLog === void 0 ? void 0 : sendLog('loopSettingChange', playbackTime, {
7164
- loop: value
7165
- });
7166
- }
5456
+ return jsxs(Fragment, {
5457
+ children: [connectionState === CastState.CONNECTED && jsx$1(CastOverlay$1, {
5458
+ onBack: onBack,
5459
+ ...castContent
5460
+ }), jsx$1(FunctionBarExtension, {
5461
+ children: jsx$1(slots.CastButton, {
5462
+ onChange: onConnectionStateChange,
5463
+ onCastStarted: handleCastStarted,
5464
+ onLoad,
5465
+ onStateChange: onConnectionStateChange,
5466
+ playlist: [],
5467
+ // not enable with empty list
5468
+ playlistStartIndex: 0,
5469
+ source,
5470
+ values
5471
+ })
5472
+ })]
5473
+ });
7167
5474
  };
7168
5475
 
7169
5476
  const printVersion = () => {
@@ -7559,6 +5866,85 @@ const setupKKFariplay = (player, extensionOptions) => {
7559
5866
  extensionOptions.responseHandlers.push(stripResponseCkc);
7560
5867
  };
7561
5868
 
5869
+ /**
5870
+ * Parses an XML duration string.
5871
+ * Negative values are not supported. Years and months are treated as exactly
5872
+ * 365 and 30 days respectively.
5873
+ * @param {string} durationString The duration string, e.g., "PT1H3M43.2S",
5874
+ * which means 1 hour, 3 minutes, and 43.2 seconds.
5875
+ * @return {?number} The parsed duration in seconds on success; otherwise,
5876
+ * return null.
5877
+ * @see {@link http://www.datypic.com/sc/xsd/t-xsd_duration.html}
5878
+ */
5879
+ const parseDuration = durationString => {
5880
+ if (!durationString) {
5881
+ return null;
5882
+ }
5883
+
5884
+ const re = '^P(?:([0-9]*)Y)?(?:([0-9]*)M)?(?:([0-9]*)D)?' + '(?:T(?:([0-9]*)H)?(?:([0-9]*)M)?(?:([0-9.]*)S)?)?$';
5885
+ const matches = new RegExp(re).exec(durationString);
5886
+
5887
+ if (!matches) {
5888
+ console.warning('Invalid duration string:', durationString);
5889
+ return null;
5890
+ } // Note: Number(null) == 0 but Number(undefined) == NaN.
5891
+
5892
+
5893
+ const years = Number(matches[1] || null);
5894
+ const months = Number(matches[2] || null);
5895
+ const days = Number(matches[3] || null);
5896
+ const hours = Number(matches[4] || null);
5897
+ const minutes = Number(matches[5] || null);
5898
+ const seconds = Number(matches[6] || null); // Assume a year always has 365 days and a month always has 30 days.
5899
+
5900
+ const d = 60 * 60 * 24 * 365 * years + 60 * 60 * 24 * 30 * months + 60 * 60 * 24 * days + 60 * 60 * hours + 60 * minutes + seconds;
5901
+ return Number.isFinite(d) ? d : null;
5902
+ };
5903
+
5904
+ const normalize = (doc, template, period) => {
5905
+ const segmentDuration = parseFloat(template.getAttribute('duration'), 10);
5906
+
5907
+ if (!segmentDuration) {
5908
+ return;
5909
+ }
5910
+
5911
+ const timescale = parseFloat(template.getAttribute('timescale'), 10);
5912
+ const periodDuration = parseDuration(period.getAttribute('duration'));
5913
+ const item = doc.createElement('S');
5914
+ item.setAttribute('d', segmentDuration);
5915
+ item.setAttribute('r', Math.ceil(periodDuration * timescale / segmentDuration) - 1);
5916
+ const timeline = doc.createElement('SegmentTimeline');
5917
+ timeline.appendChild(item);
5918
+ template.appendChild(timeline);
5919
+ template.removeAttribute('duration');
5920
+ };
5921
+
5922
+ const fixDashManifest = (data, {
5923
+ minTimeShiftBufferDepth
5924
+ } = {}) => {
5925
+ const doc = new DOMParser().parseFromString(data, 'text/xml'); // only dynamic manifest needs timeShiftBufferDepth
5926
+
5927
+ const root = doc.children[0];
5928
+
5929
+ if (root.getAttribute('type') === 'dynamic') {
5930
+ if (root.getAttribute('timeShiftBufferDepth') < minTimeShiftBufferDepth) {
5931
+ root.setAttribute('timeShiftBufferDepth', minTimeShiftBufferDepth);
5932
+ }
5933
+ } else if (root.hasAttribute('timeShiftBufferDepth')) {
5934
+ root.removeAttribute('timeShiftBufferDepth');
5935
+ } // workaround multi-period segment template bug, normalize to segment timelines
5936
+
5937
+
5938
+ if (doc.querySelectorAll('Period').length > 1) {
5939
+ Array.from(doc.querySelectorAll('Period')).forEach(period => {
5940
+ Array.from(period.querySelectorAll('SegmentTemplate')).forEach(template => normalize(doc, template, period));
5941
+ });
5942
+ }
5943
+
5944
+ window.manifestDoc = doc;
5945
+ return new XMLSerializer().serializeToString(doc);
5946
+ };
5947
+
7562
5948
  /*! @license
7563
5949
  * Shaka Player
7564
5950
  * Copyright 2016 Google LLC
@@ -8711,7 +7097,7 @@ const loadShaka = async (videoElement, config = {}, options = {}) => {
8711
7097
  // See: https://github.com/shaka-project/shaka-player/issues/3526
8712
7098
  safeSeekOffset: 0,
8713
7099
  rebufferingGoal: 0,
8714
- ...(needNativeHls() && {
7100
+ ...(isSafari() && {
8715
7101
  preferNativeHls: true
8716
7102
  }),
8717
7103
  ...config.streaming
@@ -8803,7 +7189,7 @@ const loadShaka = async (videoElement, config = {}, options = {}) => {
8803
7189
  responseHandlers: [rewriteDashManifest]
8804
7190
  };
8805
7191
 
8806
- if (needNativeHls()) {
7192
+ if (isSafari()) {
8807
7193
  setupKKFariplay(player, extensionOptions);
8808
7194
  }
8809
7195
 
@@ -8927,18 +7313,23 @@ const baseVideoStyle = {
8927
7313
  objectFit: 'contain',
8928
7314
  width: '100%',
8929
7315
  maxHeight: '100%',
7316
+ '&:fullscreen': {
7317
+ position: 'absolute',
7318
+ top: 0,
7319
+ left: 0,
7320
+ bottom: 0,
7321
+ right: 0
7322
+ },
8930
7323
  '~ .shaka-text-container': {
8931
7324
  position: 'absolute',
8932
7325
  height: '100%',
8933
7326
  width: '100%'
8934
7327
  }
8935
7328
  };
8936
- const defaultModulesConfig = {};
8937
7329
  const emptyArray = [];
8938
7330
 
8939
7331
  const Video = ({
8940
7332
  source,
8941
- videoStyle,
8942
7333
  playbackState: targetState,
8943
7334
  currentTime: targetTime,
8944
7335
  playbackRate,
@@ -8950,19 +7341,16 @@ const Video = ({
8950
7341
  iOSFullscreenDetectThreshold,
8951
7342
  // TODO organize props
8952
7343
  plugins = [],
8953
- modulesConfig = defaultModulesConfig,
8954
7344
  shaka,
8955
7345
  bitmovin,
8956
7346
  license,
8957
7347
  validationHost,
8958
7348
  videoRef,
8959
7349
  playerRef,
8960
- analyticsRef,
8961
7350
  onPlayerLoaded,
8962
7351
  onPlaybackStateChange,
8963
7352
  onBlockedAutoplay,
8964
7353
  onPlaylogFired,
8965
- subtitlesPosition,
8966
7354
  ...videoAttributes
8967
7355
  }) => {
8968
7356
  var _videoElement$current;
@@ -8976,26 +7364,6 @@ const Video = ({
8976
7364
  const videoElement = useRef();
8977
7365
  const [playbackState, setPlaybackState] = useState('');
8978
7366
  const [player, setPlayer] = useState();
8979
- const latencyManagerRef = useRef();
8980
- const eventSenderRef = useRef();
8981
- const activePlayback = !/error|ended|emptied/.test(playbackState);
8982
- useEffect(() => {
8983
- if (!activePlayback) {
8984
- return;
8985
- }
8986
-
8987
- eventSenderRef.current = createAnalytics({
8988
- video: videoElement.current,
8989
- onPlaylogFired,
8990
- modulesConfig
8991
- });
8992
- analyticsRef.current = eventSenderRef.current;
8993
- return () => {
8994
- var _eventSenderRef$curre;
8995
-
8996
- return (_eventSenderRef$curre = eventSenderRef.current) === null || _eventSenderRef$curre === void 0 ? void 0 : _eventSenderRef$curre.reset();
8997
- }; // TODO restart analytics on update of moduleConfig.analytics.*
8998
- }, [activePlayback]);
8999
7367
  useEffect(() => {
9000
7368
  const loadTask = loadPlayer(videoElement.current, {
9001
7369
  container: videoContainer.current,
@@ -9010,10 +7378,6 @@ const Video = ({
9010
7378
  playerRef.curret = basePlayer;
9011
7379
  }
9012
7380
 
9013
- if (basePlayer.modules) {
9014
- basePlayer.modules.analytics = eventSenderRef.current;
9015
- }
9016
-
9017
7381
  return basePlayer;
9018
7382
  });
9019
7383
  const offPlaybackState = subscribePlaybackState(videoElement.current, (event, state) => {
@@ -9033,22 +7397,11 @@ const Video = ({
9033
7397
  }, []);
9034
7398
  useEffect(() => {
9035
7399
  if (source && (source.length > 0 || source.src || source.hls || source.dash) && player !== null && player !== void 0 && player.isAlive()) {
9036
- Promise.resolve(false).then(ullEnabled => {
9037
- var _latencyManagerRef$cu;
9038
-
9039
- if (ullEnabled && !latencyManagerRef.current) {
9040
- latencyManagerRef.current = latencyManager(player, videoElement.current);
9041
- }
9042
-
9043
- (_latencyManagerRef$cu = latencyManagerRef.current) === null || _latencyManagerRef$cu === void 0 ? void 0 : _latencyManagerRef$cu.configure({
9044
- enabled: ullEnabled
9045
- });
9046
- load(videoElement.current, {
9047
- player,
9048
- plugins,
9049
- startTime: targetTime
9050
- }, source);
9051
- }).catch(error => console.warn(error));
7400
+ Promise.resolve(false).then(() => load(videoElement.current, {
7401
+ player,
7402
+ plugins,
7403
+ startTime: targetTime
7404
+ }, source)).catch(error => console.warn(error));
9052
7405
  }
9053
7406
 
9054
7407
  if ((!source || source.length === 0) && player) {
@@ -9083,7 +7436,7 @@ const Video = ({
9083
7436
 
9084
7437
  if (player !== null && player !== void 0 && player.isAlive() && Math.abs(currentTime - targetTime) > 0.5) {
9085
7438
  // seeking unavailable cases are handled by seek function
9086
- seek$1(videoElement.current, {
7439
+ seek(videoElement.current, {
9087
7440
  player,
9088
7441
  plugins
9089
7442
  }, targetTime);
@@ -9118,8 +7471,8 @@ const Video = ({
9118
7471
  return jsx$1("div", {
9119
7472
  ref: videoContainer,
9120
7473
  css: /*#__PURE__*/css({
9121
- video: [baseVideoStyle, videoStyle]
9122
- }, process.env.NODE_ENV === "production" ? "" : ";label:Video;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Video.js"],"names":[],"mappings":"AA6L8B","file":"Video.js","sourcesContent":["/* eslint-disable no-param-reassign */\n/* @jsxImportSource @emotion/react */\nimport {useEffect, useLayoutEffect, useRef, useState} from 'react'\nimport PropTypes from 'prop-types'\n\nimport multiRef from 'util/multiRef'\nimport loadPlayer from 'playerCore/loadPlayer'\nimport {\n  getMediaTime,\n  subscribePlaybackState,\n  load,\n  syncPlaybackState,\n  seek,\n  setPlaybackRate,\n  setQuality,\n  setAudioTrack,\n  syncTextTrack,\n} from 'playerCore/mediaBindings'\nimport latencyManager from 'playerCore/latencyManager'\nimport {createAnalytics} from 'modules/analytics'\n\nconst baseVideoStyle = {\n  objectFit: 'contain',\n  width: '100%',\n  maxHeight: '100%',\n  '~ .shaka-text-container': {\n    position: 'absolute',\n    height: '100%',\n    width: '100%',\n  }\n}\n\nconst defaultModulesConfig = {}\nconst emptyArray = []\n\nconst Video = ({\n  source,\n  videoStyle,\n  playbackState: targetState,\n  currentTime: targetTime,\n  playbackRate,\n  textTracks = emptyArray,\n  quality,\n  textTrack,\n  audio = {},\n  liveResume,\n  iOSFullscreenDetectThreshold, // TODO organize props\n  plugins = [],\n  modulesConfig = defaultModulesConfig,\n  shaka,\n  bitmovin,\n  license,\n  validationHost,\n  videoRef,\n  playerRef,\n  analyticsRef,\n  onPlayerLoaded,\n  onPlaybackStateChange,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  subtitlesPosition,\n  ...videoAttributes\n}) => {\n  const handlers = useRef()\n  handlers.current = {onPlaybackStateChange, onBlockedAutoplay}\n  const videoContainer = useRef()\n  const videoElement = useRef()\n  const [playbackState, setPlaybackState] = useState('')\n  const [player, setPlayer] = useState()\n  const latencyManagerRef = useRef()\n  const eventSenderRef = useRef()\n  const activePlayback = !/error|ended|emptied/.test(playbackState)\n  useEffect(() => {\n    if (!activePlayback) {\n      return\n    }\n    eventSenderRef.current = createAnalytics({\n      video: videoElement.current,\n      onPlaylogFired,\n      modulesConfig,\n    })\n    analyticsRef.current = eventSenderRef.current\n    return () => eventSenderRef.current?.reset()\n    // TODO restart analytics on update of moduleConfig.analytics.*\n  }, [activePlayback])\n\n  useEffect(() => {\n    const loadTask = loadPlayer(videoElement.current, {\n      container: videoContainer.current,\n      source,\n      shaka,\n      bitmovin,\n    }).then(basePlayer => {\n      setPlayer(basePlayer)\n      onPlayerLoaded?.(basePlayer)\n      if (playerRef) {\n        playerRef.curret = basePlayer\n      }\n      if (basePlayer.modules) {\n        basePlayer.modules.analytics = eventSenderRef.current\n      }\n      return basePlayer\n    })\n    const offPlaybackState = subscribePlaybackState(\n      videoElement.current,\n      (event, state) => {\n        handlers.current.onPlaybackStateChange?.(event, state)\n        // external logic may want to change targetState, hold playbackState update\n        // to prevent unwanted syncPlaybackState\n        requestAnimationFrame(() => setPlaybackState(state))\n      },\n      {iOSFullscreenDetectThreshold}\n    )\n    return () => {\n      offPlaybackState()\n      loadTask.then(currentPlayer => currentPlayer?.destroy())\n    }\n  }, [])\n  useEffect(() => {\n    if (\n      source &&\n      (source.length > 0 || source.src || source.hls || source.dash) &&\n      player?.isAlive()\n    ) {\n      Promise.resolve(false)\n        .then(ullEnabled => {\n          if (ullEnabled && !latencyManagerRef.current) {\n            latencyManagerRef.current = latencyManager(\n              player,\n              videoElement.current\n            )\n          }\n          latencyManagerRef.current?.configure({enabled: ullEnabled})\n          load(\n            videoElement.current,\n            {player, plugins, startTime: targetTime},\n            source\n          )\n        })\n        .catch(error => console.warn(error))\n    }\n    if ((!source || source.length === 0) && player) {\n      player.unload()\n      player.lastSrc = ''\n    }\n  }, [player, source])\n\n  // useEffect is too late to unlock play on Safari\n  // TODO check if this work after upgrading React 18\n  useLayoutEffect(() => {\n    if (player?.isAlive()) {\n      syncPlaybackState(\n        videoElement.current,\n        {player, plugins, liveResume},\n        targetState\n      )?.catch(error => {\n        handlers.current.onBlockedAutoplay?.(error)\n      })\n    }\n  }, [player && targetState])\n  useEffect(() => {\n    const {currentTime} = getMediaTime(videoElement.current, {player, plugins})\n    if (player?.isAlive() && Math.abs(currentTime - targetTime) > 0.5) {\n      // seeking unavailable cases are handled by seek function\n      seek(videoElement.current, {player, plugins}, targetTime)\n    }\n  }, [player && targetTime])\n  useEffect(() => {\n    setPlaybackRate(videoElement.current, {player}, playbackRate)\n  }, [playbackRate, playbackState === 'playing'])\n  useEffect(() => {\n    if (player?.isAlive()) {\n      setQuality(videoElement.current, {player}, quality)\n    }\n  }, [quality, player])\n  useEffect(() => {\n    setAudioTrack(videoElement.current, {player}, audio)\n  }, [audio?.id || `${audio.language || 'unk'}:${audio.label || ''}`, player])\n  useEffect(() => {\n    if (textTracks?.length > 0 || textTrack) {\n      return syncTextTrack(\n        videoElement.current,\n        {player},\n        textTracks?.length > 0 ? {textTracks} : textTrack\n      )\n    }\n  }, [videoElement.current?.readyState >= 2 && textTracks, textTrack])\n\n  return (\n    <div ref={videoContainer} css={{video: [baseVideoStyle, videoStyle]}}>\n      <video // eslint-disable-line jsx-a11y/media-has-caption\n        ref={multiRef(videoRef, videoElement)}\n        playsInline\n        {...videoAttributes}\n      />\n    </div>\n  )\n}\n\nVideo.propTypes = {\n  source: PropTypes.arrayOf(PropTypes.object),\n  playbackState: PropTypes.string,\n  currentTime: PropTypes.number,\n  playbackRate: PropTypes.number,\n  quality: PropTypes.object,\n  audio: PropTypes.string,\n  seekable: PropTypes.bool,\n  plugins: PropTypes.array,\n  bitmovin: PropTypes.object,\n  shaka: PropTypes.object,\n  onPlayerLoaded: PropTypes.func,\n  onPlaybackStateChange: PropTypes.func,\n  onBlockedAutoplay: PropTypes.func,\n  videoRef: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n  playerRef: PropTypes.object,\n}\n\nexport default Video\n"]} */"),
7474
+ video: baseVideoStyle
7475
+ }, 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== */"),
9123
7476
  children: jsx$1("video", {
9124
7477
  // eslint-disable-line jsx-a11y/media-has-caption
9125
7478
  ref: multiRef(videoRef, videoElement),
@@ -9129,23 +7482,6 @@ const Video = ({
9129
7482
  });
9130
7483
  };
9131
7484
 
9132
- Video.propTypes = {
9133
- source: PropTypes.arrayOf(PropTypes.object),
9134
- playbackState: PropTypes.string,
9135
- currentTime: PropTypes.number,
9136
- playbackRate: PropTypes.number,
9137
- quality: PropTypes.object,
9138
- audio: PropTypes.string,
9139
- seekable: PropTypes.bool,
9140
- plugins: PropTypes.array,
9141
- bitmovin: PropTypes.object,
9142
- shaka: PropTypes.object,
9143
- onPlayerLoaded: PropTypes.func,
9144
- onPlaybackStateChange: PropTypes.func,
9145
- onBlockedAutoplay: PropTypes.func,
9146
- videoRef: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),
9147
- playerRef: PropTypes.object
9148
- };
9149
7485
  var Video$1 = Video;
9150
7486
 
9151
7487
  const getSpeedItems = items => items.map(value => ({
@@ -9190,7 +7526,7 @@ const getQualityItemsFromManifest = player => {
9190
7526
  const getQualitySettings = (options, player) => {
9191
7527
  // With native HLS, manifest rewrite is required to enable quality setting
9192
7528
  // TODO let this covered by test, maybe refactor?
9193
- const items = needNativeHls() && !options.rewriteManifest ? [] : options.items || getQualityItemsFromManifest(player);
7529
+ const items = isSafari() && !options.rewriteManifest ? [] : options.items || getQualityItemsFromManifest(player);
9194
7530
  return items.length > 0 && items[0] && {
9195
7531
  name: 'quality',
9196
7532
  title: 'KKS.QUALITY',
@@ -9298,7 +7634,7 @@ const getSettingsData = ({
9298
7634
  }
9299
7635
  })) || [];
9300
7636
  const selectedSource = getSource(source, {
9301
- preferManifestType: needNativeHls() ? 'hls' : 'dash'
7637
+ preferManifestType: 'platform'
9302
7638
  }) || {};
9303
7639
  const currentSpeedItems = getSpeedItems(speedItems);
9304
7640
  const sections = [].concat(otherSections).concat([quality && getQualitySettings({ ...quality,
@@ -9405,7 +7741,7 @@ const parseThumbnails = (data, url) => parseVTT(data).then(items => items.map(it
9405
7741
  }));
9406
7742
 
9407
7743
  /* @jsxImportSource @emotion/react */
9408
- const containerStyle = {
7744
+ const containerStyle$1 = {
9409
7745
  position: 'absolute',
9410
7746
  left: 'calc(-1000vw - 100%)',
9411
7747
  bottom: '28px',
@@ -9435,7 +7771,8 @@ const showStyle = {
9435
7771
  left: 0,
9436
7772
  transition: 'z-index 0s linear, opacity 0.5s ease'
9437
7773
  };
9438
- const VideoThumbnail = /*#__PURE__*/forwardRef(({
7774
+
7775
+ const VideoThumbnail = ({
9439
7776
  title,
9440
7777
  className,
9441
7778
  style,
@@ -9445,10 +7782,9 @@ const VideoThumbnail = /*#__PURE__*/forwardRef(({
9445
7782
  y,
9446
7783
  width,
9447
7784
  height
9448
- }, ref) => jsxs("div", {
9449
- ref: ref // Use Number.isFinite to detect boolean
9450
- ,
9451
- css: [containerStyle, Number.isFinite(time) && time >= 0 && showStyle, process.env.NODE_ENV === "production" ? "" : ";label:VideoThumbnail;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlZpZGVvVGh1bWJuYWlsLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDTSIsImZpbGUiOiJWaWRlb1RodW1ibmFpbC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7Zm9yd2FyZFJlZn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnXG5cbmltcG9ydCB7Rm9ybWF0dGVkVGltZX0gZnJvbSAnY29udGV4dC9JMThuJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIGxlZnQ6ICdjYWxjKC0xMDAwdncgLSAxMDAlKScsXG4gIGJvdHRvbTogJzI4cHgnLFxuICB0ZXh0QWxpZ246ICdjZW50ZXInLFxuICBmb250U2l6ZTpcbiAgICAnY2FsYygxMnB4IC8gdmFyKC0tdGh1bWJuYWlsLXdpZHRoKSAqIHZhcigtLXRodW1ibmFpbC1vcmlnaW5hbC13aWR0aCkpJyxcbiAgdHJhbnNmb3JtT3JpZ2luOiAnYm90dG9tJyxcbiAgLy8gc2NhbGUgKiBvcmlnaW5hbC13aWR0aCA9PT0gd2lkdGhcbiAgJy0tdGh1bWJuYWlsLXNjYWxlJzogJ2NhbGModmFyKC0tdGh1bWJuYWlsLXdpZHRoKSAvIHZhcigtLXRodW1ibmFpbC1vcmlnaW5hbC13aWR0aCkpJyxcbiAgJy0tbWFyZ2luLXNoaWZ0JzogJ2NhbGMoNTAlICogKHZhcigtLXRodW1ibmFpbC1zY2FsZSkgLSAxKSknLFxuICB0cmFuc2Zvcm06IGBcbiAgICB0cmFuc2xhdGVYKG1heChcbiAgICAgIGNhbGMoNTAlICogKHZhcigtLXRodW1ibmFpbC1zY2FsZSkgLSAxKSksXG4gICAgICBtaW4oXG4gICAgICAgIGNhbGModmFyKC0tcG9pbnRlci14KSAtIHZhcigtLXNlZWtiYXItbGVmdCkgLSA1MCUpLFxuICAgICAgICBjYWxjKHZhcigtLXNlZWtiYXItcmlnaHQpIC0gdmFyKC0tc2Vla2Jhci1sZWZ0KSAtIDEwMCUgLSAxZW0gLSA1MCUgKiAodmFyKC0tdGh1bWJuYWlsLXNjYWxlKSAtIDEpKVxuICAgICAgKVxuICAgICkpXG4gICAgc2NhbGUodmFyKC0tdGh1bWJuYWlsLXNjYWxlKSlcbiAgYCxcbiAgJz4gLnByaW1hcnktY29udGVudCc6IHtcbiAgICBib3JkZXI6ICcxcHggc29saWQgd2hpdGUnLFxuICAgIGJveFNoYWRvdzogJzAgMCA1cHggMnB4IHJnYmEoMCwgMCwgMCwgMC4zKScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnIzAwMCcsXG4gIH0sXG59XG5cbmNvbnN0IHNob3dTdHlsZSA9IHtcbiAgbGVmdDogMCxcbiAgdHJhbnNpdGlvbjogJ3otaW5kZXggMHMgbGluZWFyLCBvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5cbmNvbnN0IFZpZGVvVGh1bWJuYWlsID0gZm9yd2FyZFJlZihcbiAgKHt0aXRsZSwgY2xhc3NOYW1lLCBzdHlsZSwgdGltZSwgaW1hZ2UsIHgsIHksIHdpZHRoLCBoZWlnaHR9LCByZWYpID0+IChcbiAgICA8ZGl2XG4gICAgICByZWY9e3JlZn1cbiAgICAgIC8vIFVzZSBOdW1iZXIuaXNGaW5pdGUgdG8gZGV0ZWN0IGJvb2xlYW5cbiAgICAgIGNzcz17W2NvbnRhaW5lclN0eWxlLCBOdW1iZXIuaXNGaW5pdGUodGltZSkgJiYgdGltZSA+PSAwICYmIHNob3dTdHlsZV19XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIC4uLnN0eWxlLFxuICAgICAgICAnLS10aHVtYm5haWwtb3JpZ2luYWwtd2lkdGgnOiBNYXRoLm1heCh3aWR0aCwgaGVpZ2h0KSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjbGFzc05hbWU9XCJwcmltYXJ5LWNvbnRlbnRcIlxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIHdpZHRoOiBgJHt3aWR0aH1weGAsXG4gICAgICAgICAgaGVpZ2h0OiBgJHtoZWlnaHR9cHhgLFxuICAgICAgICAgIGJhY2tncm91bmRJbWFnZTogYHVybCgke2ltYWdlfSlgLFxuICAgICAgICAgIGJhY2tncm91bmRQb3NpdGlvbjogYC0ke3h9cHggLSR7eX1weGAsXG4gICAgICAgIH19XG4gICAgICAvPlxuICAgICAge3RpdGxlICYmIChcbiAgICAgICAgPGRpdlxuICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICB3aWR0aDogYCR7d2lkdGh9cHhgLFxuICAgICAgICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgICAgICAgd2hpdGVTcGFjZTogJ25vd3JhcCcsXG4gICAgICAgICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICAgICAgfX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgPC9kaXY+XG4gICAgICApfVxuICAgICAgPEZvcm1hdHRlZFRpbWUgdGltZT17dGltZX0gLz5cbiAgICA8L2Rpdj5cbiAgKVxuKVxuXG5WaWRlb1RodW1ibmFpbC5wcm9wVHlwZXMgPSB7XG4gIGNsYXNzTmFtZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgc3R5bGU6IFByb3BUeXBlcy5vYmplY3QsXG4gIHRpbWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5udW1iZXIsIFByb3BUeXBlcy5vbmVPZihbZmFsc2VdKV0pLFxuICBpbWFnZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgeDogUHJvcFR5cGVzLm51bWJlcixcbiAgeTogUHJvcFR5cGVzLm51bWJlcixcbiAgd2lkdGg6IFByb3BUeXBlcy5udW1iZXIsXG4gIGhlaWdodDogUHJvcFR5cGVzLm51bWJlcixcbn1cblxuZXhwb3J0IGRlZmF1bHQgVmlkZW9UaHVtYm5haWxcbiJdfQ== */"],
7785
+ }) => jsxs("div", {
7786
+ // Use Number.isFinite to detect boolean
7787
+ css: [containerStyle$1, Number.isFinite(time) && time >= 0 && showStyle, process.env.NODE_ENV === "production" ? "" : ";label:VideoThumbnail;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlZpZGVvVGh1bWJuYWlsLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDSSIsImZpbGUiOiJWaWRlb1RodW1ibmFpbC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB7Rm9ybWF0dGVkVGltZX0gZnJvbSAnY29udGV4dC9JMThuJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIGxlZnQ6ICdjYWxjKC0xMDAwdncgLSAxMDAlKScsXG4gIGJvdHRvbTogJzI4cHgnLFxuICB0ZXh0QWxpZ246ICdjZW50ZXInLFxuICBmb250U2l6ZTpcbiAgICAnY2FsYygxMnB4IC8gdmFyKC0tdGh1bWJuYWlsLXdpZHRoKSAqIHZhcigtLXRodW1ibmFpbC1vcmlnaW5hbC13aWR0aCkpJyxcbiAgdHJhbnNmb3JtT3JpZ2luOiAnYm90dG9tJyxcbiAgLy8gc2NhbGUgKiBvcmlnaW5hbC13aWR0aCA9PT0gd2lkdGhcbiAgJy0tdGh1bWJuYWlsLXNjYWxlJzogJ2NhbGModmFyKC0tdGh1bWJuYWlsLXdpZHRoKSAvIHZhcigtLXRodW1ibmFpbC1vcmlnaW5hbC13aWR0aCkpJyxcbiAgJy0tbWFyZ2luLXNoaWZ0JzogJ2NhbGMoNTAlICogKHZhcigtLXRodW1ibmFpbC1zY2FsZSkgLSAxKSknLFxuICB0cmFuc2Zvcm06IGBcbiAgICB0cmFuc2xhdGVYKG1heChcbiAgICAgIGNhbGMoNTAlICogKHZhcigtLXRodW1ibmFpbC1zY2FsZSkgLSAxKSksXG4gICAgICBtaW4oXG4gICAgICAgIGNhbGModmFyKC0tcG9pbnRlci14KSAtIHZhcigtLXNlZWtiYXItbGVmdCkgLSA1MCUpLFxuICAgICAgICBjYWxjKHZhcigtLXNlZWtiYXItcmlnaHQpIC0gdmFyKC0tc2Vla2Jhci1sZWZ0KSAtIDEwMCUgLSAxZW0gLSA1MCUgKiAodmFyKC0tdGh1bWJuYWlsLXNjYWxlKSAtIDEpKVxuICAgICAgKVxuICAgICkpXG4gICAgc2NhbGUodmFyKC0tdGh1bWJuYWlsLXNjYWxlKSlcbiAgYCxcbiAgJz4gLnByaW1hcnktY29udGVudCc6IHtcbiAgICBib3JkZXI6ICcxcHggc29saWQgd2hpdGUnLFxuICAgIGJveFNoYWRvdzogJzAgMCA1cHggMnB4IHJnYmEoMCwgMCwgMCwgMC4zKScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnIzAwMCcsXG4gIH0sXG59XG5cbmNvbnN0IHNob3dTdHlsZSA9IHtcbiAgbGVmdDogMCxcbiAgdHJhbnNpdGlvbjogJ3otaW5kZXggMHMgbGluZWFyLCBvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5jb25zdCBWaWRlb1RodW1ibmFpbCA9ICh7dGl0bGUsIGNsYXNzTmFtZSwgc3R5bGUsIHRpbWUsIGltYWdlLCB4LCB5LCB3aWR0aCwgaGVpZ2h0fSkgPT4gKFxuICA8ZGl2XG4gICAgLy8gVXNlIE51bWJlci5pc0Zpbml0ZSB0byBkZXRlY3QgYm9vbGVhblxuICAgIGNzcz17W2NvbnRhaW5lclN0eWxlLCBOdW1iZXIuaXNGaW5pdGUodGltZSkgJiYgdGltZSA+PSAwICYmIHNob3dTdHlsZV19XG4gICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgc3R5bGU9e3tcbiAgICAgIC4uLnN0eWxlLFxuICAgICAgJy0tdGh1bWJuYWlsLW9yaWdpbmFsLXdpZHRoJzogTWF0aC5tYXgod2lkdGgsIGhlaWdodCksXG4gICAgfX1cbiAgPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzTmFtZT1cInByaW1hcnktY29udGVudFwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICB3aWR0aDogYCR7d2lkdGh9cHhgLFxuICAgICAgICBoZWlnaHQ6IGAke2hlaWdodH1weGAsXG4gICAgICAgIGJhY2tncm91bmRJbWFnZTogYHVybCgke2ltYWdlfSlgLFxuICAgICAgICBiYWNrZ3JvdW5kUG9zaXRpb246IGAtJHt4fXB4IC0ke3l9cHhgLFxuICAgICAgfX1cbiAgICAvPlxuICAgIHt0aXRsZSAmJiAoXG4gICAgICA8ZGl2XG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6IGAke3dpZHRofXB4YCxcbiAgICAgICAgICBvdmVyZmxvdzogJ2hpZGRlbicsXG4gICAgICAgICAgd2hpdGVTcGFjZTogJ25vd3JhcCcsXG4gICAgICAgICAgdGV4dE92ZXJmbG93OiAnZWxsaXBzaXMnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7dGl0bGV9XG4gICAgICA8L2Rpdj5cbiAgICApfVxuICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3RpbWV9IC8+XG4gIDwvZGl2PlxuKVxuXG5leHBvcnQgZGVmYXVsdCBWaWRlb1RodW1ibmFpbFxuIl19 */"],
9452
7788
  className: className,
9453
7789
  style: { ...style,
9454
7790
  '--thumbnail-original-width': Math.max(width, height)
@@ -9472,17 +7808,7 @@ const VideoThumbnail = /*#__PURE__*/forwardRef(({
9472
7808
  }), jsx$1(FormattedTime, {
9473
7809
  time: time
9474
7810
  })]
9475
- }));
9476
- VideoThumbnail.propTypes = {
9477
- className: PropTypes.string,
9478
- style: PropTypes.object,
9479
- time: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf([false])]),
9480
- image: PropTypes.string,
9481
- x: PropTypes.number,
9482
- y: PropTypes.number,
9483
- width: PropTypes.number,
9484
- height: PropTypes.number
9485
- };
7811
+ });
9486
7812
 
9487
7813
  /* @jsxImportSource @emotion/react */
9488
7814
 
@@ -9493,14 +7819,16 @@ const SeekPreview = ({
9493
7819
  time,
9494
7820
  chapters = []
9495
7821
  }) => {
9496
- const thumbnailRef = useRef();
9497
7822
  const [thumbnails, setThumbnails] = useState([]);
9498
7823
  useEffect(() => {
9499
7824
  let cancel = false;
9500
7825
 
9501
7826
  if (thumbnailsUrl) {
9502
- axios.get(thumbnailsUrl).then(result => parseThumbnails(result.data, thumbnailsUrl)).then(data => {
9503
- if (!cancel) setThumbnails(data);
7827
+ // TODO replace with fetch
7828
+ fetch(thumbnailsUrl).then(response => response.text()).then(data => {
7829
+ if (!cancel) {
7830
+ setThumbnails(parseThumbnails(data, thumbnailsUrl));
7831
+ }
9504
7832
  });
9505
7833
  }
9506
7834
 
@@ -9518,7 +7846,6 @@ const SeekPreview = ({
9518
7846
  return time >= chapter.startTime && time < endTime;
9519
7847
  }) || {};
9520
7848
  return thumbnails.length > 0 && jsx$1(VideoThumbnail, {
9521
- ref: thumbnailRef,
9522
7849
  title: title,
9523
7850
  time: time,
9524
7851
  image: currentThumbnail.image,
@@ -9526,15 +7853,6 @@ const SeekPreview = ({
9526
7853
  });
9527
7854
  };
9528
7855
 
9529
- SeekPreview.propTypes = {
9530
- thumbnailsUrl: PropTypes.string,
9531
- time: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf([false])]),
9532
- chapters: PropTypes.arrayOf(PropTypes.shape({
9533
- startTime: PropTypes.number,
9534
- displayName: PropTypes.string,
9535
- thumbnailUrl: PropTypes.string
9536
- }))
9537
- };
9538
7856
  var SeekPreview$1 = SeekPreview;
9539
7857
 
9540
7858
  /* eslint-disable no-nested-ternary */
@@ -9601,12 +7919,6 @@ const PremiumPlayer = ({
9601
7919
  cast: castOptions = 'compatible',
9602
7920
  slots,
9603
7921
  slotProps = {},
9604
- uiElements: {
9605
- controlButtons: targetControlButtons,
9606
- ...targetUIElements
9607
- } = {
9608
- controlButtons: {}
9609
- },
9610
7922
  onError,
9611
7923
  onPlaybackStateChange,
9612
7924
  onBack,
@@ -9620,8 +7932,6 @@ const PremiumPlayer = ({
9620
7932
  onPlaylogFired,
9621
7933
  ...videoProps
9622
7934
  }) => {
9623
- var _analyticsRef$current, _videoRef$current2;
9624
-
9625
7935
  const components = {
9626
7936
  VolumeControl,
9627
7937
  CastUi,
@@ -9635,14 +7945,11 @@ const PremiumPlayer = ({
9635
7945
  const containerRef = useRef();
9636
7946
  const playerRef = useRef();
9637
7947
  const adContainerRef = useRef();
9638
- const analyticsRef = useRef();
9639
- const refs = useRef({});
9640
- const castStartTime = useRef(); // TODO move RWD related to Layout
7948
+ const refs = useRef({}); // TODO move RWD related to Layout
9641
7949
 
9642
7950
  const {
9643
7951
  currentBreakpoint: size,
9644
7952
  width,
9645
- height,
9646
7953
  observe
9647
7954
  } = useDimensions({
9648
7955
  polyfill: ResizeObserver$1,
@@ -9658,10 +7965,6 @@ const PremiumPlayer = ({
9658
7965
  currentTime: 0,
9659
7966
  bufferTime: 0
9660
7967
  });
9661
- const {
9662
- share,
9663
- watermark
9664
- } = metadata || {};
9665
7968
 
9666
7969
  const togglePlay = (overrideState, {
9667
7970
  triggeredBy
@@ -9674,19 +7977,9 @@ const PremiumPlayer = ({
9674
7977
  }
9675
7978
  };
9676
7979
 
9677
- const sendLog = (_analyticsRef$current = analyticsRef.current) === null || _analyticsRef$current === void 0 ? void 0 : _analyticsRef$current.sendLog;
9678
-
9679
- const sendTogglePlayLog = overrideState => {
9680
- sendLog === null || sendLog === void 0 ? void 0 : sendLog(overrideState || flipState(targetState.playbackState), playbackTime);
9681
- };
9682
-
9683
- useEffect(() => {
9684
- castStartTime.current = playbackTime.currentTime;
9685
- }, [playbackTime.currentTime]);
9686
7980
  useEffect(() => {
9687
7981
  if (appPlaybackState) {
9688
7982
  togglePlay(appPlaybackState);
9689
- sendTogglePlayLog(appPlaybackState);
9690
7983
  }
9691
7984
  }, [appPlaybackState]);
9692
7985
  useEffect(() => {
@@ -9705,13 +7998,9 @@ const PremiumPlayer = ({
9705
7998
  })
9706
7999
  })));
9707
8000
 
9708
- const setTargetTime = (time, action) => {
8001
+ const setTargetTime = time => {
9709
8002
  var _videoRef$current;
9710
8003
 
9711
- if (action) {
9712
- sendLog === null || sendLog === void 0 ? void 0 : sendLog(action, playbackTime);
9713
- }
9714
-
9715
8004
  const trimmed = Math.min(time, ((_videoRef$current = videoRef.current) === null || _videoRef$current === void 0 ? void 0 : _videoRef$current.initialDuration) || Infinity);
9716
8005
  setTargetState(state => ({ ...state,
9717
8006
  // seek to 0 repeatedly edge case
@@ -9833,8 +8122,6 @@ const PremiumPlayer = ({
9833
8122
  if (!keepOpen) {
9834
8123
  setUserFocus('');
9835
8124
  }
9836
-
9837
- sendChangeSettingsLog(name, value, sendLog, playbackTime);
9838
8125
  };
9839
8126
 
9840
8127
  const openSettings = event => {
@@ -9856,11 +8143,6 @@ const PremiumPlayer = ({
9856
8143
  }));
9857
8144
  }
9858
8145
  }, [appPlaybackRate]);
9859
- useEffect(() => {
9860
- if (userFocus) {
9861
- sendLog === null || sendLog === void 0 ? void 0 : sendLog(userFocus === 'settings' ? 'openSettings' : 'closeSettings', playbackTime);
9862
- }
9863
- }, [userFocus === 'settings']);
9864
8146
  const qualityOptions = useMemo(() => getQualityOptions(settings), [settings.values.quality]);
9865
8147
  const viewMode = useLinkState(update => onViewModeChange(videoRef.current, update));
9866
8148
  const sourceOverride = useLinkState(async update => {
@@ -9869,7 +8151,7 @@ const PremiumPlayer = ({
9869
8151
  const result = source && (await ((_quality$rewriteManif = quality.rewriteManifest) === null || _quality$rewriteManif === void 0 ? void 0 : _quality$rewriteManif.call(quality, source, qualityOptions)));
9870
8152
  update(result || source);
9871
8153
  }, [source, qualityOptions]);
9872
- const waiting = useLazyWaiting(/emptied|loading|buffering/.test(playbackState));
8154
+ const waiting = /emptied|loading|buffering/.test(playbackState);
9873
8155
  const activePlayback = playbackState === 'playing' || playbackState === 'waiting';
9874
8156
  const {
9875
8157
  mode: autoHideMode,
@@ -9883,7 +8165,7 @@ const PremiumPlayer = ({
9883
8165
  const mode = userFocus === 'seekbar' ? 'hidden' : controls.autohide ? autoHideMode : controls ? 'shown' : 'hidden';
9884
8166
  const controlsDisplay = userFocus === 'seekbar' ? 'seekbar-only' : controls === 'title-only' || playbackState === 'emptied' ? 'hidden' : mode;
9885
8167
  const shouldHidePanels = (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus;
9886
- const havePlayPanel = !blocking && uiType === 'desktop' && !waiting && !/volume|''/.test(userFocus) && !/title-only|no-panel/.test(controls) && (controls.autohide || mode === 'shown');
8168
+ const havePlayPanel = !blocking && havePointer() && uiType === 'desktop' && !waiting && !/volume|''/.test(userFocus) && !/title-only|no-panel/.test(controls) && (controls.autohide || mode === 'shown');
9887
8169
  useEffect(() => {
9888
8170
  if (shouldHidePanels) {
9889
8171
  setUserFocus('');
@@ -9902,14 +8184,12 @@ const PremiumPlayer = ({
9902
8184
  onChangePrevious(event);
9903
8185
  togglePlay('paused');
9904
8186
  videoRef.current.dispatchEvent(new CustomEvent('loadstart'));
9905
- sendLog === null || sendLog === void 0 ? void 0 : sendLog('previousEpisode', playbackTime);
9906
8187
  };
9907
8188
 
9908
8189
  const changeNext = event => {
9909
8190
  onChangeNext(event);
9910
8191
  togglePlay('paused');
9911
8192
  videoRef.current.dispatchEvent(new CustomEvent('loadstart'));
9912
- sendLog === null || sendLog === void 0 ? void 0 : sendLog('nextEpisode', playbackTime);
9913
8193
  };
9914
8194
 
9915
8195
  useEffect(fetchSettings, [appSettings]);
@@ -9932,17 +8212,53 @@ const PremiumPlayer = ({
9932
8212
  userFocus,
9933
8213
  uiType
9934
8214
  }) ? 'paused' : targetState.playbackState;
8215
+ const activeThumbnailsUrl = (!userFocus || userFocus === 'seekbar') && (getThumbnailsUrl(source) || thumbnailsUrl);
8216
+ const cssVariables = {
8217
+ '--playing': playbackState === 'playing' ? '1' : '0'
8218
+ };
9935
8219
 
9936
- const handleMuteSettingChangeEvent = muted => sendLog === null || sendLog === void 0 ? void 0 : sendLog('audioMuteSettingChange', playbackTime, {
9937
- muted
9938
- });
8220
+ const onRewind = (!isLive || playbackTime.currentTime < 0) && !isEnd && (() => setTargetTime(playbackTime.currentTime - 10));
8221
+
8222
+ const onForward = (!isLive || playbackTime.currentTime < 0) && canSeek && (() => setTargetTime(playbackTime.currentTime + 10));
8223
+
8224
+ const onClickBlank = havePlayPanel && (() => togglePlay('', {
8225
+ triggeredBy: 'user-action'
8226
+ }));
8227
+
8228
+ const uiHandlers = {
8229
+ onPlay: () => {
8230
+ togglePlay('', {
8231
+ triggeredBy: 'user-action'
8232
+ });
8233
+ setIsUserActive(true);
8234
+ },
8235
+ onClickLive: isLive && (() => setTargetTime(0)),
8236
+ onClickSeekbar: () => {
8237
+ refs.current.deferedSeekFocus = setTimeout(() => setUserFocus('seekbar'), 66);
8238
+ },
8239
+ onSeek: time => {
8240
+ setTargetTime(time);
8241
+ clearTimeout(refs.current.deferedSeekFocus);
8242
+ setTimeout(() => setUserFocus(''), 66);
8243
+ },
8244
+ onChangeSettings: ({
8245
+ name,
8246
+ value,
8247
+ keepOpen
8248
+ }) => changeSettings(name, value, {
8249
+ keepOpen
8250
+ }),
8251
+ onCloseSettings: event => {
8252
+ var _slotProps$settings, _slotProps$settings$o;
9939
8253
 
8254
+ setUserFocus('');
8255
+ slotProps === null || slotProps === void 0 ? void 0 : (_slotProps$settings = slotProps.settings) === null || _slotProps$settings === void 0 ? void 0 : (_slotProps$settings$o = _slotProps$settings.onClose) === null || _slotProps$settings$o === void 0 ? void 0 : _slotProps$settings$o.call(_slotProps$settings, event);
8256
+ }
8257
+ };
9940
8258
  const uiElements = {
9941
- title,
9942
- channelTitle,
9943
- liveButton: isLive && /*#__PURE__*/jsx(components.LiveButton, {
8259
+ liveButton: uiHandlers.onClickLive && /*#__PURE__*/jsx(components.LiveButton, {
9944
8260
  usingStartOver: playbackTime.currentTime < 0,
9945
- onClick: () => setTargetTime(0, 'seekToLive')
8261
+ onClick: uiHandlers.onClickLive
9946
8262
  }),
9947
8263
  controlButtons: {
9948
8264
  playButton: /*#__PURE__*/jsx(PlayButton, {
@@ -9950,43 +8266,32 @@ const PremiumPlayer = ({
9950
8266
  ended: isEnd,
9951
8267
  hidden: uiType === 'mobile' && (waiting || /loading/.test(playbackState)),
9952
8268
  variant: !isUserActive && 'firstplay',
9953
- onClick: () => {
9954
- togglePlay('', {
9955
- triggeredBy: 'user-action'
9956
- });
9957
- sendTogglePlayLog();
9958
- setIsUserActive(true);
9959
- }
8269
+ onClick: uiHandlers.onPlay
9960
8270
  }),
9961
- ...((isEnd || canSeek) && (!isLive || playbackTime.currentTime < 0) && {
9962
- rewindButton: /*#__PURE__*/jsx(Button, {
9963
- startIcon: "rewind10",
9964
- title: "KKS.PLAYER.REWIND",
9965
- disabled: isEnd,
9966
- onClick: () => {
9967
- setTargetTime(playbackTime.currentTime - 10, 'rewind');
9968
- }
9969
- }),
9970
- forwardButton: /*#__PURE__*/jsx(ForwardButton, {
9971
- startIcon: "forward10",
9972
- title: "KKS.PLAYER.FORWARD",
9973
- disabled: !canSeek,
9974
- onClick: () => setTargetTime(playbackTime.currentTime + 10, 'forward')
9975
- }),
9976
- nextEpisodeButton: /*#__PURE__*/jsx(Button, {
9977
- startIcon: "next",
9978
- title: "KKS.PLAYER.NEXT",
9979
- disabled: !onChangeNext,
9980
- onClick: changeNext
9981
- }),
9982
- previousEpisodeButton: /*#__PURE__*/jsx(Button, {
9983
- startIcon: "previous",
9984
- title: "KKS.PLAYER.PREVIOUS",
9985
- disabled: !onChangePrevious,
9986
- onClick: changePrevious
9987
- })
8271
+ rewindButton: onRewind && /*#__PURE__*/jsx(Button, {
8272
+ startIcon: "rewind10",
8273
+ title: "KKS.PLAYER.REWIND",
8274
+ disabled: isEnd,
8275
+ onClick: onRewind
9988
8276
  }),
9989
- ...targetControlButtons
8277
+ forwardButton: onForward && /*#__PURE__*/jsx(ForwardButton, {
8278
+ startIcon: "forward10",
8279
+ title: "KKS.PLAYER.FORWARD",
8280
+ disabled: !canSeek,
8281
+ onClick: onForward
8282
+ }),
8283
+ nextEpisodeButton: /*#__PURE__*/jsx(Button, {
8284
+ startIcon: "next",
8285
+ title: "KKS.PLAYER.NEXT",
8286
+ disabled: !onChangeNext,
8287
+ onClick: changeNext
8288
+ }),
8289
+ previousEpisodeButton: /*#__PURE__*/jsx(Button, {
8290
+ startIcon: "previous",
8291
+ title: "KKS.PLAYER.PREVIOUS",
8292
+ disabled: !onChangePrevious,
8293
+ onClick: changePrevious
8294
+ })
9990
8295
  },
9991
8296
  seekbar: /*#__PURE__*/jsx(components.Seekbar, {
9992
8297
  style: /volume/.test(userFocus) && {
@@ -9997,35 +8302,24 @@ const PremiumPlayer = ({
9997
8302
  bufferTime: playbackTime.bufferTime,
9998
8303
  duration: playbackTime.duration,
9999
8304
  chapters: chapters,
10000
- onChange: () => {
10001
- refs.current.deferedSeekFocus = setTimeout(() => setUserFocus('seekbar'), 66);
10002
- },
10003
- onChangeCommitted: time => {
10004
- setTargetTime(time, 'seek');
10005
- clearTimeout(refs.current.deferedSeekFocus);
10006
- setTimeout(() => setUserFocus(''), 66);
10007
- },
8305
+ onChange: uiHandlers.onClickSeekbar,
8306
+ onChangeCommitted: uiHandlers.onSeek,
10008
8307
  marks: marks,
10009
8308
  plugins: plugins,
10010
8309
  ...slotProps.seekbar,
10011
- children: (!userFocus || userFocus === 'seekbar') && source && /*#__PURE__*/jsx(SeekPreview$1, {
10012
- thumbnailsUrl: getThumbnailsUrl(source) || thumbnailsUrl,
8310
+ children: activeThumbnailsUrl && /*#__PURE__*/jsx(SeekPreview$1, {
8311
+ thumbnailsUrl: activeThumbnailsUrl,
10013
8312
  duration: playbackTime.duration,
10014
8313
  chapters: chapters
10015
8314
  })
10016
8315
  }),
10017
8316
  displayTime: /*#__PURE__*/jsx(components.DisplayTime, { ...playbackTime
10018
8317
  }),
10019
- backButton: onBack && /*#__PURE__*/jsx(Button, {
10020
- startIcon: "back",
10021
- onClick: onBack
10022
- }),
10023
8318
  fullscreenButton: /*#__PURE__*/jsx(FullscreenButton, {
10024
8319
  viewMode: viewMode,
10025
8320
  onClick: () => toggleFullscreen(containerRef.current)
10026
8321
  }),
10027
8322
  volumeControl: width >= sizes['small-embed'] && /*#__PURE__*/jsx(components.VolumeControl, {
10028
- onAudioMuteSettingChange: handleMuteSettingChangeEvent,
10029
8323
  subscribe,
10030
8324
  onChange,
10031
8325
  toggleMute,
@@ -10034,48 +8328,10 @@ const PremiumPlayer = ({
10034
8328
  ...(slotProps === null || slotProps === void 0 ? void 0 : slotProps.volumeControl)
10035
8329
  }),
10036
8330
  backItems: /*#__PURE__*/jsx(PlayPanel, {
10037
- style: havePlayPanel ? {} : {
10038
- opacity: 0,
10039
- pointerEvents: 'none'
10040
- },
10041
8331
  animation: targetState.animation,
10042
- onClick: () => {
10043
- if (!havePointer() && mode !== 'shown') {
10044
- return;
10045
- }
10046
-
10047
- togglePlay('', {
10048
- triggeredBy: 'user-action'
10049
- });
10050
- sendTogglePlayLog();
10051
- }
10052
- }),
10053
- ...targetUIElements
10054
- };
10055
- const uiElementsOverride = !isUserActive && {
10056
- title,
10057
- channelTitle,
10058
- backButton: uiElements.backButton
10059
- };
10060
-
10061
- const sharing = share && /*#__PURE__*/jsx(Share, {
10062
- shareArray: share,
10063
- containerRef: containerRef.current,
10064
- open: userFocus === 'share',
10065
- onOpen: () => setUserFocus('share'),
10066
- onItemClick: () => setUserFocus('share-inner'),
10067
- onClose: () => setUserFocus('')
10068
- });
10069
-
10070
- const handleCastStarted = () => {
10071
- // workaround: this callback cannot get playbackTime.currentTime right value
10072
- // even if using useCallback to the state
10073
- // so temporally keeping value into castStartTime ref
10074
- seek({
10075
- seconds: castStartTime.current
10076
- });
8332
+ onClick: onClickBlank
8333
+ })
10077
8334
  };
10078
-
10079
8335
  const compatibilityCastProps = castOptions === 'compatible' && {
10080
8336
  source,
10081
8337
  values: {
@@ -10084,7 +8340,6 @@ const PremiumPlayer = ({
10084
8340
  ...intl,
10085
8341
  modulesConfig
10086
8342
  },
10087
- onCastStarted: handleCastStarted,
10088
8343
  onLoad: onCast
10089
8344
  };
10090
8345
  useEffect(() => {
@@ -10099,7 +8354,7 @@ const PremiumPlayer = ({
10099
8354
  return /*#__PURE__*/jsx(IntlProvider, { ...intl,
10100
8355
  children: /*#__PURE__*/jsxs$1(DefaultLayout, {
10101
8356
  style: { ...style,
10102
- '--playing': playbackState === 'playing' ? '1' : '0'
8357
+ cssVariables
10103
8358
  },
10104
8359
  type: uiType,
10105
8360
  display: mode,
@@ -10107,7 +8362,6 @@ const PremiumPlayer = ({
10107
8362
  size: size,
10108
8363
  video: /*#__PURE__*/jsx(Video$1, { ...videoProps,
10109
8364
  videoRef: multiRef(videoRef, videoProps.videoRef),
10110
- analyticsRef: analyticsRef,
10111
8365
  source: castState !== CastState.CONNECTED && playbackState !== 'error' && sourceOverride,
10112
8366
  playbackState: derivedPlaybackState,
10113
8367
  currentTime: targetState.currentTime,
@@ -10125,9 +8379,7 @@ const PremiumPlayer = ({
10125
8379
  onPlaylogFired: onPlaylogFired,
10126
8380
  onError: errorHandler,
10127
8381
  onPlaybackStateChange: handlePlaybackStateChange,
10128
- onBlockedAutoplay: error => {
10129
- onBlockedAutoplay === null || onBlockedAutoplay === void 0 ? void 0 : onBlockedAutoplay(error);
10130
- },
8382
+ onBlockedAutoplay: error => onBlockedAutoplay === null || onBlockedAutoplay === void 0 ? void 0 : onBlockedAutoplay(error),
10131
8383
  onCanPlay: event => {
10132
8384
  var _videoProps$onCanPlay;
10133
8385
 
@@ -10140,17 +8392,6 @@ const PremiumPlayer = ({
10140
8392
  playerRef.current = player;
10141
8393
  onPlayerLoaded === null || onPlayerLoaded === void 0 ? void 0 : onPlayerLoaded(player);
10142
8394
  syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume);
10143
- },
10144
- videoStyle: viewMode === 'fullscreen' ? {
10145
- position: 'absolute',
10146
- top: 0,
10147
- left: 0,
10148
- bottom: 0,
10149
- right: 0
10150
- } : {},
10151
- subtitlesPosition: {
10152
- height,
10153
- mode
10154
8395
  }
10155
8396
  }),
10156
8397
  containerRef: element => {
@@ -10158,29 +8399,24 @@ const PremiumPlayer = ({
10158
8399
  observe(element);
10159
8400
  },
10160
8401
  backRef: adContainerRef,
10161
- ...(uiElementsOverride || uiElements),
8402
+ title: title,
8403
+ channelTitle: channelTitle,
8404
+ backButton: onBack && /*#__PURE__*/jsx(Button, {
8405
+ startIcon: "back",
8406
+ onClick: onBack
8407
+ }),
8408
+ ...(isUserActive && uiElements),
10162
8409
  onClick: onClick,
10163
8410
  onMouseMove: onMouseMove,
10164
8411
  children: [/*#__PURE__*/jsx(LoadingSpinner, {
10165
- style: {
10166
- opacity: waiting && playbackState === 'buffering' ? '1' : '0'
10167
- }
10168
- }), playbackState === 'error' && errorData && /*#__PURE__*/jsx(Error$1, {
8412
+ active: waiting
8413
+ }), errorData && /*#__PURE__*/jsx(Error$1, {
10169
8414
  error: errorData,
10170
8415
  onBack: onBack
10171
- }), /*#__PURE__*/jsx(ChapterList, {
10172
- chapters: chapters,
10173
- open: userFocus === 'chapter-list',
10174
- onOpen: () => setUserFocus('chapter-list'),
10175
- onClose: () => setUserFocus(''),
10176
- currentTime: playbackTime.currentTime,
10177
- seek: setTargetTime
10178
- }), children, !isUserActive && !errorData && playbackState !== 'loading' && /*#__PURE__*/jsx(FisrtPlay, {
10179
- type: uiType,
10180
- children: uiElements.controlButtons.playButton
10181
- }), isUserActive && /*#__PURE__*/jsx(components.CastUi, {
8416
+ }), children, isUserActive && /*#__PURE__*/jsx(components.CastUi, {
10182
8417
  onBack: onBack,
10183
8418
  onStateChange: setCastState,
8419
+ onLoad: onCast,
10184
8420
  ...compatibilityCastProps,
10185
8421
  ...slotProps.castUi
10186
8422
  }), isUserActive &&
@@ -10193,26 +8429,12 @@ const PremiumPlayer = ({
10193
8429
  open: userFocus === 'settings',
10194
8430
  values: settings.values,
10195
8431
  onOpen: openSettings,
10196
- onChange: ({
10197
- name,
10198
- value,
10199
- keepOpen
10200
- }) => changeSettings(name, value, {
10201
- keepOpen
10202
- }),
8432
+ onChange: uiHandlers.onChangeSettings,
10203
8433
  ...(slotProps === null || slotProps === void 0 ? void 0 : slotProps.settings),
10204
- onClose: event => {
10205
- var _slotProps$settings, _slotProps$settings$o;
10206
-
10207
- setUserFocus('');
10208
- slotProps === null || slotProps === void 0 ? void 0 : (_slotProps$settings = slotProps.settings) === null || _slotProps$settings === void 0 ? void 0 : (_slotProps$settings$o = _slotProps$settings.onClose) === null || _slotProps$settings$o === void 0 ? void 0 : _slotProps$settings$o.call(_slotProps$settings, event);
10209
- }
8434
+ onClose: uiHandlers.onCloseSettings
10210
8435
  }), /*#__PURE__*/jsx(Backdrop, {
10211
8436
  open: !playbackState || playbackState === 'loading',
10212
8437
  children: /*#__PURE__*/jsx(LoadingSpinner, {})
10213
- }), sharing, watermark && /*#__PURE__*/jsx(Watermark, {
10214
- data: watermark,
10215
- portalNode: (_videoRef$current2 = videoRef.current) === null || _videoRef$current2 === void 0 ? void 0 : _videoRef$current2.parentNode
10216
8438
  })]
10217
8439
  })
10218
8440
  });
@@ -10328,6 +8550,44 @@ const usePlayPromiseHandler = () => {
10328
8550
  };
10329
8551
  };
10330
8552
 
8553
+ /* @jsxImportSource @emotion/react */
8554
+ const containerStyle = {
8555
+ position: 'absolute',
8556
+ zIndex: 1,
8557
+ top: 0,
8558
+ right: 0,
8559
+ width: '40%',
8560
+ height: '100%',
8561
+ overflow: 'auto',
8562
+ background: '#161c24',
8563
+ opacity: 0.9,
8564
+ transition: 'transform 0.2s ease',
8565
+ transform: 'translateX(100%)'
8566
+ };
8567
+ const openStyle = {
8568
+ transform: 'translateX(0)'
8569
+ };
8570
+
8571
+ const SidePanel = ({
8572
+ open,
8573
+ style,
8574
+ children,
8575
+ onClose
8576
+ }) => {
8577
+ const ref = useOnclickOutside(() => {
8578
+ if (open) {
8579
+ onClose();
8580
+ }
8581
+ }, {
8582
+ eventTypes: ['click']
8583
+ });
8584
+ return jsx$1("div", {
8585
+ ref: ref,
8586
+ css: [containerStyle, open && openStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:SidePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNpZGVQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ21CIiwiZmlsZSI6IlNpZGVQYW5lbC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbmltcG9ydCB1c2VPbmNsaWNrT3V0c2lkZSBmcm9tICdyZWFjdC1jb29sLW9uY2xpY2tvdXRzaWRlJ1xuXG4vLyBUT0RPIHRoaXMgaXMgY3VycmVudGx5IGRlc2t0b3Agb25seSwgbWF5YmUgY2FuIGJlIG1lcmdlZCB3aXRoIFN3aXBlYWJsZURyYXdsZXI/XG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogMSxcbiAgdG9wOiAwLFxuICByaWdodDogMCxcbiAgd2lkdGg6ICc0MCUnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgb3ZlcmZsb3c6ICdhdXRvJyxcbiAgYmFja2dyb3VuZDogJyMxNjFjMjQnLFxuICBvcGFjaXR5OiAwLjksXG4gIHRyYW5zaXRpb246ICd0cmFuc2Zvcm0gMC4ycyBlYXNlJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgxMDAlKScsXG59XG5cbmNvbnN0IG9wZW5TdHlsZSA9IHtcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScsXG59XG5cbmNvbnN0IFNpZGVQYW5lbCA9ICh7b3Blbiwgc3R5bGUsIGNoaWxkcmVuLCBvbkNsb3NlfSkgPT4ge1xuICBjb25zdCByZWYgPSB1c2VPbmNsaWNrT3V0c2lkZShcbiAgICAoKSA9PiB7XG4gICAgICBpZiAob3Blbikge1xuICAgICAgICBvbkNsb3NlKClcbiAgICAgIH1cbiAgICB9LFxuICAgIHtldmVudFR5cGVzOiBbJ2NsaWNrJ119XG4gIClcblxuICByZXR1cm4gKFxuICAgIDxkaXYgcmVmPXtyZWZ9IGNzcz17W2NvbnRhaW5lclN0eWxlLCBvcGVuICYmIG9wZW5TdHlsZSwgc3R5bGVdfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBTaWRlUGFuZWxcbiJdfQ== */"],
8587
+ children: children
8588
+ });
8589
+ };
8590
+
10331
8591
  /* @jsxImportSource @emotion/react */
10332
8592
  const titleStyle = {
10333
8593
  position: 'sticky',
@@ -10362,7 +8622,7 @@ const ContentDetail = ({
10362
8622
  onOpen,
10363
8623
  onClose
10364
8624
  }) => {
10365
- const Container = isDesktop() ? SidePanel$1 : SwipeableDrawer$1;
8625
+ const Container = isDesktop() ? SidePanel : SwipeableDrawer$1;
10366
8626
  return jsxs(Fragment, {
10367
8627
  children: [jsx$1(TitleBarExtension, {
10368
8628
  position: "right",