@edrlab/thorium-web 1.4.1 → 1.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/dist/{ThPreferencesAdapter-_5AePKHa.d.mts → ThPreferencesAdapter-B3a-f5v-.d.mts} +22 -17
  2. package/dist/{ThSettingsWrapper-B_9klYXH.d.mts → ThSettingsWrapper-DtzcwzYX.d.mts} +4 -4
  3. package/dist/{actions-CuRRM3rp.d.mts → actions-C33UN3Ji.d.mts} +14 -3
  4. package/dist/{actionsReducer-VFR42qgL.d.mts → actionsReducer-Bzcj3wk3.d.mts} +1 -1
  5. package/dist/{chunk-SZAVAQ6S.mjs → chunk-2B3HE57E.mjs} +42 -52
  6. package/dist/chunk-2B3HE57E.mjs.map +1 -0
  7. package/dist/{chunk-SI4FBFHM.mjs → chunk-3ITHCTDL.mjs} +157 -108
  8. package/dist/chunk-3ITHCTDL.mjs.map +1 -0
  9. package/dist/{chunk-OD75GC5N.mjs → chunk-3VB756GR.mjs} +89 -51
  10. package/dist/chunk-3VB756GR.mjs.map +1 -0
  11. package/dist/{chunk-ETLIGONP.mjs → chunk-AXX4U2FW.mjs} +25 -133
  12. package/dist/chunk-AXX4U2FW.mjs.map +1 -0
  13. package/dist/{chunk-WF2UOYO7.mjs → chunk-CCHCCVSF.mjs} +3 -3
  14. package/dist/{chunk-WF2UOYO7.mjs.map → chunk-CCHCCVSF.mjs.map} +1 -1
  15. package/dist/{chunk-RBEPH5E5.mjs → chunk-J6XDICU2.mjs} +80 -50
  16. package/dist/chunk-J6XDICU2.mjs.map +1 -0
  17. package/dist/chunk-KQ3KS5O5.mjs +37 -0
  18. package/dist/chunk-KQ3KS5O5.mjs.map +1 -0
  19. package/dist/{chunk-DQDOOTCE.mjs → chunk-KT2QY5QU.mjs} +3 -3
  20. package/dist/{chunk-DQDOOTCE.mjs.map → chunk-KT2QY5QU.mjs.map} +1 -1
  21. package/dist/{chunk-KGSFTRCH.mjs → chunk-KXOIN35D.mjs} +45 -117
  22. package/dist/chunk-KXOIN35D.mjs.map +1 -0
  23. package/dist/{chunk-E2JEGVVE.mjs → chunk-MTH2RF6V.mjs} +45 -12
  24. package/dist/chunk-MTH2RF6V.mjs.map +1 -0
  25. package/dist/{chunk-MSHUPSBI.mjs → chunk-THOJRBVD.mjs} +337 -90
  26. package/dist/chunk-THOJRBVD.mjs.map +1 -0
  27. package/dist/{chunk-VENFFPK2.mjs → chunk-VYSDLACR.mjs} +2 -2
  28. package/dist/{chunk-VENFFPK2.mjs.map → chunk-VYSDLACR.mjs.map} +1 -1
  29. package/dist/chunk-X63WSMOH.mjs +57 -0
  30. package/dist/chunk-X63WSMOH.mjs.map +1 -0
  31. package/dist/{chunk-YEVLT3AV.mjs → chunk-YE5QOQUT.mjs} +3 -3
  32. package/dist/{chunk-YEVLT3AV.mjs.map → chunk-YE5QOQUT.mjs.map} +1 -1
  33. package/dist/components/Audio/index.css +10 -0
  34. package/dist/components/Audio/index.css.map +1 -1
  35. package/dist/components/Audio/index.d.mts +12 -11
  36. package/dist/components/Audio/index.mjs +13 -12
  37. package/dist/components/Epub/index.css +10 -0
  38. package/dist/components/Epub/index.css.map +1 -1
  39. package/dist/components/Epub/index.d.mts +12 -11
  40. package/dist/components/Epub/index.mjs +14 -13
  41. package/dist/components/Misc/index.mjs +4 -4
  42. package/dist/components/Reader/index.css +10 -0
  43. package/dist/components/Reader/index.css.map +1 -1
  44. package/dist/components/Reader/index.d.mts +11 -10
  45. package/dist/components/Reader/index.mjs +21 -20
  46. package/dist/components/Reader/index.mjs.map +1 -1
  47. package/dist/components/WebPub/index.css +10 -0
  48. package/dist/components/WebPub/index.css.map +1 -1
  49. package/dist/components/WebPub/index.d.mts +12 -11
  50. package/dist/components/WebPub/index.mjs +14 -13
  51. package/dist/core/Components/index.d.mts +10 -25
  52. package/dist/core/Components/index.mjs +1 -1
  53. package/dist/core/Helpers/index.d.mts +1 -1
  54. package/dist/core/Helpers/index.mjs +3 -2
  55. package/dist/core/Hooks/index.d.mts +14 -7
  56. package/dist/core/Hooks/index.mjs +2 -1
  57. package/dist/i18n/index.mjs +2 -2
  58. package/dist/keyboardUtilities-BCP3UcLb.d.mts +30 -0
  59. package/dist/lib/index.d.mts +9 -8
  60. package/dist/lib/index.mjs +3 -2
  61. package/dist/locales/da/thorium-shared.json +217 -10
  62. package/dist/locales/he/thorium-shared.json +8 -0
  63. package/dist/locales/he/thorium-web.json +9 -0
  64. package/dist/locales/it/thorium-shared.json +2 -2
  65. package/dist/locales/it/thorium-web.json +24 -2
  66. package/dist/locales/lt/thorium-shared.json +85 -1
  67. package/dist/locales/sv/thorium-shared.json +5 -5
  68. package/dist/locales/sv/thorium-web.json +22 -0
  69. package/dist/preferences/index.d.mts +16 -23
  70. package/dist/preferences/index.mjs +4 -3
  71. package/dist/{settingsReducer-VqBhLq50.d.mts → settingsReducer-Pp9aoiiC.d.mts} +1 -1
  72. package/dist/{useAudioNavigator-CWXyNWq1.d.mts → useAudioNavigator-9RuOpLGB.d.mts} +8 -5
  73. package/dist/{useContrast-Cbso7N1l.d.mts → useContrast-Bl08zDTU.d.mts} +2 -7
  74. package/dist/{usePreferences-9ZvbcbLW.d.mts → usePreferences-Cy7-JN2x.d.mts} +4 -8
  75. package/dist/{useReaderTransitions-0hKGCvMm.d.mts → useReaderTransitions-CpgrXS5g.d.mts} +50 -23
  76. package/package.json +7 -7
  77. package/dist/chunk-44PEO3DS.mjs +0 -121
  78. package/dist/chunk-44PEO3DS.mjs.map +0 -1
  79. package/dist/chunk-E2JEGVVE.mjs.map +0 -1
  80. package/dist/chunk-ETLIGONP.mjs.map +0 -1
  81. package/dist/chunk-KGSFTRCH.mjs.map +0 -1
  82. package/dist/chunk-MSHUPSBI.mjs.map +0 -1
  83. package/dist/chunk-OD75GC5N.mjs.map +0 -1
  84. package/dist/chunk-RBEPH5E5.mjs.map +0 -1
  85. package/dist/chunk-SI4FBFHM.mjs.map +0 -1
  86. package/dist/chunk-SZAVAQ6S.mjs.map +0 -1
  87. package/dist/keyboardUtilities-BWAyLS_D.d.mts +0 -56
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/StatefulReaderRunningHead.tsx","../src/components/StatefulReaderHeader.tsx","../src/components/assets/styles/thorium-web.reader.pagination.module.css","../src/components/assets/styles/thorium-web.reader.progression.module.css","../src/core/Components/Reader/ThProgression.tsx","../src/components/StatefulReaderProgression.tsx","../src/components/StatefulReaderPagination.tsx","../src/components/StatefulReaderFooter.tsx","../src/core/Hooks/fonts/androidPatchCss.ts","../src/core/Hooks/fonts/useFonts.ts","../src/components/Settings/hooks/useZoomCallbacks.ts","../src/components/Helpers/getReaderClassNames.ts"],"names":["Fragment","jsx","wrapper","listItem","leftButton","progression","rightButton","label","useMemo","classNames","useRef","jsxs","useCallback","useEffect"],"mappings":"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","file":"chunk-KXOIN35D.mjs","sourcesContent":["\"use client\";\n\nimport { useMemo } from \"react\";\n\nimport { ThRunningHeadFormat } from \"@/preferences/models\";\nimport { ThFormatPref, ThFormatPrefValue } from \"@/preferences\";\n\nimport { ThRunningHead } from \"@/core/Components\";\n\nimport { useI18n } from \"@/i18n/useI18n\";\n\nimport { useAppSelector } from \"@/lib/hooks\";\nimport { makeBreakpointsMap } from \"@/core/Helpers/breakpointsMap\";\n\nexport const StatefulReaderRunningHead = ({ \n formatPref\n}: {\n formatPref?: ThFormatPref<ThRunningHeadFormat>;\n}) => {\n const { t } = useI18n();\n \n const unstableTimeline = useAppSelector(state => state.publication.unstableTimeline);\n const isImmersive = useAppSelector(state => state.reader.isImmersive);\n const isHovering = useAppSelector(state => state.reader.isHovering);\n const isFullscreen = useAppSelector(state => state.reader.isFullscreen);\n const breakpoint = useAppSelector(state => state.theming.containerBreakpoint);\n\n // Get the fallback format based on isFXL\n const fallbackFormat = useMemo<ThFormatPrefValue<ThRunningHeadFormat>>(() => ({\n variants: ThRunningHeadFormat.title,\n displayInImmersive: true,\n displayInFullscreen: true\n }), []);\n\n const breakpointsMap = useMemo(() => {\n return makeBreakpointsMap<ThFormatPrefValue<ThRunningHeadFormat>>({\n defaultValue: formatPref?.default || fallbackFormat,\n fromEnum: ThRunningHeadFormat,\n pref: formatPref?.breakpoints,\n validateKey: \"variants\"\n });\n }, [formatPref, fallbackFormat]);\n \n // Get current preferences with proper fallback\n const currentPrefs = useMemo(() => {\n if (!breakpoint) return formatPref?.default || fallbackFormat;\n return breakpointsMap[breakpoint] || formatPref?.default || fallbackFormat;\n }, [breakpoint, breakpointsMap, formatPref?.default, fallbackFormat]);\n\n const { variants, displayInImmersive, displayInFullscreen } = currentPrefs;\n\n const displayFormat = useMemo(() => {\n if (!variants) return ThRunningHeadFormat.title;\n \n // Check if we should hide in immersive mode\n if (isImmersive && displayInImmersive === false && !isHovering) {\n return ThRunningHeadFormat.none;\n }\n \n // Check if we should hide in fullscreen mode\n if (isImmersive && isFullscreen && displayInFullscreen === false && !isHovering) {\n return ThRunningHeadFormat.none;\n }\n \n return variants;\n }, [variants, isImmersive, displayInImmersive, isHovering, isFullscreen, displayInFullscreen]);\n\n const runningHead = useMemo(() => {\n if (displayFormat === ThRunningHeadFormat.title) {\n return unstableTimeline?.title || \"\";\n } else if (displayFormat === ThRunningHeadFormat.chapter) {\n return unstableTimeline?.progression?.currentChapter || unstableTimeline?.title || \"\";\n }\n return \"\";\n }, [displayFormat, unstableTimeline]);\n\n if (!runningHead || displayFormat === ThRunningHeadFormat.none) return null;\n \n return (\n <>\n <ThRunningHead \n label={ runningHead } \n aria-label={ t(\"reader.app.header.runningHead\") }\n />\n </>\n );\n}","\"use client\";\n\nimport React from \"react\";\n\nimport { ActionKeyType } from \"@/preferences\";\nimport { ThLayoutUI, ThRunningHeadFormat } from \"@/preferences/models\";\nimport { ThFormatPref } from \"@/preferences\";\n\nimport readerStyles from \"./assets/styles/thorium-web.reader.app.module.css\";\nimport readerHeaderStyles from \"./assets/styles/thorium-web.reader.header.module.css\";\nimport overflowMenuStyles from \"./Actions/assets/styles/thorium-web.overflow.module.css\";\n\nimport { ThHeader } from \"@/core/Components/Reader/ThHeader\";\nimport { StatefulBackLink } from \"./StatefulBackLink\";\nimport { StatefulReaderRunningHead } from \"./StatefulReaderRunningHead\";\nimport { ThInteractiveOverlay } from \"../core/Components/Reader/ThInteractiveOverlay\";\nimport { StatefulCollapsibleActionsBar } from \"./Actions/StatefulCollapsibleActionsBar\";\n\nimport { useReaderHeaderBase } from \"./hooks/useReaderHeaderBase\";\nimport { usePreferences } from \"@/preferences/hooks\";\n\nimport classNames from \"classnames\";\n\nexport const StatefulReaderHeader = ({\n actionKeys,\n actionsOrder,\n layout,\n runningHeadFormatPref\n}: {\n actionKeys: ActionKeyType[];\n actionsOrder: ActionKeyType[];\n layout: ThLayoutUI;\n runningHeadFormatPref?: ThFormatPref<ThRunningHeadFormat>;\n}) => {\n const {\n headerRef, focusWithinProps, setHover, removeHover,\n listActionItems, isImmersive, isHovering, isScroll, t,\n } = useReaderHeaderBase(actionKeys);\n\n const { preferences } = usePreferences();\n\n return (\n <>\n <ThInteractiveOverlay\n className={ classNames(readerStyles.barOverlay, readerStyles.headerOverlay) }\n isActive={ layout === ThLayoutUI.layered && isImmersive && !isHovering }\n onMouseEnter={ setHover }\n onMouseLeave={ removeHover }\n />\n\n <ThHeader\n ref={ headerRef }\n className={ classNames(readerStyles.topBar, readerHeaderStyles.header) }\n aria-label={ t(\"reader.app.header.label\") }\n onMouseEnter={ setHover }\n onMouseLeave={ removeHover }\n { ...focusWithinProps }\n >\n { preferences.theming.header?.backLink && <StatefulBackLink className={ readerHeaderStyles.backlinkWrapper } /> }\n\n <StatefulReaderRunningHead formatPref={ runningHeadFormatPref } />\n\n <StatefulCollapsibleActionsBar\n id=\"reader-header-overflowMenu\"\n items={ listActionItems() }\n prefs={{ ...preferences.actions, displayOrder: actionsOrder }}\n className={ readerHeaderStyles.actionsWrapper }\n aria-label={ t(\"reader.app.header.actions\") }\n overflowMenuClassName={\n (!isScroll || preferences.affordances.scroll.hintInImmersive)\n ? overflowMenuStyles.hint\n : undefined\n }\n />\n </ThHeader>\n </>\n );\n};\n",".wrapper {\n box-sizing: border-box;\n display: grid;\n gap: calc(var(--th-layout-spacing) / 2);\n grid-template-areas: \"pagination-start pagination-center pagination-end\";\n grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);\n background-color: var(--th-theme-background);\n color: var(--th-theme-text);\n align-items: center;\n width: 100%;\n max-width: var(--th-layout-constraints-pagination, 100%);\n}\n\n.listItem {\n box-sizing: border-box;\n list-style: none;\n}\n\n.listItem:has(.leftButton) {\n grid-area: pagination-start;\n justify-self: start;\n}\n\n.listItem:has(.progression) {\n grid-area: pagination-center;\n justify-self: center;\n}\n\n.listItem:has(.rightButton) {\n grid-area: pagination-end;\n justify-self: end;\n}\n\n\n.listItem button {\n box-sizing: border-box;\n padding: calc(var(--th-icon-size, 24px) * (1/4)) calc(var(--th-layout-spacing) / 2);\n gap: calc(var(--th-layout-spacing) / 2);\n max-height: calc(var(--th-icon-size, 24px) * 2);\n max-width: 100%;\n border-radius: var(--th-layout-radius);\n display: flex;\n align-items: center;\n}\n\n.rightButton {\n margin-inline-start: auto;\n text-align: end;\n}\n\n.listItem button[data-hovered] {\n background-color: var(--th-theme-hover);\n color: var(--th-theme-onHover);\n}\n\n.listItem button[data-focus-visible] {\n outline: 2px solid var(--th-theme-focus);\n}\n\n.listItem button[data-disabled] {\n color: var(--th-theme-disable);\n}\n\n.listItem button .label {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n white-space: normal;\n -webkit-line-clamp: 1;\n line-clamp: 1;\n}\n\n.listItem button svg {\n flex: none;\n width: var(--th-icon-size, 24px);\n height: var(--th-icon-size, 24px);\n fill: currentColor;\n}",".wrapper {\n color: var(--th-theme-text);\n font-variant-numeric: lining-nums tabular-nums;\n text-align: center;\n}","\"use client\";\n\nimport React from \"react\";\n\nexport interface ThProgressionProps extends React.HTMLAttributes<HTMLDivElement> {\n ref?: React.RefObject<HTMLDivElement>\n}\n\nexport const ThProgression = ({ \n ref,\n children, \n ...props\n}: ThProgressionProps) => {\n return (\n <>\n <div \n ref={ ref } \n {...props }\n >\n { children }\n </div>\n </>\n )\n}","\"use client\";\n\nimport { useMemo } from \"react\";\n\nimport progressionStyles from \"./assets/styles/thorium-web.reader.progression.module.css\";\n\nimport { ThProgressionFormat } from \"@/preferences/models\";\nimport { ThFormatPref, ThFormatPrefValue } from \"@/preferences\";\n\nimport { ThProgression } from \"@/core/Components/Reader/ThProgression\";\n\nimport { useI18n } from \"@/i18n/useI18n\";\n\nimport { useAppSelector } from \"@/lib/hooks\";\n\nimport { makeBreakpointsMap } from \"@/core/Helpers/breakpointsMap\";\nimport { getBestMatchingProgressionFormat } from \"@/core/Helpers/progressionFormat\";\n\nimport classNames from \"classnames\";\n\nexport const StatefulReaderProgression = ({ \n className,\n formatPref,\n fallbackVariant\n}: { \n className?: string,\n formatPref?: ThFormatPref<ThProgressionFormat | ThProgressionFormat[]>,\n fallbackVariant: ThProgressionFormat | Array<ThProgressionFormat>\n}) => {\n const { t } = useI18n();\n \n const unstableTimeline = useAppSelector(state => state.publication.unstableTimeline);\n const isImmersive = useAppSelector(state => state.reader.isImmersive);\n const isFullscreen = useAppSelector(state => state.reader.isFullscreen);\n const isHovering = useAppSelector(state => state.reader.isHovering);\n const breakpoint = useAppSelector(state => state.theming.breakpoint);\n\n \n const fallbackFormat = useMemo(() => {\n return {\n variants: fallbackVariant,\n displayInImmersive: true,\n displayInFullscreen: true\n };\n }, [fallbackVariant]);\n \n const breakpointsMap = useMemo(() => {\n return makeBreakpointsMap<ThFormatPrefValue<ThProgressionFormat | ThProgressionFormat[]>>({\n defaultValue: formatPref?.default || fallbackFormat,\n fromEnum: ThProgressionFormat,\n pref: formatPref?.breakpoints,\n validateKey: \"variants\"\n });\n }, [formatPref, fallbackFormat]);\n \n // Get current preferences with proper fallback\n const currentPrefs = useMemo(() => {\n if (!breakpoint) return formatPref?.default || fallbackFormat;\n return breakpointsMap[breakpoint] || formatPref?.default || fallbackFormat;\n }, [breakpoint, breakpointsMap, formatPref?.default, fallbackFormat]);\n\n const { variants, displayInImmersive, displayInFullscreen } = currentPrefs;\n \n // Get the display format, handling both single format and array of formats\n const displayFormat = useMemo(() => {\n if (!variants) return fallbackFormat.variants;\n \n // Check if we should hide in immersive mode\n if (isImmersive && displayInImmersive === false && !isHovering) {\n return ThProgressionFormat.none;\n }\n \n // Check if we should hide in fullscreen mode\n if (isImmersive && isFullscreen && displayInFullscreen === false && !isHovering) {\n return ThProgressionFormat.none;\n }\n \n if (Array.isArray(variants)) {\n return getBestMatchingProgressionFormat(variants, unstableTimeline?.progression) || \n fallbackFormat.variants;\n }\n \n return variants;\n }, [variants, unstableTimeline?.progression, fallbackFormat, isImmersive, isHovering, isFullscreen, displayInImmersive, displayInFullscreen]);\n\n // Compute display text based on current position and timeline\n const displayText = useMemo(() => {\n if (displayFormat === ThProgressionFormat.none || !unstableTimeline?.progression) {\n return \"\";\n }\n\n const { \n currentPositions = [],\n totalPositions,\n relativeProgression,\n totalProgression,\n currentChapter,\n positionsLeft,\n totalItems,\n currentIndex\n } = unstableTimeline.progression;\n \n let text = \"\";\n \n // Format positions for display (handle array of two positions with a dash)\n const formatPositions = (positions: number[]) => {\n if (positions.length === 2) {\n return positions.join(\"–\");\n }\n return positions[0]?.toString() || \"\";\n };\n \n switch (displayFormat) {\n case ThProgressionFormat.positions:\n if (currentPositions.length > 0) {\n text = formatPositions(currentPositions);\n }\n break;\n \n case ThProgressionFormat.positionsOfTotal:\n if (currentPositions.length > 0 && totalPositions) {\n text = t(\"reader.progression.xOfY.compact\", { \n x: formatPositions(currentPositions),\n y: totalPositions\n });\n }\n break;\n\n case ThProgressionFormat.positionsPercentOfTotal:\n if (currentPositions.length > 0 && totalPositions) {\n const percentage = Math.round((totalProgression || 0) * 100);\n text = t(\"reader.progression.xOfY.descriptive\", { \n x: formatPositions(currentPositions),\n y: totalPositions,\n z: `${ percentage }%`\n });\n }\n break;\n \n case ThProgressionFormat.positionsLeft:\n if (positionsLeft !== undefined) {\n text = t(`reader.progression.positionsLeftInChapter.descriptive`, { \n count: positionsLeft\n });\n }\n break;\n \n case ThProgressionFormat.overallProgression:\n if (totalProgression !== undefined) {\n const percentage = Math.round(totalProgression * 100);\n text = `${ percentage }%`;\n }\n break;\n \n case ThProgressionFormat.resourceProgression:\n if (relativeProgression !== undefined) {\n const percentage = Math.round(relativeProgression * 100);\n text = `${ percentage }%`;\n }\n break;\n \n case ThProgressionFormat.progressionOfResource:\n if (relativeProgression !== undefined) {\n const percentage = Math.round(relativeProgression * 100);\n text = t(\"reader.progression.xOfY.compact\", {\n x: `${ percentage }%`,\n y: currentChapter || t(\"reader.app.progression.referenceFallback\")\n });\n }\n break;\n\n case ThProgressionFormat.readingOrderIndex:\n if (currentIndex !== undefined && totalItems !== undefined) {\n text = t(\"reader.progression.xOfY.compact\", {\n x: currentIndex,\n y: totalItems\n });\n }\n break;\n }\n \n return text;\n }, [displayFormat, unstableTimeline, t]);\n\n if (!displayText || displayFormat === ThProgressionFormat.none) {\n return null;\n }\n\n return (\n <ThProgression \n id=\"current-progression\" \n className={ classNames(progressionStyles.wrapper, className) }\n aria-label={ t(\"reader.app.progression.wrapper\") }\n >\n { displayText }\n </ThProgression>\n );\n};","\"use client\";\n\nimport { useRef, KeyboardEvent } from \"react\";\n\nimport { ThPagination, ThPaginationProps } from \"@/core/Components/Reader/ThPagination\";\n\nimport readerPaginationStyles from \"./assets/styles/thorium-web.reader.pagination.module.css\";\n\nexport const StatefulReaderPagination = ({\n ref,\n links,\n compounds,\n children,\n ...props\n}: ThPaginationProps) => {\n const leftButtonRef = useRef<HTMLButtonElement>(null);\n const rightButtonRef = useRef<HTMLButtonElement>(null);\n\n const updatedCompounds = {\n ...compounds,\n leftButton: {\n ...compounds?.leftButton,\n ref: leftButtonRef,\n onKeyDown: (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n leftButtonRef.current?.blur();\n }\n }\n },\n rightButton: {\n ...compounds?.rightButton,\n ref: rightButtonRef,\n onKeyDown: (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n rightButtonRef.current?.blur();\n }\n }\n }\n };\n\n return (\n <ThPagination\n ref={ ref }\n className={ readerPaginationStyles.wrapper }\n links={ links }\n compounds={ updatedCompounds }\n { ...props }\n >\n { children }\n </ThPagination>\n )\n}\n","\"use client\";\n\nimport { useCallback, useEffect, useRef } from \"react\";\n\nimport readerStyles from \"./assets/styles/thorium-web.reader.app.module.css\";\nimport readerPaginationStyles from \"./assets/styles/thorium-web.reader.pagination.module.css\";\n\nimport { ThBreakpoints, ThLayoutUI, ThFormatPref, ThProgressionFormat } from \"@/preferences/models\";\n\nimport { ThFooter } from \"@/core/Components/Reader/ThFooter\";\nimport { StatefulReaderProgression } from \"./StatefulReaderProgression\";\nimport { ThInteractiveOverlay } from \"../core/Components/Reader/ThInteractiveOverlay\";\nimport { StatefulReaderPagination } from \"./StatefulReaderPagination\";\nimport { ThPaginationLinkProps } from \"@/core/Components/Reader/ThPagination\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useFocusWithin, useLocale } from \"react-aria\";\nimport { useI18n } from \"@/i18n/useI18n\";\n\nimport { setHovering } from \"@/lib/readerReducer\";\nimport { useAppDispatch, useAppSelector } from \"@/lib/hooks\";\nimport { useIsScroll } from \"@/hooks\";\n\nimport classNames from \"classnames\";\n\nexport const StatefulReaderFooter = ({\n layout,\n progressionFormatPref,\n progressionFormatFallback\n}: {\n layout: ThLayoutUI;\n progressionFormatPref?: ThFormatPref<ThProgressionFormat | ThProgressionFormat[]>;\n progressionFormatFallback: ThProgressionFormat | ThProgressionFormat[];\n}) => {\n const { t } = useI18n();\n const { direction } = useLocale();\n const footerRef = useRef<HTMLDivElement>(null);\n const isImmersive = useAppSelector(state => state.reader.isImmersive);\n const isHovering = useAppSelector(state => state.reader.isHovering);\n const hasScrollAffordance = useAppSelector(state => state.reader.hasScrollAffordance);\n const isRTL = useAppSelector(state => state.publication.isRTL);\n const isFXL = useAppSelector(state => state.publication.isFXL);\n const isScroll = useIsScroll();\n const breakpoint = useAppSelector(state => state.theming.containerBreakpoint);\n const reducedMotion = useAppSelector(state => state.theming.prefersReducedMotion);\n const timeline = useAppSelector(state => state.publication.unstableTimeline);\n\n const dispatch = useAppDispatch();\n\n const { focusWithinProps } = useFocusWithin({\n onFocusWithin() {\n dispatch(setHovering(true));\n },\n onBlurWithin() {\n dispatch(setHovering(false));\n }\n });\n\n const setHover = () => {\n if (!hasScrollAffordance) {\n dispatch(setHovering(true));\n }\n };\n\n const removeHover = () => {\n if (!hasScrollAffordance) {\n dispatch(setHovering(false));\n }\n };\n\n const { previousLocator, nextLocator, go } = useNavigator().unified;\n\n const buildNode = useCallback((\n locator: ReturnType<typeof previousLocator>,\n title: string | undefined,\n compactKey: string,\n descriptiveKey: string\n ) => {\n if (!locator) return undefined;\n\n return breakpoint !== ThBreakpoints.compact && breakpoint !== ThBreakpoints.medium ? (\n <>\n <span className={ readerStyles.srOnly }>{ t(descriptiveKey) }</span>\n <span className={ readerPaginationStyles.label }>{ title || locator.title || t(compactKey) }</span>\n </>\n ) : (\n <span className={ readerPaginationStyles.label }>{ t(compactKey) }</span>\n );\n }, [t, breakpoint]);\n\n const updateLinks = useCallback(() => {\n const previous = previousLocator();\n const next = nextLocator();\n\n const previousLink: ThPaginationLinkProps | undefined = previous ? {\n node: buildNode(\n previous,\n timeline?.previousItem?.title,\n isFXL ? \"reader.actions.goToPreviousPage.compact\" : \"reader.actions.goToPreviousChapter.compact\",\n isFXL ? \"reader.actions.goToPreviousPage.descriptive\" : \"reader.actions.goToPreviousChapter.descriptive\"\n ),\n onPress: () => go(previous, !reducedMotion, () => {})\n } : undefined;\n\n const nextLink: ThPaginationLinkProps | undefined = next ? {\n node: buildNode(\n next,\n timeline?.nextItem?.title,\n isFXL ? \"reader.actions.goToNextPage.compact\" : \"reader.actions.goToNextChapter.compact\",\n isFXL ? \"reader.actions.goToNextPage.descriptive\" : \"reader.actions.goToNextChapter.descriptive\"\n ),\n onPress: () => go(next, !reducedMotion, () => {})\n } : undefined;\n\n return isRTL\n ? { left: nextLink, right: previousLink }\n : { left: previousLink, right: nextLink };\n }, [go, previousLocator, nextLocator, buildNode, timeline, reducedMotion, isFXL, isRTL]);\n\n useEffect(() => {\n updateLinks();\n }, [timeline, updateLinks]);\n\n useEffect(() => {\n // Blur any focused element when entering immersive mode\n if (isImmersive) {\n const focusElement = document.activeElement;\n if (focusElement && footerRef.current?.contains(focusElement)) {\n (focusElement as HTMLElement).blur();\n }\n }\n }, [isImmersive]);\n\n return(\n <>\n <ThInteractiveOverlay\n className={ classNames(readerStyles.barOverlay, readerStyles.footerOverlay) }\n isActive={ layout === ThLayoutUI.layered && isImmersive && !isHovering }\n onMouseEnter={ setHover }\n onMouseLeave={ removeHover }\n />\n\n <ThFooter\n ref={ footerRef }\n className={ readerStyles.bottomBar }\n aria-label={ t(\"reader.app.footer.label\") }\n onMouseEnter={ setHover }\n onMouseLeave={ removeHover }\n { ...focusWithinProps }\n >\n { (isScroll)\n ? <StatefulReaderPagination\n aria-label={ t(\"reader.navigation.scroll.wrapper\") }\n links={ updateLinks() }\n dir={ direction }\n compounds={ {\n listItem: {\n className: readerPaginationStyles.listItem\n },\n leftButton: {\n className: readerPaginationStyles.leftButton,\n preventFocusOnPress: true\n },\n rightButton: {\n className: readerPaginationStyles.rightButton,\n preventFocusOnPress: true\n }\n } }\n >\n <StatefulReaderProgression\n className={ readerPaginationStyles.progression }\n formatPref={ progressionFormatPref }\n fallbackVariant={ progressionFormatFallback }\n />\n </StatefulReaderPagination>\n : <StatefulReaderProgression\n formatPref={ progressionFormatPref }\n fallbackVariant={ progressionFormatFallback }\n /> }\n </ThFooter>\n </>\n )\n}\n","export const getAndroidPatchCss = () => {\n if (typeof window === \"undefined\") {\n return \"\";\n }\n \n const origin = window.location.origin;\n \n return `/* Readium CSS\n Android Fonts Patch module\n\n A stylesheet aligning Android generic serif and sans-serif fonts on other platforms\n\n Repo: https://github.com/readium/css */\n\n/* Android resolves sans-serif to Roboto, and serif to Droid Serif \n This created issues for FXL EPUBs relying on Times (New Roman),\n Helvetica or Arial while not embedding the font files in the package.\n\n See https://github.com/readium/css/issues/149\n\n Unfortunately it is no possible to target generic family using @font-face,\n we have to target specific font-family names e.g. Times, Arial, etc.\n\n This stylesheet/patch should be loaded only for this case i.e.\n a Fixed-Layout EPUB with text but no embedded font on an Android device.\n The logic for checking these conditions are up to implementers.\n*/\n\n/* Serif (Times + Times New Roman) */\n\n@font-face {\n font-family: Times;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n\n@font-face {\n font-family: \"Times New Roman\";\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n\n@font-face {\n font-family: Times;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman-Italic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: italic;\n}\n\n@font-face {\n font-family: \"Times New Roman\";\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman-Italic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: italic;\n}\n\n@font-face {\n font-family: Times;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman-Bold.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: normal;\n}\n\n@font-face {\n font-family: \"Times New Roman\";\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman-Bold.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: normal;\n}\n\n@font-face {\n font-family: Times;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman-BoldItalic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: italic;\n}\n\n@font-face {\n font-family: \"Times New Roman\";\n src: url(\"${ new URL(\"/fonts/AndroidPatch/serif/NimbusRoman-BoldItalic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: italic;\n}\n\n/* Sans-serif (Helvetica + Arial) */\n\n@font-face {\n font-family: Helvetica;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n\n@font-face {\n font-family: Arial;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: normal;\n}\n\n@font-face {\n font-family: Helvetica;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans-Italic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: italic;\n}\n\n@font-face {\n font-family: Arial;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans-Italic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: normal;\n font-style: italic;\n}\n\n@font-face {\n font-family: Helvetica;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans-Bold.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: normal;\n}\n\n@font-face {\n font-family: Arial;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans-Bold.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: normal;\n}\n\n@font-face {\n font-family: Helvetica;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans-BoldItalic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: italic;\n}\n\n@font-face {\n font-family: Arial;\n src: url(\"${ new URL(\"/fonts/AndroidPatch/sans-serif/NimbusSans-BoldItalic.woff\", origin).toString() }\") format(\"woff\");\n font-weight: bold;\n font-style: italic;\n}`;\n};\n","\"use client\";\n\nimport { useCallback, useEffect, useRef } from \"react\";\n\nimport { InjectableFontResources } from \"@/preferences/services/fonts\";\nimport { ILinkInjectable, IUrlInjectable, IBlobInjectable } from \"@readium/navigator\";\n\nimport { getPlatform } from \"@/core/Helpers/getPlatform\";\nimport { getAndroidPatchCss } from \"./androidPatchCss\";\n\ntype FontResource = (ILinkInjectable & IUrlInjectable) | (ILinkInjectable & IBlobInjectable);\n\nexport const useFonts = (fontResources?: InjectableFontResources | null) => {\n const injectedElementsRef = useRef<{\n prepend: HTMLElement[];\n append: HTMLElement[];\n }>({\n prepend: [],\n append: []\n });\n\n const createLinkElement = useCallback((resource: FontResource): HTMLLinkElement => {\n const link = document.createElement(\"link\");\n \n // Set all custom attributes first to make sure they are\n // overridden by the core attributes\n if (\"attributes\" in resource && resource.attributes) {\n Object.entries(resource.attributes).forEach(([key, value]) => {\n link.setAttribute(key, value as string);\n });\n }\n \n link.rel = resource.rel;\n link.as = resource.as;\n \n if (\"url\" in resource) {\n link.href = resource.url;\n } else if (\"blob\" in resource && resource.blob) {\n link.href = URL.createObjectURL(resource.blob);\n }\n \n return link;\n }, []);\n\n const removeInjectedElements = useCallback(() => {\n const { prepend, append } = injectedElementsRef.current;\n \n [...prepend, ...append].forEach(element => {\n if (element.parentNode) {\n element.parentNode.removeChild(element);\n }\n // Revoke blob URLs to prevent memory leaks\n if (element instanceof HTMLLinkElement && element.href.startsWith(\"blob:\")) {\n URL.revokeObjectURL(element.href);\n }\n });\n \n injectedElementsRef.current = {\n prepend: [],\n append: []\n };\n }, []);\n\n const injectFontResources = useCallback((resources: InjectableFontResources | null) => {\n if (typeof document === \"undefined\") return;\n \n removeInjectedElements();\n \n if (!resources) return;\n \n const { prepend, append } = resources;\n const injectedElements = injectedElementsRef.current;\n \n prepend.forEach(resource => {\n const element = createLinkElement(resource);\n document.head.insertBefore(element, document.head.firstChild);\n injectedElements.prepend.push(element);\n });\n \n append.forEach(resource => {\n const element = createLinkElement(resource);\n document.head.appendChild(element);\n injectedElements.append.push(element);\n });\n }, [createLinkElement, removeInjectedElements]);\n\n const getAndroidFXLPatch = useCallback((): (ILinkInjectable & IBlobInjectable) | null => {\n const platform = getPlatform();\n const isAndroid = platform === \"android\";\n \n if (!isAndroid) {\n return null;\n }\n \n const cssContent = getAndroidPatchCss();\n const blob = new Blob([cssContent], { type: \"text/css\" });\n \n return {\n as: \"link\",\n rel: \"stylesheet\",\n blob\n };\n }, []);\n\n useEffect(() => {\n injectFontResources(fontResources || null);\n \n return () => {\n removeInjectedElements();\n };\n }, [fontResources, injectFontResources, removeInjectedElements]);\n\n return {\n injectFontResources,\n removeFontResources: removeInjectedElements,\n getAndroidFXLPatch\n };\n};","import { useCallback } from \"react\";\n\nimport { ThSettingsKeys } from \"@/preferences/models\";\nimport { usePreferences } from \"@/preferences/hooks/usePreferences\";\nimport { useAppDispatch, useAppSelector } from \"@/lib/hooks\";\nimport { setFontSize } from \"@/lib/settingsReducer\";\nimport { setWebPubZoom } from \"@/lib/webPubSettingsReducer\";\nimport { useEffectiveRange } from \"./useEffectiveRange\";\nimport { EpubPreferencesEditor, IEpubPreferences, IWebPubPreferences, WebPubPreferencesEditor } from \"@readium/navigator\";\nimport { useEpubNavigator } from \"@/core/Hooks/Epub/useEpubNavigator\";\nimport { useWebPubNavigator } from \"@/core/Hooks/WebPub/useWebPubNavigator\";\n\ntype ZoomNavigator = ReturnType<typeof useEpubNavigator> | ReturnType<typeof useWebPubNavigator>;\n\nexport const useZoomCallbacks = (navigator: ZoomNavigator) => {\n const { preferences } = usePreferences();\n const readerProfile = useAppSelector(state => state.reader.profile);\n const isFXL = useAppSelector(state => state.publication.isFXL);\n const dispatch = useAppDispatch();\n\n const isWebPub = readerProfile === \"webPub\";\n\n const getSetting = navigator.getSetting as (key: string) => number | null | undefined;\n const submitPreferences = navigator.submitPreferences as (prefs: IEpubPreferences | IWebPubPreferences) => Promise<void>;\n const { preferencesEditor } = navigator;\n\n const supportedRange = isWebPub\n ? (preferencesEditor as WebPubPreferencesEditor)?.zoom?.supportedRange\n : isFXL\n ? (preferencesEditor as unknown as WebPubPreferencesEditor)?.zoom?.supportedRange\n : (preferencesEditor as EpubPreferencesEditor)?.fontSize?.supportedRange;\n\n const zoomConfig = preferences.settings.keys[ThSettingsKeys.zoom];\n const { range } = useEffectiveRange(zoomConfig.range, supportedRange);\n const [min, max] = range;\n const step = zoomConfig.step ?? 0.05;\n\n const zoomIn = useCallback(async () => {\n if (isWebPub) {\n const next = Math.min(max, (getSetting(\"zoom\") ?? 1) + step);\n await submitPreferences({ zoom: next });\n dispatch(setWebPubZoom(getSetting(\"zoom\")));\n } else {\n const next = Math.min(max, (getSetting(\"fontSize\") ?? 1) + step);\n await submitPreferences({ fontSize: next });\n dispatch(setFontSize(getSetting(\"fontSize\")));\n }\n }, [isWebPub, getSetting, max, step, submitPreferences, dispatch]);\n\n const zoomOut = useCallback(async () => {\n if (isWebPub) {\n const next = Math.max(min, (getSetting(\"zoom\") ?? 1) - step);\n await submitPreferences({ zoom: next });\n dispatch(setWebPubZoom(getSetting(\"zoom\")));\n } else {\n const next = Math.max(min, (getSetting(\"fontSize\") ?? 1) - step);\n await submitPreferences({ fontSize: next });\n dispatch(setFontSize(getSetting(\"fontSize\")));\n }\n }, [isWebPub, getSetting, min, step, submitPreferences, dispatch]);\n\n return { zoomIn, zoomOut };\n};\n","import { ThLayoutUI } from \"@/preferences\";\nimport readerStyles from \"../assets/styles/thorium-web.reader.app.module.css\";\nimport classNames from \"classnames\";\n\ninterface ReaderStyleOptions {\n layoutUI: ThLayoutUI;\n isScroll: boolean;\n isImmersive?: boolean;\n isHovering?: boolean;\n isFXL?: boolean;\n breakpoint?: string;\n containerBreakpoint?: string;\n}\n\nconst LAYOUT_CLASSES = {\n [ThLayoutUI.stacked]: \"thorium_web_stackedUI\",\n [ThLayoutUI.layered]: \"thorium_web_layeredUI\",\n} as const;\n\nconst toBreakpointClass = (prefix: string, bp: string) =>\n `${ prefix }${ bp.charAt(0).toUpperCase() + bp.slice(1) }`;\n\nexport function getReaderClassNames(options: ReaderStyleOptions): string {\n const {\n layoutUI,\n isScroll,\n isImmersive = false,\n isHovering = false,\n isFXL = false,\n breakpoint,\n containerBreakpoint,\n } = options;\n\n return classNames(\n readerStyles.shell,\n isScroll ? \"thorium_web_isScroll\" : \"thorium_web_isPaged\",\n isImmersive && \"thorium_web_isImmersive\",\n isHovering && \"thorium_web_isHovering\",\n isFXL ? \"thorium_web_isFXL\" : \"thorium_web_isReflow\",\n LAYOUT_CLASSES[layoutUI],\n breakpoint ? toBreakpointClass(\"thorium_web_is\", breakpoint) : undefined,\n containerBreakpoint ? toBreakpointClass(\"thorium_web_container_is\", containerBreakpoint) : undefined\n );\n}"]}
@@ -1,11 +1,11 @@
1
- import { useNavigator, StatefulActionIcon, createAudioDefaultPlugin, usePositionStorage, NavigatorProvider, StatefulDockingWrapper, useReaderHeaderBase, StatefulBackLink, thorium_web_reader_header_default, StatefulCollapsibleActionsBar, thorium_web_overflow_default } from './chunk-MSHUPSBI.mjs';
2
- import { useAudioNavigator, useDocumentTitle, useAudioSettingsCache } from './chunk-SZAVAQ6S.mjs';
3
- import { setTocEntry, setAdjacentTimelineItems, setSleepTimerOnFragmentEnd, setRemotePlaybackState, setStatus, setSeekableRanges, setSeeking, setStalled, setSleepTimerOnTrackEnd, setTrackReady, setPublicationStart, setPublicationEnd, debounce, setLoading } from './chunk-YEVLT3AV.mjs';
1
+ import { useNavigator, StatefulActionIcon, usePlugins, ThPluginRegistry, createAudioDefaultPlugin, ThPluginProvider, useFocusedDockableKey, usePositionStorage, fromActionPeripheralType, fromDockingPeripheralType, NavigatorProvider, StatefulDockingWrapper, toActionPeripheralType, toDockingPeripheralType, useReaderHeaderBase, StatefulBackLink, thorium_web_reader_header_default, StatefulCollapsibleActionsBar, thorium_web_overflow_default } from './chunk-THOJRBVD.mjs';
2
+ import { useAudioNavigator, useDocumentTitle, useAudioSettingsCache } from './chunk-2B3HE57E.mjs';
3
+ import { useI18n } from './chunk-2NCN2AG2.mjs';
4
+ import { setTocEntry, setAdjacentTimelineItems, setSleepTimerOnFragmentEnd, toggleActionOpen, dockAction, setRemotePlaybackState, setStatus, setSeekableRanges, setSeeking, setStalled, setSleepTimerOnTrackEnd, setTrackReady, setPublicationStart, setPublicationEnd, debounce, setLoading } from './chunk-YE5QOQUT.mjs';
4
5
  import { findTocItemByHref } from './chunk-TEZB4ULX.mjs';
5
- import { useAudioPreferences, resolveAudioContentProtectionConfig, proxyUrl } from './chunk-OD75GC5N.mjs';
6
+ import { useAudioPreferences, resolveAudioContentProtectionConfig, useAudioActionsPreferences, proxyUrl } from './chunk-3VB756GR.mjs';
6
7
  import { useAppSelector, useAppDispatch } from './chunk-A575ZW4A.mjs';
7
- import { ThActionsBar, ThAudioProgress, usePlugins, ThPluginRegistry, ThPluginProvider } from './chunk-ETLIGONP.mjs';
8
- import { useI18n } from './chunk-2NCN2AG2.mjs';
8
+ import { ThActionsBar, ThAudioProgress } from './chunk-AXX4U2FW.mjs';
9
9
  import { useCallback, useState, useMemo, useLayoutEffect, useRef, useEffect, Fragment as Fragment$1 } from 'react';
10
10
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
11
11
  import { Link, Locator, LocatorLocations } from '@readium/shared';
@@ -519,6 +519,7 @@ var useAudioPlayerInit = ({
519
519
  preferences,
520
520
  cache,
521
521
  contentProtectionConfig,
522
+ keyboardPeripherals,
522
523
  onNavigatorReady,
523
524
  onNavigatorLoaded,
524
525
  onCleanup
@@ -544,7 +545,8 @@ var useAudioPlayerInit = ({
544
545
  }) : void 0,
545
546
  preferences: audioPreferences,
546
547
  defaults: audioDefaults,
547
- contentProtection: contentProtectionConfig
548
+ contentProtection: contentProtectionConfig,
549
+ keyboardPeripherals
548
550
  };
549
551
  isNavigatorLoadedAudio.current = true;
550
552
  onNavigatorReady?.();
@@ -566,6 +568,22 @@ var useAudioPlayerInit = ({
566
568
  navigatorReady
567
569
  };
568
570
  };
571
+ var useAudioKeyboardPeripherals = () => {
572
+ const { primaryActionsKeys, secondaryActionsKeys, primaryDisplayOrder, secondaryDisplayOrder, docking } = useAudioActionsPreferences();
573
+ return useMemo(() => {
574
+ const config = [];
575
+ const allKeys = { ...primaryActionsKeys, ...secondaryActionsKeys };
576
+ for (const [key, tokens] of Object.entries(allKeys)) {
577
+ const shortcut = tokens?.shortcut;
578
+ const isInOrder = primaryDisplayOrder.includes(key) || secondaryDisplayOrder.includes(key);
579
+ if (shortcut && isInOrder) config.push({ type: toActionPeripheralType(key), keyCombos: shortcut.keyCombos });
580
+ }
581
+ for (const [key, tokens] of Object.entries(docking.keys)) {
582
+ if (tokens?.shortcut) config.push({ type: toDockingPeripheralType(key), keyCombos: tokens.shortcut.keyCombos });
583
+ }
584
+ return config;
585
+ }, [primaryActionsKeys, secondaryActionsKeys, primaryDisplayOrder, secondaryDisplayOrder, docking.keys]);
586
+ };
569
587
 
570
588
  // src/helpers/browser.ts
571
589
  var isWebKit = typeof navigator !== "undefined" && /webkit/i.test(navigator.userAgent) && !/chrome/i.test(navigator.userAgent);
@@ -596,6 +614,8 @@ var StatefulPlayer = ({
596
614
  var StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUrl, containerRefSetter }) => {
597
615
  const { preferences } = useAudioPreferences();
598
616
  const { t } = useI18n();
617
+ const profile = useAppSelector((state) => state.reader.profile);
618
+ const keyboardPeripherals = useAudioKeyboardPeripherals();
599
619
  const wrapperRef = useRef(null);
600
620
  const coverSectionRef = useRef(null);
601
621
  const compactMinHeight = useRef(0);
@@ -627,6 +647,7 @@ var StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUr
627
647
  adjacentTimelineItems
628
648
  );
629
649
  const dispatch = useAppDispatch();
650
+ const getFocusedDockableKey = useFocusedDockableKey();
630
651
  const audioNavigator = useAudioNavigator();
631
652
  const { canGoBackward, canGoForward, submitPreferences, pause, isPlaying } = audioNavigator;
632
653
  const { setLocalData, getLocalData } = usePositionStorage(localDataKey, positionStorage);
@@ -745,11 +766,23 @@ var StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUr
745
766
  },
746
767
  contentProtection: (_type, _detail) => {
747
768
  },
748
- peripheral: (_data) => {
769
+ peripheral: (data) => {
770
+ const actionKey = fromActionPeripheralType(data.type);
771
+ if (actionKey && profile) {
772
+ dispatch(toggleActionOpen({ key: actionKey, profile }));
773
+ return;
774
+ }
775
+ const dockingKey = fromDockingPeripheralType(data.type);
776
+ if (dockingKey && profile) {
777
+ const actionKey2 = getFocusedDockableKey(dockingKey);
778
+ if (actionKey2) {
779
+ dispatch(dockAction({ key: actionKey2, dockingKey, profile }));
780
+ }
781
+ }
749
782
  },
750
783
  contextMenu: (_data) => {
751
784
  }
752
- }), [setLocalData, canGoBackward, canGoForward, isPlaying, dispatch, cache, submitPreferences, publication, handleTimelineNavigation, handleSleepTimerEndOfFragment, handleContinuousPlay]);
785
+ }), [setLocalData, canGoBackward, canGoForward, isPlaying, dispatch, cache, submitPreferences, publication, handleTimelineNavigation, handleSleepTimerEndOfFragment, handleContinuousPlay, profile, getFocusedDockableKey]);
753
786
  const initialPosition = useMemo(() => getLocalData(), [getLocalData]);
754
787
  useAudioPlayerInit({
755
788
  publication,
@@ -758,6 +791,7 @@ var StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUr
758
791
  preferences,
759
792
  cache,
760
793
  contentProtectionConfig: resolveAudioContentProtectionConfig(preferences.contentProtection, t),
794
+ keyboardPeripherals,
761
795
  onNavigatorLoaded: () => dispatch(setLoading(false))
762
796
  });
763
797
  const { compact, expanded } = preferences.theming.layout;
@@ -847,7 +881,6 @@ var StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUr
847
881
  {
848
882
  ref: wrapperRef,
849
883
  className: isExpanded ? thorium_web_audioPlayer_default.audioPlayerWrapperExpanded : thorium_web_audioPlayer_default.audioPlayerWrapper,
850
- "aria-label": t("reader.app.publicationWrapper"),
851
884
  children: isExpanded ? /* @__PURE__ */ jsxs(Fragment, { children: [
852
885
  /* @__PURE__ */ jsx("div", { className: thorium_web_audioPlayer_default.audioPlayerExpandedStart, children: expanded.start.map(renderPlayerComponent) }),
853
886
  /* @__PURE__ */ jsx("div", { className: thorium_web_audioPlayer_default.audioPlayerExpandedEnd, children: expanded.end.map(renderPlayerComponent) })
@@ -858,5 +891,5 @@ var StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUr
858
891
  };
859
892
 
860
893
  export { StatefulAudioMediaActions, StatefulAudioPlaybackControls, StatefulAudioProgressBar, StatefulNextButton, StatefulPlayPauseButton, StatefulPlayer, StatefulPreviousButton, StatefulSkipBackwardButton, StatefulSkipForwardButton };
861
- //# sourceMappingURL=chunk-E2JEGVVE.mjs.map
862
- //# sourceMappingURL=chunk-E2JEGVVE.mjs.map
894
+ //# sourceMappingURL=chunk-MTH2RF6V.mjs.map
895
+ //# sourceMappingURL=chunk-MTH2RF6V.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/Audio/controls/assets/icons/pause.svg","../src/components/Audio/controls/assets/icons/play_arrow.svg","../src/components/Audio/controls/assets/styles/thorium-web.audioPlayback.module.css","../src/components/Audio/controls/StatefulPlayPauseButton.tsx","../src/components/Audio/controls/assets/icons/skip_previous.svg","../src/components/Audio/controls/hooks/useAdjacentTocItems.ts","../src/components/Audio/controls/StatefulPreviousButton.tsx","../src/components/Audio/controls/assets/icons/skip_next.svg","../src/components/Audio/controls/StatefulNextButton.tsx","../src/components/Audio/controls/assets/icons/replay.svg","../src/components/Audio/controls/assets/icons/replay_5.svg","../src/components/Audio/controls/assets/icons/replay_10.svg","../src/components/Audio/controls/assets/icons/replay_30.svg","../src/components/Audio/controls/StatefulSkipBackwardButton.tsx","../src/components/Audio/controls/assets/icons/forward_media.svg","../src/components/Audio/controls/assets/icons/forward_5.svg","../src/components/Audio/controls/assets/icons/forward_10.svg","../src/components/Audio/controls/assets/icons/forward_30.svg","../src/components/Audio/controls/StatefulSkipForwardButton.tsx","../src/components/Audio/controls/StatefulAudioPlaybackControls.tsx","../src/components/Audio/controls/assets/styles/thorium-web.audioProgressBar.module.css","../src/components/Audio/controls/StatefulAudioProgressBar.tsx","../src/components/Audio/actions/assets/styles/thorium-web.audioActions.module.css","../src/components/Audio/actions/StatefulAudioMediaActions.tsx","../src/components/Audio/assets/styles/thorium-web.audio.app.module.css","../src/components/Audio/assets/styles/thorium-web.audioPlayer.module.css","../src/components/Audio/StatefulPlayerHeader.tsx","../src/components/Audio/assets/styles/thorium-web.audioCover.module.css","../src/components/Audio/assets/icons/music_note.svg","../src/components/Audio/assets/icons/sync.svg","../src/components/Audio/StatefulAudioCover.tsx","../src/components/Audio/assets/styles/thorium-web.audioMetadata.module.css","../src/components/Audio/StatefulAudioMetadata.tsx","../src/components/Audio/Hooks/useAudioStatelessCache.ts","../src/components/Audio/Hooks/useAudioPreferencesConfig.ts","../src/components/Audio/Hooks/useAudioPlayerInit.ts","../src/components/Audio/Hooks/useAudioKeyboardPeripherals.ts","../src/helpers/browser.ts","../src/components/Audio/StatefulPlayer.tsx"],"names":["jsx","audioControls","audioPreviousButton","audioNextButton","audioSkipBackwardButton","audioSkipForwardButton","audioPlayPauseButton","Link","wrapper","current","slider","track","thumb","seekableRange","elapsed","remaining","tick","tooltip","useCallback","segments","jsxs","Fragment","main","shell","topBar","audioPlayerWrapper","audioPlayerWrapperExpanded","audioPlayerExpandedStart","audioPlayerExpandedEnd","coverMetadataGroup","audioCoverSection","audioCoverImage","audioCoverPlaceholder","audioCoverSyncOverlay","audioCoverSyncIcon","audioMetadata","audioMetadataTitle","audioMetadataSubtitle","audioMetadataAuthors","useRef","useMemo","useState","useEffect","actionKey"],"mappings":"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","file":"chunk-MTH2RF6V.mjs","sourcesContent":["import * as React from \"react\";\nconst SvgPause = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M560-200v-560h160v560H560Zm-320 0v-560h160v560H240Z\" /></svg>;\nexport default SvgPause;","import * as React from \"react\";\nconst SvgPlayArrow = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M320-200v-560l440 280-440 280Z\" /></svg>;\nexport default SvgPlayArrow;",".audioControls {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 1rem;\n --audio-icon-base: var(--th-icon-size, 24px);\n}\n\n@container (max-width: 300px) {\n .audioControls {\n --th-icon-size: 18px;\n }\n}\n\n.audioPreviousButton,\n.audioNextButton {\n --th-icon-size: calc(var(--audio-icon-base) * (5/4));\n padding: calc(var(--th-icon-size) * (1/5));\n}\n\n.audioSkipBackwardButton,\n.audioSkipForwardButton {\n --th-icon-size: calc(var(--audio-icon-base) * (3/2));\n padding: calc(var(--th-icon-size) * (1/6));\n}\n\n.audioPlayPauseButton {\n --th-icon-size: calc(var(--audio-icon-base) * 2);\n padding: calc(var(--th-icon-size) * (1/8));\n}\n","\"use client\";\n\nimport { useCallback } from \"react\";\n\nimport PauseIcon from \"./assets/icons/pause.svg\";\nimport PlayIcon from \"./assets/icons/play_arrow.svg\";\n\nimport { StatefulActionIcon } from \"../../Actions/Triggers/StatefulActionIcon\";\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayback.module.css\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useAppSelector } from \"@/lib/hooks\";\nimport { useI18n } from \"@/i18n/useI18n\";\n\nexport const StatefulPlayPauseButton = ({ isDisabled }: { isDisabled?: boolean }) => {\n const { t } = useI18n();\n const { play, pause } = useNavigator().media;\n const isPlaying = useAppSelector(state => state.player.status === \"playing\");\n\n const handlePress = useCallback(() => {\n if (isPlaying) {\n pause();\n } else {\n play();\n }\n }, [isPlaying, play, pause]);\n\n return (\n <StatefulActionIcon\n onPress={ handlePress }\n isDisabled={ isDisabled }\n aria-label={ isPlaying ? t(\"reader.playback.actions.pause\") : t(\"reader.playback.actions.play\") }\n tooltipLabel={ isPlaying ? t(\"reader.playback.actions.pause\") : t(\"reader.playback.actions.play\") }\n className={ audioStyles.audioPlayPauseButton }\n >\n {isPlaying ? (\n <PauseIcon aria-hidden=\"true\" focusable=\"false\" />\n ) : (\n <PlayIcon aria-hidden=\"true\" focusable=\"false\" />\n )}\n </StatefulActionIcon>\n );\n};\n","import * as React from \"react\";\nconst SvgSkipPrevious = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M220-240v-480h80v480h-80Zm520 0L380-480l360-240v480Zm-80-240Zm0 90v-180l-136 90 136 90Z\" /></svg>;\nexport default SvgSkipPrevious;","import { TocItem } from \"@/helpers/buildTocTree\";\nimport { useAppSelector } from \"@/lib/hooks\";\n\nconst flattenTocTree = (items: TocItem[]): TocItem[] => {\n const result: TocItem[] = [];\n for (const item of items) {\n result.push(item);\n if (item.children) result.push(...flattenTocTree(item.children));\n }\n return result;\n};\n\nexport const useAdjacentTocItems = (): { previous: TocItem | null; next: TocItem | null } => {\n const tocTree = useAppSelector(state => state.publication.unstableTimeline?.toc?.tree);\n const tocCurrentEntry = useAppSelector(state => state.publication.unstableTimeline?.toc?.currentEntry);\n\n if (!tocTree || !tocCurrentEntry) return { previous: null, next: null };\n\n const flat = flattenTocTree(tocTree);\n const index = flat.findIndex(item => item.href === tocCurrentEntry.href);\n\n if (index < 0) return { previous: null, next: null };\n\n return {\n previous: index > 0 ? flat[index - 1] : null,\n next: index < flat.length - 1 ? flat[index + 1] : null,\n };\n};\n","\"use client\";\n\nimport SkipPreviousIcon from \"./assets/icons/skip_previous.svg\";\n\nimport { StatefulActionIcon } from \"../../Actions/Triggers/StatefulActionIcon\";\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayback.module.css\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useAppSelector } from \"@/lib/hooks\";\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { useAudioPreferences } from \"@/preferences/hooks/useAudioPreferences\";\nimport { ThAudioAffordance } from \"@/preferences/audioPreferences\";\nimport { useAdjacentTocItems } from \"./hooks/useAdjacentTocItems\";\nimport { Link } from \"@readium/shared\";\n\nexport const StatefulPreviousButton = ({ isDisabled }: { isDisabled?: boolean }) => {\n const { t } = useI18n();\n const { preferences } = useAudioPreferences();\n const { goBackward, goLink } = useNavigator().media;\n const atStart = useAppSelector(state => state.publication.atPublicationStart);\n const previousTimelineItem = useAppSelector(state => state.publication.adjacentTimelineItems.previous);\n const { previous: previousTocItem } = useAdjacentTocItems();\n\n const affordance = preferences.affordances.previous;\n const isTimeline = affordance === ThAudioAffordance.timeline;\n const isToc = affordance === ThAudioAffordance.toc;\n\n const previousItem = isToc ? previousTocItem : previousTimelineItem;\n\n const label = (isTimeline || isToc) && previousItem?.title\n ? previousItem.title\n : t(\"reader.actions.goToPreviousResource.descriptive\");\n\n const handlePress = () => (isTimeline || isToc)\n ? previousItem && goLink(new Link({ href: previousItem.href }), false, () => {})\n : goBackward(false, () => {});\n\n return (\n <StatefulActionIcon\n onPress={ handlePress }\n isDisabled={ isDisabled || ((isTimeline || isToc) ? !previousItem : atStart) }\n aria-label={ label }\n tooltipLabel={ label }\n className={ audioStyles.audioPreviousButton }\n >\n <SkipPreviousIcon aria-hidden=\"true\" focusable=\"false\" />\n </StatefulActionIcon>\n );\n};\n","import * as React from \"react\";\nconst SvgSkipNext = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M660-240v-480h80v480h-80Zm-440 0v-480l360 240-360 240Zm80-240Zm0 90 136-90-136-90v180Z\" /></svg>;\nexport default SvgSkipNext;","\"use client\";\n\nimport SkipNextIcon from \"./assets/icons/skip_next.svg\";\n\nimport { StatefulActionIcon } from \"../../Actions/Triggers/StatefulActionIcon\";\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayback.module.css\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useAppSelector } from \"@/lib/hooks\";\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { useAudioPreferences } from \"@/preferences\";\nimport { ThAudioAffordance } from \"@/preferences/audioPreferences\";\nimport { useAdjacentTocItems } from \"./hooks/useAdjacentTocItems\";\nimport { Link } from \"@readium/shared\";\n\nexport const StatefulNextButton = ({ isDisabled }: { isDisabled?: boolean }) => {\n const { t } = useI18n();\n const { preferences } = useAudioPreferences();\n const { goForward, goLink } = useNavigator().media;\n const atEnd = useAppSelector(state => state.publication.atPublicationEnd);\n const nextTimelineItem = useAppSelector(state => state.publication.adjacentTimelineItems.next);\n const { next: nextTocItem } = useAdjacentTocItems();\n\n const affordance = preferences.affordances.next;\n const isTimeline = affordance === ThAudioAffordance.timeline;\n const isToc = affordance === ThAudioAffordance.toc;\n\n const nextItem = isToc ? nextTocItem : nextTimelineItem;\n\n const label = (isTimeline || isToc) && nextItem?.title\n ? nextItem.title\n : t(\"reader.actions.goToNextResource.descriptive\");\n\n const handlePress = () => (isTimeline || isToc)\n ? nextItem && goLink(new Link({ href: nextItem.href }), false, () => {})\n : goForward(false, () => {});\n\n return (\n <StatefulActionIcon\n onPress={ handlePress }\n isDisabled={ isDisabled || ((isTimeline || isToc) ? !nextItem : atEnd) }\n aria-label={ label }\n tooltipLabel={ label }\n className={ audioStyles.audioNextButton }\n >\n <SkipNextIcon aria-hidden=\"true\" focusable=\"false\" />\n </StatefulActionIcon>\n );\n};\n","import * as React from \"react\";\nconst SvgReplay = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.85Q140-369.23 140-440h60q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440q0-117-81.5-198.5T480-720h-10.62l63.54 63.54-42.15 43.38-136.92-137.3 137.69-137.31 42.15 43.38L469.38-780H480q70.77 0 132.61 26.77 61.85 26.77 107.85 72.77 46 46 72.77 107.85Q820-510.77 820-440q0 70.77-26.77 132.61-26.77 61.85-72.77 107.85-46 46-107.85 72.77Q550.77-100 480-100q-70.77 0-132.61-26.77Z\" /></svg>;\nexport default SvgReplay;","import * as React from \"react\";\nconst SvgReplay5 = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.83Q140-369.2 140-440h60q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440q0-117-81.5-198.5T480-720h-10.62l63.54 63.54-42.15 43.38-136.92-137.3 137.69-137.31 42.15 43.38L469.38-780H480q70.8 0 132.63 26.77t107.83 72.77q46 46 72.77 107.82Q820-510.81 820-440.02t-26.77 132.63q-26.77 61.85-72.77 107.85-46 46-107.82 72.77Q550.81-100 480.02-100t-132.63-26.77Zm38.76-199.38v-47.7h120v-48.46h-120v-131.54h167.7v47.7h-120v48.46H520q14.38 0 24.12 9.73 9.73 9.73 9.73 24.11V-360q0 14.38-9.73 24.12-9.74 9.73-24.12 9.73H386.15Z\" /></svg>;\nexport default SvgReplay5;","import * as React from \"react\";\nconst SvgReplay10 = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.85Q140-369.23 140-440h60q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440q0-117-81.5-198.5T480-720h-10.62l63.54 63.54-42.15 43.38-136.92-137.3 137.69-137.31 42.15 43.38L469.38-780H480q70.77 0 132.61 26.77 61.85 26.77 107.85 72.77 46 46 72.77 107.85Q820-510.77 820-440q0 70.77-26.77 132.61-26.77 61.85-72.77 107.85-46 46-107.85 72.77Q550.77-100 480-100q-70.77 0-132.61-26.77Zm21.07-199.38v-180h-57.69v-47.7h105.38v227.7h-47.69Zm135.39 0q-17 0-28.5-11.5t-11.5-28.5v-147.7q0-17 11.5-28.5t28.5-11.5h75.38q17 0 28.5 11.5t11.5 28.5v147.7q0 17-11.5 28.5t-28.5 11.5h-75.38Zm12.3-47.7h50.77q2.31 0 3.47-1.15 1.15-1.15 1.15-3.46v-123.08q0-2.31-1.15-3.46-1.16-1.15-3.47-1.15h-50.77q-2.3 0-3.46 1.15-1.15 1.15-1.15 3.46v123.08q0 2.31 1.15 3.46 1.16 1.15 3.46 1.15Z\" /></svg>;\nexport default SvgReplay10;","import * as React from \"react\";\nconst SvgReplay30 = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.85Q140-369.23 140-440h60q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440q0-117-81.5-198.5T480-720h-10.62l63.54 63.54-42.15 43.38-136.92-137.3 137.69-137.31 42.15 43.38L469.38-780H480q70.77 0 132.61 26.77 61.85 26.77 107.85 72.77 46 46 72.77 107.85Q820-510.77 820-440q0 70.77-26.77 132.61-26.77 61.85-72.77 107.85-46 46-107.85 72.77Q550.77-100 480-100q-70.77 0-132.61-26.77Zm-46.62-199.38v-47.7h107.69v-48.46h-71.54v-35.38h71.54v-48.46H300.77v-47.7h121.54q14.69 0 24.27 9.58 9.57 9.58 9.57 24.27v160q0 14.69-9.57 24.27-9.58 9.58-24.27 9.58H300.77Zm243.08 0q-17 0-28.5-11.5t-11.5-28.5v-147.7q0-17 11.5-28.5t28.5-11.5h75.38q17 0 28.5 11.5t11.5 28.5v147.7q0 17-11.5 28.5t-28.5 11.5h-75.38Zm12.3-47.7h50.77q2.31 0 3.47-1.15 1.15-1.15 1.15-3.46v-123.08q0-2.31-1.15-3.46-1.16-1.15-3.47-1.15h-50.77q-2.3 0-3.46 1.15-1.15 1.15-1.15 3.46v123.08q0 2.31 1.15 3.46 1.16 1.15 3.46 1.15Z\" /></svg>;\nexport default SvgReplay30;","\"use client\";\n\nimport ReplayIcon from \"./assets/icons/replay.svg\";\nimport Replay5Icon from \"./assets/icons/replay_5.svg\";\nimport Replay10Icon from \"./assets/icons/replay_10.svg\";\nimport Replay30Icon from \"./assets/icons/replay_30.svg\";\n\nimport { StatefulActionIcon } from \"../../Actions/Triggers/StatefulActionIcon\";\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayback.module.css\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useAppSelector } from \"@/lib/hooks\";\nimport { useI18n } from \"@/i18n/useI18n\";\n\nconst replayIconMap: Record<number, React.ElementType> = {\n 5: Replay5Icon,\n 10: Replay10Icon,\n 30: Replay30Icon,\n};\n\nexport const StatefulSkipBackwardButton = ({ isDisabled }: { isDisabled?: boolean }) => {\n const { t } = useI18n();\n const { skipBackward } = useNavigator().media;\n const skipBackwardInterval = useAppSelector(state => state.audioSettings.skipBackwardInterval);\n\n const Icon = replayIconMap[skipBackwardInterval] ?? ReplayIcon;\n\n return (\n <StatefulActionIcon\n onPress={ skipBackward }\n isDisabled={ isDisabled }\n aria-label={ t(\"reader.playback.actions.skipBackward.descriptive\") }\n tooltipLabel={ t(\"reader.playback.actions.skipBackward.descriptive\") }\n className={ audioStyles.audioSkipBackwardButton }\n >\n <Icon aria-hidden=\"true\" focusable=\"false\" />\n </StatefulActionIcon>\n );\n};\n","import * as React from \"react\";\nconst SvgForwardMedia = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.85Q140-369.23 140-440q0-70.77 26.77-132.61 26.77-61.85 72.77-107.85 46-46 107.85-72.77Q409.23-780 480-780h10.62l-64.31-64.31 42.15-43.38 137.69 137.31-136.92 137.3-42.15-43.38L490.62-720H480q-117 0-198.5 81.5T200-440q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440h60q0 70.77-26.77 132.61-26.77 61.85-72.77 107.85-46 46-107.85 72.77Q550.77-100 480-100q-70.77 0-132.61-26.77Z\" /></svg>;\nexport default SvgForwardMedia;","import * as React from \"react\";\nconst SvgForward5 = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.82Q140-369.19 140-439.98t26.77-132.63q26.77-61.85 72.77-107.85 46-46 107.83-72.77Q409.2-780 480-780h10.62l-64.31-64.31 42.15-43.38 137.69 137.31-136.92 137.3-42.15-43.38L490.62-720H480q-117 0-198.5 81.5T200-440q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440h60q0 70.8-26.77 132.63t-72.77 107.83q-46 46-107.82 72.77Q550.81-100 480.02-100t-132.63-26.77Zm38.76-199.38v-47.7h120v-48.46h-120v-131.54h167.7v47.7h-120v48.46H520q14.38 0 24.12 9.73 9.73 9.73 9.73 24.11V-360q0 14.38-9.73 24.12-9.74 9.73-24.12 9.73H386.15Z\" /></svg>;\nexport default SvgForward5;","import * as React from \"react\";\nconst SvgForward10 = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M368.46-326.15v-180h-57.69v-47.7h105.38v227.7h-47.69Zm135.39 0q-17 0-28.5-11.5t-11.5-28.5v-147.7q0-17 11.5-28.5t28.5-11.5h75.38q17 0 28.5 11.5t11.5 28.5v147.7q0 17-11.5 28.5t-28.5 11.5h-75.38Zm12.3-47.7h50.77q2.31 0 3.47-1.15 1.15-1.15 1.15-3.46v-123.08q0-2.31-1.15-3.46-1.16-1.15-3.47-1.15h-50.77q-2.3 0-3.46 1.15-1.15 1.15-1.15 3.46v123.08q0 2.31 1.15 3.46 1.16 1.15 3.46 1.15ZM347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.85Q140-369.23 140-440q0-70.77 26.77-132.61 26.77-61.85 72.77-107.85 46-46 107.85-72.77Q409.23-780 480-780h10.62l-64.31-64.31 42.15-43.38 137.69 137.31-136.92 137.3-42.15-43.38L490.62-720H480q-117 0-198.5 81.5T200-440q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440h60q0 70.77-26.77 132.61-26.77 61.85-72.77 107.85-46 46-107.85 72.77Q550.77-100 480-100q-70.77 0-132.61-26.77Z\" /></svg>;\nexport default SvgForward10;","import * as React from \"react\";\nconst SvgForward30 = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M300.77-326.15v-47.7h107.69v-48.46h-71.54v-35.38h71.54v-48.46H300.77v-47.7h121.54q14.69 0 24.27 9.58 9.57 9.58 9.57 24.27v160q0 14.69-9.57 24.27-9.58 9.58-24.27 9.58H300.77Zm243.08 0q-17 0-28.5-11.5t-11.5-28.5v-147.7q0-17 11.5-28.5t28.5-11.5h75.38q17 0 28.5 11.5t11.5 28.5v147.7q0 17-11.5 28.5t-28.5 11.5h-75.38Zm12.3-47.7h50.77q2.31 0 3.47-1.15 1.15-1.15 1.15-3.46v-123.08q0-2.31-1.15-3.46-1.16-1.15-3.47-1.15h-50.77q-2.3 0-3.46 1.15-1.15 1.15-1.15 3.46v123.08q0 2.31 1.15 3.46 1.16 1.15 3.46 1.15ZM347.39-126.77q-61.85-26.77-107.85-72.77-46-46-72.77-107.85Q140-369.23 140-440q0-70.77 26.77-132.61 26.77-61.85 72.77-107.85 46-46 107.85-72.77Q409.23-780 480-780h10.62l-64.31-64.31 42.15-43.38 137.69 137.31-136.92 137.3-42.15-43.38L490.62-720H480q-117 0-198.5 81.5T200-440q0 117 81.5 198.5T480-160q117 0 198.5-81.5T760-440h60q0 70.77-26.77 132.61-26.77 61.85-72.77 107.85-46 46-107.85 72.77Q550.77-100 480-100q-70.77 0-132.61-26.77Z\" /></svg>;\nexport default SvgForward30;","\"use client\";\n\nimport ForwardIcon from \"./assets/icons/forward_media.svg\";\nimport Forward5Icon from \"./assets/icons/forward_5.svg\";\nimport Forward10Icon from \"./assets/icons/forward_10.svg\";\nimport Forward30Icon from \"./assets/icons/forward_30.svg\";\n\nimport { StatefulActionIcon } from \"../../Actions/Triggers/StatefulActionIcon\";\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayback.module.css\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useAppSelector } from \"@/lib/hooks\";\nimport { useI18n } from \"@/i18n/useI18n\";\n\nconst forwardIconMap: Record<number, React.ElementType> = {\n 5: Forward5Icon,\n 10: Forward10Icon,\n 30: Forward30Icon,\n};\n\nexport const StatefulSkipForwardButton = ({ isDisabled }: { isDisabled?: boolean }) => {\n const { t } = useI18n();\n const { skipForward } = useNavigator().media;\n const skipForwardInterval = useAppSelector(state => state.audioSettings.skipForwardInterval);\n\n const Icon = forwardIconMap[skipForwardInterval] ?? ForwardIcon;\n\n return (\n <StatefulActionIcon\n onPress={ skipForward }\n isDisabled={ isDisabled }\n aria-label={ t(\"reader.playback.actions.skipForward.descriptive\") }\n tooltipLabel={ t(\"reader.playback.actions.skipForward.descriptive\") }\n className={ audioStyles.audioSkipForwardButton }\n >\n <Icon aria-hidden=\"true\" focusable=\"false\" />\n </StatefulActionIcon>\n );\n};\n","\"use client\";\n\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayback.module.css\";\n\nimport { StatefulPreviousButton } from \"./StatefulPreviousButton\";\nimport { StatefulSkipBackwardButton } from \"./StatefulSkipBackwardButton\";\nimport { StatefulPlayPauseButton } from \"./StatefulPlayPauseButton\";\nimport { StatefulSkipForwardButton } from \"./StatefulSkipForwardButton\";\nimport { StatefulNextButton } from \"./StatefulNextButton\";\n\nimport { ThActionsBar } from \"@/core/Components/Actions/ThActionsBar\";\n\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { useAppSelector } from \"@/lib/hooks\";\n\nexport const StatefulAudioPlaybackControls = () => {\n const { t } = useI18n();\n const isTrackReady = useAppSelector(state => state.player.isTrackReady);\n const isStalled = useAppSelector(state => state.player.isStalled);\n\n return (\n <ThActionsBar className={ audioStyles.audioControls } aria-label={ t(\"audio.player.controls\") } dir=\"ltr\">\n <StatefulPreviousButton isDisabled={ !isTrackReady || isStalled } />\n <StatefulSkipBackwardButton isDisabled={ !isTrackReady || isStalled } />\n <StatefulPlayPauseButton isDisabled={ !isTrackReady || isStalled } />\n <StatefulSkipForwardButton isDisabled={ !isTrackReady || isStalled } />\n <StatefulNextButton isDisabled={ !isTrackReady || isStalled } />\n </ThActionsBar>\n );\n};\n",".wrapper {\n width: 100%;\n max-width: 600px;\n display: grid;\n grid-template-areas:\n \"chapter chapter chapter\"\n \"progress progress progress\"\n \"elapsed . remaining\";\n grid-template-columns: 1fr 1fr 1fr;\n align-items: center;\n gap: 0.5rem;\n container-type: inline-size;\n}\n\n.current {\n grid-area: chapter;\n text-align: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.slider {\n grid-area: progress;\n}\n\n.track {\n grid-area: progress;\n position: relative;\n height: 30px;\n width: auto;\n box-sizing: border-box;\n margin-inline: calc(var(--th-layout-spacing) / 2);\n}\n\n.track::before {\n content: \"\";\n display: block;\n position: absolute;\n background: var(--th-theme-subdue);\n height: 3px;\n width: 100%;\n top: 50%;\n transform: translateY(-50%);\n}\n\n.thumb {\n z-index: 2;\n width: 1.25rem;\n height: 1.25rem;\n border-radius: 50%;\n background: var(--th-theme-text);\n border: none;\n top: 50%;\n transform: translateY(-50%);\n}\n\n.slider[data-disabled] .track::before {\n background: var(--th-theme-disable);\n}\n\n.slider[data-disabled] .thumb {\n background: var(--th-theme-disable);\n}\n\n.slider[data-disabled] .seekableRange {\n background: var(--th-theme-disable);\n}\n\n.slider[data-disabled] .current,\n.slider[data-disabled] .elapsed,\n.slider[data-disabled] .remaining {\n color: var(--th-theme-disable);\n}\n\n.thumb[data-dragging] {\n background: var(--th-theme-subdue);\n}\n\n.thumb[data-focus-visible] {\n outline: 2px solid var(--th-theme-focus);\n}\n\n.seekableRange {\n position: absolute;\n height: 3px;\n top: 50%;\n transform: translateY(-50%);\n background: color-mix(in srgb, var(--th-theme-text) 55%, var(--th-theme-subdue));\n pointer-events: none;\n border-radius: 1px;\n z-index: 1;\n}\n\n.tick {\n position: absolute;\n width: 1px;\n height: 15px;\n top: 50%;\n transform: translateY(-50%);\n background: var(--th-theme-text);\n pointer-events: none;\n z-index: 1;\n}\n\n.tooltip {\n background-color: var(--th-theme-text);\n color: var(--th-theme-background);\n border-radius: var(--th-layout-radius);\n padding: calc(var(--th-layout-spacing) / 2);\n font-size: 0.75rem;\n pointer-events: none;\n max-width: 320px;\n text-wrap: pretty;\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n}\n\n.elapsed {\n grid-area: elapsed;\n justify-self: start;\n font-size: 0.875rem;\n color: var(--th-theme-text);\n}\n\n.remaining {\n grid-area: remaining;\n justify-self: end;\n font-size: 0.875rem;\n color: var(--th-theme-text);\n}\n\n@container (max-width: 300px) {\n .current {\n font-size: 0.875rem;\n }\n}\n","\"use client\";\n\nimport React, { useCallback, useState, useMemo } from \"react\";\n\nimport audioStyles from \"./assets/styles/thorium-web.audioProgressBar.module.css\";\n\nimport { ThAudioProgress } from \"@/core/Components/Audio/ThAudioProgress\";\n\nimport { useNavigator } from \"@/core/Navigator\";\nimport { useAppSelector } from \"@/lib\";\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { useAudioPreferences } from \"@/preferences/hooks/useAudioPreferences\";\nimport { ThAudioProgressBarVariant } from \"@/preferences/models/ui\";\n\nexport const StatefulAudioProgressBar = () => {\n const { t } = useI18n();\n const { preferences } = useAudioPreferences();\n\n const tocEntry = useAppSelector(state => state.publication.unstableTimeline?.toc?.currentEntry);\n const currentChapter = tocEntry?.title;\n\n const isStalled = useAppSelector(state => state.player.isStalled);\n const isTrackReady = useAppSelector(state => state.player.isTrackReady);\n const seekableRanges = useAppSelector(state => state.player.seekableRanges);\n const playbackRate = useAppSelector(state => state.audioSettings.playbackRate);\n\n const { currentTime, duration, seek, currentLocator, timeline } = useNavigator().media;\n\n const current = currentTime();\n const total = duration();\n\n const [hoverLabel, setHoverLabel] = useState<string | undefined>(undefined);\n\n const handleSeek = useCallback((time: number) => {\n seek(time);\n }, [seek]);\n\n const handleHoverProgression = useCallback((progression: number | null) => {\n if (progression === null) {\n setHoverLabel(undefined);\n return;\n }\n const locator = currentLocator();\n const tl = timeline();\n if (!locator || !tl) return;\n const item = tl.itemAtProgression(locator.href, progression, total);\n setHoverLabel(item?.title);\n }, [currentLocator, timeline, total]);\n\n // Parse timestamp from fragment href (e.g., \"file.mp3#t=123.45\")\n const parseTimestamp = (href: string): number => {\n const match = href.match(/#t=(\\d+(?:\\.\\d+)?)$/);\n return match ? parseFloat(match[1]) : 0;\n };\n\n // Get timeline segments for fragmented progress bar\n const segments = useMemo(() => {\n const locator = currentLocator();\n const tl = timeline();\n if (!locator || !tl || preferences.theming.layout.progressBar?.variant !== ThAudioProgressBarVariant.segmented) return [];\n \n const segments = tl.segmentsForHref(locator.href);\n if (!segments || !Array.isArray(segments)) return [];\n \n return segments.map((segment) => {\n // Parse timestamp from first reference href (e.g., \"track1.mp3#t=60\")\n const referenceHref = segment.references?.[0] || \"\";\n const timestamp = parseTimestamp(referenceHref);\n \n // Calculate percentage based on timestamp and total duration\n const percentage = total > 0 ? (timestamp / total) * 100 : 0;\n \n return {\n title: segment.title,\n timestamp,\n percentage\n };\n });\n }, [currentLocator, timeline, total, preferences.theming.layout.progressBar?.variant]);\n\n return (\n <ThAudioProgress\n currentTime={ current }\n duration={ total }\n playbackRate={ playbackRate }\n onSeek={ handleSeek }\n currentChapter={ currentChapter || \"​\" } // Zero-width space to prevent shift\n isDisabled={ !isTrackReady || isStalled }\n seekableRanges={ seekableRanges }\n hoverLabel={ hoverLabel }\n onHoverProgression={ handleHoverProgression }\n segments={ segments }\n compounds={{\n wrapper: {\n className: audioStyles.wrapper,\n onKeyDown: (e: React.KeyboardEvent) => {\n if (e.key === \"Escape\") (document.activeElement as HTMLElement)?.blur();\n }\n },\n current: {\n className: audioStyles.current\n },\n slider: {\n className: audioStyles.slider,\n \"aria-label\": t(\"audio.player.progress\")\n },\n track: {\n className: audioStyles.track\n },\n thumb: {\n className: audioStyles.thumb\n },\n elapsedTime: {\n className: audioStyles.elapsed\n },\n remainingTime: {\n className: audioStyles.remaining\n },\n seekableRange: {\n className: audioStyles.seekableRange\n },\n fragmentTick: {\n className: audioStyles.tick\n },\n tooltip: {\n className: audioStyles.tooltip,\n offset: preferences.theming.icon.tooltipOffset\n }\n }}\n />\n );\n};\n",".wrapper {\n display: flex;\n align-items: flex-start;\n justify-content: center;\n gap: 1rem;\n --audio-icon-base: var(--th-icon-size, 24px);\n}\n\n@container (max-width: 300px) {\n .wrapper {\n --th-icon-size: 18px;\n }\n}\n\n.popover {\n /* Override the default popover width — audio controls are more compact */\n width: auto;\n max-width: 95%;\n}","\"use client\";\n\nimport { Fragment, useRef } from \"react\";\n\nimport audioStyles from \"./assets/styles/thorium-web.audioActions.module.css\";\n\nimport { ThActionsBar, ThActionsTriggerVariant } from \"@/core/Components/Actions/ThActionsBar\";\nimport { usePlugins } from \"@/components/Plugins/PluginProvider\";\nimport { ActionComponent } from \"@/components/Plugins/PluginRegistry\";\n\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { useAudioPreferences } from \"@/preferences/hooks/useAudioPreferences\";\n\nconst AudioActionPair = ({ action }: { action: ActionComponent }) => {\n const triggerRef = useRef<HTMLButtonElement>(null);\n const { Trigger, Target } = action;\n return (\n <Fragment>\n <Trigger ref={ triggerRef } variant={ ThActionsTriggerVariant.button } />\n { Target && <Target triggerRef={ triggerRef } placement=\"top\" /> }\n </Fragment>\n );\n};\n\nexport const StatefulAudioMediaActions = () => {\n const { t } = useI18n();\n const { preferences } = useAudioPreferences();\n const { primaryAudioActionsMap } = usePlugins();\n\n const displayOrder = preferences.actions.primary.displayOrder;\n\n return (\n <ThActionsBar className={ audioStyles.wrapper } aria-label={ t(\"audio.player.mediaActions\") }>\n { displayOrder.map(key => {\n const action = primaryAudioActionsMap[key];\n if (!action) return null;\n return <AudioActionPair key={ key } action={ action } />;\n }) }\n </ThActionsBar>\n );\n};\n",".main {\n width: 100%;\n height: 100%;\n margin: 0;\n}\n\n.shell {\n position: relative;\n display: flex;\n flex-direction: column;\n flex: 1 1 0;\n height: 100vh;\n height: 100dvh;\n max-height: 100%;\n background-color: var(--th-theme-background);\n}\n\n.topBar {\n flex: 0 0 calc(var(--th-icon-size, 24px) * 2.5);\n height: calc(var(--th-icon-size, 24px) * 2.5);\n box-sizing: border-box;\n gap: 2px;\n touch-action: manipulation;\n background-color: var(--th-theme-background);\n}\n",".audioPlayerWrapper {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n gap: var(--th-layout-spacing);\n padding: var(--th-layout-spacing);\n height: 100%;\n width: 100%;\n overflow: hidden;\n}\n\n.audioPlayerWrapperExpanded {\n display: flex;\n flex-direction: row;\n align-items: stretch;\n box-sizing: border-box;\n gap: var(--th-layout-spacing);\n padding: var(--th-layout-spacing);\n height: 100%;\n width: 100%;\n max-width: 960px;\n margin-inline: auto;\n container-type: inline-size;\n}\n\n.audioPlayerExpandedStart {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n flex: 1 1 0;\n min-width: 0;\n gap: var(--th-layout-spacing);\n container-type: inline-size;\n}\n\n.audioPlayerExpandedEnd {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n flex: 1 1 0;\n min-width: 0;\n gap: var(--th-layout-spacing);\n container-type: inline-size;\n}\n\n.coverMetadataGroup {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--th-layout-spacing);\n flex: 0 1 auto;\n width: 100%;\n}\n","\"use client\";\n\nimport audioLayoutStyles from \"./assets/styles/thorium-web.audio.app.module.css\";\nimport readerHeaderStyles from \"../assets/styles/thorium-web.reader.header.module.css\";\nimport overflowMenuStyles from \"../Actions/assets/styles/thorium-web.overflow.module.css\";\n\nimport { StatefulBackLink } from \"../StatefulBackLink\";\nimport { StatefulCollapsibleActionsBar } from \"../Actions/StatefulCollapsibleActionsBar\";\n\nimport { useReaderHeaderBase } from \"../hooks/useReaderHeaderBase\";\nimport { useAudioPreferences } from \"@/preferences/hooks/useAudioPreferences\";\n\nimport classNames from \"classnames\";\n\nexport const StatefulPlayerHeader = ({\n actionKeys,\n actionsOrder,\n}: {\n actionKeys: string[];\n actionsOrder: string[];\n}) => {\n const {\n headerRef, listActionItems, t,\n } = useReaderHeaderBase(actionKeys);\n\n const { preferences } = useAudioPreferences();\n\n return (\n <>\n <div\n ref={ headerRef }\n className={ classNames(audioLayoutStyles.topBar, readerHeaderStyles.header) }\n >\n { preferences.theming.header?.backLink && <StatefulBackLink className={ readerHeaderStyles.backlinkWrapper } /> }\n\n <StatefulCollapsibleActionsBar\n id=\"reader-header-overflowMenu\"\n items={ listActionItems() }\n prefs={{ ...preferences.actions.secondary, displayOrder: actionsOrder }}\n className={ readerHeaderStyles.actionsWrapper }\n aria-label={ t(\"reader.app.header.actions\") }\n overflowMenuClassName={ overflowMenuStyles.hint }\n />\n </div>\n </>\n );\n};\n",".audioCoverSection {\n position: relative;\n display: flex;\n justify-content: center;\n align-items: center;\n flex: 1 1 auto;\n min-height: 100px;\n max-height: var(--th-layout-constraints-cover, 300px);\n width: 100%;\n margin: 0;\n}\n\n.audioCoverImage {\n height: 100%;\n width: auto;\n max-width: 100%;\n object-fit: contain;\n border-radius: var(--th-layout-radius);\n filter: drop-shadow(var(--th-theme-elevate));\n}\n\n.audioCoverPlaceholder {\n max-height: var(--th-layout-constraints-cover, 300px);\n width: auto;\n max-width: 100%;\n aspect-ratio: 1 / 1;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: var(--th-theme-background);\n border-radius: var(--th-layout-radius);\n border: 1px solid var(--th-theme-subdue);\n filter: drop-shadow(var(--th-theme-elevate));\n}\n\n.audioCoverPlaceholder svg {\n width: 50%;\n height: 50%;\n fill: var(--th-theme-text);\n}\n\n.audioCoverSyncOverlay {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n max-height: var(--th-layout-constraints-cover, 300px);\n width: auto;\n max-width: 100%;\n aspect-ratio: 1 / 1;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: var(--th-layout-radius);\n background-color: color-mix(in srgb, var(--th-theme-background) 60%, transparent);\n}\n\n.audioCoverSyncIcon {\n width: calc(var(--th-icon-size, 24px) * 2);\n height: calc(var(--th-icon-size, 24px) * 2);\n fill: var(--th-theme-text);\n animation: audioCoverSpin 1.2s linear infinite;\n}\n\n@keyframes audioCoverSpin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n}\n","import * as React from \"react\";\nconst SvgMusicNote = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M287-167q-47-47-47-113t47-113q47-47 113-47 23 0 42.5 5.5T480-418v-422h240v160H560v400q0 66-47 113t-113 47q-66 0-113-47Z\" /></svg>;\nexport default SvgMusicNote;","import * as React from \"react\";\nconst SvgSync = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M160-160v-80h110l-16-14q-52-46-73-105t-21-119q0-111 66.5-197.5T400-790v84q-72 26-116 88.5T240-478q0 45 17 87.5t53 78.5l10 10v-98h80v240H160Zm400-10v-84q72-26 116-88.5T720-482q0-45-17-87.5T650-648l-10-10v98h-80v-240h240v80H690l16 14q49 49 71.5 106.5T800-482q0 111-66.5 197.5T560-170Z\" /></svg>;\nexport default SvgSync;","import { Ref } from \"react\";\n\nimport styles from \"./assets/styles/thorium-web.audioCover.module.css\";\n\nimport MusicNoteIcon from \"./assets/icons/music_note.svg\";\nimport SyncIcon from \"./assets/icons/sync.svg\";\n\nimport { useI18n } from \"@/i18n/useI18n\";\n\nimport { useAppSelector } from \"@/lib/hooks\";\n\nimport { proxyUrl } from \"@/helpers/proxyUrl\";\n\ninterface StatefulAudioCoverProps {\n ref?: Ref<HTMLElement>;\n coverUrl?: string;\n title?: string;\n}\n\nexport function StatefulAudioCover({ ref, coverUrl, title }: StatefulAudioCoverProps) {\n const { t } = useI18n();\n const isTrackReady = useAppSelector(state => state.player.isTrackReady);\n const isStalled = useAppSelector(state => state.player.isStalled);\n\n const showSyncOverlay = !isTrackReady || isStalled;\n\n return (\n <figure ref={ ref } className={ styles.audioCoverSection }>\n { coverUrl ? (\n <img\n src={ proxyUrl(coverUrl) }\n alt={ title || t(\"audio.player.coverAlt\") }\n className={ styles.audioCoverImage }\n crossOrigin=\"anonymous\"\n />\n ) : (\n <div className={ styles.audioCoverPlaceholder }>\n { showSyncOverlay ? (\n <SyncIcon className={ styles.audioCoverSyncIcon } aria-hidden=\"true\" />\n ) : (\n <MusicNoteIcon />\n ) }\n </div>\n ) }\n { coverUrl && showSyncOverlay && (\n <div className={ styles.audioCoverSyncOverlay } aria-hidden=\"true\">\n <SyncIcon className={ styles.audioCoverSyncIcon } />\n </div>\n ) }\n </figure>\n );\n}\n",".audioMetadata {\n display: flex;\n flex-direction: column;\n align-items: center;\n margin: 0;\n gap: var(--th-layout-spacing);\n text-align: center;\n}\n\n.audioMetadata hgroup {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 0;\n margin: 0;\n}\n\n.audioMetadataTitle {\n margin: 0;\n font-size: 1em;\n font-weight: bold;\n color: var(--th-theme-text);\n}\n\n.audioMetadataSubtitle {\n display: block;\n margin: 0;\n margin-top: calc(var(--th-layout-spacing) / 4);\n font-weight: normal;\n color: var(--th-theme-text);\n}\n\n.audioMetadataAuthors {\n margin: 0;\n color: var(--th-theme-subdue-text);\n}\n\n@container (max-width: 300px) {\n .audioMetadata {\n font-size: 0.875rem;\n }\n}\n","import styles from \"./assets/styles/thorium-web.audioMetadata.module.css\";\n\nimport { Publication } from \"@readium/shared\";\nimport { useAudioPreferences } from \"@/preferences/hooks/useAudioPreferences\";\nimport { ThAudioPublicationMetadataComponent } from \"@/preferences/models\";\n\ninterface StatefulAudioMetadataProps {\n publication: Publication;\n}\n\nexport function StatefulAudioMetadata({ publication }: StatefulAudioMetadataProps) {\n const { preferences } = useAudioPreferences();\n const { metadata } = publication;\n\n const title = metadata.title.getTranslation(\"en\");\n const subtitle = metadata.subtitle?.getTranslation(\"en\");\n const authors = metadata.authors?.items.map(a => a.name.getTranslation(\"en\"));\n\n const metadataOrder = preferences.theming.layout.publicationMetadata.order;\n\n const renderMetadataComponents = () => {\n return metadataOrder.map((component: ThAudioPublicationMetadataComponent) => {\n switch (component) {\n case ThAudioPublicationMetadataComponent.title:\n return <h1 key=\"title\" className={ styles.audioMetadataTitle }>{ title }</h1>;\n\n case ThAudioPublicationMetadataComponent.titleWithSubtitle:\n return (\n <hgroup key=\"title-with-subtitle\">\n <h1 className={ styles.audioMetadataTitle }>{ title }</h1>\n { subtitle && <p className={ styles.audioMetadataSubtitle }>{ subtitle }</p> }\n </hgroup>\n );\n\n case ThAudioPublicationMetadataComponent.subtitleWithTitle:\n return (\n <hgroup key=\"subtitle-with-title\">\n { subtitle && <p className={ styles.audioMetadataSubtitle }>{ subtitle }</p> }\n <h1 className={ styles.audioMetadataTitle }>{ title }</h1>\n </hgroup>\n );\n\n case ThAudioPublicationMetadataComponent.authors:\n return authors && authors.length > 0 ? (\n <p key=\"authors\" className={ styles.audioMetadataAuthors }>{ authors.join(\", \") }</p>\n ) : null;\n \n default:\n return null;\n }\n }).filter(Boolean);\n };\n\n return (\n <header className={ styles.audioMetadata }>\n { renderMetadataComponents() }\n </header>\n );\n}\n","\"use client\";\n\nimport { useRef } from \"react\";\nimport { AudioSettings, useAudioSettingsCache } from \"@/core/Hooks/Audio/useAudioSettingsCache\";\nimport { AdjacentTimelineItem } from \"@/lib/publicationReducer\";\n\nexport interface AudioStatelessCache {\n settings: AudioSettings;\n sleepTimerOnTrackEnd: boolean;\n sleepTimerOnFragmentEnd: boolean;\n adjacentTimelineItems: {\n previous: AdjacentTimelineItem | null;\n next: AdjacentTimelineItem | null;\n };\n}\n\nexport const useAudioStatelessCache = (\n volume: number,\n playbackRate: number,\n preservePitch: boolean,\n skipBackwardInterval: number,\n skipForwardInterval: number,\n skipInterval: number,\n pollInterval: number,\n autoPlay: boolean,\n enableMediaSession: boolean,\n sleepTimerOnTrackEnd: boolean,\n sleepTimerOnFragmentEnd: boolean,\n adjacentTimelineItems: {\n previous: AdjacentTimelineItem | null;\n next: AdjacentTimelineItem | null;\n }\n) => {\n const settingsCache = useAudioSettingsCache(\n volume,\n playbackRate,\n preservePitch,\n skipBackwardInterval,\n skipForwardInterval,\n skipInterval,\n pollInterval,\n autoPlay,\n enableMediaSession\n );\n\n const cache = useRef<AudioStatelessCache>({\n settings: settingsCache.current.settings,\n sleepTimerOnTrackEnd,\n sleepTimerOnFragmentEnd,\n adjacentTimelineItems,\n });\n\n // Update cache synchronously on every render to ensure fresh values\n cache.current.settings = settingsCache.current.settings;\n cache.current.sleepTimerOnTrackEnd = sleepTimerOnTrackEnd;\n cache.current.sleepTimerOnFragmentEnd = sleepTimerOnFragmentEnd;\n cache.current.adjacentTimelineItems = adjacentTimelineItems;\n\n return cache;\n};\n","\"use client\";\n\nimport { useMemo } from \"react\";\n\nimport { ThAudioPreferences } from \"@/preferences/audioPreferences\";\nimport { ThAudioKeys } from \"@/preferences/models/audio\";\nimport { AudioSettings } from \"@/core/Hooks/Audio/useAudioSettingsCache\";\n\ninterface UseAudioPreferencesConfigProps {\n settings: AudioSettings;\n preferences: ThAudioPreferences;\n}\n\nexport const useAudioPreferencesConfig = ({\n settings,\n preferences,\n}: UseAudioPreferencesConfigProps) => {\n const audioPreferences = useMemo(() => {\n const isSkipIntervalMode = ThAudioKeys.skipInterval in preferences.settings.keys;\n return {\n volume: settings.volume,\n playbackRate: settings.playbackRate,\n preservePitch: settings.preservePitch,\n skipBackwardInterval: isSkipIntervalMode ? settings.skipInterval : settings.skipBackwardInterval,\n skipForwardInterval: isSkipIntervalMode ? settings.skipInterval : settings.skipForwardInterval,\n pollInterval: settings.pollInterval,\n autoPlay: settings.autoPlay,\n enableMediaSession: settings.enableMediaSession,\n };\n }, [settings, preferences.settings.keys]);\n\n const audioDefaults = useMemo(() => {\n return {\n volume: 1.0,\n playbackRate: 1.0,\n preservePitch: true,\n skipBackwardInterval: 10,\n skipForwardInterval: 10,\n pollInterval: 1000,\n autoPlay: false,\n enableMediaSession: true,\n };\n }, []);\n\n return { audioPreferences, audioDefaults };\n};\n","\"use client\";\n\nimport { useCallback, useEffect, useState, useRef } from \"react\";\n\nimport { Locator, LocatorLocations, Publication } from \"@readium/shared\";\nimport { AudioNavigatorListeners, IAudioContentProtectionConfig, IKeyboardPeripheralsConfig } from \"@readium/navigator\";\nimport { ThAudioPreferences } from \"@/preferences/audioPreferences\";\n\nimport { AudioStatelessCache } from \"./useAudioStatelessCache\";\nimport { useAudioPreferencesConfig } from \"./useAudioPreferencesConfig\";\nimport { useAudioNavigator, AudioNavigatorLoadProps } from \"@/core/Hooks/Audio/useAudioNavigator\";\n\ninterface UseAudioPlayerInitProps {\n publication: Publication | null;\n initialPosition: Locator | null;\n listeners: AudioNavigatorListeners;\n preferences: ThAudioPreferences;\n cache: React.RefObject<AudioStatelessCache>;\n contentProtectionConfig?: IAudioContentProtectionConfig;\n keyboardPeripherals?: IKeyboardPeripheralsConfig;\n onNavigatorReady?: () => void;\n onNavigatorLoaded?: () => void;\n onCleanup?: () => void;\n}\n\nexport const useAudioPlayerInit = ({\n publication,\n initialPosition,\n listeners,\n preferences,\n cache,\n contentProtectionConfig,\n keyboardPeripherals,\n onNavigatorReady,\n onNavigatorLoaded,\n onCleanup,\n}: UseAudioPlayerInitProps) => {\n const [navigatorReady, setNavigatorReady] = useState(false);\n\n const { audioPreferences, audioDefaults } = useAudioPreferencesConfig({\n settings: cache.current.settings,\n preferences,\n });\n\n const handleCleanup = useCallback(() => {\n onCleanup?.();\n }, [onCleanup]);\n\n const { AudioNavigatorLoad, AudioNavigatorDestroy } = useAudioNavigator();\n const isNavigatorLoadedAudio = useRef(false);\n\n useEffect(() => {\n // Only initialize once, never re-render\n if (!publication || isNavigatorLoadedAudio.current) return;\n\n // Initialize navigator for Audio\n\n const config: AudioNavigatorLoadProps = {\n publication,\n listeners,\n initialPosition: initialPosition ? new Locator({\n ...initialPosition,\n locations: initialPosition.locations ? new LocatorLocations(initialPosition.locations) : undefined\n }) : undefined,\n preferences: audioPreferences,\n defaults: audioDefaults,\n contentProtection: contentProtectionConfig,\n keyboardPeripherals,\n };\n\n isNavigatorLoadedAudio.current = true;\n\n // Call onNavigatorReady outside of navigator load\n onNavigatorReady?.();\n\n // Pass onNavigatorLoaded as the callback to AudioNavigatorLoad\n AudioNavigatorLoad(config, () => {\n // Set navigatorReady to true only after navigator actually loads\n setNavigatorReady(true);\n onNavigatorLoaded?.();\n });\n\n return () => {\n if (isNavigatorLoadedAudio.current) {\n setNavigatorReady(false);\n AudioNavigatorDestroy(() => {\n isNavigatorLoadedAudio.current = false;\n handleCleanup();\n });\n }\n };\n }, []);\n\n return {\n navigatorReady,\n };\n};\n","\"use client\";\n\nimport { useMemo } from \"react\";\n\nimport { IKeyboardPeripheralsConfig } from \"@readium/navigator\";\n\nimport { useAudioActionsPreferences } from \"@/preferences/hooks/useActionsPreferences\";\n\nimport { toActionPeripheralType, toDockingPeripheralType } from \"@/helpers/peripherals\";\n\nexport const useAudioKeyboardPeripherals = (): IKeyboardPeripheralsConfig => {\n const { primaryActionsKeys, secondaryActionsKeys, primaryDisplayOrder, secondaryDisplayOrder, docking } = useAudioActionsPreferences();\n\n return useMemo(() => {\n const config: IKeyboardPeripheralsConfig = [];\n const allKeys = { ...primaryActionsKeys, ...secondaryActionsKeys };\n\n for (const [key, tokens] of Object.entries(allKeys)) {\n const shortcut = tokens?.shortcut;\n const isInOrder = primaryDisplayOrder.includes(key) || secondaryDisplayOrder.includes(key);\n if (shortcut && isInOrder) config.push({ type: toActionPeripheralType(key), keyCombos: shortcut.keyCombos });\n }\n\n for (const [key, tokens] of Object.entries(docking.keys)) {\n if (tokens?.shortcut) config.push({ type: toDockingPeripheralType(key), keyCombos: tokens.shortcut.keyCombos });\n }\n\n return config;\n }, [primaryActionsKeys, secondaryActionsKeys, primaryDisplayOrder, secondaryDisplayOrder, docking.keys]);\n};\n","/**\n * True for any browser running on the WebKit engine without Chrome's Blink layer\n * (Safari on macOS/iOS, and all iOS browsers which are forced onto WebKit).\n * Used to gate around WebKit-specific platform quirks.\n */\nexport const isWebKit = typeof navigator !== \"undefined\"\n && /webkit/i.test(navigator.userAgent)\n && !/chrome/i.test(navigator.userAgent);\n","\"use client\";\n\nimport { useLayoutEffect, useState, useMemo, useCallback, useRef, useEffect } from \"react\";\n\nimport audioLayoutStyles from \"./assets/styles/thorium-web.audio.app.module.css\";\nimport audioStyles from \"./assets/styles/thorium-web.audioPlayer.module.css\";\n\nimport { ThPluginRegistry } from \"../Plugins/PluginRegistry\";\n\nimport { ThPluginProvider } from \"../Plugins/PluginProvider\";\nimport { NavigatorProvider } from \"@/core/Navigator\";\n\nimport { Publication } from \"@readium/shared\";\nimport { ContextMenuEvent, SuspiciousActivityEvent } from \"@readium/navigator-html-injectables\";\nimport { fromActionPeripheralType, fromDockingPeripheralType } from \"@/helpers/peripherals\";\nimport { AudioNavigatorListeners, KeyboardPeripheralEventData } from \"@readium/navigator\";\nimport { PositionStorage } from \"../Reader/StatefulReaderWrapper\";\nimport { ThAudioPlayerComponent } from \"@/preferences/models\";\n\nimport { StatefulDockingWrapper } from \"../Docking/StatefulDockingWrapper\";\nimport { StatefulPlayerHeader } from \"./StatefulPlayerHeader\";\n\nimport { StatefulAudioCover } from \"./StatefulAudioCover\";\nimport { StatefulAudioMetadata } from \"./StatefulAudioMetadata\";\nimport { StatefulAudioPlaybackControls } from \"./controls/StatefulAudioPlaybackControls\";\nimport { StatefulAudioMediaActions } from \"./actions/StatefulAudioMediaActions\";\nimport { StatefulAudioProgressBar } from \"./controls/StatefulAudioProgressBar\";\n\nimport { useAudioPreferences } from \"@/preferences/hooks/useAudioPreferences\";\nimport { useAudioNavigator } from \"@/core/Hooks/Audio/useAudioNavigator\";\nimport { useAudioStatelessCache } from \"./Hooks/useAudioStatelessCache\";\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { resolveAudioContentProtectionConfig } from \"@/preferences/models/protection\";\nimport { usePositionStorage } from \"@/hooks/usePositionStorage\";\nimport { useDocumentTitle } from \"@/core/Hooks/useDocumentTitle\";\nimport { useAudioPlayerInit } from \"./Hooks/useAudioPlayerInit\";\nimport { useAudioKeyboardPeripherals } from \"./Hooks/useAudioKeyboardPeripherals\";\nimport { useFocusedDockableKey } from \"../Docking/hooks/useFocusedDockableKey\";\n\nimport { useAppSelector, useAppDispatch } from \"@/lib/hooks\";\nimport {\n setLoading\n} from \"@/lib/readerReducer\";\nimport { toggleActionOpen, dockAction } from \"@/lib/actionsReducer\";\nimport { ThDockingKeys } from \"@/preferences/models\";\nimport {\n setPublicationStart,\n setPublicationEnd,\n setTocEntry,\n setAdjacentTimelineItems,\n} from \"@/lib/publicationReducer\";\nimport { findTocItemByHref, TocItem } from \"@/helpers/buildTocTree\";\nimport { isWebKit } from \"@/helpers/browser\";\nimport { TimelineItem } from \"@readium/shared\";\nimport { \n setStatus,\n setSeeking,\n setStalled,\n setTrackReady,\n setSleepTimerOnTrackEnd,\n setSleepTimerOnFragmentEnd,\n setRemotePlaybackState,\n setSeekableRanges\n} from \"@/lib/playerReducer\";\n\nimport { createAudioDefaultPlugin } from \"../Plugins/helpers/createAudioDefaultPlugin\";\nimport debounce from \"debounce\";\n\nexport interface StatefulPlayerProps {\n publication: Publication;\n localDataKey: string | null;\n plugins?: any[];\n positionStorage?: PositionStorage;\n coverUrl?: string;\n containerRefSetter?: (el: Element | null) => void;\n}\n\nexport const StatefulPlayer = ({\n publication,\n localDataKey,\n plugins,\n positionStorage,\n coverUrl,\n containerRefSetter\n}: StatefulPlayerProps) => {\n const [pluginsRegistered, setPluginsRegistered] = useState(false);\n\n useLayoutEffect(() => {\n if (plugins && plugins.length > 0) {\n plugins.forEach(plugin => {\n ThPluginRegistry.register(plugin);\n });\n } else {\n ThPluginRegistry.register(createAudioDefaultPlugin());\n }\n setPluginsRegistered(true);\n }, [plugins]);\n\n if (!pluginsRegistered) {\n return null;\n }\n\n return (\n <ThPluginProvider>\n <StatefulPlayerInner publication={ publication } localDataKey={ localDataKey } positionStorage={ positionStorage } coverUrl={ coverUrl } containerRefSetter={ containerRefSetter } />\n </ThPluginProvider>\n );\n};\n\nconst StatefulPlayerInner = ({ publication, localDataKey, positionStorage, coverUrl, containerRefSetter }: { publication: Publication; localDataKey: string | null; positionStorage?: PositionStorage; coverUrl?: string; containerRefSetter?: (el: Element | null) => void }) => {\n const { preferences } = useAudioPreferences();\n const { t } = useI18n();\n const profile = useAppSelector(state => state.reader.profile);\n const keyboardPeripherals = useAudioKeyboardPeripherals();\n\n const wrapperRef = useRef<HTMLElement>(null);\n const coverSectionRef = useRef<HTMLElement>(null);\n const compactMinHeight = useRef<number>(0);\n const [isExpanded, setIsExpanded] = useState(false);\n\n const sleepOnTrackEnd = useAppSelector(state => state.player.sleepTimer.onTrackEnd);\n const sleepOnFragmentEnd = useAppSelector(state => state.player.sleepTimer.onFragmentEnd);\n const adjacentTimelineItems = useAppSelector(state => state.publication.adjacentTimelineItems);\n const volume = useAppSelector(state => state.audioSettings.volume);\n const playbackRate = useAppSelector(state => state.audioSettings.playbackRate);\n const preservePitch = useAppSelector(state => state.audioSettings.preservePitch);\n const skipBackwardInterval = useAppSelector(state => state.audioSettings.skipBackwardInterval);\n const skipForwardInterval = useAppSelector(state => state.audioSettings.skipForwardInterval);\n const skipInterval = useAppSelector(state => state.audioSettings.skipInterval);\n const pollInterval = useAppSelector(state => state.audioSettings.pollInterval);\n const autoPlay = useAppSelector(state => state.audioSettings.autoPlay);\n const enableMediaSession = useAppSelector(state => state.audioSettings.enableMediaSession);\n\n const cache = useAudioStatelessCache(\n volume,\n playbackRate,\n preservePitch,\n skipBackwardInterval,\n skipForwardInterval,\n skipInterval,\n pollInterval,\n autoPlay,\n enableMediaSession,\n sleepOnTrackEnd,\n sleepOnFragmentEnd,\n adjacentTimelineItems\n );\n\n const dispatch = useAppDispatch();\n const getFocusedDockableKey = useFocusedDockableKey();\n\n const audioNavigator = useAudioNavigator();\n const { canGoBackward, canGoForward, submitPreferences, pause, isPlaying } = audioNavigator;\n\n const { setLocalData, getLocalData } = usePositionStorage(localDataKey, positionStorage);\n\n const documentTitle = publication?.metadata?.title?.getTranslation(\"en\");\n useDocumentTitle(documentTitle);\n\n const tocTree = useAppSelector(state => state.publication.unstableTimeline?.toc?.tree);\n const tocTreeRef = useRef<TocItem[] | undefined>(undefined);\n useEffect(() => {\n tocTreeRef.current = tocTree;\n }, [tocTree]);\n\n // Callback to handle timeline navigation state updates\n const handleTimelineNavigation = useCallback((item: TimelineItem) => {\n const tl = publication.timeline;\n const link = tl.linkFor(item);\n if (link) {\n const matched = findTocItemByHref(tocTreeRef.current || [], link.href);\n dispatch(setTocEntry(matched || null));\n }\n const { previous, next } = tl.adjacentTo(item);\n dispatch(setAdjacentTimelineItems({\n previous: previous ? { title: previous.title, href: tl.linkFor(previous)?.href ?? \"\" } : null,\n next: next ? { title: next.title, href: tl.linkFor(next)?.href ?? \"\" } : null,\n }));\n return { previous, next };\n }, [dispatch, publication]);\n\n // Callback to check if affordance is timeline or toc (fragment-based)\n const isFragmentAffordance = useCallback((affordance: string) => {\n return affordance === \"timeline\" || affordance === \"toc\";\n }, []);\n\n // Callback to handle sleep timer endOfFragment logic\n const handleSleepTimerEndOfFragment = useCallback((isTransitionToNext: boolean) => {\n if (!cache.current.sleepTimerOnFragmentEnd || !isTransitionToNext) return;\n \n const nextAffordance = preferences.affordances.next;\n if (isFragmentAffordance(nextAffordance)) {\n pause();\n dispatch(setSleepTimerOnFragmentEnd(false));\n }\n }, [cache, preferences.affordances.next, isFragmentAffordance, pause, dispatch]);\n\n // Callback to handle continuous play logic\n const handleContinuousPlay = useCallback((isTransitionToNext: boolean) => {\n if (!cache.current.settings.autoPlay && isTransitionToNext) {\n if (isFragmentAffordance(preferences.affordances.next)) {\n pause();\n }\n }\n }, [cache, preferences.affordances.next, isFragmentAffordance, pause]);\n\n const listeners: AudioNavigatorListeners = useMemo(() => ({\n timelineItemChanged: (item: TimelineItem | undefined) => {\n if (!item) {\n dispatch(setTocEntry(null));\n dispatch(setAdjacentTimelineItems({ previous: null, next: null }));\n return;\n }\n\n // Capture the previous \"next\" item from cache BEFORE handleTimelineNavigation updates Redux state\n const previousNextItem = cache.current.adjacentTimelineItems.next;\n const currentItemHref = publication.timeline.linkFor(item)?.href ?? \"\";\n\n // Update TOC entry and adjacent items (this updates Redux state)\n handleTimelineNavigation(item);\n\n // Check if we're transitioning to the next fragment by comparing current item href with previous next item href\n const isTransitionToNext = previousNextItem !== null &&\n previousNextItem.href === currentItemHref;\n\n handleSleepTimerEndOfFragment(isTransitionToNext);\n handleContinuousPlay(isTransitionToNext);\n },\n positionChanged: (locator) => {\n setLocalData(locator);\n\n if (canGoBackward()) {\n dispatch(setPublicationStart(false));\n } else {\n dispatch(setPublicationStart(true));\n }\n\n if (canGoForward()) {\n dispatch(setPublicationEnd(false));\n } else {\n dispatch(setPublicationEnd(true));\n }\n },\n trackLoaded: () => {\n dispatch(setTrackReady(true));\n dispatch(setStalled(false));\n dispatch(setStatus(isPlaying() ? \"playing\" : \"paused\"));\n },\n trackEnded: () => {\n if (cache.current.sleepTimerOnTrackEnd) {\n submitPreferences({ autoPlay: false });\n }\n if (cache.current.sleepTimerOnFragmentEnd) {\n submitPreferences({ autoPlay: false });\n dispatch(setSleepTimerOnFragmentEnd(false));\n }\n },\n metadataLoaded: () => {},\n play: () => {\n if (cache.current.sleepTimerOnTrackEnd) {\n submitPreferences({ autoPlay: cache.current.settings.autoPlay });\n dispatch(setSleepTimerOnTrackEnd(false));\n }\n dispatch(setStatus(\"playing\"));\n },\n pause: () => {\n dispatch(setStatus(\"paused\"));\n },\n stalled: (isStalled) => {\n dispatch(setStalled(isStalled));\n },\n seeking: (isSeeking) => {\n dispatch(setSeeking(isSeeking));\n },\n seekable: (timeRanges) => {\n const ranges = [];\n for (let i = 0; i < timeRanges.length; i++) {\n ranges.push({ start: timeRanges.start(i), end: timeRanges.end(i) });\n }\n dispatch(setSeekableRanges(ranges));\n },\n error: (error, locator) => {\n console.error(\"[AudioNavigator] playback error\", error, locator);\n dispatch(setStatus(\"paused\"));\n },\n remotePlaybackStateChanged: (state) => {\n if (isWebKit) return;\n dispatch(setRemotePlaybackState(state));\n },\n contentProtection: (_type: string, _detail: SuspiciousActivityEvent) => {},\n peripheral: (data: KeyboardPeripheralEventData) => {\n const actionKey = fromActionPeripheralType(data.type);\n\n if (actionKey && profile) {\n dispatch(toggleActionOpen({ key: actionKey, profile }));\n return;\n }\n\n const dockingKey = fromDockingPeripheralType(data.type);\n\n if (dockingKey && profile) {\n const actionKey = getFocusedDockableKey(dockingKey as ThDockingKeys);\n if (actionKey) {\n dispatch(dockAction({ key: actionKey, dockingKey: dockingKey as ThDockingKeys, profile }));\n }\n }\n },\n contextMenu: (_data: ContextMenuEvent) => {}\n }), [setLocalData, canGoBackward, canGoForward, isPlaying, dispatch, cache, submitPreferences, publication, handleTimelineNavigation, handleSleepTimerEndOfFragment, handleContinuousPlay, profile, getFocusedDockableKey]);\n\n const initialPosition = useMemo(() => getLocalData(), [getLocalData]);\n\n useAudioPlayerInit({\n publication,\n initialPosition,\n listeners,\n preferences,\n cache,\n contentProtectionConfig: resolveAudioContentProtectionConfig(preferences.contentProtection, t),\n keyboardPeripherals,\n onNavigatorLoaded: () => dispatch(setLoading(false)),\n });\n\n const { compact, expanded } = preferences.theming.layout;\n\n const renderPlayerComponent = useCallback((component: ThAudioPlayerComponent) => {\n switch (component) {\n case ThAudioPlayerComponent.cover:\n return <StatefulAudioCover key={ component } ref={ coverSectionRef } coverUrl={ coverUrl } title={ publication?.metadata?.title?.getTranslation(\"en\") } />;\n case ThAudioPlayerComponent.metadata:\n return publication ? <StatefulAudioMetadata key={ component } publication={ publication } /> : null;\n case ThAudioPlayerComponent.playbackControls:\n return <StatefulAudioPlaybackControls key={ component } />;\n case ThAudioPlayerComponent.progressBar:\n return <StatefulAudioProgressBar key={ component } />;\n case ThAudioPlayerComponent.mediaActions:\n return <StatefulAudioMediaActions key={ component } />;\n }\n }, [coverUrl, publication]);\n\n const renderCompactComponents = useCallback(() => {\n const coverIdx = compact.order.indexOf(ThAudioPlayerComponent.cover);\n const metaIdx = compact.order.indexOf(ThAudioPlayerComponent.metadata);\n const adjacent = coverIdx !== -1 && metaIdx !== -1 && Math.abs(coverIdx - metaIdx) === 1;\n\n if (!adjacent) {\n return compact.order.map(renderPlayerComponent);\n }\n\n const groupStart = Math.min(coverIdx, metaIdx);\n const nodes: React.ReactNode[] = [];\n for (let i = 0; i < compact.order.length; i++) {\n if (i === groupStart) {\n nodes.push(\n <div key=\"cover-metadata-group\" className={ audioStyles.coverMetadataGroup }>\n { renderPlayerComponent(compact.order[i]) }\n { renderPlayerComponent(compact.order[i + 1]) }\n </div>\n );\n i++;\n } else {\n nodes.push(renderPlayerComponent(compact.order[i]));\n }\n }\n return nodes;\n }, [compact.order, renderPlayerComponent]);\n\n useEffect(() => {\n const el = wrapperRef.current;\n if (!el) return;\n\n const check = debounce(() => {\n if (!isExpanded) {\n const overflow = el.scrollHeight - el.clientHeight;\n if (overflow > 0) {\n const coverEl = coverSectionRef.current;\n if (coverEl) {\n const minHeight = parseFloat(getComputedStyle(coverEl).minHeight) || 0;\n const newMaxHeight = coverEl.clientHeight - overflow;\n if (newMaxHeight >= minHeight) {\n el.style.setProperty(\"--th-layout-constraints-cover\", `${ newMaxHeight }px`);\n return;\n }\n }\n el.style.removeProperty(\"--th-layout-constraints-cover\");\n compactMinHeight.current = el.scrollHeight;\n setIsExpanded(true);\n } else {\n el.style.removeProperty(\"--th-layout-constraints-cover\");\n }\n } else {\n if (el.clientHeight > compactMinHeight.current) {\n setIsExpanded(false);\n }\n }\n }, 100);\n\n const observer = new ResizeObserver(check);\n\n observer.observe(el);\n return () => {\n check.clear();\n observer.disconnect();\n };\n }, [isExpanded]);\n\n return (\n <>\n <NavigatorProvider mediaNavigator={ audioNavigator }>\n <main className={ audioLayoutStyles.main }>\n <StatefulDockingWrapper>\n <div ref={ containerRefSetter } className={ audioLayoutStyles.shell }>\n <StatefulPlayerHeader\n actionKeys={ preferences.actions.secondary.displayOrder as string[] }\n actionsOrder={ preferences.actions.secondary.displayOrder as string[] }\n />\n\n <article\n ref={ wrapperRef }\n className={ isExpanded ? audioStyles.audioPlayerWrapperExpanded : audioStyles.audioPlayerWrapper }\n >\n { isExpanded ? (\n <>\n <div className={ audioStyles.audioPlayerExpandedStart }>\n { expanded.start.map(renderPlayerComponent) }\n </div>\n <div className={ audioStyles.audioPlayerExpandedEnd }>\n { expanded.end.map(renderPlayerComponent) }\n </div>\n </>\n ) : renderCompactComponents() }\n </article>\n </div>\n </StatefulDockingWrapper>\n </main>\n </NavigatorProvider>\n </>\n );\n};\n"]}