@react-pdf-kit/viewer 2.0.0-beta.0 → 2.0.0-beta.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 (184) hide show
  1. package/README.md +6 -6
  2. package/dist/{LayoutWrapper-a871c161.js → LayoutWrapper-6224491f.js} +1 -1
  3. package/dist/{RotateTool.module-03987eba.js → RotateTool.module-67946714.js} +1 -1
  4. package/dist/{SearchCloseButton-cbf182aa.js → SearchCloseButton-08d57275.js} +1 -1
  5. package/dist/ToolbarLayout.module-37619c4b.js +3548 -0
  6. package/dist/assets/style.css +1 -0
  7. package/dist/assets/style.js +74 -0
  8. package/dist/components/RPConfig.js +127 -127
  9. package/dist/components/RPController.js +178 -64
  10. package/dist/components/RPDropFileZone.js +26 -12
  11. package/dist/components/RPPages.js +82 -6
  12. package/dist/components/RPProvider.js +169 -19
  13. package/dist/components/RPTheme.js +6 -5
  14. package/dist/components/icons/LoaderIcon.js +1 -1
  15. package/dist/components/layout/Container.js +1 -1
  16. package/dist/components/layout/LayoutContainer.js +88 -6
  17. package/dist/components/layout/LayoutWrapper.js +2 -1
  18. package/dist/components/layout/RPDefaultLayout.js +129 -3
  19. package/dist/components/layout/RPLayout.js +97 -7
  20. package/dist/components/layout/WrapperLayout.js +22 -9
  21. package/dist/components/layout/sidebar/RPSidebar.js +129 -2
  22. package/dist/components/layout/sidebar/RPSplitter.js +1 -1
  23. package/dist/components/layout/sidebar/Thumbnail.js +89 -6
  24. package/dist/components/layout/sidebar/Thumbnails.js +136 -2
  25. package/dist/components/layout/toolbar/DarkModeTool.js +22 -13
  26. package/dist/components/layout/toolbar/DocumentDialog.js +89 -6
  27. package/dist/components/layout/toolbar/DocumentProperties.js +18 -8
  28. package/dist/components/layout/toolbar/FileDownloadTool.js +129 -2
  29. package/dist/components/layout/toolbar/FileUploadTool.js +31 -10
  30. package/dist/components/layout/toolbar/FullScreenTool.js +39 -27
  31. package/dist/components/layout/toolbar/MenuItem.js +12 -8
  32. package/dist/components/layout/toolbar/MenuSeparator.js +8 -4
  33. package/dist/components/layout/toolbar/MostPageTool.js +89 -7
  34. package/dist/components/layout/toolbar/OtherTool.js +121 -3
  35. package/dist/components/layout/toolbar/Paginate.js +125 -2
  36. package/dist/components/layout/toolbar/PrintTool.js +129 -2
  37. package/dist/components/layout/toolbar/PropertyItem.js +1 -1
  38. package/dist/components/layout/toolbar/RPMenuItem.js +20 -13
  39. package/dist/components/layout/toolbar/RPMoreOptions.js +171 -44
  40. package/dist/components/layout/toolbar/RPToolbar.js +135 -3
  41. package/dist/components/layout/toolbar/RPToolbarEnd.js +135 -2
  42. package/dist/components/layout/toolbar/RotateTool.js +39 -18
  43. package/dist/components/layout/toolbar/ScrollModeTool.js +27 -18
  44. package/dist/components/layout/toolbar/SearchCloseButton.js +11 -2
  45. package/dist/components/layout/toolbar/SearchResultNavigator.js +135 -3
  46. package/dist/components/layout/toolbar/SearchTool.js +87 -6
  47. package/dist/components/layout/toolbar/SelectionModeTool.js +19 -10
  48. package/dist/components/layout/toolbar/ThumbnailTool.js +141 -10
  49. package/dist/components/layout/toolbar/ToolbarCustom.js +90 -7
  50. package/dist/components/layout/toolbar/ToolbarDefault.js +91 -7
  51. package/dist/components/layout/toolbar/ToolbarLayout.js +147 -6
  52. package/dist/components/layout/toolbar/ViewModeTool.js +26 -17
  53. package/dist/components/layout/toolbar/ZoomTool.js +140 -128
  54. package/dist/components/layout/toolbar/tools/DocumentPropertiesTool.js +139 -7
  55. package/dist/components/layout/toolbar/tools/FileDownloadTool.js +142 -9
  56. package/dist/components/layout/toolbar/tools/FileUploadTool.js +27 -8
  57. package/dist/components/layout/toolbar/tools/FullScreenTool.js +23 -13
  58. package/dist/components/layout/toolbar/tools/InputPageTool.js +159 -26
  59. package/dist/components/layout/toolbar/tools/NextPageTool.js +89 -7
  60. package/dist/components/layout/toolbar/tools/PreviousPageTool.js +144 -11
  61. package/dist/components/layout/toolbar/tools/PrintTool.js +140 -7
  62. package/dist/components/layout/toolbar/tools/RotateClockwiseTool.js +29 -8
  63. package/dist/components/layout/toolbar/tools/RotateCounterclockwiseTool.js +32 -11
  64. package/dist/components/layout/toolbar/tools/ThemeSwitcherTool.js +15 -6
  65. package/dist/components/layout/toolbar/tools/ThumbnailTool.js +144 -11
  66. package/dist/components/layout/toolbar/tools/ZoomInTool.js +47 -20
  67. package/dist/components/layout/toolbar/tools/ZoomLevelDisplay.js +142 -0
  68. package/dist/components/layout/toolbar/tools/ZoomLevelTool.js +160 -29
  69. package/dist/components/layout/toolbar/tools/ZoomOutTool.js +45 -18
  70. package/dist/components/layout/toolbar/tools/defaults/RPHorizontalBar.js +100 -13
  71. package/dist/components/layout/toolbar/tools/defaults/RPVerticalBar.js +146 -11
  72. package/dist/components/layout/toolbar/tools/more-options/DocumentProperties.js +15 -5
  73. package/dist/components/layout/toolbar/tools/more-options/FileDownloadTool.js +143 -11
  74. package/dist/components/layout/toolbar/tools/more-options/FileUploadTool.js +90 -7
  75. package/dist/components/layout/toolbar/tools/more-options/FullScreenTool.js +21 -9
  76. package/dist/components/layout/toolbar/tools/more-options/MostPageTool.js +90 -8
  77. package/dist/components/layout/toolbar/tools/more-options/PrintTool.js +139 -7
  78. package/dist/components/layout/toolbar/tools/more-options/RotateTool.js +33 -12
  79. package/dist/components/layout/toolbar/tools/more-options/ScrollModeTool.js +23 -14
  80. package/dist/components/layout/toolbar/tools/more-options/SelectionModeTool.js +22 -13
  81. package/dist/components/layout/toolbar/tools/more-options/ViewModeTool.js +25 -16
  82. package/dist/components/page/AnnotationLayer.js +86 -6
  83. package/dist/components/page/CanvasLayer.js +90 -6
  84. package/dist/components/page/CustomElement.js +49 -18
  85. package/dist/components/page/DualPage.js +138 -2
  86. package/dist/components/page/RPPage.js +88 -6
  87. package/dist/components/page/SinglePage.js +138 -2
  88. package/dist/components/page/TextHighlightLayer.js +88 -6
  89. package/dist/components/page/TextLayer.js +88 -6
  90. package/dist/components/ui/Button.js +9 -8
  91. package/dist/components/ui/Checkbox.js +6 -5
  92. package/dist/components/ui/DropDown.js +18 -14
  93. package/dist/components/ui/Input.js +10 -9
  94. package/dist/components/ui/LoadingIndicator.js +137 -2
  95. package/dist/components/ui/PasswordModal.js +18 -15
  96. package/dist/components/ui/RPTooltip.js +202 -415
  97. package/dist/contexts/DimensionPagesContext.js +35 -17
  98. package/dist/contexts/DropFileZoneContext.js +32 -22
  99. package/dist/contexts/ElementPageContext.js +114 -51
  100. package/dist/contexts/EventCallbackContext.js +30 -0
  101. package/dist/contexts/FileInputContext.js +32 -22
  102. package/dist/contexts/GlobalCurrentPage.js +13 -10
  103. package/dist/contexts/HighlightContext.js +24 -11
  104. package/dist/contexts/LicenseContext.js +1 -0
  105. package/dist/contexts/LoaderContext.js +10 -9
  106. package/dist/contexts/LocalizationContext.js +11 -10
  107. package/dist/contexts/PagesRotateContext.js +36 -18
  108. package/dist/contexts/PaginationContext.js +137 -4
  109. package/dist/contexts/PrintContext.js +140 -4
  110. package/dist/contexts/RPDocumentContext.js +38 -28
  111. package/dist/contexts/RenderQueueProvider.js +138 -4
  112. package/dist/contexts/RotationContext.js +25 -15
  113. package/dist/contexts/ScrollModeContext.js +7 -6
  114. package/dist/contexts/SearchContext.js +140 -4
  115. package/dist/contexts/SelectionModeContext.js +5 -4
  116. package/dist/contexts/ThumbnailsContext.js +140 -4
  117. package/dist/contexts/ViewModeContext.js +10 -9
  118. package/dist/contexts/ZoomContext.js +34 -24
  119. package/dist/index-808ea7bf.js +1685 -0
  120. package/dist/index-a48ec088.js +1672 -0
  121. package/dist/{index-35c7f4a2.js → index-c9a2990a.js} +3 -3
  122. package/dist/libInjectCss.js +9 -0
  123. package/dist/main.js +218 -84
  124. package/dist/types/assets/style.d.ts +1 -0
  125. package/dist/types/components/layout/toolbar/tools/ZoomLevelDisplay.d.ts +7 -0
  126. package/dist/types/contexts/EventCallbackContext.d.ts +5 -0
  127. package/dist/types/libInjectCss.d.ts +1 -0
  128. package/dist/types/main.d.ts +1 -1
  129. package/dist/types/utils/annotations.d.ts +1 -2
  130. package/dist/types/utils/approximateFragtion.d.ts +9 -0
  131. package/dist/types/utils/getElementPositionInPage.d.ts +5 -0
  132. package/dist/types/utils/injectPrintCSS.d.ts +1 -0
  133. package/dist/types/utils/link_service.d.ts +11 -1
  134. package/dist/types/utils/types.d.ts +11 -1
  135. package/dist/types/utils/zoom.d.ts +2 -0
  136. package/dist/utils/annotations.js +48 -58
  137. package/dist/utils/approximateFragtion.js +22 -0
  138. package/dist/utils/getElementPositionInPage.js +84 -0
  139. package/dist/utils/getZoomLevel.js +9 -8
  140. package/dist/utils/hooks/useDarkModeProps.js +3 -2
  141. package/dist/utils/hooks/useFileDownload.js +90 -6
  142. package/dist/utils/hooks/useHighlight.js +13 -12
  143. package/dist/utils/hooks/useLicense.js +1 -1
  144. package/dist/utils/hooks/useLoadPdf.js +46 -41
  145. package/dist/utils/hooks/useLoadWorker.js +8 -8
  146. package/dist/utils/hooks/usePageRotateContext.js +33 -17
  147. package/dist/utils/hooks/usePaginate.js +88 -6
  148. package/dist/utils/hooks/usePinch.js +62 -41
  149. package/dist/utils/hooks/usePresentPage.js +88 -6
  150. package/dist/utils/hooks/usePrint.js +89 -6
  151. package/dist/utils/hooks/useRotate.js +21 -7
  152. package/dist/utils/hooks/useScrollToPage.js +86 -6
  153. package/dist/utils/hooks/useSearch.js +86 -6
  154. package/dist/utils/hooks/useThumbnail.js +89 -6
  155. package/dist/utils/hooks/useVirtualReactWindow.js +88 -6
  156. package/dist/utils/hooks/useWatermark.js +18 -15
  157. package/dist/utils/injectPrintCSS.js +22 -0
  158. package/dist/utils/link_service.js +49 -9
  159. package/dist/utils/renderPage.js +1 -0
  160. package/dist/utils/zoom.js +6 -0
  161. package/package.json +18 -23
  162. package/dist/ToolbarLayout.module-c588d36b.js +0 -3411
  163. package/dist/ZoomTool.module-6c5eabbb.js +0 -12
  164. package/dist/assets/Button.css +0 -1
  165. package/dist/assets/Checkbox.css +0 -1
  166. package/dist/assets/Container.css +0 -1
  167. package/dist/assets/DropDown.css +0 -1
  168. package/dist/assets/Input.css +0 -1
  169. package/dist/assets/LayoutWrapper.css +0 -1
  170. package/dist/assets/LoaderIcon.css +0 -1
  171. package/dist/assets/MenuItem.css +0 -1
  172. package/dist/assets/MenuSeparator.css +0 -1
  173. package/dist/assets/PasswordModal.css +0 -1
  174. package/dist/assets/PropertyItem.css +0 -1
  175. package/dist/assets/RPDropFileZone.css +0 -1
  176. package/dist/assets/RPSplitter.css +0 -1
  177. package/dist/assets/RPTooltip.css +0 -1
  178. package/dist/assets/RotateTool.css +0 -1
  179. package/dist/assets/SearchCloseButton.css +0 -1
  180. package/dist/assets/ToolbarLayout.css +0 -1
  181. package/dist/assets/WrapperLayout.css +0 -1
  182. package/dist/assets/ZoomTool.css +0 -1
  183. package/dist/floating-ui.react-dom-6b2fe0df.js +0 -1474
  184. package/dist/index-f563c6f0.js +0 -1889
@@ -1,34 +1,39 @@
1
- import { useState as a, useRef as N, useEffect as k } from "react";
2
- import * as x from "pdfjs-dist";
3
- import { ErrorType as O } from "../types.js";
4
- import { getThumbnailViewport as U } from "../getThumbnailViewport.js";
5
- import { useConfigContext as h } from "../../contexts/ConfigContext.js";
6
- import { useDocumentPasswordContext as j } from "../../contexts/DocumentPasswordContext.js";
7
- const G = (f, s, V = {}) => {
8
- const [n, C] = a(), { workerUrlAdded: y } = h(), [I, L] = a(/* @__PURE__ */ new Map()), d = N(), [S, m] = a(0), [P, T] = a(!1), [q, v] = a(), { password: u, passwordError: D, setPasswordError: c, passwordRequired: g, setPasswordRequired: p } = j(), { onLoadError: i, onLoaded: w } = V;
9
- return k(() => {
10
- if (!y || !f)
1
+ import { useState as a, useRef as O, useEffect as T } from "react";
2
+ import * as C from "pdfjs-dist";
3
+ import { ErrorType as U } from "../types.js";
4
+ import { getThumbnailViewport as h } from "../getThumbnailViewport.js";
5
+ import { useConfigContext as j } from "../../contexts/ConfigContext.js";
6
+ import { useDocumentPasswordContext as A } from "../../contexts/DocumentPasswordContext.js";
7
+ import "../../th_TH-d627cd51.js";
8
+ import "react/jsx-runtime";
9
+ import "../appConsole.js";
10
+ const Q = (l, s, I = {}) => {
11
+ const [n, S] = a(), { workerUrlAdded: k } = j(), [q, x] = a(/* @__PURE__ */ new Map()), d = O(), [m, P] = a(0), [g, V] = a(!1), [v, D] = a(), { password: u, passwordError: N, setPasswordError: c, passwordRequired: p, setPasswordRequired: w } = A(), { onLoadError: i, onLoaded: E, onLoadProgress: R } = I;
12
+ return T(() => {
13
+ R && R(m);
14
+ }, [m, R]), T(() => {
15
+ if (!k || !l)
11
16
  return;
12
- m(0), d.current = Date.now();
13
- const r = d.current, E = {
14
- url: f,
17
+ P(0), d.current = Date.now();
18
+ const r = d.current, b = {
19
+ url: l,
15
20
  cMapPacked: (s == null ? void 0 : s.isCompressed) ?? !0,
16
21
  ...(s == null ? void 0 : s.url) && { cMapUrl: s.url },
17
22
  ...u && { password: u },
18
- verbosity: x.VerbosityLevel.ERRORS
23
+ verbosity: C.VerbosityLevel.ERRORS
19
24
  };
20
25
  try {
21
- const e = x.getDocument(E);
26
+ const e = C.getDocument(b);
22
27
  e.onProgress = (o) => {
23
28
  if (r === d.current) {
24
- const { loaded: R, total: l } = o, b = l ? Math.min(100, Math.round(R / l * 100)) : 0;
25
- m(b);
29
+ const { loaded: y, total: f } = o, L = f ? Math.min(100, Math.round(y / f * 100)) : 0;
30
+ P(L);
26
31
  }
27
- }, T(!0);
28
- const t = e.promise.then((o) => (r === d.current && (C(o), m(100)), w && w(o), p(!1), c(""), o)).catch((o) => {
29
- o instanceof Error && o.name === "PasswordException" ? (p(!0), c(o.message || "Password required")) : o instanceof Error && o.name === "InvalidPDFException" && u ? (p(!0), c("Incorrect password")) : i && i(o);
32
+ }, V(!0);
33
+ const t = e.promise.then((o) => (r === d.current && (S(o), P(100)), E && E(o), w(!1), c(""), o)).catch((o) => {
34
+ o instanceof Error && o.name === "PasswordException" ? (w(!0), c(o.message || "Password required")) : o instanceof Error && o.name === "InvalidPDFException" && u ? (w(!0), c("Incorrect password")) : i && i(o);
30
35
  }).finally(() => {
31
- T(!1);
36
+ V(!1);
32
37
  });
33
38
  return () => {
34
39
  t.finally(() => {
@@ -36,42 +41,42 @@ const G = (f, s, V = {}) => {
36
41
  });
37
42
  };
38
43
  } catch (e) {
39
- v(O.NOT_SUPPORTED), i && i(e);
44
+ D(U.NOT_SUPPORTED), i && i(e);
40
45
  }
41
- }, [f, y, u, i, w]), k(() => {
42
- if (g)
46
+ }, [l, k, u, i, E]), T(() => {
47
+ if (p)
43
48
  return;
44
49
  const r = /* @__PURE__ */ new Map();
45
- if (!n || P) {
46
- L(r);
50
+ if (!n || g) {
51
+ x(r);
47
52
  return;
48
53
  }
49
- const E = n.numPages, e = [];
50
- for (let t = 1; t <= E; t++) {
54
+ const b = n.numPages, e = [];
55
+ for (let t = 1; t <= b; t++) {
51
56
  const o = n.getPage(t);
52
57
  e.push(o);
53
58
  }
54
59
  Promise.all(e).then((t) => {
55
60
  t.map((o) => {
56
- const { thumbnailViewport: R, scale: l } = U(o), b = o.getViewport();
61
+ const { thumbnailViewport: y, scale: f } = h(o), L = o.getViewport();
57
62
  r.set(o.pageNumber, {
58
63
  page: o,
59
- thumbnailViewport: R,
60
- thumbnailScale: l,
61
- defaultRotation: b.rotation
64
+ thumbnailViewport: y,
65
+ thumbnailScale: f,
66
+ defaultRotation: L.rotation
62
67
  });
63
- }), L(r);
68
+ }), x(r);
64
69
  });
65
- }, [n, P, g]), {
70
+ }, [n, g, p]), {
66
71
  pdf: n,
67
- pages: I,
68
- loading: P,
69
- error: q,
70
- loadingProgress: S,
71
- passwordRequired: g,
72
- passwordError: D
72
+ pages: q,
73
+ loading: g,
74
+ error: v,
75
+ loadingProgress: m,
76
+ passwordRequired: p,
77
+ passwordError: N
73
78
  };
74
79
  };
75
80
  export {
76
- G as useLoadPdf
81
+ Q as useLoadPdf
77
82
  };