@edrlab/thorium-web 1.1.7 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{ThPreferencesAdapter-B8AYujCA.d.mts → ThPreferencesAdapter-DrZ5_6Dv.d.mts} +4 -139
- package/dist/{ThSettingsWrapper-BlmAxcWF.d.mts → ThSettingsWrapper-8Kx0SnH4.d.mts} +1 -1
- package/dist/{actions-BRtHsxpm.d.mts → actions-D2CHvCHu.d.mts} +2 -2
- package/dist/{actionsReducer-bT0pfxLJ.d.mts → actionsReducer-kc-S130w.d.mts} +3 -24
- package/dist/chunk-34MVY33F.mjs +913 -0
- package/dist/chunk-34MVY33F.mjs.map +1 -0
- package/dist/{chunk-KJXHAJYK.mjs → chunk-4VHEHMJN.mjs} +128 -11
- package/dist/chunk-4VHEHMJN.mjs.map +1 -0
- package/dist/{chunk-6V3O7FCS.mjs → chunk-72XCX5TD.mjs} +3 -3
- package/dist/{chunk-6V3O7FCS.mjs.map → chunk-72XCX5TD.mjs.map} +1 -1
- package/dist/{chunk-YIW2OOMW.mjs → chunk-7NEQAW7J.mjs} +2 -2
- package/dist/chunk-7NEQAW7J.mjs.map +1 -0
- package/dist/{chunk-4C3UOTX4.mjs → chunk-H4J2VY7Z.mjs} +172 -27
- package/dist/chunk-H4J2VY7Z.mjs.map +1 -0
- package/dist/{chunk-COQXDRKD.mjs → chunk-K3K7TUWM.mjs} +2 -2
- package/dist/chunk-K3K7TUWM.mjs.map +1 -0
- package/dist/chunk-RRDEPGBK.mjs +75 -0
- package/dist/chunk-RRDEPGBK.mjs.map +1 -0
- package/dist/chunk-S4M7ED5Q.mjs +407 -0
- package/dist/chunk-S4M7ED5Q.mjs.map +1 -0
- package/dist/components/Epub/index.d.mts +17 -11
- package/dist/components/Epub/index.mjs +9 -828
- package/dist/components/Epub/index.mjs.map +1 -1
- package/dist/components/Misc/index.css +23 -0
- package/dist/components/Misc/index.css.map +1 -1
- package/dist/components/Misc/index.d.mts +10 -1
- package/dist/components/Misc/index.mjs +31 -3
- package/dist/components/Misc/index.mjs.map +1 -1
- package/dist/components/Reader/index.css +1283 -0
- package/dist/components/Reader/index.css.map +1 -0
- package/dist/components/Reader/index.d.mts +30 -0
- package/dist/components/Reader/index.mjs +79 -0
- package/dist/components/Reader/index.mjs.map +1 -0
- package/dist/components/WebPub/index.d.mts +15 -31
- package/dist/components/WebPub/index.mjs +9 -372
- package/dist/components/WebPub/index.mjs.map +1 -1
- package/dist/core/Components/index.d.mts +7 -6
- package/dist/core/Helpers/index.d.mts +1 -1
- package/dist/core/Hooks/index.d.mts +54 -5
- package/dist/core/Hooks/index.mjs +1 -1
- package/dist/errorHandler-CL2YIfQY.d.mts +26 -0
- package/dist/i18n/index.mjs +2 -2
- package/dist/immer.d-CoRThNOF.d.mts +23 -0
- package/dist/lib/index.d.mts +12 -162
- package/dist/lib/index.mjs +1 -1
- package/dist/locales/el/thorium-web.json +31 -0
- package/dist/locales/en/thorium-web.json +10 -1
- package/dist/locales/et/thorium-web.json +6 -2
- package/dist/locales/fi/thorium-shared.json +14 -8
- package/dist/locales/fi/thorium-web.json +2 -1
- package/dist/locales/fr/thorium-shared.json +100 -0
- package/dist/locales/it/thorium-shared.json +9 -0
- package/dist/locales/lt/thorium-shared.json +22 -13
- package/dist/locales/lt/thorium-web.json +2 -1
- package/dist/locales/pt-PT/thorium-shared.json +64 -1
- package/dist/locales/pt-PT/thorium-web.json +4 -3
- package/dist/locales/sv/thorium-shared.json +61 -3
- package/dist/locales/sv/thorium-web.json +4 -3
- package/dist/preferences/index.d.mts +8 -7
- package/dist/preferences/index.mjs +1 -1
- package/dist/settingsReducer-C1wwCAMv.d.mts +159 -0
- package/dist/{ui-BVlJcPL_.d.mts → ui-CamWuqOo.d.mts} +1 -1
- package/dist/useContrast-D6sjPjxy.d.mts +152 -0
- package/dist/{useEpubNavigator-CsraD65e.d.mts → useEpubNavigator-CwHJfoiV.d.mts} +1 -1
- package/dist/{usePreferences-rfT368__.d.mts → usePreferences-BXFJbval.d.mts} +1 -1
- package/dist/{StatefulReader-CjgFzHoO.d.mts → useReaderTransitions-guT-eA-Q.d.mts} +50 -50
- package/package.json +5 -3
- package/dist/chunk-4C3UOTX4.mjs.map +0 -1
- package/dist/chunk-COQXDRKD.mjs.map +0 -1
- package/dist/chunk-KJXHAJYK.mjs.map +0 -1
- package/dist/chunk-YIW2OOMW.mjs.map +0 -1
- package/dist/useContrast-Cgsrl7GS.d.mts +0 -15
|
@@ -0,0 +1,407 @@
|
|
|
1
|
+
import { ThPluginRegistry, createDefaultPlugin, ThPluginProvider, useSpacingPresets, useFonts, useSettingsComponentStatus, usePositionStorage, useLineHeight, Peripherals, NavigatorProvider, thorium_web_reader_app_default, StatefulDockingWrapper, StatefulReaderHeader, StatefulReaderFooter, getReaderClassNames } from './chunk-H4J2VY7Z.mjs';
|
|
2
|
+
import { useWebPubSettingsCache, useFullscreen, useWebPubNavigator, useTimeline, useDocumentTitle } from './chunk-4VHEHMJN.mjs';
|
|
3
|
+
import { useAppSelector, useAppDispatch, setFullscreen, setTimeline, setHovering, toggleImmersive, useAppStore, toggleActionOpen, setPublicationStart, setPublicationEnd, setLoading } from './chunk-K3K7TUWM.mjs';
|
|
4
|
+
import { usePreferences, resolveContentProtectionConfig } from './chunk-7NEQAW7J.mjs';
|
|
5
|
+
import { useI18n } from './chunk-IYAFKTPL.mjs';
|
|
6
|
+
import { useState, useLayoutEffect, useRef, useCallback, useMemo, useEffect } from 'react';
|
|
7
|
+
import { I18nProvider } from 'react-aria';
|
|
8
|
+
import { Locator } from '@readium/shared';
|
|
9
|
+
import classNames from 'classnames';
|
|
10
|
+
import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
|
|
11
|
+
|
|
12
|
+
var useWebPubPreferencesConfig = ({
|
|
13
|
+
settings,
|
|
14
|
+
fontLanguage,
|
|
15
|
+
hasDisplayTransformability,
|
|
16
|
+
getFontMetadata,
|
|
17
|
+
lineHeightOptions
|
|
18
|
+
}) => {
|
|
19
|
+
const webPubPreferences = useMemo(() => {
|
|
20
|
+
const preferences = {
|
|
21
|
+
zoom: settings.zoom
|
|
22
|
+
};
|
|
23
|
+
if (hasDisplayTransformability) {
|
|
24
|
+
preferences.fontFamily = getFontMetadata(settings.fontFamily[fontLanguage] ?? "")?.fontStack || null;
|
|
25
|
+
preferences.fontWeight = settings.fontWeight;
|
|
26
|
+
preferences.hyphens = settings.hyphens;
|
|
27
|
+
preferences.letterSpacing = settings.letterSpacing;
|
|
28
|
+
preferences.lineHeight = settings.lineHeight === null ? null : lineHeightOptions[settings.lineHeight];
|
|
29
|
+
preferences.paragraphIndent = settings.paragraphIndent;
|
|
30
|
+
preferences.paragraphSpacing = settings.paragraphSpacing;
|
|
31
|
+
preferences.textAlign = settings.textAlign;
|
|
32
|
+
preferences.textNormalization = settings.textNormalization;
|
|
33
|
+
preferences.wordSpacing = settings.wordSpacing;
|
|
34
|
+
}
|
|
35
|
+
return preferences;
|
|
36
|
+
}, [
|
|
37
|
+
settings,
|
|
38
|
+
fontLanguage,
|
|
39
|
+
hasDisplayTransformability,
|
|
40
|
+
getFontMetadata,
|
|
41
|
+
lineHeightOptions
|
|
42
|
+
]);
|
|
43
|
+
return { webPubPreferences };
|
|
44
|
+
};
|
|
45
|
+
var useWebPubInjectablesConfig = ({
|
|
46
|
+
isFontFamilyUsed,
|
|
47
|
+
fontLanguage,
|
|
48
|
+
getFontInjectables
|
|
49
|
+
}) => {
|
|
50
|
+
const injectables = useMemo(() => {
|
|
51
|
+
let injectablesConfig;
|
|
52
|
+
if (isFontFamilyUsed) {
|
|
53
|
+
const fontResources = getFontInjectables({ language: fontLanguage });
|
|
54
|
+
if (fontResources) {
|
|
55
|
+
injectablesConfig = {
|
|
56
|
+
allowedDomains: fontResources.allowedDomains,
|
|
57
|
+
rules: [{
|
|
58
|
+
resources: [/\.xhtml$/, /\.html$/],
|
|
59
|
+
prepend: fontResources.prepend,
|
|
60
|
+
append: fontResources.append
|
|
61
|
+
}]
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return injectablesConfig;
|
|
66
|
+
}, [isFontFamilyUsed, fontLanguage, getFontInjectables]);
|
|
67
|
+
return { injectables };
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
// src/components/WebPub/Hooks/useReaderInit.ts
|
|
71
|
+
var useWebPubReaderInit = ({
|
|
72
|
+
container,
|
|
73
|
+
publication,
|
|
74
|
+
initialPosition,
|
|
75
|
+
listeners,
|
|
76
|
+
preferences,
|
|
77
|
+
cache,
|
|
78
|
+
isFontFamilyUsed,
|
|
79
|
+
fontLanguage,
|
|
80
|
+
hasDisplayTransformability,
|
|
81
|
+
getFontMetadata,
|
|
82
|
+
injectFontResources,
|
|
83
|
+
removeFontResources,
|
|
84
|
+
getFontInjectables,
|
|
85
|
+
lineHeightOptions,
|
|
86
|
+
contentProtectionConfig,
|
|
87
|
+
onNavigatorReady,
|
|
88
|
+
onNavigatorLoaded,
|
|
89
|
+
onCleanup
|
|
90
|
+
}) => {
|
|
91
|
+
const [navigatorReady, setNavigatorReady] = useState(false);
|
|
92
|
+
const { webPubPreferences } = useWebPubPreferencesConfig({
|
|
93
|
+
settings: cache.current.settings,
|
|
94
|
+
fontLanguage,
|
|
95
|
+
hasDisplayTransformability,
|
|
96
|
+
getFontMetadata,
|
|
97
|
+
lineHeightOptions
|
|
98
|
+
});
|
|
99
|
+
const { injectables } = useWebPubInjectablesConfig({
|
|
100
|
+
isFontFamilyUsed,
|
|
101
|
+
fontLanguage,
|
|
102
|
+
getFontInjectables
|
|
103
|
+
});
|
|
104
|
+
const handleCleanup = useCallback(() => {
|
|
105
|
+
removeFontResources();
|
|
106
|
+
onCleanup?.();
|
|
107
|
+
}, [removeFontResources, onCleanup]);
|
|
108
|
+
const { WebPubNavigatorLoad, WebPubNavigatorDestroy } = useWebPubNavigator();
|
|
109
|
+
const isNavigatorLoadedWebPub = useRef(false);
|
|
110
|
+
useEffect(() => {
|
|
111
|
+
if (!publication || isNavigatorLoadedWebPub.current) return;
|
|
112
|
+
if (!container.current) {
|
|
113
|
+
console.error("Container ref is not available for navigator initialization");
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const config = {
|
|
117
|
+
container: container.current,
|
|
118
|
+
publication,
|
|
119
|
+
listeners,
|
|
120
|
+
initialPosition: initialPosition ? new Locator(initialPosition) : void 0,
|
|
121
|
+
preferences: webPubPreferences,
|
|
122
|
+
defaults: {
|
|
123
|
+
experiments: preferences.experiments?.webPub || null
|
|
124
|
+
},
|
|
125
|
+
injectables,
|
|
126
|
+
contentProtection: contentProtectionConfig
|
|
127
|
+
};
|
|
128
|
+
isNavigatorLoadedWebPub.current = true;
|
|
129
|
+
onNavigatorReady?.();
|
|
130
|
+
WebPubNavigatorLoad(config, () => {
|
|
131
|
+
setNavigatorReady(true);
|
|
132
|
+
onNavigatorLoaded?.();
|
|
133
|
+
});
|
|
134
|
+
return () => {
|
|
135
|
+
if (isNavigatorLoadedWebPub.current) {
|
|
136
|
+
setNavigatorReady(false);
|
|
137
|
+
WebPubNavigatorDestroy(() => {
|
|
138
|
+
isNavigatorLoadedWebPub.current = false;
|
|
139
|
+
handleCleanup();
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
}, []);
|
|
144
|
+
useEffect(() => {
|
|
145
|
+
if (isFontFamilyUsed) {
|
|
146
|
+
const fontResources = getFontInjectables({ language: fontLanguage });
|
|
147
|
+
if (fontResources) {
|
|
148
|
+
injectFontResources(getFontInjectables(void 0, true));
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}, [isFontFamilyUsed, fontLanguage, getFontInjectables, injectFontResources]);
|
|
152
|
+
return {
|
|
153
|
+
navigatorReady
|
|
154
|
+
};
|
|
155
|
+
};
|
|
156
|
+
var ExperimentalWebPubStatefulReader = ({
|
|
157
|
+
publication,
|
|
158
|
+
localDataKey,
|
|
159
|
+
plugins,
|
|
160
|
+
positionStorage
|
|
161
|
+
}) => {
|
|
162
|
+
const [pluginsRegistered, setPluginsRegistered] = useState(false);
|
|
163
|
+
useLayoutEffect(() => {
|
|
164
|
+
if (plugins && plugins.length > 0) {
|
|
165
|
+
plugins.forEach((plugin) => {
|
|
166
|
+
ThPluginRegistry.register(plugin);
|
|
167
|
+
});
|
|
168
|
+
} else {
|
|
169
|
+
ThPluginRegistry.register(createDefaultPlugin());
|
|
170
|
+
}
|
|
171
|
+
setPluginsRegistered(true);
|
|
172
|
+
}, [plugins]);
|
|
173
|
+
if (!pluginsRegistered) {
|
|
174
|
+
return null;
|
|
175
|
+
}
|
|
176
|
+
return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(ThPluginProvider, { children: /* @__PURE__ */ jsx(StatefulReaderInner, { publication, localDataKey, positionStorage }) }) });
|
|
177
|
+
};
|
|
178
|
+
var StatefulReaderInner = ({ publication, localDataKey, positionStorage }) => {
|
|
179
|
+
const { preferences, getFontMetadata, getFontInjectables } = usePreferences();
|
|
180
|
+
const { t } = useI18n();
|
|
181
|
+
const { getEffectiveSpacingValue } = useSpacingPresets();
|
|
182
|
+
const { injectFontResources, removeFontResources } = useFonts();
|
|
183
|
+
const { isComponentUsed: isFontFamilyUsed } = useSettingsComponentStatus({
|
|
184
|
+
settingsKey: "fontFamily" /* fontFamily */,
|
|
185
|
+
publicationType: "webpub",
|
|
186
|
+
componentType: "text"
|
|
187
|
+
});
|
|
188
|
+
const container = useRef(null);
|
|
189
|
+
const textAlign = useAppSelector((state) => state.webPubSettings.textAlign);
|
|
190
|
+
const fontFamily = useAppSelector((state) => state.webPubSettings.fontFamily);
|
|
191
|
+
const fontWeight = useAppSelector((state) => state.webPubSettings.fontWeight);
|
|
192
|
+
const hyphens = useAppSelector((state) => state.webPubSettings.hyphens);
|
|
193
|
+
const letterSpacing = getEffectiveSpacingValue("letterSpacing" /* letterSpacing */);
|
|
194
|
+
const lineHeight = getEffectiveSpacingValue("lineHeight" /* lineHeight */);
|
|
195
|
+
const paragraphIndent = getEffectiveSpacingValue("paragraphIndent" /* paragraphIndent */);
|
|
196
|
+
const paragraphSpacing = getEffectiveSpacingValue("paragraphSpacing" /* paragraphSpacing */);
|
|
197
|
+
const publisherStyles = useAppSelector((state) => state.webPubSettings.publisherStyles);
|
|
198
|
+
const textNormalization = useAppSelector((state) => state.webPubSettings.textNormalization);
|
|
199
|
+
const wordSpacing = getEffectiveSpacingValue("wordSpacing" /* wordSpacing */);
|
|
200
|
+
const zoom = useAppSelector((state) => state.webPubSettings.zoom);
|
|
201
|
+
const fontLanguage = useAppSelector((state) => state.publication.fontLanguage);
|
|
202
|
+
const hasDisplayTransformability = useAppSelector((state) => state.publication.hasDisplayTransformability);
|
|
203
|
+
const isImmersive = useAppSelector((state) => state.reader.isImmersive);
|
|
204
|
+
const isHovering = useAppSelector((state) => state.reader.isHovering);
|
|
205
|
+
const cache = useWebPubSettingsCache(
|
|
206
|
+
fontFamily,
|
|
207
|
+
fontWeight,
|
|
208
|
+
hyphens,
|
|
209
|
+
letterSpacing,
|
|
210
|
+
lineHeight,
|
|
211
|
+
paragraphIndent,
|
|
212
|
+
paragraphSpacing,
|
|
213
|
+
publisherStyles,
|
|
214
|
+
textAlign,
|
|
215
|
+
textNormalization,
|
|
216
|
+
wordSpacing,
|
|
217
|
+
zoom
|
|
218
|
+
);
|
|
219
|
+
const layoutUI = preferences.theming.layout.ui?.webPub || "stacked-ui" /* stacked */;
|
|
220
|
+
const dispatch = useAppDispatch();
|
|
221
|
+
const onFsChange = useCallback((isFullscreen) => {
|
|
222
|
+
dispatch(setFullscreen(isFullscreen));
|
|
223
|
+
}, [dispatch]);
|
|
224
|
+
const fs = useFullscreen(onFsChange);
|
|
225
|
+
const webPubNavigator = useWebPubNavigator();
|
|
226
|
+
const {
|
|
227
|
+
currentPositions,
|
|
228
|
+
canGoBackward,
|
|
229
|
+
canGoForward
|
|
230
|
+
} = webPubNavigator;
|
|
231
|
+
const { setLocalData, getLocalData, localData } = usePositionStorage(localDataKey, positionStorage);
|
|
232
|
+
const timeline = useTimeline({
|
|
233
|
+
publication,
|
|
234
|
+
currentLocation: localData,
|
|
235
|
+
currentPositions: currentPositions() || [],
|
|
236
|
+
positionsList: void 0,
|
|
237
|
+
onChange: (timeline2) => {
|
|
238
|
+
dispatch(setTimeline(timeline2));
|
|
239
|
+
}
|
|
240
|
+
});
|
|
241
|
+
const lineHeightOptions = useLineHeight();
|
|
242
|
+
const documentTitleFormat = preferences.metadata?.documentTitle?.format;
|
|
243
|
+
let documentTitle;
|
|
244
|
+
if (documentTitleFormat) {
|
|
245
|
+
if (typeof documentTitleFormat === "object" && "key" in documentTitleFormat) {
|
|
246
|
+
const translatedTitle = t(documentTitleFormat.key);
|
|
247
|
+
documentTitle = translatedTitle !== documentTitleFormat.key ? translatedTitle : documentTitleFormat.fallback;
|
|
248
|
+
} else {
|
|
249
|
+
switch (documentTitleFormat) {
|
|
250
|
+
case "title" /* title */:
|
|
251
|
+
documentTitle = timeline?.title;
|
|
252
|
+
break;
|
|
253
|
+
case "chapter" /* chapter */:
|
|
254
|
+
documentTitle = timeline?.progression?.currentChapter;
|
|
255
|
+
break;
|
|
256
|
+
case "titleAndChapter" /* titleAndChapter */:
|
|
257
|
+
if (timeline?.title && timeline?.progression?.currentChapter) {
|
|
258
|
+
documentTitle = `${timeline.title} \u2013 ${timeline.progression.currentChapter}`;
|
|
259
|
+
}
|
|
260
|
+
break;
|
|
261
|
+
case "none" /* none */:
|
|
262
|
+
documentTitle = void 0;
|
|
263
|
+
break;
|
|
264
|
+
default:
|
|
265
|
+
documentTitle = documentTitleFormat;
|
|
266
|
+
break;
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
useDocumentTitle(documentTitle);
|
|
271
|
+
const toggleIsImmersive = useCallback(() => {
|
|
272
|
+
dispatch(setHovering(false));
|
|
273
|
+
dispatch(toggleImmersive());
|
|
274
|
+
}, [dispatch]);
|
|
275
|
+
const appStore = useAppStore();
|
|
276
|
+
const p = useMemo(() => new Peripherals(appStore, preferences.actions, {
|
|
277
|
+
moveTo: () => {
|
|
278
|
+
},
|
|
279
|
+
goProgression: () => {
|
|
280
|
+
},
|
|
281
|
+
toggleAction: (actionKey) => {
|
|
282
|
+
switch (actionKey) {
|
|
283
|
+
case "fullscreen" /* fullscreen */:
|
|
284
|
+
fs.handleFullscreen();
|
|
285
|
+
break;
|
|
286
|
+
case "settings" /* settings */:
|
|
287
|
+
case "toc" /* toc */:
|
|
288
|
+
dispatch(toggleActionOpen({
|
|
289
|
+
key: actionKey
|
|
290
|
+
}));
|
|
291
|
+
break;
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
}), [appStore, preferences.actions, fs, dispatch]);
|
|
295
|
+
const listeners = useMemo(() => ({
|
|
296
|
+
frameLoaded: async function(_wnd) {
|
|
297
|
+
p.observe(window);
|
|
298
|
+
},
|
|
299
|
+
positionChanged: async function(locator) {
|
|
300
|
+
setLocalData(locator);
|
|
301
|
+
if (canGoBackward()) {
|
|
302
|
+
dispatch(setPublicationStart(false));
|
|
303
|
+
} else {
|
|
304
|
+
dispatch(setPublicationStart(true));
|
|
305
|
+
}
|
|
306
|
+
if (canGoForward()) {
|
|
307
|
+
dispatch(setPublicationEnd(false));
|
|
308
|
+
} else {
|
|
309
|
+
dispatch(setPublicationEnd(true));
|
|
310
|
+
}
|
|
311
|
+
},
|
|
312
|
+
tap: function(_e) {
|
|
313
|
+
toggleIsImmersive();
|
|
314
|
+
return true;
|
|
315
|
+
},
|
|
316
|
+
click: function(_e) {
|
|
317
|
+
return false;
|
|
318
|
+
},
|
|
319
|
+
zoom: function(_scale) {
|
|
320
|
+
},
|
|
321
|
+
scroll: function(_delta) {
|
|
322
|
+
},
|
|
323
|
+
customEvent: function(_key, _data) {
|
|
324
|
+
},
|
|
325
|
+
handleLocator: function(locator) {
|
|
326
|
+
const href = locator.href;
|
|
327
|
+
if (href.startsWith("http://") || href.startsWith("https://") || href.startsWith("mailto:") || href.startsWith("tel:")) {
|
|
328
|
+
if (confirm(`Open "${href}" ?`)) window.open(href, "_blank");
|
|
329
|
+
} else {
|
|
330
|
+
console.warn("Unhandled locator", locator);
|
|
331
|
+
}
|
|
332
|
+
return false;
|
|
333
|
+
},
|
|
334
|
+
textSelected: function(_selection) {
|
|
335
|
+
},
|
|
336
|
+
contentProtection: function(_type, _data) {
|
|
337
|
+
},
|
|
338
|
+
contextMenu: function(_data) {
|
|
339
|
+
},
|
|
340
|
+
peripheral: function(_data) {
|
|
341
|
+
}
|
|
342
|
+
}), [p, setLocalData, canGoBackward, canGoForward, dispatch, toggleIsImmersive]);
|
|
343
|
+
const initialPosition = useMemo(() => getLocalData(), [getLocalData]);
|
|
344
|
+
useWebPubReaderInit({
|
|
345
|
+
container,
|
|
346
|
+
publication,
|
|
347
|
+
initialPosition,
|
|
348
|
+
listeners,
|
|
349
|
+
preferences,
|
|
350
|
+
cache,
|
|
351
|
+
isFontFamilyUsed,
|
|
352
|
+
fontLanguage,
|
|
353
|
+
hasDisplayTransformability,
|
|
354
|
+
getFontMetadata,
|
|
355
|
+
injectFontResources,
|
|
356
|
+
removeFontResources,
|
|
357
|
+
getFontInjectables,
|
|
358
|
+
lineHeightOptions,
|
|
359
|
+
contentProtectionConfig: resolveContentProtectionConfig(preferences.contentProtection, t),
|
|
360
|
+
onNavigatorReady: () => {
|
|
361
|
+
dispatch(setLoading(false));
|
|
362
|
+
},
|
|
363
|
+
onNavigatorLoaded: () => {
|
|
364
|
+
p.observe(window);
|
|
365
|
+
},
|
|
366
|
+
onCleanup: () => {
|
|
367
|
+
p.destroy();
|
|
368
|
+
}
|
|
369
|
+
});
|
|
370
|
+
return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(I18nProvider, { locale: preferences.locale, children: /* @__PURE__ */ jsx(NavigatorProvider, { navigator: webPubNavigator, children: /* @__PURE__ */ jsx("main", { className: thorium_web_reader_app_default.main, children: /* @__PURE__ */ jsx(StatefulDockingWrapper, { children: /* @__PURE__ */ jsxs(
|
|
371
|
+
"div",
|
|
372
|
+
{
|
|
373
|
+
className: classNames(
|
|
374
|
+
getReaderClassNames({
|
|
375
|
+
isScroll: true,
|
|
376
|
+
isImmersive,
|
|
377
|
+
isHovering,
|
|
378
|
+
layoutUI
|
|
379
|
+
})
|
|
380
|
+
),
|
|
381
|
+
children: [
|
|
382
|
+
/* @__PURE__ */ jsx(
|
|
383
|
+
StatefulReaderHeader,
|
|
384
|
+
{
|
|
385
|
+
actionKeys: preferences.actions.webPubOrder,
|
|
386
|
+
actionsOrder: preferences.actions.webPubOrder,
|
|
387
|
+
layout: layoutUI,
|
|
388
|
+
runningHeadFormatPref: preferences.theming.header?.runningHead?.format?.webPub
|
|
389
|
+
}
|
|
390
|
+
),
|
|
391
|
+
/* @__PURE__ */ jsx("article", { className: thorium_web_reader_app_default.wrapper, "aria-label": t("reader.app.publicationWrapper"), children: /* @__PURE__ */ jsx("div", { id: "thorium-web-container", className: thorium_web_reader_app_default.iframeContainer, ref: container }) }),
|
|
392
|
+
/* @__PURE__ */ jsx(
|
|
393
|
+
StatefulReaderFooter,
|
|
394
|
+
{
|
|
395
|
+
layout: layoutUI,
|
|
396
|
+
progressionFormatPref: preferences.theming.progression?.format?.webPub,
|
|
397
|
+
progressionFormatFallback: "readingOrderIndex" /* readingOrderIndex */
|
|
398
|
+
}
|
|
399
|
+
)
|
|
400
|
+
]
|
|
401
|
+
}
|
|
402
|
+
) }) }) }) }) });
|
|
403
|
+
};
|
|
404
|
+
|
|
405
|
+
export { ExperimentalWebPubStatefulReader };
|
|
406
|
+
//# sourceMappingURL=chunk-S4M7ED5Q.mjs.map
|
|
407
|
+
//# sourceMappingURL=chunk-S4M7ED5Q.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/WebPub/Hooks/usePreferencesConfig.ts","../src/components/WebPub/Hooks/useInjectablesConfig.ts","../src/components/WebPub/Hooks/useReaderInit.ts","../src/components/WebPub/StatefulReader.tsx"],"names":["useMemo","useState","useRef","useCallback","timeline"],"mappings":";;;;;;;;;;;AAiBO,IAAM,6BAA6B,CAAC;AAAA,EACzC,QAAA;AAAA,EACA,YAAA;AAAA,EACA,0BAAA;AAAA,EACA,eAAA;AAAA,EACA;AACF,CAAA,KAAuC;AACrC,EAAA,MAAM,iBAAA,GAAoB,QAAQ,MAAM;AACtC,IAAA,MAAM,WAAA,GAAkC;AAAA,MACtC,MAAM,QAAA,CAAS;AAAA,KACjB;AAEA,IAAA,IAAI,0BAAA,EAA4B;AAC9B,MAAA,WAAA,CAAY,UAAA,GAAa,gBAAgB,QAAA,CAAS,UAAA,CAAW,YAAY,CAAA,IAAK,EAAE,GAAG,SAAA,IAAa,IAAA;AAChG,MAAA,WAAA,CAAY,aAAa,QAAA,CAAS,UAAA;AAClC,MAAA,WAAA,CAAY,UAAU,QAAA,CAAS,OAAA;AAC/B,MAAA,WAAA,CAAY,gBAAgB,QAAA,CAAS,aAAA;AACrC,MAAA,WAAA,CAAY,aAAa,QAAA,CAAS,UAAA,KAAe,OAC7C,IAAA,GACA,iBAAA,CAAkB,SAAS,UAAU,CAAA;AACzC,MAAA,WAAA,CAAY,kBAAkB,QAAA,CAAS,eAAA;AACvC,MAAA,WAAA,CAAY,mBAAmB,QAAA,CAAS,gBAAA;AACxC,MAAA,WAAA,CAAY,YAAY,QAAA,CAAS,SAAA;AACjC,MAAA,WAAA,CAAY,oBAAoB,QAAA,CAAS,iBAAA;AACzC,MAAA,WAAA,CAAY,cAAc,QAAA,CAAS,WAAA;AAAA,IACrC;AAEA,IAAA,OAAO,WAAA;AAAA,EACT,CAAA,EAAG;AAAA,IACD,QAAA;AAAA,IACA,YAAA;AAAA,IACA,0BAAA;AAAA,IACA,eAAA;AAAA,IACA;AAAA,GACD,CAAA;AAED,EAAA,OAAO,EAAE,iBAAA,EAAkB;AAC7B,CAAA;ACzCO,IAAM,6BAA6B,CAAC;AAAA,EACzC,gBAAA;AAAA,EACA,YAAA;AAAA,EACA;AACF,CAAA,KAAuC;AACrC,EAAA,MAAM,WAAA,GAAcA,QAAQ,MAAM;AAChC,IAAA,IAAI,iBAAA;AAEJ,IAAA,IAAI,gBAAA,EAAkB;AACpB,MAAA,MAAM,aAAA,GAAgB,kBAAA,CAAmB,EAAE,QAAA,EAAU,cAAc,CAAA;AACnE,MAAA,IAAI,aAAA,EAAe;AACjB,QAAA,iBAAA,GAAoB;AAAA,UAClB,gBAAgB,aAAA,CAAc,cAAA;AAAA,UAC9B,OAAO,CAAC;AAAA,YACN,SAAA,EAAW,CAAC,UAAA,EAAY,SAAS,CAAA;AAAA,YACjC,SAAS,aAAA,CAAc,OAAA;AAAA,YACvB,QAAQ,aAAA,CAAc;AAAA,WACvB;AAAA,SACH;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,iBAAA;AAAA,EACT,CAAA,EAAG,CAAC,gBAAA,EAAkB,YAAA,EAAc,kBAAkB,CAAC,CAAA;AAEvD,EAAA,OAAO,EAAE,WAAA,EAAY;AACvB,CAAA;;;ACHO,IAAM,sBAAsB,CAAC;AAAA,EAClC,SAAA;AAAA,EACA,WAAA;AAAA,EACA,eAAA;AAAA,EACA,SAAA;AAAA,EACA,WAAA;AAAA,EACA,KAAA;AAAA,EACA,gBAAA;AAAA,EACA,YAAA;AAAA,EACA,0BAAA;AAAA,EACA,eAAA;AAAA,EACA,mBAAA;AAAA,EACA,mBAAA;AAAA,EACA,kBAAA;AAAA,EACA,iBAAA;AAAA,EACA,uBAAA;AAAA,EACA,gBAAA;AAAA,EACA,iBAAA;AAAA,EACA;AACF,CAAA,KAAgC;AAC9B,EAAA,MAAM,CAAC,cAAA,EAAgB,iBAAiB,CAAA,GAAI,SAAS,KAAK,CAAA;AAE1D,EAAA,MAAM,EAAE,iBAAA,EAAkB,GAAI,0BAAA,CAA2B;AAAA,IACvD,QAAA,EAAU,MAAM,OAAA,CAAQ,QAAA;AAAA,IACxB,YAAA;AAAA,IACA,0BAAA;AAAA,IACA,eAAA;AAAA,IACA;AAAA,GACD,CAAA;AAED,EAAA,MAAM,EAAE,WAAA,EAAY,GAAI,0BAAA,CAA2B;AAAA,IACjD,gBAAA;AAAA,IACA,YAAA;AAAA,IACA;AAAA,GACD,CAAA;AAED,EAAA,MAAM,aAAA,GAAgB,YAAY,MAAM;AACtC,IAAA,mBAAA,EAAoB;AACpB,IAAA,SAAA,IAAY;AAAA,EACd,CAAA,EAAG,CAAC,mBAAA,EAAqB,SAAS,CAAC,CAAA;AAEnC,EAAA,MAAM,EAAE,mBAAA,EAAqB,sBAAA,EAAuB,GAAI,kBAAA,EAAmB;AAC3E,EAAA,MAAM,uBAAA,GAA0B,OAAO,KAAK,CAAA;AAE5C,EAAA,SAAA,CAAU,MAAM;AAEd,IAAA,IAAI,CAAC,WAAA,IAAe,uBAAA,CAAwB,OAAA,EAAS;AAGrD,IAAA,IAAI,CAAC,UAAU,OAAA,EAAS;AACtB,MAAA,OAAA,CAAQ,MAAM,6DAA6D,CAAA;AAC3E,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,MAAA,GAAmC;AAAA,MACvC,WAAW,SAAA,CAAU,OAAA;AAAA,MACrB,WAAA;AAAA,MACA,SAAA;AAAA,MACA,eAAA,EAAiB,eAAA,GAAkB,IAAI,OAAA,CAAQ,eAAe,CAAA,GAAI,MAAA;AAAA,MAClE,WAAA,EAAa,iBAAA;AAAA,MACb,QAAA,EAAU;AAAA,QACR,WAAA,EAAa,WAAA,CAAY,WAAA,EAAa,MAAA,IAAU;AAAA,OAClD;AAAA,MACA,WAAA;AAAA,MACA,iBAAA,EAAmB;AAAA,KACrB;AAEA,IAAA,uBAAA,CAAwB,OAAA,GAAU,IAAA;AAGlC,IAAA,gBAAA,IAAmB;AAGnB,IAAA,mBAAA,CAAoB,QAAQ,MAAM;AAEhC,MAAA,iBAAA,CAAkB,IAAI,CAAA;AACtB,MAAA,iBAAA,IAAoB;AAAA,IACtB,CAAC,CAAA;AAED,IAAA,OAAO,MAAM;AACX,MAAA,IAAI,wBAAwB,OAAA,EAAS;AACnC,QAAA,iBAAA,CAAkB,KAAK,CAAA;AACvB,QAAA,sBAAA,CAAuB,MAAM;AAC3B,UAAA,uBAAA,CAAwB,OAAA,GAAU,KAAA;AAClC,UAAA,aAAA,EAAc;AAAA,QAChB,CAAC,CAAA;AAAA,MACH;AAAA,IACF,CAAA;AAAA,EACF,CAAA,EAAG,EAAE,CAAA;AAGL,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,gBAAA,EAAkB;AACpB,MAAA,MAAM,aAAA,GAAgB,kBAAA,CAAmB,EAAE,QAAA,EAAU,cAAc,CAAA;AACnE,MAAA,IAAI,aAAA,EAAe;AACjB,QAAA,mBAAA,CAAoB,kBAAA,CAAmB,MAAA,EAAW,IAAI,CAAC,CAAA;AAAA,MACzD;AAAA,IACF;AAAA,EACF,GAAG,CAAC,gBAAA,EAAkB,YAAA,EAAc,kBAAA,EAAoB,mBAAmB,CAAC,CAAA;AAE5E,EAAA,OAAO;AAAA,IACL;AAAA,GACF;AACF,CAAA;ACnEO,IAAM,mCAAmC,CAAC;AAAA,EAC/C,WAAA;AAAA,EACA,YAAA;AAAA,EACA,OAAA;AAAA,EACA;AACF,CAAA,KAA2B;AACzB,EAAA,MAAM,CAAC,iBAAA,EAAmB,oBAAoB,CAAA,GAAIC,SAAS,KAAK,CAAA;AAEhE,EAAA,eAAA,CAAgB,MAAM;AACpB,IAAA,IAAI,OAAA,IAAW,OAAA,CAAQ,MAAA,GAAS,CAAA,EAAG;AACjC,MAAA,OAAA,CAAQ,QAAQ,CAAA,MAAA,KAAU;AACxB,QAAA,gBAAA,CAAiB,SAAS,MAAM,CAAA;AAAA,MAClC,CAAC,CAAA;AAAA,IACH,CAAA,MAAO;AACL,MAAA,gBAAA,CAAiB,QAAA,CAAS,qBAAqB,CAAA;AAAA,IACjD;AACA,IAAA,oBAAA,CAAqB,IAAI,CAAA;AAAA,EAC3B,CAAA,EAAG,CAAC,OAAO,CAAC,CAAA;AAEZ,EAAA,IAAI,CAAC,iBAAA,EAAmB;AACtB,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,uBACE,GAAA,CAAA,QAAA,EAAA,EACE,8BAAC,gBAAA,EAAA,EACC,QAAA,kBAAA,GAAA,CAAC,uBAAoB,WAAA,EAA4B,YAAA,EAA8B,eAAA,EAAoC,CAAA,EACrH,CAAA,EACF,CAAA;AAEJ;AAEA,IAAM,sBAAsB,CAAC,EAAE,WAAA,EAAa,YAAA,EAAc,iBAAgB,KAAoG;AAC5K,EAAA,MAAM,EAAE,WAAA,EAAa,eAAA,EAAiB,kBAAA,KAAuB,cAAA,EAAe;AAC5E,EAAA,MAAM,EAAE,CAAA,EAAE,GAAI,OAAA,EAAQ;AACtB,EAAA,MAAM,EAAE,wBAAA,EAAyB,GAAI,iBAAA,EAAkB;AACvD,EAAA,MAAM,EAAE,mBAAA,EAAqB,mBAAA,EAAoB,GAAI,QAAA,EAAS;AAG9D,EAAA,MAAM,EAAE,eAAA,EAAiB,gBAAA,EAAiB,GAAI,0BAAA,CAA2B;AAAA,IACvE,WAAA,EAAA,YAAA;AAAA,IACA,eAAA,EAAiB,QAAA;AAAA,IACjB,aAAA,EAAe;AAAA,GAChB,CAAA;AAED,EAAA,MAAM,SAAA,GAAYC,OAAuB,IAAI,CAAA;AAE7C,EAAA,MAAM,SAAA,GAAY,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,SAAS,CAAA;AACxE,EAAA,MAAM,UAAA,GAAa,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,UAAU,CAAA;AAC1E,EAAA,MAAM,UAAA,GAAa,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,UAAU,CAAA;AAC1E,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,OAAO,CAAA;AACpE,EAAA,MAAM,gBAAgB,wBAAA,CAAA,eAAA,qBAA4D;AAClF,EAAA,MAAM,aAAa,wBAAA,CAAA,YAAA,kBAAyD;AAC5E,EAAA,MAAM,kBAAkB,wBAAA,CAAA,iBAAA,uBAA8D;AACtF,EAAA,MAAM,mBAAmB,wBAAA,CAAA,kBAAA,wBAA+D;AACxF,EAAA,MAAM,eAAA,GAAkB,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,eAAe,CAAA;AACpF,EAAA,MAAM,iBAAA,GAAoB,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,iBAAiB,CAAA;AACxF,EAAA,MAAM,cAAc,wBAAA,CAAA,aAAA,mBAA0D;AAC9E,EAAA,MAAM,IAAA,GAAO,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,eAAe,IAAI,CAAA;AAC9D,EAAA,MAAM,YAAA,GAAe,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,YAAY,YAAY,CAAA;AAC3E,EAAA,MAAM,0BAAA,GAA6B,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,YAAY,0BAA0B,CAAA;AACvG,EAAA,MAAM,WAAA,GAAc,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,OAAO,WAAW,CAAA;AACpE,EAAA,MAAM,UAAA,GAAa,cAAA,CAAe,CAAA,KAAA,KAAS,KAAA,CAAM,OAAO,UAAU,CAAA;AAElE,EAAA,MAAM,KAAA,GAAQ,sBAAA;AAAA,IACZ,UAAA;AAAA,IACA,UAAA;AAAA,IACA,OAAA;AAAA,IACA,aAAA;AAAA,IACA,UAAA;AAAA,IACA,eAAA;AAAA,IACA,gBAAA;AAAA,IACA,eAAA;AAAA,IACA,SAAA;AAAA,IACA,iBAAA;AAAA,IACA,WAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,MAAM,QAAA,GAAW,WAAA,CAAY,OAAA,CAAQ,MAAA,CAAO,EAAA,EAAI,MAAA,IAAA,YAAA;AAEhD,EAAA,MAAM,WAAW,cAAA,EAAe;AAEhC,EAAA,MAAM,UAAA,GAAaC,WAAAA,CAAY,CAAC,YAAA,KAA0B;AACxD,IAAA,QAAA,CAAS,aAAA,CAAc,YAAY,CAAC,CAAA;AAAA,EACtC,CAAA,EAAG,CAAC,QAAQ,CAAC,CAAA;AACb,EAAA,MAAM,EAAA,GAAK,cAAc,UAAU,CAAA;AAEnC,EAAA,MAAM,kBAAkB,kBAAA,EAAmB;AAC3C,EAAA,MAAM;AAAA,IACJ,gBAAA;AAAA,IACA,aAAA;AAAA,IACA;AAAA,GACF,GAAI,eAAA;AAEJ,EAAA,MAAM,EAAE,YAAA,EAAc,YAAA,EAAc,WAAU,GAAI,kBAAA,CAAmB,cAAc,eAAe,CAAA;AAElG,EAAA,MAAM,WAAW,WAAA,CAAY;AAAA,IAC3B,WAAA;AAAA,IACA,eAAA,EAAiB,SAAA;AAAA,IACjB,gBAAA,EAAkB,gBAAA,EAAiB,IAAK,EAAC;AAAA,IACzC,aAAA,EAAe,MAAA;AAAA,IACf,QAAA,EAAU,CAACC,SAAAA,KAAa;AACtB,MAAA,QAAA,CAAS,WAAA,CAAYA,SAAQ,CAAC,CAAA;AAAA,IAChC;AAAA,GACD,CAAA;AAED,EAAA,MAAM,oBAAoB,aAAA,EAAc;AAExC,EAAA,MAAM,mBAAA,GAAsB,WAAA,CAAY,QAAA,EAAU,aAAA,EAAe,MAAA;AAEjE,EAAA,IAAI,aAAA;AAEJ,EAAA,IAAI,mBAAA,EAAqB;AACvB,IAAA,IAAI,OAAO,mBAAA,KAAwB,QAAA,IAAY,KAAA,IAAS,mBAAA,EAAqB;AAC3E,MAAA,MAAM,eAAA,GAAkB,CAAA,CAAE,mBAAA,CAAoB,GAAG,CAAA;AACjD,MAAA,aAAA,GAAgB,eAAA,KAAoB,mBAAA,CAAoB,GAAA,GACpD,eAAA,GACA,mBAAA,CAAoB,QAAA;AAAA,IAC1B,CAAA,MAAO;AACL,MAAA,QAAQ,mBAAA;AAAqB,QAC3B,KAAA,OAAA;AACE,UAAA,aAAA,GAAgB,QAAA,EAAU,KAAA;AAC1B,UAAA;AAAA,QACF,KAAA,SAAA;AACE,UAAA,aAAA,GAAgB,UAAU,WAAA,EAAa,cAAA;AACvC,UAAA;AAAA,QACF,KAAA,iBAAA;AACE,UAAA,IAAI,QAAA,EAAU,KAAA,IAAS,QAAA,EAAU,WAAA,EAAa,cAAA,EAAgB;AAC5D,YAAA,aAAA,GAAgB,GAAI,QAAA,CAAS,KAAM,CAAA,QAAA,EAAO,QAAA,CAAS,YAAY,cAAe,CAAA,CAAA;AAAA,UAChF;AACA,UAAA;AAAA,QACF,KAAA,MAAA;AACE,UAAA,aAAA,GAAgB,MAAA;AAChB,UAAA;AAAA,QACF;AACE,UAAA,aAAA,GAAgB,mBAAA;AAChB,UAAA;AAAA;AACJ,IACF;AAAA,EACF;AAEA,EAAA,gBAAA,CAAiB,aAAa,CAAA;AAE9B,EAAA,MAAM,iBAAA,GAAoBD,YAAY,MAAM;AAE1C,IAAA,QAAA,CAAS,WAAA,CAAY,KAAK,CAAC,CAAA;AAC3B,IAAA,QAAA,CAAS,iBAAiB,CAAA;AAAA,EAC5B,CAAA,EAAG,CAAC,QAAQ,CAAC,CAAA;AAEb,EAAA,MAAM,WAAW,WAAA,EAAY;AAE7B,EAAA,MAAM,IAAIH,OAAAA,CAAQ,MAAM,IAAI,WAAA,CAAY,QAAA,EAAU,YAAY,OAAA,EAAS;AAAA,IACrE,QAAQ,MAAM;AAAA,IAAC,CAAA;AAAA,IACf,eAAe,MAAM;AAAA,IAAC,CAAA;AAAA,IACtB,YAAA,EAAc,CAAC,SAAA,KAAc;AAC3B,MAAA,QAAQ,SAAA;AAAW,QACjB,KAAA,YAAA;AACE,UAAA,EAAA,CAAG,gBAAA,EAAiB;AACpB,UAAA;AAAA,QACF,KAAA,UAAA;AAAA,QACA,KAAA,KAAA;AACE,UAAA,QAAA,CAAS,gBAAA,CAAiB;AAAA,YACxB,GAAA,EAAK;AAAA,WACN,CAAC,CAAA;AACF,UAAA;AAEA;AACJ,IACF;AAAA,GACD,GAAG,CAAC,QAAA,EAAU,YAAY,OAAA,EAAS,EAAA,EAAI,QAAQ,CAAC,CAAA;AAEjD,EAAA,MAAM,SAAA,GAAsCA,QAAQ,OAAO;AAAA,IACzD,WAAA,EAAa,eAAgB,IAAA,EAA6B;AACxD,MAAA,CAAA,CAAE,QAAQ,MAAM,CAAA;AAAA,IAClB,CAAA;AAAA,IACA,eAAA,EAAiB,eAAgB,OAAA,EAAiC;AAChE,MAAA,YAAA,CAAa,OAAO,CAAA;AAEpB,MAAA,IAAI,eAAc,EAAG;AACnB,QAAA,QAAA,CAAS,mBAAA,CAAoB,KAAK,CAAC,CAAA;AAAA,MACrC,CAAA,MAAO;AACL,QAAA,QAAA,CAAS,mBAAA,CAAoB,IAAI,CAAC,CAAA;AAAA,MACpC;AAEA,MAAA,IAAI,cAAa,EAAG;AAClB,QAAA,QAAA,CAAS,iBAAA,CAAkB,KAAK,CAAC,CAAA;AAAA,MACnC,CAAA,MAAO;AACL,QAAA,QAAA,CAAS,iBAAA,CAAkB,IAAI,CAAC,CAAA;AAAA,MAClC;AAAA,IACF,CAAA;AAAA,IACA,GAAA,EAAK,SAAU,EAAA,EAA8B;AAC3C,MAAA,iBAAA,EAAkB;AAClB,MAAA,OAAO,IAAA;AAAA,IACT,CAAA;AAAA,IACA,KAAA,EAAO,SAAU,EAAA,EAA8B;AAC7C,MAAA,OAAO,KAAA;AAAA,IACT,CAAA;AAAA,IACA,IAAA,EAAM,SAAU,MAAA,EAAsB;AAAA,IAAE,CAAA;AAAA,IACxC,MAAA,EAAQ,SAAU,MAAA,EAAsB;AAAA,IAAE,CAAA;AAAA,IAC1C,WAAA,EAAa,SAAU,IAAA,EAAc,KAAA,EAAsB;AAAA,IAAE,CAAA;AAAA,IAC7D,aAAA,EAAe,SAAU,OAAA,EAA2B;AAClD,MAAA,MAAM,OAAO,OAAA,CAAQ,IAAA;AAErB,MAAA,IACE,IAAA,CAAK,UAAA,CAAW,SAAS,CAAA,IACzB,KAAK,UAAA,CAAW,UAAU,CAAA,IAC1B,IAAA,CAAK,WAAW,SAAS,CAAA,IACzB,IAAA,CAAK,UAAA,CAAW,MAAM,CAAA,EACtB;AACA,QAAA,IAAI,OAAA,CAAQ,SAAS,IAAI,CAAA,GAAA,CAAK,GAAG,MAAA,CAAO,IAAA,CAAK,MAAM,QAAQ,CAAA;AAAA,MAC7D,CAAA,MAAO;AACL,QAAA,OAAA,CAAQ,IAAA,CAAK,qBAAqB,OAAO,CAAA;AAAA,MAC3C;AACA,MAAA,OAAO,KAAA;AAAA,IACT,CAAA;AAAA,IACA,YAAA,EAAc,SAAU,UAAA,EAAsC;AAAA,IAAC,CAAA;AAAA,IAC/D,iBAAA,EAAmB,SAAU,KAAA,EAAe,KAAA,EAAsB;AAAA,IAAC,CAAA;AAAA,IACnE,WAAA,EAAa,SAAU,KAAA,EAAsB;AAAA,IAAC,CAAA;AAAA,IAC9C,UAAA,EAAY,SAAU,KAAA,EAAsB;AAAA,IAAC;AAAA,GAC/C,CAAA,EAAI,CAAC,CAAA,EAAG,YAAA,EAAc,eAAe,YAAA,EAAc,QAAA,EAAU,iBAAiB,CAAC,CAAA;AAE/E,EAAA,MAAM,kBAAkBA,OAAAA,CAAQ,MAAM,cAAa,EAAG,CAAC,YAAY,CAAC,CAAA;AAGpE,EAA2B,mBAAA,CAAoB;AAAA,IAC7C,SAAA;AAAA,IACA,WAAA;AAAA,IACA,eAAA;AAAA,IACA,SAAA;AAAA,IACA,WAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,YAAA;AAAA,IACA,0BAAA;AAAA,IACA,eAAA;AAAA,IACA,mBAAA;AAAA,IACA,mBAAA;AAAA,IACA,kBAAA;AAAA,IACA,iBAAA;AAAA,IACA,uBAAA,EAAyB,8BAAA,CAA+B,WAAA,CAAY,iBAAA,EAAmB,CAAC,CAAA;AAAA,IACxF,kBAAkB,MAAM;AACtB,MAAA,QAAA,CAAS,UAAA,CAAW,KAAK,CAAC,CAAA;AAAA,IAC5B,CAAA;AAAA,IACA,mBAAmB,MAAM;AACvB,MAAA,CAAA,CAAE,QAAQ,MAAM,CAAA;AAAA,IAClB,CAAA;AAAA,IACA,WAAW,MAAM;AACf,MAAA,CAAA,CAAE,OAAA,EAAQ;AAAA,IACZ;AAAA,GACD;AAED,EAAA,uCAEE,QAAA,kBAAA,GAAA,CAAC,YAAA,EAAA,EAAa,MAAA,EAAS,WAAA,CAAY,QACnC,QAAA,kBAAA,GAAA,CAAC,iBAAA,EAAA,EAAkB,SAAA,EAAY,eAAA,EAC7B,8BAAC,MAAA,EAAA,EAAK,SAAA,EAAY,8BAAA,CAAa,IAAA,EAC7B,8BAAC,sBAAA,EAAA,EACC,QAAA,kBAAA,IAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,SAAA,EACE,UAAA;AAAA,QACE,mBAAA,CAAoB;AAAA,UAClB,QAAA,EAAU,IAAA;AAAA,UACV,WAAA;AAAA,UACA,UAAA;AAAA,UACA;AAAA,SACD;AAAA,OACH;AAAA,MAGF,QAAA,EAAA;AAAA,wBAAA,GAAA;AAAA,UAAC,oBAAA;AAAA,UAAA;AAAA,YACC,UAAA,EAAa,YAAY,OAAA,CAAQ,WAAA;AAAA,YACjC,YAAA,EAAe,YAAY,OAAA,CAAQ,WAAA;AAAA,YACnC,MAAA,EAAS,QAAA;AAAA,YACT,qBAAA,EAAwB,WAAA,CAAY,OAAA,CAAQ,MAAA,EAAQ,aAAa,MAAA,EAAQ;AAAA;AAAA,SAC3E;AAAA,4BAEC,SAAA,EAAA,EAAQ,SAAA,EAAY,+BAAa,OAAA,EAAU,YAAA,EAAa,EAAE,+BAA+B,CAAA,EACxF,QAAA,kBAAA,GAAA,CAAC,KAAA,EAAA,EAAI,IAAG,uBAAA,EAAwB,SAAA,EAAY,+BAAa,eAAA,EAAkB,GAAA,EAAM,WAAY,CAAA,EAC/F,CAAA;AAAA,wBAEF,GAAA;AAAA,UAAC,oBAAA;AAAA,UAAA;AAAA,YACC,MAAA,EAAS,QAAA;AAAA,YACT,qBAAA,EAAwB,WAAA,CAAY,OAAA,CAAQ,WAAA,EAAa,MAAA,EAAQ,MAAA;AAAA,YACjE,yBAAA,EAAA,mBAAA;AAAA;AAAA;AACF;AAAA;AAAA,GACF,EACF,CAAA,EACF,CAAA,EACF,CAAA,EACA,CAAA,EACA,CAAA;AACD,CAAA","file":"chunk-S4M7ED5Q.mjs","sourcesContent":["\"use client\";\n\nimport { useMemo } from \"react\";\n\nimport { IWebPubPreferences, TextAlignment } from \"@readium/navigator\";\nimport { ThLineHeightOptions } from \"@/preferences/models\";\nimport { FontMetadata } from \"@/preferences/services/fonts\";\nimport { WebPubCSSSettings } from \"@/core/Hooks/WebPub/useWebPubSettingsCache\";\n\ninterface UseWebPubPreferencesConfigProps {\n settings: WebPubCSSSettings;\n fontLanguage: string;\n hasDisplayTransformability: boolean;\n getFontMetadata: (fontFamily: string) => FontMetadata;\n lineHeightOptions: Record<ThLineHeightOptions, number | null>;\n}\n\nexport const useWebPubPreferencesConfig = ({\n settings,\n fontLanguage,\n hasDisplayTransformability,\n getFontMetadata,\n lineHeightOptions,\n}: UseWebPubPreferencesConfigProps) => {\n const webPubPreferences = useMemo(() => {\n const preferences: IWebPubPreferences = {\n zoom: settings.zoom\n };\n\n if (hasDisplayTransformability) {\n preferences.fontFamily = getFontMetadata(settings.fontFamily[fontLanguage] ?? \"\")?.fontStack || null;\n preferences.fontWeight = settings.fontWeight;\n preferences.hyphens = settings.hyphens;\n preferences.letterSpacing = settings.letterSpacing;\n preferences.lineHeight = settings.lineHeight === null \n ? null \n : lineHeightOptions[settings.lineHeight];\n preferences.paragraphIndent = settings.paragraphIndent;\n preferences.paragraphSpacing = settings.paragraphSpacing;\n preferences.textAlign = settings.textAlign as TextAlignment | null | undefined;\n preferences.textNormalization = settings.textNormalization;\n preferences.wordSpacing = settings.wordSpacing;\n }\n\n return preferences;\n }, [\n settings,\n fontLanguage,\n hasDisplayTransformability,\n getFontMetadata,\n lineHeightOptions,\n ]);\n\n return { webPubPreferences };\n};\n","\"use client\";\n\nimport { useMemo } from \"react\";\n\nimport { IInjectablesConfig } from \"@readium/navigator\";\nimport { InjectableFontResources } from \"@/preferences/services/fonts\";\n\ninterface UseWebPubInjectablesConfigProps {\n isFontFamilyUsed: boolean;\n fontLanguage: string;\n getFontInjectables: (options?: { language?: string } | { key?: string }, optimize?: boolean) => InjectableFontResources | null;\n}\n\nexport const useWebPubInjectablesConfig = ({\n isFontFamilyUsed,\n fontLanguage,\n getFontInjectables,\n}: UseWebPubInjectablesConfigProps) => {\n const injectables = useMemo(() => {\n let injectablesConfig: IInjectablesConfig | undefined;\n\n if (isFontFamilyUsed) {\n const fontResources = getFontInjectables({ language: fontLanguage });\n if (fontResources) {\n injectablesConfig = {\n allowedDomains: fontResources.allowedDomains,\n rules: [{\n resources: [/\\.xhtml$/, /\\.html$/],\n prepend: fontResources.prepend,\n append: fontResources.append\n }]\n };\n }\n }\n\n return injectablesConfig;\n }, [isFontFamilyUsed, fontLanguage, getFontInjectables]);\n\n return { injectables };\n};\n","\"use client\";\n\nimport { useCallback, useEffect, useState, useRef } from \"react\";\n\nimport { Locator, Publication } from \"@readium/shared\";\nimport { ThLineHeightOptions } from \"@/preferences/models\";\nimport { WebPubNavigatorListeners, IContentProtectionConfig } from \"@readium/navigator\";\nimport { ThPreferences } from \"@/preferences\";\nimport { FontMetadata, InjectableFontResources } from \"@/preferences/services/fonts\";\nimport { WebPubStatelessCache } from \"@/core/Hooks/WebPub/useWebPubSettingsCache\";\n\nimport { useWebPubPreferencesConfig } from \"./usePreferencesConfig\";\nimport { useWebPubInjectablesConfig } from \"./useInjectablesConfig\";\nimport { useWebPubNavigator, WebPubNavigatorLoadProps } from \"@/core/Hooks/WebPub/useWebPubNavigator\";\n\ninterface UseWebPubReaderInitProps {\n container: React.RefObject<HTMLDivElement | null>;\n publication: Publication | null;\n initialPosition: Locator | null;\n listeners: WebPubNavigatorListeners;\n preferences: ThPreferences;\n cache: React.RefObject<WebPubStatelessCache>;\n isFontFamilyUsed: boolean;\n fontLanguage: string;\n hasDisplayTransformability: boolean;\n getFontMetadata: (fontId: string) => FontMetadata;\n injectFontResources: (resources: InjectableFontResources | null) => void;\n removeFontResources: () => void;\n getFontInjectables: (options?: { language?: string } | { key?: string }, optimize?: boolean) => InjectableFontResources | null;\n lineHeightOptions: Record<ThLineHeightOptions, number | null>;\n contentProtectionConfig?: IContentProtectionConfig;\n onNavigatorReady?: () => void;\n onNavigatorLoaded?: () => void;\n onCleanup?: () => void;\n}\n\nexport const useWebPubReaderInit = ({\n container,\n publication,\n initialPosition,\n listeners,\n preferences,\n cache,\n isFontFamilyUsed,\n fontLanguage,\n hasDisplayTransformability,\n getFontMetadata,\n injectFontResources,\n removeFontResources,\n getFontInjectables,\n lineHeightOptions,\n contentProtectionConfig,\n onNavigatorReady,\n onNavigatorLoaded,\n onCleanup,\n}: UseWebPubReaderInitProps) => {\n const [navigatorReady, setNavigatorReady] = useState(false);\n\n const { webPubPreferences } = useWebPubPreferencesConfig({\n settings: cache.current.settings,\n fontLanguage,\n hasDisplayTransformability,\n getFontMetadata,\n lineHeightOptions,\n });\n\n const { injectables } = useWebPubInjectablesConfig({\n isFontFamilyUsed,\n fontLanguage,\n getFontInjectables,\n });\n\n const handleCleanup = useCallback(() => {\n removeFontResources();\n onCleanup?.();\n }, [removeFontResources, onCleanup]);\n\n const { WebPubNavigatorLoad, WebPubNavigatorDestroy } = useWebPubNavigator();\n const isNavigatorLoadedWebPub = useRef(false);\n \n useEffect(() => {\n // Only initialize once, never re-render\n if (!publication || isNavigatorLoadedWebPub.current) return;\n\n // Add container protection\n if (!container.current) {\n console.error(\"Container ref is not available for navigator initialization\");\n return;\n }\n\n const config: WebPubNavigatorLoadProps = {\n container: container.current,\n publication,\n listeners,\n initialPosition: initialPosition ? new Locator(initialPosition) : undefined,\n preferences: webPubPreferences,\n defaults: {\n experiments: preferences.experiments?.webPub || null\n },\n injectables,\n contentProtection: contentProtectionConfig,\n };\n\n isNavigatorLoadedWebPub.current = true;\n \n // Call onNavigatorReady outside of navigator load\n onNavigatorReady?.();\n \n // Pass onNavigatorLoaded as the callback to WebPubNavigatorLoad\n WebPubNavigatorLoad(config, () => {\n // Set navigatorReady to true only after navigator actually loads\n setNavigatorReady(true);\n onNavigatorLoaded?.();\n });\n\n return () => {\n if (isNavigatorLoadedWebPub.current) {\n setNavigatorReady(false);\n WebPubNavigatorDestroy(() => {\n isNavigatorLoadedWebPub.current = false;\n handleCleanup();\n });\n }\n };\n }, []);\n\n // Handle font resource injection\n useEffect(() => {\n if (isFontFamilyUsed) {\n const fontResources = getFontInjectables({ language: fontLanguage });\n if (fontResources) {\n injectFontResources(getFontInjectables(undefined, true));\n }\n }\n }, [isFontFamilyUsed, fontLanguage, getFontInjectables, injectFontResources]);\n\n return {\n navigatorReady,\n };\n};\n","\"use client\";\n\nimport { useState, useRef, useCallback, useMemo, useLayoutEffect } from \"react\";\n\nimport readerStyles from \"../assets/styles/thorium-web.reader.app.module.css\";\n\nimport { StatefulReaderProps } from \"../Reader/StatefulReaderWrapper\";\n\nimport { \n ThActionsKeys, \n ThLayoutUI,\n ThDocumentTitleFormat,\n ThProgressionFormat, \n ThSpacingSettingsKeys,\n ThSettingsKeys\n} from \"@/preferences/models\";\n\nimport { ThPluginRegistry } from \"../Plugins/PluginRegistry\";\n\nimport { I18nProvider } from \"react-aria\";\nimport { ThPluginProvider } from \"../Plugins/PluginProvider\";\nimport { NavigatorProvider } from \"@/core/Navigator\";\n\nimport {\n BasicTextSelection,\n FrameClickEvent,\n} from \"@readium/navigator-html-injectables\";\nimport { WebPubNavigatorListeners } from \"@readium/navigator\";\nimport { \n Locator, \n Publication\n} from \"@readium/shared\";\n\nimport { StatefulDockingWrapper } from \"../Docking/StatefulDockingWrapper\";\nimport { StatefulReaderHeader } from \"../StatefulReaderHeader\";\nimport { StatefulReaderFooter } from \"../StatefulReaderFooter\";\nimport { PositionStorage } from \"../Reader/StatefulReaderWrapper\";\n\nimport { usePreferences } from \"@/preferences/hooks/usePreferences\";\nimport { useSettingsComponentStatus } from \"@/components/Settings/hooks/useSettingsComponentStatus\";\nimport { useWebPubNavigator } from \"@/core/Hooks/WebPub\";\nimport { useWebPubSettingsCache } from \"@/core/Hooks/WebPub/useWebPubSettingsCache\";\nimport { useWebPubReaderInit } from \"./Hooks/useReaderInit\";\nimport { useFullscreen } from \"@/core/Hooks/useFullscreen\";\nimport { useI18n } from \"@/i18n/useI18n\";\nimport { useTimeline } from \"@/core/Hooks/useTimeline\";\nimport { usePositionStorage } from \"@/hooks/usePositionStorage\";\nimport { useDocumentTitle } from \"@/core/Hooks/useDocumentTitle\";\nimport { useSpacingPresets } from \"../Settings/Spacing/hooks/useSpacingPresets\";\nimport { useLineHeight } from \"../Settings/Spacing/hooks/useLineHeight\";\nimport { useFonts } from \"@/core/Hooks/fonts/useFonts\";\n\nimport { toggleActionOpen } from \"@/lib/actionsReducer\";\nimport { useAppSelector, useAppDispatch, useAppStore } from \"@/lib/hooks\";\nimport { \n setLoading,\n setHovering, \n toggleImmersive, \n setFullscreen,\n} from \"@/lib/readerReducer\";\nimport { \n setTimeline,\n setPublicationStart,\n setPublicationEnd\n} from \"@/lib/publicationReducer\";\n\nimport classNames from \"classnames\";\nimport { createDefaultPlugin } from \"../Plugins/helpers/createDefaultPlugin\";\nimport Peripherals from \"../../helpers/peripherals\";\nimport { getReaderClassNames } from \"../Helpers/getReaderClassNames\";\nimport { resolveContentProtectionConfig } from \"@/preferences/models/protection\";\n\nexport const ExperimentalWebPubStatefulReader = ({\n publication,\n localDataKey,\n plugins,\n positionStorage\n}: StatefulReaderProps) => {\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(createDefaultPlugin());\n }\n setPluginsRegistered(true);\n }, [plugins]);\n\n if (!pluginsRegistered) {\n return null;\n }\n\n return (\n <>\n <ThPluginProvider>\n <StatefulReaderInner publication={ publication } localDataKey={ localDataKey } positionStorage={ positionStorage } />\n </ThPluginProvider>\n </>\n );\n};\n\nconst StatefulReaderInner = ({ publication, localDataKey, positionStorage }: { publication: Publication; localDataKey: string | null; positionStorage?: PositionStorage }) => {\n const { preferences, getFontMetadata, getFontInjectables } = usePreferences();\n const { t } = useI18n();\n const { getEffectiveSpacingValue } = useSpacingPresets();\n const { injectFontResources, removeFontResources } = useFonts();\n\n // Check if font family component is being used\n const { isComponentUsed: isFontFamilyUsed } = useSettingsComponentStatus({\n settingsKey: ThSettingsKeys.fontFamily,\n publicationType: \"webpub\",\n componentType: \"text\"\n });\n\n const container = useRef<HTMLDivElement>(null);\n\n const textAlign = useAppSelector(state => state.webPubSettings.textAlign);\n const fontFamily = useAppSelector(state => state.webPubSettings.fontFamily);\n const fontWeight = useAppSelector(state => state.webPubSettings.fontWeight);\n const hyphens = useAppSelector(state => state.webPubSettings.hyphens);\n const letterSpacing = getEffectiveSpacingValue(ThSpacingSettingsKeys.letterSpacing);\n const lineHeight = getEffectiveSpacingValue(ThSpacingSettingsKeys.lineHeight);\n const paragraphIndent = getEffectiveSpacingValue(ThSpacingSettingsKeys.paragraphIndent);\n const paragraphSpacing = getEffectiveSpacingValue(ThSpacingSettingsKeys.paragraphSpacing);\n const publisherStyles = useAppSelector(state => state.webPubSettings.publisherStyles);\n const textNormalization = useAppSelector(state => state.webPubSettings.textNormalization);\n const wordSpacing = getEffectiveSpacingValue(ThSpacingSettingsKeys.wordSpacing);\n const zoom = useAppSelector(state => state.webPubSettings.zoom);\n const fontLanguage = useAppSelector(state => state.publication.fontLanguage);\n const hasDisplayTransformability = useAppSelector(state => state.publication.hasDisplayTransformability);\n const isImmersive = useAppSelector(state => state.reader.isImmersive);\n const isHovering = useAppSelector(state => state.reader.isHovering);\n\n const cache = useWebPubSettingsCache(\n fontFamily,\n fontWeight,\n hyphens,\n letterSpacing,\n lineHeight,\n paragraphIndent,\n paragraphSpacing,\n publisherStyles,\n textAlign,\n textNormalization,\n wordSpacing,\n zoom\n );\n\n const layoutUI = preferences.theming.layout.ui?.webPub || ThLayoutUI.stacked;\n\n const dispatch = useAppDispatch();\n\n const onFsChange = useCallback((isFullscreen: boolean) => {\n dispatch(setFullscreen(isFullscreen));\n }, [dispatch]);\n const fs = useFullscreen(onFsChange);\n\n const webPubNavigator = useWebPubNavigator();\n const { \n currentPositions,\n canGoBackward,\n canGoForward,\n } = webPubNavigator;\n\n const { setLocalData, getLocalData, localData } = usePositionStorage(localDataKey, positionStorage);\n\n const timeline = useTimeline({\n publication: publication,\n currentLocation: localData,\n currentPositions: currentPositions() || [],\n positionsList: undefined,\n onChange: (timeline) => {\n dispatch(setTimeline(timeline));\n }\n });\n\n const lineHeightOptions = useLineHeight();\n\n const documentTitleFormat = preferences.metadata?.documentTitle?.format;\n\n let documentTitle: string | undefined;\n\n if (documentTitleFormat) {\n if (typeof documentTitleFormat === \"object\" && \"key\" in documentTitleFormat) {\n const translatedTitle = t(documentTitleFormat.key);\n documentTitle = translatedTitle !== documentTitleFormat.key \n ? translatedTitle \n : documentTitleFormat.fallback;\n } else {\n switch (documentTitleFormat) {\n case ThDocumentTitleFormat.title:\n documentTitle = timeline?.title;\n break;\n case ThDocumentTitleFormat.chapter:\n documentTitle = timeline?.progression?.currentChapter;\n break;\n case ThDocumentTitleFormat.titleAndChapter:\n if (timeline?.title && timeline?.progression?.currentChapter) {\n documentTitle = `${ timeline.title } – ${ timeline.progression.currentChapter }`;\n }\n break;\n case ThDocumentTitleFormat.none:\n documentTitle = undefined;\n break;\n default: \n documentTitle = documentTitleFormat;\n break;\n }\n }\n }\n\n useDocumentTitle(documentTitle);\n\n const toggleIsImmersive = useCallback(() => {\n // If tap/click in iframe, then header/footer no longer hoovering \n dispatch(setHovering(false));\n dispatch(toggleImmersive());\n }, [dispatch]);\n\n const appStore = useAppStore();\n\n const p = useMemo(() => new Peripherals(appStore, preferences.actions, {\n moveTo: () => {},\n goProgression: () => {},\n toggleAction: (actionKey) => {\n switch (actionKey) {\n case ThActionsKeys.fullscreen:\n fs.handleFullscreen();\n break;\n case ThActionsKeys.settings:\n case ThActionsKeys.toc:\n dispatch(toggleActionOpen({\n key: actionKey\n }))\n break;\n default:\n break\n }\n }\n }), [appStore, preferences.actions, fs, dispatch]);\n\n const listeners: WebPubNavigatorListeners = useMemo(() => ({\n frameLoaded: async function (_wnd: Window): Promise<void> {\n p.observe(window);\n },\n positionChanged: async function (locator: Locator): Promise<void> {\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 tap: function (_e: FrameClickEvent): boolean {\n toggleIsImmersive();\n return true;\n },\n click: function (_e: FrameClickEvent): boolean {\n return false;\n },\n zoom: function (_scale: number): void { },\n scroll: function (_delta: number): void { },\n customEvent: function (_key: string, _data: unknown): void { },\n handleLocator: function (locator: Locator): boolean {\n const href = locator.href;\n\n if (\n href.startsWith(\"http://\") ||\n href.startsWith(\"https://\") ||\n href.startsWith(\"mailto:\") ||\n href.startsWith(\"tel:\")\n ) {\n if (confirm(`Open \"${href}\" ?`)) window.open(href, \"_blank\");\n } else {\n console.warn(\"Unhandled locator\", locator);\n }\n return false;\n },\n textSelected: function (_selection: BasicTextSelection): void {},\n contentProtection: function (_type: string, _data: unknown): void {},\n contextMenu: function (_data: unknown): void {},\n peripheral: function (_data: unknown): void {},\n }), [p, setLocalData, canGoBackward, canGoForward, dispatch, toggleIsImmersive]);\n\n const initialPosition = useMemo(() => getLocalData(), [getLocalData]);\n\n // Initialize reader using the new composite hook\n const { navigatorReady } = useWebPubReaderInit({\n container,\n publication,\n initialPosition,\n listeners,\n preferences,\n cache,\n isFontFamilyUsed,\n fontLanguage,\n hasDisplayTransformability,\n getFontMetadata,\n injectFontResources,\n removeFontResources,\n getFontInjectables,\n lineHeightOptions,\n contentProtectionConfig: resolveContentProtectionConfig(preferences.contentProtection, t),\n onNavigatorReady: () => {\n dispatch(setLoading(false));\n },\n onNavigatorLoaded: () => {\n p.observe(window);\n },\n onCleanup: () => {\n p.destroy();\n },\n });\n\n return (\n <>\n <I18nProvider locale={ preferences.locale }>\n <NavigatorProvider navigator={ webPubNavigator }>\n <main className={ readerStyles.main }>\n <StatefulDockingWrapper>\n <div \n className={ \n classNames(\n getReaderClassNames({\n isScroll: true,\n isImmersive,\n isHovering,\n layoutUI\n })\n )\n }\n >\n <StatefulReaderHeader \n actionKeys={ preferences.actions.webPubOrder }\n actionsOrder={ preferences.actions.webPubOrder }\n layout={ layoutUI } \n runningHeadFormatPref={ preferences.theming.header?.runningHead?.format?.webPub }\n />\n\n <article className={ readerStyles.wrapper } aria-label={ t(\"reader.app.publicationWrapper\") }>\n <div id=\"thorium-web-container\" className={ readerStyles.iframeContainer } ref={ container }></div>\n </article>\n\n <StatefulReaderFooter \n layout={ layoutUI } \n progressionFormatPref={ preferences.theming.progression?.format?.webPub }\n progressionFormatFallback={ ThProgressionFormat.readingOrderIndex }\n />\n </div>\n </StatefulDockingWrapper>\n </main>\n </NavigatorProvider>\n </I18nProvider>\n </>\n)};"]}
|
|
@@ -1,25 +1,29 @@
|
|
|
1
|
-
|
|
1
|
+
import { ai as StatefulReaderProps } from '../../useReaderTransitions-guT-eA-Q.mjs';
|
|
2
|
+
export { a6 as ScrimPref, d as StatefulActionContainerProps, m as StatefulActionIcon, l as StatefulActionIconProps, c as StatefulActionTriggerProps, S as StatefulActionsMapObject, a7 as StatefulBottomSheet, a5 as StatefulBottomSheetProps, q as StatefulCollapsibleActionsBar, p as StatefulCollapsibleActionsBarProps, a9 as StatefulDockedSheet, a8 as StatefulDockedSheetProps, z as StatefulDropdown, y as StatefulDropdownProps, Y as StatefulFontFamily, ab as StatefulFullScreenSheet, aa as StatefulFullScreenSheetProps, e as StatefulFullscreenTrigger, x as StatefulGroupWrapper, w as StatefulGroupWrapperProps, _ as StatefulHyphens, f as StatefulJumpToPositionContainer, g as StatefulJumpToPositionTrigger, M as StatefulLetterSpacing, N as StatefulLineHeight, B as StatefulNumberField, A as StatefulNumberFieldProps, s as StatefulOverflowMenu, o as StatefulOverflowMenuItem, n as StatefulOverflowMenuItemProps, r as StatefulOverflowMenuProps, O as StatefulParagraphIndent, P as StatefulParagraphSpacing, ad as StatefulPopoverSheet, ac as StatefulPopoverSheetProps, ag as StatefulPreferencesProvider, a3 as StatefulPublisherStyles, D as StatefulRadioGroup, C as StatefulRadioGroupProps, h as StatefulSettingsContainer, L as StatefulSettingsItemProps, i as StatefulSettingsTrigger, af as StatefulSheet, ae as StatefulSheetWrapper, F as StatefulSlider, E as StatefulSliderProps, Q as StatefulSpacingGroup, R as StatefulSpacingGroupContainer, U as StatefulSpacingPresets, H as StatefulSwitch, G as StatefulSwitchProps, $ as StatefulTextAlign, a0 as StatefulTextGroup, a1 as StatefulTextGroupContainer, a2 as StatefulTextNormalize, j as StatefulTocContainer, k as StatefulTocTrigger, V as StatefulWordSpacing, a4 as StatefulZoom, T as ThPlugin, Z as UnstableStatefulFontWeight, v as createDefaultPlugin, t as useDocking, J as useGridNavigation, I as useGridNavigationProps, K as useGridTemplate, W as useLineHeight, u as useNavigator, a as usePublication, b as useReaderTransitions, X as useSpacingPresets } from '../../useReaderTransitions-guT-eA-Q.mjs';
|
|
2
3
|
export { canRenderProgressionFormat, getBestMatchingProgressionFormat, getPlatform, getSupportedProgressionFormats, isActiveElement, isIOSish, isInteractiveElement, isIpadOS, isKeyboardTriggered, isMacish, makeBreakpointsMap, propsToCSSVars } from '../../core/Helpers/index.mjs';
|
|
3
4
|
export { U as UnstableKey, a as UnstableMetaKey, c as UnstableMetaKeys, g as UnstablePShortcut, b as UnstablePlatformModifier, f as UnstableShortcut, d as UnstableShortcutMetaKeywords, e as UnstableShortcutRepresentation, j as buildShortcut, h as defaultPlatformModifier, i as getPlatformModifier, m as metaKeys } from '../../keyboardUtilities-BWAyLS_D.mjs';
|
|
4
|
-
export { AppDispatch, AppState, AppStore,
|
|
5
|
-
export { f as ActionOverflowOpenPayload, c as ActionStateDockPayload, g as ActionStateDockedPayload, a as ActionStateObject, d as ActionStateOpenPayload, h as ActionStateSlotPayload, i as ActionStateSlotWidthPayload, e as ActionStateTogglePayload, k as ActionsReducerState, A as ActionsStateKeys, j as DockState, D as DockStateObject, O as OverflowStateKeys, b as OverflowStateObject, l as actionsSlice, o as activateDockPanel, q as collapseDockPanel, p as deactivateDockPanel, m as dockAction, r as expandDockPanel, s as setActionOpen, u as setDockPanelWidth, n as setOverflow, t as toggleActionOpen } from '../../actionsReducer-
|
|
6
|
-
export { u as
|
|
7
|
-
export {
|
|
5
|
+
export { AppDispatch, AppState, AppStore, L10nObject, PaginatedAffordanceObject, PaginatedAffordancePayload, PaginatedAffordanceProperties, PreferencesReducerState, PublicationReducerState, ReaderProfile, ReaderReducerState, RenditionChangePayload, RenditionObject, RenditionProperties, RootState, ThReduxPreferencesAdapter, ThStoreProvider, ThemeReducerState, ThemeStateChangePayload, ThemeStateObject, UIChangePayload, WebPubSettingsReducerState, initialWebPubSettingsState, makeStore, preferencesSlice, publicationSlice, readerSlice, setBreakpoint, setColorScheme, setContrast, setDirection, setFXL, setFontLanguage, setForcedColors, setFullscreen, setHasArrows, setHasDisplayTransformability, setHovering, setImmersive, setL10n, setLoading, setMonochrome, setPaginatedAffordance, setPlatformModifier, setPositionsList, setProgressionFormat, setPublicationEnd, setPublicationStart, setRTL, setReaderProfile, setReducedMotion, setReducedTransparency, setRunningHeadFormat, setScrollAffordance, setScrollAffordances, setSettingsContainer, setTheme, setTimeline, setTocEntry, setTocTree, setUI, setUserNavigated, setWebPubFontFamily, setWebPubFontWeight, setWebPubHyphens, setWebPubLetterSpacing, setWebPubLineHeight, setWebPubParagraphIndent, setWebPubParagraphSpacing, setWebPubPublisherStyles, setWebPubSpacingPreset, setWebPubTextAlign, setWebPubTextNormalization, setWebPubWordSpacing, setWebPubZoom, themeSlice, toggleImmersive, updateFromPreferences, useAppDispatch, useAppSelector, useAppStore, webPubSettingsSlice } from '../../lib/index.mjs';
|
|
6
|
+
export { f as ActionOverflowOpenPayload, c as ActionStateDockPayload, g as ActionStateDockedPayload, a as ActionStateObject, d as ActionStateOpenPayload, h as ActionStateSlotPayload, i as ActionStateSlotWidthPayload, e as ActionStateTogglePayload, k as ActionsReducerState, A as ActionsStateKeys, j as DockState, D as DockStateObject, O as OverflowStateKeys, b as OverflowStateObject, l as actionsSlice, o as activateDockPanel, q as collapseDockPanel, p as deactivateDockPanel, m as dockAction, r as expandDockPanel, s as setActionOpen, u as setDockPanelWidth, n as setOverflow, t as toggleActionOpen } from '../../actionsReducer-kc-S130w.mjs';
|
|
7
|
+
export { F as FontFamilyStateObject, L as LineLengthStateObject, S as SetFontFamilyPayload, a as SetLineLengthPayload, c as SetSpacingPresetPayload, b as SetSpacingSettingPayload, f as SettingsReducerState, d as SpacingStateKey, e as SpacingStateObject, h as handleSpacingSetting, i as initialSettingsState, g as setColumnCount, l as setFontFamily, j as setFontSize, k as setFontWeight, m as setHyphens, n as setLetterSpacing, o as setLineHeight, p as setLineLength, q as setParagraphIndent, r as setParagraphSpacing, t as setPublisherStyles, u as setScroll, v as setSpacingPreset, w as setTextAlign, x as setTextNormalization, y as setWordSpacing, s as settingsSlice } from '../../settingsReducer-C1wwCAMv.mjs';
|
|
8
|
+
export { u as useTheming } from '../../ThPreferencesAdapter-DrZ5_6Dv.mjs';
|
|
9
|
+
export { T as ThPreferencesProvider, u as usePreferences } from '../../usePreferences-BXFJbval.mjs';
|
|
8
10
|
export { Trans } from 'react-i18next';
|
|
9
11
|
export { DEFAULT_CONFIG, ThI18nProvider, initI18n, useI18n } from '../../i18n/index.mjs';
|
|
10
12
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
11
|
-
export { u as useEpubNavigator } from '../../useEpubNavigator-
|
|
13
|
+
export { u as useEpubNavigator } from '../../useEpubNavigator-CwHJfoiV.mjs';
|
|
12
14
|
export { default as i18n } from 'i18next';
|
|
13
15
|
import 'react-aria-components';
|
|
14
|
-
import '../../actions-
|
|
15
|
-
import '../../ui-
|
|
16
|
-
import '../../ThSettingsWrapper-
|
|
16
|
+
import '../../actions-D2CHvCHu.mjs';
|
|
17
|
+
import '../../ui-CamWuqOo.mjs';
|
|
18
|
+
import '../../ThSettingsWrapper-8Kx0SnH4.mjs';
|
|
17
19
|
import 'react';
|
|
18
20
|
import 'react-aria';
|
|
19
|
-
import '../../useContrast-
|
|
21
|
+
import '../../useContrast-D6sjPjxy.mjs';
|
|
20
22
|
import '@readium/shared';
|
|
23
|
+
import '../../errorHandler-CL2YIfQY.mjs';
|
|
21
24
|
import '../../useTimeline-DyMx_aWY.mjs';
|
|
22
25
|
import '@reduxjs/toolkit';
|
|
26
|
+
import '../../immer.d-CoRThNOF.mjs';
|
|
23
27
|
import 'react-redux';
|
|
24
28
|
import '@readium/navigator';
|
|
25
29
|
|
|
@@ -29,4 +33,6 @@ declare const StatefulLayout: () => react_jsx_runtime.JSX.Element;
|
|
|
29
33
|
|
|
30
34
|
declare const StatefulTheme: () => react_jsx_runtime.JSX.Element;
|
|
31
35
|
|
|
32
|
-
|
|
36
|
+
declare const StatefulReader: ({ publication, localDataKey, plugins, positionStorage }: StatefulReaderProps) => react_jsx_runtime.JSX.Element | null;
|
|
37
|
+
|
|
38
|
+
export { StatefulColumns, StatefulLayout, StatefulReader, StatefulTheme };
|