@prose-reader/core 1.21.0 → 1.22.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.
Files changed (35) hide show
  1. package/dist/context.d.ts +6 -1
  2. package/dist/createReaderWithEnhancer.d.ts +233 -805
  3. package/dist/enhancers/accessibility.d.ts +231 -805
  4. package/dist/enhancers/chrome.d.ts +231 -805
  5. package/dist/enhancers/cssFix.d.ts +6639 -0
  6. package/dist/enhancers/fonts.d.ts +233 -807
  7. package/dist/enhancers/hotkeys.d.ts +231 -805
  8. package/dist/enhancers/layoutEnhancer/layoutEnhancer.d.ts +231 -805
  9. package/dist/enhancers/links.d.ts +231 -805
  10. package/dist/enhancers/loadingEnhancer.d.ts +231 -805
  11. package/dist/enhancers/media.d.ts +231 -805
  12. package/dist/enhancers/navigation.d.ts +231 -805
  13. package/dist/enhancers/pagination.d.ts +233 -805
  14. package/dist/enhancers/progression.d.ts +231 -805
  15. package/dist/enhancers/resources/index.d.ts +231 -805
  16. package/dist/enhancers/theme.d.ts +231 -805
  17. package/dist/enhancers/types/enhancer.d.ts +231 -805
  18. package/dist/enhancers/utils.d.ts +231 -805
  19. package/dist/enhancers/webkit.d.ts +231 -805
  20. package/dist/enhancers/zoom/index.d.ts +231 -805
  21. package/dist/prose.js +300 -278
  22. package/dist/prose.js.map +1 -1
  23. package/dist/prose.umd.cjs +299 -277
  24. package/dist/prose.umd.cjs.map +1 -1
  25. package/dist/reader.d.ts +231 -805
  26. package/dist/spine/locationResolver.d.ts +7 -17
  27. package/dist/spine/navigationResolver.d.ts +5 -8
  28. package/dist/spine/types.d.ts +10 -0
  29. package/dist/spineItem/locationResolver.d.ts +3 -7
  30. package/dist/spineItem/navigationResolver.d.ts +7 -17
  31. package/dist/spineItem/types.d.ts +19 -0
  32. package/dist/spineItemManager.d.ts +6 -519
  33. package/dist/types/Hook.d.ts +6 -6
  34. package/dist/types/Spine.d.ts +1 -5
  35. package/package.json +3 -3
@@ -471,7 +471,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
471
471
  isReady$: Observable<boolean>;
472
472
  };
473
473
  }[];
474
- getAbsolutePositionOf: ((spineItemOrIndex: number | {
474
+ getAbsolutePositionOf: (spineItemOrIndex: number | {
475
475
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
476
476
  blankPagePosition: "after" | "before" | "none";
477
477
  minimumWidth: number;
@@ -640,188 +640,13 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
640
640
  isReady$: Observable<boolean>;
641
641
  };
642
642
  }) => {
643
- leftStart: number;
644
- leftEnd: number;
645
- topStart: number;
646
- topEnd: number;
643
+ left: number;
644
+ right: number;
645
+ top: number;
646
+ bottom: number;
647
647
  width: number;
648
648
  height: number;
649
- }) | ((spineItemOrIndex: number | {
650
- layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
651
- blankPagePosition: "after" | "before" | "none";
652
- minimumWidth: number;
653
- spreadPosition: "none" | "right" | "left";
654
- }) => {
655
- width: number;
656
- height: number;
657
- };
658
- item: {
659
- id: string;
660
- href: string;
661
- renditionLayout: "reflowable" | "pre-paginated";
662
- progressionWeight: number;
663
- pageSpreadLeft: true | undefined;
664
- pageSpreadRight: true | undefined;
665
- mediaType?: string | undefined;
666
- };
667
- load: () => void;
668
- adjustPositionOfElement: ({ right, left, top }: {
669
- right?: number | undefined;
670
- left?: number | undefined;
671
- top?: number | undefined;
672
- }) => void;
673
- getElementDimensions: () => {
674
- width: number;
675
- height: number;
676
- };
677
- getHtmlFromResource: (response: Response) => Promise<string>;
678
- getResource: () => Promise<Response>;
679
- translateFramePositionIntoPage: (position: {
680
- clientX: number;
681
- clientY: number;
682
- }) => {
683
- clientX: number;
684
- clientY: number;
685
- };
686
- setLayoutDirty: () => void;
687
- injectStyle: (cssText: string) => void;
688
- loadContent: () => void;
689
- unloadContent: () => void;
690
- spineItemFrame: {
691
- getIsLoaded: () => boolean;
692
- getIsReady: () => boolean;
693
- getViewportDimensions: () => {
694
- width: number;
695
- height: number;
696
- } | undefined;
697
- getFrameElement: () => HTMLIFrameElement | undefined;
698
- getHtmlFromResource: (response: Response) => Promise<string>;
699
- load: () => void;
700
- unload: () => void;
701
- staticLayout: (size: {
702
- width: number;
703
- height: number;
704
- }) => void;
705
- getManipulableFrame: () => {
706
- frame: HTMLIFrameElement;
707
- removeStyle: (id: string) => void;
708
- addStyle: (id: string, style: string, prepend?: boolean) => void;
709
- } | undefined;
710
- getReadingDirection: () => "ltr" | "rtl" | undefined;
711
- isUsingVerticalWriting: () => boolean;
712
- getWritingMode: () => "vertical-rl" | "horizontal-tb" | undefined;
713
- destroy: () => void;
714
- $: {
715
- unload$: Observable<void>;
716
- unloaded$: Observable<void>;
717
- loaded$: Observable<HTMLIFrameElement>;
718
- ready$: Observable<FontFaceSet | undefined>;
719
- isReady$: Observable<boolean>;
720
- contentLayoutChange$: Observable<{
721
- isFirstLayout: boolean;
722
- } | {
723
- isFirstLayout: boolean;
724
- }>;
725
- };
726
- };
727
- element: HTMLElement;
728
- getBoundingRectOfElementFromSelector: (selector: string) => DOMRect | undefined;
729
- getViewPortInformation: () => {
730
- computedScale: number;
731
- computedWidthScale: number;
732
- viewportDimensions: {
733
- width: number;
734
- height: number;
735
- };
736
- } | undefined;
737
- isImageType: () => boolean;
738
- isReady: () => boolean;
739
- destroy: () => void;
740
- isUsingVerticalWriting: () => boolean | undefined;
741
- getReadingDirection: () => "ltr" | "rtl" | undefined;
742
- manipulateSpineItem: (cb: (options: {
743
- container: HTMLElement;
744
- item: {
745
- id: string;
746
- href: string;
747
- renditionLayout: "reflowable" | "pre-paginated";
748
- progressionWeight: number;
749
- pageSpreadLeft: true | undefined;
750
- pageSpreadRight: true | undefined;
751
- mediaType?: string | undefined;
752
- };
753
- overlayElement: HTMLDivElement;
754
- } & ({
755
- frame: HTMLIFrameElement;
756
- removeStyle: (id: string) => void;
757
- addStyle: (id: string, style: string, prepend?: boolean) => void;
758
- } | {
759
- frame: undefined;
760
- removeStyle: (id: string) => void;
761
- addStyle: (id: string, style: string) => void;
762
- })) => boolean) => boolean;
763
- executeOnLayoutBeforeMeasurementHook: (options: {
764
- minimumWidth: number;
765
- }) => void;
766
- selectionTracker: {
767
- track: (frameToTrack: HTMLIFrameElement) => void;
768
- destroy: () => void;
769
- isSelecting: () => boolean;
770
- getSelection: () => Selection | undefined;
771
- $: Observable<{
772
- event: "selectionchange";
773
- data: Selection | null;
774
- } | {
775
- event: "selectstart";
776
- data: Selection | null;
777
- } | {
778
- event: "selectend";
779
- data: Selection | null;
780
- }>;
781
- };
782
- fingerTracker: {
783
- track: (frame: HTMLIFrameElement) => void;
784
- getFingerPositionInIframe(): {
785
- x: number | undefined;
786
- y: number | undefined;
787
- } | undefined;
788
- destroy: () => void;
789
- $: Observable<{
790
- event: "fingermove";
791
- data: {
792
- x: number;
793
- y: number;
794
- };
795
- } | {
796
- event: "fingerout";
797
- data: undefined;
798
- }>;
799
- };
800
- getDimensionsForReflowableContent: (isUsingVerticalWriting: boolean, minimumWidth: number) => {
801
- columnHeight: number;
802
- columnWidth: number;
803
- width: number;
804
- };
805
- getDimensionsForPaginatedContent: () => {
806
- columnHeight: number;
807
- columnWidth: number;
808
- };
809
- $: {
810
- contentLayout$: Observable<{
811
- isFirstLayout: boolean;
812
- isReady: boolean;
813
- }>;
814
- loaded$: Observable<HTMLIFrameElement>;
815
- isReady$: Observable<boolean>;
816
- };
817
- }) => {
818
- leftStart: number;
819
- leftEnd: number;
820
- topStart: number;
821
- topEnd: number;
822
- width: number;
823
- height: number;
824
- });
649
+ };
825
650
  getSelection: () => Selection | undefined;
826
651
  isSelecting: () => boolean | undefined;
827
652
  normalizeEventForViewport: <E extends MouseEvent | TouchEvent | PointerEvent>(event: E) => E;
@@ -855,11 +680,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
855
680
  end: string;
856
681
  };
857
682
  locator: {
858
- getSpinePositionFromSpineItemPosition: (spineItemPosition: {
859
- x: number;
860
- y: number;
861
- outsideOfBoundaries?: boolean | undefined;
862
- }, spineItem: {
683
+ getSpinePositionFromSpineItemPosition: (spineItemPosition: import("../spineItem/types").SpineItemPosition | import("../spineItem/types").SpineItemNavigationPosition, spineItem: {
863
684
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
864
685
  blankPagePosition: "after" | "before" | "none";
865
686
  minimumWidth: number;
@@ -1027,10 +848,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
1027
848
  loaded$: Observable<HTMLIFrameElement>;
1028
849
  isReady$: Observable<boolean>;
1029
850
  };
1030
- }) => {
1031
- x: number;
1032
- y: number;
1033
- };
851
+ }) => import("../spine/types").SpinePosition;
1034
852
  getSpinePositionFromSpineItem: (spineItem: {
1035
853
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
1036
854
  blankPagePosition: "after" | "before" | "none";
@@ -1199,10 +1017,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
1199
1017
  loaded$: Observable<HTMLIFrameElement>;
1200
1018
  isReady$: Observable<boolean>;
1201
1019
  };
1202
- }) => {
1203
- x: number;
1204
- y: number;
1205
- };
1020
+ }) => import("../spine/types").SpinePosition;
1206
1021
  getSpinePositionFromSpineItemAnchor: (anchor: string, spineItem: {
1207
1022
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
1208
1023
  blankPagePosition: "after" | "before" | "none";
@@ -1371,14 +1186,8 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
1371
1186
  loaded$: Observable<HTMLIFrameElement>;
1372
1187
  isReady$: Observable<boolean>;
1373
1188
  };
1374
- }) => {
1375
- x: number;
1376
- y: number;
1377
- };
1378
- getSpineItemPositionFromSpinePosition: ((position: {
1379
- x: number;
1380
- y: number;
1381
- }, spineItem: {
1189
+ }) => import("../spine/types").SpinePosition;
1190
+ getSpineItemPositionFromSpinePosition: ((position: import("../spine/types").UnsafeSpinePosition, spineItem: {
1382
1191
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
1383
1192
  blankPagePosition: "after" | "before" | "none";
1384
1193
  minimumWidth: number;
@@ -1546,14 +1355,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
1546
1355
  loaded$: Observable<HTMLIFrameElement>;
1547
1356
  isReady$: Observable<boolean>;
1548
1357
  };
1549
- }) => {
1550
- x: number;
1551
- y: number;
1552
- outsideOfBoundaries?: boolean | undefined;
1553
- }) | ((position: {
1554
- x: number;
1555
- y: number;
1556
- }, spineItem: {
1358
+ }) => import("../spineItem/types").UnsafeSpineItemPosition) | ((position: import("../spine/types").UnsafeSpinePosition, spineItem: {
1557
1359
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
1558
1360
  blankPagePosition: "after" | "before" | "none";
1559
1361
  minimumWidth: number;
@@ -1721,15 +1523,8 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
1721
1523
  loaded$: Observable<HTMLIFrameElement>;
1722
1524
  isReady$: Observable<boolean>;
1723
1525
  };
1724
- }) => {
1725
- x: number;
1726
- y: number;
1727
- outsideOfBoundaries?: boolean | undefined;
1728
- });
1729
- getSpineItemFromPosition: ((position: {
1730
- x: number;
1731
- y: number;
1732
- }) => {
1526
+ }) => import("../spineItem/types").UnsafeSpineItemPosition);
1527
+ getSpineItemFromPosition: ((position: import("../spine/types").UnsafeSpinePosition) => {
1733
1528
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
1734
1529
  blankPagePosition: "after" | "before" | "none";
1735
1530
  minimumWidth: number;
@@ -1897,10 +1692,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
1897
1692
  loaded$: Observable<HTMLIFrameElement>;
1898
1693
  isReady$: Observable<boolean>;
1899
1694
  };
1900
- } | undefined) | ((position: {
1901
- x: number;
1902
- y: number;
1903
- }) => {
1695
+ } | undefined) | ((position: import("../spine/types").UnsafeSpinePosition) => {
1904
1696
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
1905
1697
  blankPagePosition: "after" | "before" | "none";
1906
1698
  minimumWidth: number;
@@ -2407,22 +2199,11 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
2407
2199
  isReady$: Observable<boolean>;
2408
2200
  };
2409
2201
  }) => number | undefined;
2410
- getSpineItemsFromReadingOrderPosition: (position: {
2411
- x: number;
2412
- y: number;
2413
- }) => {
2414
- left: number;
2415
- right: number;
2202
+ getSpineItemsFromReadingOrderPosition: (position: import("../spine/types").SpinePosition) => {
2416
2203
  begin: number;
2417
- beginPosition: {
2418
- x: number;
2419
- y: number;
2420
- };
2204
+ beginPosition: import("../spine/types").SpinePosition;
2421
2205
  end: number;
2422
- endPosition: {
2423
- x: number;
2424
- y: number;
2425
- };
2206
+ endPosition: import("../spine/types").SpinePosition;
2426
2207
  } | undefined;
2427
2208
  };
2428
2209
  getCurrentNavigationPosition: () => import("../spine/navigationResolver").ViewportNavigationEntry;
@@ -2454,56 +2235,213 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
2454
2235
  endCfi: string | undefined;
2455
2236
  endSpineItemIndex: number | undefined;
2456
2237
  }>;
2457
- $: {
2458
- state$: Observable<{
2459
- supportedPageTurnAnimation: NonNullable<"none" | "fade" | "slide" | undefined>[];
2460
- supportedPageTurnMode: NonNullable<"controlled" | "scrollable" | undefined>[];
2461
- supportedPageTurnDirection: NonNullable<"vertical" | "horizontal" | undefined>[];
2462
- supportedComputedPageTurnDirection: NonNullable<"vertical" | "horizontal" | undefined>[];
2463
- }>;
2464
- ready$: Observable<void>;
2465
- selection$: Observable<{
2466
- toString: () => string;
2467
- getAnchorCfi: () => string | undefined;
2468
- getFocusCfi: () => string | undefined;
2469
- } | null>;
2470
- viewportState$: Observable<"free" | "busy">;
2471
- layout$: Observable<boolean>;
2472
- itemsCreated$: Observable<{
2473
- item: {
2474
- id: string;
2475
- href: string;
2476
- renditionLayout: "reflowable" | "pre-paginated";
2477
- progressionWeight: number;
2478
- pageSpreadLeft: true | undefined;
2479
- pageSpreadRight: true | undefined;
2480
- mediaType?: string | undefined;
2481
- };
2482
- element: HTMLElement;
2483
- }[]>;
2484
- itemsBeforeDestroy$: Observable<void>;
2485
- itemIsReady$: Observable<{
2486
- item: {
2487
- id: string;
2488
- href: string;
2489
- renditionLayout: "reflowable" | "pre-paginated";
2490
- progressionWeight: number;
2491
- pageSpreadLeft: true | undefined;
2492
- pageSpreadRight: true | undefined;
2493
- mediaType?: string | undefined;
2494
- };
2495
- isReady: boolean;
2496
- }>;
2497
- destroy$: Subject<void>;
2498
- };
2499
- __debug: {
2500
- pagination: {
2501
- destroy: () => void;
2502
- updateBeginAndEnd: ((begin: {
2503
- spineItem: {
2504
- layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
2505
- blankPagePosition: "after" | "before" | "none";
2506
- minimumWidth: number;
2238
+ spineItems$: Observable<{
2239
+ layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
2240
+ blankPagePosition: "after" | "before" | "none";
2241
+ minimumWidth: number;
2242
+ spreadPosition: "none" | "right" | "left";
2243
+ }) => {
2244
+ width: number;
2245
+ height: number;
2246
+ };
2247
+ item: {
2248
+ id: string;
2249
+ href: string;
2250
+ renditionLayout: "reflowable" | "pre-paginated";
2251
+ progressionWeight: number;
2252
+ pageSpreadLeft: true | undefined;
2253
+ pageSpreadRight: true | undefined;
2254
+ mediaType?: string | undefined;
2255
+ };
2256
+ load: () => void;
2257
+ adjustPositionOfElement: ({ right, left, top }: {
2258
+ right?: number | undefined;
2259
+ left?: number | undefined;
2260
+ top?: number | undefined;
2261
+ }) => void;
2262
+ getElementDimensions: () => {
2263
+ width: number;
2264
+ height: number;
2265
+ };
2266
+ getHtmlFromResource: (response: Response) => Promise<string>;
2267
+ getResource: () => Promise<Response>;
2268
+ translateFramePositionIntoPage: (position: {
2269
+ clientX: number;
2270
+ clientY: number;
2271
+ }) => {
2272
+ clientX: number;
2273
+ clientY: number;
2274
+ };
2275
+ setLayoutDirty: () => void;
2276
+ injectStyle: (cssText: string) => void;
2277
+ loadContent: () => void;
2278
+ unloadContent: () => void;
2279
+ spineItemFrame: {
2280
+ getIsLoaded: () => boolean;
2281
+ getIsReady: () => boolean;
2282
+ getViewportDimensions: () => {
2283
+ width: number;
2284
+ height: number;
2285
+ } | undefined;
2286
+ getFrameElement: () => HTMLIFrameElement | undefined;
2287
+ getHtmlFromResource: (response: Response) => Promise<string>;
2288
+ load: () => void;
2289
+ unload: () => void;
2290
+ staticLayout: (size: {
2291
+ width: number;
2292
+ height: number;
2293
+ }) => void;
2294
+ getManipulableFrame: () => {
2295
+ frame: HTMLIFrameElement;
2296
+ removeStyle: (id: string) => void;
2297
+ addStyle: (id: string, style: string, prepend?: boolean) => void;
2298
+ } | undefined;
2299
+ getReadingDirection: () => "ltr" | "rtl" | undefined;
2300
+ isUsingVerticalWriting: () => boolean;
2301
+ getWritingMode: () => "vertical-rl" | "horizontal-tb" | undefined;
2302
+ destroy: () => void;
2303
+ $: {
2304
+ unload$: Observable<void>;
2305
+ unloaded$: Observable<void>;
2306
+ loaded$: Observable<HTMLIFrameElement>;
2307
+ ready$: Observable<FontFaceSet | undefined>;
2308
+ isReady$: Observable<boolean>;
2309
+ contentLayoutChange$: Observable<{
2310
+ isFirstLayout: boolean;
2311
+ } | {
2312
+ isFirstLayout: boolean;
2313
+ }>;
2314
+ };
2315
+ };
2316
+ element: HTMLElement;
2317
+ getBoundingRectOfElementFromSelector: (selector: string) => DOMRect | undefined;
2318
+ getViewPortInformation: () => {
2319
+ computedScale: number;
2320
+ computedWidthScale: number;
2321
+ viewportDimensions: {
2322
+ width: number;
2323
+ height: number;
2324
+ };
2325
+ } | undefined;
2326
+ isImageType: () => boolean;
2327
+ isReady: () => boolean;
2328
+ destroy: () => void;
2329
+ isUsingVerticalWriting: () => boolean | undefined;
2330
+ getReadingDirection: () => "ltr" | "rtl" | undefined;
2331
+ manipulateSpineItem: (cb: (options: {
2332
+ container: HTMLElement;
2333
+ item: {
2334
+ id: string;
2335
+ href: string;
2336
+ renditionLayout: "reflowable" | "pre-paginated";
2337
+ progressionWeight: number;
2338
+ pageSpreadLeft: true | undefined;
2339
+ pageSpreadRight: true | undefined;
2340
+ mediaType?: string | undefined;
2341
+ };
2342
+ overlayElement: HTMLDivElement;
2343
+ } & ({
2344
+ frame: HTMLIFrameElement;
2345
+ removeStyle: (id: string) => void;
2346
+ addStyle: (id: string, style: string, prepend?: boolean) => void;
2347
+ } | {
2348
+ frame: undefined;
2349
+ removeStyle: (id: string) => void;
2350
+ addStyle: (id: string, style: string) => void;
2351
+ })) => boolean) => boolean;
2352
+ executeOnLayoutBeforeMeasurementHook: (options: {
2353
+ minimumWidth: number;
2354
+ }) => void;
2355
+ selectionTracker: {
2356
+ track: (frameToTrack: HTMLIFrameElement) => void;
2357
+ destroy: () => void;
2358
+ isSelecting: () => boolean;
2359
+ getSelection: () => Selection | undefined;
2360
+ $: Observable<{
2361
+ event: "selectionchange";
2362
+ data: Selection | null;
2363
+ } | {
2364
+ event: "selectstart";
2365
+ data: Selection | null;
2366
+ } | {
2367
+ event: "selectend";
2368
+ data: Selection | null;
2369
+ }>;
2370
+ };
2371
+ fingerTracker: {
2372
+ track: (frame: HTMLIFrameElement) => void;
2373
+ getFingerPositionInIframe(): {
2374
+ x: number | undefined;
2375
+ y: number | undefined;
2376
+ } | undefined;
2377
+ destroy: () => void;
2378
+ $: Observable<{
2379
+ event: "fingermove";
2380
+ data: {
2381
+ x: number;
2382
+ y: number;
2383
+ };
2384
+ } | {
2385
+ event: "fingerout";
2386
+ data: undefined;
2387
+ }>;
2388
+ };
2389
+ getDimensionsForReflowableContent: (isUsingVerticalWriting: boolean, minimumWidth: number) => {
2390
+ columnHeight: number;
2391
+ columnWidth: number;
2392
+ width: number;
2393
+ };
2394
+ getDimensionsForPaginatedContent: () => {
2395
+ columnHeight: number;
2396
+ columnWidth: number;
2397
+ };
2398
+ $: {
2399
+ contentLayout$: Observable<{
2400
+ isFirstLayout: boolean;
2401
+ isReady: boolean;
2402
+ }>;
2403
+ loaded$: Observable<HTMLIFrameElement>;
2404
+ isReady$: Observable<boolean>;
2405
+ };
2406
+ }[]>;
2407
+ $: {
2408
+ state$: Observable<{
2409
+ supportedPageTurnAnimation: NonNullable<"none" | "fade" | "slide" | undefined>[];
2410
+ supportedPageTurnMode: NonNullable<"controlled" | "scrollable" | undefined>[];
2411
+ supportedPageTurnDirection: NonNullable<"vertical" | "horizontal" | undefined>[];
2412
+ supportedComputedPageTurnDirection: NonNullable<"vertical" | "horizontal" | undefined>[];
2413
+ }>;
2414
+ ready$: Observable<void>;
2415
+ selection$: Observable<{
2416
+ toString: () => string;
2417
+ getAnchorCfi: () => string | undefined;
2418
+ getFocusCfi: () => string | undefined;
2419
+ } | null>;
2420
+ viewportState$: Observable<"free" | "busy">;
2421
+ layout$: Observable<boolean>;
2422
+ itemsBeforeDestroy$: Observable<void>;
2423
+ itemIsReady$: Observable<{
2424
+ item: {
2425
+ id: string;
2426
+ href: string;
2427
+ renditionLayout: "reflowable" | "pre-paginated";
2428
+ progressionWeight: number;
2429
+ pageSpreadLeft: true | undefined;
2430
+ pageSpreadRight: true | undefined;
2431
+ mediaType?: string | undefined;
2432
+ };
2433
+ isReady: boolean;
2434
+ }>;
2435
+ destroy$: Subject<void>;
2436
+ };
2437
+ __debug: {
2438
+ pagination: {
2439
+ destroy: () => void;
2440
+ updateBeginAndEnd: ((begin: {
2441
+ spineItem: {
2442
+ layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
2443
+ blankPagePosition: "after" | "before" | "none";
2444
+ minimumWidth: number;
2507
2445
  spreadPosition: "none" | "right" | "left";
2508
2446
  }) => {
2509
2447
  width: number;
@@ -4250,7 +4188,7 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
4250
4188
  isReady$: Observable<boolean>;
4251
4189
  };
4252
4190
  }) => "after" | "before";
4253
- getAbsolutePositionOf: ((spineItemOrIndex: number | {
4191
+ getAbsolutePositionOf: (spineItemOrIndex: number | {
4254
4192
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
4255
4193
  blankPagePosition: "after" | "before" | "none";
4256
4194
  minimumWidth: number;
@@ -4419,525 +4357,13 @@ export declare const linksEnhancer: <InheritOptions extends import("../reader").
4419
4357
  isReady$: Observable<boolean>;
4420
4358
  };
4421
4359
  }) => {
4422
- leftStart: number;
4423
- leftEnd: number;
4424
- topStart: number;
4425
- topEnd: number;
4360
+ left: number;
4361
+ right: number;
4362
+ top: number;
4363
+ bottom: number;
4426
4364
  width: number;
4427
4365
  height: number;
4428
- }) | ((spineItemOrIndex: number | {
4429
- layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
4430
- blankPagePosition: "after" | "before" | "none";
4431
- minimumWidth: number;
4432
- spreadPosition: "none" | "right" | "left";
4433
- }) => {
4434
- width: number;
4435
- height: number;
4436
- };
4437
- item: {
4438
- id: string;
4439
- href: string;
4440
- renditionLayout: "reflowable" | "pre-paginated";
4441
- progressionWeight: number;
4442
- pageSpreadLeft: true | undefined;
4443
- pageSpreadRight: true | undefined;
4444
- mediaType?: string | undefined;
4445
- };
4446
- load: () => void;
4447
- adjustPositionOfElement: ({ right, left, top }: {
4448
- right?: number | undefined;
4449
- left?: number | undefined;
4450
- top?: number | undefined;
4451
- }) => void;
4452
- getElementDimensions: () => {
4453
- width: number;
4454
- height: number;
4455
- };
4456
- getHtmlFromResource: (response: Response) => Promise<string>;
4457
- getResource: () => Promise<Response>;
4458
- translateFramePositionIntoPage: (position: {
4459
- clientX: number;
4460
- clientY: number;
4461
- }) => {
4462
- clientX: number;
4463
- clientY: number;
4464
- };
4465
- setLayoutDirty: () => void;
4466
- injectStyle: (cssText: string) => void;
4467
- loadContent: () => void;
4468
- unloadContent: () => void;
4469
- spineItemFrame: {
4470
- getIsLoaded: () => boolean;
4471
- getIsReady: () => boolean;
4472
- getViewportDimensions: () => {
4473
- width: number;
4474
- height: number;
4475
- } | undefined;
4476
- getFrameElement: () => HTMLIFrameElement | undefined;
4477
- getHtmlFromResource: (response: Response) => Promise<string>;
4478
- load: () => void;
4479
- unload: () => void;
4480
- staticLayout: (size: {
4481
- width: number;
4482
- height: number;
4483
- }) => void;
4484
- getManipulableFrame: () => {
4485
- frame: HTMLIFrameElement;
4486
- removeStyle: (id: string) => void;
4487
- addStyle: (id: string, style: string, prepend?: boolean) => void;
4488
- } | undefined;
4489
- getReadingDirection: () => "ltr" | "rtl" | undefined;
4490
- isUsingVerticalWriting: () => boolean;
4491
- getWritingMode: () => "vertical-rl" | "horizontal-tb" | undefined;
4492
- destroy: () => void;
4493
- $: {
4494
- unload$: Observable<void>;
4495
- unloaded$: Observable<void>;
4496
- loaded$: Observable<HTMLIFrameElement>;
4497
- ready$: Observable<FontFaceSet | undefined>;
4498
- isReady$: Observable<boolean>;
4499
- contentLayoutChange$: Observable<{
4500
- isFirstLayout: boolean;
4501
- } | {
4502
- isFirstLayout: boolean;
4503
- }>;
4504
- };
4505
- };
4506
- element: HTMLElement;
4507
- getBoundingRectOfElementFromSelector: (selector: string) => DOMRect | undefined;
4508
- getViewPortInformation: () => {
4509
- computedScale: number;
4510
- computedWidthScale: number;
4511
- viewportDimensions: {
4512
- width: number;
4513
- height: number;
4514
- };
4515
- } | undefined;
4516
- isImageType: () => boolean;
4517
- isReady: () => boolean;
4518
- destroy: () => void;
4519
- isUsingVerticalWriting: () => boolean | undefined;
4520
- getReadingDirection: () => "ltr" | "rtl" | undefined;
4521
- manipulateSpineItem: (cb: (options: {
4522
- container: HTMLElement;
4523
- item: {
4524
- id: string;
4525
- href: string;
4526
- renditionLayout: "reflowable" | "pre-paginated";
4527
- progressionWeight: number;
4528
- pageSpreadLeft: true | undefined;
4529
- pageSpreadRight: true | undefined;
4530
- mediaType?: string | undefined;
4531
- };
4532
- overlayElement: HTMLDivElement;
4533
- } & ({
4534
- frame: HTMLIFrameElement;
4535
- removeStyle: (id: string) => void;
4536
- addStyle: (id: string, style: string, prepend?: boolean) => void;
4537
- } | {
4538
- frame: undefined;
4539
- removeStyle: (id: string) => void;
4540
- addStyle: (id: string, style: string) => void;
4541
- })) => boolean) => boolean;
4542
- executeOnLayoutBeforeMeasurementHook: (options: {
4543
- minimumWidth: number;
4544
- }) => void;
4545
- selectionTracker: {
4546
- track: (frameToTrack: HTMLIFrameElement) => void;
4547
- destroy: () => void;
4548
- isSelecting: () => boolean;
4549
- getSelection: () => Selection | undefined;
4550
- $: Observable<{
4551
- event: "selectionchange";
4552
- data: Selection | null;
4553
- } | {
4554
- event: "selectstart";
4555
- data: Selection | null;
4556
- } | {
4557
- event: "selectend";
4558
- data: Selection | null;
4559
- }>;
4560
- };
4561
- fingerTracker: {
4562
- track: (frame: HTMLIFrameElement) => void;
4563
- getFingerPositionInIframe(): {
4564
- x: number | undefined;
4565
- y: number | undefined;
4566
- } | undefined;
4567
- destroy: () => void;
4568
- $: Observable<{
4569
- event: "fingermove";
4570
- data: {
4571
- x: number;
4572
- y: number;
4573
- };
4574
- } | {
4575
- event: "fingerout";
4576
- data: undefined;
4577
- }>;
4578
- };
4579
- getDimensionsForReflowableContent: (isUsingVerticalWriting: boolean, minimumWidth: number) => {
4580
- columnHeight: number;
4581
- columnWidth: number;
4582
- width: number;
4583
- };
4584
- getDimensionsForPaginatedContent: () => {
4585
- columnHeight: number;
4586
- columnWidth: number;
4587
- };
4588
- $: {
4589
- contentLayout$: Observable<{
4590
- isFirstLayout: boolean;
4591
- isReady: boolean;
4592
- }>;
4593
- loaded$: Observable<HTMLIFrameElement>;
4594
- isReady$: Observable<boolean>;
4595
- };
4596
- }) => {
4597
- leftStart: number;
4598
- leftEnd: number;
4599
- topStart: number;
4600
- topEnd: number;
4601
- width: number;
4602
- height: number;
4603
- });
4604
- getSpineItemAtPosition: ((position: import("../types").ViewportPosition) => {
4605
- layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
4606
- blankPagePosition: "after" | "before" | "none";
4607
- minimumWidth: number;
4608
- spreadPosition: "none" | "right" | "left";
4609
- }) => {
4610
- width: number;
4611
- height: number;
4612
- };
4613
- item: {
4614
- id: string;
4615
- href: string;
4616
- renditionLayout: "reflowable" | "pre-paginated";
4617
- progressionWeight: number;
4618
- pageSpreadLeft: true | undefined;
4619
- pageSpreadRight: true | undefined;
4620
- mediaType?: string | undefined;
4621
- };
4622
- load: () => void;
4623
- adjustPositionOfElement: ({ right, left, top }: {
4624
- right?: number | undefined;
4625
- left?: number | undefined;
4626
- top?: number | undefined;
4627
- }) => void;
4628
- getElementDimensions: () => {
4629
- width: number;
4630
- height: number;
4631
- };
4632
- getHtmlFromResource: (response: Response) => Promise<string>;
4633
- getResource: () => Promise<Response>;
4634
- translateFramePositionIntoPage: (position: {
4635
- clientX: number;
4636
- clientY: number;
4637
- }) => {
4638
- clientX: number;
4639
- clientY: number;
4640
- };
4641
- setLayoutDirty: () => void;
4642
- injectStyle: (cssText: string) => void;
4643
- loadContent: () => void;
4644
- unloadContent: () => void;
4645
- spineItemFrame: {
4646
- getIsLoaded: () => boolean;
4647
- getIsReady: () => boolean;
4648
- getViewportDimensions: () => {
4649
- width: number;
4650
- height: number;
4651
- } | undefined;
4652
- getFrameElement: () => HTMLIFrameElement | undefined;
4653
- getHtmlFromResource: (response: Response) => Promise<string>;
4654
- load: () => void;
4655
- unload: () => void;
4656
- staticLayout: (size: {
4657
- width: number;
4658
- height: number;
4659
- }) => void;
4660
- getManipulableFrame: () => {
4661
- frame: HTMLIFrameElement;
4662
- removeStyle: (id: string) => void;
4663
- addStyle: (id: string, style: string, prepend?: boolean) => void;
4664
- } | undefined;
4665
- getReadingDirection: () => "ltr" | "rtl" | undefined;
4666
- isUsingVerticalWriting: () => boolean;
4667
- getWritingMode: () => "vertical-rl" | "horizontal-tb" | undefined;
4668
- destroy: () => void;
4669
- $: {
4670
- unload$: Observable<void>;
4671
- unloaded$: Observable<void>;
4672
- loaded$: Observable<HTMLIFrameElement>;
4673
- ready$: Observable<FontFaceSet | undefined>;
4674
- isReady$: Observable<boolean>;
4675
- contentLayoutChange$: Observable<{
4676
- isFirstLayout: boolean;
4677
- } | {
4678
- isFirstLayout: boolean;
4679
- }>;
4680
- };
4681
- };
4682
- element: HTMLElement;
4683
- getBoundingRectOfElementFromSelector: (selector: string) => DOMRect | undefined;
4684
- getViewPortInformation: () => {
4685
- computedScale: number;
4686
- computedWidthScale: number;
4687
- viewportDimensions: {
4688
- width: number;
4689
- height: number;
4690
- };
4691
- } | undefined;
4692
- isImageType: () => boolean;
4693
- isReady: () => boolean;
4694
- destroy: () => void;
4695
- isUsingVerticalWriting: () => boolean | undefined;
4696
- getReadingDirection: () => "ltr" | "rtl" | undefined;
4697
- manipulateSpineItem: (cb: (options: {
4698
- container: HTMLElement;
4699
- item: {
4700
- id: string;
4701
- href: string;
4702
- renditionLayout: "reflowable" | "pre-paginated";
4703
- progressionWeight: number;
4704
- pageSpreadLeft: true | undefined;
4705
- pageSpreadRight: true | undefined;
4706
- mediaType?: string | undefined;
4707
- };
4708
- overlayElement: HTMLDivElement;
4709
- } & ({
4710
- frame: HTMLIFrameElement;
4711
- removeStyle: (id: string) => void;
4712
- addStyle: (id: string, style: string, prepend?: boolean) => void;
4713
- } | {
4714
- frame: undefined;
4715
- removeStyle: (id: string) => void;
4716
- addStyle: (id: string, style: string) => void;
4717
- })) => boolean) => boolean;
4718
- executeOnLayoutBeforeMeasurementHook: (options: {
4719
- minimumWidth: number;
4720
- }) => void;
4721
- selectionTracker: {
4722
- track: (frameToTrack: HTMLIFrameElement) => void;
4723
- destroy: () => void;
4724
- isSelecting: () => boolean;
4725
- getSelection: () => Selection | undefined;
4726
- $: Observable<{
4727
- event: "selectionchange";
4728
- data: Selection | null;
4729
- } | {
4730
- event: "selectstart";
4731
- data: Selection | null;
4732
- } | {
4733
- event: "selectend";
4734
- data: Selection | null;
4735
- }>;
4736
- };
4737
- fingerTracker: {
4738
- track: (frame: HTMLIFrameElement) => void;
4739
- getFingerPositionInIframe(): {
4740
- x: number | undefined;
4741
- y: number | undefined;
4742
- } | undefined;
4743
- destroy: () => void;
4744
- $: Observable<{
4745
- event: "fingermove";
4746
- data: {
4747
- x: number;
4748
- y: number;
4749
- };
4750
- } | {
4751
- event: "fingerout";
4752
- data: undefined;
4753
- }>;
4754
- };
4755
- getDimensionsForReflowableContent: (isUsingVerticalWriting: boolean, minimumWidth: number) => {
4756
- columnHeight: number;
4757
- columnWidth: number;
4758
- width: number;
4759
- };
4760
- getDimensionsForPaginatedContent: () => {
4761
- columnHeight: number;
4762
- columnWidth: number;
4763
- };
4764
- $: {
4765
- contentLayout$: Observable<{
4766
- isFirstLayout: boolean;
4767
- isReady: boolean;
4768
- }>;
4769
- loaded$: Observable<HTMLIFrameElement>;
4770
- isReady$: Observable<boolean>;
4771
- };
4772
- } | undefined) | ((position: import("../types").ViewportPosition) => {
4773
- layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
4774
- blankPagePosition: "after" | "before" | "none";
4775
- minimumWidth: number;
4776
- spreadPosition: "none" | "right" | "left";
4777
- }) => {
4778
- width: number;
4779
- height: number;
4780
- };
4781
- item: {
4782
- id: string;
4783
- href: string;
4784
- renditionLayout: "reflowable" | "pre-paginated";
4785
- progressionWeight: number;
4786
- pageSpreadLeft: true | undefined;
4787
- pageSpreadRight: true | undefined;
4788
- mediaType?: string | undefined;
4789
- };
4790
- load: () => void;
4791
- adjustPositionOfElement: ({ right, left, top }: {
4792
- right?: number | undefined;
4793
- left?: number | undefined;
4794
- top?: number | undefined;
4795
- }) => void;
4796
- getElementDimensions: () => {
4797
- width: number;
4798
- height: number;
4799
- };
4800
- getHtmlFromResource: (response: Response) => Promise<string>;
4801
- getResource: () => Promise<Response>;
4802
- translateFramePositionIntoPage: (position: {
4803
- clientX: number;
4804
- clientY: number;
4805
- }) => {
4806
- clientX: number;
4807
- clientY: number;
4808
- };
4809
- setLayoutDirty: () => void;
4810
- injectStyle: (cssText: string) => void;
4811
- loadContent: () => void;
4812
- unloadContent: () => void;
4813
- spineItemFrame: {
4814
- getIsLoaded: () => boolean;
4815
- getIsReady: () => boolean;
4816
- getViewportDimensions: () => {
4817
- width: number;
4818
- height: number;
4819
- } | undefined;
4820
- getFrameElement: () => HTMLIFrameElement | undefined;
4821
- getHtmlFromResource: (response: Response) => Promise<string>;
4822
- load: () => void;
4823
- unload: () => void;
4824
- staticLayout: (size: {
4825
- width: number;
4826
- height: number;
4827
- }) => void;
4828
- getManipulableFrame: () => {
4829
- frame: HTMLIFrameElement;
4830
- removeStyle: (id: string) => void;
4831
- addStyle: (id: string, style: string, prepend?: boolean) => void;
4832
- } | undefined;
4833
- getReadingDirection: () => "ltr" | "rtl" | undefined;
4834
- isUsingVerticalWriting: () => boolean;
4835
- getWritingMode: () => "vertical-rl" | "horizontal-tb" | undefined;
4836
- destroy: () => void;
4837
- $: {
4838
- unload$: Observable<void>;
4839
- unloaded$: Observable<void>;
4840
- loaded$: Observable<HTMLIFrameElement>;
4841
- ready$: Observable<FontFaceSet | undefined>;
4842
- isReady$: Observable<boolean>;
4843
- contentLayoutChange$: Observable<{
4844
- isFirstLayout: boolean;
4845
- } | {
4846
- isFirstLayout: boolean;
4847
- }>;
4848
- };
4849
- };
4850
- element: HTMLElement;
4851
- getBoundingRectOfElementFromSelector: (selector: string) => DOMRect | undefined;
4852
- getViewPortInformation: () => {
4853
- computedScale: number;
4854
- computedWidthScale: number;
4855
- viewportDimensions: {
4856
- width: number;
4857
- height: number;
4858
- };
4859
- } | undefined;
4860
- isImageType: () => boolean;
4861
- isReady: () => boolean;
4862
- destroy: () => void;
4863
- isUsingVerticalWriting: () => boolean | undefined;
4864
- getReadingDirection: () => "ltr" | "rtl" | undefined;
4865
- manipulateSpineItem: (cb: (options: {
4866
- container: HTMLElement;
4867
- item: {
4868
- id: string;
4869
- href: string;
4870
- renditionLayout: "reflowable" | "pre-paginated";
4871
- progressionWeight: number;
4872
- pageSpreadLeft: true | undefined;
4873
- pageSpreadRight: true | undefined;
4874
- mediaType?: string | undefined;
4875
- };
4876
- overlayElement: HTMLDivElement;
4877
- } & ({
4878
- frame: HTMLIFrameElement;
4879
- removeStyle: (id: string) => void;
4880
- addStyle: (id: string, style: string, prepend?: boolean) => void;
4881
- } | {
4882
- frame: undefined;
4883
- removeStyle: (id: string) => void;
4884
- addStyle: (id: string, style: string) => void;
4885
- })) => boolean) => boolean;
4886
- executeOnLayoutBeforeMeasurementHook: (options: {
4887
- minimumWidth: number;
4888
- }) => void;
4889
- selectionTracker: {
4890
- track: (frameToTrack: HTMLIFrameElement) => void;
4891
- destroy: () => void;
4892
- isSelecting: () => boolean;
4893
- getSelection: () => Selection | undefined;
4894
- $: Observable<{
4895
- event: "selectionchange";
4896
- data: Selection | null;
4897
- } | {
4898
- event: "selectstart";
4899
- data: Selection | null;
4900
- } | {
4901
- event: "selectend";
4902
- data: Selection | null;
4903
- }>;
4904
- };
4905
- fingerTracker: {
4906
- track: (frame: HTMLIFrameElement) => void;
4907
- getFingerPositionInIframe(): {
4908
- x: number | undefined;
4909
- y: number | undefined;
4910
- } | undefined;
4911
- destroy: () => void;
4912
- $: Observable<{
4913
- event: "fingermove";
4914
- data: {
4915
- x: number;
4916
- y: number;
4917
- };
4918
- } | {
4919
- event: "fingerout";
4920
- data: undefined;
4921
- }>;
4922
- };
4923
- getDimensionsForReflowableContent: (isUsingVerticalWriting: boolean, minimumWidth: number) => {
4924
- columnHeight: number;
4925
- columnWidth: number;
4926
- width: number;
4927
- };
4928
- getDimensionsForPaginatedContent: () => {
4929
- columnHeight: number;
4930
- columnWidth: number;
4931
- };
4932
- $: {
4933
- contentLayout$: Observable<{
4934
- isFirstLayout: boolean;
4935
- isReady: boolean;
4936
- }>;
4937
- loaded$: Observable<HTMLIFrameElement>;
4938
- isReady$: Observable<boolean>;
4939
- };
4940
- } | undefined);
4366
+ };
4941
4367
  getFocusedSpineItem: () => {
4942
4368
  layout: ({ blankPagePosition, minimumWidth, spreadPosition, }: {
4943
4369
  blankPagePosition: "after" | "before" | "none";