@kkcompany/player 2.25.0-canary.20 → 2.25.0-canary.22

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
@@ -762,30 +762,29 @@ const syncTextTrack = (media, {
762
762
 
763
763
  Array.from(cues).forEach(cue => customTextTrack.addCue(new VTTCue(cue.startTime, cue.endTime, cue.text)));
764
764
  customTextTrack.mode = 'showing';
765
- } else if (language === textTrackOptionOff.language) {
766
- player.setTextTrackVisibility(false);
767
- } else {
768
- if (customTextTrack) {
769
- customTextTrack.mode = 'hidden';
770
- }
765
+ return;
766
+ }
771
767
 
772
- const track = getTextTracks(media, {
773
- player
774
- }).find(t => (!language || t.language === language) && (!label || t.label === label));
768
+ if (customTextTrack) {
769
+ customTextTrack.mode = 'hidden';
770
+ }
775
771
 
776
- if (track) {
777
- player === null || player === void 0 ? void 0 : player.selectTextTrack(track);
778
- } else {
779
- player.setTextTrackVisibility(false);
780
- console.warn(`Text track ${label} ${language} doesn't exist`);
781
- }
772
+ const matchedTrack = getTextTracks(media, {
773
+ player
774
+ }).find(t => (!language || t.language === language) && (!label || t.label === label));
775
+
776
+ if (matchedTrack) {
777
+ player === null || player === void 0 ? void 0 : player.selectTextTrack(matchedTrack);
778
+ return;
782
779
  }
783
780
 
784
- return ((_media$textTracks = media.textTracks) === null || _media$textTracks === void 0 ? void 0 : _media$textTracks.addEventListener) && on(media.textTracks, 'change', () => {
785
- if (language === textTrackOptionOff.language) {
786
- player.setTextTrackVisibility(false);
787
- }
788
- });
781
+ player.setTextTrackVisibility(false);
782
+
783
+ if (!/off|none/i.test(label + language)) {
784
+ console.warn(`turn off text track: ${label} ${language} is not found`);
785
+ }
786
+
787
+ return ((_media$textTracks = media.textTracks) === null || _media$textTracks === void 0 ? void 0 : _media$textTracks.addEventListener) && once(media.textTracks, 'change', () => player.setTextTrackVisibility(false));
789
788
  }; // assume unique labels as defined in spec
790
789
 
791
790
 
@@ -812,7 +811,7 @@ function convertToSeconds(timeString) {
812
811
  function getVersion() {
813
812
  try {
814
813
  // eslint-disable-next-line no-undef
815
- return "2.25.0-canary.20";
814
+ return "2.25.0-canary.22";
816
815
  } catch (e) {
817
816
  return undefined;
818
817
  }
@@ -1137,11 +1136,9 @@ const getLanguageOptions = (player, sorted) => {
1137
1136
  });
1138
1137
  const textOptions = [].concat(textTracks, {
1139
1138
  type: 'subtitles',
1140
- label: 'none',
1141
1139
  language: 'none',
1142
1140
  selected: !textTracks.some(track => track.selected),
1143
1141
  value: {
1144
- label: 'none',
1145
1142
  language: 'none',
1146
1143
  id: 'off'
1147
1144
  }
@@ -3864,7 +3861,7 @@ const SliderRail = ({
3864
3861
  css: [style, orientation !== 'horizontal' && {
3865
3862
  borderRadius: '0.2em',
3866
3863
  alignSelf: 'normal'
3867
- }, 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"]} */"],
3864
+ }, 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      {...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"]} */"],
3868
3865
  ...rest
3869
3866
  });
3870
3867
 
@@ -3879,7 +3876,7 @@ const SliderTrack = ({
3879
3876
  height: `${value * 100}%`
3880
3877
  } : {
3881
3878
  width: `${value * 100}%`
3882
- }, 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"]} */"],
3879
+ }, 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      {...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"]} */"],
3883
3880
  ...rest
3884
3881
  });
3885
3882
 
@@ -3985,7 +3982,7 @@ const SimpleSlider = ({
3985
3982
  };
3986
3983
  return jsxs("div", {
3987
3984
  className: className,
3988
- css: [containerStyle$4, 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"]} */"],
3985
+ css: [containerStyle$4, 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      {...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"]} */"],
3989
3986
  style: { ...(orientation === 'vertical' && {
3990
3987
  flexDirection: 'column',
3991
3988
  '--slider-thumb-y': `${thumbPosition * 100}%`
@@ -3994,7 +3991,6 @@ const SimpleSlider = ({
3994
3991
  '--slider-thumb-x': `${thumbPosition * 100}%`
3995
3992
  })
3996
3993
  },
3997
- onClick: event => event.stopPropagation(),
3998
3994
  ...eventHandlers({
3999
3995
  onPointerDown: event => {
4000
3996
  if (event.type === 'pointerdown') {
@@ -4122,8 +4118,7 @@ const sliderStyle = {
4122
4118
  },
4123
4119
  '> div:last-of-type': {
4124
4120
  width: '1.2em',
4125
- height: '1.2em',
4126
- background: 'var(--theme-color, red)'
4121
+ height: '1.2em'
4127
4122
  },
4128
4123
  '&:hover > div:last-of-type': {
4129
4124
  opacity: 1
@@ -4202,7 +4197,7 @@ const SeekbarTrack = ({
4202
4197
  current,
4203
4198
  buffered
4204
4199
  }) => jsxs("div", {
4205
- css: [style, segmentedTrackStyle, process.env.NODE_ENV === "production" ? "" : ";label:SeekbarTrack;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUZNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
4200
+ css: [style, segmentedTrackStyle, process.env.NODE_ENV === "production" ? "" : ";label:SeekbarTrack;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0ZNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgfSxcbiAgJyY6aG92ZXIgPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIG9wYWNpdHk6IDEsXG4gIH0sXG59XG5cbmNvbnN0IHJlZHVjZVBvaW50ZXIgPSAoc3RhdGUsIHt0eXBlLCB2YWx1ZSwgeH0pID0+IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnbW92ZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBob3ZlcjogdHJ1ZSwgdmFsdWUsIHh9XG4gICAgY2FzZSAnY2hhbmdlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGZvY3VzZWQ6IHRydWUsIHZhbHVlfVxuICAgIGNhc2UgJ3JlbGVhc2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogZmFsc2UsIHZhbHVlfVxuICAgIGNhc2UgJ2xlYXZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiBmYWxzZX1cbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHN0YXRlXG4gIH1cbn1cblxuY29uc3QgU2Vla2JhclJhaWwgPSAoKSA9PiAnJ1xuXG5jb25zdCBzZWdtZW50ZWRUcmFja1N0eWxlID0ge1xuICBib3hTaXppbmc6ICdib3JkZXItYm94JyxcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIG1hcmdpbjogJzAgMnB4JyxcbiAgaGVpZ2h0OiAnMjRweCcsXG4gIGJvcmRlclRvcDogJ2NhbGMoMTJweCAtIDAuM2VtKSBzb2xpZCB0cmFuc3BhcmVudCcsXG4gIGJvcmRlckJvdHRvbTogJ2NhbGMoMTJweCAtIDAuM2VtKSBzb2xpZCB0cmFuc3BhcmVudCcsXG4gIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICcmOmhvdmVyJzoge1xuICAgIHRyYW5zZm9ybTogJ3NjYWxlKDEsIDEuNSknLFxuICB9LFxuICAnPiBkaXYnOiB7XG4gICAgaGVpZ2h0OiAnMC42ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC4yKScsXG4gICAgJyY6bm90KDpmaXJzdC1vZi10eXBlKSc6IHtcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgdG9wOiAnMCcsXG4gICAgfSxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDIpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC4zKScsXG4gIH0sXG4gICc+IGRpdjpudGgtb2YtdHlwZSgzKSc6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICd2YXIoLS10aGVtZS1jb2xvciwgcmVkKScsXG4gIH0sXG59XG5cbmNvbnN0IFNlZWtiYXJUcmFjayA9ICh7c2VnbWVudHMsIHN0eWxlfSkgPT5cbiAgc2VnbWVudHMubWFwKCh7bGVuZ3RoLCBjdXJyZW50LCBidWZmZXJlZH0pID0+IChcbiAgICA8ZGl2XG4gICAgICBjc3M9e1tzdHlsZSwgc2VnbWVudGVkVHJhY2tTdHlsZV19XG4gICAgICBzdHlsZT17e1xuICAgICAgICBmbGV4OiBgMCAke2xlbmd0aCAqIDEwMH0lYCxcbiAgICAgICAgd2lkdGg6IGBjYWxjKCR7bGVuZ3RoICogMTAwfSUgLSA0cHgpYCxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiAnMTAwJSd9fSAvPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiBgJHtidWZmZXJlZCAqIDEwMH0lYH19IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2N1cnJlbnQgKiAxMDB9JWB9fSAvPlxuICAgIDwvZGl2PlxuICApKVxuXG4vLyBUT0RPIHVzZSBjbGFzc05hbWUgaW5zdGVhZCBvZiBjbGFzc2VzID9cbmNvbnN0IFNlZWtiYXIgPSAoe1xuICBzdHlsZSxcbiAgY2xhc3NlcyxcbiAgc3RhcnRUaW1lID0gMCxcbiAgY3VycmVudFRpbWUsXG4gIGJ1ZmZlclRpbWUsXG4gIGR1cmF0aW9uLFxuICBjaGFwdGVycyA9IFtdLFxuICBtYXJrcyxcbiAgdGltZURpc3BsYXkgPSBmYWxzZSwgLy8gVE9ETyBtb3JlIHNjYWxhYmxlIHdheT9cbiAgb25DaGFuZ2UsXG4gIG9uQ2hhbmdlQ29tbWl0dGVkLFxuICBjaGlsZHJlbixcbiAgb25Qb2ludGVyTW92ZSxcbiAgb25Qb2ludGVyTGVhdmUsXG4gIC4uLnJlc3Rcbn0pID0+IHtcbiAgY29uc3QgW3BvaW50ZXJTdGF0ZSwgZGlzcGF0Y2hQb2ludGVyXSA9IHVzZVJlZHVjZXIocmVkdWNlUG9pbnRlciwge30pXG4gIGNvbnN0IHBvaW50ZXJBY3RpdmUgPSBwb2ludGVyU3RhdGUuaG92ZXIgfHwgcG9pbnRlclN0YXRlLmZvY3VzZWRcbiAgLy8gdG8gcmVmbGVjdCBib3VuZGFyeSB3aGVuIGNvbnRhaW5lciByZXNpemVkXG4gIGNvbnN0IHtvYnNlcnZlfSA9IHVzZURpbWVuc2lvbnMoKVxuICBjb25zdCByZWYgPSB1c2VSZWYoKVxuICBjb25zdCByZWN0ID0gcmVmLmN1cnJlbnQ/LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpXG4gIGNvbnN0IGhhbmRsZXJzID0gb25DaGFuZ2VDb21taXR0ZWQgJiYge1xuICAgIG9uUG9pbnRlck1vdmU6IChldmVudCwge3ZhbHVlLCB4fSkgPT4ge1xuICAgICAgb25Qb2ludGVyTW92ZT8uKGV2ZW50LCB7dmFsdWUsIHh9KVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnbW92ZScsIHZhbHVlLCB4fSlcbiAgICB9LFxuICAgIG9uUG9pbnRlckxlYXZlOiBldmVudCA9PiB7XG4gICAgICBvblBvaW50ZXJMZWF2ZT8uKGV2ZW50KVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnbGVhdmUnfSlcbiAgICB9LFxuICAgIG9uQ2hhbmdlOiAoXywge3ZhbHVlfSkgPT4ge1xuICAgICAgb25DaGFuZ2U/Lih2YWx1ZSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2NoYW5nZScsIHZhbHVlfSlcbiAgICB9LFxuICAgIG9uQ2hhbmdlQ29tbWl0dGVkOiAoXywge3ZhbHVlfSkgPT4ge1xuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAncmVsZWFzZScsIHZhbHVlfSlcbiAgICAgIG9uQ2hhbmdlQ29tbWl0dGVkPy4odmFsdWUpXG4gICAgfSxcbiAgfVxuICBjb25zdCBlbmRUaW1lID0gc3RhcnRUaW1lICsgZHVyYXRpb25cbiAgY29uc3Qgc2VnbWVudHMgPSBnZXRUaW1lbGluZVNlZ21lbnRzKGNoYXB0ZXJzLCB7XG4gICAgc3RhcnRUaW1lLFxuICAgIGN1cnJlbnQ6IHBvaW50ZXJTdGF0ZS5mb2N1c2VkID8gcG9pbnRlclN0YXRlLnZhbHVlIDogY3VycmVudFRpbWUsXG4gICAgYnVmZmVyZWQ6IGJ1ZmZlclRpbWUsXG4gICAgZHVyYXRpb24sXG4gIH0pXG5cbiAgcmV0dXJuICEoZHVyYXRpb24gPiAwKSA/IChcbiAgICA8ZGl2IC8+XG4gICkgOiAoXG4gICAgPGRpdlxuICAgICAgcmVmPXtlbGVtZW50ID0+IHtcbiAgICAgICAgb2JzZXJ2ZShlbGVtZW50KVxuICAgICAgICByZWYuY3VycmVudCA9IGVsZW1lbnRcbiAgICAgIH19XG4gICAgICBjc3M9e1tzZWVrYmFyU3R5bGUsIHN0eWxlXX1cbiAgICAgIHN0eWxlPXtcbiAgICAgICAgcmVjdCAmJiB7XG4gICAgICAgICAgJy0tc2Vla2Jhci1sZWZ0JzogYCR7cmVjdC5sZWZ0fXB4YCxcbiAgICAgICAgICAnLS1zZWVrYmFyLXJpZ2h0JzogYCR7cmVjdC5yaWdodH1weGAsXG4gICAgICAgICAgJy0tcG9pbnRlci14JzogYCR7cG9pbnRlclN0YXRlLnh9cHhgLFxuICAgICAgICB9XG4gICAgICB9XG4gICAgPlxuICAgICAgeyF0aW1lRGlzcGxheSA/IChcbiAgICAgICAgJydcbiAgICAgICkgOiBwb2ludGVyQWN0aXZlID8gKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtwb2ludGVyU3RhdGUudmFsdWV9IC8+XG4gICAgICApIDogKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtNYXRoLm1pbihNYXRoLm1heCgwLCBjdXJyZW50VGltZSksIGR1cmF0aW9uKX0gLz5cbiAgICAgICl9XG4gICAgICA8U2ltcGxlU2xpZGVyXG4gICAgICAgIGNzcz17W3NsaWRlclN0eWxlLCB0aW1lRGlzcGxheSAmJiB7bWFyZ2luOiAnMCAxZW0nfV19XG4gICAgICAgIGNsYXNzZXM9e2NsYXNzZXN9XG4gICAgICAgIGRpc2FibGVkPXshb25DaGFuZ2VDb21taXR0ZWR9XG4gICAgICAgIC8vIGRpc3BsYXkgZmlsbGVkIHdoZW4gc2VlayBoYW5kbGVyIGlzIG5vdCBwcm92aWRlZCwgZnJvbSBQbGF5Qm95IGJlaGF2aW9yXG4gICAgICAgIHZhbHVlPXtvbkNoYW5nZUNvbW1pdHRlZCA/IGN1cnJlbnRUaW1lIDogZW5kVGltZX1cbiAgICAgICAgbWluPXtzdGFydFRpbWV9XG4gICAgICAgIG1heD17ZW5kVGltZX1cbiAgICAgICAgbWFya3M9e21hcmtzfVxuICAgICAgICB7Li4uaGFuZGxlcnN9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgICBzbG90cz17e1JhaWw6IFNlZWtiYXJSYWlsLCBUcmFjazogU2Vla2JhclRyYWNrfX1cbiAgICAgICAgc2xvdFByb3BzPXt7dHJhY2s6IHtzZWdtZW50c319fVxuICAgICAgLz5cbiAgICAgIHt0aW1lRGlzcGxheSAmJiA8Rm9ybWF0dGVkVGltZSB0aW1lPXtkdXJhdGlvbn0gLz59XG4gICAgICB7Y2hpbGRyZW4gJiZcbiAgICAgICAgW11cbiAgICAgICAgICAuY29uY2F0KGNoaWxkcmVuKVxuICAgICAgICAgIC5tYXAoY2hpbGQgPT5cbiAgICAgICAgICAgIGNsb25lRWxlbWVudChjaGlsZCwge3RpbWU6IHBvaW50ZXJBY3RpdmUgJiYgcG9pbnRlclN0YXRlLnZhbHVlfSlcbiAgICAgICAgICApfVxuICAgIDwvZGl2PlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFNlZWtiYXJcbiJdfQ== */"],
4206
4201
  style: {
4207
4202
  flex: `0 ${length * 100}%`,
4208
4203
  width: `calc(${length * 100}% - 4px)`
@@ -4303,7 +4298,7 @@ const Seekbar = ({
4303
4298
  observe(element);
4304
4299
  ref.current = element;
4305
4300
  },
4306
- css: [seekbarStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkpNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
4301
+ css: [seekbarStyle, style, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEpNIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgfSxcbiAgJyY6aG92ZXIgPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIG9wYWNpdHk6IDEsXG4gIH0sXG59XG5cbmNvbnN0IHJlZHVjZVBvaW50ZXIgPSAoc3RhdGUsIHt0eXBlLCB2YWx1ZSwgeH0pID0+IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnbW92ZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBob3ZlcjogdHJ1ZSwgdmFsdWUsIHh9XG4gICAgY2FzZSAnY2hhbmdlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGZvY3VzZWQ6IHRydWUsIHZhbHVlfVxuICAgIGNhc2UgJ3JlbGVhc2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogZmFsc2UsIHZhbHVlfVxuICAgIGNhc2UgJ2xlYXZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiBmYWxzZX1cbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHN0YXRlXG4gIH1cbn1cblxuY29uc3QgU2Vla2JhclJhaWwgPSAoKSA9PiAnJ1xuXG5jb25zdCBzZWdtZW50ZWRUcmFja1N0eWxlID0ge1xuICBib3hTaXppbmc6ICdib3JkZXItYm94JyxcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIG1hcmdpbjogJzAgMnB4JyxcbiAgaGVpZ2h0OiAnMjRweCcsXG4gIGJvcmRlclRvcDogJ2NhbGMoMTJweCAtIDAuM2VtKSBzb2xpZCB0cmFuc3BhcmVudCcsXG4gIGJvcmRlckJvdHRvbTogJ2NhbGMoMTJweCAtIDAuM2VtKSBzb2xpZCB0cmFuc3BhcmVudCcsXG4gIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICcmOmhvdmVyJzoge1xuICAgIHRyYW5zZm9ybTogJ3NjYWxlKDEsIDEuNSknLFxuICB9LFxuICAnPiBkaXYnOiB7XG4gICAgaGVpZ2h0OiAnMC42ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC4yKScsXG4gICAgJyY6bm90KDpmaXJzdC1vZi10eXBlKSc6IHtcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgdG9wOiAnMCcsXG4gICAgfSxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDIpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC4zKScsXG4gIH0sXG4gICc+IGRpdjpudGgtb2YtdHlwZSgzKSc6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICd2YXIoLS10aGVtZS1jb2xvciwgcmVkKScsXG4gIH0sXG59XG5cbmNvbnN0IFNlZWtiYXJUcmFjayA9ICh7c2VnbWVudHMsIHN0eWxlfSkgPT5cbiAgc2VnbWVudHMubWFwKCh7bGVuZ3RoLCBjdXJyZW50LCBidWZmZXJlZH0pID0+IChcbiAgICA8ZGl2XG4gICAgICBjc3M9e1tzdHlsZSwgc2VnbWVudGVkVHJhY2tTdHlsZV19XG4gICAgICBzdHlsZT17e1xuICAgICAgICBmbGV4OiBgMCAke2xlbmd0aCAqIDEwMH0lYCxcbiAgICAgICAgd2lkdGg6IGBjYWxjKCR7bGVuZ3RoICogMTAwfSUgLSA0cHgpYCxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiAnMTAwJSd9fSAvPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiBgJHtidWZmZXJlZCAqIDEwMH0lYH19IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2N1cnJlbnQgKiAxMDB9JWB9fSAvPlxuICAgIDwvZGl2PlxuICApKVxuXG4vLyBUT0RPIHVzZSBjbGFzc05hbWUgaW5zdGVhZCBvZiBjbGFzc2VzID9cbmNvbnN0IFNlZWtiYXIgPSAoe1xuICBzdHlsZSxcbiAgY2xhc3NlcyxcbiAgc3RhcnRUaW1lID0gMCxcbiAgY3VycmVudFRpbWUsXG4gIGJ1ZmZlclRpbWUsXG4gIGR1cmF0aW9uLFxuICBjaGFwdGVycyA9IFtdLFxuICBtYXJrcyxcbiAgdGltZURpc3BsYXkgPSBmYWxzZSwgLy8gVE9ETyBtb3JlIHNjYWxhYmxlIHdheT9cbiAgb25DaGFuZ2UsXG4gIG9uQ2hhbmdlQ29tbWl0dGVkLFxuICBjaGlsZHJlbixcbiAgb25Qb2ludGVyTW92ZSxcbiAgb25Qb2ludGVyTGVhdmUsXG4gIC4uLnJlc3Rcbn0pID0+IHtcbiAgY29uc3QgW3BvaW50ZXJTdGF0ZSwgZGlzcGF0Y2hQb2ludGVyXSA9IHVzZVJlZHVjZXIocmVkdWNlUG9pbnRlciwge30pXG4gIGNvbnN0IHBvaW50ZXJBY3RpdmUgPSBwb2ludGVyU3RhdGUuaG92ZXIgfHwgcG9pbnRlclN0YXRlLmZvY3VzZWRcbiAgLy8gdG8gcmVmbGVjdCBib3VuZGFyeSB3aGVuIGNvbnRhaW5lciByZXNpemVkXG4gIGNvbnN0IHtvYnNlcnZlfSA9IHVzZURpbWVuc2lvbnMoKVxuICBjb25zdCByZWYgPSB1c2VSZWYoKVxuICBjb25zdCByZWN0ID0gcmVmLmN1cnJlbnQ/LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpXG4gIGNvbnN0IGhhbmRsZXJzID0gb25DaGFuZ2VDb21taXR0ZWQgJiYge1xuICAgIG9uUG9pbnRlck1vdmU6IChldmVudCwge3ZhbHVlLCB4fSkgPT4ge1xuICAgICAgb25Qb2ludGVyTW92ZT8uKGV2ZW50LCB7dmFsdWUsIHh9KVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnbW92ZScsIHZhbHVlLCB4fSlcbiAgICB9LFxuICAgIG9uUG9pbnRlckxlYXZlOiBldmVudCA9PiB7XG4gICAgICBvblBvaW50ZXJMZWF2ZT8uKGV2ZW50KVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnbGVhdmUnfSlcbiAgICB9LFxuICAgIG9uQ2hhbmdlOiAoXywge3ZhbHVlfSkgPT4ge1xuICAgICAgb25DaGFuZ2U/Lih2YWx1ZSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2NoYW5nZScsIHZhbHVlfSlcbiAgICB9LFxuICAgIG9uQ2hhbmdlQ29tbWl0dGVkOiAoXywge3ZhbHVlfSkgPT4ge1xuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAncmVsZWFzZScsIHZhbHVlfSlcbiAgICAgIG9uQ2hhbmdlQ29tbWl0dGVkPy4odmFsdWUpXG4gICAgfSxcbiAgfVxuICBjb25zdCBlbmRUaW1lID0gc3RhcnRUaW1lICsgZHVyYXRpb25cbiAgY29uc3Qgc2VnbWVudHMgPSBnZXRUaW1lbGluZVNlZ21lbnRzKGNoYXB0ZXJzLCB7XG4gICAgc3RhcnRUaW1lLFxuICAgIGN1cnJlbnQ6IHBvaW50ZXJTdGF0ZS5mb2N1c2VkID8gcG9pbnRlclN0YXRlLnZhbHVlIDogY3VycmVudFRpbWUsXG4gICAgYnVmZmVyZWQ6IGJ1ZmZlclRpbWUsXG4gICAgZHVyYXRpb24sXG4gIH0pXG5cbiAgcmV0dXJuICEoZHVyYXRpb24gPiAwKSA/IChcbiAgICA8ZGl2IC8+XG4gICkgOiAoXG4gICAgPGRpdlxuICAgICAgcmVmPXtlbGVtZW50ID0+IHtcbiAgICAgICAgb2JzZXJ2ZShlbGVtZW50KVxuICAgICAgICByZWYuY3VycmVudCA9IGVsZW1lbnRcbiAgICAgIH19XG4gICAgICBjc3M9e1tzZWVrYmFyU3R5bGUsIHN0eWxlXX1cbiAgICAgIHN0eWxlPXtcbiAgICAgICAgcmVjdCAmJiB7XG4gICAgICAgICAgJy0tc2Vla2Jhci1sZWZ0JzogYCR7cmVjdC5sZWZ0fXB4YCxcbiAgICAgICAgICAnLS1zZWVrYmFyLXJpZ2h0JzogYCR7cmVjdC5yaWdodH1weGAsXG4gICAgICAgICAgJy0tcG9pbnRlci14JzogYCR7cG9pbnRlclN0YXRlLnh9cHhgLFxuICAgICAgICB9XG4gICAgICB9XG4gICAgPlxuICAgICAgeyF0aW1lRGlzcGxheSA/IChcbiAgICAgICAgJydcbiAgICAgICkgOiBwb2ludGVyQWN0aXZlID8gKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtwb2ludGVyU3RhdGUudmFsdWV9IC8+XG4gICAgICApIDogKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtNYXRoLm1pbihNYXRoLm1heCgwLCBjdXJyZW50VGltZSksIGR1cmF0aW9uKX0gLz5cbiAgICAgICl9XG4gICAgICA8U2ltcGxlU2xpZGVyXG4gICAgICAgIGNzcz17W3NsaWRlclN0eWxlLCB0aW1lRGlzcGxheSAmJiB7bWFyZ2luOiAnMCAxZW0nfV19XG4gICAgICAgIGNsYXNzZXM9e2NsYXNzZXN9XG4gICAgICAgIGRpc2FibGVkPXshb25DaGFuZ2VDb21taXR0ZWR9XG4gICAgICAgIC8vIGRpc3BsYXkgZmlsbGVkIHdoZW4gc2VlayBoYW5kbGVyIGlzIG5vdCBwcm92aWRlZCwgZnJvbSBQbGF5Qm95IGJlaGF2aW9yXG4gICAgICAgIHZhbHVlPXtvbkNoYW5nZUNvbW1pdHRlZCA/IGN1cnJlbnRUaW1lIDogZW5kVGltZX1cbiAgICAgICAgbWluPXtzdGFydFRpbWV9XG4gICAgICAgIG1heD17ZW5kVGltZX1cbiAgICAgICAgbWFya3M9e21hcmtzfVxuICAgICAgICB7Li4uaGFuZGxlcnN9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgICBzbG90cz17e1JhaWw6IFNlZWtiYXJSYWlsLCBUcmFjazogU2Vla2JhclRyYWNrfX1cbiAgICAgICAgc2xvdFByb3BzPXt7dHJhY2s6IHtzZWdtZW50c319fVxuICAgICAgLz5cbiAgICAgIHt0aW1lRGlzcGxheSAmJiA8Rm9ybWF0dGVkVGltZSB0aW1lPXtkdXJhdGlvbn0gLz59XG4gICAgICB7Y2hpbGRyZW4gJiZcbiAgICAgICAgW11cbiAgICAgICAgICAuY29uY2F0KGNoaWxkcmVuKVxuICAgICAgICAgIC5tYXAoY2hpbGQgPT5cbiAgICAgICAgICAgIGNsb25lRWxlbWVudChjaGlsZCwge3RpbWU6IHBvaW50ZXJBY3RpdmUgJiYgcG9pbnRlclN0YXRlLnZhbHVlfSlcbiAgICAgICAgICApfVxuICAgIDwvZGl2PlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFNlZWtiYXJcbiJdfQ== */"],
4307
4302
  style: rect && {
4308
4303
  '--seekbar-left': `${rect.left}px`,
4309
4304
  '--seekbar-right': `${rect.right}px`,
@@ -4316,7 +4311,7 @@ const Seekbar = ({
4316
4311
  }), jsx$1(SimpleSlider, {
4317
4312
  css: [sliderStyle, timeDisplay && {
4318
4313
  margin: '0 1em'
4319
- }, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEtRIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgICBiYWNrZ3JvdW5kOiAndmFyKC0tdGhlbWUtY29sb3IsIHJlZCknLFxuICB9LFxuICAnJjpob3ZlciA+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgb3BhY2l0eTogMSxcbiAgfSxcbn1cblxuY29uc3QgcmVkdWNlUG9pbnRlciA9IChzdGF0ZSwge3R5cGUsIHZhbHVlLCB4fSkgPT4ge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdtb3ZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiB0cnVlLCB2YWx1ZSwgeH1cbiAgICBjYXNlICdjaGFuZ2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogdHJ1ZSwgdmFsdWV9XG4gICAgY2FzZSAncmVsZWFzZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBmb2N1c2VkOiBmYWxzZSwgdmFsdWV9XG4gICAgY2FzZSAnbGVhdmUnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgaG92ZXI6IGZhbHNlfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gc3RhdGVcbiAgfVxufVxuXG5jb25zdCBTZWVrYmFyUmFpbCA9ICgpID0+ICcnXG5cbmNvbnN0IHNlZ21lbnRlZFRyYWNrU3R5bGUgPSB7XG4gIGJveFNpemluZzogJ2JvcmRlci1ib3gnLFxuICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgbWFyZ2luOiAnMCAycHgnLFxuICBoZWlnaHQ6ICcyNHB4JyxcbiAgYm9yZGVyVG9wOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYm9yZGVyQm90dG9tOiAnY2FsYygxMnB4IC0gMC4zZW0pIHNvbGlkIHRyYW5zcGFyZW50JyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgJyY6aG92ZXInOiB7XG4gICAgdHJhbnNmb3JtOiAnc2NhbGUoMSwgMS41KScsXG4gIH0sXG4gICc+IGRpdic6IHtcbiAgICBoZWlnaHQ6ICcwLjZlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjIpJyxcbiAgICAnJjpub3QoOmZpcnN0LW9mLXR5cGUpJzoge1xuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6ICcwJyxcbiAgICB9LFxuICB9LFxuICAnPiBkaXY6bnRoLW9mLXR5cGUoMiknOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjMpJyxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDMpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXRoZW1lLWNvbG9yLCByZWQpJyxcbiAgfSxcbn1cblxuY29uc3QgU2Vla2JhclRyYWNrID0gKHtzZWdtZW50cywgc3R5bGV9KSA9PlxuICBzZWdtZW50cy5tYXAoKHtsZW5ndGgsIGN1cnJlbnQsIGJ1ZmZlcmVkfSkgPT4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W3N0eWxlLCBzZWdtZW50ZWRUcmFja1N0eWxlXX1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGZsZXg6IGAwICR7bGVuZ3RoICogMTAwfSVgLFxuICAgICAgICB3aWR0aDogYGNhbGMoJHtsZW5ndGggKiAxMDB9JSAtIDRweClgLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6ICcxMDAlJ319IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2J1ZmZlcmVkICogMTAwfSVgfX0gLz5cbiAgICAgIDxkaXYgc3R5bGU9e3t3aWR0aDogYCR7Y3VycmVudCAqIDEwMH0lYH19IC8+XG4gICAgPC9kaXY+XG4gICkpXG5cbi8vIFRPRE8gdXNlIGNsYXNzTmFtZSBpbnN0ZWFkIG9mIGNsYXNzZXMgP1xuY29uc3QgU2Vla2JhciA9ICh7XG4gIHN0eWxlLFxuICBjbGFzc2VzLFxuICBzdGFydFRpbWUgPSAwLFxuICBjdXJyZW50VGltZSxcbiAgYnVmZmVyVGltZSxcbiAgZHVyYXRpb24sXG4gIGNoYXB0ZXJzID0gW10sXG4gIG1hcmtzLFxuICB0aW1lRGlzcGxheSA9IGZhbHNlLCAvLyBUT0RPIG1vcmUgc2NhbGFibGUgd2F5P1xuICBvbkNoYW5nZSxcbiAgb25DaGFuZ2VDb21taXR0ZWQsXG4gIGNoaWxkcmVuLFxuICBvblBvaW50ZXJNb3ZlLFxuICBvblBvaW50ZXJMZWF2ZSxcbiAgLi4ucmVzdFxufSkgPT4ge1xuICBjb25zdCBbcG9pbnRlclN0YXRlLCBkaXNwYXRjaFBvaW50ZXJdID0gdXNlUmVkdWNlcihyZWR1Y2VQb2ludGVyLCB7fSlcbiAgY29uc3QgcG9pbnRlckFjdGl2ZSA9IHBvaW50ZXJTdGF0ZS5ob3ZlciB8fCBwb2ludGVyU3RhdGUuZm9jdXNlZFxuICAvLyB0byByZWZsZWN0IGJvdW5kYXJ5IHdoZW4gY29udGFpbmVyIHJlc2l6ZWRcbiAgY29uc3Qge29ic2VydmV9ID0gdXNlRGltZW5zaW9ucygpXG4gIGNvbnN0IHJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IHJlY3QgPSByZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgaGFuZGxlcnMgPSBvbkNoYW5nZUNvbW1pdHRlZCAmJiB7XG4gICAgb25Qb2ludGVyTW92ZTogKGV2ZW50LCB7dmFsdWUsIHh9KSA9PiB7XG4gICAgICBvblBvaW50ZXJNb3ZlPy4oZXZlbnQsIHt2YWx1ZSwgeH0pXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdtb3ZlJywgdmFsdWUsIHh9KVxuICAgIH0sXG4gICAgb25Qb2ludGVyTGVhdmU6IGV2ZW50ID0+IHtcbiAgICAgIG9uUG9pbnRlckxlYXZlPy4oZXZlbnQpXG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdsZWF2ZSd9KVxuICAgIH0sXG4gICAgb25DaGFuZ2U6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBvbkNoYW5nZT8uKHZhbHVlKVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnY2hhbmdlJywgdmFsdWV9KVxuICAgIH0sXG4gICAgb25DaGFuZ2VDb21taXR0ZWQ6IChfLCB7dmFsdWV9KSA9PiB7XG4gICAgICBkaXNwYXRjaFBvaW50ZXIoe3R5cGU6ICdyZWxlYXNlJywgdmFsdWV9KVxuICAgICAgb25DaGFuZ2VDb21taXR0ZWQ/Lih2YWx1ZSlcbiAgICB9LFxuICB9XG4gIGNvbnN0IGVuZFRpbWUgPSBzdGFydFRpbWUgKyBkdXJhdGlvblxuICBjb25zdCBzZWdtZW50cyA9IGdldFRpbWVsaW5lU2VnbWVudHMoY2hhcHRlcnMsIHtcbiAgICBzdGFydFRpbWUsXG4gICAgY3VycmVudDogcG9pbnRlclN0YXRlLmZvY3VzZWQgPyBwb2ludGVyU3RhdGUudmFsdWUgOiBjdXJyZW50VGltZSxcbiAgICBidWZmZXJlZDogYnVmZmVyVGltZSxcbiAgICBkdXJhdGlvbixcbiAgfSlcblxuICByZXR1cm4gIShkdXJhdGlvbiA+IDApID8gKFxuICAgIDxkaXYgLz5cbiAgKSA6IChcbiAgICA8ZGl2XG4gICAgICByZWY9e2VsZW1lbnQgPT4ge1xuICAgICAgICBvYnNlcnZlKGVsZW1lbnQpXG4gICAgICAgIHJlZi5jdXJyZW50ID0gZWxlbWVudFxuICAgICAgfX1cbiAgICAgIGNzcz17W3NlZWtiYXJTdHlsZSwgc3R5bGVdfVxuICAgICAgc3R5bGU9e1xuICAgICAgICByZWN0ICYmIHtcbiAgICAgICAgICAnLS1zZWVrYmFyLWxlZnQnOiBgJHtyZWN0LmxlZnR9cHhgLFxuICAgICAgICAgICctLXNlZWtiYXItcmlnaHQnOiBgJHtyZWN0LnJpZ2h0fXB4YCxcbiAgICAgICAgICAnLS1wb2ludGVyLXgnOiBgJHtwb2ludGVyU3RhdGUueH1weGAsXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICA+XG4gICAgICB7IXRpbWVEaXNwbGF5ID8gKFxuICAgICAgICAnJ1xuICAgICAgKSA6IHBvaW50ZXJBY3RpdmUgPyAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e3BvaW50ZXJTdGF0ZS52YWx1ZX0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e01hdGgubWluKE1hdGgubWF4KDAsIGN1cnJlbnRUaW1lKSwgZHVyYXRpb24pfSAvPlxuICAgICAgKX1cbiAgICAgIDxTaW1wbGVTbGlkZXJcbiAgICAgICAgY3NzPXtbc2xpZGVyU3R5bGUsIHRpbWVEaXNwbGF5ICYmIHttYXJnaW46ICcwIDFlbSd9XX1cbiAgICAgICAgY2xhc3Nlcz17Y2xhc3Nlc31cbiAgICAgICAgZGlzYWJsZWQ9eyFvbkNoYW5nZUNvbW1pdHRlZH1cbiAgICAgICAgLy8gZGlzcGxheSBmaWxsZWQgd2hlbiBzZWVrIGhhbmRsZXIgaXMgbm90IHByb3ZpZGVkLCBmcm9tIFBsYXlCb3kgYmVoYXZpb3JcbiAgICAgICAgdmFsdWU9e29uQ2hhbmdlQ29tbWl0dGVkID8gY3VycmVudFRpbWUgOiBlbmRUaW1lfVxuICAgICAgICBtaW49e3N0YXJ0VGltZX1cbiAgICAgICAgbWF4PXtlbmRUaW1lfVxuICAgICAgICBtYXJrcz17bWFya3N9XG4gICAgICAgIHsuLi5oYW5kbGVyc31cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHNsb3RzPXt7UmFpbDogU2Vla2JhclJhaWwsIFRyYWNrOiBTZWVrYmFyVHJhY2t9fVxuICAgICAgICBzbG90UHJvcHM9e3t0cmFjazoge3NlZ21lbnRzfX19XG4gICAgICAvPlxuICAgICAge3RpbWVEaXNwbGF5ICYmIDxGb3JtYXR0ZWRUaW1lIHRpbWU9e2R1cmF0aW9ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJlxuICAgICAgICBbXVxuICAgICAgICAgIC5jb25jYXQoY2hpbGRyZW4pXG4gICAgICAgICAgLm1hcChjaGlsZCA9PlxuICAgICAgICAgICAgY2xvbmVFbGVtZW50KGNoaWxkLCB7dGltZTogcG9pbnRlckFjdGl2ZSAmJiBwb2ludGVyU3RhdGUudmFsdWV9KVxuICAgICAgICAgICl9XG4gICAgPC9kaXY+XG4gIClcbn1cblxuZXhwb3J0IGRlZmF1bHQgU2Vla2JhclxuIl19 */"],
4314
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Seekbar;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlZWtiYXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMktRIiwiZmlsZSI6IlNlZWtiYXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZVJlZHVjZXIsIHVzZVJlZiwgY2xvbmVFbGVtZW50fSBmcm9tICdyZWFjdCdcbmltcG9ydCB1c2VEaW1lbnNpb25zIGZyb20gJ3JlYWN0LWNvb2wtZGltZW5zaW9ucydcbmltcG9ydCBTaW1wbGVTbGlkZXIgZnJvbSAncGxheWVyVWkvU2ltcGxlU2xpZGVyJ1xuaW1wb3J0IHtGb3JtYXR0ZWRUaW1lfSBmcm9tICdjb250ZXh0L0kxOG4nXG5pbXBvcnQge2dldFRpbWVsaW5lU2VnbWVudHN9IGZyb20gJ3ByZW1pdW0vdGltZWxpbmUnXG5cbmNvbnN0IHNlZWtiYXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIG1pbldpZHRoOiAnMCcsXG4gIGhlaWdodDogJzI0cHgnLFxuICBmb250U2l6ZTogJzc1JScsXG4gIGxldHRlclNwYWNpbmc6ICcxcHgnLFxuICBjb2xvcjogJyNmZmYnLFxufVxuXG5jb25zdCBzbGlkZXJTdHlsZSA9IHtcbiAgbWluV2lkdGg6ICcwJyxcbiAgZmxleDogMSxcbiAgJ0BtZWRpYSAoaG92ZXI6IGhvdmVyKSwgc2NyZWVuIGFuZCAoLW1zLWhpZ2gtY29udHJhc3Q6IGFjdGl2ZSksICgtbXMtaGlnaC1jb250cmFzdDogbm9uZSknOlxuICAgIHtcbiAgICAgICc+IGRpdjpsYXN0LW9mLXR5cGUnOiB7XG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZS1vdXQnLFxuICAgICAgfSxcbiAgICB9LFxuICAnPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIHdpZHRoOiAnMS4yZW0nLFxuICAgIGhlaWdodDogJzEuMmVtJyxcbiAgfSxcbiAgJyY6aG92ZXIgPiBkaXY6bGFzdC1vZi10eXBlJzoge1xuICAgIG9wYWNpdHk6IDEsXG4gIH0sXG59XG5cbmNvbnN0IHJlZHVjZVBvaW50ZXIgPSAoc3RhdGUsIHt0eXBlLCB2YWx1ZSwgeH0pID0+IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnbW92ZSc6XG4gICAgICByZXR1cm4gey4uLnN0YXRlLCBob3ZlcjogdHJ1ZSwgdmFsdWUsIHh9XG4gICAgY2FzZSAnY2hhbmdlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGZvY3VzZWQ6IHRydWUsIHZhbHVlfVxuICAgIGNhc2UgJ3JlbGVhc2UnOlxuICAgICAgcmV0dXJuIHsuLi5zdGF0ZSwgZm9jdXNlZDogZmFsc2UsIHZhbHVlfVxuICAgIGNhc2UgJ2xlYXZlJzpcbiAgICAgIHJldHVybiB7Li4uc3RhdGUsIGhvdmVyOiBmYWxzZX1cbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHN0YXRlXG4gIH1cbn1cblxuY29uc3QgU2Vla2JhclJhaWwgPSAoKSA9PiAnJ1xuXG5jb25zdCBzZWdtZW50ZWRUcmFja1N0eWxlID0ge1xuICBib3hTaXppbmc6ICdib3JkZXItYm94JyxcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gIG1hcmdpbjogJzAgMnB4JyxcbiAgaGVpZ2h0OiAnMjRweCcsXG4gIGJvcmRlclRvcDogJ2NhbGMoMTJweCAtIDAuM2VtKSBzb2xpZCB0cmFuc3BhcmVudCcsXG4gIGJvcmRlckJvdHRvbTogJ2NhbGMoMTJweCAtIDAuM2VtKSBzb2xpZCB0cmFuc3BhcmVudCcsXG4gIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICcmOmhvdmVyJzoge1xuICAgIHRyYW5zZm9ybTogJ3NjYWxlKDEsIDEuNSknLFxuICB9LFxuICAnPiBkaXYnOiB7XG4gICAgaGVpZ2h0OiAnMC42ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC4yKScsXG4gICAgJyY6bm90KDpmaXJzdC1vZi10eXBlKSc6IHtcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgdG9wOiAnMCcsXG4gICAgfSxcbiAgfSxcbiAgJz4gZGl2Om50aC1vZi10eXBlKDIpJzoge1xuICAgIGJhY2tncm91bmRDb2xvcjogJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC4zKScsXG4gIH0sXG4gICc+IGRpdjpudGgtb2YtdHlwZSgzKSc6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6ICd2YXIoLS10aGVtZS1jb2xvciwgcmVkKScsXG4gIH0sXG59XG5cbmNvbnN0IFNlZWtiYXJUcmFjayA9ICh7c2VnbWVudHMsIHN0eWxlfSkgPT5cbiAgc2VnbWVudHMubWFwKCh7bGVuZ3RoLCBjdXJyZW50LCBidWZmZXJlZH0pID0+IChcbiAgICA8ZGl2XG4gICAgICBjc3M9e1tzdHlsZSwgc2VnbWVudGVkVHJhY2tTdHlsZV19XG4gICAgICBzdHlsZT17e1xuICAgICAgICBmbGV4OiBgMCAke2xlbmd0aCAqIDEwMH0lYCxcbiAgICAgICAgd2lkdGg6IGBjYWxjKCR7bGVuZ3RoICogMTAwfSUgLSA0cHgpYCxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiAnMTAwJSd9fSAvPlxuICAgICAgPGRpdiBzdHlsZT17e3dpZHRoOiBgJHtidWZmZXJlZCAqIDEwMH0lYH19IC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7d2lkdGg6IGAke2N1cnJlbnQgKiAxMDB9JWB9fSAvPlxuICAgIDwvZGl2PlxuICApKVxuXG4vLyBUT0RPIHVzZSBjbGFzc05hbWUgaW5zdGVhZCBvZiBjbGFzc2VzID9cbmNvbnN0IFNlZWtiYXIgPSAoe1xuICBzdHlsZSxcbiAgY2xhc3NlcyxcbiAgc3RhcnRUaW1lID0gMCxcbiAgY3VycmVudFRpbWUsXG4gIGJ1ZmZlclRpbWUsXG4gIGR1cmF0aW9uLFxuICBjaGFwdGVycyA9IFtdLFxuICBtYXJrcyxcbiAgdGltZURpc3BsYXkgPSBmYWxzZSwgLy8gVE9ETyBtb3JlIHNjYWxhYmxlIHdheT9cbiAgb25DaGFuZ2UsXG4gIG9uQ2hhbmdlQ29tbWl0dGVkLFxuICBjaGlsZHJlbixcbiAgb25Qb2ludGVyTW92ZSxcbiAgb25Qb2ludGVyTGVhdmUsXG4gIC4uLnJlc3Rcbn0pID0+IHtcbiAgY29uc3QgW3BvaW50ZXJTdGF0ZSwgZGlzcGF0Y2hQb2ludGVyXSA9IHVzZVJlZHVjZXIocmVkdWNlUG9pbnRlciwge30pXG4gIGNvbnN0IHBvaW50ZXJBY3RpdmUgPSBwb2ludGVyU3RhdGUuaG92ZXIgfHwgcG9pbnRlclN0YXRlLmZvY3VzZWRcbiAgLy8gdG8gcmVmbGVjdCBib3VuZGFyeSB3aGVuIGNvbnRhaW5lciByZXNpemVkXG4gIGNvbnN0IHtvYnNlcnZlfSA9IHVzZURpbWVuc2lvbnMoKVxuICBjb25zdCByZWYgPSB1c2VSZWYoKVxuICBjb25zdCByZWN0ID0gcmVmLmN1cnJlbnQ/LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpXG4gIGNvbnN0IGhhbmRsZXJzID0gb25DaGFuZ2VDb21taXR0ZWQgJiYge1xuICAgIG9uUG9pbnRlck1vdmU6IChldmVudCwge3ZhbHVlLCB4fSkgPT4ge1xuICAgICAgb25Qb2ludGVyTW92ZT8uKGV2ZW50LCB7dmFsdWUsIHh9KVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnbW92ZScsIHZhbHVlLCB4fSlcbiAgICB9LFxuICAgIG9uUG9pbnRlckxlYXZlOiBldmVudCA9PiB7XG4gICAgICBvblBvaW50ZXJMZWF2ZT8uKGV2ZW50KVxuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAnbGVhdmUnfSlcbiAgICB9LFxuICAgIG9uQ2hhbmdlOiAoXywge3ZhbHVlfSkgPT4ge1xuICAgICAgb25DaGFuZ2U/Lih2YWx1ZSlcbiAgICAgIGRpc3BhdGNoUG9pbnRlcih7dHlwZTogJ2NoYW5nZScsIHZhbHVlfSlcbiAgICB9LFxuICAgIG9uQ2hhbmdlQ29tbWl0dGVkOiAoXywge3ZhbHVlfSkgPT4ge1xuICAgICAgZGlzcGF0Y2hQb2ludGVyKHt0eXBlOiAncmVsZWFzZScsIHZhbHVlfSlcbiAgICAgIG9uQ2hhbmdlQ29tbWl0dGVkPy4odmFsdWUpXG4gICAgfSxcbiAgfVxuICBjb25zdCBlbmRUaW1lID0gc3RhcnRUaW1lICsgZHVyYXRpb25cbiAgY29uc3Qgc2VnbWVudHMgPSBnZXRUaW1lbGluZVNlZ21lbnRzKGNoYXB0ZXJzLCB7XG4gICAgc3RhcnRUaW1lLFxuICAgIGN1cnJlbnQ6IHBvaW50ZXJTdGF0ZS5mb2N1c2VkID8gcG9pbnRlclN0YXRlLnZhbHVlIDogY3VycmVudFRpbWUsXG4gICAgYnVmZmVyZWQ6IGJ1ZmZlclRpbWUsXG4gICAgZHVyYXRpb24sXG4gIH0pXG5cbiAgcmV0dXJuICEoZHVyYXRpb24gPiAwKSA/IChcbiAgICA8ZGl2IC8+XG4gICkgOiAoXG4gICAgPGRpdlxuICAgICAgcmVmPXtlbGVtZW50ID0+IHtcbiAgICAgICAgb2JzZXJ2ZShlbGVtZW50KVxuICAgICAgICByZWYuY3VycmVudCA9IGVsZW1lbnRcbiAgICAgIH19XG4gICAgICBjc3M9e1tzZWVrYmFyU3R5bGUsIHN0eWxlXX1cbiAgICAgIHN0eWxlPXtcbiAgICAgICAgcmVjdCAmJiB7XG4gICAgICAgICAgJy0tc2Vla2Jhci1sZWZ0JzogYCR7cmVjdC5sZWZ0fXB4YCxcbiAgICAgICAgICAnLS1zZWVrYmFyLXJpZ2h0JzogYCR7cmVjdC5yaWdodH1weGAsXG4gICAgICAgICAgJy0tcG9pbnRlci14JzogYCR7cG9pbnRlclN0YXRlLnh9cHhgLFxuICAgICAgICB9XG4gICAgICB9XG4gICAgPlxuICAgICAgeyF0aW1lRGlzcGxheSA/IChcbiAgICAgICAgJydcbiAgICAgICkgOiBwb2ludGVyQWN0aXZlID8gKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtwb2ludGVyU3RhdGUudmFsdWV9IC8+XG4gICAgICApIDogKFxuICAgICAgICA8Rm9ybWF0dGVkVGltZSB0aW1lPXtNYXRoLm1pbihNYXRoLm1heCgwLCBjdXJyZW50VGltZSksIGR1cmF0aW9uKX0gLz5cbiAgICAgICl9XG4gICAgICA8U2ltcGxlU2xpZGVyXG4gICAgICAgIGNzcz17W3NsaWRlclN0eWxlLCB0aW1lRGlzcGxheSAmJiB7bWFyZ2luOiAnMCAxZW0nfV19XG4gICAgICAgIGNsYXNzZXM9e2NsYXNzZXN9XG4gICAgICAgIGRpc2FibGVkPXshb25DaGFuZ2VDb21taXR0ZWR9XG4gICAgICAgIC8vIGRpc3BsYXkgZmlsbGVkIHdoZW4gc2VlayBoYW5kbGVyIGlzIG5vdCBwcm92aWRlZCwgZnJvbSBQbGF5Qm95IGJlaGF2aW9yXG4gICAgICAgIHZhbHVlPXtvbkNoYW5nZUNvbW1pdHRlZCA/IGN1cnJlbnRUaW1lIDogZW5kVGltZX1cbiAgICAgICAgbWluPXtzdGFydFRpbWV9XG4gICAgICAgIG1heD17ZW5kVGltZX1cbiAgICAgICAgbWFya3M9e21hcmtzfVxuICAgICAgICB7Li4uaGFuZGxlcnN9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgICBzbG90cz17e1JhaWw6IFNlZWtiYXJSYWlsLCBUcmFjazogU2Vla2JhclRyYWNrfX1cbiAgICAgICAgc2xvdFByb3BzPXt7dHJhY2s6IHtzZWdtZW50c319fVxuICAgICAgLz5cbiAgICAgIHt0aW1lRGlzcGxheSAmJiA8Rm9ybWF0dGVkVGltZSB0aW1lPXtkdXJhdGlvbn0gLz59XG4gICAgICB7Y2hpbGRyZW4gJiZcbiAgICAgICAgW11cbiAgICAgICAgICAuY29uY2F0KGNoaWxkcmVuKVxuICAgICAgICAgIC5tYXAoY2hpbGQgPT5cbiAgICAgICAgICAgIGNsb25lRWxlbWVudChjaGlsZCwge3RpbWU6IHBvaW50ZXJBY3RpdmUgJiYgcG9pbnRlclN0YXRlLnZhbHVlfSlcbiAgICAgICAgICApfVxuICAgIDwvZGl2PlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IFNlZWtiYXJcbiJdfQ== */"],
4320
4315
  classes: classes,
4321
4316
  disabled: !onChangeCommitted // display filled when seek handler is not provided, from PlayBoy behavior
4322
4317
  ,
@@ -4876,12 +4871,12 @@ const containerStyle$3 = {
4876
4871
  height: '100%',
4877
4872
  transform: 'translateY(-150vh)',
4878
4873
  opacity: '0',
4879
- transition: 'opacity 0.5s ease, transform 0s 0.5s linear'
4874
+ transition: 'opacity 0.1s ease, transform 0s linear 0.1s'
4880
4875
  };
4881
4876
  const openStyle$1 = {
4882
4877
  transform: 'translateY(0)',
4883
4878
  opacity: '1',
4884
- transition: 'opacity 0.5s ease'
4879
+ transition: 'opacity 0.2s ease, transform 0s'
4885
4880
  };
4886
4881
 
4887
4882
  const DefaultContainer = ({
@@ -4889,7 +4884,7 @@ const DefaultContainer = ({
4889
4884
  containerRef,
4890
4885
  children
4891
4886
  }) => jsx$1("div", {
4892
- css: [containerStyle$3, open && openStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:DefaultContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QkkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC41cyBlYXNlLCB0cmFuc2Zvcm0gMHMgMC41cyBsaW5lYXInLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5cbmNvbnN0IERlZmF1bHRDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW59KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tjb250YWluZXJTdHlsZSwgb3BlbiAmJiBvcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAnMicsXG4gIGJvdHRvbTogJ2NhbGMoM2VtICsgdmFyKC0tYm90dG9tLXNwYWNpbmcsIDByZW0pKScsXG4gIHJpZ2h0OiAnY2FsYyh2YXIoLS1zcGFjaW5nLCAwLjc1ZW0pICsgMC41ZW0gKyAwLjVyZW0pJyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgb3V0bGluZTogJ25vbmUnLFxuICBvcGFjaXR5OiAnMCcsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTEwMHZoKScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzIGxpbmVhciAwLjJzJyxcbn1cblxuY29uc3QgRGVza3RvcE9wZW5TdHlsZSA9IHtcbiAgb3BhY2l0eTogJzEnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKDApJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4ycyBlYXNlLCB0cmFuc2Zvcm0gMHMnLFxufVxuXG5jb25zdCBEZXNrdG9wQ29udGFpbmVyID0gKHtvcGVuLCBjb250YWluZXJSZWYsIGNoaWxkcmVuLCBvbkNsb3NlLCAuLi5yZXN0fSkgPT4gKFxuICA8ZGl2XG4gICAgY3NzPXtbZGVza3RvcENvbnRhaW5lclN0eWxlLCBvcGVuICYmIERlc2t0b3BPcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICAgIHsuLi5yZXN0fVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgT3ZlcmxheVBhbmVsID0gKHtcbiAgYnV0dG9uSWNvbixcbiAgdGl0bGUsXG4gIHVpVHlwZSA9IGlzRGVza3RvcCgpID8gJ2Rlc2t0b3AnIDogJ21vYmlsZScsXG4gIGNoaWxkcmVuLFxuICBzbG90cyA9IHtcbiAgICByb290OiB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IERlc2t0b3BDb250YWluZXIgOiBEZWZhdWx0Q29udGFpbmVyLFxuICB9LFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IGNvbXBvbmVudHMgPSB7XG4gICAgcm9vdDogc2xvdHMucm9vdCxcbiAgfVxuICBjb25zdCBCdXR0b25XcmFwID1cbiAgICB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IEZ1bmN0aW9uQmFyRXh0ZW5zaW9uIDogVGl0bGVCYXJFeHRlbnNpb25cbiAgY29uc3QgW29wZW4sIHNldE9wZW5dID0gdXNlU3RhdGUoZmFsc2UpXG4gIGNvbnN0IG9uT3BlbiA9IGV2ZW50ID0+IHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHNldE9wZW4odHJ1ZSksIDEpXG4gICAgZXZlbnQuY3VycmVudFRhcmdldC5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KCdmb2N1cy1tZW51Jywge2RldGFpbDoge3N0YXR1czogJ29wZW4nfSwgYnViYmxlczogdHJ1ZX0pXG4gICAgKVxuICB9XG4gIGNvbnN0IGNvbnRhaW5lclJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IG9uQ2xvc2UgPSAoKSA9PiB7XG4gICAgc2V0T3BlbihmYWxzZSlcbiAgICBjb250YWluZXJSZWYuY3VycmVudC5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KCdmb2N1cy1tZW51Jywge2RldGFpbDoge3N0YXR1czogJ2Nsb3NlZCd9LCBidWJibGVzOiB0cnVlfSlcbiAgICApXG4gIH1cbiAgY29uc3QgcmVmID0gdXNlT25jbGlja091dHNpZGUoXG4gICAgKCkgPT4ge1xuICAgICAgaWYgKG9wZW4gJiYgdWlUeXBlID09PSAnZGVza3RvcCcpIHtcbiAgICAgICAgb25DbG9zZSgpXG4gICAgICB9XG4gICAgfSxcbiAgICB7ZXZlbnRUeXBlczogWydjbGljayddfVxuICApXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmVmKGNvbnRhaW5lclJlZi5jdXJyZW50KVxuICAgIHJldHVybiBvbihjb250YWluZXJSZWYuY3VycmVudCwgJ2Nsb3NlLW1lbnUnLCBvbkNsb3NlKVxuICB9LCBbXSlcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8QnV0dG9uV3JhcCBwb3NpdGlvbj1cInJpZ2h0XCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICB0aXRsZT17dGl0bGV9XG4gICAgICAgICAgc3RhcnRJY29uPXtidXR0b25JY29ufVxuICAgICAgICAgIG9uQ2xpY2s9e29wZW4gPyB1bmRlZmluZWQgOiBvbk9wZW59XG4gICAgICAgIC8+XG4gICAgICA8L0J1dHRvbldyYXA+XG4gICAgICA8Y29tcG9uZW50cy5yb290IGNvbnRhaW5lclJlZj17Y29udGFpbmVyUmVmfSBvcGVuPXtvcGVufSB7Li4ucmVzdH0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvY29tcG9uZW50cy5yb290PlxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IE92ZXJsYXlQYW5lbFxuIl19 */"],
4887
+ css: [containerStyle$3, open && openStyle$1, process.env.NODE_ENV === "production" ? "" : ";label:DefaultContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QkkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4xcyBlYXNlLCB0cmFuc2Zvcm0gMHMgbGluZWFyIDAuMXMnLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzJyxcbn1cblxuY29uc3QgRGVmYXVsdENvbnRhaW5lciA9ICh7b3BlbiwgY29udGFpbmVyUmVmLCBjaGlsZHJlbn0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W2NvbnRhaW5lclN0eWxlLCBvcGVuICYmIG9wZW5TdHlsZV19XG4gICAgcmVmPXtjb250YWluZXJSZWZ9XG4gICAgb25DbGljaz17ZXZlbnQgPT4gZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCl9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5jb25zdCBkZXNrdG9wQ29udGFpbmVyU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICB6SW5kZXg6ICcyJyxcbiAgYm90dG9tOiAnY2FsYygzZW0gKyB2YXIoLS1ib3R0b20tc3BhY2luZywgMHJlbSkpJyxcbiAgcmlnaHQ6ICdjYWxjKHZhcigtLXNwYWNpbmcsIDAuNzVlbSkgKyAwLjVlbSArIDAuNXJlbSknLFxuICBiYWNrZ3JvdW5kOiAndHJhbnNwYXJlbnQnLFxuICBvdXRsaW5lOiAnbm9uZScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSgtMTAwdmgpJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4xcyBlYXNlLCB0cmFuc2Zvcm0gMHMgbGluZWFyIDAuMXMnLFxufVxuXG5jb25zdCBEZXNrdG9wT3BlblN0eWxlID0ge1xuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcycsXG59XG5cbmNvbnN0IERlc2t0b3BDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW4sIG9uQ2xvc2UsIC4uLnJlc3R9KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tkZXNrdG9wQ29udGFpbmVyU3R5bGUsIG9wZW4gJiYgRGVza3RvcE9wZW5TdHlsZV19XG4gICAgcmVmPXtjb250YWluZXJSZWZ9XG4gICAgb25DbGljaz17ZXZlbnQgPT4gZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCl9XG4gICAgey4uLnJlc3R9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5jb25zdCBPdmVybGF5UGFuZWwgPSAoe1xuICBidXR0b25JY29uLFxuICB0aXRsZSxcbiAgdWlUeXBlID0gaXNEZXNrdG9wKCkgPyAnZGVza3RvcCcgOiAnbW9iaWxlJyxcbiAgY2hpbGRyZW4sXG4gIHNsb3RzID0ge1xuICAgIHJvb3Q6IHVpVHlwZSA9PT0gJ2Rlc2t0b3AnID8gRGVza3RvcENvbnRhaW5lciA6IERlZmF1bHRDb250YWluZXIsXG4gIH0sXG4gIC4uLnJlc3Rcbn0pID0+IHtcbiAgY29uc3QgY29tcG9uZW50cyA9IHtcbiAgICByb290OiBzbG90cy5yb290LFxuICB9XG4gIGNvbnN0IEJ1dHRvbldyYXAgPVxuICAgIHVpVHlwZSA9PT0gJ2Rlc2t0b3AnID8gRnVuY3Rpb25CYXJFeHRlbnNpb24gOiBUaXRsZUJhckV4dGVuc2lvblxuICBjb25zdCBbb3Blbiwgc2V0T3Blbl0gPSB1c2VTdGF0ZShmYWxzZSlcbiAgY29uc3Qgb25PcGVuID0gZXZlbnQgPT4ge1xuICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0T3Blbih0cnVlKSwgMSlcbiAgICBjb25zdCBjb250YWluZXIgPSBldmVudC5jdXJyZW50VGFyZ2V0XG4gICAgY29uc3QgY2xvc2VNZW51ID0gKCkgPT4gc2V0T3BlbihmYWxzZSlcbiAgICBjb250YWluZXIuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudCgnZm9jdXMtbWVudScsIHtcbiAgICAgICAgZGV0YWlsOiB7c3RhdHVzOiAnb3BlbicsIGNsb3NlTWVudX0sXG4gICAgICAgIGJ1YmJsZXM6IHRydWUsXG4gICAgICB9KVxuICAgIClcbiAgfVxuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWYoKVxuICBjb25zdCBvbkNsb3NlID0gKCkgPT4ge1xuICAgIHNldE9wZW4oZmFsc2UpXG4gICAgY29udGFpbmVyUmVmLmN1cnJlbnQuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudCgnZm9jdXMtbWVudScsIHtkZXRhaWw6IHtzdGF0dXM6ICdjbG9zZWQnfSwgYnViYmxlczogdHJ1ZX0pXG4gICAgKVxuICB9XG4gIGNvbnN0IHJlZiA9IHVzZU9uY2xpY2tPdXRzaWRlKFxuICAgICgpID0+IHtcbiAgICAgIGlmIChvcGVuICYmIHVpVHlwZSA9PT0gJ2Rlc2t0b3AnKSB7XG4gICAgICAgIG9uQ2xvc2UoKVxuICAgICAgfVxuICAgIH0sXG4gICAge2V2ZW50VHlwZXM6IFsnY2xpY2snXX1cbiAgKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIHJlZihjb250YWluZXJSZWYuY3VycmVudClcbiAgICByZXR1cm4gb24oY29udGFpbmVyUmVmLmN1cnJlbnQsICdjbG9zZS1tZW51Jywgb25DbG9zZSlcbiAgfSwgW10pXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPEJ1dHRvbldyYXAgcG9zaXRpb249XCJyaWdodFwiPlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgdGl0bGU9e3RpdGxlfVxuICAgICAgICAgIHN0YXJ0SWNvbj17YnV0dG9uSWNvbn1cbiAgICAgICAgICBvbkNsaWNrPXtvcGVuID8gdW5kZWZpbmVkIDogb25PcGVufVxuICAgICAgICAvPlxuICAgICAgPC9CdXR0b25XcmFwPlxuICAgICAgPGNvbXBvbmVudHMucm9vdCBjb250YWluZXJSZWY9e2NvbnRhaW5lclJlZn0gb3Blbj17b3Blbn0gey4uLnJlc3R9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L2NvbXBvbmVudHMucm9vdD5cbiAgICA8Lz5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBPdmVybGF5UGFuZWxcbiJdfQ== */"],
4893
4888
  ref: containerRef,
4894
4889
  onClick: event => event.stopPropagation(),
4895
4890
  children: children
@@ -4904,7 +4899,7 @@ const desktopContainerStyle$1 = {
4904
4899
  outline: 'none',
4905
4900
  opacity: '0',
4906
4901
  transform: 'translateY(-100vh)',
4907
- transition: 'opacity 0.2s ease, transform 0s linear 0.2s'
4902
+ transition: 'opacity 0.1s ease, transform 0s linear 0.1s'
4908
4903
  };
4909
4904
  const DesktopOpenStyle = {
4910
4905
  opacity: '1',
@@ -4919,7 +4914,7 @@ const DesktopContainer = ({
4919
4914
  onClose,
4920
4915
  ...rest
4921
4916
  }) => jsx$1("div", {
4922
- css: [desktopContainerStyle$1, open && DesktopOpenStyle, process.env.NODE_ENV === "production" ? "" : ";label:DesktopContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3REkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC41cyBlYXNlLCB0cmFuc2Zvcm0gMHMgMC41cyBsaW5lYXInLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuNXMgZWFzZScsXG59XG5cbmNvbnN0IERlZmF1bHRDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW59KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tjb250YWluZXJTdHlsZSwgb3BlbiAmJiBvcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgZGVza3RvcENvbnRhaW5lclN0eWxlID0ge1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgekluZGV4OiAnMicsXG4gIGJvdHRvbTogJ2NhbGMoM2VtICsgdmFyKC0tYm90dG9tLXNwYWNpbmcsIDByZW0pKScsXG4gIHJpZ2h0OiAnY2FsYyh2YXIoLS1zcGFjaW5nLCAwLjc1ZW0pICsgMC41ZW0gKyAwLjVyZW0pJyxcbiAgYmFja2dyb3VuZDogJ3RyYW5zcGFyZW50JyxcbiAgb3V0bGluZTogJ25vbmUnLFxuICBvcGFjaXR5OiAnMCcsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTEwMHZoKScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzIGxpbmVhciAwLjJzJyxcbn1cblxuY29uc3QgRGVza3RvcE9wZW5TdHlsZSA9IHtcbiAgb3BhY2l0eTogJzEnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKDApJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4ycyBlYXNlLCB0cmFuc2Zvcm0gMHMnLFxufVxuXG5jb25zdCBEZXNrdG9wQ29udGFpbmVyID0gKHtvcGVuLCBjb250YWluZXJSZWYsIGNoaWxkcmVuLCBvbkNsb3NlLCAuLi5yZXN0fSkgPT4gKFxuICA8ZGl2XG4gICAgY3NzPXtbZGVza3RvcENvbnRhaW5lclN0eWxlLCBvcGVuICYmIERlc2t0b3BPcGVuU3R5bGVdfVxuICAgIHJlZj17Y29udGFpbmVyUmVmfVxuICAgIG9uQ2xpY2s9e2V2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpfVxuICAgIHsuLi5yZXN0fVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuY29uc3QgT3ZlcmxheVBhbmVsID0gKHtcbiAgYnV0dG9uSWNvbixcbiAgdGl0bGUsXG4gIHVpVHlwZSA9IGlzRGVza3RvcCgpID8gJ2Rlc2t0b3AnIDogJ21vYmlsZScsXG4gIGNoaWxkcmVuLFxuICBzbG90cyA9IHtcbiAgICByb290OiB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IERlc2t0b3BDb250YWluZXIgOiBEZWZhdWx0Q29udGFpbmVyLFxuICB9LFxuICAuLi5yZXN0XG59KSA9PiB7XG4gIGNvbnN0IGNvbXBvbmVudHMgPSB7XG4gICAgcm9vdDogc2xvdHMucm9vdCxcbiAgfVxuICBjb25zdCBCdXR0b25XcmFwID1cbiAgICB1aVR5cGUgPT09ICdkZXNrdG9wJyA/IEZ1bmN0aW9uQmFyRXh0ZW5zaW9uIDogVGl0bGVCYXJFeHRlbnNpb25cbiAgY29uc3QgW29wZW4sIHNldE9wZW5dID0gdXNlU3RhdGUoZmFsc2UpXG4gIGNvbnN0IG9uT3BlbiA9IGV2ZW50ID0+IHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHNldE9wZW4odHJ1ZSksIDEpXG4gICAgZXZlbnQuY3VycmVudFRhcmdldC5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KCdmb2N1cy1tZW51Jywge2RldGFpbDoge3N0YXR1czogJ29wZW4nfSwgYnViYmxlczogdHJ1ZX0pXG4gICAgKVxuICB9XG4gIGNvbnN0IGNvbnRhaW5lclJlZiA9IHVzZVJlZigpXG4gIGNvbnN0IG9uQ2xvc2UgPSAoKSA9PiB7XG4gICAgc2V0T3BlbihmYWxzZSlcbiAgICBjb250YWluZXJSZWYuY3VycmVudC5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KCdmb2N1cy1tZW51Jywge2RldGFpbDoge3N0YXR1czogJ2Nsb3NlZCd9LCBidWJibGVzOiB0cnVlfSlcbiAgICApXG4gIH1cbiAgY29uc3QgcmVmID0gdXNlT25jbGlja091dHNpZGUoXG4gICAgKCkgPT4ge1xuICAgICAgaWYgKG9wZW4gJiYgdWlUeXBlID09PSAnZGVza3RvcCcpIHtcbiAgICAgICAgb25DbG9zZSgpXG4gICAgICB9XG4gICAgfSxcbiAgICB7ZXZlbnRUeXBlczogWydjbGljayddfVxuICApXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmVmKGNvbnRhaW5lclJlZi5jdXJyZW50KVxuICAgIHJldHVybiBvbihjb250YWluZXJSZWYuY3VycmVudCwgJ2Nsb3NlLW1lbnUnLCBvbkNsb3NlKVxuICB9LCBbXSlcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8QnV0dG9uV3JhcCBwb3NpdGlvbj1cInJpZ2h0XCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICB0aXRsZT17dGl0bGV9XG4gICAgICAgICAgc3RhcnRJY29uPXtidXR0b25JY29ufVxuICAgICAgICAgIG9uQ2xpY2s9e29wZW4gPyB1bmRlZmluZWQgOiBvbk9wZW59XG4gICAgICAgIC8+XG4gICAgICA8L0J1dHRvbldyYXA+XG4gICAgICA8Y29tcG9uZW50cy5yb290IGNvbnRhaW5lclJlZj17Y29udGFpbmVyUmVmfSBvcGVuPXtvcGVufSB7Li4ucmVzdH0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvY29tcG9uZW50cy5yb290PlxuICAgIDwvPlxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IE92ZXJsYXlQYW5lbFxuIl19 */"],
4917
+ css: [desktopContainerStyle$1, open && DesktopOpenStyle, process.env.NODE_ENV === "production" ? "" : ";label:DesktopContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk92ZXJsYXlQYW5lbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3REkiLCJmaWxlIjoiT3ZlcmxheVBhbmVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUganN4LWExMXkvbm8tc3RhdGljLWVsZW1lbnQtaW50ZXJhY3Rpb25zICovXG4vKiBAanN4SW1wb3J0U291cmNlIEBlbW90aW9uL3JlYWN0ICovXG5pbXBvcnQge3VzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZX0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlT25jbGlja091dHNpZGUgZnJvbSAncmVhY3QtY29vbC1vbmNsaWNrb3V0c2lkZSdcbmltcG9ydCB7b259IGZyb20gJ3V0aWwvZXZlbnRzJ1xuaW1wb3J0IHtpc0Rlc2t0b3B9IGZyb20gJ3V0aWwvZW52aXJvbm1lbnQnXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnLi9idXR0b25zJ1xuaW1wb3J0IHtGdW5jdGlvbkJhckV4dGVuc2lvbiwgVGl0bGVCYXJFeHRlbnNpb259IGZyb20gJy4vdWlFeHRlbnNpb25zJ1xuXG5jb25zdCBjb250YWluZXJTdHlsZSA9IHtcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gIHpJbmRleDogJzInLFxuICB0b3A6ICcwJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgaGVpZ2h0OiAnMTAwJScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoLTE1MHZoKScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4xcyBlYXNlLCB0cmFuc2Zvcm0gMHMgbGluZWFyIDAuMXMnLFxufVxuXG5jb25zdCBvcGVuU3R5bGUgPSB7XG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zaXRpb246ICdvcGFjaXR5IDAuMnMgZWFzZSwgdHJhbnNmb3JtIDBzJyxcbn1cblxuY29uc3QgRGVmYXVsdENvbnRhaW5lciA9ICh7b3BlbiwgY29udGFpbmVyUmVmLCBjaGlsZHJlbn0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W2NvbnRhaW5lclN0eWxlLCBvcGVuICYmIG9wZW5TdHlsZV19XG4gICAgcmVmPXtjb250YWluZXJSZWZ9XG4gICAgb25DbGljaz17ZXZlbnQgPT4gZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCl9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5jb25zdCBkZXNrdG9wQ29udGFpbmVyU3R5bGUgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICB6SW5kZXg6ICcyJyxcbiAgYm90dG9tOiAnY2FsYygzZW0gKyB2YXIoLS1ib3R0b20tc3BhY2luZywgMHJlbSkpJyxcbiAgcmlnaHQ6ICdjYWxjKHZhcigtLXNwYWNpbmcsIDAuNzVlbSkgKyAwLjVlbSArIDAuNXJlbSknLFxuICBiYWNrZ3JvdW5kOiAndHJhbnNwYXJlbnQnLFxuICBvdXRsaW5lOiAnbm9uZScsXG4gIG9wYWNpdHk6ICcwJyxcbiAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSgtMTAwdmgpJyxcbiAgdHJhbnNpdGlvbjogJ29wYWNpdHkgMC4xcyBlYXNlLCB0cmFuc2Zvcm0gMHMgbGluZWFyIDAuMXMnLFxufVxuXG5jb25zdCBEZXNrdG9wT3BlblN0eWxlID0ge1xuICBvcGFjaXR5OiAnMScsXG4gIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVkoMCknLFxuICB0cmFuc2l0aW9uOiAnb3BhY2l0eSAwLjJzIGVhc2UsIHRyYW5zZm9ybSAwcycsXG59XG5cbmNvbnN0IERlc2t0b3BDb250YWluZXIgPSAoe29wZW4sIGNvbnRhaW5lclJlZiwgY2hpbGRyZW4sIG9uQ2xvc2UsIC4uLnJlc3R9KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e1tkZXNrdG9wQ29udGFpbmVyU3R5bGUsIG9wZW4gJiYgRGVza3RvcE9wZW5TdHlsZV19XG4gICAgcmVmPXtjb250YWluZXJSZWZ9XG4gICAgb25DbGljaz17ZXZlbnQgPT4gZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCl9XG4gICAgey4uLnJlc3R9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvZGl2PlxuKVxuXG5jb25zdCBPdmVybGF5UGFuZWwgPSAoe1xuICBidXR0b25JY29uLFxuICB0aXRsZSxcbiAgdWlUeXBlID0gaXNEZXNrdG9wKCkgPyAnZGVza3RvcCcgOiAnbW9iaWxlJyxcbiAgY2hpbGRyZW4sXG4gIHNsb3RzID0ge1xuICAgIHJvb3Q6IHVpVHlwZSA9PT0gJ2Rlc2t0b3AnID8gRGVza3RvcENvbnRhaW5lciA6IERlZmF1bHRDb250YWluZXIsXG4gIH0sXG4gIC4uLnJlc3Rcbn0pID0+IHtcbiAgY29uc3QgY29tcG9uZW50cyA9IHtcbiAgICByb290OiBzbG90cy5yb290LFxuICB9XG4gIGNvbnN0IEJ1dHRvbldyYXAgPVxuICAgIHVpVHlwZSA9PT0gJ2Rlc2t0b3AnID8gRnVuY3Rpb25CYXJFeHRlbnNpb24gOiBUaXRsZUJhckV4dGVuc2lvblxuICBjb25zdCBbb3Blbiwgc2V0T3Blbl0gPSB1c2VTdGF0ZShmYWxzZSlcbiAgY29uc3Qgb25PcGVuID0gZXZlbnQgPT4ge1xuICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0T3Blbih0cnVlKSwgMSlcbiAgICBjb25zdCBjb250YWluZXIgPSBldmVudC5jdXJyZW50VGFyZ2V0XG4gICAgY29uc3QgY2xvc2VNZW51ID0gKCkgPT4gc2V0T3BlbihmYWxzZSlcbiAgICBjb250YWluZXIuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudCgnZm9jdXMtbWVudScsIHtcbiAgICAgICAgZGV0YWlsOiB7c3RhdHVzOiAnb3BlbicsIGNsb3NlTWVudX0sXG4gICAgICAgIGJ1YmJsZXM6IHRydWUsXG4gICAgICB9KVxuICAgIClcbiAgfVxuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWYoKVxuICBjb25zdCBvbkNsb3NlID0gKCkgPT4ge1xuICAgIHNldE9wZW4oZmFsc2UpXG4gICAgY29udGFpbmVyUmVmLmN1cnJlbnQuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudCgnZm9jdXMtbWVudScsIHtkZXRhaWw6IHtzdGF0dXM6ICdjbG9zZWQnfSwgYnViYmxlczogdHJ1ZX0pXG4gICAgKVxuICB9XG4gIGNvbnN0IHJlZiA9IHVzZU9uY2xpY2tPdXRzaWRlKFxuICAgICgpID0+IHtcbiAgICAgIGlmIChvcGVuICYmIHVpVHlwZSA9PT0gJ2Rlc2t0b3AnKSB7XG4gICAgICAgIG9uQ2xvc2UoKVxuICAgICAgfVxuICAgIH0sXG4gICAge2V2ZW50VHlwZXM6IFsnY2xpY2snXX1cbiAgKVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIHJlZihjb250YWluZXJSZWYuY3VycmVudClcbiAgICByZXR1cm4gb24oY29udGFpbmVyUmVmLmN1cnJlbnQsICdjbG9zZS1tZW51Jywgb25DbG9zZSlcbiAgfSwgW10pXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPEJ1dHRvbldyYXAgcG9zaXRpb249XCJyaWdodFwiPlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgdGl0bGU9e3RpdGxlfVxuICAgICAgICAgIHN0YXJ0SWNvbj17YnV0dG9uSWNvbn1cbiAgICAgICAgICBvbkNsaWNrPXtvcGVuID8gdW5kZWZpbmVkIDogb25PcGVufVxuICAgICAgICAvPlxuICAgICAgPC9CdXR0b25XcmFwPlxuICAgICAgPGNvbXBvbmVudHMucm9vdCBjb250YWluZXJSZWY9e2NvbnRhaW5lclJlZn0gb3Blbj17b3Blbn0gey4uLnJlc3R9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L2NvbXBvbmVudHMucm9vdD5cbiAgICA8Lz5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBPdmVybGF5UGFuZWxcbiJdfQ== */"],
4923
4918
  ref: containerRef,
4924
4919
  onClick: event => event.stopPropagation(),
4925
4920
  ...rest,
@@ -4944,9 +4939,14 @@ const OverlayPanel = ({
4944
4939
 
4945
4940
  const onOpen = event => {
4946
4941
  setTimeout(() => setOpen(true), 1);
4947
- event.currentTarget.dispatchEvent(new CustomEvent('focus-menu', {
4942
+ const container = event.currentTarget;
4943
+
4944
+ const closeMenu = () => setOpen(false);
4945
+
4946
+ container.dispatchEvent(new CustomEvent('focus-menu', {
4948
4947
  detail: {
4949
- status: 'open'
4948
+ status: 'open',
4949
+ closeMenu
4950
4950
  },
4951
4951
  bubbles: true
4952
4952
  }));
@@ -5000,6 +5000,7 @@ const menuItemStyle = {
5000
5000
  minWidth: 0,
5001
5001
  color: 'rgba(255, 255, 255, 0.6)',
5002
5002
  background: 'var(--menu-item-background, rgba(255, 255, 255, 0.08))',
5003
+ cursor: 'pointer',
5003
5004
  '> div': {
5004
5005
  overflow: 'hidden',
5005
5006
  whiteSpace: 'nowrap',
@@ -5026,7 +5027,7 @@ const MenuItem = ({
5026
5027
  selected,
5027
5028
  onClick
5028
5029
  }) => jsx$1("div", {
5029
- css: [menuItemStyle, selected && menuItemSelectedStyle, process.env.NODE_ENV === "production" ? "" : ";label:MenuItem;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lbnVJdGVtLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9DSSIsImZpbGUiOiJNZW51SXRlbS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuaW1wb3J0IGljb24gZnJvbSAnc3R5bGUvaWNvbidcbmltcG9ydCB7Rm9ybWF0dGVkTWVzc2FnZX0gZnJvbSAnY29udGV4dC9JMThuJ1xuXG5jb25zdCBtZW51SXRlbVN0eWxlID0ge1xuICBwYWRkaW5nOiAndmFyKC0tbWVudS1pdGVtLXBhZGRpbmcsIDAuNWVtIDFlbSkgJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgbWluV2lkdGg6IDAsXG4gIGNvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjYpJyxcbiAgYmFja2dyb3VuZDogJ3ZhcigtLW1lbnUtaXRlbS1iYWNrZ3JvdW5kLCByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMDgpKScsXG4gICc+IGRpdic6IHtcbiAgICBvdmVyZmxvdzogJ2hpZGRlbicsXG4gICAgd2hpdGVTcGFjZTogJ25vd3JhcCcsXG4gICAgdGV4dE92ZXJmbG93OiAnZWxsaXBzaXMnLFxuICB9LFxufVxuXG5jb25zdCBtZW51SXRlbVNlbGVjdGVkU3R5bGUgPSB7XG4gIGNvbG9yOiAnI0ZGRicsXG4gIGZvbnRXZWlnaHQ6ICc2MDAnLFxuICAnOjphZnRlcic6IHtcbiAgICBjb250ZW50OiAnXCIgXCInLFxuICAgIGRpc3BsYXk6ICdpbmxpbmUtYmxvY2snLFxuICAgIGZsZXg6ICcwIDAgMWVtJyxcbiAgICBoZWlnaHQ6ICcxZW0nLFxuICAgIG1hcmdpbkxlZnQ6ICcwLjVlbScsXG4gICAgYmFja2dyb3VuZENvbG9yOiAndmFyKC0tc2V0dGluZy1jaGVjay1pY29uLWNvbG9yLCAjZmZmKScsXG4gICAgbWFza1NpemU6ICdjb250YWluJyxcbiAgICBtYXNrSW1hZ2U6IGB1cmwoJHtpY29uLmNoZWNrfSlgLFxuICB9LFxufVxuXG5jb25zdCBNZW51SXRlbSA9ICh7bGFiZWwsIHNlbGVjdGVkLCBvbkNsaWNrfSkgPT4gKFxuICA8ZGl2XG4gICAgY3NzPXtbbWVudUl0ZW1TdHlsZSwgc2VsZWN0ZWQgJiYgbWVudUl0ZW1TZWxlY3RlZFN0eWxlXX1cbiAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICA+XG4gICAgPGRpdj5cbiAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlIGlkPXtgS0tTLlNFVFRJTkcuJHtsYWJlbH1gfSBkZWZhdWx0TWVzc2FnZT17bGFiZWx9IC8+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuKVxuXG5leHBvcnQgZGVmYXVsdCBNZW51SXRlbVxuIl19 */"],
5030
+ css: [menuItemStyle, selected && menuItemSelectedStyle, process.env.NODE_ENV === "production" ? "" : ";label:MenuItem;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lbnVJdGVtLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDSSIsImZpbGUiOiJNZW51SXRlbS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBqc3hJbXBvcnRTb3VyY2UgQGVtb3Rpb24vcmVhY3QgKi9cbi8qIGVzbGludC1kaXNhYmxlIGpzeC1hMTF5L25vLXN0YXRpYy1lbGVtZW50LWludGVyYWN0aW9ucyAqL1xuaW1wb3J0IGljb24gZnJvbSAnc3R5bGUvaWNvbidcbmltcG9ydCB7Rm9ybWF0dGVkTWVzc2FnZX0gZnJvbSAnY29udGV4dC9JMThuJ1xuXG5jb25zdCBtZW51SXRlbVN0eWxlID0ge1xuICBwYWRkaW5nOiAndmFyKC0tbWVudS1pdGVtLXBhZGRpbmcsIDAuNWVtIDFlbSkgJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgbWluV2lkdGg6IDAsXG4gIGNvbG9yOiAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjYpJyxcbiAgYmFja2dyb3VuZDogJ3ZhcigtLW1lbnUtaXRlbS1iYWNrZ3JvdW5kLCByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMDgpKScsXG4gIGN1cnNvcjogJ3BvaW50ZXInLFxuICAnPiBkaXYnOiB7XG4gICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIHRleHRPdmVyZmxvdzogJ2VsbGlwc2lzJyxcbiAgfSxcbn1cblxuY29uc3QgbWVudUl0ZW1TZWxlY3RlZFN0eWxlID0ge1xuICBjb2xvcjogJyNGRkYnLFxuICBmb250V2VpZ2h0OiAnNjAwJyxcbiAgJzo6YWZ0ZXInOiB7XG4gICAgY29udGVudDogJ1wiIFwiJyxcbiAgICBkaXNwbGF5OiAnaW5saW5lLWJsb2NrJyxcbiAgICBmbGV4OiAnMCAwIDFlbScsXG4gICAgaGVpZ2h0OiAnMWVtJyxcbiAgICBtYXJnaW5MZWZ0OiAnMC41ZW0nLFxuICAgIGJhY2tncm91bmRDb2xvcjogJ3ZhcigtLXNldHRpbmctY2hlY2staWNvbi1jb2xvciwgI2ZmZiknLFxuICAgIG1hc2tTaXplOiAnY29udGFpbicsXG4gICAgbWFza0ltYWdlOiBgdXJsKCR7aWNvbi5jaGVja30pYCxcbiAgfSxcbn1cblxuY29uc3QgTWVudUl0ZW0gPSAoe2xhYmVsLCBzZWxlY3RlZCwgb25DbGlja30pID0+IChcbiAgPGRpdlxuICAgIGNzcz17W21lbnVJdGVtU3R5bGUsIHNlbGVjdGVkICYmIG1lbnVJdGVtU2VsZWN0ZWRTdHlsZV19XG4gICAgb25DbGljaz17b25DbGlja31cbiAgPlxuICAgIDxkaXY+XG4gICAgICA8Rm9ybWF0dGVkTWVzc2FnZSBpZD17YEtLUy5TRVRUSU5HLiR7bGFiZWx9YH0gZGVmYXVsdE1lc3NhZ2U9e2xhYmVsfSAvPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbilcblxuZXhwb3J0IGRlZmF1bHQgTWVudUl0ZW1cbiJdfQ== */"],
5030
5031
  onClick: onClick,
5031
5032
  children: jsx$1("div", {
5032
5033
  children: jsx$1(FormattedMessage, {
@@ -8797,8 +8798,8 @@ const shouldPause = ({
8797
8798
 
8798
8799
 
8799
8800
  const menuClasses = {
8800
- default: /*#__PURE__*/css$1(LanguageMenu.styles, process.env.NODE_ENV === "production" ? "" : ";label:default;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AAuEW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {havePointer, isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getLanguageOptions, getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  textTracks = [],\n  getPlayer,\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => {\n  const options = getLanguageOptions(getPlayer(), {audioTracks, textTracks})\n  return (\n    audioTracks.length > 0 &&\n    textTracks.length > 0 && (\n    <OverlayPanel title=\"字幕・音声を切り替える\" buttonIcon=\"subtitle\">\n      <slots.LanguageMenu\n        uiType={uiType}\n        classes={menuClasses}\n        sectionOptions={[options.audioTracks, options.textTracks]}\n        onChange={onChange}\n        {...rest}\n      />\n    </OverlayPanel>\n    )\n  )\n}\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  audioTrack: appAudioTrack,\n  textTrack: appTextTrack,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n        otherSections: appSettings.sections,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus\n  const havePlayPanel =\n    !blocking &&\n    havePointer() &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n    }\n  }, [shouldHidePanels])\n  useEffect(() => \n    on(containerRef.current, 'focus-menu', event => {\n      if (event.detail?.status === 'open') {\n        setUserFocus('menu')\n      }\n      if (event.detail?.status === 'closed') {\n        setUserFocus(current => (current === 'menu' ? '' : current))\n      }\n    })\n  , [])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n  const selectedAudioTrack = settings.preferred?.audio || appAudioTrack\n  const selectedTextTrack = settings.preferred?.subtitles || appTextTrack\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audioTrack={selectedAudioTrack}\n            textTrack={selectedTextTrack}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          getPlayer={() => playerRef.current}\n          onChange={(_event, item) =>\n            uiHandlers.onChangeSettings({\n              name: item.type,\n              value: item.value,\n              keepOpen: true,\n            })\n          }\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */"),
8801
- desktop: /*#__PURE__*/css$1(LanguageMenu.styles, LanguageMenu.desktopStyles, process.env.NODE_ENV === "production" ? "" : ";label:desktop;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AAwEW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {havePointer, isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getLanguageOptions, getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  textTracks = [],\n  getPlayer,\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => {\n  const options = getLanguageOptions(getPlayer(), {audioTracks, textTracks})\n  return (\n    audioTracks.length > 0 &&\n    textTracks.length > 0 && (\n    <OverlayPanel title=\"字幕・音声を切り替える\" buttonIcon=\"subtitle\">\n      <slots.LanguageMenu\n        uiType={uiType}\n        classes={menuClasses}\n        sectionOptions={[options.audioTracks, options.textTracks]}\n        onChange={onChange}\n        {...rest}\n      />\n    </OverlayPanel>\n    )\n  )\n}\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  audioTrack: appAudioTrack,\n  textTrack: appTextTrack,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n        otherSections: appSettings.sections,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus\n  const havePlayPanel =\n    !blocking &&\n    havePointer() &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n    }\n  }, [shouldHidePanels])\n  useEffect(() => \n    on(containerRef.current, 'focus-menu', event => {\n      if (event.detail?.status === 'open') {\n        setUserFocus('menu')\n      }\n      if (event.detail?.status === 'closed') {\n        setUserFocus(current => (current === 'menu' ? '' : current))\n      }\n    })\n  , [])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n  const selectedAudioTrack = settings.preferred?.audio || appAudioTrack\n  const selectedTextTrack = settings.preferred?.subtitles || appTextTrack\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audioTrack={selectedAudioTrack}\n            textTrack={selectedTextTrack}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          getPlayer={() => playerRef.current}\n          onChange={(_event, item) =>\n            uiHandlers.onChangeSettings({\n              name: item.type,\n              value: item.value,\n              keepOpen: true,\n            })\n          }\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */")
8801
+ default: /*#__PURE__*/css$1(LanguageMenu.styles, process.env.NODE_ENV === "production" ? "" : ";label:default;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AAuEW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getLanguageOptions, getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  textTracks = [],\n  getPlayer,\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => {\n  const options = getLanguageOptions(getPlayer(), {audioTracks, textTracks})\n  return (\n    audioTracks.length > 0 &&\n    textTracks.length > 0 && (\n      <OverlayPanel\n        uiType={uiType}\n        title=\"字幕・音声を切り替える\"\n        buttonIcon=\"subtitle\"\n      >\n      <slots.LanguageMenu\n        uiType={uiType}\n        classes={menuClasses}\n        sectionOptions={[options.audioTracks, options.textTracks]}\n        onChange={onChange}\n        {...rest}\n      />\n    </OverlayPanel>\n    )\n  )\n}\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  audioTrack: appAudioTrack,\n  textTrack: appTextTrack,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n        otherSections: appSettings.sections,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' ||\n      controlsDisplay === 'hidden' ||\n      playbackState === 'ended') &&\n    userFocus\n  const havePlayPanel =\n    !blocking &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n      if (refs.current.closeMenu) {\n        refs.current.closeMenu()\n        refs.current.closeMenu = undefined\n      }\n    }\n  }, [shouldHidePanels])\n  useEffect(() => \n    on(containerRef.current, 'focus-menu', event => {\n      if (event.detail?.status === 'open') {\n        setUserFocus('menu')\n        refs.current.closeMenu = () => event.detail.closeMenu?.()\n      }\n      if (event.detail?.status === 'closed') {\n        setUserFocus(current => (current === 'menu' ? '' : current))\n      }\n    })\n  , [])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n  const selectedAudioTrack = settings.preferred?.audio || appAudioTrack\n  const selectedTextTrack = settings.preferred?.subtitles || appTextTrack\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audioTrack={selectedAudioTrack}\n            textTrack={selectedTextTrack}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          getPlayer={() => playerRef.current}\n          onChange={(_event, item) =>\n            uiHandlers.onChangeSettings({\n              name: item.type,\n              value: item.value,\n              keepOpen: true,\n            })\n          }\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */"),
8802
+ desktop: /*#__PURE__*/css$1(LanguageMenu.styles, LanguageMenu.desktopStyles, process.env.NODE_ENV === "production" ? "" : ";label:desktop;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PremiumPlayer.js"],"names":[],"mappings":"AAwEW","file":"PremiumPlayer.js","sourcesContent":["/* eslint-disable no-nested-ternary */\nimport {useEffect, useMemo, useRef, useState} from 'react'\nimport {css} from '@emotion/css'\nimport useDimensions from 'react-cool-dimensions'\nimport {ResizeObserver} from '@juggle/resize-observer'\n\nimport {handleError} from 'playerCore/errors'\nimport {on} from 'util/events'\nimport {isDesktop} from 'util/environment'\nimport multiRef from 'util/multiRef'\nimport {onViewModeChange, toggleFullscreen} from 'util/viewModes'\nimport {useAutoHide} from 'hooks'\nimport {IntlProvider} from 'context/I18n'\nimport {getMediaTime, isBuffered} from 'playerCore/mediaBindings'\nimport Error from 'playerUi/Error'\nimport Layout from 'playerUi/DefaultLayout'\nimport {\n  Button,\n  LiveButton,\n  FullscreenButton,\n  PlayButton,\n  ForwardButton,\n} from 'playerUi/buttons'\nimport Seekbar from 'playerUi/Seekbar'\nimport DisplayTime from 'playerUi/DisplayTime'\nimport LoadingSpinner from 'playerUi/LoadingSpinner'\nimport Backdrop from 'playerUi/Backdrop'\nimport Settings from 'playerUi/Settings'\nimport OverlayPanel from 'playerUi/OverlayPanel'\nimport LanguageMenu from 'playerUi/LanguageMenu'\nimport PlayPanel from 'playerUi/PlayPane'\nimport VolumeControl from 'component/VolumeControl'\nimport CastUi from 'cast/CastUi'\nimport {linkCast} from 'cast/framework'\nimport {CastState} from 'Enum'\nimport {dispatchChapterEvents} from './timeline'\nimport Video from '../Video'\nimport {getLanguageOptions, getQualityOptions, getSettingsData} from './settings'\nimport {linkMediaVolume, syncVolume} from './volume'\nimport SeekPreview from './SeekPreview'\n\nconst sizes = {\n  'small-embed': 200,\n  embed: 400,\n  'tablet-portrait': 600,\n  'tablet-landscape': 900,\n  desktop: 1200,\n}\n\nconst useLinkState = (request, dependencies = []) => {\n  const [state, setState] = useState()\n  useEffect(() => {\n    request(setState)\n  }, dependencies)\n  return state\n}\n\nconst flipState = state => (state === 'playing' ? 'paused' : 'playing')\n\n// FIXME: too few lines to split a file, looking a better place\nconst getThumbnailsUrl = source =>\n  [].concat(source).find(item => item.type === 'thumbnail')?.src\n\nconst defaultSettings = {}\n\nconst shouldPause = ({userFocus, uiType}) =>\n  (uiType === 'mobile' && /settings|chapter-list/.test(userFocus)) ||\n  /blocking|seekbar|share-inner/.test(userFocus)\n\n// TODO extract to somewhere else\nconst menuClasses = {\n  default: css(LanguageMenu.styles),\n  desktop: css(LanguageMenu.styles, LanguageMenu.desktopStyles),\n}\n\nconst LanguageSettings = ({\n  uiType,\n  audioTracks = [],\n  textTracks = [],\n  getPlayer,\n  onChange,\n  slots = {LanguageMenu},\n  ...rest\n}) => {\n  const options = getLanguageOptions(getPlayer(), {audioTracks, textTracks})\n  return (\n    audioTracks.length > 0 &&\n    textTracks.length > 0 && (\n      <OverlayPanel\n        uiType={uiType}\n        title=\"字幕・音声を切り替える\"\n        buttonIcon=\"subtitle\"\n      >\n      <slots.LanguageMenu\n        uiType={uiType}\n        classes={menuClasses}\n        sectionOptions={[options.audioTracks, options.textTracks]}\n        onChange={onChange}\n        {...rest}\n      />\n    </OverlayPanel>\n    )\n  )\n}\n\nconst PremiumPlayer = ({\n  source,\n  startTime,\n  quality = {},\n  title,\n  metadata,\n  channelTitle,\n  chapters,\n  playbackState: appPlaybackState,\n  currentTime: appCurrentTime,\n  playbackRate: appPlaybackRate,\n  loop,\n  volume: appVolume,\n  audioTrack: appAudioTrack,\n  textTrack: appTextTrack,\n  thumbnailsUrl,\n  controls = {autohide: 3000},\n  marks = [],\n  // TODO sectionId\n  intl,\n  settings: appSettings = defaultSettings,\n  blocking,\n  plugins = [],\n  modulesConfig,\n\n  uiType = isDesktop() ? 'desktop' : 'mobile',\n  style,\n  children,\n  uiMode = 'standalone',\n  cast: castOptions = 'compatible',\n  slots,\n  slotProps = {},\n  onError,\n  onPlaybackStateChange,\n  onBack,\n  onCast,\n  onChangeNext,\n  onChangePrevious,\n  onOpenSettings,\n  onChangeSettings,\n  onPlayerLoaded,\n  onBlockedAutoplay,\n  onPlaylogFired,\n  ...videoProps\n}) => {\n  const components = {\n    VolumeControl,\n    CastUi,\n    DisplayTime,\n    LiveButton,\n    Seekbar,\n    Settings,\n    ...slots,\n  }\n  const videoRef = useRef()\n  const containerRef = useRef()\n  const playerRef = useRef()\n  const adContainerRef = useRef()\n  const refs = useRef({})\n  // TODO move RWD related to Layout\n  const {\n    currentBreakpoint: size,\n    width,\n    observe,\n  } = useDimensions({\n    polyfill: ResizeObserver,\n    breakpoints: sizes,\n  })\n  const [isUserActive, setIsUserActive] = useState(\n    uiMode === 'standalone' ? true : videoProps.autoplay\n  )\n  const [userFocus, setUserFocus] = useState('')\n  const [targetState, setTargetState] = useState(() => ({\n    playbackState:\n      appPlaybackState || (videoProps.autoplay ? 'playing' : 'paused'),\n    currentTime: startTime,\n  }))\n  const [playbackTime, setPlaybackTime] = useState({\n    currentTime: 0,\n    bufferTime: 0,\n  })\n  const togglePlay = (overrideState, {triggeredBy} = {}) => {\n    if (targetState.playbackState !== overrideState) {\n      setTargetState(state => ({\n        ...state,\n        playbackState: overrideState || flipState(state.playbackState),\n        animation:\n          triggeredBy === 'user-action' && flipState(state.playbackState),\n      }))\n    }\n  }\n\n  useEffect(() => {\n    if (appPlaybackState) {\n      togglePlay(appPlaybackState)\n    }\n  }, [appPlaybackState])\n  useEffect(() => {\n    if (uiType === 'mobile') {\n      on(document, 'visibilitychange', () => togglePlay('paused'))\n    }\n  }, [uiType, targetState.playbackState])\n  const updatePlaybackTime = event =>\n    requestAnimationFrame(\n      () =>\n        (event?.type !== 'timeupdate' || isBuffered(videoRef.current)) &&\n        setPlaybackTime(state => ({\n          ...state,\n          ...getMediaTime(videoRef.current, {\n            player: playerRef.current,\n            plugins,\n          }),\n          ...(event?.type === 'durationchange' && {\n            currentTime: state.currentTime,\n          }),\n        }))\n    )\n  const setTargetTime = time => {\n    const trimmed = Math.min(\n      time,\n      videoRef.current?.initialDuration || Infinity\n    )\n    setTargetState(state => ({\n      ...state,\n      // seek to 0 repeatedly edge case\n      currentTime: state.currentTime !== trimmed ? trimmed : trimmed + 0.01,\n    }))\n    updatePlaybackTime()\n  }\n  const [playbackState, setPlaybackState] = useState('init')\n  const [castState, setCastState] = useState('')\n  useEffect(() => {\n    if (typeof appCurrentTime === 'number') setTargetTime(appCurrentTime || 0)\n    if (typeof appCurrentTime === 'object')\n      setTargetTime(appCurrentTime?.value || 0)\n  }, [appCurrentTime])\n  const [errorData, setErrorData] = useState()\n  const errorHandler = reactEvent => {\n    onError?.(reactEvent.nativeEvent)\n    handleError(reactEvent, {\n      media: videoRef.current,\n      displayError: data => {\n        setPlaybackState('error')\n        setErrorData(current => (current?.code ? current : data))\n      },\n    })\n  }\n  const isLive = playbackTime.streamType === 'live'\n  const [settings, setSettings] = useState(() => ({\n    sections: [],\n    values: {speed: 1},\n  }))\n  const fetchSettings = () => {\n    if (!playerRef.current) {\n      return\n    }\n    const speedItems = appSettings.speedItems || (isLive ? [] : undefined)\n    setSettings(current => {\n      const {values, sections} = getSettingsData({\n        media: videoRef.current,\n        player: playerRef.current,\n        source,\n        quality,\n        speedItems,\n        loop,\n        preferred: current.preferred,\n        otherSections: appSettings.sections,\n      })\n      return {preferred: current.preferred, values, sections}\n    })\n  }\n  const lastState = useRef(playbackState)\n  const handlePlaybackStateChange = (event, state) => {\n    if (lastState.current === 'error') {\n      return\n    }\n    onPlaybackStateChange?.(event, state)\n    // previously UI playback state was synced only when\n    // exiting iOS video only fullscreen(webkitendfullscreen)\n    if (\n      /playing|paused/.test(state) &&\n      !(uiType === 'mobile' && blocking) &&\n      !shouldPause({userFocus, uiType})\n    ) {\n      togglePlay(state)\n    }\n    if (state === 'ended') {\n      togglePlay('paused')\n    }\n    if (state === 'loading' && lastState.current !== 'init') {\n      setTimeout(() => togglePlay('playing'), 1)\n    }\n    if (state === 'playing') {\n      setIsUserActive(true)\n    }\n    if (lastState.current === 'loading') {\n      fetchSettings()\n    }\n    lastState.current = state\n    setPlaybackState(state)\n  }\n\n  const changeSettings = (name, value, {keepOpen} = {}) => {\n    // TODO consider merge into useReducer?\n    onChangeSettings?.({name, value})\n    setTargetTime(playbackTime.currentTime)\n    setSettings(current => ({\n      ...current,\n      values: {...current.values, [name]: value},\n      preferred: {...current.preferred, [name]: value},\n    }))\n    if (!keepOpen) {\n      setUserFocus('')\n    }\n  }\n  const openSettings = event => {\n    const animationFrame =\n      userFocus !== 'settings' &&\n      requestAnimationFrame(() => {\n        onOpenSettings?.(event, settings)\n        // In iOS Safari, we need to update settings data\n        fetchSettings()\n      })\n    setUserFocus(current => (current === 'settings' ? '' : 'settings'))\n    return animationFrame\n  }\n  useEffect(() => {\n    if (appPlaybackRate > 0) {\n      setSettings(current => ({\n        ...current,\n        values: {...current.values, speed: appPlaybackRate},\n      }))\n    }\n  }, [appPlaybackRate])\n\n  const qualityOptions = useMemo(\n    () => getQualityOptions(settings),\n    [settings.values.quality]\n  )\n  const viewMode = useLinkState(update =>\n    onViewModeChange(videoRef.current, update)\n  )\n  const sourceOverride = useLinkState(\n    async update => {\n      const result =\n        source && (await quality.rewriteManifest?.(source, qualityOptions))\n      update(result || source)\n    },\n    [source, qualityOptions]\n  )\n  const waiting = /emptied|loading|buffering/.test(playbackState)\n  const activePlayback =\n    playbackState === 'playing' || playbackState === 'waiting'\n  const {\n    mode: autoHideMode,\n    onClick,\n    onMouseMove,\n  } = useAutoHide({\n    pinned: !controls.autohide || waiting || !activePlayback || userFocus,\n    tapToHide: uiType === 'mobile',\n    hideTimeMs: controls.autohide,\n  })\n  const mode =\n    userFocus === 'seekbar'\n      ? 'hidden'\n      : controls.autohide\n      ? autoHideMode\n      : controls\n      ? 'shown'\n      : 'hidden'\n  const controlsDisplay =\n    userFocus === 'seekbar'\n      ? 'seekbar-only'\n      : controls === 'title-only' || playbackState === 'emptied'\n      ? 'hidden'\n      : mode\n  const shouldHidePanels =\n    (controls === 'no-panel' ||\n      controlsDisplay === 'hidden' ||\n      playbackState === 'ended') &&\n    userFocus\n  const havePlayPanel =\n    !blocking &&\n    uiType === 'desktop' &&\n    !waiting &&\n    !/volume|''/.test(userFocus) &&\n    !/title-only|no-panel/.test(controls) &&\n    (controls.autohide || mode === 'shown')\n\n  useEffect(() => {\n    if (shouldHidePanels) {\n      setUserFocus('')\n      if (refs.current.closeMenu) {\n        refs.current.closeMenu()\n        refs.current.closeMenu = undefined\n      }\n    }\n  }, [shouldHidePanels])\n  useEffect(() => \n    on(containerRef.current, 'focus-menu', event => {\n      if (event.detail?.status === 'open') {\n        setUserFocus('menu')\n        refs.current.closeMenu = () => event.detail.closeMenu?.()\n      }\n      if (event.detail?.status === 'closed') {\n        setUserFocus(current => (current === 'menu' ? '' : current))\n      }\n    })\n  , [])\n  const {subscribe, onChange, toggleMute} = linkMediaVolume(() => ({\n    video: videoRef.current,\n    getPlayer: () => playerRef.current,\n  }))\n  const changePrevious = event => {\n    onChangePrevious(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n  const changeNext = event => {\n    onChangeNext(event)\n    togglePlay('paused')\n    videoRef.current.dispatchEvent(new CustomEvent('loadstart'))\n  }\n\n  useEffect(fetchSettings, [appSettings])\n  useEffect(() => {\n    // The adContainer should be set before `load` because ImaDai.load needs it.\n    plugins.forEach(plugin => plugin.setAdContainer?.(adContainerRef.current))\n  }, [])\n\n  useEffect(\n    () =>\n      dispatchChapterEvents({\n        media: videoRef.current,\n        chapters,\n        getTime: () => videoRef.current.currentTime,\n      }),\n    [chapters]\n  )\n\n  const isEnd = playbackState === 'ended'\n  const canSeek = !isEnd && playbackTime.duration > 0\n  const derivedPlaybackState =\n    (uiType === 'mobile' && blocking) || shouldPause({userFocus, uiType})\n      ? 'paused'\n      : targetState.playbackState\n  const activeThumbnailsUrl =\n    (!userFocus || userFocus === 'seekbar') &&\n    (getThumbnailsUrl(source) || thumbnailsUrl)\n  const cssVariables = {\n    '--playing': playbackState === 'playing' ? '1' : '0',\n  }\n  const onRewind =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime - 10, 'rewind'))\n  const onForward =\n    (!isLive || playbackTime.currentTime < 0) &&\n    canSeek &&\n    (() => setTargetTime(playbackTime.currentTime + 10, 'forward'))\n  const onClickBlank =\n    havePlayPanel && (() => togglePlay('', {triggeredBy: 'user-action'}))\n\n  const uiHandlers = {\n    onPlay: () => {\n      togglePlay('', {triggeredBy: 'user-action'})\n      setIsUserActive(true)\n    },\n    onClickLive: isLive && (() => setTargetTime(0, 'seekToLive')),\n    onClickSeekbar: () => {\n      refs.current.deferedSeekFocus = setTimeout(\n        () => setUserFocus('seekbar'),\n        66\n      )\n    },\n    onSeek: time => {\n      setTargetTime(time, 'seek')\n      clearTimeout(refs.current.deferedSeekFocus)\n      setTimeout(() => setUserFocus(''), 66)\n    },\n    onChangeSettings: ({name, value, keepOpen}) =>\n      changeSettings(name, value, {keepOpen}),\n    onCloseSettings: event => {\n      setUserFocus('')\n      slotProps?.settings?.onClose?.(event)\n    },\n  }\n\n  const uiElements = {\n    liveButton: uiHandlers.onClickLive && (\n      <components.LiveButton\n        usingStartOver={playbackTime.currentTime < 0}\n        onClick={uiHandlers.onClickLive}\n      />\n    ),\n    controlButtons: {\n      playButton: (\n        <PlayButton\n          playbackState={derivedPlaybackState}\n          ended={isEnd}\n          hidden={\n            uiType === 'mobile' && (waiting || /loading/.test(playbackState))\n          }\n          variant={!isUserActive && 'firstplay'}\n          onClick={uiHandlers.onPlay}\n        />\n      ),\n      rewindButton: onRewind && (\n        <Button\n          startIcon=\"rewind10\"\n          title=\"KKS.PLAYER.REWIND\"\n          disabled={isEnd}\n          onClick={onRewind}\n        />\n      ),\n      forwardButton: onForward && (\n        <ForwardButton\n          startIcon=\"forward10\"\n          title=\"KKS.PLAYER.FORWARD\"\n          disabled={!canSeek}\n          onClick={onForward}\n        />\n      ),\n      nextEpisodeButton: (\n        <Button\n          startIcon=\"next\"\n          title=\"KKS.PLAYER.NEXT\"\n          disabled={!onChangeNext}\n          onClick={changeNext}\n        />\n      ),\n      previousEpisodeButton: (\n        <Button\n          startIcon=\"previous\"\n          title=\"KKS.PLAYER.PREVIOUS\"\n          disabled={!onChangePrevious}\n          onClick={changePrevious}\n        />\n      ),\n    },\n    seekbar: (\n      <components.Seekbar\n        style={/volume/.test(userFocus) && {opacity: '0'}}\n        startTime={playbackTime.startTime}\n        currentTime={playbackTime.currentTime}\n        bufferTime={playbackTime.bufferTime}\n        duration={playbackTime.duration}\n        chapters={chapters}\n        onChange={uiHandlers.onClickSeekbar}\n        onChangeCommitted={uiHandlers.onSeek}\n        marks={marks}\n        plugins={plugins}\n        {...slotProps.seekbar}\n      >\n        {activeThumbnailsUrl && (\n          <SeekPreview\n            thumbnailsUrl={activeThumbnailsUrl}\n            duration={playbackTime.duration}\n            chapters={chapters}\n          />\n        )}\n      </components.Seekbar>\n    ),\n    displayTime: <components.DisplayTime {...playbackTime} />,\n    fullscreenButton: (\n      <FullscreenButton\n        viewMode={viewMode}\n        onClick={() => toggleFullscreen(containerRef.current)}\n      />\n    ),\n    volumeControl: width >= sizes['small-embed'] && (\n      <components.VolumeControl\n        {...{subscribe, onChange, toggleMute}}\n        onMouseOver={() => setUserFocus('volume')}\n        onMouseOut={() => setUserFocus('')}\n        {...slotProps?.volumeControl}\n      />\n    ),\n    backItems: (\n      <PlayPanel animation={targetState.animation} onClick={onClickBlank} />\n    ),\n  }\n  const compatibilityCastProps = castOptions === 'compatible' && {\n    source,\n    values: {title, ...settings.values, ...intl, modulesConfig},\n    onLoad: onCast,\n  }\n\n  useEffect(() => {\n    if (castOptions && castOptions !== 'compatible') {\n      return linkCast({source, ...castOptions})\n    } // TODO playlist, audio / subtitle setting\n  }, [source, castOptions.contentId, castOptions.customData])\n  const selectedAudioTrack = settings.preferred?.audio || appAudioTrack\n  const selectedTextTrack = settings.preferred?.subtitles || appTextTrack\n\n  return (\n    <IntlProvider {...intl}>\n      <Layout\n        style={{...style, cssVariables}}\n        type={uiType}\n        display={mode}\n        controlsDisplay={controlsDisplay}\n        size={size}\n        video={\n          <Video\n            {...videoProps}\n            videoRef={multiRef(videoRef, videoProps.videoRef)}\n            source={\n              castState !== CastState.CONNECTED &&\n              playbackState !== 'error' &&\n              sourceOverride\n            }\n            playbackState={derivedPlaybackState}\n            currentTime={targetState.currentTime}\n            {...(appVolume >= 0 && {volume: appVolume, muted: appVolume <= 0})}\n            playbackRate={settings.values.speed}\n            videoResolution={qualityOptions}\n            audioTrack={selectedAudioTrack}\n            textTrack={selectedTextTrack}\n            loop={settings.values.loop}\n            plugins={plugins}\n            modulesConfig={modulesConfig}\n            onPlaylogFired={onPlaylogFired}\n            onError={errorHandler}\n            onPlaybackStateChange={handlePlaybackStateChange}\n            onBlockedAutoplay={error => onBlockedAutoplay?.(error)}\n            onCanPlay={event => {\n              updatePlaybackTime(event)\n              videoProps.onCanPlay?.(event)\n            }}\n            onTimeUpdate={updatePlaybackTime}\n            onDurationChange={updatePlaybackTime}\n            onPlayerLoaded={player => {\n              playerRef.current = player\n              onPlayerLoaded?.(player)\n              syncVolume(videoRef.current, videoProps.muted ? 0 : appVolume)\n            }}\n          />\n        }\n        containerRef={element => {\n          containerRef.current = element\n          observe(element)\n        }}\n        backRef={adContainerRef}\n        title={title}\n        channelTitle={channelTitle}\n        backButton={onBack && <Button startIcon=\"back\" onClick={onBack} />}\n        {...(isUserActive && uiElements)}\n        onClick={onClick}\n        onMouseMove={onMouseMove}\n      >\n        <LoadingSpinner active={waiting} />\n        {errorData && <Error error={errorData} onBack={onBack} />}\n        {children}\n        {/* TODO sync Cast last played time back */}\n        {isUserActive && (\n          <components.CastUi\n            onBack={onBack}\n            onStateChange={setCastState}\n            onLoad={onCast}\n            {...compatibilityCastProps}\n            {...slotProps.castUi}\n          />\n        )}\n        {isUserActive && ( // TODO: Design <Extenstion /> flag\n          <components.Settings\n            type={uiType}\n            sections={settings.sections}\n            // TODO hasBottomPanel bottom: 8em\n            open={userFocus === 'settings'}\n            values={settings.values}\n            onOpen={openSettings}\n            onChange={uiHandlers.onChangeSettings}\n            {...slotProps?.settings}\n            onClose={uiHandlers.onCloseSettings}\n          />\n        )}\n        <LanguageSettings\n          uiType={uiType}\n          getPlayer={() => playerRef.current}\n          onChange={(_event, item) =>\n            uiHandlers.onChangeSettings({\n              name: item.type,\n              value: item.value,\n              keepOpen: true,\n            })\n          }\n          {...slotProps.languageSettings}\n        />\n        <Backdrop open={!playbackState || playbackState === 'loading'}>\n          <LoadingSpinner />\n        </Backdrop>\n      </Layout>\n    </IntlProvider>\n  )\n}\n\nexport default PremiumPlayer\n"]} */")
8802
8803
  };
8803
8804
 
8804
8805
  const LanguageSettings = ({
@@ -8817,6 +8818,7 @@ const LanguageSettings = ({
8817
8818
  textTracks
8818
8819
  });
8819
8820
  return audioTracks.length > 0 && textTracks.length > 0 && /*#__PURE__*/jsx(OverlayPanel, {
8821
+ uiType: uiType,
8820
8822
  title: "\u5B57\u5E55\u30FB\u97F3\u58F0\u3092\u5207\u308A\u66FF\u3048\u308B",
8821
8823
  buttonIcon: "subtitle",
8822
8824
  children: /*#__PURE__*/jsx(slots.LanguageMenu, {
@@ -9109,21 +9111,32 @@ const PremiumPlayer = ({
9109
9111
  });
9110
9112
  const mode = userFocus === 'seekbar' ? 'hidden' : controls.autohide ? autoHideMode : controls ? 'shown' : 'hidden';
9111
9113
  const controlsDisplay = userFocus === 'seekbar' ? 'seekbar-only' : controls === 'title-only' || playbackState === 'emptied' ? 'hidden' : mode;
9112
- const shouldHidePanels = (controls === 'no-panel' || controlsDisplay === 'hidden') && userFocus;
9113
- const havePlayPanel = !blocking && havePointer() && uiType === 'desktop' && !waiting && !/volume|''/.test(userFocus) && !/title-only|no-panel/.test(controls) && (controls.autohide || mode === 'shown');
9114
+ const shouldHidePanels = (controls === 'no-panel' || controlsDisplay === 'hidden' || playbackState === 'ended') && userFocus;
9115
+ const havePlayPanel = !blocking && uiType === 'desktop' && !waiting && !/volume|''/.test(userFocus) && !/title-only|no-panel/.test(controls) && (controls.autohide || mode === 'shown');
9114
9116
  useEffect(() => {
9115
9117
  if (shouldHidePanels) {
9116
9118
  setUserFocus('');
9119
+
9120
+ if (refs.current.closeMenu) {
9121
+ refs.current.closeMenu();
9122
+ refs.current.closeMenu = undefined;
9123
+ }
9117
9124
  }
9118
9125
  }, [shouldHidePanels]);
9119
9126
  useEffect(() => on(containerRef.current, 'focus-menu', event => {
9120
- var _event$detail, _event$detail2;
9127
+ var _event$detail, _event$detail3;
9121
9128
 
9122
9129
  if (((_event$detail = event.detail) === null || _event$detail === void 0 ? void 0 : _event$detail.status) === 'open') {
9123
9130
  setUserFocus('menu');
9131
+
9132
+ refs.current.closeMenu = () => {
9133
+ var _event$detail$closeMe, _event$detail2;
9134
+
9135
+ return (_event$detail$closeMe = (_event$detail2 = event.detail).closeMenu) === null || _event$detail$closeMe === void 0 ? void 0 : _event$detail$closeMe.call(_event$detail2);
9136
+ };
9124
9137
  }
9125
9138
 
9126
- if (((_event$detail2 = event.detail) === null || _event$detail2 === void 0 ? void 0 : _event$detail2.status) === 'closed') {
9139
+ if (((_event$detail3 = event.detail) === null || _event$detail3 === void 0 ? void 0 : _event$detail3.status) === 'closed') {
9127
9140
  setUserFocus(current => current === 'menu' ? '' : current);
9128
9141
  }
9129
9142
  }), []);