@cannyminds/dms-file-viewers 0.5.0 → 0.6.0

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 (101) hide show
  1. package/dist/{chunk-DOOYIHGW.js → chunk-56PP5GHZ.js} +70 -18
  2. package/dist/chunk-56PP5GHZ.js.map +1 -0
  3. package/dist/{chunk-7BLEPGZ4.mjs → chunk-7AUCINV2.mjs} +70 -18
  4. package/dist/chunk-7AUCINV2.mjs.map +1 -0
  5. package/dist/chunk-A2MSWOEM.js +159 -0
  6. package/dist/chunk-A2MSWOEM.js.map +1 -0
  7. package/dist/{chunk-SBEFC7HP.js → chunk-CQ3HSM5S.js} +70 -18
  8. package/dist/chunk-CQ3HSM5S.js.map +1 -0
  9. package/dist/{chunk-QELOFQEB.js → chunk-D7LXG67Z.js} +135 -234
  10. package/dist/chunk-D7LXG67Z.js.map +1 -0
  11. package/dist/chunk-EAM7CURM.js +334 -0
  12. package/dist/chunk-EAM7CURM.js.map +1 -0
  13. package/dist/{chunk-SNEIVT4R.js → chunk-ETHSDRF5.js} +70 -18
  14. package/dist/chunk-ETHSDRF5.js.map +1 -0
  15. package/dist/{chunk-RE4XRGSV.js → chunk-FA5L62Y5.js} +52 -32
  16. package/dist/chunk-FA5L62Y5.js.map +1 -0
  17. package/dist/chunk-GMDRDOWP.mjs +159 -0
  18. package/dist/chunk-GMDRDOWP.mjs.map +1 -0
  19. package/dist/{chunk-4DJJINTB.mjs → chunk-KBST5Z5H.mjs} +69 -17
  20. package/dist/chunk-KBST5Z5H.mjs.map +1 -0
  21. package/dist/{chunk-WP55NYFS.js → chunk-LQVHD4FS.js} +71 -19
  22. package/dist/chunk-LQVHD4FS.js.map +1 -0
  23. package/dist/chunk-M57PSU4O.mjs +36 -0
  24. package/dist/chunk-M57PSU4O.mjs.map +1 -0
  25. package/dist/{chunk-YHMHDPLQ.mjs → chunk-PFJKVNUA.mjs} +69 -17
  26. package/dist/chunk-PFJKVNUA.mjs.map +1 -0
  27. package/dist/{chunk-677DWENS.mjs → chunk-THFHTTQX.mjs} +64 -17
  28. package/dist/chunk-THFHTTQX.mjs.map +1 -0
  29. package/dist/chunk-U4W524VZ.mjs +334 -0
  30. package/dist/chunk-U4W524VZ.mjs.map +1 -0
  31. package/dist/{chunk-77UARJVQ.js → chunk-UUM656JE.js} +66 -19
  32. package/dist/chunk-UUM656JE.js.map +1 -0
  33. package/dist/{chunk-QQDQJ7TS.mjs → chunk-VJFXCN5Z.mjs} +50 -30
  34. package/dist/chunk-VJFXCN5Z.mjs.map +1 -0
  35. package/dist/{chunk-BHMFZTZ7.mjs → chunk-WNZHGFNC.mjs} +69 -17
  36. package/dist/chunk-WNZHGFNC.mjs.map +1 -0
  37. package/dist/chunk-YEPEMLM3.js +36 -0
  38. package/dist/chunk-YEPEMLM3.js.map +1 -0
  39. package/dist/{chunk-K5SKH4SD.mjs → chunk-ZKGWS327.mjs} +70 -169
  40. package/dist/chunk-ZKGWS327.mjs.map +1 -0
  41. package/dist/components/viewers/AudioViewer.d.mts +1 -1
  42. package/dist/components/viewers/AudioViewer.d.ts +1 -1
  43. package/dist/components/viewers/AudioViewer.js +4 -3
  44. package/dist/components/viewers/AudioViewer.js.map +1 -1
  45. package/dist/components/viewers/AudioViewer.mjs +3 -2
  46. package/dist/components/viewers/DefaultViewer.d.mts +1 -1
  47. package/dist/components/viewers/DefaultViewer.d.ts +1 -1
  48. package/dist/components/viewers/DefaultViewer.js +4 -3
  49. package/dist/components/viewers/DefaultViewer.js.map +1 -1
  50. package/dist/components/viewers/DefaultViewer.mjs +3 -2
  51. package/dist/components/viewers/ImageViewer.d.mts +1 -1
  52. package/dist/components/viewers/ImageViewer.d.ts +1 -1
  53. package/dist/components/viewers/ImageViewer.js +4 -4
  54. package/dist/components/viewers/ImageViewer.mjs +3 -3
  55. package/dist/components/viewers/PDFViewer.d.mts +1 -1
  56. package/dist/components/viewers/PDFViewer.d.ts +1 -1
  57. package/dist/components/viewers/PDFViewer.js +5 -3
  58. package/dist/components/viewers/PDFViewer.js.map +1 -1
  59. package/dist/components/viewers/PDFViewer.mjs +4 -2
  60. package/dist/components/viewers/TIFFViewer.d.mts +1 -1
  61. package/dist/components/viewers/TIFFViewer.d.ts +1 -1
  62. package/dist/components/viewers/TIFFViewer.js +4 -3
  63. package/dist/components/viewers/TIFFViewer.js.map +1 -1
  64. package/dist/components/viewers/TIFFViewer.mjs +3 -2
  65. package/dist/components/viewers/TextViewer.d.mts +1 -1
  66. package/dist/components/viewers/TextViewer.d.ts +1 -1
  67. package/dist/components/viewers/TextViewer.js +4 -3
  68. package/dist/components/viewers/TextViewer.js.map +1 -1
  69. package/dist/components/viewers/TextViewer.mjs +3 -2
  70. package/dist/components/viewers/VideoViewer.d.mts +1 -1
  71. package/dist/components/viewers/VideoViewer.d.ts +1 -1
  72. package/dist/components/viewers/VideoViewer.js +4 -3
  73. package/dist/components/viewers/VideoViewer.js.map +1 -1
  74. package/dist/components/viewers/VideoViewer.mjs +3 -2
  75. package/dist/index.d.mts +2 -2
  76. package/dist/index.d.ts +2 -2
  77. package/dist/index.js +14 -11
  78. package/dist/index.js.map +1 -1
  79. package/dist/index.mjs +12 -9
  80. package/dist/index.mjs.map +1 -1
  81. package/dist/{types-C6IEfcTM.d.mts → types-BmZB9kkJ.d.mts} +13 -1
  82. package/dist/{types-C6IEfcTM.d.ts → types-BmZB9kkJ.d.ts} +13 -1
  83. package/package.json +1 -1
  84. package/dist/chunk-4DJJINTB.mjs.map +0 -1
  85. package/dist/chunk-677DWENS.mjs.map +0 -1
  86. package/dist/chunk-6ZBHO5SP.js +0 -294
  87. package/dist/chunk-6ZBHO5SP.js.map +0 -1
  88. package/dist/chunk-77UARJVQ.js.map +0 -1
  89. package/dist/chunk-7BLEPGZ4.mjs.map +0 -1
  90. package/dist/chunk-BHMFZTZ7.mjs.map +0 -1
  91. package/dist/chunk-DOOYIHGW.js.map +0 -1
  92. package/dist/chunk-K5SKH4SD.mjs.map +0 -1
  93. package/dist/chunk-QELOFQEB.js.map +0 -1
  94. package/dist/chunk-QQDQJ7TS.mjs.map +0 -1
  95. package/dist/chunk-RE4XRGSV.js.map +0 -1
  96. package/dist/chunk-SBEFC7HP.js.map +0 -1
  97. package/dist/chunk-SNEIVT4R.js.map +0 -1
  98. package/dist/chunk-UX6U3H7J.mjs +0 -294
  99. package/dist/chunk-UX6U3H7J.mjs.map +0 -1
  100. package/dist/chunk-WP55NYFS.js.map +0 -1
  101. package/dist/chunk-YHMHDPLQ.mjs.map +0 -1
@@ -1,8 +1,11 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }"use client";
2
2
 
3
3
 
4
+ var _chunkYEPEMLM3js = require('./chunk-YEPEMLM3.js');
4
5
 
5
- var _chunkRE4XRGSVjs = require('./chunk-RE4XRGSV.js');
6
+
7
+
8
+ var _chunkFA5L62Y5js = require('./chunk-FA5L62Y5.js');
6
9
 
7
10
  // src/components/viewers/TextViewer.tsx
8
11
 
@@ -10,7 +13,7 @@ var _chunkRE4XRGSVjs = require('./chunk-RE4XRGSV.js');
10
13
 
11
14
 
12
15
 
13
- var _react = require('react');
16
+ var _react = require('react'); var _react2 = _interopRequireDefault(_react);
14
17
 
15
18
 
16
19
 
@@ -24,6 +27,8 @@ var _react = require('react');
24
27
 
25
28
  var _material = require('@mui/material');
26
29
  var _Download = require('@mui/icons-material/Download'); var _Download2 = _interopRequireDefault(_Download);
30
+ var _Print = require('@mui/icons-material/Print'); var _Print2 = _interopRequireDefault(_Print);
31
+ var _Fullscreen = require('@mui/icons-material/Fullscreen'); var _Fullscreen2 = _interopRequireDefault(_Fullscreen);
27
32
  var _Info = require('@mui/icons-material/Info'); var _Info2 = _interopRequireDefault(_Info);
28
33
  var _Description = require('@mui/icons-material/Description'); var _Description2 = _interopRequireDefault(_Description);
29
34
  var _jsxruntime = require('react/jsx-runtime');
@@ -39,38 +44,41 @@ var TextViewer = ({
39
44
  onLoad,
40
45
  onError,
41
46
  onDownloadClick,
47
+ onPrintClick,
42
48
  onMetadataClick,
43
49
  onPropertiesClick,
44
- showMetadata = true,
45
- showProperties = true,
50
+ showDownload = true,
51
+ showPrint = true,
52
+ showMetadata = false,
53
+ showProperties = false,
46
54
  // Extract props that shouldn't be passed to DOM elements
47
55
  mimeType,
48
56
  fileSize,
49
57
  showPageCount,
50
58
  showPageNavigation,
51
59
  showZoomControls,
52
- showDownload,
53
- showPrint,
54
60
  showSearch,
55
- onPrintClick,
56
61
  customRegistry,
57
62
  initialSearchText,
58
63
  initialSearchPages,
59
64
  autoOpenSearch,
60
65
  autoExecuteSearch,
61
66
  onSearchComplete,
67
+ toolbarActions,
62
68
  ...props
63
69
  }) => {
64
70
  const [content, setContent] = _react.useState.call(void 0, "");
65
71
  const [lines, setLines] = _react.useState.call(void 0, []);
66
72
  const [isLoading, setIsLoading] = _react.useState.call(void 0, false);
67
73
  const [error, setError] = _react.useState.call(void 0, null);
74
+ const [isFullScreen, setIsFullScreen] = _react.useState.call(void 0, false);
75
+ const containerRef = _react2.default.useRef(null);
68
76
  const resolvedFileName = _react.useMemo.call(void 0,
69
77
  () => fileName || _optionalChain([file, 'optionalAccess', _ => _.name]) || (url ? url.split("/").pop() : "text-document"),
70
78
  [fileName, file, url]
71
79
  );
72
80
  const fileExtension = _react.useMemo.call(void 0,
73
- () => _chunkRE4XRGSVjs.getFileExtension.call(void 0, resolvedFileName || ""),
81
+ () => _chunkYEPEMLM3js.getFileExtension.call(void 0, resolvedFileName || ""),
74
82
  [resolvedFileName]
75
83
  );
76
84
  const loadText = _react.useCallback.call(void 0, async () => {
@@ -109,9 +117,30 @@ var TextViewer = ({
109
117
  _react.useEffect.call(void 0, () => {
110
118
  void loadText();
111
119
  }, [loadText]);
120
+ const handleToggleFullScreen = () => {
121
+ if (!isFullScreen && _optionalChain([containerRef, 'access', _4 => _4.current, 'optionalAccess', _5 => _5.requestFullscreen])) {
122
+ containerRef.current.requestFullscreen();
123
+ setIsFullScreen(true);
124
+ } else if (isFullScreen && document.exitFullscreen) {
125
+ document.exitFullscreen();
126
+ setIsFullScreen(false);
127
+ }
128
+ };
129
+ const toolbar = _chunkFA5L62Y5js.mergeToolbarConfig.call(void 0, {
130
+ showDownload,
131
+ showPrint,
132
+ showMetadata,
133
+ showProperties,
134
+ onDownloadClick,
135
+ onPrintClick,
136
+ onMetadataClick,
137
+ onPropertiesClick,
138
+ toolbarActions
139
+ });
112
140
  return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
113
141
  _material.Box,
114
142
  {
143
+ ref: containerRef,
115
144
  className: `text-viewer ${className}`,
116
145
  sx: { width, height, ...style },
117
146
  ...props,
@@ -119,34 +148,57 @@ var TextViewer = ({
119
148
  /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
120
149
  _material.CardHeader,
121
150
  {
122
- avatar: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkRE4XRGSVjs.FileIcon_default, { ext: fileExtension, size: 32 }),
151
+ avatar: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkFA5L62Y5js.FileIcon_default, { ext: fileExtension, size: 32 }),
123
152
  title: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Typography, { variant: "subtitle1", fontWeight: 500, children: resolvedFileName }),
124
153
  action: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _material.Stack, { direction: "row", spacing: 1, children: [
125
- /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: "Download", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
154
+ !toolbar.isHidden("download") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("download") || "Download", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
126
155
  _material.IconButton,
127
156
  {
128
157
  size: "small",
129
- onClick: onDownloadClick,
158
+ onClick: toolbar.getHandler("download", onDownloadClick),
159
+ disabled: toolbar.isDisabled("download"),
130
160
  "aria-label": "Download text file",
131
- children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Download2.default, {})
161
+ children: toolbar.getIcon("download") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Download2.default, {})
162
+ }
163
+ ) }),
164
+ !toolbar.isHidden("print") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("print") || "Print", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
165
+ _material.IconButton,
166
+ {
167
+ size: "small",
168
+ onClick: toolbar.getHandler("print", onPrintClick),
169
+ disabled: toolbar.isDisabled("print"),
170
+ "aria-label": "Print text file",
171
+ children: toolbar.getIcon("print") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Print2.default, {})
172
+ }
173
+ ) }),
174
+ !toolbar.isHidden("fullscreen") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("fullscreen") || "Fullscreen", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
175
+ _material.IconButton,
176
+ {
177
+ size: "small",
178
+ onClick: toolbar.getHandler("fullscreen", handleToggleFullScreen),
179
+ disabled: toolbar.isDisabled("fullscreen"),
180
+ "aria-label": "Toggle fullscreen",
181
+ children: toolbar.getIcon("fullscreen") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Fullscreen2.default, {})
132
182
  }
133
183
  ) }),
134
- showMetadata && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: "Document Metadata", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
184
+ !toolbar.isHidden("metadata") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("metadata") || "Document Metadata", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
135
185
  _material.IconButton,
136
186
  {
137
187
  size: "small",
138
- onClick: onMetadataClick,
188
+ onClick: toolbar.getHandler("metadata", onMetadataClick),
189
+ disabled: toolbar.isDisabled("metadata"),
139
190
  "aria-label": "View document metadata",
140
- children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Info2.default, {})
191
+ children: toolbar.getIcon("metadata") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Description2.default, {})
141
192
  }
142
193
  ) }),
143
- showProperties && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: "Document Properties", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
194
+ !toolbar.isHidden("properties") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("properties") || "Document Properties", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
144
195
  _material.IconButton,
145
196
  {
146
197
  size: "small",
147
- onClick: onPropertiesClick,
198
+ onClick: toolbar.getHandler("properties", onPropertiesClick),
199
+ disabled: toolbar.isDisabled("properties"),
148
200
  "aria-label": "View document properties",
149
- children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Description2.default, {})
201
+ children: toolbar.getIcon("properties") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Info2.default, {})
150
202
  }
151
203
  ) })
152
204
  ] }),
@@ -180,4 +232,4 @@ var TextViewer = ({
180
232
 
181
233
 
182
234
  exports.TextViewer = TextViewer;
183
- //# sourceMappingURL=chunk-WP55NYFS.js.map
235
+ //# sourceMappingURL=chunk-LQVHD4FS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["d:\\Projects\\DMS-File-Viewers\\packages\\lib\\dist\\chunk-LQVHD4FS.js"],"names":[],"mappings":"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AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,wBAAA;AACA,UAAA;AACA,UAAA;AACA,YAAA;AACA,YAAA;AACA,YAAA;AACA,cAAA;AACA,gBAAA;AACA,gBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,gBAAA;AACA,cAAA;AACA,cAAA;AACA,gBAAA;AACA,gBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,gBAAA;AACA,cAAA;AACA,cAAA;AACA,gBAAA;AACA,gBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,gBAAA;AACA,cAAA;AACA,cAAA;AACA,gBAAA;AACA,gBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,gBAAA;AACA,cAAA;AACA,cAAA;AACA,gBAAA;AACA,gBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,kBAAA;AACA,gBAAA;AACA,cAAA;AACA,YAAA;AACA,YAAA;AACA,UAAA;AACA,QAAA;AACA,QAAA;AACA,QAAA;AACA,wBAAA;AACA,wBAAA;AACA,UAAA;AACA,UAAA;AACA,UAAA;AACA,UAAA;AACA,QAAA;AACA,UAAA;AACA,UAAA;AACA,YAAA;AACA,cAAA;AACA,cAAA;AACA,YAAA;AACA,YAAA;AACA,UAAA;AACA,UAAA;AACA,QAAA;AACA,MAAA;AACA,IAAA;AACA,EAAA;AACA;AACA;AACA;AACA;AACA","file":"D:\\Projects\\DMS-File-Viewers\\packages\\lib\\dist\\chunk-LQVHD4FS.js","sourcesContent":[null]}
@@ -0,0 +1,36 @@
1
+ "use client";
2
+
3
+ // src/utils/fileUtils.ts
4
+ var getFileExtension = (fileName) => {
5
+ const extension = fileName.toLowerCase().split(".").pop();
6
+ return extension || "";
7
+ };
8
+ var getMimeTypeFromExtension = (extension) => {
9
+ const mimeTypes = {
10
+ "pdf": "application/pdf",
11
+ "txt": "text/plain",
12
+ "json": "application/json",
13
+ "xml": "text/xml",
14
+ "csv": "text/csv",
15
+ "jpg": "image/jpeg",
16
+ "jpeg": "image/jpeg",
17
+ "png": "image/png",
18
+ "gif": "image/gif",
19
+ "svg": "image/svg+xml",
20
+ "mp4": "video/mp4",
21
+ "webm": "video/webm",
22
+ "mp3": "audio/mpeg",
23
+ "wav": "audio/wav",
24
+ "doc": "application/msword",
25
+ "docx": "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
26
+ "xls": "application/vnd.ms-excel",
27
+ "xlsx": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
28
+ };
29
+ return mimeTypes[extension] || "application/octet-stream";
30
+ };
31
+
32
+ export {
33
+ getFileExtension,
34
+ getMimeTypeFromExtension
35
+ };
36
+ //# sourceMappingURL=chunk-M57PSU4O.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/fileUtils.ts"],"sourcesContent":["export const getFileExtension = (fileName: string): string => {\r\n const extension = fileName.toLowerCase().split('.').pop();\r\n return extension || '';\r\n};\r\n\r\nexport const getMimeTypeFromExtension = (extension: string): string => {\r\n const mimeTypes: Record<string, string> = {\r\n 'pdf': 'application/pdf',\r\n 'txt': 'text/plain',\r\n 'json': 'application/json',\r\n 'xml': 'text/xml',\r\n 'csv': 'text/csv',\r\n 'jpg': 'image/jpeg',\r\n 'jpeg': 'image/jpeg',\r\n 'png': 'image/png',\r\n 'gif': 'image/gif',\r\n 'svg': 'image/svg+xml',\r\n 'mp4': 'video/mp4',\r\n 'webm': 'video/webm',\r\n 'mp3': 'audio/mpeg',\r\n 'wav': 'audio/wav',\r\n 'doc': 'application/msword',\r\n 'docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\r\n 'xls': 'application/vnd.ms-excel',\r\n 'xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n };\r\n\r\n return mimeTypes[extension] || 'application/octet-stream';\r\n};"],"mappings":";;;AAAO,IAAM,mBAAmB,CAAC,aAA6B;AAC5D,QAAM,YAAY,SAAS,YAAY,EAAE,MAAM,GAAG,EAAE,IAAI;AACxD,SAAO,aAAa;AACtB;AAEO,IAAM,2BAA2B,CAAC,cAA8B;AACrE,QAAM,YAAoC;AAAA,IACxC,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,QAAQ;AAAA,EACV;AAEA,SAAO,UAAU,SAAS,KAAK;AACjC;","names":[]}
@@ -1,8 +1,11 @@
1
1
  "use client";
2
2
  import {
3
- FileIcon_default,
4
3
  getFileExtension
5
- } from "./chunk-QQDQJ7TS.mjs";
4
+ } from "./chunk-M57PSU4O.mjs";
5
+ import {
6
+ FileIcon_default,
7
+ mergeToolbarConfig
8
+ } from "./chunk-VJFXCN5Z.mjs";
6
9
 
7
10
  // src/components/viewers/TIFFViewer.tsx
8
11
  import {
@@ -24,6 +27,8 @@ import {
24
27
  IconButton
25
28
  } from "@mui/material";
26
29
  import DownloadIcon from "@mui/icons-material/Download";
30
+ import PrintIcon from "@mui/icons-material/Print";
31
+ import FullscreenIcon from "@mui/icons-material/Fullscreen";
27
32
  import FirstPageIcon from "@mui/icons-material/FirstPage";
28
33
  import LastPageIcon from "@mui/icons-material/LastPage";
29
34
  import ChevronLeftIcon from "@mui/icons-material/ChevronLeft";
@@ -93,18 +98,27 @@ var TIFFViewerContent = ({
93
98
  onLoad,
94
99
  onError,
95
100
  onDownloadClick,
101
+ onPrintClick,
96
102
  onMetadataClick,
97
103
  onPropertiesClick,
98
- showMetadata = true,
99
- showProperties = true,
104
+ showDownload = true,
105
+ showPrint = true,
106
+ showMetadata = false,
107
+ showProperties = false,
100
108
  // Extract props that shouldn't be passed to DOM elements
101
109
  mimeType,
102
110
  fileSize,
111
+ showPageCount,
112
+ showPageNavigation,
113
+ showZoomControls,
114
+ showSearch,
115
+ customRegistry,
103
116
  initialSearchText,
104
117
  initialSearchPages,
105
118
  autoOpenSearch,
106
119
  autoExecuteSearch,
107
120
  onSearchComplete,
121
+ toolbarActions,
108
122
  ...props
109
123
  }) => {
110
124
  const [frames, setFrames] = useState([]);
@@ -115,7 +129,9 @@ var TIFFViewerContent = ({
115
129
  const [zoom, setZoom] = useState(1);
116
130
  const [viewportWidth, setViewportWidth] = useState(0);
117
131
  const [viewportHeight, setViewportHeight] = useState(0);
132
+ const [isFullScreen, setIsFullScreen] = useState(false);
118
133
  const viewportRef = useRef(null);
134
+ const containerRef = useRef(null);
119
135
  const resolvedFileName = useMemo(
120
136
  () => fileName || sourceDescription,
121
137
  [fileName, sourceDescription]
@@ -230,6 +246,16 @@ var TIFFViewerContent = ({
230
246
  const handleNextPage = useCallback(() => {
231
247
  setCurrentIndex((index) => Math.min(index + 1, frames.length - 1));
232
248
  }, [frames.length]);
249
+ const handleToggleFullScreen = useCallback(() => {
250
+ if (!isFullScreen && containerRef.current?.requestFullscreen) {
251
+ containerRef.current.requestFullscreen();
252
+ setIsFullScreen(true);
253
+ } else if (isFullScreen && document.exitFullscreen) {
254
+ document.exitFullscreen();
255
+ setIsFullScreen(false);
256
+ }
257
+ }, [isFullScreen]);
258
+ const toolbar = mergeToolbarConfig({ showDownload, showPrint, showMetadata, showProperties, onDownloadClick, onPrintClick, onMetadataClick, onPropertiesClick, toolbarActions });
233
259
  const effectiveScale = useMemo(() => {
234
260
  if (!currentFrame) {
235
261
  return 1;
@@ -287,6 +313,7 @@ var TIFFViewerContent = ({
287
313
  return /* @__PURE__ */ jsx(
288
314
  Box,
289
315
  {
316
+ ref: containerRef,
290
317
  className: `tiff-viewer ${className}`,
291
318
  sx: {
292
319
  width,
@@ -408,34 +435,59 @@ var TIFFViewerContent = ({
408
435
  }
409
436
  ),
410
437
  /* @__PURE__ */ jsx(Divider, { orientation: "vertical", flexItem: true, sx: { mx: 1 } }),
411
- /* @__PURE__ */ jsx(
438
+ !toolbar.isHidden("download") && /* @__PURE__ */ jsx(
412
439
  IconButton,
413
440
  {
414
441
  size: "small",
415
- onClick: onDownloadClick,
416
- title: "Download",
442
+ onClick: toolbar.getHandler("download", onDownloadClick),
443
+ disabled: toolbar.isDisabled("download"),
444
+ title: toolbar.getLabel("download") || "Download",
417
445
  "aria-label": "Download TIFF",
418
- children: /* @__PURE__ */ jsx(DownloadIcon, { fontSize: "small" })
446
+ children: toolbar.getIcon("download") || /* @__PURE__ */ jsx(DownloadIcon, { fontSize: "small" })
447
+ }
448
+ ),
449
+ !toolbar.isHidden("print") && /* @__PURE__ */ jsx(
450
+ IconButton,
451
+ {
452
+ size: "small",
453
+ onClick: toolbar.getHandler("print", onPrintClick),
454
+ disabled: toolbar.isDisabled("print"),
455
+ title: toolbar.getLabel("print") || "Print",
456
+ "aria-label": "Print TIFF",
457
+ children: toolbar.getIcon("print") || /* @__PURE__ */ jsx(PrintIcon, { fontSize: "small" })
458
+ }
459
+ ),
460
+ !toolbar.isHidden("fullscreen") && /* @__PURE__ */ jsx(
461
+ IconButton,
462
+ {
463
+ size: "small",
464
+ onClick: toolbar.getHandler("fullscreen", handleToggleFullScreen),
465
+ disabled: toolbar.isDisabled("fullscreen"),
466
+ title: toolbar.getLabel("fullscreen") || "Fullscreen",
467
+ "aria-label": "Toggle fullscreen",
468
+ children: toolbar.getIcon("fullscreen") || /* @__PURE__ */ jsx(FullscreenIcon, { fontSize: "small" })
419
469
  }
420
470
  ),
421
- showMetadata && /* @__PURE__ */ jsx(
471
+ !toolbar.isHidden("metadata") && /* @__PURE__ */ jsx(
422
472
  IconButton,
423
473
  {
424
474
  size: "small",
425
- onClick: onMetadataClick,
426
- title: "Document Metadata",
475
+ onClick: toolbar.getHandler("metadata", onMetadataClick),
476
+ disabled: toolbar.isDisabled("metadata"),
477
+ title: toolbar.getLabel("metadata") || "Document Metadata",
427
478
  "aria-label": "View document metadata",
428
- children: /* @__PURE__ */ jsx(InfoIcon, { fontSize: "small" })
479
+ children: toolbar.getIcon("metadata") || /* @__PURE__ */ jsx(DescriptionIcon, { fontSize: "small" })
429
480
  }
430
481
  ),
431
- showProperties && /* @__PURE__ */ jsx(
482
+ !toolbar.isHidden("properties") && /* @__PURE__ */ jsx(
432
483
  IconButton,
433
484
  {
434
485
  size: "small",
435
- onClick: onPropertiesClick,
436
- title: "Document Properties",
486
+ onClick: toolbar.getHandler("properties", onPropertiesClick),
487
+ disabled: toolbar.isDisabled("properties"),
488
+ title: toolbar.getLabel("properties") || "Document Properties",
437
489
  "aria-label": "View document properties",
438
- children: /* @__PURE__ */ jsx(DescriptionIcon, { fontSize: "small" })
490
+ children: toolbar.getIcon("properties") || /* @__PURE__ */ jsx(InfoIcon, { fontSize: "small" })
439
491
  }
440
492
  )
441
493
  ] }) }),
@@ -490,4 +542,4 @@ var TIFFViewer = (props) => {
490
542
  export {
491
543
  TIFFViewer
492
544
  };
493
- //# sourceMappingURL=chunk-YHMHDPLQ.mjs.map
545
+ //# sourceMappingURL=chunk-PFJKVNUA.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/viewers/TIFFViewer.tsx"],"sourcesContent":["import React, {\r\n useCallback,\r\n useEffect,\r\n useMemo,\r\n useRef,\r\n useState\r\n} from 'react';\r\nimport {\r\n Box,\r\n Button,\r\n ButtonGroup,\r\n Card,\r\n CardContent,\r\n CardHeader,\r\n Divider,\r\n LinearProgress,\r\n Stack,\r\n Typography,\r\n IconButton,\r\n Tooltip\r\n} from '@mui/material';\r\nimport DownloadIcon from '@mui/icons-material/Download';\r\nimport PrintIcon from '@mui/icons-material/Print';\r\nimport FullscreenIcon from '@mui/icons-material/Fullscreen';\r\nimport FirstPageIcon from '@mui/icons-material/FirstPage';\r\nimport LastPageIcon from '@mui/icons-material/LastPage';\r\nimport ChevronLeftIcon from '@mui/icons-material/ChevronLeft';\r\nimport ChevronRightIcon from '@mui/icons-material/ChevronRight';\r\nimport ZoomInIcon from '@mui/icons-material/ZoomIn';\r\nimport ZoomOutIcon from '@mui/icons-material/ZoomOut';\r\nimport FitScreenIcon from '@mui/icons-material/FitScreen';\r\nimport AspectRatioIcon from '@mui/icons-material/AspectRatio';\r\nimport InfoIcon from '@mui/icons-material/Info';\r\nimport DescriptionIcon from '@mui/icons-material/Description';\r\nimport * as UTIF from 'utif';\r\nimport { FileViewerProps } from '../../types';\r\nimport { getFileExtension } from '../../utils/fileUtils';\r\nimport { mergeToolbarConfig } from '../../utils/toolbarUtils';\r\nimport FileIcon from '../FileIcon';\r\n\r\ninterface TiffFrame {\r\n dataUrl: string;\r\n width: number;\r\n height: number;\r\n}\r\n\r\nconst decodeTiff = (buffer: ArrayBuffer): TiffFrame[] => {\r\n if (typeof window === 'undefined') {\r\n return [];\r\n }\r\n\r\n const frames: TiffFrame[] = [];\r\n const images = UTIF.decode(buffer);\r\n\r\n images.forEach((image) => {\r\n try {\r\n UTIF.decodeImage(buffer, image);\r\n const rgba = UTIF.toRGBA8(image);\r\n const width = image.width || 0;\r\n const height = image.height || 0;\r\n\r\n if (!width || !height) {\r\n return;\r\n }\r\n\r\n const canvas = document.createElement('canvas');\r\n canvas.width = width;\r\n canvas.height = height;\r\n const context = canvas.getContext('2d');\r\n\r\n if (!context) {\r\n return;\r\n }\r\n\r\n const clamped = new Uint8ClampedArray(rgba.length);\r\n clamped.set(rgba);\r\n const imageData = new ImageData(clamped, width, height);\r\n context.putImageData(imageData, 0, 0);\r\n frames.push({ dataUrl: canvas.toDataURL('image/png'), width, height });\r\n } catch (error) {\r\n // Skip frames that fail to decode\r\n }\r\n });\r\n\r\n return frames;\r\n};\r\n\r\nconst resolveDocumentName = (file?: File, fileName?: string, url?: string) => {\r\n if (file?.name) {\r\n return file.name;\r\n }\r\n if (fileName) {\r\n return fileName;\r\n }\r\n if (url) {\r\n const parts = url.split('?')[0]?.split('#')[0]?.split('/') ?? [];\r\n return parts[parts.length - 1] || 'document.tiff';\r\n }\r\n return 'document.tiff';\r\n};\r\n\r\ninterface TIFFViewerContentProps extends FileViewerProps {\r\n sourceDescription: string;\r\n}\r\n\r\nconst TIFFViewerContent: React.FC<TIFFViewerContentProps> = ({\r\n sourceDescription,\r\n file,\r\n url,\r\n fileName,\r\n className = '',\r\n style = {},\r\n width = '100%',\r\n height = '100%',\r\n onLoad,\r\n onError,\r\n onDownloadClick,\r\n onPrintClick,\r\n onMetadataClick,\r\n onPropertiesClick,\r\n showDownload = true,\r\n showPrint = true,\r\n showMetadata = false,\r\n showProperties = false,\r\n // Extract props that shouldn't be passed to DOM elements\r\n mimeType,\r\n fileSize,\r\n showPageCount,\r\n showPageNavigation,\r\n showZoomControls,\r\n showSearch,\r\n customRegistry,\r\n initialSearchText,\r\n initialSearchPages,\r\n autoOpenSearch,\r\n autoExecuteSearch,\r\n onSearchComplete,\r\n toolbarActions,\r\n ...props\r\n}) => {\r\n const [frames, setFrames] = useState<TiffFrame[]>([]);\r\n const [currentIndex, setCurrentIndex] = useState(0);\r\n const [isLoading, setIsLoading] = useState(false);\r\n const [error, setError] = useState<string | null>(null);\r\n const [fitMode, setFitMode] = useState<'fit-width' | 'fit-page' | 'zoom'>('fit-page');\r\n const [zoom, setZoom] = useState(1);\r\n const [viewportWidth, setViewportWidth] = useState<number>(0);\r\n const [viewportHeight, setViewportHeight] = useState<number>(0);\r\n const [isFullScreen, setIsFullScreen] = useState(false);\r\n const viewportRef = useRef<HTMLDivElement | null>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n\r\n const resolvedFileName = useMemo(\r\n () => fileName || sourceDescription,\r\n [fileName, sourceDescription]\r\n );\r\n\r\n const fileExtension = useMemo(\r\n () => getFileExtension(resolvedFileName || ''),\r\n [resolvedFileName]\r\n );\r\n\r\n const loadTiff = useCallback(async () => {\r\n if (!file && !url) {\r\n setFrames([]);\r\n setCurrentIndex(0);\r\n setError(null);\r\n return;\r\n }\r\n\r\n if (typeof window === 'undefined') {\r\n return;\r\n }\r\n\r\n setIsLoading(true);\r\n setError(null);\r\n\r\n try {\r\n let buffer: ArrayBuffer;\r\n if (file) {\r\n buffer = await file.arrayBuffer();\r\n } else {\r\n const response = await fetch(url!);\r\n if (!response.ok) {\r\n throw new Error(`Failed to fetch TIFF (${response.status})`);\r\n }\r\n buffer = await response.arrayBuffer();\r\n }\r\n\r\n const decodedFrames = decodeTiff(buffer);\r\n setFrames(decodedFrames);\r\n setCurrentIndex(0);\r\n setFitMode('fit-page');\r\n setZoom(1);\r\n\r\n if (decodedFrames.length > 0) {\r\n onLoad?.();\r\n } else {\r\n setError('No displayable frames detected in TIFF file.');\r\n }\r\n } catch (err) {\r\n const message = err instanceof Error ? err.message : 'Unable to load TIFF file';\r\n setError(message);\r\n setFrames([]);\r\n setCurrentIndex(0);\r\n setFitMode('fit-page');\r\n setZoom(1);\r\n onError?.(new Error(message));\r\n } finally {\r\n setIsLoading(false);\r\n }\r\n }, [file, url, onLoad, onError]);\r\n\r\n useEffect(() => {\r\n void loadTiff();\r\n }, [loadTiff]);\r\n\r\n const currentFrame = frames[currentIndex];\r\n const hasFrames = frames.length > 0;\r\n const hasMultipleFrames = frames.length > 1;\r\n\r\n useEffect(() => {\r\n if (hasFrames) {\r\n setZoom(1);\r\n setFitMode('fit-page');\r\n }\r\n }, [currentIndex, hasFrames]);\r\n\r\n useEffect(() => {\r\n if (typeof window === 'undefined' || typeof ResizeObserver === 'undefined') {\r\n return undefined;\r\n }\r\n\r\n if (!viewportRef.current) {\r\n return undefined;\r\n }\r\n\r\n const updateSize = () => {\r\n const bounds = viewportRef.current?.getBoundingClientRect();\r\n if (bounds) {\r\n setViewportWidth(bounds.width);\r\n setViewportHeight(bounds.height);\r\n }\r\n };\r\n\r\n updateSize();\r\n const observer = new ResizeObserver(updateSize);\r\n observer.observe(viewportRef.current);\r\n\r\n return () => {\r\n observer.disconnect();\r\n };\r\n }, []);\r\n\r\n const handleZoomIn = useCallback(() => {\r\n setFitMode('zoom');\r\n setZoom((value) => Math.min(Math.round((value + 0.25) * 100) / 100, 5));\r\n }, []);\r\n\r\n const handleZoomOut = useCallback(() => {\r\n setFitMode('zoom');\r\n setZoom((value) => Math.max(Math.round((value - 0.25) * 100) / 100, 0.25));\r\n }, []);\r\n\r\n const handleFitWidth = useCallback(() => {\r\n setFitMode('fit-width');\r\n setZoom(1);\r\n }, []);\r\n\r\n const handleFitPage = useCallback(() => {\r\n setFitMode('fit-page');\r\n setZoom(1);\r\n }, []);\r\n\r\n const handleFirstPage = useCallback(() => {\r\n setCurrentIndex(0);\r\n }, []);\r\n\r\n const handleLastPage = useCallback(() => {\r\n setCurrentIndex(frames.length - 1);\r\n }, [frames.length]);\r\n\r\n const handlePreviousPage = useCallback(() => {\r\n setCurrentIndex((index) => Math.max(index - 1, 0));\r\n }, []);\r\n\r\n const handleNextPage = useCallback(() => {\r\n setCurrentIndex((index) => Math.min(index + 1, frames.length - 1));\r\n }, [frames.length]);\r\n\r\n const handleToggleFullScreen = useCallback(() => {\r\n if (!isFullScreen && containerRef.current?.requestFullscreen) {\r\n containerRef.current.requestFullscreen();\r\n setIsFullScreen(true);\r\n } else if (isFullScreen && document.exitFullscreen) {\r\n document.exitFullscreen();\r\n setIsFullScreen(false);\r\n }\r\n }, [isFullScreen]);\r\n\r\n const toolbar = mergeToolbarConfig({ showDownload, showPrint, showMetadata, showProperties, onDownloadClick, onPrintClick, onMetadataClick, onPropertiesClick, toolbarActions });\r\n\r\n const effectiveScale = useMemo(() => {\r\n if (!currentFrame) {\r\n return 1;\r\n }\r\n\r\n if (fitMode === 'zoom') {\r\n return zoom;\r\n }\r\n\r\n const frameWidth = currentFrame.width;\r\n const frameHeight = currentFrame.height;\r\n\r\n if (!viewportWidth || !viewportHeight || !frameWidth || !frameHeight) {\r\n return 1;\r\n }\r\n\r\n if (fitMode === 'fit-page') {\r\n const ratio = Math.min(viewportWidth / frameWidth, viewportHeight / frameHeight);\r\n return ratio || 1;\r\n }\r\n\r\n const widthRatio = viewportWidth / frameWidth;\r\n return widthRatio || 1;\r\n }, [currentFrame, fitMode, viewportWidth, viewportHeight, zoom]);\r\n\r\n const displayScale = useMemo(() => Math.round(effectiveScale * 100), [effectiveScale]);\r\n\r\n const renderImage = () => {\r\n if (!currentFrame) {\r\n return (\r\n <Typography variant=\"body2\" color=\"text.secondary\">\r\n No TIFF frame available.\r\n </Typography>\r\n );\r\n }\r\n\r\n const widthPx = currentFrame.width * effectiveScale;\r\n const heightPx = currentFrame.height * effectiveScale;\r\n\r\n return (\r\n <Box\r\n sx={{\r\n position: 'relative',\r\n width: widthPx,\r\n height: heightPx,\r\n borderRadius: 1,\r\n boxShadow: 1,\r\n backgroundColor: '#fff'\r\n }}\r\n >\r\n <Box\r\n component=\"img\"\r\n src={currentFrame.dataUrl}\r\n alt={`${resolvedFileName} page ${currentIndex + 1}`}\r\n sx={{\r\n width: widthPx,\r\n height: heightPx,\r\n display: 'block',\r\n borderRadius: 1\r\n }}\r\n />\r\n </Box>\r\n );\r\n };\r\n\r\n return (\r\n <Box\r\n ref={containerRef}\r\n className={`tiff-viewer ${className}`}\r\n sx={{\r\n width,\r\n height,\r\n display: 'flex',\r\n flexDirection: 'column',\r\n overflow: 'hidden',\r\n ...style\r\n }}\r\n {...props}\r\n >\r\n <Card sx={{ height: '100%', width: '100%', display: 'flex', flexDirection: 'column', overflow: 'hidden' }} elevation={1}>\r\n <CardHeader\r\n avatar={<FileIcon ext={fileExtension} size={32} />}\r\n title={\r\n <Typography variant=\"subtitle1\" fontWeight={500}>\r\n {resolvedFileName}\r\n </Typography>\r\n }\r\n sx={{ pb: 1 }}\r\n />\r\n\r\n {/* Toolbar - All Controls at Top (Centered) */}\r\n <Box sx={{ px: 2, pb: 1, display: 'flex', justifyContent: 'center' }}>\r\n <Stack direction=\"row\" spacing={1} alignItems=\"center\" flexWrap=\"wrap\" gap={1}>\r\n {/* Page Navigation */}\r\n {hasMultipleFrames && (\r\n <>\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleFirstPage}\r\n disabled={currentIndex === 0}\r\n title=\"First Page\"\r\n aria-label=\"Go to first page\"\r\n >\r\n <FirstPageIcon fontSize=\"small\" />\r\n </IconButton>\r\n <IconButton\r\n size=\"small\"\r\n onClick={handlePreviousPage}\r\n disabled={currentIndex === 0}\r\n title=\"Previous Page\"\r\n aria-label=\"Go to previous page\"\r\n >\r\n <ChevronLeftIcon fontSize=\"small\" />\r\n </IconButton>\r\n <Typography variant=\"body2\" color=\"text.secondary\" sx={{ minWidth: 100, textAlign: 'center' }}>\r\n Page {currentIndex + 1} of {frames.length}\r\n </Typography>\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleNextPage}\r\n disabled={currentIndex === frames.length - 1}\r\n title=\"Next Page\"\r\n aria-label=\"Go to next page\"\r\n >\r\n <ChevronRightIcon fontSize=\"small\" />\r\n </IconButton>\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleLastPage}\r\n disabled={currentIndex === frames.length - 1}\r\n title=\"Last Page\"\r\n aria-label=\"Go to last page\"\r\n >\r\n <LastPageIcon fontSize=\"small\" />\r\n </IconButton>\r\n <Divider orientation=\"vertical\" flexItem sx={{ mx: 1 }} />\r\n </>\r\n )}\r\n\r\n {/* Zoom Controls */}\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleZoomOut}\r\n disabled={!hasFrames || zoom <= 0.25}\r\n title=\"Zoom Out\"\r\n aria-label=\"Zoom out\"\r\n >\r\n <ZoomOutIcon fontSize=\"small\" />\r\n </IconButton>\r\n <Typography variant=\"body2\" color=\"text.secondary\" sx={{ minWidth: 64, textAlign: 'center' }}>\r\n {hasFrames ? `${displayScale}%` : '—'}\r\n </Typography>\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleZoomIn}\r\n disabled={!hasFrames || zoom >= 5}\r\n title=\"Zoom In\"\r\n aria-label=\"Zoom in\"\r\n >\r\n <ZoomInIcon fontSize=\"small\" />\r\n </IconButton>\r\n\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleFitWidth}\r\n disabled={!hasFrames}\r\n title=\"Fit to Width\"\r\n aria-label=\"Fit to width\"\r\n color={fitMode === 'fit-width' ? 'primary' : 'default'}\r\n >\r\n <AspectRatioIcon fontSize=\"small\" />\r\n </IconButton>\r\n\r\n <IconButton\r\n size=\"small\"\r\n onClick={handleFitPage}\r\n disabled={!hasFrames}\r\n title=\"Fit to Page\"\r\n aria-label=\"Fit to page\"\r\n color={fitMode === 'fit-page' ? 'primary' : 'default'}\r\n >\r\n <FitScreenIcon fontSize=\"small\" />\r\n </IconButton>\r\n\r\n <Divider orientation=\"vertical\" flexItem sx={{ mx: 1 }} />\r\n\r\n {/* Actions */}\r\n {!toolbar.isHidden('download') && (\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler('download', onDownloadClick)}\r\n disabled={toolbar.isDisabled('download')}\r\n title={toolbar.getLabel('download') || \"Download\"}\r\n aria-label=\"Download TIFF\"\r\n >\r\n {toolbar.getIcon('download') || <DownloadIcon fontSize=\"small\" />}\r\n </IconButton>\r\n )}\r\n\r\n {!toolbar.isHidden('print') && (\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler('print', onPrintClick)}\r\n disabled={toolbar.isDisabled('print')}\r\n title={toolbar.getLabel('print') || \"Print\"}\r\n aria-label=\"Print TIFF\"\r\n >\r\n {toolbar.getIcon('print') || <PrintIcon fontSize=\"small\" />}\r\n </IconButton>\r\n )}\r\n\r\n {!toolbar.isHidden('fullscreen') && (\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler('fullscreen', handleToggleFullScreen)}\r\n disabled={toolbar.isDisabled('fullscreen')}\r\n title={toolbar.getLabel('fullscreen') || \"Fullscreen\"}\r\n aria-label=\"Toggle fullscreen\"\r\n >\r\n {toolbar.getIcon('fullscreen') || <FullscreenIcon fontSize=\"small\" />}\r\n </IconButton>\r\n )}\r\n\r\n {!toolbar.isHidden('metadata') && (\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler('metadata', onMetadataClick)}\r\n disabled={toolbar.isDisabled('metadata')}\r\n title={toolbar.getLabel('metadata') || \"Document Metadata\"}\r\n aria-label=\"View document metadata\"\r\n >\r\n {toolbar.getIcon('metadata') || <DescriptionIcon fontSize=\"small\" />}\r\n </IconButton>\r\n )}\r\n\r\n {!toolbar.isHidden('properties') && (\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler('properties', onPropertiesClick)}\r\n disabled={toolbar.isDisabled('properties')}\r\n title={toolbar.getLabel('properties') || \"Document Properties\"}\r\n aria-label=\"View document properties\"\r\n >\r\n {toolbar.getIcon('properties') || <InfoIcon fontSize=\"small\" />}\r\n </IconButton>\r\n )}\r\n </Stack>\r\n </Box>\r\n\r\n {isLoading && <LinearProgress sx={{ mx: 3, mb: 1 }} />}\r\n {error && (\r\n <Typography color=\"error\" variant=\"body2\" sx={{ px: 3, pb: 1 }}>\r\n {error}\r\n </Typography>\r\n )}\r\n <Divider />\r\n <CardContent\r\n sx={{\r\n flexGrow: 1,\r\n flexShrink: 1,\r\n minHeight: 0,\r\n p: 0,\r\n overflow: 'auto',\r\n backgroundColor: '#f6f8fa',\r\n position: 'relative'\r\n }}\r\n >\r\n <Box\r\n ref={viewportRef}\r\n sx={{\r\n position: 'absolute',\r\n top: 0,\r\n left: 0,\r\n right: 0,\r\n bottom: 0,\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n p: 3,\r\n overflow: 'auto'\r\n }}\r\n >\r\n {renderImage()}\r\n </Box>\r\n </CardContent>\r\n </Card>\r\n </Box>\r\n );\r\n};\r\n\r\nexport const TIFFViewer: React.FC<FileViewerProps> = (props) => {\r\n const sourceDescription = useMemo(\r\n () => resolveDocumentName(props.file, props.fileName, props.url),\r\n [props.file, props.fileName, props.url]\r\n );\r\n\r\n return <TIFFViewerContent {...props} sourceDescription={sourceDescription} />;\r\n};\r\n"],"mappings":"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","names":[]}
@@ -1,13 +1,18 @@
1
1
  "use client";
2
2
  import {
3
- FileIcon_default,
4
3
  getFileExtension
5
- } from "./chunk-QQDQJ7TS.mjs";
4
+ } from "./chunk-M57PSU4O.mjs";
5
+ import {
6
+ FileIcon_default,
7
+ mergeToolbarConfig
8
+ } from "./chunk-VJFXCN5Z.mjs";
6
9
 
7
10
  // src/components/viewers/DefaultViewer.tsx
8
- import { useMemo } from "react";
11
+ import React, { useMemo } from "react";
9
12
  import { Box, Card, CardContent, CardHeader, Typography, IconButton, Tooltip, Stack } from "@mui/material";
10
13
  import DownloadIcon from "@mui/icons-material/Download";
14
+ import PrintIcon from "@mui/icons-material/Print";
15
+ import FullscreenIcon from "@mui/icons-material/Fullscreen";
11
16
  import InfoIcon from "@mui/icons-material/Info";
12
17
  import DescriptionIcon from "@mui/icons-material/Description";
13
18
  import { jsx, jsxs } from "react/jsx-runtime";
@@ -27,18 +32,36 @@ var DefaultViewer = ({
27
32
  showPageCount,
28
33
  showPageNavigation,
29
34
  showZoomControls,
30
- showDownload,
31
- showPrint,
35
+ showDownload = true,
36
+ showPrint = true,
32
37
  showSearch,
33
- showMetadata,
34
- showProperties,
38
+ showMetadata = false,
39
+ showProperties = false,
35
40
  onMetadataClick,
36
41
  onPropertiesClick,
37
42
  onPrintClick,
38
43
  onDownloadClick,
39
44
  customRegistry,
45
+ initialSearchText,
46
+ initialSearchPages,
47
+ autoOpenSearch,
48
+ autoExecuteSearch,
49
+ onSearchComplete,
50
+ toolbarActions,
40
51
  ...props
41
52
  }) => {
53
+ const [isFullScreen, setIsFullScreen] = React.useState(false);
54
+ const containerRef = React.useRef(null);
55
+ const handleToggleFullScreen = () => {
56
+ if (!isFullScreen && containerRef.current?.requestFullscreen) {
57
+ containerRef.current.requestFullscreen();
58
+ setIsFullScreen(true);
59
+ } else if (isFullScreen && document.exitFullscreen) {
60
+ document.exitFullscreen();
61
+ setIsFullScreen(false);
62
+ }
63
+ };
64
+ const toolbar = mergeToolbarConfig({ ...props, showDownload, showPrint, showMetadata, showProperties, onMetadataClick, onPropertiesClick, onPrintClick, onDownloadClick, toolbarActions });
42
65
  const resolvedFileName = useMemo(
43
66
  () => fileName || file?.name || (url ? url.split("/").pop() : "unknown-file"),
44
67
  [fileName, file, url]
@@ -50,6 +73,7 @@ var DefaultViewer = ({
50
73
  return /* @__PURE__ */ jsx(
51
74
  Box,
52
75
  {
76
+ ref: containerRef,
53
77
  className: `default-viewer ${className}`,
54
78
  sx: { width, height, ...style },
55
79
  ...props,
@@ -60,31 +84,54 @@ var DefaultViewer = ({
60
84
  avatar: /* @__PURE__ */ jsx(FileIcon_default, { ext: fileExtension, size: 32 }),
61
85
  title: /* @__PURE__ */ jsx(Typography, { variant: "subtitle1", fontWeight: 500, children: resolvedFileName }),
62
86
  action: /* @__PURE__ */ jsxs(Stack, { direction: "row", spacing: 1, children: [
63
- /* @__PURE__ */ jsx(Tooltip, { title: "Download", children: /* @__PURE__ */ jsx(
87
+ !toolbar.isHidden("download") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("download") || "Download", children: /* @__PURE__ */ jsx(
64
88
  IconButton,
65
89
  {
66
90
  size: "small",
67
- onClick: onDownloadClick,
91
+ onClick: toolbar.getHandler("download", onDownloadClick),
92
+ disabled: toolbar.isDisabled("download"),
68
93
  "aria-label": "Download file",
69
- children: /* @__PURE__ */ jsx(DownloadIcon, {})
94
+ children: toolbar.getIcon("download") || /* @__PURE__ */ jsx(DownloadIcon, {})
95
+ }
96
+ ) }),
97
+ !toolbar.isHidden("print") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("print") || "Print", children: /* @__PURE__ */ jsx(
98
+ IconButton,
99
+ {
100
+ size: "small",
101
+ onClick: toolbar.getHandler("print", onPrintClick),
102
+ disabled: toolbar.isDisabled("print"),
103
+ "aria-label": "Print file",
104
+ children: toolbar.getIcon("print") || /* @__PURE__ */ jsx(PrintIcon, {})
105
+ }
106
+ ) }),
107
+ !toolbar.isHidden("fullscreen") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("fullscreen") || "Fullscreen", children: /* @__PURE__ */ jsx(
108
+ IconButton,
109
+ {
110
+ size: "small",
111
+ onClick: toolbar.getHandler("fullscreen", handleToggleFullScreen),
112
+ disabled: toolbar.isDisabled("fullscreen"),
113
+ "aria-label": "Toggle fullscreen",
114
+ children: toolbar.getIcon("fullscreen") || /* @__PURE__ */ jsx(FullscreenIcon, {})
70
115
  }
71
116
  ) }),
72
- showMetadata && /* @__PURE__ */ jsx(Tooltip, { title: "Document Metadata", children: /* @__PURE__ */ jsx(
117
+ !toolbar.isHidden("metadata") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("metadata") || "Document Metadata", children: /* @__PURE__ */ jsx(
73
118
  IconButton,
74
119
  {
75
120
  size: "small",
76
- onClick: onMetadataClick,
121
+ onClick: toolbar.getHandler("metadata", onMetadataClick),
122
+ disabled: toolbar.isDisabled("metadata"),
77
123
  "aria-label": "View document metadata",
78
- children: /* @__PURE__ */ jsx(InfoIcon, {})
124
+ children: toolbar.getIcon("metadata") || /* @__PURE__ */ jsx(DescriptionIcon, {})
79
125
  }
80
126
  ) }),
81
- showProperties && /* @__PURE__ */ jsx(Tooltip, { title: "Document Properties", children: /* @__PURE__ */ jsx(
127
+ !toolbar.isHidden("properties") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("properties") || "Document Properties", children: /* @__PURE__ */ jsx(
82
128
  IconButton,
83
129
  {
84
130
  size: "small",
85
- onClick: onPropertiesClick,
131
+ onClick: toolbar.getHandler("properties", onPropertiesClick),
132
+ disabled: toolbar.isDisabled("properties"),
86
133
  "aria-label": "View document properties",
87
- children: /* @__PURE__ */ jsx(DescriptionIcon, {})
134
+ children: toolbar.getIcon("properties") || /* @__PURE__ */ jsx(InfoIcon, {})
88
135
  }
89
136
  ) })
90
137
  ] }),
@@ -130,4 +177,4 @@ var DefaultViewer = ({
130
177
  export {
131
178
  DefaultViewer
132
179
  };
133
- //# sourceMappingURL=chunk-677DWENS.mjs.map
180
+ //# sourceMappingURL=chunk-THFHTTQX.mjs.map