@nypl/web-reader 4.2.0 → 4.3.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 (117) hide show
  1. package/README.md +178 -188
  2. package/dist/{esm/index.css → index.css} +3 -1
  3. package/dist/index.css.map +1 -0
  4. package/dist/index.d.ts +532 -0
  5. package/dist/index.js +9381 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/index.mjs +9378 -0
  8. package/dist/index.mjs.map +1 -0
  9. package/dist/injectable-html-styles/ReadiumCSS-after.css +488 -2
  10. package/dist/injectable-html-styles/ReadiumCSS-after.css.map +1 -7
  11. package/dist/injectable-html-styles/ReadiumCSS-after.d.ts +2 -0
  12. package/dist/injectable-html-styles/ReadiumCSS-before.css +648 -2
  13. package/dist/injectable-html-styles/ReadiumCSS-before.css.map +1 -7
  14. package/dist/injectable-html-styles/ReadiumCSS-before.d.ts +2 -0
  15. package/dist/injectable-html-styles/ReadiumCSS-default.css +141 -2
  16. package/dist/injectable-html-styles/ReadiumCSS-default.css.map +1 -7
  17. package/dist/injectable-html-styles/ReadiumCSS-default.d.ts +2 -0
  18. package/package.json +10 -33
  19. package/dist/cjs/index.css +0 -2
  20. package/dist/cjs/index.css.map +0 -7
  21. package/dist/cjs/index.js +0 -340
  22. package/dist/cjs/index.js.map +0 -7
  23. package/dist/esm/index.css.map +0 -7
  24. package/dist/esm/index.js +0 -42090
  25. package/dist/esm/index.js.map +0 -7
  26. package/dist/types/HtmlReader/effects.d.ts +0 -22
  27. package/dist/types/HtmlReader/index.d.ts +0 -15
  28. package/dist/types/HtmlReader/lib.d.ts +0 -112
  29. package/dist/types/HtmlReader/reducer.d.ts +0 -8
  30. package/dist/types/HtmlReader/types.d.ts +0 -116
  31. package/dist/types/HtmlReader/useIframeLinkClick.d.ts +0 -4
  32. package/dist/types/HtmlReader/useLocationQuery.d.ts +0 -8
  33. package/dist/types/HtmlReader/useResource.d.ts +0 -14
  34. package/dist/types/HtmlReader/useUpdateCSS.d.ts +0 -7
  35. package/dist/types/HtmlReader/useUpdateScroll.d.ts +0 -6
  36. package/dist/types/HtmlReader/useWindowResize.d.ts +0 -7
  37. package/dist/types/PdfReader/ChakraPage.d.ts +0 -3
  38. package/dist/types/PdfReader/ScrollPage.d.ts +0 -12
  39. package/dist/types/PdfReader/index.d.ts +0 -13
  40. package/dist/types/PdfReader/useMeasure.d.ts +0 -7
  41. package/dist/types/Readium/Injectable.d.ts +0 -11
  42. package/dist/types/Readium/Locator.d.ts +0 -20
  43. package/dist/types/WebpubManifestTypes/ConformsTo.d.ts +0 -3
  44. package/dist/types/WebpubManifestTypes/Contributor.d.ts +0 -17
  45. package/dist/types/WebpubManifestTypes/EpubExtension.d.ts +0 -47
  46. package/dist/types/WebpubManifestTypes/LanguageMap.d.ts +0 -3
  47. package/dist/types/WebpubManifestTypes/Metadata.d.ts +0 -47
  48. package/dist/types/WebpubManifestTypes/OPDSLink.d.ts +0 -63
  49. package/dist/types/WebpubManifestTypes/PresentationHints.d.ts +0 -53
  50. package/dist/types/WebpubManifestTypes/ReadiumLink.d.ts +0 -58
  51. package/dist/types/WebpubManifestTypes/Subject.d.ts +0 -16
  52. package/dist/types/WebpubManifestTypes/WebpubManifest.d.ts +0 -14
  53. package/dist/types/constants.d.ts +0 -37
  54. package/dist/types/index.d.ts +0 -16
  55. package/dist/types/types.d.ts +0 -123
  56. package/dist/types/ui/Button.d.ts +0 -9
  57. package/dist/types/ui/ErrorBoundary.d.ts +0 -16
  58. package/dist/types/ui/Footer.d.ts +0 -9
  59. package/dist/types/ui/Header.d.ts +0 -9
  60. package/dist/types/ui/HtmlSettings.d.ts +0 -9
  61. package/dist/types/ui/LoadingSkeleton.d.ts +0 -9
  62. package/dist/types/ui/PageButton.d.ts +0 -7
  63. package/dist/types/ui/PdfSettings.d.ts +0 -8
  64. package/dist/types/ui/SettingsButton.d.ts +0 -5
  65. package/dist/types/ui/TableOfContent.d.ts +0 -7
  66. package/dist/types/ui/ToggleButton.d.ts +0 -14
  67. package/dist/types/ui/ToggleGroup.d.ts +0 -8
  68. package/dist/types/ui/hooks/useColorModeValue.d.ts +0 -7
  69. package/dist/types/ui/hooks/useContainerWidth.d.ts +0 -6
  70. package/dist/types/ui/hooks/useEventListener.d.ts +0 -8
  71. package/dist/types/ui/hooks/useFullScreen.d.ts +0 -7
  72. package/dist/types/ui/icons/Continuous.d.ts +0 -4
  73. package/dist/types/ui/icons/Day.d.ts +0 -4
  74. package/dist/types/ui/icons/EnlargeFont.d.ts +0 -4
  75. package/dist/types/ui/icons/Night.d.ts +0 -4
  76. package/dist/types/ui/icons/Paginated.d.ts +0 -4
  77. package/dist/types/ui/icons/Previous.d.ts +0 -4
  78. package/dist/types/ui/icons/ReaderSettings.d.ts +0 -4
  79. package/dist/types/ui/icons/ReduceFont.d.ts +0 -4
  80. package/dist/types/ui/icons/Reset.d.ts +0 -4
  81. package/dist/types/ui/icons/Sepia.d.ts +0 -4
  82. package/dist/types/ui/icons/TableOfContents.d.ts +0 -4
  83. package/dist/types/ui/icons/ToggleFullScreen.d.ts +0 -4
  84. package/dist/types/ui/icons/ToggleFullScreenExit.d.ts +0 -4
  85. package/dist/types/ui/icons/index.d.ts +0 -14
  86. package/dist/types/ui/manager.d.ts +0 -9
  87. package/dist/types/ui/menu/index.d.ts +0 -10
  88. package/dist/types/ui/menu/menu.d.ts +0 -76
  89. package/dist/types/ui/menu/use-menu.d.ts +0 -2510
  90. package/dist/types/ui/nypl-base-theme/components/button.d.ts +0 -94
  91. package/dist/types/ui/nypl-base-theme/components/checkbox.d.ts +0 -41
  92. package/dist/types/ui/nypl-base-theme/components/form-error.d.ts +0 -14
  93. package/dist/types/ui/nypl-base-theme/components/form-label.d.ts +0 -14
  94. package/dist/types/ui/nypl-base-theme/components/form.d.ts +0 -15
  95. package/dist/types/ui/nypl-base-theme/components/input.d.ts +0 -107
  96. package/dist/types/ui/nypl-base-theme/components/text-area.d.ts +0 -34
  97. package/dist/types/ui/nypl-base-theme/foundations/breakpoints.d.ts +0 -8
  98. package/dist/types/ui/nypl-base-theme/foundations/colors.d.ts +0 -3
  99. package/dist/types/ui/nypl-base-theme/foundations/global.d.ts +0 -13
  100. package/dist/types/ui/nypl-base-theme/foundations/radii.d.ts +0 -12
  101. package/dist/types/ui/nypl-base-theme/foundations/spacing.d.ts +0 -49
  102. package/dist/types/ui/nypl-base-theme/foundations/typography.d.ts +0 -10
  103. package/dist/types/ui/nypl-base-theme/index.d.ts +0 -7
  104. package/dist/types/ui/nypl-base-theme/types.d.ts +0 -1
  105. package/dist/types/ui/theme/components/alert.d.ts +0 -24
  106. package/dist/types/ui/theme/components/button.d.ts +0 -93
  107. package/dist/types/ui/theme/components/text.d.ts +0 -20
  108. package/dist/types/ui/theme/foundations/colors.d.ts +0 -3
  109. package/dist/types/ui/theme/foundations/fonts.d.ts +0 -3
  110. package/dist/types/ui/theme/foundations/typography.d.ts +0 -6
  111. package/dist/types/ui/theme/index.d.ts +0 -12
  112. package/dist/types/ui/theme/types.d.ts +0 -1
  113. package/dist/types/useWebReader.d.ts +0 -7
  114. package/dist/types/utils/decryptAxisNow.d.ts +0 -0
  115. package/dist/types/utils/fetch.d.ts +0 -4
  116. package/dist/types/utils/getColor.d.ts +0 -2
  117. package/dist/types/utils/localstorage.d.ts +0 -21
@@ -0,0 +1,532 @@
1
+ import { FC } from 'react';
2
+
3
+ interface Injectable {
4
+ type: string;
5
+ url?: string;
6
+ r2after?: boolean;
7
+ r2before?: boolean;
8
+ r2default?: boolean;
9
+ fontFamily?: string;
10
+ systemFont?: boolean;
11
+ appearance?: string;
12
+ async?: boolean;
13
+ }
14
+
15
+ interface Locator {
16
+ href: string;
17
+ type?: string;
18
+ title?: string;
19
+ locations: Locations;
20
+ text?: LocatorText;
21
+ }
22
+ interface LocatorText {
23
+ after?: string;
24
+ before?: string;
25
+ highlight?: string;
26
+ }
27
+ interface Locations {
28
+ fragment?: string;
29
+ progression?: number;
30
+ position?: number;
31
+ totalProgression?: number;
32
+ remainingPositions?: number;
33
+ totalRemainingPositions?: number;
34
+ }
35
+
36
+ declare const ReadiumWebpubContext = "http://readium.org/webpub/default.jsonld";
37
+ declare const IS_DEV: boolean;
38
+ declare const HEADER_HEIGHT = 48;
39
+ declare const FOOTER_HEIGHT = 48;
40
+ declare const CHROME_HEIGHT: number;
41
+ declare const DEFAULT_HEIGHT: string;
42
+ declare const DEFAULT_SHOULD_GROW_WHEN_SCROLLING = true;
43
+ declare const DEFAULT_SETTINGS: ReaderSettings;
44
+ declare const FONT_DETAILS: {
45
+ publisher: {
46
+ heading: string;
47
+ body: string;
48
+ token: string;
49
+ fontWeight: string;
50
+ };
51
+ serif: {
52
+ heading: string;
53
+ body: string;
54
+ token: string;
55
+ fontWeight: string;
56
+ };
57
+ 'sans-serif': {
58
+ heading: string;
59
+ body: string;
60
+ token: string;
61
+ fontWeight: string;
62
+ };
63
+ 'open-dyslexic': {
64
+ heading: string;
65
+ body: string;
66
+ token: string;
67
+ fontWeight: string;
68
+ };
69
+ };
70
+ declare const LOCAL_STORAGE_SETTINGS_KEY = "web-reader-settings";
71
+ declare const LOCAL_STORAGE_LOCATIONS_KEY = "web-reader-locations";
72
+
73
+ declare const WebpubPdfConformsTo = "http://librarysimplified.org/terms/profiles/pdf";
74
+ declare const EpubConformsTo = "https://readium.org/webpub-manifest/profiles/epub";
75
+ declare type ConformsTo = typeof WebpubPdfConformsTo | typeof EpubConformsTo;
76
+
77
+ interface EPUBExtensionLinkProperties {
78
+ /**
79
+ * Identifies content contained in the linked resource, that cannot be strictly identified using a media type.
80
+ */
81
+ contains?: ('mathml' | 'onix' | 'remote-resources' | 'js' | 'svg' | 'xmp')[];
82
+ /**
83
+ * Hints how the layout of the resource should be presented
84
+ */
85
+ layout?: 'fixed' | 'reflowable';
86
+ /**
87
+ * Indicates that a resource is encrypted/obfuscated and provides relevant information for decryption
88
+ */
89
+ encrypted?: {
90
+ /**
91
+ * Identifies the algorithm used to encrypt the resource
92
+ */
93
+ algorithm: string;
94
+ /**
95
+ * Compression method used on the resource
96
+ */
97
+ compression?: string;
98
+ /**
99
+ * Original length of the resource in bytes before compression and/or encryption
100
+ */
101
+ originalLength?: number;
102
+ /**
103
+ * Identifies the encryption profile used to encrypt the resource
104
+ */
105
+ profile?: string;
106
+ /**
107
+ * Identifies the encryption scheme used to encrypt the resource
108
+ */
109
+ scheme?: string;
110
+ [k: string]: unknown;
111
+ };
112
+ [k: string]: unknown;
113
+ }
114
+ interface EPUBExtensionMetadata {
115
+ presentation?: {
116
+ /**
117
+ * Hints how the layout of the resource should be presented
118
+ */
119
+ layout?: 'fixed' | 'reflowable';
120
+ [k: string]: unknown;
121
+ };
122
+ [k: string]: unknown;
123
+ }
124
+
125
+ interface OPDSLinkProperties {
126
+ /**
127
+ * Provide a hint about the expected number of items returned
128
+ */
129
+ numberOfItems?: number;
130
+ /**
131
+ * The price of a publication is tied to its acquisition link
132
+ */
133
+ price?: {
134
+ value: number;
135
+ currency: 'AED' | 'AFN' | 'ALL' | 'AMD' | 'ANG' | 'AOA' | 'ARS' | 'AUD' | 'AWG' | 'AZN' | 'BAM' | 'BBD' | 'BDT' | 'BGN' | 'BHD' | 'BIF' | 'BMD' | 'BND' | 'BOB' | 'BOV' | 'BRL' | 'BSD' | 'BTN' | 'BWP' | 'BYN' | 'BZD' | 'CAD' | 'CDF' | 'CHE' | 'CHF' | 'CHW' | 'CLF' | 'CLP' | 'CNY' | 'COP' | 'COU' | 'CRC' | 'CUC' | 'CUP' | 'CVE' | 'CZK' | 'DJF' | 'DKK' | 'DOP' | 'DZD' | 'EGP' | 'ERN' | 'ETB' | 'EUR' | 'FJD' | 'FKP' | 'GBP' | 'GEL' | 'GHS' | 'GIP' | 'GMD' | 'GNF' | 'GTQ' | 'GYD' | 'HKD' | 'HNL' | 'HRK' | 'HTG' | 'HUF' | 'IDR' | 'ILS' | 'INR' | 'IQD' | 'IRR' | 'ISK' | 'JMD' | 'JOD' | 'JPY' | 'KES' | 'KGS' | 'KHR' | 'KMF' | 'KPW' | 'KRW' | 'KWD' | 'KYD' | 'KZT' | 'LAK' | 'LBP' | 'LKR' | 'LRD' | 'LSL' | 'LYD' | 'MAD' | 'MDL' | 'MGA' | 'MKD' | 'MMK' | 'MNT' | 'MOP' | 'MRU' | 'MUR' | 'MVR' | 'MWK' | 'MXN' | 'MXV' | 'MYR' | 'MZN' | 'NAD' | 'NGN' | 'NIO' | 'NOK' | 'NPR' | 'NZD' | 'OMR' | 'PAB' | 'PEN' | 'PGK' | 'PHP' | 'PKR' | 'PLN' | 'PYG' | 'QAR' | 'RON' | 'RSD' | 'RUB' | 'RWF' | 'SAR' | 'SBD' | 'SCR' | 'SDG' | 'SEK' | 'SGD' | 'SHP' | 'SLL' | 'SOS' | 'SRD' | 'SSP' | 'STN' | 'SVC' | 'SYP' | 'SZL' | 'THB' | 'TJS' | 'TMT' | 'TND' | 'TOP' | 'TRY' | 'TTD' | 'TWD' | 'TZS' | 'UAH' | 'UGX' | 'USD' | 'USN' | 'UYI' | 'UYU' | 'UZS' | 'VEF' | 'VES' | 'VND' | 'VUV' | 'WST' | 'XAF' | 'XAG' | 'XAU' | 'XBA' | 'XBB' | 'XBC' | 'XBD' | 'XCD' | 'XDR' | 'XOF' | 'XPD' | 'XPF' | 'XPT' | 'XSU' | 'XTS' | 'XUA' | 'XXX' | 'YER' | 'ZAR' | 'ZMW' | 'ZWL';
136
+ [k: string]: unknown;
137
+ };
138
+ /**
139
+ * Indirect acquisition provides a hint for the expected media type that will be acquired after additional steps
140
+ */
141
+ indirectAcquisition?: OPDSAcquisitionObject[];
142
+ /**
143
+ * Library-specific feature for unavailable books that support a hold list
144
+ */
145
+ holds?: {
146
+ total?: number;
147
+ position?: number;
148
+ [k: string]: unknown;
149
+ };
150
+ /**
151
+ * Library-specific feature that contains information about the copies that a library has acquired
152
+ */
153
+ copies?: {
154
+ total?: number;
155
+ available?: number;
156
+ [k: string]: unknown;
157
+ };
158
+ /**
159
+ * Indicates the availability of a given resource
160
+ */
161
+ availability?: {
162
+ state: 'available' | 'unavailable' | 'reserved' | 'ready';
163
+ /**
164
+ * Timestamp for the previous state change
165
+ */
166
+ since?: ({
167
+ [k: string]: unknown;
168
+ } | {
169
+ [k: string]: unknown;
170
+ }) & string;
171
+ /**
172
+ * Timestamp for the next state change
173
+ */
174
+ until?: ({
175
+ [k: string]: unknown;
176
+ } | {
177
+ [k: string]: unknown;
178
+ }) & string;
179
+ [k: string]: unknown;
180
+ };
181
+ [k: string]: unknown;
182
+ }
183
+ interface OPDSAcquisitionObject {
184
+ type: string;
185
+ child?: OPDSAcquisitionObject[];
186
+ [k: string]: unknown;
187
+ }
188
+
189
+ interface PresentationHintsLinkProperties {
190
+ /**
191
+ * Specifies whether or not the parts of a linked resource that flow out of the viewport are clipped.
192
+ */
193
+ clipped?: boolean;
194
+ /**
195
+ * Specifies constraints for the presentation of a linked resource within the viewport.
196
+ */
197
+ fit?: 'contain' | 'cover' | 'width' | 'height';
198
+ /**
199
+ * Suggested orientation for the device when displaying the linked resource.
200
+ */
201
+ orientation?: 'auto' | 'landscape' | 'portrait';
202
+ /**
203
+ * Indicates how the linked resource should be displayed in a reading environment that displays synthetic spreads.
204
+ */
205
+ page?: 'left' | 'right' | 'center';
206
+ /**
207
+ * Indicates the condition to be met for the linked resource to be rendered within a synthetic spread.
208
+ */
209
+ spread?: 'auto' | 'both' | 'none' | 'landscape';
210
+ [k: string]: unknown;
211
+ }
212
+
213
+ interface ReadiumLink {
214
+ /**
215
+ * URI or URI template of the linked resource
216
+ */
217
+ href: string;
218
+ /**
219
+ * MIME type of the linked resource
220
+ */
221
+ type?: string;
222
+ /**
223
+ * Indicates that a URI template is used in href
224
+ */
225
+ templated?: boolean;
226
+ /**
227
+ * Title of the linked resource
228
+ */
229
+ title?: string;
230
+ /**
231
+ * Relation between the linked resource and its containing collection
232
+ */
233
+ rel?: string | string[];
234
+ /**
235
+ * Properties associated to the linked resource
236
+ */
237
+ properties?: OPDSLinkProperties & EPUBExtensionLinkProperties & PresentationHintsLinkProperties;
238
+ /**
239
+ * Height of the linked resource in pixels
240
+ */
241
+ height?: number;
242
+ /**
243
+ * Width of the linked resource in pixels
244
+ */
245
+ width?: number;
246
+ /**
247
+ * Bitrate of the linked resource in kbps
248
+ */
249
+ bitrate?: number;
250
+ /**
251
+ * Length of the linked resource in seconds
252
+ */
253
+ duration?: number;
254
+ /**
255
+ * Expected language of the linked resource
256
+ */
257
+ language?: string | string[];
258
+ /**
259
+ * Alternate resources for the linked resource
260
+ */
261
+ alternate?: ReadiumLink[];
262
+ /**
263
+ * Resources that are children of the linked resource, in the context of a given collection role
264
+ */
265
+ children?: ReadiumLink[];
266
+ [k: string]: unknown;
267
+ }
268
+
269
+ interface ContributorObject {
270
+ name: string | {
271
+ /**
272
+ * This interface was referenced by `undefined`'s JSON-Schema definition
273
+ * via the `patternProperty` "^((?<grandfathered>(en-GB-oed|i-ami|i-bnn|i-default|i-enochian|i-hak|i-klingon|i-lux|i-mingo|i-navajo|i-pwn|i-tao|i-tay|i-tsu|sgn-BE-FR|sgn-BE-NL|sgn-CH-DE)|(art-lojban|cel-gaulish|no-bok|no-nyn|zh-guoyu|zh-hakka|zh-min|zh-min-nan|zh-xiang))|((?<language>([A-Za-z]{2,3}(-(?<extlang>[A-Za-z]{3}(-[A-Za-z]{3}){0,2}))?)|[A-Za-z]{4}|[A-Za-z]{5,8})(-(?<script>[A-Za-z]{4}))?(-(?<region>[A-Za-z]{2}|[0-9]{3}))?(-(?<variant>[A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*(-(?<extension>[0-9A-WY-Za-wy-z](-[A-Za-z0-9]{2,8})+))*(-(?<privateUse>x(-[A-Za-z0-9]{1,8})+))?)|(?<privateUse2>x(-[A-Za-z0-9]{1,8})+))$".
274
+ */
275
+ [k: string]: string;
276
+ };
277
+ identifier?: string;
278
+ sortAs?: string;
279
+ role?: string | string[];
280
+ position?: number;
281
+ links?: ReadiumLink[];
282
+ [k: string]: unknown;
283
+ }
284
+ declare type Contributor = string | (string | ContributorObject)[] | ContributorObject;
285
+
286
+ declare type LanguageMap = string | {
287
+ [k: string]: string;
288
+ };
289
+
290
+ interface SubjectObject {
291
+ name: string | {
292
+ /**
293
+ * This interface was referenced by `undefined`'s JSON-Schema definition
294
+ * via the `patternProperty` "^((?<grandfathered>(en-GB-oed|i-ami|i-bnn|i-default|i-enochian|i-hak|i-klingon|i-lux|i-mingo|i-navajo|i-pwn|i-tao|i-tay|i-tsu|sgn-BE-FR|sgn-BE-NL|sgn-CH-DE)|(art-lojban|cel-gaulish|no-bok|no-nyn|zh-guoyu|zh-hakka|zh-min|zh-min-nan|zh-xiang))|((?<language>([A-Za-z]{2,3}(-(?<extlang>[A-Za-z]{3}(-[A-Za-z]{3}){0,2}))?)|[A-Za-z]{4}|[A-Za-z]{5,8})(-(?<script>[A-Za-z]{4}))?(-(?<region>[A-Za-z]{2}|[0-9]{3}))?(-(?<variant>[A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*(-(?<extension>[0-9A-WY-Za-wy-z](-[A-Za-z0-9]{2,8})+))*(-(?<privateUse>x(-[A-Za-z0-9]{1,8})+))?)|(?<privateUse2>x(-[A-Za-z0-9]{1,8})+))$".
295
+ */
296
+ [k: string]: string;
297
+ };
298
+ sortAs?: string;
299
+ code?: string;
300
+ scheme?: string;
301
+ links?: ReadiumLink[];
302
+ [k: string]: unknown;
303
+ }
304
+ declare type Subject = string | (string | SubjectObject)[] | SubjectObject;
305
+
306
+ interface Metadata extends Contributors, EPUBExtensionMetadata {
307
+ identifier?: string;
308
+ '@type'?: string;
309
+ conformsTo?: ConformsTo;
310
+ title: LanguageMap;
311
+ subtitle?: LanguageMap;
312
+ modified?: string;
313
+ published?: {
314
+ [k: string]: unknown;
315
+ } & string;
316
+ /**
317
+ * The language must be a valid BCP 47 tag.
318
+ */
319
+ language?: string | string[];
320
+ sortAs?: LanguageMap;
321
+ subject?: Subject;
322
+ readingProgression?: 'rtl' | 'ltr' | 'ttb' | 'btt' | 'auto';
323
+ description?: string;
324
+ duration?: number;
325
+ numberOfPages?: number;
326
+ belongsTo?: {
327
+ collection?: Contributor;
328
+ series?: Contributor;
329
+ [k: string]: unknown;
330
+ };
331
+ [k: string]: unknown;
332
+ }
333
+ interface Contributors {
334
+ author?: Contributor;
335
+ translator?: Contributor;
336
+ editor?: Contributor;
337
+ artist?: Contributor;
338
+ illustrator?: Contributor;
339
+ letterer?: Contributor;
340
+ penciler?: Contributor;
341
+ colorist?: Contributor;
342
+ inker?: Contributor;
343
+ narrator?: Contributor;
344
+ contributor?: Contributor;
345
+ publisher?: Contributor;
346
+ imprint?: Contributor;
347
+ }
348
+
349
+ /**
350
+ * Type definitions for a manifest
351
+ */
352
+
353
+ interface WebpubManifest {
354
+ '@context'?: typeof ReadiumWebpubContext;
355
+ metadata: Metadata;
356
+ links: ReadiumLink[];
357
+ readingOrder: ReadiumLink[];
358
+ resources?: ReadiumLink[];
359
+ toc?: ReadiumLink[];
360
+ }
361
+
362
+ declare type ColorMode = 'night' | 'sepia' | 'day';
363
+ declare type FontFamily = 'publisher' | 'serif' | 'sans-serif' | 'open-dyslexic';
364
+ declare type Navigator = {
365
+ goForward: () => void;
366
+ goBackward: () => void;
367
+ setScroll: (val: 'scrolling' | 'paginated') => Promise<void>;
368
+ goToPage: (href: string) => void;
369
+ };
370
+ declare type PdfNavigator = Navigator & {
371
+ zoomIn: () => Promise<void>;
372
+ zoomOut: () => Promise<void>;
373
+ };
374
+ declare type HtmlNavigator = Navigator & {
375
+ increaseFontSize: () => Promise<void>;
376
+ decreaseFontSize: () => Promise<void>;
377
+ resetSettings: () => Promise<void>;
378
+ setFontFamily: (family: FontFamily) => Promise<void>;
379
+ setColorMode: (mode: ColorMode) => Promise<void>;
380
+ };
381
+ declare type ReaderSettings = {
382
+ colorMode: ColorMode;
383
+ isScrolling: boolean;
384
+ fontSize: number;
385
+ fontFamily: FontFamily;
386
+ };
387
+ /**
388
+ * This is the "public" state of the reader that
389
+ * is returned to consumers of useWebReader. Each
390
+ * reader (pdf/html) has its own internal state with
391
+ * more details necessary for rendering
392
+ */
393
+ declare type ReaderState = {
394
+ atStart: boolean;
395
+ atEnd: boolean;
396
+ location?: Locator;
397
+ settings: ReaderSettings | undefined;
398
+ };
399
+ declare type InactiveReader = null;
400
+ declare type LoadingReader = {
401
+ isLoading: true;
402
+ content: JSX.Element;
403
+ navigator: null;
404
+ state: null;
405
+ manifest: null;
406
+ type: null;
407
+ };
408
+ declare type CommonReader = {
409
+ isLoading: false;
410
+ content: JSX.Element;
411
+ manifest: WebpubManifest;
412
+ };
413
+ declare type PDFActiveReader = CommonReader & {
414
+ state: ReaderState;
415
+ navigator: PdfNavigator;
416
+ type: 'PDF';
417
+ };
418
+ declare type HTMLActiveReader = CommonReader & {
419
+ state: ReaderState;
420
+ navigator: HtmlNavigator;
421
+ type: 'HTML';
422
+ };
423
+ declare type ActiveReader = PDFActiveReader | HTMLActiveReader;
424
+ declare type ReaderReturn = InactiveReader | LoadingReader | ActiveReader;
425
+ declare type GetContent = (href: string) => Promise<string>;
426
+ declare type ReaderManagerArguments = {
427
+ headerLeft?: JSX.Element;
428
+ };
429
+ declare type UseWebReaderArguments = {
430
+ webpubManifestUrl: string;
431
+ proxyUrl?: string;
432
+ getContent?: GetContent;
433
+ pdfWorkerSrc?: string;
434
+ injectablesReflowable?: Injectable[];
435
+ injectablesFixed?: Injectable[];
436
+ /**
437
+ * CSS string to set the height of the reader in paginated mode, and also
438
+ * in scrolling mode if `growWhenScrolling` is `false`.
439
+ *
440
+ * eg: "800px" or `calc(100vh-${CHROME_HEIGHT})`
441
+ *
442
+ * Default: `calc(100vh-${CHROME_HEIGHT})`
443
+ */
444
+ height?: string;
445
+ /**
446
+ * Tells the renderer if it should grow to fit content in scrolling mode, or if should
447
+ * remain the same height and instead show an internal scroll bar. Set to `true` by
448
+ * default, as this should be used in a full-page reader, the most common use case.
449
+ *
450
+ * Default: `true`
451
+ */
452
+ growWhenScrolling?: boolean;
453
+ /**
454
+ * Initial user settings for the reader
455
+ */
456
+ readerSettings?: Partial<ReaderSettings>;
457
+ /**
458
+ * If enabled, reading location will be persisted to local storage and recalled from
459
+ * there upon initial load.
460
+ *
461
+ * Default: `true`
462
+ */
463
+ persistLastLocation?: boolean;
464
+ /**
465
+ * If enabled, reader settings will be persisted to local storage and recalled
466
+ * from there upon initial load.
467
+ *
468
+ * Default: `true`
469
+ */
470
+ persistSettings?: boolean;
471
+ };
472
+ declare type ActiveReaderArguments = UseWebReaderArguments & {
473
+ manifest: WebpubManifest;
474
+ };
475
+ declare type InactiveReaderArguments = undefined;
476
+ declare type ReaderArguments = ActiveReaderArguments | InactiveReaderArguments;
477
+
478
+ /**
479
+ * The React hook that exposes the main API into the reader. It
480
+ * will determine the type of the webpub, and then use the correct reader
481
+ * for that type.
482
+ */
483
+ declare function useWebReader(args: UseWebReaderArguments): HTMLActiveReader | PDFActiveReader | LoadingReader;
484
+
485
+ declare function useHtmlReader(args: ReaderArguments): ReaderReturn;
486
+
487
+ /**
488
+ * The PDF reader
489
+ *
490
+ * The PDF reader loads resources in two stages: First, it fetches the PDF resource as an Uint8Array
491
+ * Then, it passes this array into the <Document> object, which loads the PDF inside an iframe
492
+ *
493
+ * @param args T
494
+ * @returns
495
+ */
496
+ declare function usePdfReader(args: ReaderArguments): ReaderReturn;
497
+
498
+ declare type Dict<T = any> = Record<string, T>;
499
+
500
+ /**
501
+ * See Chakra default theme for shape of theme object:
502
+ * https://github.com/chakra-ui/chakra-ui/tree/main/packages/theme
503
+ *
504
+ * Making this a function because we need to adjust the theme based
505
+ * on the colorMode that's being passed in.
506
+ *
507
+ * Returns the chakra theme object with an additional property `currentColorMode`
508
+ */
509
+ declare function getTheme(colorMode?: ColorMode): Dict<unknown>;
510
+
511
+ declare const useColorModeValue: (light: string, dark: string, sepia: string) => string;
512
+
513
+ declare function clearWebReaderLocalStorage(): void;
514
+
515
+ /**
516
+ * Adds TOC data to Webpub Manifest from single-resource PDF using PDF.js
517
+ * @param manifest
518
+ * @param getResource - a function to get the resource. This allows the caller
519
+ * to decide how to get the resource, for example through a proxy if necessary.
520
+ * @param pdfWorkerSrc - the path to the pdfjs worker file. Necessary to use pdfjs.
521
+ * @returns {WebpubManifest} manifest object
522
+ */
523
+ declare function addTocToManifest(manifest: WebpubManifest, getResource: (url: string) => Promise<Uint8Array>, pdfWorkerSrc: string): Promise<WebpubManifest>;
524
+
525
+ /**
526
+ * The main React component export.
527
+ */
528
+ declare type WebReaderProps = UseWebReaderArguments & ReaderManagerArguments;
529
+ declare const WebReaderWithoutBoundary: FC<WebReaderProps>;
530
+ declare const WebReader: FC<WebReaderProps>;
531
+
532
+ export { CHROME_HEIGHT, DEFAULT_HEIGHT, DEFAULT_SETTINGS, DEFAULT_SHOULD_GROW_WHEN_SCROLLING, FONT_DETAILS, FOOTER_HEIGHT, HEADER_HEIGHT, IS_DEV, LOCAL_STORAGE_LOCATIONS_KEY, LOCAL_STORAGE_SETTINGS_KEY, ReadiumWebpubContext, WebReaderProps, WebReaderWithoutBoundary, addTocToManifest, clearWebReaderLocalStorage, WebReader as default, getTheme, useColorModeValue, useHtmlReader, usePdfReader, useWebReader };