@cannymindstech/file-viewers 0.28.0 → 0.28.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/dist/chunk-2BLHLWNN.js +299 -0
  2. package/dist/chunk-2BLHLWNN.js.map +1 -0
  3. package/dist/chunk-4HVU224A.js +2454 -0
  4. package/dist/chunk-4HVU224A.js.map +1 -0
  5. package/dist/chunk-6BRYDA3B.js +329 -0
  6. package/dist/chunk-6BRYDA3B.js.map +1 -0
  7. package/dist/chunk-6L72TJIW.mjs +2454 -0
  8. package/dist/chunk-6L72TJIW.mjs.map +1 -0
  9. package/dist/chunk-7PMZ4GN5.mjs +290 -0
  10. package/dist/chunk-7PMZ4GN5.mjs.map +1 -0
  11. package/dist/chunk-B5NNB4KD.mjs +268 -0
  12. package/dist/chunk-B5NNB4KD.mjs.map +1 -0
  13. package/dist/chunk-CIWCHSAA.js +309 -0
  14. package/dist/chunk-CIWCHSAA.js.map +1 -0
  15. package/dist/chunk-D7SDEVDM.js +268 -0
  16. package/dist/chunk-D7SDEVDM.js.map +1 -0
  17. package/dist/chunk-EKNP342T.mjs +299 -0
  18. package/dist/chunk-EKNP342T.mjs.map +1 -0
  19. package/dist/chunk-EM63H4SA.js +290 -0
  20. package/dist/chunk-EM63H4SA.js.map +1 -0
  21. package/dist/chunk-IJMNPAXX.mjs +309 -0
  22. package/dist/chunk-IJMNPAXX.mjs.map +1 -0
  23. package/dist/chunk-JKX5RSLF.mjs +871 -0
  24. package/dist/chunk-JKX5RSLF.mjs.map +1 -0
  25. package/dist/chunk-KJNOBIUZ.mjs +36 -0
  26. package/dist/chunk-KJNOBIUZ.mjs.map +1 -0
  27. package/dist/chunk-KQLIG6WK.js +871 -0
  28. package/dist/chunk-KQLIG6WK.js.map +1 -0
  29. package/dist/chunk-KWHXS7I4.mjs +615 -0
  30. package/dist/chunk-KWHXS7I4.mjs.map +1 -0
  31. package/dist/chunk-NELCZBZV.js +489 -0
  32. package/dist/chunk-NELCZBZV.js.map +1 -0
  33. package/dist/chunk-OPJOCUSL.js +36 -0
  34. package/dist/chunk-OPJOCUSL.js.map +1 -0
  35. package/dist/chunk-S5KXYKBX.js +615 -0
  36. package/dist/chunk-S5KXYKBX.js.map +1 -0
  37. package/dist/chunk-W2P6JHTQ.mjs +489 -0
  38. package/dist/chunk-W2P6JHTQ.mjs.map +1 -0
  39. package/dist/chunk-XJQ5J2UF.mjs +329 -0
  40. package/dist/chunk-XJQ5J2UF.mjs.map +1 -0
  41. package/dist/components/viewers/AudioViewer.d.mts +6 -0
  42. package/dist/components/viewers/AudioViewer.d.ts +6 -0
  43. package/dist/components/viewers/AudioViewer.js +10 -0
  44. package/dist/components/viewers/AudioViewer.js.map +1 -0
  45. package/dist/components/viewers/AudioViewer.mjs +10 -0
  46. package/dist/components/viewers/AudioViewer.mjs.map +1 -0
  47. package/dist/components/viewers/DefaultViewer.d.mts +6 -0
  48. package/dist/components/viewers/DefaultViewer.d.ts +6 -0
  49. package/dist/components/viewers/DefaultViewer.js +10 -0
  50. package/dist/components/viewers/DefaultViewer.js.map +1 -0
  51. package/dist/components/viewers/DefaultViewer.mjs +10 -0
  52. package/dist/components/viewers/DefaultViewer.mjs.map +1 -0
  53. package/dist/components/viewers/ImageViewer.d.mts +6 -0
  54. package/dist/components/viewers/ImageViewer.d.ts +6 -0
  55. package/dist/components/viewers/ImageViewer.js +10 -0
  56. package/dist/components/viewers/ImageViewer.js.map +1 -0
  57. package/dist/components/viewers/ImageViewer.mjs +10 -0
  58. package/dist/components/viewers/ImageViewer.mjs.map +1 -0
  59. package/dist/components/viewers/PDFViewer.d.mts +51 -0
  60. package/dist/components/viewers/PDFViewer.d.ts +51 -0
  61. package/dist/components/viewers/PDFViewer.js +11 -0
  62. package/dist/components/viewers/PDFViewer.js.map +1 -0
  63. package/dist/components/viewers/PDFViewer.mjs +11 -0
  64. package/dist/components/viewers/PDFViewer.mjs.map +1 -0
  65. package/dist/components/viewers/TIFFViewer.d.mts +6 -0
  66. package/dist/components/viewers/TIFFViewer.d.ts +6 -0
  67. package/dist/components/viewers/TIFFViewer.js +10 -0
  68. package/dist/components/viewers/TIFFViewer.js.map +1 -0
  69. package/dist/components/viewers/TIFFViewer.mjs +10 -0
  70. package/dist/components/viewers/TIFFViewer.mjs.map +1 -0
  71. package/dist/components/viewers/TextViewer.d.mts +6 -0
  72. package/dist/components/viewers/TextViewer.d.ts +6 -0
  73. package/dist/components/viewers/TextViewer.js +10 -0
  74. package/dist/components/viewers/TextViewer.js.map +1 -0
  75. package/dist/components/viewers/TextViewer.mjs +10 -0
  76. package/dist/components/viewers/TextViewer.mjs.map +1 -0
  77. package/dist/components/viewers/VideoViewer.d.mts +6 -0
  78. package/dist/components/viewers/VideoViewer.d.ts +6 -0
  79. package/dist/components/viewers/VideoViewer.js +10 -0
  80. package/dist/components/viewers/VideoViewer.js.map +1 -0
  81. package/dist/components/viewers/VideoViewer.mjs +10 -0
  82. package/dist/components/viewers/VideoViewer.mjs.map +1 -0
  83. package/dist/index.d.mts +75 -0
  84. package/dist/index.d.ts +75 -0
  85. package/dist/index.js +305 -0
  86. package/dist/index.js.map +1 -0
  87. package/dist/index.mjs +305 -0
  88. package/dist/index.mjs.map +1 -0
  89. package/dist/types-DMF9gANJ.d.mts +101 -0
  90. package/dist/types-DMF9gANJ.d.ts +101 -0
  91. package/package.json +3 -2
@@ -0,0 +1,329 @@
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
+
3
+
4
+ var _chunkOPJOCUSLjs = require('./chunk-OPJOCUSL.js');
5
+
6
+
7
+
8
+ var _chunkEM63H4SAjs = require('./chunk-EM63H4SA.js');
9
+
10
+ // src/components/viewers/VideoViewer.tsx
11
+
12
+
13
+
14
+
15
+
16
+ var _react = require('react');
17
+
18
+
19
+
20
+
21
+
22
+
23
+
24
+
25
+
26
+
27
+ var _material = require('@mui/material');
28
+ var _Download = require('@mui/icons-material/Download'); var _Download2 = _interopRequireDefault(_Download);
29
+ var _Print = require('@mui/icons-material/Print'); var _Print2 = _interopRequireDefault(_Print);
30
+ var _Fullscreen = require('@mui/icons-material/Fullscreen'); var _Fullscreen2 = _interopRequireDefault(_Fullscreen);
31
+ var _Info = require('@mui/icons-material/Info'); var _Info2 = _interopRequireDefault(_Info);
32
+ var _Description = require('@mui/icons-material/Description'); var _Description2 = _interopRequireDefault(_Description);
33
+ var _History = require('@mui/icons-material/History'); var _History2 = _interopRequireDefault(_History);
34
+ var _iconsmaterial = require('@mui/icons-material');
35
+ var _jsxruntime = require('react/jsx-runtime');
36
+ var VideoViewer = ({
37
+ file,
38
+ url,
39
+ fileName,
40
+ className = "",
41
+ style = {},
42
+ width = "100%",
43
+ height = "100%",
44
+ onLoad,
45
+ onError,
46
+ onDownloadClick,
47
+ onPrintClick,
48
+ onMetadataClick,
49
+ onTagsClick,
50
+ onPropertiesClick,
51
+ onHistoryClick,
52
+ showDownload = true,
53
+ showPrint = false,
54
+ showMetadata = false,
55
+ showTags = true,
56
+ showProperties = false,
57
+ showHistory = true,
58
+ // Extract props that shouldn't be passed to DOM elements
59
+ mimeType,
60
+ fileSize,
61
+ showPageCount,
62
+ showPageNavigation,
63
+ showZoomControls,
64
+ showSearch,
65
+ customRegistry,
66
+ initialSearchText,
67
+ initialSearchPages,
68
+ autoOpenSearch,
69
+ autoExecuteSearch,
70
+ onSearchComplete,
71
+ toolbarActions,
72
+ ...props
73
+ }) => {
74
+ const videoRef = _react.useRef.call(void 0, null);
75
+ const containerRef = _react.useRef.call(void 0, null);
76
+ const [videoSource, setVideoSource] = _react.useState.call(void 0, null);
77
+ const [isLoading, setIsLoading] = _react.useState.call(void 0, false);
78
+ const [error, setError] = _react.useState.call(void 0, null);
79
+ const [videoDimensions, setVideoDimensions] = _react.useState.call(void 0, null);
80
+ const [isFullScreen, setIsFullScreen] = _react.useState.call(void 0, false);
81
+ _react.useEffect.call(void 0, () => {
82
+ let objectUrl = null;
83
+ if (file) {
84
+ objectUrl = URL.createObjectURL(file);
85
+ setVideoSource(objectUrl);
86
+ setIsLoading(true);
87
+ } else if (url) {
88
+ setVideoSource(url);
89
+ } else {
90
+ setVideoSource(null);
91
+ }
92
+ setError(null);
93
+ return () => {
94
+ if (objectUrl) {
95
+ URL.revokeObjectURL(objectUrl);
96
+ }
97
+ };
98
+ }, [file, url]);
99
+ _react.useEffect.call(void 0, () => {
100
+ const element = videoRef.current;
101
+ if (!element) {
102
+ return;
103
+ }
104
+ const handleLoaded = () => {
105
+ setIsLoading(false);
106
+ setVideoDimensions({
107
+ width: element.videoWidth,
108
+ height: element.videoHeight
109
+ });
110
+ _optionalChain([onLoad, 'optionalCall', _ => _()]);
111
+ };
112
+ const handleError = () => {
113
+ const message = "Failed to load video resource";
114
+ setIsLoading(false);
115
+ setError(message);
116
+ _optionalChain([onError, 'optionalCall', _2 => _2(new Error(message))]);
117
+ };
118
+ element.addEventListener("loadedmetadata", handleLoaded);
119
+ element.addEventListener("error", handleError);
120
+ return () => {
121
+ element.removeEventListener("loadedmetadata", handleLoaded);
122
+ element.removeEventListener("error", handleError);
123
+ };
124
+ }, [onLoad, onError, videoSource]);
125
+ const resolvedFileName = _react.useMemo.call(void 0,
126
+ () => fileName || _optionalChain([file, 'optionalAccess', _3 => _3.name]) || (url ? url.split("/").pop() : "video"),
127
+ [fileName, file, url]
128
+ );
129
+ const fileExtension = _react.useMemo.call(void 0,
130
+ () => _chunkOPJOCUSLjs.getFileExtension.call(void 0, resolvedFileName || ""),
131
+ [resolvedFileName]
132
+ );
133
+ const handleToggleFullScreen = () => {
134
+ if (!isFullScreen && _optionalChain([containerRef, 'access', _4 => _4.current, 'optionalAccess', _5 => _5.requestFullscreen])) {
135
+ containerRef.current.requestFullscreen();
136
+ setIsFullScreen(true);
137
+ } else if (isFullScreen && document.exitFullscreen) {
138
+ document.exitFullscreen();
139
+ setIsFullScreen(false);
140
+ }
141
+ };
142
+ const toolbar = _chunkEM63H4SAjs.mergeToolbarConfig.call(void 0, {
143
+ showDownload,
144
+ showPrint,
145
+ showMetadata,
146
+ showTags,
147
+ showProperties,
148
+ showHistory,
149
+ onDownloadClick,
150
+ onPrintClick,
151
+ onMetadataClick,
152
+ onTagsClick,
153
+ onPropertiesClick,
154
+ onHistoryClick,
155
+ toolbarActions
156
+ });
157
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
158
+ _material.Box,
159
+ {
160
+ ref: containerRef,
161
+ className: `video-viewer ${className}`,
162
+ sx: { width, height, ...style },
163
+ ...props,
164
+ children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
165
+ _material.Card,
166
+ {
167
+ sx: { height: "100%", display: "flex", flexDirection: "column" },
168
+ elevation: 1,
169
+ children: [
170
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
171
+ _material.CardHeader,
172
+ {
173
+ avatar: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkEM63H4SAjs.FileIcon_default, { ext: fileExtension, size: 32 }),
174
+ title: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Typography, { variant: "subtitle1", fontWeight: 500, children: resolvedFileName }),
175
+ action: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _material.Stack, { direction: "row", spacing: 1, children: [
176
+ !toolbar.isHidden("download") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("download") || "Download", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
177
+ _material.IconButton,
178
+ {
179
+ size: "small",
180
+ onClick: toolbar.getHandler("download", onDownloadClick),
181
+ disabled: toolbar.isDisabled("download"),
182
+ "aria-label": "Download video",
183
+ children: toolbar.getIcon("download") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Download2.default, {})
184
+ }
185
+ ) }),
186
+ !toolbar.isHidden("print") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("print") || "Print", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
187
+ _material.IconButton,
188
+ {
189
+ size: "small",
190
+ onClick: toolbar.getHandler("print", onPrintClick),
191
+ disabled: toolbar.isDisabled("print"),
192
+ "aria-label": "Print video",
193
+ children: toolbar.getIcon("print") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Print2.default, {})
194
+ }
195
+ ) }),
196
+ !toolbar.isHidden("fullscreen") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("fullscreen") || "Fullscreen", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
197
+ _material.IconButton,
198
+ {
199
+ size: "small",
200
+ onClick: toolbar.getHandler(
201
+ "fullscreen",
202
+ handleToggleFullScreen
203
+ ),
204
+ disabled: toolbar.isDisabled("fullscreen"),
205
+ "aria-label": "Toggle fullscreen",
206
+ children: toolbar.getIcon("fullscreen") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Fullscreen2.default, {})
207
+ }
208
+ ) }),
209
+ !toolbar.isHidden("metadata") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
210
+ _material.Tooltip,
211
+ {
212
+ title: toolbar.getLabel("metadata") || "Document Metadata",
213
+ children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
214
+ _material.IconButton,
215
+ {
216
+ size: "small",
217
+ onClick: toolbar.getHandler("metadata", onMetadataClick),
218
+ disabled: toolbar.isDisabled("metadata"),
219
+ "aria-label": "View document metadata",
220
+ children: toolbar.getIcon("metadata") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Description2.default, {})
221
+ }
222
+ )
223
+ }
224
+ ),
225
+ !toolbar.isHidden("properties") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
226
+ _material.Tooltip,
227
+ {
228
+ title: toolbar.getLabel("properties") || "Document Properties",
229
+ children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
230
+ _material.IconButton,
231
+ {
232
+ size: "small",
233
+ onClick: toolbar.getHandler(
234
+ "properties",
235
+ onPropertiesClick
236
+ ),
237
+ disabled: toolbar.isDisabled("properties"),
238
+ "aria-label": "View document properties",
239
+ children: toolbar.getIcon("properties") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _Info2.default, {})
240
+ }
241
+ )
242
+ }
243
+ ),
244
+ !toolbar.isHidden("tags") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Tooltip, { title: toolbar.getLabel("tags") || "Document Tags", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
245
+ _material.IconButton,
246
+ {
247
+ size: "small",
248
+ onClick: toolbar.getHandler("tags", onTagsClick),
249
+ disabled: toolbar.isDisabled("tags"),
250
+ "aria-label": "View document tags",
251
+ children: toolbar.getIcon("tags") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _iconsmaterial.LocalOffer, {})
252
+ }
253
+ ) }),
254
+ !toolbar.isHidden("history") && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
255
+ _material.Tooltip,
256
+ {
257
+ title: toolbar.getLabel("history") || "Document History",
258
+ children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
259
+ _material.IconButton,
260
+ {
261
+ size: "small",
262
+ onClick: toolbar.getHandler("history", onHistoryClick),
263
+ disabled: toolbar.isDisabled("history"),
264
+ "aria-label": "View document history",
265
+ children: toolbar.getIcon("history") || /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _History2.default, {})
266
+ }
267
+ )
268
+ }
269
+ )
270
+ ] }),
271
+ sx: { pb: 1.5 }
272
+ }
273
+ ),
274
+ isLoading && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.LinearProgress, { sx: { mx: 3, mb: 2 } }),
275
+ error && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Typography, { color: "error", variant: "body2", sx: { px: 3, pb: 1 }, children: error }),
276
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
277
+ _material.CardContent,
278
+ {
279
+ sx: {
280
+ flexGrow: 1,
281
+ display: "flex",
282
+ alignItems: "center",
283
+ justifyContent: "center",
284
+ p: 2,
285
+ overflow: "hidden"
286
+ },
287
+ children: videoSource ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
288
+ _material.Box,
289
+ {
290
+ sx: {
291
+ width: "100%",
292
+ height: "100%",
293
+ display: "flex",
294
+ alignItems: "center",
295
+ justifyContent: "center",
296
+ backgroundColor: "#000",
297
+ borderRadius: 2
298
+ },
299
+ children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
300
+ "video",
301
+ {
302
+ ref: videoRef,
303
+ controls: true,
304
+ controlsList: "nodownload",
305
+ style: {
306
+ maxWidth: "100%",
307
+ maxHeight: "100%",
308
+ width: "auto",
309
+ height: "auto",
310
+ objectFit: "contain"
311
+ },
312
+ src: videoSource
313
+ }
314
+ )
315
+ }
316
+ ) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _material.Typography, { variant: "body2", color: "text.secondary", children: "No video source provided." })
317
+ }
318
+ )
319
+ ]
320
+ }
321
+ )
322
+ }
323
+ );
324
+ };
325
+
326
+
327
+
328
+ exports.VideoViewer = VideoViewer;
329
+ //# sourceMappingURL=chunk-6BRYDA3B.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/premkumar/Documents/GitHub/DMS-File-Viewers/packages/lib/dist/chunk-6BRYDA3B.js","../src/components/viewers/VideoViewer.tsx"],"names":[],"mappings":"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","file":"/home/premkumar/Documents/GitHub/DMS-File-Viewers/packages/lib/dist/chunk-6BRYDA3B.js","sourcesContent":[null,"import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport {\n Box,\n Card,\n CardContent,\n CardHeader,\n LinearProgress,\n Typography,\n Stack,\n IconButton,\n Tooltip,\n} from \"@mui/material\";\nimport DownloadIcon from \"@mui/icons-material/Download\";\nimport PrintIcon from \"@mui/icons-material/Print\";\nimport FullscreenIcon from \"@mui/icons-material/Fullscreen\";\nimport InfoIcon from \"@mui/icons-material/Info\";\nimport DescriptionIcon from \"@mui/icons-material/Description\";\nimport HistoryIcon from \"@mui/icons-material/History\";\nimport { LocalOffer } from \"@mui/icons-material\";\nimport { FileViewerProps } from \"../../types\";\nimport { getFileExtension } from \"../../utils/fileUtils\";\nimport { mergeToolbarConfig } from \"../../utils/toolbarUtils\";\nimport FileIcon from \"../FileIcon\";\n\nexport const VideoViewer: React.FC<FileViewerProps> = ({\n file,\n url,\n fileName,\n className = \"\",\n style = {},\n width = \"100%\",\n height = \"100%\",\n onLoad,\n onError,\n onDownloadClick,\n onPrintClick,\n onMetadataClick,\n onTagsClick,\n onPropertiesClick,\n onHistoryClick,\n showDownload = true,\n showPrint = false,\n showMetadata = false,\n showTags = true,\n showProperties = false,\n showHistory = true,\n // Extract props that shouldn't be passed to DOM elements\n mimeType,\n fileSize,\n showPageCount,\n showPageNavigation,\n showZoomControls,\n showSearch,\n customRegistry,\n initialSearchText,\n initialSearchPages,\n autoOpenSearch,\n autoExecuteSearch,\n onSearchComplete,\n toolbarActions,\n ...props\n}) => {\n const videoRef = useRef<HTMLVideoElement | null>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const [videoSource, setVideoSource] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<string | null>(null);\n const [videoDimensions, setVideoDimensions] = useState<{\n width: number;\n height: number;\n } | null>(null);\n const [isFullScreen, setIsFullScreen] = useState(false);\n\n useEffect(() => {\n let objectUrl: string | null = null;\n\n if (file) {\n objectUrl = URL.createObjectURL(file);\n setVideoSource(objectUrl);\n setIsLoading(true);\n } else if (url) {\n setVideoSource(url);\n } else {\n setVideoSource(null);\n }\n\n setError(null);\n\n return () => {\n if (objectUrl) {\n URL.revokeObjectURL(objectUrl);\n }\n };\n }, [file, url]);\n\n useEffect(() => {\n const element = videoRef.current;\n if (!element) {\n return;\n }\n\n const handleLoaded = () => {\n setIsLoading(false);\n // Capture video dimensions\n setVideoDimensions({\n width: element.videoWidth,\n height: element.videoHeight,\n });\n onLoad?.();\n };\n\n const handleError = () => {\n const message = \"Failed to load video resource\";\n setIsLoading(false);\n setError(message);\n onError?.(new Error(message));\n };\n\n element.addEventListener(\"loadedmetadata\", handleLoaded);\n element.addEventListener(\"error\", handleError);\n\n return () => {\n element.removeEventListener(\"loadedmetadata\", handleLoaded);\n element.removeEventListener(\"error\", handleError);\n };\n }, [onLoad, onError, videoSource]);\n\n const resolvedFileName = useMemo(\n () => fileName || file?.name || (url ? url.split(\"/\").pop() : \"video\"),\n [fileName, file, url]\n );\n\n const fileExtension = useMemo(\n () => getFileExtension(resolvedFileName || \"\"),\n [resolvedFileName]\n );\n\n const handleToggleFullScreen = () => {\n if (!isFullScreen && containerRef.current?.requestFullscreen) {\n containerRef.current.requestFullscreen();\n setIsFullScreen(true);\n } else if (isFullScreen && document.exitFullscreen) {\n document.exitFullscreen();\n setIsFullScreen(false);\n }\n };\n\n const toolbar = mergeToolbarConfig({\n showDownload,\n showPrint,\n showMetadata,\n showTags,\n showProperties,\n showHistory,\n onDownloadClick,\n onPrintClick,\n onMetadataClick,\n onTagsClick,\n onPropertiesClick,\n onHistoryClick,\n toolbarActions,\n });\n\n return (\n <Box\n ref={containerRef}\n className={`video-viewer ${className}`}\n sx={{ width, height, ...style }}\n {...props}\n >\n <Card\n sx={{ height: \"100%\", display: \"flex\", flexDirection: \"column\" }}\n elevation={1}\n >\n <CardHeader\n avatar={<FileIcon ext={fileExtension} size={32} />}\n title={\n <Typography variant=\"subtitle1\" fontWeight={500}>\n {resolvedFileName}\n </Typography>\n }\n action={\n <Stack direction=\"row\" spacing={1}>\n {!toolbar.isHidden(\"download\") && (\n <Tooltip title={toolbar.getLabel(\"download\") || \"Download\"}>\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\"download\", onDownloadClick)}\n disabled={toolbar.isDisabled(\"download\")}\n aria-label=\"Download video\"\n >\n {toolbar.getIcon(\"download\") || <DownloadIcon />}\n </IconButton>\n </Tooltip>\n )}\n {!toolbar.isHidden(\"print\") && (\n <Tooltip title={toolbar.getLabel(\"print\") || \"Print\"}>\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\"print\", onPrintClick)}\n disabled={toolbar.isDisabled(\"print\")}\n aria-label=\"Print video\"\n >\n {toolbar.getIcon(\"print\") || <PrintIcon />}\n </IconButton>\n </Tooltip>\n )}\n {!toolbar.isHidden(\"fullscreen\") && (\n <Tooltip title={toolbar.getLabel(\"fullscreen\") || \"Fullscreen\"}>\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\n \"fullscreen\",\n handleToggleFullScreen\n )}\n disabled={toolbar.isDisabled(\"fullscreen\")}\n aria-label=\"Toggle fullscreen\"\n >\n {toolbar.getIcon(\"fullscreen\") || <FullscreenIcon />}\n </IconButton>\n </Tooltip>\n )}\n {!toolbar.isHidden(\"metadata\") && (\n <Tooltip\n title={toolbar.getLabel(\"metadata\") || \"Document Metadata\"}\n >\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\"metadata\", onMetadataClick)}\n disabled={toolbar.isDisabled(\"metadata\")}\n aria-label=\"View document metadata\"\n >\n {toolbar.getIcon(\"metadata\") || <DescriptionIcon />}\n </IconButton>\n </Tooltip>\n )}\n {!toolbar.isHidden(\"properties\") && (\n <Tooltip\n title={\n toolbar.getLabel(\"properties\") || \"Document Properties\"\n }\n >\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\n \"properties\",\n onPropertiesClick\n )}\n disabled={toolbar.isDisabled(\"properties\")}\n aria-label=\"View document properties\"\n >\n {toolbar.getIcon(\"properties\") || <InfoIcon />}\n </IconButton>\n </Tooltip>\n )}\n {!toolbar.isHidden(\"tags\") && (\n <Tooltip title={toolbar.getLabel(\"tags\") || \"Document Tags\"}>\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\"tags\", onTagsClick)}\n disabled={toolbar.isDisabled(\"tags\")}\n aria-label=\"View document tags\"\n >\n {toolbar.getIcon(\"tags\") || <LocalOffer />}\n </IconButton>\n </Tooltip>\n )}\n {!toolbar.isHidden(\"history\") && (\n <Tooltip\n title={toolbar.getLabel(\"history\") || \"Document History\"}\n >\n <IconButton\n size=\"small\"\n onClick={toolbar.getHandler(\"history\", onHistoryClick)}\n disabled={toolbar.isDisabled(\"history\")}\n aria-label=\"View document history\"\n >\n {toolbar.getIcon(\"history\") || <HistoryIcon />}\n </IconButton>\n </Tooltip>\n )}\n </Stack>\n }\n sx={{ pb: 1.5 }}\n />\n {isLoading && <LinearProgress sx={{ mx: 3, mb: 2 }} />}\n {error && (\n <Typography color=\"error\" variant=\"body2\" sx={{ px: 3, pb: 1 }}>\n {error}\n </Typography>\n )}\n <CardContent\n sx={{\n flexGrow: 1,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n p: 2,\n overflow: \"hidden\",\n }}\n >\n {videoSource ? (\n <Box\n sx={{\n width: \"100%\",\n height: \"100%\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"#000\",\n borderRadius: 2,\n }}\n >\n <video\n ref={videoRef}\n controls\n controlsList=\"nodownload\"\n style={{\n maxWidth: \"100%\",\n maxHeight: \"100%\",\n width: \"auto\",\n height: \"auto\",\n objectFit: \"contain\",\n }}\n src={videoSource}\n />\n </Box>\n ) : (\n <Typography variant=\"body2\" color=\"text.secondary\">\n No video source provided.\n </Typography>\n )}\n </CardContent>\n </Card>\n </Box>\n );\n};\n"]}