@react-pdf-kit/viewer 2.0.0-beta.1 → 2.0.0-beta.11

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 (150) hide show
  1. package/README.md +6 -6
  2. package/dist/Combination-54a77a7a.js +701 -0
  3. package/dist/MostPageTool.module-13578ad6.js +6 -0
  4. package/dist/OtherTool.module-a4be5f1f.js +6 -0
  5. package/dist/Paginate.module-206a7d7d.js +8 -0
  6. package/dist/PaginationContext-9217cab4.js +201 -0
  7. package/dist/{LayoutWrapper-6224491f.js → RPLayout.module-967bf4bc.js} +3 -9
  8. package/dist/RPToolbar.module-27d7fe77.js +10 -0
  9. package/dist/SearchTool.module-99f60dc7.js +16 -0
  10. package/dist/ToolbarLayout.module-1fee0a18.js +11 -0
  11. package/dist/ZoomTool.module-7082af8c.js +12 -0
  12. package/dist/assets/style.css +1 -1
  13. package/dist/assets/style.js +32 -31
  14. package/dist/components/RPConfig.js +10 -1485
  15. package/dist/components/RPController.js +77 -148
  16. package/dist/components/RPPages.js +981 -124
  17. package/dist/components/RPProvider.js +56 -118
  18. package/dist/components/icons/DualPageIcon.js +6 -6
  19. package/dist/components/icons/SinglePageIcon.js +6 -6
  20. package/dist/components/layout/LayoutContainer.js +31 -138
  21. package/dist/components/layout/LayoutWrapper.js +8 -4
  22. package/dist/components/layout/RPDefaultLayout.js +162 -88
  23. package/dist/components/layout/RPLayout.js +119 -107
  24. package/dist/components/layout/sidebar/RPSidebar.js +83 -113
  25. package/dist/components/layout/sidebar/Thumbnail.js +120 -126
  26. package/dist/components/layout/sidebar/Thumbnails.js +56 -121
  27. package/dist/components/layout/toolbar/DarkModeTool.js +6 -4
  28. package/dist/components/layout/toolbar/DocumentDialog.js +304 -132
  29. package/dist/components/layout/toolbar/DocumentProperties.js +12 -9
  30. package/dist/components/layout/toolbar/FileDownloadTool.js +34 -126
  31. package/dist/components/layout/toolbar/FileUploadTool.js +8 -5
  32. package/dist/components/layout/toolbar/FullScreenTool.js +16 -13
  33. package/dist/components/layout/toolbar/MenuItem.js +11 -8
  34. package/dist/components/layout/toolbar/MenuSeparator.js +8 -5
  35. package/dist/components/layout/toolbar/MostPageTool.js +64 -125
  36. package/dist/components/layout/toolbar/OtherTool.js +162 -114
  37. package/dist/components/layout/toolbar/Paginate.js +113 -117
  38. package/dist/components/layout/toolbar/PrintTool.js +55 -125
  39. package/dist/components/layout/toolbar/RPMenuItem.js +14 -11
  40. package/dist/components/layout/toolbar/RPMoreOptions.js +66 -121
  41. package/dist/components/layout/toolbar/RPToolbar.js +89 -81
  42. package/dist/components/layout/toolbar/RPToolbarEnd.js +68 -90
  43. package/dist/components/layout/toolbar/RotateTool.js +12 -9
  44. package/dist/components/layout/toolbar/ScrollModeTool.js +14 -11
  45. package/dist/components/layout/toolbar/SearchCloseButton.js +23 -9
  46. package/dist/components/layout/toolbar/SearchResultNavigator.js +53 -106
  47. package/dist/components/layout/toolbar/SearchTool.js +222 -121
  48. package/dist/components/layout/toolbar/SelectionModeTool.js +8 -5
  49. package/dist/components/layout/toolbar/ThumbnailTool.js +15 -124
  50. package/dist/components/layout/toolbar/ToolbarCustom.js +44 -130
  51. package/dist/components/layout/toolbar/ToolbarDefault.js +122 -120
  52. package/dist/components/layout/toolbar/ToolbarLayout.js +85 -83
  53. package/dist/components/layout/toolbar/ViewModeTool.js +10 -7
  54. package/dist/components/layout/toolbar/ZoomTool.js +128 -120
  55. package/dist/components/layout/toolbar/tools/DocumentPropertiesTool.js +17 -123
  56. package/dist/components/layout/toolbar/tools/DualPageTool.js +26 -0
  57. package/dist/components/layout/toolbar/tools/FileDownloadTool.js +10 -121
  58. package/dist/components/layout/toolbar/tools/FileUploadTool.js +6 -4
  59. package/dist/components/layout/toolbar/tools/FullScreenTool.js +13 -11
  60. package/dist/components/layout/toolbar/tools/InputPageTool.js +19 -112
  61. package/dist/components/layout/toolbar/tools/NextPageTool.js +30 -123
  62. package/dist/components/layout/toolbar/tools/PreviousPageTool.js +16 -109
  63. package/dist/components/layout/toolbar/tools/PrintTool.js +12 -123
  64. package/dist/components/layout/toolbar/tools/RotateClockwiseTool.js +6 -4
  65. package/dist/components/layout/toolbar/tools/RotateCounterclockwiseTool.js +6 -4
  66. package/dist/components/layout/toolbar/tools/SelectionModeSwitcherTool.js +31 -0
  67. package/dist/components/layout/toolbar/tools/SinglePageTool.js +26 -0
  68. package/dist/components/layout/toolbar/tools/ThemeSwitcherTool.js +6 -4
  69. package/dist/components/layout/toolbar/tools/ThumbnailTool.js +17 -128
  70. package/dist/components/layout/toolbar/tools/ZoomInTool.js +6 -4
  71. package/dist/components/layout/toolbar/tools/ZoomLevelDisplay.js +22 -137
  72. package/dist/components/layout/toolbar/tools/ZoomLevelTool.js +26 -123
  73. package/dist/components/layout/toolbar/tools/ZoomOutTool.js +6 -4
  74. package/dist/components/layout/toolbar/tools/defaults/RPHorizontalBar.js +95 -105
  75. package/dist/components/layout/toolbar/tools/defaults/RPVerticalBar.js +16 -125
  76. package/dist/components/layout/toolbar/tools/more-options/DocumentProperties.js +8 -5
  77. package/dist/components/layout/toolbar/tools/more-options/FileDownloadTool.js +10 -117
  78. package/dist/components/layout/toolbar/tools/more-options/FileUploadTool.js +12 -120
  79. package/dist/components/layout/toolbar/tools/more-options/FullScreenTool.js +10 -7
  80. package/dist/components/layout/toolbar/tools/more-options/MostPageTool.js +36 -125
  81. package/dist/components/layout/toolbar/tools/more-options/PrintTool.js +16 -123
  82. package/dist/components/layout/toolbar/tools/more-options/RotateTool.js +14 -11
  83. package/dist/components/layout/toolbar/tools/more-options/ScrollModeTool.js +15 -12
  84. package/dist/components/layout/toolbar/tools/more-options/SelectionModeTool.js +18 -15
  85. package/dist/components/layout/toolbar/tools/more-options/ViewModeTool.js +10 -7
  86. package/dist/components/page/AnnotationLayer.js +122 -126
  87. package/dist/components/page/CanvasLayer.js +54 -125
  88. package/dist/components/page/DualPage.js +68 -111
  89. package/dist/components/page/RPPage.js +126 -125
  90. package/dist/components/page/SinglePage.js +58 -111
  91. package/dist/components/page/TextHighlightLayer.js +184 -128
  92. package/dist/components/page/TextLayer.js +184 -125
  93. package/dist/components/ui/Checkbox.js +25 -24
  94. package/dist/components/ui/DropDown.js +11 -8
  95. package/dist/components/ui/LoadingIndicator.js +34 -129
  96. package/dist/components/ui/RPTooltip.js +412 -196
  97. package/dist/contexts/ElementPageContext.js +1 -1
  98. package/dist/contexts/FullScreenContext.js +17 -10
  99. package/dist/contexts/LocalizationContext.js +24 -29
  100. package/dist/contexts/PaginationContext.js +14 -119
  101. package/dist/contexts/PrintContext.js +67 -133
  102. package/dist/contexts/RPDocumentContext.js +32 -24
  103. package/dist/contexts/RenderQueueProvider.js +47 -119
  104. package/dist/contexts/SearchContext.js +65 -113
  105. package/dist/contexts/ThumbnailsContext.js +32 -133
  106. package/dist/contexts/ZoomContext.js +22 -22
  107. package/dist/floating-ui.react-dom-5ec29bd6.js +1327 -0
  108. package/dist/index-4baea9b5.js +1198 -0
  109. package/dist/index-655864a7.js +27 -0
  110. package/dist/{index-c9a2990a.js → index-c0faa594.js} +64 -87
  111. package/dist/index-e3ee9457.js +150 -0
  112. package/dist/main.js +193 -142
  113. package/dist/types/components/icons/DualPageIcon.d.ts +1 -1
  114. package/dist/types/components/icons/SinglePageIcon.d.ts +1 -1
  115. package/dist/types/components/layout/toolbar/tools/DualPageTool.d.ts +3 -0
  116. package/dist/types/components/layout/toolbar/tools/SelectionModeSwitcherTool.d.ts +3 -0
  117. package/dist/types/components/layout/toolbar/tools/SinglePageTool.d.ts +3 -0
  118. package/dist/types/contexts/RenderQueueProvider.d.ts +2 -2
  119. package/dist/types/main.d.ts +5 -5
  120. package/dist/types/utils/annotations.d.ts +2 -1
  121. package/dist/types/utils/getElementPositionInPage.d.ts +2 -2
  122. package/dist/types/utils/hooks/useCopyText.d.ts +1 -0
  123. package/dist/types/utils/hooks/usePrint.d.ts +3 -2
  124. package/dist/types/utils/hooks/useSearch.d.ts +1 -2
  125. package/dist/types/utils/renderPage.d.ts +2 -2
  126. package/dist/types/utils/types.d.ts +27 -4
  127. package/dist/utils/annotations.js +128 -142
  128. package/dist/utils/getWordPositionInPage.js +5 -5
  129. package/dist/utils/highlight.js +72 -72
  130. package/dist/utils/hooks/useCopyText.js +36 -0
  131. package/dist/utils/hooks/useFileDownload.js +20 -129
  132. package/dist/utils/hooks/useHighlight.js +28 -28
  133. package/dist/utils/hooks/useLicense.js +1 -1
  134. package/dist/utils/hooks/useLoadPdf.js +42 -39
  135. package/dist/utils/hooks/useLoadWorker.js +9 -6
  136. package/dist/utils/hooks/useLocalization.js +13 -13
  137. package/dist/utils/hooks/usePaginate.js +21 -126
  138. package/dist/utils/hooks/usePresentPage.js +75 -127
  139. package/dist/utils/hooks/usePrint.js +173 -130
  140. package/dist/utils/hooks/useScrollToPage.js +15 -120
  141. package/dist/utils/hooks/useSearch.js +132 -126
  142. package/dist/utils/hooks/useThumbnail.js +47 -130
  143. package/dist/utils/hooks/useVirtualReactWindow.js +64 -128
  144. package/dist/utils/injectPrintCSS.js +1 -1
  145. package/dist/utils/renderPage.js +12 -10
  146. package/package.json +26 -23
  147. package/dist/SearchCloseButton-08d57275.js +0 -33
  148. package/dist/ToolbarLayout.module-37619c4b.js +0 -3548
  149. package/dist/index-808ea7bf.js +0 -1685
  150. package/dist/index-a48ec088.js +0 -1672
@@ -1,142 +1,77 @@
1
- import "react/jsx-runtime";
2
- import "react";
3
- import { p as Go } from "../../../ToolbarLayout.module-37619c4b.js";
4
- import "../../../utils/hooks/useInfiniteScroll.js";
5
- import "../../../utils/withRef.js";
6
- import "../../icons/ChevronUpIcon.js";
7
- import "../../ui/Button.js";
1
+ import { jsx as s } from "react/jsx-runtime";
2
+ import { useRef as b, useImperativeHandle as _, useMemo as N, useCallback as x, useEffect as R } from "react";
3
+ import { Thumbnail as q } from "./Thumbnail.js";
4
+ import { useThumbnailContext as y } from "../../../contexts/ThumbnailsContext.js";
5
+ import { useInfiniteScroll as C } from "../../../utils/hooks/useInfiniteScroll.js";
6
+ import { u as I } from "../../../PaginationContext-9217cab4.js";
7
+ import { withRef as S } from "../../../utils/withRef.js";
8
8
  import "../../../clsx-0c6e471a.js";
9
- import "../../ui/Input.js";
10
- import "../../../utils/types.js";
11
- import "../../../th_TH-d627cd51.js";
12
- import "../../../contexts/ScrollModeContext.js";
13
- import "../../../utils/appConsole.js";
14
- import "../../../contexts/InitialStateContext.js";
9
+ import "../../icons/LoaderIcon.js";
10
+ import "../../../contexts/PagesRotateContext.js";
15
11
  import "../../../contexts/RPDocumentContext.js";
16
12
  import "../../../utils/hooks/useLoadPdf.js";
17
13
  import "pdfjs-dist";
14
+ import "../../../utils/types.js";
15
+ import "../../../th_TH-d627cd51.js";
18
16
  import "../../../utils/getThumbnailViewport.js";
19
17
  import "../../../contexts/ConfigContext.js";
20
18
  import "../../../contexts/DocumentPasswordContext.js";
19
+ import "../../../utils/appConsole.js";
21
20
  import "../../../utils/hooks/usePdfProperties.js";
22
21
  import "../../../utils/convertPdfDate.js";
23
22
  import "../../../utils/formatFileSize.js";
24
- import "../../../contexts/DarkModeContext.js";
25
- import "../../../utils/hooks/useDarkMode.js";
26
23
  import "../../../contexts/RotationContext.js";
27
- import "../../../contexts/LayerContext.js";
24
+ import "../../../contexts/InitialStateContext.js";
25
+ import "../../../contexts/EventCallbackContext.js";
26
+ import "../../../contexts/RenderQueueProvider.js";
27
+ import "../../../utils/Queue.js";
28
+ import "../../../utils/renderPage.js";
29
+ import "../../../contexts/ScrollModeContext.js";
30
+ import "../../../contexts/GlobalCurrentPage.js";
31
+ import "../../../contexts/ViewModeContext.js";
32
+ import "../../../contexts/VirtualScrollContext.js";
33
+ import "../../../contexts/VirtualGridContext.js";
34
+ import "../../../utils/smoothScrollTo.js";
35
+ import "../../../contexts/DimensionPagesContext.js";
28
36
  import "../../../contexts/ZoomContext.js";
29
37
  import "../../../utils/constants.js";
30
38
  import "../../../utils/getZoomLevel.js";
31
39
  import "../../../contexts/LayoutContainerContext.js";
32
- import "../../../contexts/ViewModeContext.js";
33
- import "../../../contexts/GlobalCurrentPage.js";
34
- import "../../../contexts/EventCallbackContext.js";
35
40
  import "../../../utils/hooks/useDebounce.js";
36
- import "../../../contexts/VirtualScrollContext.js";
37
- import "../../../contexts/VirtualGridContext.js";
38
- import "../../../contexts/SelectionModeContext.js";
39
- import "../../../contexts/FullScreenContext.js";
40
- import "../../../utils/hooks/useFullScreen.js";
41
- import "../../../contexts/FileInputContext.js";
42
- import "../../../contexts/DropFileZoneContext.js";
43
- import "../../../contexts/ToolbarComponentContext.js";
44
- import "../../../contexts/ToolComponentContext.js";
45
- import "../../../utils/highlight.js";
46
- import "../../../utils/charators.js";
47
- import "../../../contexts/DimensionPagesContext.js";
48
- import "../../../contexts/PagesRotateContext.js";
49
- import "../../../contexts/LocalizationContext.js";
50
- import "../../../utils/hooks/useLocalization.js";
51
- import "../../../contexts/HighlightContext.js";
52
- import "../../../utils/hooks/useHighlight.js";
53
- import "../../../contexts/LicenseContext.js";
54
- import "../../../utils/hooks/useLicense.js";
55
- import "../../../contexts/DownloadContext.js";
56
41
  import "../../../contexts/SmoothScrollContext.js";
57
- import "../../../contexts/ElementPageContext.js";
58
- import "../../../utils/const.js";
59
42
  import "../../../utils/getScrollDistance.js";
60
- import "../../../utils/getElementPositionInPage.js";
61
- import "../../../utils/Queue.js";
62
- import "../../../utils/renderPage.js";
63
- import "../../../contexts/LoaderContext.js";
64
- import "../../icons/LoaderIcon.js";
65
- import "../../../contexts/IconToolContext.js";
66
- import "../../../contexts/OtherToolContext.js";
67
- import "../../RPConfig.js";
68
- import "../../RPTheme.js";
69
- import "../../../contexts/ThemeContext.js";
70
- import "../../../utils/hooks/useLoadWorker.js";
71
- import "../../icons/Thumbnail.js";
72
- import "../Container.js";
73
- import "../../../contexts/ViewportContext.js";
74
- import "./RPSplitter.js";
75
- import "../WrapperLayout.js";
76
- import "../../../LayoutWrapper-6224491f.js";
77
- import "../../RPDropFileZone.js";
78
- import "../../icons/LightPdfIcon.js";
79
- import "../../icons/DarkPdfIcon.js";
80
- import "../../../SearchCloseButton-08d57275.js";
81
- import "../../ui/RPTooltip.js";
82
- import "../../../index-c9a2990a.js";
83
- import "react-dom";
84
- import "../../../index-808ea7bf.js";
85
- import "../../icons/CloseIcon.js";
86
- import "../../ui/Checkbox.js";
87
- import "../../icons/CheckIcon.js";
88
- import "../../../contexts/IconContext.js";
89
- import "../../ui/DropDown.js";
90
- import "../../../index-a48ec088.js";
91
- import "../toolbar/MenuItem.js";
92
- import "../toolbar/MenuSeparator.js";
93
- import "../../../utils/dateFormatter.js";
94
- import "../toolbar/PropertyItem.js";
95
- import "../../../RotateTool.module-67946714.js";
96
- import "../../../utils/link_service.js";
97
- import "../../../utils/annotations.js";
98
- import "../../../utils/sanitizeExternalUrl.js";
99
- import "../../page/searchHighlight.js";
100
- import "../../page/CustomElement.js";
101
43
  import "../../../utils/calculatePage.js";
102
- import "../../../utils/hooks/useMousePressed.js";
103
- import "../../../utils/hooks/useGrabScroll.js";
104
- import "../../../utils/hooks/usePinch.js";
105
- import "../../ui/PasswordModal.js";
106
- import "../../../utils/approximateFragtion.js";
107
- import "../../../utils/getWordPositionInPage.js";
108
- import "../../../utils/smoothScrollTo.js";
109
- import "../toolbar/FileUploadTool.js";
110
- import "../../icons/FileUploadDefaultIcon.js";
111
- import "../toolbar/DarkModeTool.js";
112
- import "../../icons/MoonIcon.js";
113
- import "../../icons/SunIcon.js";
114
- import "../../icons/ThreeDotIcon.js";
115
- import "../toolbar/DocumentProperties.js";
116
- import "../../icons/InfoIcon.js";
117
- import "../toolbar/RotateTool.js";
118
- import "../../icons/ClockwiseIcon.js";
119
- import "../../../utils/hooks/useRotate.js";
120
- import "../toolbar/ViewModeTool.js";
121
- import "../../icons/SinglePageIcon.js";
122
- import "../../icons/DualPageIcon.js";
123
- import "../toolbar/ScrollModeTool.js";
124
- import "../../icons/PageScrollingIcon.js";
125
- import "../../icons/VerticalScrollingIcon.js";
126
- import "../../icons/HorizontalScrollingIcon.js";
127
- import "../../icons/FileDownloadDefaultIcon.js";
128
- import "../../icons/PrintDefaultIcon.js";
129
- import "../toolbar/FullScreenTool.js";
130
- import "../../icons/FullScreenIcon.js";
131
- import "../../icons/GoToDownIcon.js";
132
- import "../toolbar/SelectionModeTool.js";
133
- import "../../icons/TextSelectionDefaultIcon.js";
134
- import "../../icons/HandModeDefaultIcon.js";
135
- import "../../icons/ZoomInIcon.js";
136
- import "../../icons/ZoomOutIcon.js";
137
- import "../../../utils/zoom.js";
138
- import "../../icons/SearchIcon.js";
139
- import "../../icons/ClearIcon.js";
44
+ import "../../../utils/hooks/useThumbnail.js";
45
+ const d = {
46
+ "rp-thumbnails-container": "_rp-thumbnails-container_16vqr_1",
47
+ "rp-thumbnails": "_rp-thumbnails_16vqr_1"
48
+ }, j = 16, D = (r, n) => {
49
+ const t = r == null ? void 0 : r.querySelector(`#page-${n}`);
50
+ r && (t != null && t.offsetTop) && (r.scrollTop = (t == null ? void 0 : t.offsetTop) - j);
51
+ }, Nt = S((r, n) => {
52
+ const { show: t, width: T } = r, { focusedPage: i, totalPages: a } = I(), { thumbnailPages: e, addPage: u, thumbnailLength: m, addToPage: c } = y(), p = b(null), l = b(1);
53
+ _(n, () => p.current);
54
+ const f = N(() => Object.values(e), [e]), P = x(() => {
55
+ const o = m + 1;
56
+ o <= a && u(o);
57
+ }, [u, a, m]);
58
+ return R(() => {
59
+ i > m && a > m ? c(i) : t && l.current !== i && (D(p.current, i), l.current = i);
60
+ }, [i, m, c, t, f]), C(p.current, P), /* @__PURE__ */ s("div", { ref: p, className: d["rp-thumbnails-container"], style: { width: T }, children: /* @__PURE__ */ s("div", { className: d["rp-thumbnails"], children: t ? f.map((o, v) => {
61
+ var g, h;
62
+ return /* @__PURE__ */ s(
63
+ q,
64
+ {
65
+ isFocused: i === ((g = o.page) == null ? void 0 : g.pageNumber),
66
+ pageNumber: (h = o.page) == null ? void 0 : h.pageNumber,
67
+ loading: o.loading,
68
+ viewport: o.viewport,
69
+ defaultRotation: o.defaultRotation
70
+ },
71
+ v
72
+ );
73
+ }) : null }) });
74
+ });
140
75
  export {
141
- Go as Thumbnails
76
+ Nt as Thumbnails
142
77
  };
@@ -14,9 +14,11 @@ import "../../../clsx-0c6e471a.js";
14
14
  import "../../../utils/withRef.js";
15
15
  import "../../../utils/hooks/useDarkMode.js";
16
16
  import "../../../utils/appConsole.js";
17
- import "../../../index-c9a2990a.js";
17
+ import "../../../index-c0faa594.js";
18
18
  import "react-dom";
19
- import "../../../index-808ea7bf.js";
19
+ import "../../../index-e3ee9457.js";
20
+ import "../../../floating-ui.react-dom-5ec29bd6.js";
21
+ import "../../../index-655864a7.js";
20
22
  import "../../../utils/hooks/useLocalization.js";
21
23
  import "../../../th_TH-d627cd51.js";
22
24
  const M = () => {
@@ -25,12 +27,12 @@ const M = () => {
25
27
  }, x = () => {
26
28
  const { darkModeIcon: t } = p(), { darkModeIcon: r } = l();
27
29
  return t || r || /* @__PURE__ */ o(a, {});
28
- }, J = () => {
30
+ }, N = () => {
29
31
  const { darkMode: t, setDarkMode: r } = I(), { themeSwitcher: i = !0 } = k(), { themeSwitcher: m = !0 } = T(), { localeMessages: n } = C(), e = t ? n == null ? void 0 : n.themeEnableLightTooltip : n == null ? void 0 : n.themeEnableDarkTooltip, d = u(() => {
30
32
  r((h) => !h);
31
33
  }, [r]);
32
34
  return !i || !m ? null : typeof i == "function" ? /* @__PURE__ */ o(c, { content: e, children: /* @__PURE__ */ o(i, { darkMode: t, setDarkMode: r }) }) : typeof m == "function" ? /* @__PURE__ */ o(c, { content: e, children: /* @__PURE__ */ o(m, { darkMode: t, setDarkMode: r }) }) : /* @__PURE__ */ o(c, { content: e, children: /* @__PURE__ */ o(s, { onClick: d, "aria-label": e, children: t ? /* @__PURE__ */ o(x, {}) : /* @__PURE__ */ o(M, {}) }) });
33
35
  };
34
36
  export {
35
- J as DarkModeTool
37
+ N as DarkModeTool
36
38
  };