@kkcompany/player 2.25.0-canary.25 → 2.25.0-canary.26

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.
Files changed (2) hide show
  1. package/dist/reactEntry.mjs +573 -79
  2. package/package.json +1 -1
@@ -1355,9 +1355,11 @@ var icon_default = {
1355
1355
  back1: backIcon,
1356
1356
  forward10: "",
1357
1357
  rewind10: "",
1358
- volumeHigh: "",
1359
- volumeLow: "",
1360
- mute: "",
1358
+ volumeHigh: "",
1359
+ volumeLow: "",
1360
+ mute: "",
1361
+ speed: "",
1362
+ subtitle: "",
1361
1363
  setting: "",
1362
1364
  subtitle: "",
1363
1365
  check: "",
@@ -1365,6 +1367,8 @@ var icon_default = {
1365
1367
  "exit-fullscreen": "",
1366
1368
  previous: "",
1367
1369
  next: "",
1370
+ telasaNext: "",
1371
+ telasaPrevious: "",
1368
1372
  pausedCircle: "",
1369
1373
  playingCircle: "",
1370
1374
  playCircleBorder: "",
@@ -1377,6 +1381,7 @@ var icon_default = {
1377
1381
  castConntecting2: "",
1378
1382
  castCenterIcon: "",
1379
1383
  warning: "",
1384
+ telasaWarning: "",
1380
1385
  cancel: "",
1381
1386
  info: "",
1382
1387
  share: "",
@@ -1674,6 +1679,8 @@ const Switch = ({ checked, ...rest }) => /* @__PURE__ */ jsx$1("div", {
1674
1679
  ...rest,
1675
1680
  children: /* @__PURE__ */ jsx$1("div", { css: thumbStyle$1 })
1676
1681
  });
1682
+ const NextButton = ({ ...rest }) => /* @__PURE__ */ jsx$1(Button, { ...rest });
1683
+ const PreviousButton = ({ ...rest }) => /* @__PURE__ */ jsx$1(Button, { ...rest });
1677
1684
 
1678
1685
  //#endregion
1679
1686
  //#region src/playerUi/Error.js
@@ -1689,7 +1696,7 @@ const style$7 = {
1689
1696
  padding: "0 1.5rem",
1690
1697
  textAlign: "center"
1691
1698
  };
1692
- const Error$1 = ({ error = {}, onBack }) => {
1699
+ const Error$1 = ({ error = {}, onBack, icon = "warning" }) => {
1693
1700
  const intl = useIntl();
1694
1701
  const values = {
1695
1702
  CODE: error.code || 0,
@@ -1701,7 +1708,7 @@ const Error$1 = ({ error = {}, onBack }) => {
1701
1708
  open: true,
1702
1709
  children: [
1703
1710
  /* @__PURE__ */ jsx$1(Icon_default, {
1704
- type: "warning",
1711
+ type: icon,
1705
1712
  style: iconStyle$1
1706
1713
  }),
1707
1714
  /* @__PURE__ */ jsx$1("div", {
@@ -1791,10 +1798,10 @@ const bottomUiTop = (container) => {
1791
1798
  };
1792
1799
 
1793
1800
  //#endregion
1794
- //#region src/playerUi/DefaultLayout.js
1801
+ //#region src/playerUi/ClassicLayout.js
1795
1802
  const hidden = { display: "none" };
1796
1803
  const invisible = (hiddenArea) => ({ visibility: `var(${hiddenArea}, visible)` });
1797
- const containerStyle$6 = {
1804
+ const containerStyle$7 = {
1798
1805
  "--spacing": "0.5em",
1799
1806
  "--center-pointer-events": "auto",
1800
1807
  width: "100%",
@@ -1856,7 +1863,7 @@ const displayHidden = { "> div:not(.pinned), > button:not(.pinned), > img:not(.p
1856
1863
  opacity: 0,
1857
1864
  transform: "translate(-200vw, 0)",
1858
1865
  transition: "opacity 0.8s var(--autohide-delay, 0s) ease-out, transform 0s calc(0.8s + var(--autohide-delay, 0s))",
1859
- "button": {
1866
+ button: {
1860
1867
  opacity: 0,
1861
1868
  transition: "opacity 0s calc(0.8s + var(--autohide-delay, 0s)) ease-out"
1862
1869
  }
@@ -1994,7 +2001,7 @@ const desktopControls = {
1994
2001
  };
1995
2002
  const seekbarStyles = {
1996
2003
  flex: "1 var(--seekbar-flex-basis, 100%)",
1997
- "&:not(:empty)": { margin: "0 calc(var(--spacing, 0.75em) - 0.5em + 0.5rem)" }
2004
+ "&:not(:empty)": { margin: "0 calc(var(--spacing, 0.75em) - 0.5em + 0.5rem) 0.5rem" }
1998
2005
  };
1999
2006
  const adContainerStyle = {
2000
2007
  flexGrow: 1,
@@ -2019,7 +2026,7 @@ const ControlsBlock = ({ order = "mobile", liveButton, playButton, rewindButton
2019
2026
  nextEpisodeButton,
2020
2027
  forwardButton
2021
2028
  ] });
2022
- const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveButton, controlsDisplay = display, size, title = "", channelTitle = "", video, haveBottomItem, seekbar = "", displayTime, controlButtons, volumeControl, fullscreenButton, backButton = "", adStatus = "", adLink = "", adSkipButton, backItems, children, containerRef, backRef, adContainerRef, ...rest }) => {
2029
+ const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveButton, controlsDisplay = display, size, title = "", channelTitle = "", video, haveBottomItem, seekbar = "", displayTime, controlButtons, volumeControl, fullscreenButton, speedButton = "", subtitleButton = "", backButton = "", adStatus = "", adLink = "", adSkipButton, backItems, children, containerRef, backRef, adContainerRef, ...rest }) => {
2023
2030
  const slotRef = useRef({});
2024
2031
  return /* @__PURE__ */ jsxs$1("div", {
2025
2032
  style: {
@@ -2027,7 +2034,7 @@ const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveB
2027
2034
  "--player-bottom-ui-height": type$1 === "desktop" && controlsDisplay === "shown" ? "3.5rem" : "0"
2028
2035
  },
2029
2036
  css: [
2030
- containerStyle$6,
2037
+ containerStyle$7,
2031
2038
  videoContainerStyle,
2032
2039
  responsiveStyles[size],
2033
2040
  type$1 === "desktop" && desktopStyle$2,
@@ -2093,7 +2100,7 @@ const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveB
2093
2100
  css: [
2094
2101
  rowStyle,
2095
2102
  {
2096
- marginTop: "1em",
2103
+ margin: "1rem 0",
2097
2104
  paddingTop: 0,
2098
2105
  paddingBottom: "calc(1em - var(--bottom-spacing, 0) / 5)",
2099
2106
  flexWrap: "wrap",
@@ -2110,6 +2117,7 @@ const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveB
2110
2117
  liveButton,
2111
2118
  ...controlButtons
2112
2119
  }),
2120
+ type$1 === "desktop" && volumeControl,
2113
2121
  type$1 === "desktop" ? /* @__PURE__ */ jsx$1("div", {
2114
2122
  css: [displayStyles[controlsDisplay]],
2115
2123
  children: displayTime
@@ -2131,13 +2139,14 @@ const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveB
2131
2139
  slotRef.current.infoBar = element;
2132
2140
  }
2133
2141
  }),
2134
- volumeControl,
2135
2142
  /* @__PURE__ */ jsx$1("div", {
2136
- css: [adStatus ? hidden : { display: "flex" }],
2143
+ css: adStatus && hidden,
2137
2144
  ref: (element) => {
2138
2145
  slotRef.current.functionBar = element;
2139
2146
  }
2140
2147
  }),
2148
+ speedButton,
2149
+ subtitleButton,
2141
2150
  fullscreenButton
2142
2151
  ]
2143
2152
  }),
@@ -2148,7 +2157,7 @@ const DefaultLayout = ({ type: type$1 = "mobile", style: style$8, display, liveB
2148
2157
  ]
2149
2158
  });
2150
2159
  };
2151
- var DefaultLayout_default = DefaultLayout;
2160
+ var ClassicLayout_default = DefaultLayout;
2152
2161
 
2153
2162
  //#endregion
2154
2163
  //#region src/util/gestures.js
@@ -2244,7 +2253,7 @@ const pointerHandlers = ({ onMove, onLeave }) => {
2244
2253
 
2245
2254
  //#endregion
2246
2255
  //#region src/playerUi/SimpleSlider.jsx
2247
- const containerStyle$5 = {
2256
+ const containerStyle$6 = {
2248
2257
  position: "relative",
2249
2258
  width: "100%",
2250
2259
  height: "100%",
@@ -2263,7 +2272,8 @@ const trackStyle = {
2263
2272
  position: "absolute",
2264
2273
  width: "4px",
2265
2274
  height: "100%",
2266
- backgroundColor: "var(--sender-seekbar-background, #fff)"
2275
+ backgroundColor: "var(--sender-seekbar-background, #fff)",
2276
+ borderRadius: "0.2em"
2267
2277
  };
2268
2278
  const markStyle = {
2269
2279
  position: "absolute",
@@ -2274,12 +2284,12 @@ const markStyle = {
2274
2284
  };
2275
2285
  const thumbStyle = {
2276
2286
  position: "absolute",
2277
- height: "0.66em",
2278
- width: "0.66em",
2287
+ height: "1rem",
2288
+ width: "1rem",
2279
2289
  borderRadius: "100%",
2280
2290
  backgroundColor: "#fff",
2281
2291
  boxShadow: "0 2px 2px 0 rgba(0, 0, 0, 0.5)",
2282
- transform: "translateY(calc(var(--slider-thumb-y) - 0.35em))"
2292
+ transform: "translateY(calc(var(--slider-thumb-y) - 0.25rem))"
2283
2293
  };
2284
2294
  const getPointerValue = ({ orientation, x, y, left, bottom, height, width }) => Math.max(0, orientation === "vertical" ? Math.min((bottom - y) / height, 1) : Math.min((x - left) / width, 1));
2285
2295
  const debouncedPointerHandlers = ({ state, onMove, onLeave }) => {
@@ -2337,7 +2347,10 @@ const SliderTrack = ({ value, orientation, style: style$8, ...rest }) => /* @__P
2337
2347
  css: [style$8, orientation === "vertical" ? {
2338
2348
  bottom: "0",
2339
2349
  height: `${value * 100}%`
2340
- } : { width: `${value * 100}%` }],
2350
+ } : {
2351
+ width: `${value * 100}%`,
2352
+ height: "0.25rem"
2353
+ }],
2341
2354
  ...rest
2342
2355
  });
2343
2356
  const defaultSlots = {
@@ -2395,12 +2408,12 @@ const SimpleSlider = ({ min = 0, max = 100, value, secondaryTrackValue, marks =
2395
2408
  setFocusValue();
2396
2409
  };
2397
2410
  const thumbPositionStyle = {
2398
- bottom: `calc(var(--slider-thumb-y) - 0.35em)`,
2399
- left: `calc(var(--slider-thumb-x) - 0.25em)`
2411
+ bottom: `calc(var(--slider-thumb-y) - 0.25rem)`,
2412
+ left: `calc(var(--slider-thumb-x) - 0.25rem)`
2400
2413
  };
2401
2414
  return /* @__PURE__ */ jsxs$1("div", {
2402
2415
  className,
2403
- css: [containerStyle$5, disabled && disabledStyle],
2416
+ css: [containerStyle$6, disabled && disabledStyle],
2404
2417
  style: {
2405
2418
  ...orientation === "vertical" && {
2406
2419
  flexDirection: "column",
@@ -2463,7 +2476,7 @@ const seekbarStyle = {
2463
2476
  display: "flex",
2464
2477
  alignItems: "center",
2465
2478
  minWidth: "0",
2466
- height: "24px",
2479
+ height: "0.25rem",
2467
2480
  fontSize: "75%",
2468
2481
  letterSpacing: "1px",
2469
2482
  color: "#fff"
@@ -2511,13 +2524,13 @@ const segmentedTrackStyle = {
2511
2524
  boxSizing: "border-box",
2512
2525
  position: "relative",
2513
2526
  margin: "0 2px",
2514
- height: "24px",
2515
- borderTop: "calc(12px - 0.3em) solid transparent",
2516
- borderBottom: "calc(12px - 0.3em) solid transparent",
2527
+ height: "0.25rem",
2528
+ borderTop: "0 solid transparent",
2529
+ borderBottom: "0 solid transparent",
2517
2530
  background: "transparent",
2518
2531
  "&:hover": { transform: "scale(1, 1.5)" },
2519
2532
  "> div": {
2520
- height: "0.6em",
2533
+ height: "0.25rem",
2521
2534
  backgroundColor: "rgba(255, 255, 255, 0.2)",
2522
2535
  "&:not(:first-of-type)": {
2523
2536
  position: "absolute",
@@ -2589,10 +2602,13 @@ const Seekbar$1 = ({ style: style$8, classes, startTime = 0, currentTime, buffer
2589
2602
  ref.current = element;
2590
2603
  },
2591
2604
  css: [seekbarStyle, style$8],
2592
- style: rect && {
2593
- "--seekbar-left": `${rect.left}px`,
2594
- "--seekbar-right": `${rect.right}px`,
2595
- "--pointer-x": `${pointerState.x}px`
2605
+ style: {
2606
+ height: "0.25rem",
2607
+ ...rect && {
2608
+ "--seekbar-left": `${rect.left}px`,
2609
+ "--seekbar-right": `${rect.right}px`,
2610
+ "--pointer-x": `${pointerState.x}px`
2611
+ }
2596
2612
  },
2597
2613
  children: [
2598
2614
  !timeDisplay ? "" : pointerActive ? /* @__PURE__ */ jsx$1(FormattedTime, { time: pointerState.value }) : /* @__PURE__ */ jsx$1(FormattedTime, { time: Math.min(Math.max(0, currentTime), duration) }),
@@ -2924,7 +2940,7 @@ const CloseButton = (props) => /* @__PURE__ */ jsx$1("button", {
2924
2940
  css: mobileStyle$1.dismiss,
2925
2941
  ...props
2926
2942
  });
2927
- const DesktopContainer$1 = ({ open, style: style$8, children, onClose, ...rest }) => /* @__PURE__ */ jsx$1("div", {
2943
+ const DesktopContainer$3 = ({ open, style: style$8, children, onClose, ...rest }) => /* @__PURE__ */ jsx$1("div", {
2928
2944
  css: [style$8, open && desktopStyle$1.open],
2929
2945
  ...rest,
2930
2946
  children
@@ -2936,7 +2952,7 @@ const Settings = ({ open, values, sections: originalSections, type: uiType, clos
2936
2952
  quality: true,
2937
2953
  speed: true,
2938
2954
  loop: true
2939
- }, slots = { root: uiType === "desktop" ? DesktopContainer$1 : SwipeableDrawer_default }, onChange, onOpen, onClose }) => {
2955
+ }, slots = { root: uiType === "desktop" ? DesktopContainer$3 : SwipeableDrawer_default }, onChange, onOpen, onClose }) => {
2940
2956
  const sections = originalSections.filter((section) => enabledSettingSections[section.name]);
2941
2957
  const Container = slots.root;
2942
2958
  const ButtonWrap = buttonPosition === "top-right" ? TitleBarExtension : FunctionBarExtension;
@@ -3022,7 +3038,7 @@ var Settings_default = Settings;
3022
3038
 
3023
3039
  //#endregion
3024
3040
  //#region src/playerUi/OverlayPanel.js
3025
- const containerStyle$4 = {
3041
+ const containerStyle$5 = {
3026
3042
  position: "absolute",
3027
3043
  zIndex: "2",
3028
3044
  top: "0",
@@ -3038,12 +3054,12 @@ const openStyle$2 = {
3038
3054
  transition: "opacity 0.2s ease, transform 0s"
3039
3055
  };
3040
3056
  const DefaultContainer = ({ open, containerRef, children }) => /* @__PURE__ */ jsx$1("div", {
3041
- css: [containerStyle$4, open && openStyle$2],
3057
+ css: [containerStyle$5, open && openStyle$2],
3042
3058
  ref: containerRef,
3043
3059
  onClick: (event) => event.stopPropagation(),
3044
3060
  children
3045
3061
  });
3046
- const desktopContainerStyle$1 = {
3062
+ const desktopContainerStyle$2 = {
3047
3063
  position: "absolute",
3048
3064
  zIndex: "2",
3049
3065
  bottom: "calc(3em + var(--bottom-spacing, 0rem))",
@@ -3059,25 +3075,25 @@ const DesktopOpenStyle = {
3059
3075
  transform: "translateY(0)",
3060
3076
  transition: "opacity 0.2s ease, transform 0s"
3061
3077
  };
3062
- const DesktopContainer = ({ open, containerRef, children, onClose, ...rest }) => /* @__PURE__ */ jsx$1("div", {
3063
- css: [desktopContainerStyle$1, open && DesktopOpenStyle],
3078
+ const DesktopContainer$2 = ({ open, containerRef, children, onClose, ...rest }) => /* @__PURE__ */ jsx$1("div", {
3079
+ css: [desktopContainerStyle$2, open && DesktopOpenStyle],
3064
3080
  ref: containerRef,
3065
3081
  onClick: (event) => event.stopPropagation(),
3066
3082
  ...rest,
3067
3083
  children
3068
3084
  });
3069
- const OverlayPanel = ({ buttonIcon, title, uiType = isDesktop() ? "desktop" : "mobile", children, slots = { root: uiType === "desktop" ? DesktopContainer : DefaultContainer }, ...rest }) => {
3085
+ const OverlayPanel = ({ buttonIcon, title, uiType = isDesktop() ? "desktop" : "mobile", children, slots = { root: uiType === "desktop" ? DesktopContainer$2 : DefaultContainer }, ...rest }) => {
3070
3086
  const components = { root: slots.root };
3071
3087
  const ButtonWrap = uiType === "desktop" ? FunctionBarExtension : TitleBarExtension;
3072
3088
  const [open, setOpen] = useState(false);
3073
3089
  const onOpen = (event) => {
3074
3090
  setTimeout(() => setOpen(true), 1);
3075
3091
  const container = event.currentTarget;
3076
- const closeMenu$1 = () => setOpen(false);
3092
+ const closeMenu$2 = () => setOpen(false);
3077
3093
  container.dispatchEvent(new CustomEvent("focus-menu", {
3078
3094
  detail: {
3079
3095
  status: "open",
3080
- closeMenu: closeMenu$1
3096
+ closeMenu: closeMenu$2
3081
3097
  },
3082
3098
  bubbles: true
3083
3099
  }));
@@ -3115,7 +3131,7 @@ var OverlayPanel_default = OverlayPanel;
3115
3131
 
3116
3132
  //#endregion
3117
3133
  //#region src/playerUi/MenuItem.js
3118
- const menuItemStyle = {
3134
+ const menuItemStyle$1 = {
3119
3135
  padding: "var(--menu-item-padding, 0.5em 1em) ",
3120
3136
  display: "flex",
3121
3137
  alignItems: "center",
@@ -3129,7 +3145,7 @@ const menuItemStyle = {
3129
3145
  textOverflow: "ellipsis"
3130
3146
  }
3131
3147
  };
3132
- const menuItemSelectedStyle = {
3148
+ const menuItemSelectedStyle$1 = {
3133
3149
  color: "#FFF",
3134
3150
  fontWeight: "500",
3135
3151
  "::after": {
@@ -3144,7 +3160,7 @@ const menuItemSelectedStyle = {
3144
3160
  }
3145
3161
  };
3146
3162
  const MenuItem = ({ label, selected, onClick }) => /* @__PURE__ */ jsx$1("div", {
3147
- css: [menuItemStyle, selected && menuItemSelectedStyle],
3163
+ css: [menuItemStyle$1, selected && menuItemSelectedStyle$1],
3148
3164
  onClick,
3149
3165
  children: /* @__PURE__ */ jsx$1("div", { children: /* @__PURE__ */ jsx$1(FormattedMessage, {
3150
3166
  id: `KKS.SETTING.${label}`,
@@ -3173,7 +3189,7 @@ const landscapeStyle = {
3173
3189
  borderLeft: "1px solid transparent"
3174
3190
  }
3175
3191
  };
3176
- const containerStyle$3 = {
3192
+ const containerStyle$4 = {
3177
3193
  fontSize: "16px",
3178
3194
  background: "#262626",
3179
3195
  height: "100%",
@@ -3207,7 +3223,7 @@ const twoColumnStyle = {
3207
3223
  textOverflow: "ellipsis"
3208
3224
  }
3209
3225
  };
3210
- const desktopContainerStyle = {
3226
+ const desktopContainerStyle$1 = {
3211
3227
  paddingBottom: "1.5em",
3212
3228
  width: "34em",
3213
3229
  minHeight: "min(30.5vh, calc(100vh - 16em))",
@@ -3243,16 +3259,16 @@ const desktop2ColumnStyle = {
3243
3259
  fontWeight: "700"
3244
3260
  }
3245
3261
  };
3246
- const closeMenu = (event) => event.currentTarget.dispatchEvent(new CustomEvent("close-menu", { bubbles: true }));
3262
+ const closeMenu$1 = (event) => event.currentTarget.dispatchEvent(new CustomEvent("close-menu", { bubbles: true }));
3247
3263
  const LanguageMenu = ({ uiType = "mobile", title = "音声 ・ 字幕", sections = ["音声", "字幕"], sectionOptions = [], onChange }) => /* @__PURE__ */ jsxs$1("div", {
3248
3264
  css: [
3249
- containerStyle$3,
3265
+ containerStyle$4,
3250
3266
  twoColumnStyle,
3251
- uiType === "desktop" && [desktopContainerStyle, desktop2ColumnStyle]
3267
+ uiType === "desktop" && [desktopContainerStyle$1, desktop2ColumnStyle]
3252
3268
  ],
3253
3269
  children: [/* @__PURE__ */ jsxs$1("h3", { children: [uiType !== "desktop" && /* @__PURE__ */ jsx$1(Button, {
3254
3270
  startIcon: "close",
3255
- onClick: closeMenu
3271
+ onClick: closeMenu$1
3256
3272
  }), title] }), /* @__PURE__ */ jsxs$1("div", { children: [
3257
3273
  /* @__PURE__ */ jsxs$1("div", { children: [/* @__PURE__ */ jsx$1("div", { children: sections[0] }), sectionOptions[0].map((option) => /* @__PURE__ */ jsx$1(MenuItem_default, {
3258
3274
  ...option,
@@ -3265,8 +3281,8 @@ const LanguageMenu = ({ uiType = "mobile", title = "音声 ・ 字幕", sections
3265
3281
  }))] })
3266
3282
  ] })]
3267
3283
  });
3268
- LanguageMenu.styles = containerStyle$3;
3269
- LanguageMenu.desktopStyles = desktopContainerStyle;
3284
+ LanguageMenu.styles = containerStyle$4;
3285
+ LanguageMenu.desktopStyles = desktopContainerStyle$1;
3270
3286
  var LanguageMenu_default = LanguageMenu;
3271
3287
 
3272
3288
  //#endregion
@@ -3403,10 +3419,11 @@ const sliderStyles = {
3403
3419
  },
3404
3420
  horizontal: {
3405
3421
  width: "5em",
3406
- "> div:first-of-type": { height: "0.25em" }
3422
+ "> div:first-of-type": { height: "0.25em" },
3423
+ marginRight: "1em"
3407
3424
  }
3408
3425
  };
3409
- const VolumeControl = ({ slider = "vertical", style: style$8, subscribe, onChange, toggleMute: toggleMute$2, onAudioMuteSettingChange, ...rest }) => {
3426
+ const VolumeControl = ({ slider = "horizontal", style: style$8, subscribe, onChange, toggleMute: toggleMute$2, onAudioMuteSettingChange, ...rest }) => {
3410
3427
  const sliderOrientation = getSliderOrientation(slider);
3411
3428
  const [{ volume, muted }, setState] = useState({
3412
3429
  muted: false,
@@ -3629,19 +3646,454 @@ const CastUi = ({ onBack, onStateChange, source, onCastStarted, onLoad, values,
3629
3646
  return /* @__PURE__ */ jsxs$1(Fragment$1, { children: [connectionState === CastState.CONNECTED && /* @__PURE__ */ jsx$1(CastOverlay_default, {
3630
3647
  onBack,
3631
3648
  ...castContent
3632
- }), /* @__PURE__ */ jsx$1(FunctionBarExtension, { children: /* @__PURE__ */ jsx$1(slots.CastButton, {
3633
- onChange: onConnectionStateChange,
3634
- onCastStarted: handleCastStarted,
3635
- onLoad,
3636
- onStateChange: onConnectionStateChange,
3637
- playlist: [],
3638
- playlistStartIndex: 0,
3639
- source,
3640
- values
3641
- }) })] });
3649
+ }), /* @__PURE__ */ jsx$1(TitleBarExtension, {
3650
+ position: "right",
3651
+ children: /* @__PURE__ */ jsx$1(slots.CastButton, {
3652
+ onChange: onConnectionStateChange,
3653
+ onCastStarted: handleCastStarted,
3654
+ onLoad,
3655
+ onStateChange: onConnectionStateChange,
3656
+ playlist: [],
3657
+ playlistStartIndex: 0,
3658
+ source,
3659
+ values
3660
+ })
3661
+ })] });
3642
3662
  };
3643
3663
  var CastUi_default = CastUi;
3644
3664
 
3665
+ //#endregion
3666
+ //#region src/playerUi/SingleLayerMenu.js
3667
+ const dragHandleStyle = {
3668
+ width: "48px",
3669
+ height: "6px",
3670
+ margin: "1rem auto",
3671
+ borderRadius: "0.75em",
3672
+ background: "rgba(255, 255, 255, 0.3)",
3673
+ cursor: "grab",
3674
+ "&:active": { cursor: "grabbing" }
3675
+ };
3676
+ const sharedUlStyle = {
3677
+ margin: 0,
3678
+ padding: 0,
3679
+ listStyle: "none"
3680
+ };
3681
+ const sharedH3BaseStyle = {
3682
+ margin: 0,
3683
+ fontSize: "1rem",
3684
+ color: "rgba(255, 255, 255, 1)"
3685
+ };
3686
+ const sharedDivLastChildBaseStyle = {
3687
+ padding: "0.5em 1.0em",
3688
+ fontSize: "14px",
3689
+ color: "rgba(255, 255, 255, 0.6)"
3690
+ };
3691
+ const containerStyle$3 = {
3692
+ fontSize: "16px",
3693
+ height: "100%",
3694
+ maxHeight: "70vh",
3695
+ borderRadius: "1em 1em 0 0",
3696
+ background: "#262626",
3697
+ paddingTop: "0.5rem",
3698
+ display: "flex",
3699
+ flexDirection: "column",
3700
+ overflow: "hidden",
3701
+ h3: {
3702
+ ...sharedH3BaseStyle,
3703
+ padding: "1em",
3704
+ display: "flex",
3705
+ alignItems: "center",
3706
+ flexShrink: 0
3707
+ },
3708
+ ul: {
3709
+ ...sharedUlStyle,
3710
+ overflowY: "auto",
3711
+ overscrollBehavior: "contain",
3712
+ flex: "1 1 auto",
3713
+ minHeight: 0
3714
+ },
3715
+ "> div:last-child": {
3716
+ ...sharedDivLastChildBaseStyle,
3717
+ lineHeight: "1.4",
3718
+ flexShrink: 0,
3719
+ "> div": { padding: "0.5em 1em" }
3720
+ }
3721
+ };
3722
+ const desktopContainerStyle = {
3723
+ fontSize: "16px",
3724
+ width: "22.5em",
3725
+ minHeight: "30.5%",
3726
+ maxHeight: "63.5%",
3727
+ borderRadius: "1em",
3728
+ background: "rgba(0, 0, 0, 0.8)",
3729
+ h3: {
3730
+ ...sharedH3BaseStyle,
3731
+ borderRadius: "1em 1em 0 0",
3732
+ padding: "1.0em",
3733
+ background: "rgba(0, 0, 0, 0.8)"
3734
+ },
3735
+ ul: sharedUlStyle,
3736
+ "> div:last-child": {
3737
+ ...sharedDivLastChildBaseStyle,
3738
+ background: "rgba(0, 0, 0, 0.8)",
3739
+ borderRadius: "0 0 1em 1em",
3740
+ paddingBottom: "1.5em"
3741
+ }
3742
+ };
3743
+ const menuItemStyle = { "::before": {
3744
+ content: "\" \"",
3745
+ display: "inline-block",
3746
+ flex: "0 0 1em",
3747
+ height: "1em",
3748
+ marginRight: "0.5em",
3749
+ backgroundColor: "#EB5505",
3750
+ maskSize: "contain",
3751
+ maskImage: `url(${icon_default.check})`,
3752
+ opacity: 0
3753
+ } };
3754
+ const menuItemSelectedStyle = { "::before": { opacity: 1 } };
3755
+ const closeMenu = (event) => event.currentTarget.dispatchEvent(new CustomEvent("close-menu", { bubbles: true }));
3756
+ const isValueEqual = (value1, value2) => {
3757
+ if (typeof value1 !== "object" || value1 === null || typeof value2 !== "object" || value2 === null) return value1 === value2;
3758
+ if (value1.id !== void 0 && value2.id !== void 0) return value1.id === value2.id;
3759
+ return value1 === value2;
3760
+ };
3761
+ const SingleLayerMenu = ({ uiType = "mobile", title = "再生速度", options = [], selectedValue = 1, onChange }) => {
3762
+ const regularOptions = options.filter((option) => option.type !== "info");
3763
+ const infoOptions = options.filter((option) => option.type === "info");
3764
+ return /* @__PURE__ */ jsxs$1("div", {
3765
+ css: [uiType === "desktop" ? desktopContainerStyle : containerStyle$3, infoOptions.length === 0 && { "> ul > li:last-child > div:last-child": { borderRadius: "0 0 1em 1em" } }],
3766
+ children: [
3767
+ uiType !== "desktop" && /* @__PURE__ */ jsx$1("div", { css: dragHandleStyle }),
3768
+ /* @__PURE__ */ jsx$1("h3", { children: title }),
3769
+ /* @__PURE__ */ jsx$1("ul", { children: regularOptions.map((option) => {
3770
+ const isSelected = isValueEqual(selectedValue, option.value);
3771
+ return /* @__PURE__ */ jsx$1("li", { children: /* @__PURE__ */ jsx$1("div", {
3772
+ role: "menuitemradio",
3773
+ "aria-checked": isSelected,
3774
+ tabIndex: 0,
3775
+ css: [
3776
+ {
3777
+ padding: "1em",
3778
+ display: "flex",
3779
+ alignItems: "center",
3780
+ minWidth: 0,
3781
+ color: isSelected ? "#EB5505" : "rgba(255, 255, 255, 1)",
3782
+ background: uiType === "desktop" ? "rgba(0, 0, 0, 0.8)" : "#262626",
3783
+ cursor: "pointer"
3784
+ },
3785
+ menuItemStyle,
3786
+ isSelected && menuItemSelectedStyle
3787
+ ],
3788
+ onClick: (event) => {
3789
+ onChange?.(option.value, option);
3790
+ closeMenu(event);
3791
+ },
3792
+ onKeyDown: (event) => {
3793
+ if (event.key === "Enter" || event.key === " ") {
3794
+ event.preventDefault();
3795
+ onChange?.(option.value, option);
3796
+ closeMenu(event);
3797
+ }
3798
+ },
3799
+ children: option.label
3800
+ }) }, option.value);
3801
+ }) }),
3802
+ infoOptions.length > 0 && /* @__PURE__ */ jsx$1("div", { children: infoOptions.map((option) => /* @__PURE__ */ jsxs$1("div", {
3803
+ css: { padding: "0.5rem" },
3804
+ children: [/* @__PURE__ */ jsx$1("svg", {
3805
+ xmlns: "http://www.w3.org/2000/svg",
3806
+ width: "4",
3807
+ height: "4",
3808
+ viewBox: "0 0 4 4",
3809
+ fill: "none",
3810
+ children: /* @__PURE__ */ jsx$1("circle", {
3811
+ cx: "2",
3812
+ cy: "2",
3813
+ r: "2",
3814
+ fill: "#999999"
3815
+ })
3816
+ }), option.label]
3817
+ }, option.value)) })
3818
+ ]
3819
+ });
3820
+ };
3821
+ var SingleLayerMenu_default = SingleLayerMenu;
3822
+
3823
+ //#endregion
3824
+ //#region src/playerUi/SpeedButton.js
3825
+ const desktopOverlayStyle$1 = {
3826
+ position: "absolute",
3827
+ zIndex: "1",
3828
+ bottom: "calc(5em + var(--bottom-spacing, 0rem))",
3829
+ right: "1rem",
3830
+ display: "flex",
3831
+ alignItems: "flex-end",
3832
+ outline: "none",
3833
+ opacity: "1",
3834
+ transform: "translateY(-100vh)"
3835
+ };
3836
+ const desktopOverlayOpenStyle$1 = {
3837
+ position: "fixed",
3838
+ opacity: "0.8",
3839
+ transform: "translate(-5vw, -5vh)",
3840
+ transition: "opacity 0.2s ease, transform 0s"
3841
+ };
3842
+ const DesktopContainer$1 = ({ open, style: style$8, children, containerRef, ...rest }) => /* @__PURE__ */ jsx$1("div", {
3843
+ ref: containerRef,
3844
+ css: [style$8, open && desktopOverlayOpenStyle$1],
3845
+ onClick: (e) => e.stopPropagation(),
3846
+ role: "dialog",
3847
+ "aria-modal": "true",
3848
+ tabIndex: -1,
3849
+ ...rest,
3850
+ children
3851
+ });
3852
+ const SpeedButton = ({ uiType = "mobile", speed = 1, speedSection, isLive = false, open: controlledOpen, onChange, disabled, onOpen, onClose }) => {
3853
+ const [internalOpen, setInternalOpen] = useState(false);
3854
+ const open = controlledOpen !== void 0 ? controlledOpen : internalOpen;
3855
+ const buttonRef = useRef();
3856
+ const containerRef = useRef();
3857
+ const handleClick = (event) => {
3858
+ event.stopPropagation();
3859
+ const newOpen = !open;
3860
+ if (controlledOpen === void 0) setInternalOpen(newOpen);
3861
+ if (newOpen) onOpen?.();
3862
+ else onClose?.();
3863
+ };
3864
+ const handleChange = (value, option) => {
3865
+ onChange?.(value, option);
3866
+ if (controlledOpen === void 0) setInternalOpen(false);
3867
+ onClose?.();
3868
+ };
3869
+ const handleClose = () => {
3870
+ if (controlledOpen === void 0) setInternalOpen(false);
3871
+ onClose?.();
3872
+ };
3873
+ useEffect(() => {
3874
+ if (open) {
3875
+ const handleCloseMenu = () => {
3876
+ if (controlledOpen === void 0) setInternalOpen(false);
3877
+ onClose?.();
3878
+ };
3879
+ const removeCloseMenuListener = on(document, "close-menu", handleCloseMenu);
3880
+ if (uiType === "desktop") {
3881
+ const handleOutsideClick = (event) => {
3882
+ if (containerRef.current && !containerRef.current.contains(event.target) && !buttonRef.current?.contains(event.target)) {
3883
+ if (controlledOpen === void 0) setInternalOpen(false);
3884
+ onClose?.();
3885
+ }
3886
+ };
3887
+ const removeOutsideClickListener = on(document, "click", handleOutsideClick);
3888
+ return () => {
3889
+ removeCloseMenuListener();
3890
+ removeOutsideClickListener();
3891
+ };
3892
+ }
3893
+ return removeCloseMenuListener;
3894
+ }
3895
+ }, [
3896
+ open,
3897
+ uiType,
3898
+ onClose
3899
+ ]);
3900
+ if (isLive || !speedSection) return null;
3901
+ const speedOptions = Array.isArray(speedSection) ? speedSection : Array.isArray(speedSection?.items) ? speedSection.items : [];
3902
+ const speedLabel = speed === 1 ? "1x" : `${speed}x`;
3903
+ const Container = uiType === "desktop" ? DesktopContainer$1 : SwipeableDrawer_default;
3904
+ const menuOptions = speedOptions.map((option) => ({
3905
+ label: (option.value === 1 ? "1x (デフォルト)" : `${option.value}x`) || option.label,
3906
+ value: option.value
3907
+ }));
3908
+ const infoOptions = [{
3909
+ type: "info",
3910
+ label: "ビデオプレーヤーを閉じると、再生速度はデフォルトにリセットされます。デフォルト設定は、マイページ>設定から変更可能です。",
3911
+ value: "info1"
3912
+ }, {
3913
+ type: "info",
3914
+ label: "再生速度を変更した場合、お客様の通信状況によっては正しく再生できない場合があります。",
3915
+ value: "info2"
3916
+ }];
3917
+ const allOptions = [...menuOptions, ...infoOptions];
3918
+ return /* @__PURE__ */ jsxs$1(Fragment$1, { children: [/* @__PURE__ */ jsxs$1("button", {
3919
+ ref: buttonRef,
3920
+ type: "button",
3921
+ css: {
3922
+ border: "none",
3923
+ outline: "none",
3924
+ cursor: disabled ? "default" : "pointer",
3925
+ padding: "0.75em 0.5em",
3926
+ flexShrink: 0,
3927
+ backgroundColor: "transparent",
3928
+ userSelect: "none",
3929
+ display: "flex",
3930
+ alignItems: "center",
3931
+ gap: "0.25em",
3932
+ opacity: disabled ? .5 : 1,
3933
+ "> *": { pointerEvents: "none" }
3934
+ },
3935
+ onClick: handleClick,
3936
+ disabled,
3937
+ title: speedLabel,
3938
+ children: [/* @__PURE__ */ jsx$1(Icon_default, { type: "speed" }), /* @__PURE__ */ jsx$1("span", {
3939
+ style: {
3940
+ fontSize: "1em",
3941
+ color: "rgba(255, 255, 255, 1)"
3942
+ },
3943
+ children: speedLabel
3944
+ })]
3945
+ }), createPortal(/* @__PURE__ */ jsx$1(Container, {
3946
+ style: uiType === "desktop" ? desktopOverlayStyle$1 : void 0,
3947
+ open,
3948
+ onClose: handleClose,
3949
+ containerRef: uiType === "desktop" ? containerRef : void 0,
3950
+ onClick: (e) => e.stopPropagation(),
3951
+ children: /* @__PURE__ */ jsx$1(SingleLayerMenu_default, {
3952
+ uiType,
3953
+ title: "再生速度",
3954
+ options: allOptions,
3955
+ selectedValue: speed,
3956
+ onChange: handleChange
3957
+ })
3958
+ }), getTopElement())] });
3959
+ };
3960
+ var SpeedButton_default = SpeedButton;
3961
+
3962
+ //#endregion
3963
+ //#region src/playerUi/SubtitleButton.js
3964
+ const desktopOverlayStyle = {
3965
+ position: "absolute",
3966
+ zIndex: "1",
3967
+ bottom: "calc(5em + var(--bottom-spacing, 0rem))",
3968
+ right: "1rem",
3969
+ display: "flex",
3970
+ alignItems: "flex-end",
3971
+ outline: "none",
3972
+ opacity: "1",
3973
+ transform: "translateY(-100vh)"
3974
+ };
3975
+ const desktopOverlayOpenStyle = {
3976
+ position: "fixed",
3977
+ opacity: "0.8",
3978
+ transform: "translate(-5vw, -5vh)",
3979
+ transition: "opacity 0.2s ease, transform 0s"
3980
+ };
3981
+ const DesktopContainer = ({ open, style: style$8, children, containerRef }) => /* @__PURE__ */ jsx$1("div", {
3982
+ ref: containerRef,
3983
+ css: [style$8, open && desktopOverlayOpenStyle],
3984
+ onClick: (e) => e.stopPropagation(),
3985
+ onKeyDown: (e) => e.stopPropagation(),
3986
+ role: "presentation",
3987
+ tabIndex: -1,
3988
+ children
3989
+ });
3990
+ const SubtitleButton = ({ uiType = "mobile", subtitle = {
3991
+ language: "off",
3992
+ id: "off"
3993
+ }, subtitleSection, isLive = false, open: controlledOpen, onChange, disabled, onOpen, onClose }) => {
3994
+ const [internalOpen, setInternalOpen] = useState(false);
3995
+ const open = controlledOpen !== void 0 ? controlledOpen : internalOpen;
3996
+ const buttonRef = useRef();
3997
+ const containerRef = useRef();
3998
+ const handleClick = (event) => {
3999
+ event.stopPropagation();
4000
+ const newOpen = !open;
4001
+ if (controlledOpen === void 0) setInternalOpen(newOpen);
4002
+ if (newOpen) onOpen?.();
4003
+ else onClose?.();
4004
+ };
4005
+ const handleChange = (value, option) => {
4006
+ onChange?.(value, option);
4007
+ if (controlledOpen === void 0) setInternalOpen(false);
4008
+ onClose?.();
4009
+ };
4010
+ const handleClose = () => {
4011
+ if (controlledOpen === void 0) setInternalOpen(false);
4012
+ onClose?.();
4013
+ };
4014
+ useEffect(() => {
4015
+ if (open) {
4016
+ const handleCloseMenu = () => {
4017
+ if (controlledOpen === void 0) setInternalOpen(false);
4018
+ onClose?.();
4019
+ };
4020
+ const removeCloseMenuListener = on(document, "close-menu", handleCloseMenu);
4021
+ if (uiType === "desktop") {
4022
+ const handleOutsideClick = (event) => {
4023
+ if (containerRef.current && !containerRef.current.contains(event.target) && !buttonRef.current?.contains(event.target)) {
4024
+ if (controlledOpen === void 0) setInternalOpen(false);
4025
+ onClose?.();
4026
+ }
4027
+ };
4028
+ const removeOutsideClickListener = on(document, "click", handleOutsideClick);
4029
+ return () => {
4030
+ removeCloseMenuListener();
4031
+ removeOutsideClickListener();
4032
+ };
4033
+ }
4034
+ return removeCloseMenuListener;
4035
+ }
4036
+ }, [
4037
+ open,
4038
+ uiType,
4039
+ onClose
4040
+ ]);
4041
+ if (isLive || !subtitleSection) return null;
4042
+ const subtitleOptions = Array.isArray(subtitleSection) ? subtitleSection : Array.isArray(subtitleSection?.items) ? subtitleSection.items : [];
4043
+ const getSubtitleLabel = () => {
4044
+ if (!subtitle || subtitle.language === "off" || subtitle.id === "off") return "オフ";
4045
+ return subtitleOptions.find((option) => option.value?.id === subtitle.id)?.label || subtitle.label || "オフ";
4046
+ };
4047
+ const subtitleLabel = getSubtitleLabel();
4048
+ const Container = uiType === "desktop" ? DesktopContainer : SwipeableDrawer_default;
4049
+ const menuOptions = [{
4050
+ label: "オフ",
4051
+ value: {
4052
+ language: "off",
4053
+ id: "off"
4054
+ }
4055
+ }, ...subtitleOptions.map((option) => ({
4056
+ label: option.label || option.value?.label || "Unknown",
4057
+ value: option.value
4058
+ }))];
4059
+ return /* @__PURE__ */ jsxs$1(Fragment$1, { children: [/* @__PURE__ */ jsx$1("button", {
4060
+ ref: buttonRef,
4061
+ type: "button",
4062
+ css: {
4063
+ border: "none",
4064
+ outline: "none",
4065
+ cursor: disabled ? "default" : "pointer",
4066
+ padding: "0.75em 0.5em",
4067
+ flexShrink: 0,
4068
+ backgroundColor: "transparent",
4069
+ userSelect: "none",
4070
+ display: "flex",
4071
+ alignItems: "center",
4072
+ gap: "0.25em",
4073
+ opacity: disabled ? .5 : 1,
4074
+ "> *": { pointerEvents: "none" }
4075
+ },
4076
+ onClick: handleClick,
4077
+ disabled,
4078
+ title: subtitleLabel,
4079
+ children: /* @__PURE__ */ jsx$1(Icon_default, { type: "subtitle" })
4080
+ }), createPortal(/* @__PURE__ */ jsx$1(Container, {
4081
+ style: uiType === "desktop" ? desktopOverlayStyle : void 0,
4082
+ open,
4083
+ onClose: handleClose,
4084
+ containerRef: uiType === "desktop" ? containerRef : void 0,
4085
+ onClick: (e) => e.stopPropagation(),
4086
+ children: /* @__PURE__ */ jsx$1(SingleLayerMenu_default, {
4087
+ uiType,
4088
+ title: "字幕",
4089
+ options: menuOptions,
4090
+ selectedValue: subtitle,
4091
+ onChange: handleChange
4092
+ })
4093
+ }), getTopElement())] });
4094
+ };
4095
+ var SubtitleButton_default = SubtitleButton;
4096
+
3645
4097
  //#endregion
3646
4098
  //#region src/premium/settings.js
3647
4099
  const getSpeedItems = (items) => items.map((value) => ({
@@ -3902,7 +4354,7 @@ const showStyle = {
3902
4354
  left: 0,
3903
4355
  transition: "z-index 0s linear, opacity 0.5s ease"
3904
4356
  };
3905
- const VideoThumbnail = ({ title, className, style: style$8, time, image, x, y, width, height }) => /* @__PURE__ */ jsxs$1("div", {
4357
+ const VideoThumbnail = ({ title, className, style: style$8, time, image, x, y, width, height, ...slotProps }) => /* @__PURE__ */ jsxs$1("div", {
3906
4358
  css: [containerStyle$2, Number.isFinite(time) && time >= 0 && showStyle],
3907
4359
  className,
3908
4360
  style: {
@@ -3916,7 +4368,8 @@ const VideoThumbnail = ({ title, className, style: style$8, time, image, x, y, w
3916
4368
  width: `${width}px`,
3917
4369
  height: `${height}px`,
3918
4370
  backgroundImage: `url(${image})`,
3919
- backgroundPosition: `-${x}px -${y}px`
4371
+ backgroundPosition: `-${x}px -${y}px`,
4372
+ ...slotProps
3920
4373
  }
3921
4374
  }),
3922
4375
  title && /* @__PURE__ */ jsx$1("div", {
@@ -3936,7 +4389,7 @@ var VideoThumbnail_default = VideoThumbnail;
3936
4389
  //#endregion
3937
4390
  //#region src/premium/SeekPreview.js
3938
4391
  const at = (array, index) => index < 0 ? array[array.length + index] : array[index];
3939
- const SeekPreview = ({ thumbnailsUrl, time, chapters = [] }) => {
4392
+ const SeekPreview = ({ thumbnailsUrl, time, chapters = [], ...rest }) => {
3940
4393
  const [thumbnails, setThumbnails] = useState([]);
3941
4394
  useEffect(() => {
3942
4395
  let cancel = false;
@@ -3958,7 +4411,8 @@ const SeekPreview = ({ thumbnailsUrl, time, chapters = [] }) => {
3958
4411
  title,
3959
4412
  time,
3960
4413
  image: currentThumbnail.image,
3961
- ...currentThumbnail.position
4414
+ ...currentThumbnail.position,
4415
+ ...rest
3962
4416
  });
3963
4417
  };
3964
4418
  var SeekPreview_default = SeekPreview;
@@ -4007,12 +4461,17 @@ const LanguageSettings = ({ uiType, audioTracks = [], textTracks = [], getPlayer
4007
4461
  };
4008
4462
  const PremiumPlayer = ({ source, startTime, quality = {}, title, metadata, channelTitle, chapters, playbackState: appPlaybackState, currentTime: appCurrentTime, playbackRate: appPlaybackRate, loop, volume: appVolume, audioTrack: appAudioTrack, textTrack: appTextTrack, thumbnailsUrl, controls = { autohide: 3e3 }, marks = [], intl, settings: appSettings = defaultSettings, blocking, plugins = [], modulesConfig, uiType = isDesktop() ? "desktop" : "mobile", style: style$8, children, uiMode = "standalone", cast: castOptions = "compatible", slots, slotProps = {}, onError, onPlaybackStateChange, onBack, onCast, onChangeNext, onChangePrevious, onOpenSettings, onChangeSettings, onPlayerLoaded, onBlockedAutoplay, onPlaylogFired, ...videoProps }) => {
4009
4463
  const components = {
4464
+ root: ClassicLayout_default,
4010
4465
  VolumeControl: VolumeControl_default,
4011
4466
  CastUi: CastUi_default,
4012
4467
  DisplayTime: DisplayTime_default,
4013
4468
  LiveButton,
4014
4469
  Seekbar: Seekbar_default$1,
4015
4470
  Settings: Settings_default,
4471
+ SpeedButton: SpeedButton_default,
4472
+ SubtitleButton: SubtitleButton_default,
4473
+ NextButton,
4474
+ PreviousButton,
4016
4475
  ...slots
4017
4476
  };
4018
4477
  const videoRef = useRef();
@@ -4272,17 +4731,19 @@ const PremiumPlayer = ({ source, startTime, quality = {}, title, metadata, chann
4272
4731
  disabled: !canSeek,
4273
4732
  onClick: onForward
4274
4733
  }),
4275
- nextEpisodeButton: /* @__PURE__ */ jsx(Button, {
4734
+ nextEpisodeButton: /* @__PURE__ */ jsx(components.NextButton, {
4276
4735
  startIcon: "next",
4277
4736
  title: "KKS.PLAYER.NEXT",
4278
4737
  disabled: !onChangeNext,
4279
- onClick: changeNext
4738
+ onClick: changeNext,
4739
+ ...slotProps.nextButton
4280
4740
  }),
4281
- previousEpisodeButton: /* @__PURE__ */ jsx(Button, {
4741
+ previousEpisodeButton: /* @__PURE__ */ jsx(components.PreviousButton, {
4282
4742
  startIcon: "previous",
4283
4743
  title: "KKS.PLAYER.PREVIOUS",
4284
4744
  disabled: !onChangePrevious,
4285
- onClick: changePrevious
4745
+ onClick: changePrevious,
4746
+ ...slotProps.previousButton
4286
4747
  })
4287
4748
  },
4288
4749
  seekbar: /* @__PURE__ */ jsx(components.Seekbar, {
@@ -4300,7 +4761,8 @@ const PremiumPlayer = ({ source, startTime, quality = {}, title, metadata, chann
4300
4761
  children: activeThumbnailsUrl && /* @__PURE__ */ jsx(SeekPreview_default, {
4301
4762
  thumbnailsUrl: activeThumbnailsUrl,
4302
4763
  duration: playbackTime.duration,
4303
- chapters
4764
+ chapters,
4765
+ ...slotProps.seekPreview
4304
4766
  })
4305
4767
  }),
4306
4768
  displayTime: /* @__PURE__ */ jsx(components.DisplayTime, { ...playbackTime }),
@@ -4308,6 +4770,30 @@ const PremiumPlayer = ({ source, startTime, quality = {}, title, metadata, chann
4308
4770
  viewMode,
4309
4771
  onClick: () => toggleFullscreen(containerRef.current)
4310
4772
  }),
4773
+ speedButton: /* @__PURE__ */ jsx(components.SpeedButton, {
4774
+ uiType,
4775
+ speed: settings.values.speed,
4776
+ speedSection: settings.sections.find((s) => s.name === "speed"),
4777
+ isLive,
4778
+ open: userFocus === "speed",
4779
+ onChange: (value) => changeSettings("speed", value),
4780
+ disabled: !isUserActive,
4781
+ onOpen: () => setUserFocus("speed"),
4782
+ onClose: () => setUserFocus(""),
4783
+ ...slotProps?.speedButton
4784
+ }),
4785
+ subtitleButton: /* @__PURE__ */ jsx(components.SubtitleButton, {
4786
+ uiType,
4787
+ subtitle: settings.values.subtitles,
4788
+ subtitleSection: settings.sections.find((s) => s.name === "subtitles"),
4789
+ isLive,
4790
+ open: userFocus === "subtitle",
4791
+ onChange: (value) => changeSettings("subtitles", value),
4792
+ disabled: !isUserActive,
4793
+ onOpen: () => setUserFocus("subtitle"),
4794
+ onClose: () => setUserFocus(""),
4795
+ ...slotProps?.subtitleButton
4796
+ }),
4311
4797
  volumeControl: width >= sizes$1["small-embed"] && /* @__PURE__ */ jsx(components.VolumeControl, {
4312
4798
  subscribe,
4313
4799
  onChange,
@@ -4345,7 +4831,7 @@ const PremiumPlayer = ({ source, startTime, quality = {}, title, metadata, chann
4345
4831
  const selectedTextTrack = settings.preferred?.subtitles || appTextTrack;
4346
4832
  return /* @__PURE__ */ jsx(IntlProvider, {
4347
4833
  ...intl,
4348
- children: /* @__PURE__ */ jsxs(DefaultLayout_default, {
4834
+ children: /* @__PURE__ */ jsxs(components.root, {
4349
4835
  style: {
4350
4836
  ...style$8,
4351
4837
  cssVariables
@@ -4403,10 +4889,18 @@ const PremiumPlayer = ({ source, startTime, quality = {}, title, metadata, chann
4403
4889
  onMouseMove,
4404
4890
  children: [
4405
4891
  /* @__PURE__ */ jsx(LoadingSpinner_default, { active: waiting }),
4406
- errorData && /* @__PURE__ */ jsx(Error_default, {
4892
+ errorData && (slots?.maskError ? typeof slots.maskError === "function" ? slots.maskError({
4407
4893
  error: errorData,
4408
- onBack
4409
- }),
4894
+ onBack: slotProps?.error?.onBack
4895
+ }) : slots.maskError : /* @__PURE__ */ jsx(Error_default, {
4896
+ error: errorData,
4897
+ onBack,
4898
+ ...slotProps?.error
4899
+ })),
4900
+ isEnd && slots?.maskReplay && (typeof slots.maskReplay === "function" ? slots.maskReplay({
4901
+ replay: () => setTargetTime(0),
4902
+ back: slotProps?.error?.onBack
4903
+ }) : slots.maskReplay),
4410
4904
  children,
4411
4905
  isUserActive && /* @__PURE__ */ jsx(components.CastUi, {
4412
4906
  onBack,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kkcompany/player",
3
- "version": "2.25.0-canary.25",
3
+ "version": "2.25.0-canary.26",
4
4
  "module": "dist/index.mjs",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",