@react-pdf-kit/viewer 2.0.0-beta.1 → 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 (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 +23 -20
  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,19 +1,21 @@
1
- import "react/jsx-runtime";
2
- import "react";
3
- import "../../icons/Thumbnail.js";
4
- import "../../ui/Button.js";
5
- import { a0 as Eo } from "../../../ToolbarLayout.module-37619c4b.js";
6
- import "./RPSplitter.js";
7
- import "../../../contexts/ToolbarComponentContext.js";
8
- import "../../../contexts/IconContext.js";
9
- import "../../ui/RPTooltip.js";
10
- import "../../../contexts/LocalizationContext.js";
11
- import "../../../contexts/IconToolContext.js";
12
- import "../../../utils/constants.js";
1
+ import { jsx as t, Fragment as f, jsxs as l } from "react/jsx-runtime";
2
+ import { useState as T, useRef as s, useCallback as C, useMemo as I } from "react";
3
+ import { ThumbnailIcon as _ } from "../../icons/Thumbnail.js";
4
+ import { UIButton as w } from "../../ui/Button.js";
5
+ import { Thumbnails as x } from "./Thumbnails.js";
6
+ import { RPSplitter as R } from "./RPSplitter.js";
7
+ import { useThumbnailContext as v } from "../../../contexts/ThumbnailsContext.js";
8
+ import { useToolbarComponentContext as N } from "../../../contexts/ToolbarComponentContext.js";
9
+ import { useIconContext as S } from "../../../contexts/IconContext.js";
10
+ import k from "../../ui/RPTooltip.js";
11
+ import { useLocalizationContext as z } from "../../../contexts/LocalizationContext.js";
12
+ import { useIconToolContext as q } from "../../../contexts/IconToolContext.js";
13
+ import { THUMBNAIL_MIN_WIDTH as y } from "../../../utils/constants.js";
13
14
  import "../../../clsx-0c6e471a.js";
14
15
  import "../../../utils/withRef.js";
15
- import "../../icons/ChevronUpIcon.js";
16
- import "../../ui/Input.js";
16
+ import "./Thumbnail.js";
17
+ import "../../icons/LoaderIcon.js";
18
+ import "../../../PaginationContext-9217cab4.js";
17
19
  import "../../../utils/types.js";
18
20
  import "../../../th_TH-d627cd51.js";
19
21
  import "../../../contexts/ScrollModeContext.js";
@@ -28,115 +30,83 @@ import "../../../contexts/DocumentPasswordContext.js";
28
30
  import "../../../utils/hooks/usePdfProperties.js";
29
31
  import "../../../utils/convertPdfDate.js";
30
32
  import "../../../utils/formatFileSize.js";
31
- import "../../../contexts/DarkModeContext.js";
32
- import "../../../utils/hooks/useDarkMode.js";
33
- import "../../../contexts/RotationContext.js";
34
- import "../../../contexts/LayerContext.js";
35
- import "../../../contexts/ZoomContext.js";
36
- import "../../../utils/getZoomLevel.js";
37
- import "../../../contexts/LayoutContainerContext.js";
38
- import "../../../contexts/ViewModeContext.js";
39
33
  import "../../../contexts/GlobalCurrentPage.js";
40
34
  import "../../../contexts/EventCallbackContext.js";
41
- import "../../../utils/hooks/useDebounce.js";
35
+ import "../../../contexts/ViewModeContext.js";
42
36
  import "../../../contexts/VirtualScrollContext.js";
43
37
  import "../../../contexts/VirtualGridContext.js";
44
- import "../../../contexts/SelectionModeContext.js";
45
- import "../../../contexts/FullScreenContext.js";
46
- import "../../../utils/hooks/useFullScreen.js";
47
- import "../../../contexts/FileInputContext.js";
48
- import "../../../contexts/DropFileZoneContext.js";
49
- import "../../../contexts/ToolComponentContext.js";
50
- import "../../../utils/highlight.js";
51
- import "../../../utils/charators.js";
38
+ import "../../../utils/smoothScrollTo.js";
52
39
  import "../../../contexts/DimensionPagesContext.js";
40
+ import "../../../contexts/ZoomContext.js";
41
+ import "../../../utils/getZoomLevel.js";
42
+ import "../../../contexts/LayoutContainerContext.js";
43
+ import "../../../contexts/RotationContext.js";
44
+ import "../../../utils/hooks/useDebounce.js";
53
45
  import "../../../contexts/PagesRotateContext.js";
54
- import "../../../contexts/HighlightContext.js";
55
- import "../../../utils/hooks/useHighlight.js";
56
- import "../../../contexts/LicenseContext.js";
57
- import "../../../utils/hooks/useLicense.js";
58
- import "../../../contexts/DownloadContext.js";
59
46
  import "../../../contexts/SmoothScrollContext.js";
60
- import "../../../contexts/ElementPageContext.js";
61
- import "../../../utils/const.js";
62
47
  import "../../../utils/getScrollDistance.js";
63
- import "../../../utils/getElementPositionInPage.js";
48
+ import "../../../utils/calculatePage.js";
49
+ import "../../../contexts/RenderQueueProvider.js";
64
50
  import "../../../utils/Queue.js";
65
51
  import "../../../utils/renderPage.js";
66
- import "../../../contexts/LoaderContext.js";
67
- import "../../icons/LoaderIcon.js";
68
- import "../../../contexts/OtherToolContext.js";
69
- import "../../RPConfig.js";
70
- import "../../RPTheme.js";
71
- import "../../../contexts/ThemeContext.js";
72
- import "../../../utils/hooks/useLoadWorker.js";
73
- import "../Container.js";
74
- import "../../../contexts/ViewportContext.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 "../../../utils/hooks/useLocalization.js";
81
- import "../../../SearchCloseButton-08d57275.js";
82
- import "../../icons/CloseIcon.js";
83
- import "../../ui/Checkbox.js";
84
- import "../../../index-c9a2990a.js";
85
- import "react-dom";
86
- import "../../icons/CheckIcon.js";
87
- import "../../ui/DropDown.js";
88
- import "../../../index-a48ec088.js";
89
- import "../../../index-808ea7bf.js";
90
- import "../toolbar/MenuItem.js";
91
- import "../toolbar/MenuSeparator.js";
92
- import "../../../utils/dateFormatter.js";
93
- import "../toolbar/PropertyItem.js";
94
- import "../../../RotateTool.module-67946714.js";
95
52
  import "../../../utils/hooks/useInfiniteScroll.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
- 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";
53
+ import "../../../utils/hooks/useThumbnail.js";
54
+ import "../../../index-c0faa594.js";
55
+ import "react-dom";
56
+ import "../../../index-e3ee9457.js";
57
+ import "../../../floating-ui.react-dom-5ec29bd6.js";
58
+ import "../../../index-655864a7.js";
59
+ import "../../../utils/hooks/useLocalization.js";
60
+ const n = {
61
+ "rp-sidebar-content-wrapper": "_rp-sidebar-content-wrapper_1bqgz_1",
62
+ "rp-sidebar-content": "_rp-sidebar-content_1bqgz_1",
63
+ "rp-thumbnails-wrapper": "_rp-thumbnails-wrapper_1bqgz_16"
64
+ }, B = () => {
65
+ const { thumbnailIcon: o } = S(), { thumbnailIcon: m } = q();
66
+ return o || m || /* @__PURE__ */ t(_, {});
67
+ }, Dt = () => {
68
+ const { active: o, setActive: m } = v(), [c, b] = T(y), e = s(null), a = s(null), { thumbnailTool: i, sidebarEnable: u } = N(), { localeMessages: r } = z(), p = C(() => {
69
+ m((d) => !d);
70
+ }, []), h = I(() => typeof i != "boolean" && i ? /* @__PURE__ */ t(i, { onClick: p, active: o }) : i ? /* @__PURE__ */ t(k, { content: r == null ? void 0 : r.thumbnailTooltip, children: /* @__PURE__ */ t(
71
+ w,
72
+ {
73
+ onClick: p,
74
+ active: o,
75
+ "aria-label": r == null ? void 0 : r.thumbnailTooltip,
76
+ children: /* @__PURE__ */ t(B, {})
77
+ }
78
+ ) }) : null, [i, o, p, r]);
79
+ return /* @__PURE__ */ t(f, { children: u && /* @__PURE__ */ l(
80
+ "div",
81
+ {
82
+ style: { "--rp-thumbnail-width": `${c}px` },
83
+ className: n["rp-sidebar-content-wrapper"],
84
+ "data-rp": "sidebar",
85
+ children: [
86
+ /* @__PURE__ */ t("div", { ref: a, className: n["rp-sidebar-content"], children: h }),
87
+ /* @__PURE__ */ l(
88
+ "div",
89
+ {
90
+ "data-rp": "thumbnailSidebar",
91
+ hidden: !o,
92
+ className: n["rp-thumbnails-wrapper"],
93
+ children: [
94
+ /* @__PURE__ */ t(x, { show: o, ref: e }),
95
+ /* @__PURE__ */ t(
96
+ R,
97
+ {
98
+ onWidthChange: b,
99
+ thumbnailRef: e,
100
+ leftSidebarRef: a
101
+ }
102
+ )
103
+ ]
104
+ }
105
+ )
106
+ ]
107
+ }
108
+ ) });
109
+ };
140
110
  export {
141
- Eo as RPSidebar
111
+ Dt as RPSidebar
142
112
  };
@@ -1,142 +1,136 @@
1
- import "react/jsx-runtime";
2
- import "react";
3
- import { $ as Fo } from "../../../ToolbarLayout.module-37619c4b.js";
4
- import "../../../clsx-0c6e471a.js";
5
- import "../../icons/LoaderIcon.js";
6
- import "../../../contexts/PagesRotateContext.js";
7
- import "../../../contexts/RPDocumentContext.js";
8
- import "../../../contexts/DocumentPasswordContext.js";
9
- import "../../../contexts/DarkModeContext.js";
10
- import "../../../contexts/RotationContext.js";
11
- import "../../../contexts/LayerContext.js";
12
- import "../../../contexts/ZoomContext.js";
13
- import "../../../contexts/ViewModeContext.js";
1
+ import { jsxs as S, jsx as r } from "react/jsx-runtime";
2
+ import { useRef as l, useState as y, useMemo as _, useCallback as L, useEffect as x } from "react";
3
+ import { c as j } from "../../../clsx-0c6e471a.js";
4
+ import { LoaderIcon as k } from "../../icons/LoaderIcon.js";
5
+ import { u as q } from "../../../PaginationContext-9217cab4.js";
6
+ import { usePagesRotateContext as I } from "../../../contexts/PagesRotateContext.js";
7
+ import { useRenderQueue as M } from "../../../contexts/RenderQueueProvider.js";
8
+ import { useDocumentContext as Q } from "../../../contexts/RPDocumentContext.js";
9
+ import "../../../utils/types.js";
10
+ import "../../../th_TH-d627cd51.js";
14
11
  import "../../../contexts/ScrollModeContext.js";
15
- import "../../../contexts/VirtualScrollContext.js";
16
- import "../../../contexts/VirtualGridContext.js";
17
- import "../../../contexts/SelectionModeContext.js";
12
+ import "../../../utils/appConsole.js";
18
13
  import "../../../contexts/InitialStateContext.js";
19
- import "../../../contexts/FullScreenContext.js";
20
- import "../../../contexts/FileInputContext.js";
21
- import "../../../contexts/DropFileZoneContext.js";
22
- import "../../../contexts/LayoutContainerContext.js";
23
- import "../../../contexts/DimensionPagesContext.js";
24
- import "../../../contexts/LocalizationContext.js";
25
- import "../../../contexts/HighlightContext.js";
26
- import "../../../contexts/LicenseContext.js";
27
- import "../../../contexts/DownloadContext.js";
28
- import "../../../contexts/SmoothScrollContext.js";
29
- import "../../../contexts/ElementPageContext.js";
30
14
  import "../../../contexts/GlobalCurrentPage.js";
31
- import "../../../contexts/LoaderContext.js";
32
- import "../../../contexts/ToolComponentContext.js";
33
- import "../../../contexts/IconToolContext.js";
34
- import "../../../contexts/OtherToolContext.js";
35
15
  import "../../../contexts/EventCallbackContext.js";
36
- import "../../RPConfig.js";
37
- import "../Container.js";
38
- import "../../../contexts/ViewportContext.js";
39
- import "../../../contexts/ToolbarComponentContext.js";
40
- import "./RPSplitter.js";
41
- import "../WrapperLayout.js";
42
- import "../../../LayoutWrapper-6224491f.js";
43
- import "../../../contexts/ThemeContext.js";
44
- import "../../RPDropFileZone.js";
45
- import "../../ui/Button.js";
46
- import "../../../SearchCloseButton-08d57275.js";
47
- import "../../ui/Input.js";
48
- import "../../ui/Checkbox.js";
49
- import "../../../contexts/IconContext.js";
50
- import "../../ui/RPTooltip.js";
51
- import "../../ui/DropDown.js";
52
- import "../toolbar/MenuItem.js";
53
- import "../toolbar/MenuSeparator.js";
54
- import "../../../utils/dateFormatter.js";
55
- import "../toolbar/PropertyItem.js";
56
- import "../../../RotateTool.module-67946714.js";
57
- import "../../icons/ChevronUpIcon.js";
58
- import "../../../utils/types.js";
59
- import "../../../th_TH-d627cd51.js";
60
- import "../../../utils/highlight.js";
61
- import "../../../utils/charators.js";
62
- import "../../../utils/Queue.js";
63
- import "../../../utils/renderPage.js";
64
- import "pdfjs-dist";
65
- import "../../icons/Thumbnail.js";
66
- import "../../../utils/withRef.js";
67
- import "../../../utils/hooks/useInfiniteScroll.js";
16
+ import "../../../contexts/ViewModeContext.js";
17
+ import "../../../contexts/VirtualScrollContext.js";
18
+ import "../../../contexts/VirtualGridContext.js";
19
+ import "../../../utils/smoothScrollTo.js";
20
+ import "../../../contexts/DimensionPagesContext.js";
21
+ import "../../../contexts/ZoomContext.js";
68
22
  import "../../../utils/constants.js";
69
- import "../../../utils/link_service.js";
70
- import "../../../utils/annotations.js";
71
- import "../../../utils/sanitizeExternalUrl.js";
72
- import "../../page/searchHighlight.js";
73
- import "../../../utils/const.js";
74
- import "../../page/CustomElement.js";
75
- import "../../../utils/appConsole.js";
23
+ import "../../../utils/getZoomLevel.js";
24
+ import "../../../contexts/LayoutContainerContext.js";
25
+ import "../../../contexts/RotationContext.js";
76
26
  import "../../../utils/hooks/useLoadPdf.js";
27
+ import "pdfjs-dist";
77
28
  import "../../../utils/getThumbnailViewport.js";
78
29
  import "../../../contexts/ConfigContext.js";
30
+ import "../../../contexts/DocumentPasswordContext.js";
79
31
  import "../../../utils/hooks/usePdfProperties.js";
80
32
  import "../../../utils/convertPdfDate.js";
81
33
  import "../../../utils/formatFileSize.js";
82
- import "../../../utils/getZoomLevel.js";
83
34
  import "../../../utils/hooks/useDebounce.js";
84
- import "../../../utils/hooks/useLicense.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 "../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 "../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 "../toolbar/DocumentProperties.js";
109
- import "../../icons/InfoIcon.js";
110
- import "../toolbar/RotateTool.js";
111
- import "../../icons/ClockwiseIcon.js";
112
- import "../../../utils/hooks/useRotate.js";
113
- import "../toolbar/ViewModeTool.js";
114
- import "../../icons/SinglePageIcon.js";
115
- import "../../icons/DualPageIcon.js";
116
- import "../../icons/CheckIcon.js";
117
- import "../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 "../toolbar/FullScreenTool.js";
124
- import "../../icons/FullScreenIcon.js";
125
- import "../../../utils/hooks/useFullScreen.js";
126
- import "../../icons/GoToDownIcon.js";
127
- import "../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
+ import "../../../utils/Queue.js";
39
+ import "../../../utils/renderPage.js";
40
+ const i = {
41
+ "rp-thumbnail-wrapper": "_rp-thumbnail-wrapper_3fenb_1",
42
+ "rp-thumbnail-text": "_rp-thumbnail-text_3fenb_10",
43
+ "rp-thumbnail": "_rp-thumbnail_3fenb_1",
44
+ "rp-thumbnail-active": "_rp-thumbnail-active_3fenb_22",
45
+ "rp-thumbnail-loader": "_rp-thumbnail-loader_3fenb_31"
46
+ }, Rt = (w) => {
47
+ const { pageNumber: t, isFocused: h, viewport: s } = w, { goToPage: b } = q(), { pageRotate: R } = I(), o = l(null), n = M(), { pages: m } = Q(), [a, f] = y(null), u = l(!1), d = l(), C = _(() => h ? i["rp-thumbnail-active"] : "", [h]), p = _(() => ({
48
+ width: Math.round(s.width),
49
+ height: Math.round(s.height)
50
+ }), [s]), P = L(() => {
51
+ t && b(t);
52
+ }, [b, t]);
53
+ return x(() => {
54
+ const e = m.get(t);
55
+ d.current === e || (f(null), d.current = e);
56
+ }, [m, t]), x(() => {
57
+ const e = m.get(t);
58
+ if (!o.current || !t || !e || a)
59
+ return;
60
+ const c = new IntersectionObserver(($) => {
61
+ $.forEach((E) => {
62
+ if (u.current) {
63
+ u.current = !1, n.removeQueue(`thumbnail-${t}`);
64
+ return;
65
+ }
66
+ if (E.isIntersecting) {
67
+ const g = document.createElement("canvas");
68
+ u.current = !0, n.enqueue(
69
+ `thumbnail-${t}`,
70
+ {
71
+ page: e.page,
72
+ canvasElem: g,
73
+ options: {
74
+ scale: 1
75
+ },
76
+ onLoaded: () => {
77
+ g.toBlob((v) => {
78
+ if (!v)
79
+ return;
80
+ const N = URL.createObjectURL(v);
81
+ f(N);
82
+ });
83
+ }
84
+ },
85
+ 2
86
+ );
87
+ }
88
+ });
89
+ });
90
+ return o.current && c.observe(o.current), () => {
91
+ c.disconnect(), n.removeQueue(`thumbnail-${t}`);
92
+ };
93
+ }, [n, t, m, a]), /* @__PURE__ */ S(
94
+ "div",
95
+ {
96
+ onClick: P,
97
+ id: `page-${t}`,
98
+ className: i["rp-thumbnail-wrapper"],
99
+ ref: o,
100
+ children: [
101
+ /* @__PURE__ */ r(
102
+ "div",
103
+ {
104
+ style: {
105
+ transform: `rotate(${R[t || 0]}deg)`
106
+ },
107
+ className: j(C, i["rp-thumbnail"]),
108
+ children: a ? /* @__PURE__ */ r(
109
+ "img",
110
+ {
111
+ src: a,
112
+ width: p.width,
113
+ height: p.height,
114
+ alt: "thumbnail"
115
+ }
116
+ ) : /* @__PURE__ */ r(
117
+ "div",
118
+ {
119
+ className: i["rp-thumbnail-loader"],
120
+ style: {
121
+ width: `${p.width}px`,
122
+ height: `${p.height}px`
123
+ },
124
+ children: /* @__PURE__ */ r(k, {})
125
+ }
126
+ )
127
+ }
128
+ ),
129
+ /* @__PURE__ */ r("div", { className: i["rp-thumbnail-text"], children: t })
130
+ ]
131
+ }
132
+ );
133
+ };
140
134
  export {
141
- Fo as Thumbnail
135
+ Rt as Thumbnail
142
136
  };