@react-pdf-kit/viewer 2.0.0-beta.0 → 2.0.0-beta.10

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 (212) hide show
  1. package/dist/Combination-54a77a7a.js +701 -0
  2. package/dist/MostPageTool.module-13578ad6.js +6 -0
  3. package/dist/OtherTool.module-a4be5f1f.js +6 -0
  4. package/dist/Paginate.module-206a7d7d.js +8 -0
  5. package/dist/PaginationContext-9217cab4.js +201 -0
  6. package/dist/{LayoutWrapper-a871c161.js → RPLayout.module-967bf4bc.js} +3 -9
  7. package/dist/RPToolbar.module-27d7fe77.js +10 -0
  8. package/dist/{RotateTool.module-03987eba.js → RotateTool.module-67946714.js} +1 -1
  9. package/dist/SearchTool.module-99f60dc7.js +16 -0
  10. package/dist/ToolbarLayout.module-1fee0a18.js +11 -0
  11. package/dist/{ZoomTool.module-6c5eabbb.js → ZoomTool.module-7082af8c.js} +1 -1
  12. package/dist/assets/style.css +1 -0
  13. package/dist/assets/style.js +75 -0
  14. package/dist/components/RPConfig.js +14 -1489
  15. package/dist/components/RPController.js +109 -66
  16. package/dist/components/RPDropFileZone.js +26 -12
  17. package/dist/components/RPPages.js +991 -58
  18. package/dist/components/RPProvider.js +107 -19
  19. package/dist/components/RPTheme.js +6 -5
  20. package/dist/components/icons/DualPageIcon.js +6 -6
  21. package/dist/components/icons/LoaderIcon.js +1 -1
  22. package/dist/components/icons/SinglePageIcon.js +6 -6
  23. package/dist/components/layout/Container.js +1 -1
  24. package/dist/components/layout/LayoutContainer.js +32 -57
  25. package/dist/components/layout/LayoutWrapper.js +9 -4
  26. package/dist/components/layout/RPDefaultLayout.js +214 -14
  27. package/dist/components/layout/RPLayout.js +143 -41
  28. package/dist/components/layout/WrapperLayout.js +22 -9
  29. package/dist/components/layout/sidebar/RPSidebar.js +110 -13
  30. package/dist/components/layout/sidebar/RPSplitter.js +1 -1
  31. package/dist/components/layout/sidebar/Thumbnail.js +129 -52
  32. package/dist/components/layout/sidebar/Thumbnails.js +75 -6
  33. package/dist/components/layout/toolbar/DarkModeTool.js +24 -13
  34. package/dist/components/layout/toolbar/DocumentDialog.js +311 -56
  35. package/dist/components/layout/toolbar/DocumentProperties.js +21 -8
  36. package/dist/components/layout/toolbar/FileDownloadTool.js +48 -13
  37. package/dist/components/layout/toolbar/FileUploadTool.js +34 -10
  38. package/dist/components/layout/toolbar/FullScreenTool.js +43 -28
  39. package/dist/components/layout/toolbar/MenuItem.js +15 -8
  40. package/dist/components/layout/toolbar/MenuSeparator.js +11 -4
  41. package/dist/components/layout/toolbar/MostPageTool.js +72 -51
  42. package/dist/components/layout/toolbar/OtherTool.js +188 -22
  43. package/dist/components/layout/toolbar/Paginate.js +136 -17
  44. package/dist/components/layout/toolbar/PrintTool.js +70 -13
  45. package/dist/components/layout/toolbar/PropertyItem.js +1 -1
  46. package/dist/components/layout/toolbar/RPMenuItem.js +23 -13
  47. package/dist/components/layout/toolbar/RPMoreOptions.js +119 -47
  48. package/dist/components/layout/toolbar/RPToolbar.js +148 -8
  49. package/dist/components/layout/toolbar/RPToolbarEnd.js +118 -7
  50. package/dist/components/layout/toolbar/RotateTool.js +42 -18
  51. package/dist/components/layout/toolbar/ScrollModeTool.js +33 -21
  52. package/dist/components/layout/toolbar/SearchCloseButton.js +30 -7
  53. package/dist/components/layout/toolbar/SearchResultNavigator.js +87 -8
  54. package/dist/components/layout/toolbar/SearchTool.js +236 -54
  55. package/dist/components/layout/toolbar/SelectionModeTool.js +22 -10
  56. package/dist/components/layout/toolbar/ThumbnailTool.js +32 -10
  57. package/dist/components/layout/toolbar/ToolbarCustom.js +52 -55
  58. package/dist/components/layout/toolbar/ToolbarDefault.js +144 -58
  59. package/dist/components/layout/toolbar/ToolbarLayout.js +149 -6
  60. package/dist/components/layout/toolbar/ViewModeTool.js +31 -19
  61. package/dist/components/layout/toolbar/ZoomTool.js +104 -84
  62. package/dist/components/layout/toolbar/tools/DocumentPropertiesTool.js +38 -12
  63. package/dist/components/layout/toolbar/tools/DualPageTool.js +26 -0
  64. package/dist/components/layout/toolbar/tools/FileDownloadTool.js +31 -9
  65. package/dist/components/layout/toolbar/tools/FileUploadTool.js +29 -8
  66. package/dist/components/layout/toolbar/tools/FullScreenTool.js +25 -13
  67. package/dist/components/layout/toolbar/tools/InputPageTool.js +66 -26
  68. package/dist/components/layout/toolbar/tools/NextPageTool.js +36 -47
  69. package/dist/components/layout/toolbar/tools/PreviousPageTool.js +51 -11
  70. package/dist/components/layout/toolbar/tools/PrintTool.js +29 -7
  71. package/dist/components/layout/toolbar/tools/RotateClockwiseTool.js +31 -8
  72. package/dist/components/layout/toolbar/tools/RotateCounterclockwiseTool.js +34 -11
  73. package/dist/components/layout/toolbar/tools/SelectionModeSwitcherTool.js +31 -0
  74. package/dist/components/layout/toolbar/tools/SinglePageTool.js +26 -0
  75. package/dist/components/layout/toolbar/tools/ThemeSwitcherTool.js +17 -6
  76. package/dist/components/layout/toolbar/tools/ThumbnailTool.js +35 -13
  77. package/dist/components/layout/toolbar/tools/ZoomInTool.js +49 -20
  78. package/dist/components/layout/toolbar/tools/ZoomLevelDisplay.js +27 -0
  79. package/dist/components/layout/toolbar/tools/ZoomLevelTool.js +57 -23
  80. package/dist/components/layout/toolbar/tools/ZoomOutTool.js +47 -18
  81. package/dist/components/layout/toolbar/tools/defaults/RPHorizontalBar.js +122 -45
  82. package/dist/components/layout/toolbar/tools/defaults/RPVerticalBar.js +37 -11
  83. package/dist/components/layout/toolbar/tools/more-options/DocumentProperties.js +18 -5
  84. package/dist/components/layout/toolbar/tools/more-options/FileDownloadTool.js +36 -11
  85. package/dist/components/layout/toolbar/tools/more-options/FileUploadTool.js +25 -50
  86. package/dist/components/layout/toolbar/tools/more-options/FullScreenTool.js +24 -9
  87. package/dist/components/layout/toolbar/tools/more-options/MostPageTool.js +47 -54
  88. package/dist/components/layout/toolbar/tools/more-options/PrintTool.js +32 -7
  89. package/dist/components/layout/toolbar/tools/more-options/RotateTool.js +36 -12
  90. package/dist/components/layout/toolbar/tools/more-options/ScrollModeTool.js +26 -14
  91. package/dist/components/layout/toolbar/tools/more-options/SelectionModeTool.js +27 -15
  92. package/dist/components/layout/toolbar/tools/more-options/ViewModeTool.js +30 -18
  93. package/dist/components/page/AnnotationLayer.js +130 -54
  94. package/dist/components/page/CanvasLayer.js +62 -49
  95. package/dist/components/page/CustomElement.js +49 -18
  96. package/dist/components/page/DualPage.js +97 -4
  97. package/dist/components/page/RPPage.js +134 -51
  98. package/dist/components/page/SinglePage.js +87 -4
  99. package/dist/components/page/TextHighlightLayer.js +195 -57
  100. package/dist/components/page/TextLayer.js +193 -52
  101. package/dist/components/ui/Button.js +9 -8
  102. package/dist/components/ui/Checkbox.js +27 -25
  103. package/dist/components/ui/DropDown.js +21 -14
  104. package/dist/components/ui/Input.js +10 -9
  105. package/dist/components/ui/LoadingIndicator.js +45 -5
  106. package/dist/components/ui/PasswordModal.js +18 -15
  107. package/dist/components/ui/RPTooltip.js +98 -95
  108. package/dist/contexts/DimensionPagesContext.js +35 -17
  109. package/dist/contexts/DropFileZoneContext.js +32 -22
  110. package/dist/contexts/ElementPageContext.js +114 -51
  111. package/dist/contexts/EventCallbackContext.js +30 -0
  112. package/dist/contexts/FileInputContext.js +32 -22
  113. package/dist/contexts/FullScreenContext.js +17 -10
  114. package/dist/contexts/GlobalCurrentPage.js +13 -10
  115. package/dist/contexts/HighlightContext.js +24 -11
  116. package/dist/contexts/LicenseContext.js +1 -0
  117. package/dist/contexts/LoaderContext.js +10 -9
  118. package/dist/contexts/LocalizationContext.js +25 -29
  119. package/dist/contexts/PagesRotateContext.js +36 -18
  120. package/dist/contexts/PaginationContext.js +32 -4
  121. package/dist/contexts/PrintContext.js +76 -6
  122. package/dist/contexts/RPDocumentContext.js +48 -30
  123. package/dist/contexts/RenderQueueProvider.js +70 -8
  124. package/dist/contexts/RotationContext.js +25 -15
  125. package/dist/contexts/ScrollModeContext.js +7 -6
  126. package/dist/contexts/SearchContext.js +94 -6
  127. package/dist/contexts/SelectionModeContext.js +5 -4
  128. package/dist/contexts/ThumbnailsContext.js +41 -6
  129. package/dist/contexts/ViewModeContext.js +10 -9
  130. package/dist/contexts/ZoomContext.js +48 -38
  131. package/dist/floating-ui.react-dom-5ec29bd6.js +1327 -0
  132. package/dist/index-4baea9b5.js +1198 -0
  133. package/dist/index-655864a7.js +27 -0
  134. package/dist/{index-35c7f4a2.js → index-c0faa594.js} +63 -86
  135. package/dist/index-e3ee9457.js +150 -0
  136. package/dist/libInjectCss.js +9 -0
  137. package/dist/main.js +269 -84
  138. package/dist/types/assets/style.d.ts +1 -0
  139. package/dist/types/components/icons/DualPageIcon.d.ts +1 -1
  140. package/dist/types/components/icons/SinglePageIcon.d.ts +1 -1
  141. package/dist/types/components/layout/toolbar/tools/DualPageTool.d.ts +3 -0
  142. package/dist/types/components/layout/toolbar/tools/SelectionModeSwitcherTool.d.ts +3 -0
  143. package/dist/types/components/layout/toolbar/tools/SinglePageTool.d.ts +3 -0
  144. package/dist/types/components/layout/toolbar/tools/ZoomLevelDisplay.d.ts +7 -0
  145. package/dist/types/contexts/EventCallbackContext.d.ts +5 -0
  146. package/dist/types/contexts/RenderQueueProvider.d.ts +2 -2
  147. package/dist/types/libInjectCss.d.ts +1 -0
  148. package/dist/types/main.d.ts +6 -6
  149. package/dist/types/utils/annotations.d.ts +3 -3
  150. package/dist/types/utils/approximateFragtion.d.ts +9 -0
  151. package/dist/types/utils/getElementPositionInPage.d.ts +5 -0
  152. package/dist/types/utils/hooks/useCopyText.d.ts +1 -0
  153. package/dist/types/utils/hooks/usePrint.d.ts +3 -2
  154. package/dist/types/utils/hooks/useSearch.d.ts +1 -2
  155. package/dist/types/utils/injectPrintCSS.d.ts +1 -0
  156. package/dist/types/utils/link_service.d.ts +11 -1
  157. package/dist/types/utils/renderPage.d.ts +2 -2
  158. package/dist/types/utils/types.d.ts +38 -5
  159. package/dist/types/utils/zoom.d.ts +2 -0
  160. package/dist/utils/annotations.js +125 -149
  161. package/dist/utils/approximateFragtion.js +22 -0
  162. package/dist/utils/getElementPositionInPage.js +84 -0
  163. package/dist/utils/getWordPositionInPage.js +5 -5
  164. package/dist/utils/getZoomLevel.js +9 -8
  165. package/dist/utils/highlight.js +72 -72
  166. package/dist/utils/hooks/useCopyText.js +36 -0
  167. package/dist/utils/hooks/useDarkModeProps.js +3 -2
  168. package/dist/utils/hooks/useFileDownload.js +29 -54
  169. package/dist/utils/hooks/useHighlight.js +34 -33
  170. package/dist/utils/hooks/useLicense.js +1 -1
  171. package/dist/utils/hooks/useLoadPdf.js +44 -36
  172. package/dist/utils/hooks/useLoadWorker.js +11 -8
  173. package/dist/utils/hooks/useLocalization.js +13 -13
  174. package/dist/utils/hooks/usePageRotateContext.js +33 -17
  175. package/dist/utils/hooks/usePaginate.js +26 -49
  176. package/dist/utils/hooks/usePinch.js +62 -41
  177. package/dist/utils/hooks/usePresentPage.js +80 -50
  178. package/dist/utils/hooks/usePrint.js +181 -55
  179. package/dist/utils/hooks/useRotate.js +21 -7
  180. package/dist/utils/hooks/useScrollToPage.js +26 -51
  181. package/dist/utils/hooks/useSearch.js +141 -55
  182. package/dist/utils/hooks/useThumbnail.js +55 -55
  183. package/dist/utils/hooks/useVirtualReactWindow.js +70 -52
  184. package/dist/utils/hooks/useWatermark.js +18 -15
  185. package/dist/utils/injectPrintCSS.js +22 -0
  186. package/dist/utils/link_service.js +49 -9
  187. package/dist/utils/renderPage.js +13 -10
  188. package/dist/utils/zoom.js +6 -0
  189. package/package.json +6 -8
  190. package/dist/SearchCloseButton-cbf182aa.js +0 -33
  191. package/dist/ToolbarLayout.module-c588d36b.js +0 -3411
  192. package/dist/assets/Button.css +0 -1
  193. package/dist/assets/Checkbox.css +0 -1
  194. package/dist/assets/Container.css +0 -1
  195. package/dist/assets/DropDown.css +0 -1
  196. package/dist/assets/Input.css +0 -1
  197. package/dist/assets/LayoutWrapper.css +0 -1
  198. package/dist/assets/LoaderIcon.css +0 -1
  199. package/dist/assets/MenuItem.css +0 -1
  200. package/dist/assets/MenuSeparator.css +0 -1
  201. package/dist/assets/PasswordModal.css +0 -1
  202. package/dist/assets/PropertyItem.css +0 -1
  203. package/dist/assets/RPDropFileZone.css +0 -1
  204. package/dist/assets/RPSplitter.css +0 -1
  205. package/dist/assets/RPTooltip.css +0 -1
  206. package/dist/assets/RotateTool.css +0 -1
  207. package/dist/assets/SearchCloseButton.css +0 -1
  208. package/dist/assets/ToolbarLayout.css +0 -1
  209. package/dist/assets/WrapperLayout.css +0 -1
  210. package/dist/assets/ZoomTool.css +0 -1
  211. package/dist/floating-ui.react-dom-6b2fe0df.js +0 -1474
  212. package/dist/index-f563c6f0.js +0 -1889
@@ -1,25 +1,25 @@
1
- import { useState as a, useMemo as m } from "react";
2
- import { e as s, t as p, z as u, i as _, p as L } from "../../th_TH-d627cd51.js";
3
- const f = (e) => {
1
+ import { useState as a, useCallback as z, useMemo as m } from "react";
2
+ import { e as s, t as p, z as _, i as L, p as T } from "../../th_TH-d627cd51.js";
3
+ const h = (e) => {
4
4
  const [o, c] = a(e), [t, i] = a({
5
5
  en_US: s,
6
6
  th_TH: p,
7
- zh_CN: u,
8
- it_IT: _,
9
- pt_PT: L
10
- }), n = (r) => {
11
- i((z) => ({
12
- ...z,
7
+ zh_CN: _,
8
+ it_IT: L,
9
+ pt_PT: T
10
+ }), l = z((r) => {
11
+ i((u) => ({
12
+ ...u,
13
13
  ...r
14
14
  }));
15
- }, l = m(() => t[o] || s, [o, t]);
15
+ }, []), n = m(() => t[o] || s, [o, t]);
16
16
  return {
17
17
  locale: o,
18
18
  setLocale: c,
19
- localeMessages: l,
20
- addLocalization: n
19
+ localeMessages: n,
20
+ addLocalization: l
21
21
  };
22
22
  };
23
23
  export {
24
- f as useLocalization
24
+ h as useLocalization
25
25
  };
@@ -1,26 +1,42 @@
1
- import { useMemo as c, useCallback as u } from "react";
2
- import { usePagesRotateContext as f } from "../../contexts/PagesRotateContext.js";
3
- import { useLicenseContext as m } from "../../contexts/LicenseContext.js";
4
- import { LicenseType as p } from "../types.js";
1
+ import { useMemo as a, useCallback as l } from "react";
2
+ import { usePagesRotateContext as c } from "../../contexts/PagesRotateContext.js";
3
+ import { useLicenseContext as u } from "../../contexts/LicenseContext.js";
4
+ import { LicenseType as f } from "../types.js";
5
5
  import { ORGANIZATION_ALLOWED_FEATURES_MESSAGE as R } from "../const.js";
6
- const y = () => {
7
- const { setSinglePageRotate: n } = f(), { type: r, validating: s } = m(), a = c(() => r !== p.Developer, [r]), i = u(
8
- (l, e) => {
9
- n((t) => {
10
- const o = typeof e == "function" ? e(t[l] || 0) : e;
11
- return o % 90 !== 0 ? (console.warn("rotationDegree must be a multiple of 90 got", o), t) : {
12
- ...t,
13
- [l]: o
6
+ import "react/jsx-runtime";
7
+ import "../../contexts/RPDocumentContext.js";
8
+ import "./useLoadPdf.js";
9
+ import "pdfjs-dist";
10
+ import "../getThumbnailViewport.js";
11
+ import "../../contexts/ConfigContext.js";
12
+ import "../../contexts/DocumentPasswordContext.js";
13
+ import "../appConsole.js";
14
+ import "./usePdfProperties.js";
15
+ import "../convertPdfDate.js";
16
+ import "../formatFileSize.js";
17
+ import "../../th_TH-d627cd51.js";
18
+ import "../../contexts/RotationContext.js";
19
+ import "../../contexts/InitialStateContext.js";
20
+ import "../../contexts/EventCallbackContext.js";
21
+ import "./useLicense.js";
22
+ const U = () => {
23
+ const { setSinglePageRotate: r } = c(), { type: i, validating: n } = u(), m = a(() => i !== f.Developer, [i]), p = l(
24
+ (s, t) => {
25
+ r((o) => {
26
+ const e = typeof t == "function" ? t(o[s] || 0) : t;
27
+ return e % 90 !== 0 ? (console.warn("rotationDegree must be a multiple of 90 got", e), o) : {
28
+ ...o,
29
+ [s]: e
14
30
  };
15
31
  });
16
32
  },
17
- [n]
33
+ [r]
18
34
  );
19
- return { rotate: c(() => s !== !1 ? () => {
20
- } : a ? i : () => {
35
+ return { rotate: a(() => n !== !1 ? () => {
36
+ } : m ? p : () => {
21
37
  console.error(R);
22
- }, [s, a, i]) };
38
+ }, [n, m, p]) };
23
39
  };
24
40
  export {
25
- y as usePageRotateContext
41
+ U as usePageRotateContext
26
42
  };
@@ -1,60 +1,37 @@
1
1
  import "react";
2
2
  import "../types.js";
3
- import { s as mo } from "../../ToolbarLayout.module-c588d36b.js";
3
+ import { b as I } from "../../PaginationContext-9217cab4.js";
4
+ import "../../contexts/ViewModeContext.js";
5
+ import "../../contexts/ScrollModeContext.js";
6
+ import "./useDebounce.js";
7
+ import "../../contexts/DimensionPagesContext.js";
8
+ import "../../contexts/LayoutContainerContext.js";
9
+ import "../../th_TH-d627cd51.js";
4
10
  import "react/jsx-runtime";
5
11
  import "../../contexts/RPDocumentContext.js";
12
+ import "./useLoadPdf.js";
13
+ import "pdfjs-dist";
14
+ import "../getThumbnailViewport.js";
15
+ import "../../contexts/ConfigContext.js";
6
16
  import "../../contexts/DocumentPasswordContext.js";
7
- import "../../contexts/DarkModeContext.js";
8
- import "../../contexts/RotationContext.js";
9
- import "../../contexts/LayerContext.js";
10
- import "../../contexts/ZoomContext.js";
11
- import "../../contexts/ViewModeContext.js";
12
- import "../../contexts/ScrollModeContext.js";
17
+ import "../appConsole.js";
18
+ import "./usePdfProperties.js";
19
+ import "../convertPdfDate.js";
20
+ import "../formatFileSize.js";
21
+ import "../../contexts/GlobalCurrentPage.js";
22
+ import "../../contexts/InitialStateContext.js";
23
+ import "../../contexts/EventCallbackContext.js";
13
24
  import "../../contexts/VirtualScrollContext.js";
14
25
  import "../../contexts/VirtualGridContext.js";
15
- import "../../contexts/SelectionModeContext.js";
16
- import "../../contexts/InitialStateContext.js";
17
- import "../../contexts/FullScreenContext.js";
18
- import "../../contexts/FileInputContext.js";
19
- import "../../contexts/DropFileZoneContext.js";
20
- import "../../contexts/LayoutContainerContext.js";
21
- import "../../contexts/DimensionPagesContext.js";
22
- import "../../contexts/LocalizationContext.js";
23
- import "../../contexts/HighlightContext.js";
24
- import "../../contexts/LicenseContext.js";
25
- import "../../contexts/DownloadContext.js";
26
+ import "../smoothScrollTo.js";
26
27
  import "../../contexts/SmoothScrollContext.js";
27
- import "../../contexts/ElementPageContext.js";
28
+ import "../getScrollDistance.js";
29
+ import "../calculatePage.js";
30
+ import "../../contexts/ZoomContext.js";
31
+ import "../constants.js";
32
+ import "../getZoomLevel.js";
33
+ import "../../contexts/RotationContext.js";
28
34
  import "../../contexts/PagesRotateContext.js";
29
- import "../../contexts/GlobalCurrentPage.js";
30
- import "../../contexts/LoaderContext.js";
31
- import "../../contexts/ToolComponentContext.js";
32
- import "../../contexts/IconToolContext.js";
33
- import "../../contexts/OtherToolContext.js";
34
- import "../../components/RPConfig.js";
35
- import "../../components/layout/Container.js";
36
- import "../../contexts/ViewportContext.js";
37
- import "../../contexts/ToolbarComponentContext.js";
38
- import "../../components/layout/sidebar/RPSplitter.js";
39
- import "../../components/layout/WrapperLayout.js";
40
- import "../../LayoutWrapper-a871c161.js";
41
- import "../../contexts/ThemeContext.js";
42
- import "../../components/RPDropFileZone.js";
43
- import "../../components/ui/Button.js";
44
- import "../../SearchCloseButton-cbf182aa.js";
45
- import "../../components/ui/Input.js";
46
- import "../../components/ui/Checkbox.js";
47
- import "../../components/icons/LoaderIcon.js";
48
- import "../../contexts/IconContext.js";
49
- import "../../components/ui/RPTooltip.js";
50
- import "../../components/ui/DropDown.js";
51
- import "../../ZoomTool.module-6c5eabbb.js";
52
- import "../../components/layout/toolbar/MenuItem.js";
53
- import "../../components/layout/toolbar/MenuSeparator.js";
54
- import "../dateFormatter.js";
55
- import "../../components/layout/toolbar/PropertyItem.js";
56
- import "../../RotateTool.module-03987eba.js";
57
- import "./useDebounce.js";
58
35
  export {
59
- mo as usePaginate
36
+ I as usePaginate
60
37
  };
@@ -1,79 +1,100 @@
1
- import { useState as L, useRef as T, useCallback as r, useEffect as u } from "react";
1
+ import { useState as E, useRef as T, useCallback as c, useEffect as i } from "react";
2
2
  import { useDebounce as g } from "./useDebounce.js";
3
3
  import { useZoomContext as A } from "../../contexts/ZoomContext.js";
4
- const I = (n) => {
5
- const { currentZoom: p, setZoomLevel: w } = A(), [D, d] = L(0), a = g(D, 100), [o, b] = L(!1), c = T(null), i = r((e) => {
6
- d(e ? (t) => t + 3 : (t) => t - 3);
7
- }, []), f = r(
4
+ import "react/jsx-runtime";
5
+ import "../types.js";
6
+ import "../../th_TH-d627cd51.js";
7
+ import "../appConsole.js";
8
+ import "../../contexts/InitialStateContext.js";
9
+ import "../../contexts/RPDocumentContext.js";
10
+ import "./useLoadPdf.js";
11
+ import "pdfjs-dist";
12
+ import "../getThumbnailViewport.js";
13
+ import "../../contexts/ConfigContext.js";
14
+ import "../../contexts/DocumentPasswordContext.js";
15
+ import "./usePdfProperties.js";
16
+ import "../convertPdfDate.js";
17
+ import "../formatFileSize.js";
18
+ import "../constants.js";
19
+ import "../getZoomLevel.js";
20
+ import "../../contexts/LayoutContainerContext.js";
21
+ import "../../contexts/ViewModeContext.js";
22
+ import "../../contexts/RotationContext.js";
23
+ import "../../contexts/GlobalCurrentPage.js";
24
+ import "../../contexts/EventCallbackContext.js";
25
+ const V = (o) => {
26
+ const { currentZoom: L, setZoomLevel: w } = A(), [D, m] = E(0), d = g(D, 100), [s, b] = E(!1), r = T(null), u = c((e) => {
27
+ m(e ? (t) => t + 3 : (t) => t - 3);
28
+ }, []), a = c(
8
29
  (e) => {
9
30
  if (!e.ctrlKey)
10
31
  return;
11
32
  e.preventDefault();
12
33
  const t = e.deltaY < 0;
13
- i(t);
34
+ u(t);
14
35
  },
15
- [i]
36
+ [u]
16
37
  );
17
- u(() => {
18
- if (a) {
19
- const e = Math.round(p * 100 + a);
20
- d(0), w(e > 25 ? e : 25);
38
+ i(() => {
39
+ if (d) {
40
+ const e = Math.round(L * 100 + d);
41
+ m(0), w(e > 25 ? e : 25);
21
42
  }
22
- }, [a]);
23
- const E = (e, t) => {
24
- const s = e.clientX - t.clientX, l = e.clientY - t.clientY;
25
- return Math.sqrt(s * s + l * l);
26
- }, h = r(
43
+ }, [d]);
44
+ const p = (e, t) => {
45
+ const n = e.clientX - t.clientX, l = e.clientY - t.clientY;
46
+ return Math.sqrt(n * n + l * l);
47
+ }, f = c(
27
48
  (e) => {
28
- if (!o || e.touches.length !== 2)
49
+ if (!s || e.touches.length !== 2)
29
50
  return;
30
- const t = E(e.touches[0], e.touches[1]);
31
- c.current = t, e.preventDefault();
51
+ const t = p(e.touches[0], e.touches[1]);
52
+ r.current = t, e.preventDefault();
32
53
  },
33
- [o]
34
- ), v = r(() => {
35
- c.current = null;
36
- }, []), m = r(
54
+ [s]
55
+ ), h = c(() => {
56
+ r.current = null;
57
+ }, []), v = c(
37
58
  (e) => {
38
- if (!o || e.touches.length !== 2 || c.current === null)
59
+ if (!s || e.touches.length !== 2 || r.current === null)
39
60
  return;
40
- const t = E(e.touches[0], e.touches[1]), s = t - c.current, l = Math.abs(s) > 5, S = s > 0;
41
- l && (i(S), c.current = t, e.preventDefault());
61
+ const t = p(e.touches[0], e.touches[1]), n = t - r.current, l = Math.abs(n) > 5, S = n > 0;
62
+ l && (u(S), r.current = t, e.preventDefault());
42
63
  },
43
- [i, o]
64
+ [u, s]
44
65
  ), y = () => {
45
66
  document.activeElement instanceof HTMLElement && document.activeElement.blur();
46
67
  };
47
- u(() => {
48
- if (o) {
68
+ i(() => {
69
+ if (s) {
49
70
  document.body.style.touchAction = "pan-x pan-y";
50
71
  return;
51
72
  }
52
73
  document.body.style.touchAction = "";
53
- }, [o]), u(() => {
74
+ }, [s]), i(() => {
54
75
  const e = () => {
55
- const t = document.activeElement, s = !!(t != null && t.closest('[data-rp="container"]'));
56
- b(s);
76
+ const t = document.activeElement, n = !!(t != null && t.closest('[data-rp="container"]'));
77
+ b(n);
57
78
  };
58
79
  return window.addEventListener("focusin", e), window.addEventListener("focusout", e), e(), () => {
59
80
  window.removeEventListener("focusin", e), window.removeEventListener("focusout", e);
60
81
  };
61
- }, []), u(() => {
62
- if (!n)
82
+ }, []), i(() => {
83
+ if (!o)
63
84
  return;
64
85
  const e = (t) => {
65
- n.contains(t.target) || y();
86
+ o.contains(t.target) || y();
66
87
  };
67
88
  return document.addEventListener("scroll", e), () => {
68
89
  document.removeEventListener("scroll", e);
69
90
  };
70
- }, [n]), u(() => {
71
- if (n)
72
- return n.addEventListener("wheel", f, { passive: !1 }), n.addEventListener("touchstart", h, { passive: !1 }), n.addEventListener("touchmove", m, { passive: !1 }), n.addEventListener("touchend", v, { passive: !1 }), () => {
73
- n.removeEventListener("wheel", f), n.removeEventListener("touchstart", h), n.removeEventListener("touchmove", m), n.removeEventListener("touchend", v);
91
+ }, [o]), i(() => {
92
+ if (o)
93
+ return o.addEventListener("wheel", a, { passive: !1 }), o.addEventListener("touchstart", f, { passive: !1 }), o.addEventListener("touchmove", v, { passive: !1 }), o.addEventListener("touchend", h, { passive: !1 }), () => {
94
+ o.removeEventListener("wheel", a), o.removeEventListener("touchstart", f), o.removeEventListener("touchmove", v), o.removeEventListener("touchend", h);
74
95
  };
75
- }, [n, f, h, m, v]);
96
+ }, [o, a, f, v, h]);
76
97
  };
77
98
  export {
78
- I as usePinch
99
+ V as usePinch
79
100
  };
@@ -1,60 +1,90 @@
1
- import "react";
2
- import "../../contexts/LayoutContainerContext.js";
3
- import "../../contexts/DimensionPagesContext.js";
4
- import "../calculatePage.js";
1
+ import { useRef as E, useState as F, useMemo as N, useEffect as b, useCallback as R } from "react";
2
+ import { useLayoutContainer as v } from "../../contexts/LayoutContainerContext.js";
3
+ import { useDimensionPagesContext as C } from "../../contexts/DimensionPagesContext.js";
4
+ import { getGridDimension as D, getPositionFromPage as q } from "../calculatePage.js";
5
+ import { u as A } from "../../PaginationContext-9217cab4.js";
6
+ import { useDebounce as H } from "./useDebounce.js";
7
+ import { useSmoothScrollContext as M } from "../../contexts/SmoothScrollContext.js";
5
8
  import "react/jsx-runtime";
9
+ import "../appConsole.js";
6
10
  import "../../contexts/RPDocumentContext.js";
11
+ import "./useLoadPdf.js";
12
+ import "pdfjs-dist";
13
+ import "../types.js";
14
+ import "../../th_TH-d627cd51.js";
15
+ import "../getThumbnailViewport.js";
16
+ import "../../contexts/ConfigContext.js";
7
17
  import "../../contexts/DocumentPasswordContext.js";
8
- import { N as pr } from "../../ToolbarLayout.module-c588d36b.js";
9
- import "../../contexts/DarkModeContext.js";
10
- import "../../contexts/RotationContext.js";
11
- import "../../contexts/LayerContext.js";
18
+ import "./usePdfProperties.js";
19
+ import "../convertPdfDate.js";
20
+ import "../formatFileSize.js";
12
21
  import "../../contexts/ZoomContext.js";
22
+ import "../../contexts/InitialStateContext.js";
23
+ import "../constants.js";
24
+ import "../getZoomLevel.js";
13
25
  import "../../contexts/ViewModeContext.js";
26
+ import "../../contexts/RotationContext.js";
27
+ import "../../contexts/GlobalCurrentPage.js";
28
+ import "../../contexts/EventCallbackContext.js";
29
+ import "../../contexts/PagesRotateContext.js";
14
30
  import "../../contexts/ScrollModeContext.js";
15
31
  import "../../contexts/VirtualScrollContext.js";
16
32
  import "../../contexts/VirtualGridContext.js";
17
- import "../../contexts/SelectionModeContext.js";
18
- import "../../contexts/InitialStateContext.js";
19
- import "../../contexts/FullScreenContext.js";
20
- import "../../contexts/FileInputContext.js";
21
- import "../../contexts/DropFileZoneContext.js";
22
- import "../../contexts/LocalizationContext.js";
23
- import "../../contexts/HighlightContext.js";
24
- import "../../contexts/LicenseContext.js";
25
- import "../../contexts/DownloadContext.js";
26
- import "../../contexts/SmoothScrollContext.js";
27
- import "../../contexts/ElementPageContext.js";
28
- import "../../contexts/PagesRotateContext.js";
29
- import "../../contexts/GlobalCurrentPage.js";
30
- import "../../contexts/LoaderContext.js";
31
- import "../../contexts/ToolComponentContext.js";
32
- import "../../contexts/IconToolContext.js";
33
- import "../../contexts/OtherToolContext.js";
34
- import "../../components/RPConfig.js";
35
- import "../../components/layout/Container.js";
36
- import "../../contexts/ViewportContext.js";
37
- import "../../contexts/ToolbarComponentContext.js";
38
- import "../../components/layout/sidebar/RPSplitter.js";
39
- import "../../components/layout/WrapperLayout.js";
40
- import "../../LayoutWrapper-a871c161.js";
41
- import "../../contexts/ThemeContext.js";
42
- import "../../components/RPDropFileZone.js";
43
- import "../../components/ui/Button.js";
44
- import "../../SearchCloseButton-cbf182aa.js";
45
- import "../../components/ui/Input.js";
46
- import "../../components/ui/Checkbox.js";
47
- import "../../components/icons/LoaderIcon.js";
48
- import "../../contexts/IconContext.js";
49
- import "../../components/ui/RPTooltip.js";
50
- import "../../components/ui/DropDown.js";
51
- import "../../ZoomTool.module-6c5eabbb.js";
52
- import "../../components/layout/toolbar/MenuItem.js";
53
- import "../../components/layout/toolbar/MenuSeparator.js";
54
- import "../dateFormatter.js";
55
- import "../../components/layout/toolbar/PropertyItem.js";
56
- import "../../RotateTool.module-03987eba.js";
57
- import "./useDebounce.js";
33
+ import "../smoothScrollTo.js";
34
+ import "../getScrollDistance.js";
35
+ const Tt = (u, X, e) => {
36
+ const f = E(), { contentRef: Y } = v(), { heights: P, widths: h } = C(), { setFocusedPage: w } = A(), [I, S] = F([]), { targetScrollPage: l } = M(), i = H(I, 0, 500), W = N(() => {
37
+ const { rowsHeight: p, columnsWidth: r } = D({ heights: P, widths: h }, u);
38
+ return P.map((o, c) => {
39
+ const t = h[c], n = q(c + 1, u), s = r.slice(0, n.columnIndex).reduce((a, d) => a + d, 0), m = p.slice(0, n.rowIndex).reduce((a, d) => a + d, 0), g = s + t, T = m + o;
40
+ return {
41
+ pageNumber: c + 1,
42
+ ...n,
43
+ width: t,
44
+ height: o,
45
+ startX: s,
46
+ startY: m,
47
+ endX: g,
48
+ endY: T
49
+ };
50
+ });
51
+ }, [P, h, u, X]);
52
+ b(() => {
53
+ var r;
54
+ i.length > 0 && !l.current && w(i[0].pageNumber), ((r = i[0]) == null ? void 0 : r.ratio) && i.some((o) => o.pageNumber === l.current) && setTimeout(() => {
55
+ l.current = void 0;
56
+ }, 500);
57
+ }, [i, w]);
58
+ const L = R(
59
+ (p) => {
60
+ f.current && cancelAnimationFrame(f.current), f.current = requestAnimationFrame(() => {
61
+ const r = p.target, o = {
62
+ startTop: r.scrollTop,
63
+ startLeft: r.scrollLeft,
64
+ endTop: r.scrollTop + r.clientHeight,
65
+ endLeft: r.scrollLeft + r.clientWidth
66
+ }, c = W.filter((t) => {
67
+ const n = t.endX >= o.startLeft && t.endY >= o.startTop, s = t.startX <= o.endLeft && t.startY <= o.endTop;
68
+ return n && s;
69
+ }).map((t) => {
70
+ const n = o.startLeft > t.startX ? o.startLeft : t.startX, s = o.startTop > t.startY ? o.startTop : t.startY, m = o.endLeft < t.endX ? o.endLeft : t.endX, g = o.endTop < t.endY ? o.endTop : t.endY, T = m - n, a = g - s, x = +(T * a / (t.width * t.height) * 100).toFixed(2);
71
+ return {
72
+ pageNumber: t.pageNumber,
73
+ ratio: x
74
+ };
75
+ }).sort((t, n) => n.ratio - t.ratio);
76
+ S(c);
77
+ });
78
+ },
79
+ [Y, W]
80
+ );
81
+ b(() => {
82
+ if (e)
83
+ return e == null || e.addEventListener("scroll", L), () => {
84
+ e == null || e.removeEventListener("scroll", L);
85
+ };
86
+ }, [e, L]);
87
+ };
58
88
  export {
59
- pr as usePresentPage
89
+ Tt as usePresentPage
60
90
  };