@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,7 +1,7 @@
1
1
  import { jsx as r, Fragment as f, jsxs as t } from "react/jsx-runtime";
2
2
  import { useMemo as N } from "react";
3
3
  import l from "../../../../ui/RPTooltip.js";
4
- import { G as C } from "../../../../../index-a48ec088.js";
4
+ import { G as C } from "../../../../../index-4baea9b5.js";
5
5
  import { MenuItem as e } from "../../MenuItem.js";
6
6
  import { PageScrollingIcon as G } from "../../../../icons/PageScrollingIcon.js";
7
7
  import { VerticalScrollingIcon as R } from "../../../../icons/VerticalScrollingIcon.js";
@@ -11,42 +11,45 @@ import { ViewMode as A, ScrollMode as i } from "../../../../../utils/types.js";
11
11
  import { CheckIcon as c } from "../../../../icons/CheckIcon.js";
12
12
  import { useViewModeContext as v } from "../../../../../contexts/ViewModeContext.js";
13
13
  import { useLocalizationContext as _ } from "../../../../../contexts/LocalizationContext.js";
14
- import "../../../../../index-c9a2990a.js";
14
+ import "../../../../../index-c0faa594.js";
15
15
  import "react-dom";
16
- import "../../../../../index-808ea7bf.js";
16
+ import "../../../../../index-e3ee9457.js";
17
+ import "../../../../../floating-ui.react-dom-5ec29bd6.js";
18
+ import "../../../../../index-655864a7.js";
17
19
  import "../../../../../utils/withRef.js";
20
+ import "../../../../../Combination-54a77a7a.js";
18
21
  import "../../../../../clsx-0c6e471a.js";
19
22
  import "../../../../../utils/appConsole.js";
20
23
  import "../../../../../contexts/InitialStateContext.js";
21
24
  import "../../../../../th_TH-d627cd51.js";
22
25
  import "../../../../../utils/hooks/useLocalization.js";
23
- const Q = (S) => {
24
- const { icons: h, isToolVisible: I = !0 } = S, { pageScrollIcon: p, verticalScrollIcon: d, horizontalScrollIcon: u } = h ?? {}, { viewMode: L } = v(), { scrollMode: n, setScrollMode: m } = T(), { localeMessages: o } = _(), a = N(() => L === A.DUAL_PAGE, [L]);
26
+ const Y = (S) => {
27
+ const { icons: h, isToolVisible: I = !0 } = S, { pageScrollIcon: p, verticalScrollIcon: d, horizontalScrollIcon: u } = h ?? {}, { viewMode: L } = v(), { scrollMode: m, setScrollMode: n } = T(), { localeMessages: o } = _(), a = N(() => L === A.DUAL_PAGE, [L]);
25
28
  return I ? /* @__PURE__ */ r(f, { children: /* @__PURE__ */ t(C, { children: [
26
- /* @__PURE__ */ r(e, { onClick: () => m(i.PAGE_SCROLLING), children: /* @__PURE__ */ t(l, { className: "rp-menu-item", content: o == null ? void 0 : o.pageScrollingTooltip, children: [
29
+ /* @__PURE__ */ r(e, { onClick: () => n(i.PAGE_SCROLLING), children: /* @__PURE__ */ t(l, { className: "rp-menu-item", content: o == null ? void 0 : o.pageScrollingTooltip, children: [
27
30
  /* @__PURE__ */ r("div", { className: "rp-menu-item-left", children: p || /* @__PURE__ */ r(G, {}) }),
28
31
  o == null ? void 0 : o.pageScrollingLabel,
29
- n === i.PAGE_SCROLLING ? /* @__PURE__ */ r(c, { className: "rp-menu-item-right" }) : null
32
+ m === i.PAGE_SCROLLING ? /* @__PURE__ */ r(c, { className: "rp-menu-item-right" }) : null
30
33
  ] }) }),
31
- /* @__PURE__ */ r(e, { onClick: () => m(i.VERTICAL_SCROLLING), children: /* @__PURE__ */ t(l, { className: "rp-menu-item", content: o == null ? void 0 : o.verticalScrollingTooltip, children: [
34
+ /* @__PURE__ */ r(e, { onClick: () => n(i.VERTICAL_SCROLLING), children: /* @__PURE__ */ t(l, { className: "rp-menu-item", content: o == null ? void 0 : o.verticalScrollingTooltip, children: [
32
35
  /* @__PURE__ */ r("div", { className: "rp-menu-item-left", children: d || /* @__PURE__ */ r(R, {}) }),
33
36
  o == null ? void 0 : o.verticalScrollingLabel,
34
- n === i.VERTICAL_SCROLLING ? /* @__PURE__ */ r(c, { className: "rp-menu-item-right" }) : null
37
+ m === i.VERTICAL_SCROLLING ? /* @__PURE__ */ r(c, { className: "rp-menu-item-right" }) : null
35
38
  ] }) }),
36
39
  /* @__PURE__ */ r(
37
40
  e,
38
41
  {
39
42
  disabled: a,
40
- onClick: () => m(i.HORIZONTAL_SCROLLING),
43
+ onClick: () => n(i.HORIZONTAL_SCROLLING),
41
44
  children: /* @__PURE__ */ t(l, { className: "rp-menu-item", content: o == null ? void 0 : o.horizontalTooltip, children: [
42
45
  /* @__PURE__ */ r("div", { className: "rp-menu-item-left", children: u || /* @__PURE__ */ r(O, {}) }),
43
46
  o == null ? void 0 : o.horizontalLabel,
44
- n === i.HORIZONTAL_SCROLLING ? /* @__PURE__ */ r(c, { className: "rp-menu-item-right" }) : null
47
+ m === i.HORIZONTAL_SCROLLING ? /* @__PURE__ */ r(c, { className: "rp-menu-item-right" }) : null
45
48
  ] })
46
49
  }
47
50
  )
48
51
  ] }) }) : null;
49
52
  };
50
53
  export {
51
- Q as ScrollModeTool
54
+ Y as ScrollModeTool
52
55
  };
@@ -1,39 +1,42 @@
1
- import { jsx as t, Fragment as a, jsxs as e } from "react/jsx-runtime";
2
- import l from "../../../../ui/RPTooltip.js";
3
- import { G as T } from "../../../../../index-a48ec088.js";
1
+ import { jsx as t, Fragment as a, jsxs as r } from "react/jsx-runtime";
2
+ import c from "../../../../ui/RPTooltip.js";
3
+ import { G as T } from "../../../../../index-4baea9b5.js";
4
4
  import { TextSelectionDefaultIcon as x } from "../../../../icons/TextSelectionDefaultIcon.js";
5
5
  import { HandModeDefaultIcon as S } from "../../../../icons/HandModeDefaultIcon.js";
6
- import { CheckIcon as p } from "../../../../icons/CheckIcon.js";
6
+ import { CheckIcon as l } from "../../../../icons/CheckIcon.js";
7
7
  import { MenuItem as d } from "../../MenuItem.js";
8
8
  import { SelectionMode as i } from "../../../../../utils/types.js";
9
9
  import { MenuSeparator as N } from "../../MenuSeparator.js";
10
10
  import { useSelectionModeContext as s } from "../../../../../contexts/SelectionModeContext.js";
11
11
  import { useLocalizationContext as I } from "../../../../../contexts/LocalizationContext.js";
12
12
  import "react";
13
- import "../../../../../index-c9a2990a.js";
13
+ import "../../../../../index-c0faa594.js";
14
14
  import "react-dom";
15
- import "../../../../../index-808ea7bf.js";
15
+ import "../../../../../index-e3ee9457.js";
16
+ import "../../../../../floating-ui.react-dom-5ec29bd6.js";
17
+ import "../../../../../index-655864a7.js";
16
18
  import "../../../../../utils/withRef.js";
19
+ import "../../../../../Combination-54a77a7a.js";
17
20
  import "../../../../../clsx-0c6e471a.js";
18
21
  import "../../../../../th_TH-d627cd51.js";
19
22
  import "../../../../../utils/appConsole.js";
20
23
  import "../../../../../utils/hooks/useLocalization.js";
21
- const y = (u) => {
22
- const { icons: f, isToolVisible: h = !0 } = u, { textSelectionIcon: r, handModeIcon: n } = f ?? {}, { selectionMode: m, setSelectionMode: c } = s(), { localeMessages: o } = I();
23
- return h ? /* @__PURE__ */ t(a, { children: /* @__PURE__ */ e(T, { children: [
24
- /* @__PURE__ */ t(d, { onClick: () => c(i.TEXT), children: /* @__PURE__ */ e(l, { className: "rp-menu-item", content: o == null ? void 0 : o.textSelectionTooltip, children: [
25
- /* @__PURE__ */ t("div", { className: "rp-menu-item-left", children: r || /* @__PURE__ */ t(x, {}) }),
24
+ const K = (u) => {
25
+ const { icons: f, isToolVisible: h = !0 } = u, { textSelectionIcon: e, handModeIcon: n } = f ?? {}, { selectionMode: m, setSelectionMode: p } = s(), { localeMessages: o } = I();
26
+ return h ? /* @__PURE__ */ t(a, { children: /* @__PURE__ */ r(T, { children: [
27
+ /* @__PURE__ */ t(d, { onClick: () => p(i.TEXT), children: /* @__PURE__ */ r(c, { className: "rp-menu-item", content: o == null ? void 0 : o.textSelectionTooltip, children: [
28
+ /* @__PURE__ */ t("div", { className: "rp-menu-item-left", children: e || /* @__PURE__ */ t(x, {}) }),
26
29
  o == null ? void 0 : o.textSelectionLabel,
27
- m === i.TEXT ? /* @__PURE__ */ t(p, { className: "rp-menu-item-right" }) : null
30
+ m === i.TEXT ? /* @__PURE__ */ t(l, { className: "rp-menu-item-right" }) : null
28
31
  ] }) }),
29
- /* @__PURE__ */ t(d, { onClick: () => c(i.HAND), children: /* @__PURE__ */ e(l, { className: "rp-menu-item", content: o == null ? void 0 : o.handToolTooltip, children: [
32
+ /* @__PURE__ */ t(d, { onClick: () => p(i.HAND), children: /* @__PURE__ */ r(c, { className: "rp-menu-item", content: o == null ? void 0 : o.handToolTooltip, children: [
30
33
  /* @__PURE__ */ t("div", { className: "rp-menu-item-left", children: n || /* @__PURE__ */ t(S, {}) }),
31
34
  o == null ? void 0 : o.handToolLabel,
32
- m === i.HAND ? /* @__PURE__ */ t(p, { className: "rp-menu-item-right" }) : null
35
+ m === i.HAND ? /* @__PURE__ */ t(l, { className: "rp-menu-item-right" }) : null
33
36
  ] }) }),
34
37
  /* @__PURE__ */ t(N, {})
35
38
  ] }) }) : null;
36
39
  };
37
40
  export {
38
- y as SelectionModeTool
41
+ K as SelectionModeTool
39
42
  };
@@ -1,26 +1,29 @@
1
1
  import { jsx as r, Fragment as h, jsxs as i } from "react/jsx-runtime";
2
2
  import { useMemo as I } from "react";
3
3
  import l from "../../../../ui/RPTooltip.js";
4
- import { G as N } from "../../../../../index-a48ec088.js";
4
+ import { G as N } from "../../../../../index-4baea9b5.js";
5
5
  import { MenuSeparator as L } from "../../MenuSeparator.js";
6
6
  import { MenuItem as p } from "../../MenuItem.js";
7
- import { DualPageIcon as C } from "../../../../icons/SinglePageIcon.js";
8
- import { SinglePageIcon as S } from "../../../../icons/DualPageIcon.js";
7
+ import { DualPageIcon as C } from "../../../../icons/DualPageIcon.js";
8
+ import { SinglePageIcon as S } from "../../../../icons/SinglePageIcon.js";
9
9
  import { useViewModeContext as x } from "../../../../../contexts/ViewModeContext.js";
10
10
  import { ScrollMode as G, ViewMode as c } from "../../../../../utils/types.js";
11
11
  import { CheckIcon as u } from "../../../../icons/CheckIcon.js";
12
12
  import { useScrollModeContext as T } from "../../../../../contexts/ScrollModeContext.js";
13
13
  import { useLocalizationContext as b } from "../../../../../contexts/LocalizationContext.js";
14
- import "../../../../../index-c9a2990a.js";
14
+ import "../../../../../index-c0faa594.js";
15
15
  import "react-dom";
16
- import "../../../../../index-808ea7bf.js";
16
+ import "../../../../../index-e3ee9457.js";
17
+ import "../../../../../floating-ui.react-dom-5ec29bd6.js";
18
+ import "../../../../../index-655864a7.js";
17
19
  import "../../../../../utils/withRef.js";
20
+ import "../../../../../Combination-54a77a7a.js";
18
21
  import "../../../../../clsx-0c6e471a.js";
19
22
  import "../../../../../utils/appConsole.js";
20
23
  import "../../../../../contexts/InitialStateContext.js";
21
24
  import "../../../../../th_TH-d627cd51.js";
22
25
  import "../../../../../utils/hooks/useLocalization.js";
23
- const Q = (a) => {
26
+ const Y = (a) => {
24
27
  const { icons: d, isToolVisible: s = !0 } = a, { singlePageIcon: t, dualPageIcon: e } = d ?? {}, { viewMode: m, setDualPage: f, setSinglePage: P } = x(), { scrollMode: n } = T(), { localeMessages: o } = b(), g = I(() => [G.HORIZONTAL_SCROLLING].includes(n), [n]);
25
28
  return s ? /* @__PURE__ */ r(h, { children: /* @__PURE__ */ i(N, { children: [
26
29
  /* @__PURE__ */ r(p, { onClick: P, children: /* @__PURE__ */ i(l, { className: "rp-menu-item", content: o == null ? void 0 : o.singlePageTooltip, children: [
@@ -37,5 +40,5 @@ const Q = (a) => {
37
40
  ] }) }) : null;
38
41
  };
39
42
  export {
40
- Q as ViewModeTool
43
+ Y as ViewModeTool
41
44
  };
@@ -1,142 +1,138 @@
1
- import "react/jsx-runtime";
2
- import "react";
3
- import "../../contexts/RPDocumentContext.js";
4
- import "../../contexts/DocumentPasswordContext.js";
5
- import { I as Fr } from "../../ToolbarLayout.module-37619c4b.js";
6
- import "../../contexts/DarkModeContext.js";
7
- import "../../utils/types.js";
8
- import "../../contexts/RotationContext.js";
9
- import "../../contexts/LayerContext.js";
10
- import "../../contexts/ZoomContext.js";
1
+ import { jsx as k } from "react/jsx-runtime";
2
+ import { useRef as y, useState as F, useMemo as S, useEffect as f, useCallback as E } from "react";
3
+ import { u as P } from "../../PaginationContext-9217cab4.js";
4
+ import { usePrintContext as j } from "../../contexts/PrintContext.js";
5
+ import { AnnotationLayer as R } from "pdfjs-dist";
6
+ import { SimpleLinkService as x } from "../../utils/link_service.js";
7
+ import { AnnotationSubType as $ } from "../../utils/types.js";
8
+ import { useScrollModeContext as D } from "../../contexts/ScrollModeContext.js";
9
+ import { insertDateText as I, annotationEventsHandler as _, handleAnnotationWidget as J, bindLayerEvents as N, unbindLayerEvents as A } from "../../utils/annotations.js";
10
+ import { useInitialStateContext as O } from "../../contexts/InitialStateContext.js";
11
+ import { useDocumentContext as V } from "../../contexts/RPDocumentContext.js";
12
+ import { useFileDownload as W } from "../../utils/hooks/useFileDownload.js";
13
+ import "../../utils/appConsole.js";
14
+ import "../../contexts/GlobalCurrentPage.js";
15
+ import "../../contexts/EventCallbackContext.js";
11
16
  import "../../contexts/ViewModeContext.js";
12
- import "../../contexts/ScrollModeContext.js";
17
+ import "../../th_TH-d627cd51.js";
13
18
  import "../../contexts/VirtualScrollContext.js";
14
19
  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";
20
+ import "../../utils/smoothScrollTo.js";
21
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 "../../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 "../../contexts/EventCallbackContext.js";
35
- import "../RPConfig.js";
36
- import "../layout/Container.js";
37
- import "../../contexts/ViewportContext.js";
38
- import "../../contexts/ToolbarComponentContext.js";
39
- import "../layout/sidebar/RPSplitter.js";
40
- import "../layout/WrapperLayout.js";
41
- import "../../LayoutWrapper-6224491f.js";
42
- import "../../contexts/ThemeContext.js";
43
- import "../RPDropFileZone.js";
44
- import "../ui/Button.js";
45
- import "../../SearchCloseButton-08d57275.js";
46
- import "../ui/Input.js";
47
- import "../ui/Checkbox.js";
48
- import "../icons/LoaderIcon.js";
49
- import "../../contexts/IconContext.js";
50
- import "../ui/RPTooltip.js";
51
- import "../ui/DropDown.js";
52
- import "../layout/toolbar/MenuItem.js";
53
- import "../layout/toolbar/MenuSeparator.js";
54
- import "../../utils/dateFormatter.js";
55
- import "../layout/toolbar/PropertyItem.js";
56
- import "../../RotateTool.module-67946714.js";
57
- import "pdfjs-dist";
58
- import "../../utils/link_service.js";
59
- import "../../utils/annotations.js";
22
+ import "../../contexts/ZoomContext.js";
23
+ import "../../utils/constants.js";
24
+ import "../../utils/getZoomLevel.js";
25
+ import "../../contexts/LayoutContainerContext.js";
26
+ import "../../contexts/RotationContext.js";
60
27
  import "../../utils/hooks/useLoadPdf.js";
61
28
  import "../../utils/getThumbnailViewport.js";
62
29
  import "../../contexts/ConfigContext.js";
63
- import "../../th_TH-d627cd51.js";
64
- import "../../utils/appConsole.js";
30
+ import "../../contexts/DocumentPasswordContext.js";
65
31
  import "../../utils/hooks/usePdfProperties.js";
66
32
  import "../../utils/convertPdfDate.js";
67
33
  import "../../utils/formatFileSize.js";
68
- import "../icons/ChevronUpIcon.js";
69
- import "../../utils/highlight.js";
70
- import "../../utils/charators.js";
71
- import "../../utils/Queue.js";
72
- import "../../utils/renderPage.js";
73
- import "../icons/Thumbnail.js";
74
- import "../../clsx-0c6e471a.js";
75
- import "../../utils/withRef.js";
76
- import "../../utils/hooks/useInfiniteScroll.js";
77
- import "../../utils/constants.js";
78
- import "./searchHighlight.js";
79
- import "../../utils/const.js";
80
- import "./CustomElement.js";
81
- import "../../utils/getZoomLevel.js";
82
34
  import "../../utils/hooks/useDebounce.js";
83
- import "../../utils/hooks/useLicense.js";
35
+ import "../../contexts/PagesRotateContext.js";
36
+ import "../../contexts/SmoothScrollContext.js";
84
37
  import "../../utils/getScrollDistance.js";
85
- import "../../utils/getElementPositionInPage.js";
86
38
  import "../../utils/calculatePage.js";
87
- import "../../utils/hooks/useMousePressed.js";
88
- import "../../utils/hooks/useGrabScroll.js";
89
- import "../../utils/hooks/usePinch.js";
90
- import "../ui/PasswordModal.js";
91
- import "../../utils/hooks/useLocalization.js";
92
- import "../../utils/approximateFragtion.js";
93
- import "../../utils/getWordPositionInPage.js";
94
- import "../../utils/smoothScrollTo.js";
95
- import "../layout/toolbar/FileUploadTool.js";
96
- import "../icons/FileUploadDefaultIcon.js";
97
- import "../../index-a48ec088.js";
98
- import "../../index-c9a2990a.js";
99
- import "react-dom";
100
- import "../../index-808ea7bf.js";
101
- import "../layout/toolbar/DarkModeTool.js";
102
- import "../icons/MoonIcon.js";
103
- import "../icons/SunIcon.js";
104
- import "../../utils/hooks/useDarkMode.js";
105
- import "../icons/ThreeDotIcon.js";
106
- import "../icons/CloseIcon.js";
107
- import "../layout/toolbar/DocumentProperties.js";
108
- import "../icons/InfoIcon.js";
109
- import "../layout/toolbar/RotateTool.js";
110
- import "../icons/ClockwiseIcon.js";
111
- import "../../utils/hooks/useRotate.js";
112
- import "../layout/toolbar/ViewModeTool.js";
113
- import "../icons/SinglePageIcon.js";
114
- import "../icons/DualPageIcon.js";
115
- import "../icons/CheckIcon.js";
116
- import "../layout/toolbar/ScrollModeTool.js";
117
- import "../icons/PageScrollingIcon.js";
118
- import "../icons/VerticalScrollingIcon.js";
119
- import "../icons/HorizontalScrollingIcon.js";
120
- import "../icons/FileDownloadDefaultIcon.js";
121
- import "../icons/PrintDefaultIcon.js";
122
- import "../layout/toolbar/FullScreenTool.js";
123
- import "../icons/FullScreenIcon.js";
124
- import "../../utils/hooks/useFullScreen.js";
125
- import "../icons/GoToDownIcon.js";
126
- import "../layout/toolbar/SelectionModeTool.js";
127
- import "../icons/TextSelectionDefaultIcon.js";
128
- import "../icons/HandModeDefaultIcon.js";
129
- import "../icons/ZoomInIcon.js";
130
- import "../icons/ZoomOutIcon.js";
131
- import "../../utils/zoom.js";
132
- import "../icons/SearchIcon.js";
133
- import "../icons/ClearIcon.js";
134
- import "../../utils/hooks/useHighlight.js";
135
- import "../RPTheme.js";
136
- import "../../utils/hooks/useLoadWorker.js";
137
- import "../icons/LightPdfIcon.js";
138
- import "../icons/DarkPdfIcon.js";
39
+ import "../../utils/hooks/usePrint.js";
139
40
  import "../../utils/sanitizeExternalUrl.js";
41
+ import "../../utils/dateFormatter.js";
42
+ import "../../contexts/DownloadContext.js";
43
+ const H = {
44
+ "rp-annotation-layer": "_rp-annotation-layer_rwxfx_1"
45
+ };
46
+ let U = "https://unpkg.com/pdfjs-dist@4.4.168/web/images/";
47
+ const $t = (C) => {
48
+ const { pageNumber: u } = C, n = y(null), { pages: h, pdf: t } = V(), { interactiveForm: M } = O(), r = y(), [a, L] = F(), { goToPage: d } = P(), { scrollMode: T } = D(), { print: v } = j(), { download: w } = W(), o = S(() => h.get(u), [h, u]), s = S(() => o == null ? void 0 : o.page.getViewport(), [o]);
49
+ f(() => {
50
+ r.current && (r.current.div.replaceChildren(), r.current = void 0);
51
+ }, [t]), f(() => {
52
+ o && o.page.getAnnotations().then((e) => {
53
+ r.current = void 0, L(e), n.current && (n.current.innerText = "");
54
+ });
55
+ }, [o]);
56
+ const m = E(
57
+ (e) => {
58
+ !a || !t || (I(n.current), _(e, t, a).then((i) => {
59
+ var p, l;
60
+ ((p = i == null ? void 0 : i.data) == null ? void 0 : p.action) === "Print" ? v() : ((l = i == null ? void 0 : i.data) == null ? void 0 : l.action) === "SaveAs" && w();
61
+ }));
62
+ },
63
+ [t, a, T, v, w]
64
+ );
65
+ return f(() => {
66
+ if (!o || !a)
67
+ return;
68
+ const e = o.page.getViewport();
69
+ if (r.current) {
70
+ r.current.update({
71
+ viewport: e.clone({ dontFlip: !0 })
72
+ });
73
+ return;
74
+ }
75
+ const i = /* @__PURE__ */ new Map([]);
76
+ for (const c of a) {
77
+ const { annotationType: g } = c;
78
+ switch (g) {
79
+ case $.Widget:
80
+ J(c, e, i);
81
+ break;
82
+ }
83
+ }
84
+ const p = new AbortController();
85
+ return (async () => {
86
+ var b;
87
+ r.current && (r.current.div.replaceChildren(), r.current = void 0), n.current && (n.current.innerText = ""), r.current = new R({
88
+ div: n.current,
89
+ accessibilityManager: void 0,
90
+ annotationCanvasMap: void 0,
91
+ annotationEditorUIManager: void 0,
92
+ structTreeLayer: null,
93
+ page: o.page,
94
+ viewport: e.clone({ dontFlip: !0 }),
95
+ commentManager: void 0,
96
+ linkService: new x(t, d),
97
+ annotationStorage: t == null ? void 0 : t.annotationStorage
98
+ }), n.current && A(n.current, m);
99
+ const c = await (t == null ? void 0 : t.hasJSActions()), g = await (t == null ? void 0 : t.getFieldObjects());
100
+ if (p.signal.aborted)
101
+ throw "abort";
102
+ return (b = r.current) == null ? void 0 : b.render({
103
+ annotations: a,
104
+ annotationStorage: t == null ? void 0 : t.annotationStorage,
105
+ hasJSActions: c,
106
+ fieldObjects: g,
107
+ div: n.current,
108
+ viewport: e.clone({ dontFlip: !0 }),
109
+ page: o.page,
110
+ imageResourcesPath: U,
111
+ renderForms: M ?? !0,
112
+ linkService: new x(t, d),
113
+ downloadManager: null,
114
+ enableScripting: !1
115
+ });
116
+ })().then(() => {
117
+ n.current && N(n.current, m);
118
+ }).catch((c) => {
119
+ if (c !== "abort")
120
+ throw c;
121
+ }).finally(() => {
122
+ r.current = void 0;
123
+ }), () => {
124
+ p.abort("clear"), n.current && A(n.current, m);
125
+ };
126
+ }, [t, a, m, d]), /* @__PURE__ */ k(
127
+ "div",
128
+ {
129
+ "data-rp": `page-${u}-annotationLayer`,
130
+ style: { width: `${s == null ? void 0 : s.width}px`, height: `${s == null ? void 0 : s.height}px` },
131
+ className: H["rp-annotation-layer"],
132
+ ref: n
133
+ }
134
+ );
135
+ };
140
136
  export {
141
- Fr as AnnotationLayer
137
+ $t as AnnotationLayer
142
138
  };
@@ -1,142 +1,71 @@
1
- import "react/jsx-runtime";
2
- import "react";
3
- import "../../contexts/RPDocumentContext.js";
4
- import "../../contexts/DocumentPasswordContext.js";
5
- import { G as Fo } from "../../ToolbarLayout.module-37619c4b.js";
6
- import "../../contexts/DarkModeContext.js";
7
- import "../../contexts/RotationContext.js";
8
- import "../../contexts/LayerContext.js";
9
- import "../../contexts/ZoomContext.js";
10
- import "../../contexts/ViewModeContext.js";
11
- import "../../contexts/ScrollModeContext.js";
12
- import "../../contexts/VirtualScrollContext.js";
13
- import "../../contexts/VirtualGridContext.js";
14
- import "../../contexts/SelectionModeContext.js";
15
- import "../../contexts/InitialStateContext.js";
16
- import "../../contexts/FullScreenContext.js";
17
- import "../../contexts/FileInputContext.js";
18
- import "../../contexts/DropFileZoneContext.js";
19
- import "../../contexts/LayoutContainerContext.js";
20
- import "../../contexts/DimensionPagesContext.js";
21
- import "../../contexts/LocalizationContext.js";
22
- import "../../contexts/HighlightContext.js";
23
- import "../../contexts/LicenseContext.js";
24
- import "../../contexts/DownloadContext.js";
25
- import "../../contexts/SmoothScrollContext.js";
26
- import "../../contexts/ElementPageContext.js";
27
- import "../../contexts/PagesRotateContext.js";
28
- import "../../contexts/GlobalCurrentPage.js";
29
- import "../../contexts/LoaderContext.js";
30
- import "../../contexts/ToolComponentContext.js";
31
- import "../../contexts/IconToolContext.js";
32
- import "../../contexts/OtherToolContext.js";
33
- import "../../contexts/EventCallbackContext.js";
34
- import "../RPConfig.js";
35
- import "../layout/Container.js";
36
- import "../../contexts/ViewportContext.js";
37
- import "../../contexts/ToolbarComponentContext.js";
38
- import "../layout/sidebar/RPSplitter.js";
39
- import "../layout/WrapperLayout.js";
40
- import "../../LayoutWrapper-6224491f.js";
41
- import "../../contexts/ThemeContext.js";
42
- import "../RPDropFileZone.js";
43
- import "../ui/Button.js";
44
- import "../../SearchCloseButton-08d57275.js";
45
- import "../ui/Input.js";
46
- import "../ui/Checkbox.js";
47
- import "../icons/LoaderIcon.js";
48
- import "../../contexts/IconContext.js";
49
- import "../ui/RPTooltip.js";
50
- import "../ui/DropDown.js";
51
- import "../layout/toolbar/MenuItem.js";
52
- import "../layout/toolbar/MenuSeparator.js";
53
- import "../../utils/dateFormatter.js";
54
- import "../layout/toolbar/PropertyItem.js";
55
- import "../../RotateTool.module-67946714.js";
1
+ import { jsx as l } from "react/jsx-runtime";
2
+ import { useRef as p, useEffect as x } from "react";
3
+ import { useDocumentContext as C } from "../../contexts/RPDocumentContext.js";
4
+ import { useZoomContext as R } from "../../contexts/ZoomContext.js";
5
+ import { usePagesRotateContext as q } from "../../contexts/PagesRotateContext.js";
6
+ import { useRenderQueue as L } from "../../contexts/RenderQueueProvider.js";
7
+ import { useInitialStateContext as k } from "../../contexts/InitialStateContext.js";
56
8
  import "../../utils/hooks/useLoadPdf.js";
57
9
  import "pdfjs-dist";
58
10
  import "../../utils/types.js";
59
11
  import "../../th_TH-d627cd51.js";
60
12
  import "../../utils/getThumbnailViewport.js";
61
13
  import "../../contexts/ConfigContext.js";
14
+ import "../../contexts/DocumentPasswordContext.js";
62
15
  import "../../utils/appConsole.js";
63
16
  import "../../utils/hooks/usePdfProperties.js";
64
17
  import "../../utils/convertPdfDate.js";
65
18
  import "../../utils/formatFileSize.js";
66
- import "../icons/ChevronUpIcon.js";
67
- import "../../utils/highlight.js";
68
- import "../../utils/charators.js";
69
- import "../../utils/Queue.js";
70
- import "../../utils/renderPage.js";
71
- import "../icons/Thumbnail.js";
72
- import "../../clsx-0c6e471a.js";
73
- import "../../utils/withRef.js";
74
- import "../../utils/hooks/useInfiniteScroll.js";
75
19
  import "../../utils/constants.js";
76
- import "../../utils/link_service.js";
77
- import "../../utils/annotations.js";
78
- import "../../utils/sanitizeExternalUrl.js";
79
- import "./searchHighlight.js";
80
- import "../../utils/const.js";
81
- import "./CustomElement.js";
82
20
  import "../../utils/getZoomLevel.js";
21
+ import "../../contexts/LayoutContainerContext.js";
22
+ import "../../contexts/ViewModeContext.js";
23
+ import "../../contexts/RotationContext.js";
24
+ import "../../contexts/GlobalCurrentPage.js";
25
+ import "../../contexts/EventCallbackContext.js";
83
26
  import "../../utils/hooks/useDebounce.js";
84
- import "../../utils/hooks/useLicense.js";
27
+ import "../../utils/Queue.js";
28
+ import "../../utils/renderPage.js";
29
+ import "../../PaginationContext-9217cab4.js";
30
+ import "../../contexts/ScrollModeContext.js";
31
+ import "../../contexts/VirtualScrollContext.js";
32
+ import "../../contexts/VirtualGridContext.js";
33
+ import "../../utils/smoothScrollTo.js";
34
+ import "../../contexts/DimensionPagesContext.js";
35
+ import "../../contexts/SmoothScrollContext.js";
85
36
  import "../../utils/getScrollDistance.js";
86
- import "../../utils/getElementPositionInPage.js";
87
37
  import "../../utils/calculatePage.js";
88
- import "../../utils/hooks/useMousePressed.js";
89
- import "../../utils/hooks/useGrabScroll.js";
90
- import "../../utils/hooks/usePinch.js";
91
- import "../ui/PasswordModal.js";
92
- import "../../utils/hooks/useLocalization.js";
93
- import "../../utils/approximateFragtion.js";
94
- import "../../utils/getWordPositionInPage.js";
95
- import "../../utils/smoothScrollTo.js";
96
- import "../layout/toolbar/FileUploadTool.js";
97
- import "../icons/FileUploadDefaultIcon.js";
98
- import "../../index-a48ec088.js";
99
- import "../../index-c9a2990a.js";
100
- import "react-dom";
101
- import "../../index-808ea7bf.js";
102
- import "../layout/toolbar/DarkModeTool.js";
103
- import "../icons/MoonIcon.js";
104
- import "../icons/SunIcon.js";
105
- import "../../utils/hooks/useDarkMode.js";
106
- import "../icons/ThreeDotIcon.js";
107
- import "../icons/CloseIcon.js";
108
- import "../layout/toolbar/DocumentProperties.js";
109
- import "../icons/InfoIcon.js";
110
- import "../layout/toolbar/RotateTool.js";
111
- import "../icons/ClockwiseIcon.js";
112
- import "../../utils/hooks/useRotate.js";
113
- import "../layout/toolbar/ViewModeTool.js";
114
- import "../icons/SinglePageIcon.js";
115
- import "../icons/DualPageIcon.js";
116
- import "../icons/CheckIcon.js";
117
- import "../layout/toolbar/ScrollModeTool.js";
118
- import "../icons/PageScrollingIcon.js";
119
- import "../icons/VerticalScrollingIcon.js";
120
- import "../icons/HorizontalScrollingIcon.js";
121
- import "../icons/FileDownloadDefaultIcon.js";
122
- import "../icons/PrintDefaultIcon.js";
123
- import "../layout/toolbar/FullScreenTool.js";
124
- import "../icons/FullScreenIcon.js";
125
- import "../../utils/hooks/useFullScreen.js";
126
- import "../icons/GoToDownIcon.js";
127
- import "../layout/toolbar/SelectionModeTool.js";
128
- import "../icons/TextSelectionDefaultIcon.js";
129
- import "../icons/HandModeDefaultIcon.js";
130
- import "../icons/ZoomInIcon.js";
131
- import "../icons/ZoomOutIcon.js";
132
- import "../../utils/zoom.js";
133
- import "../icons/SearchIcon.js";
134
- import "../icons/ClearIcon.js";
135
- import "../../utils/hooks/useHighlight.js";
136
- import "../RPTheme.js";
137
- import "../../utils/hooks/useLoadWorker.js";
138
- import "../icons/LightPdfIcon.js";
139
- import "../icons/DarkPdfIcon.js";
38
+ const pt = (d) => {
39
+ const { pageNumber: t, onLoaded: n, onLoading: o } = d, r = p(null), { pages: e } = C(), { pageRotate: a } = q(), v = p(), { currentZoom: m } = R(), { interactiveForm: s } = k(), i = L(), u = p(`page-${t}`);
40
+ return x(() => {
41
+ if (!e || m === 0)
42
+ return;
43
+ const c = e.get(t);
44
+ if (r.current && c) {
45
+ const f = r.current;
46
+ f.hidden = !0;
47
+ const g = v.current;
48
+ g && g.cancel(), o && o(), i.enqueue(
49
+ u.current,
50
+ {
51
+ page: c.page,
52
+ canvasElem: f,
53
+ options: {
54
+ scale: m,
55
+ rotate: a[t],
56
+ renderForms: !0,
57
+ interactiveForm: s
58
+ },
59
+ onLoaded: n
60
+ },
61
+ 3
62
+ );
63
+ }
64
+ return () => {
65
+ i.removeQueue(u.current);
66
+ };
67
+ }, [e, t, a, m, o, n, i, s]), /* @__PURE__ */ l("canvas", { "data-rp": `page-${t}-canvas`, ref: r });
68
+ };
140
69
  export {
141
- Fo as CanvasLayer
70
+ pt as CanvasLayer
142
71
  };