@cannymindstech/file-viewers 0.27.12 → 0.28.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 (91) hide show
  1. package/package.json +2 -2
  2. package/dist/chunk-2BLHLWNN.js +0 -299
  3. package/dist/chunk-2BLHLWNN.js.map +0 -1
  4. package/dist/chunk-6BRYDA3B.js +0 -329
  5. package/dist/chunk-6BRYDA3B.js.map +0 -1
  6. package/dist/chunk-7JPF5AYR.mjs +0 -488
  7. package/dist/chunk-7JPF5AYR.mjs.map +0 -1
  8. package/dist/chunk-7P6WEBHN.js +0 -2299
  9. package/dist/chunk-7P6WEBHN.js.map +0 -1
  10. package/dist/chunk-7PMZ4GN5.mjs +0 -290
  11. package/dist/chunk-7PMZ4GN5.mjs.map +0 -1
  12. package/dist/chunk-B5NNB4KD.mjs +0 -268
  13. package/dist/chunk-B5NNB4KD.mjs.map +0 -1
  14. package/dist/chunk-CIWCHSAA.js +0 -309
  15. package/dist/chunk-CIWCHSAA.js.map +0 -1
  16. package/dist/chunk-D7SDEVDM.js +0 -268
  17. package/dist/chunk-D7SDEVDM.js.map +0 -1
  18. package/dist/chunk-ECZ6IBOS.js +0 -424
  19. package/dist/chunk-ECZ6IBOS.js.map +0 -1
  20. package/dist/chunk-EKNP342T.mjs +0 -299
  21. package/dist/chunk-EKNP342T.mjs.map +0 -1
  22. package/dist/chunk-EM63H4SA.js +0 -290
  23. package/dist/chunk-EM63H4SA.js.map +0 -1
  24. package/dist/chunk-IJMNPAXX.mjs +0 -309
  25. package/dist/chunk-IJMNPAXX.mjs.map +0 -1
  26. package/dist/chunk-JKX5RSLF.mjs +0 -871
  27. package/dist/chunk-JKX5RSLF.mjs.map +0 -1
  28. package/dist/chunk-KJNOBIUZ.mjs +0 -36
  29. package/dist/chunk-KJNOBIUZ.mjs.map +0 -1
  30. package/dist/chunk-KQCU7XW2.mjs +0 -424
  31. package/dist/chunk-KQCU7XW2.mjs.map +0 -1
  32. package/dist/chunk-KQLIG6WK.js +0 -871
  33. package/dist/chunk-KQLIG6WK.js.map +0 -1
  34. package/dist/chunk-OPJOCUSL.js +0 -36
  35. package/dist/chunk-OPJOCUSL.js.map +0 -1
  36. package/dist/chunk-PZGUVU6N.mjs +0 -2299
  37. package/dist/chunk-PZGUVU6N.mjs.map +0 -1
  38. package/dist/chunk-QV63FULE.js +0 -488
  39. package/dist/chunk-QV63FULE.js.map +0 -1
  40. package/dist/chunk-XJQ5J2UF.mjs +0 -329
  41. package/dist/chunk-XJQ5J2UF.mjs.map +0 -1
  42. package/dist/components/viewers/AudioViewer.d.mts +0 -6
  43. package/dist/components/viewers/AudioViewer.d.ts +0 -6
  44. package/dist/components/viewers/AudioViewer.js +0 -10
  45. package/dist/components/viewers/AudioViewer.js.map +0 -1
  46. package/dist/components/viewers/AudioViewer.mjs +0 -10
  47. package/dist/components/viewers/AudioViewer.mjs.map +0 -1
  48. package/dist/components/viewers/DefaultViewer.d.mts +0 -6
  49. package/dist/components/viewers/DefaultViewer.d.ts +0 -6
  50. package/dist/components/viewers/DefaultViewer.js +0 -10
  51. package/dist/components/viewers/DefaultViewer.js.map +0 -1
  52. package/dist/components/viewers/DefaultViewer.mjs +0 -10
  53. package/dist/components/viewers/DefaultViewer.mjs.map +0 -1
  54. package/dist/components/viewers/ImageViewer.d.mts +0 -6
  55. package/dist/components/viewers/ImageViewer.d.ts +0 -6
  56. package/dist/components/viewers/ImageViewer.js +0 -10
  57. package/dist/components/viewers/ImageViewer.js.map +0 -1
  58. package/dist/components/viewers/ImageViewer.mjs +0 -10
  59. package/dist/components/viewers/ImageViewer.mjs.map +0 -1
  60. package/dist/components/viewers/PDFViewer.d.mts +0 -51
  61. package/dist/components/viewers/PDFViewer.d.ts +0 -51
  62. package/dist/components/viewers/PDFViewer.js +0 -11
  63. package/dist/components/viewers/PDFViewer.js.map +0 -1
  64. package/dist/components/viewers/PDFViewer.mjs +0 -11
  65. package/dist/components/viewers/PDFViewer.mjs.map +0 -1
  66. package/dist/components/viewers/TIFFViewer.d.mts +0 -6
  67. package/dist/components/viewers/TIFFViewer.d.ts +0 -6
  68. package/dist/components/viewers/TIFFViewer.js +0 -10
  69. package/dist/components/viewers/TIFFViewer.js.map +0 -1
  70. package/dist/components/viewers/TIFFViewer.mjs +0 -10
  71. package/dist/components/viewers/TIFFViewer.mjs.map +0 -1
  72. package/dist/components/viewers/TextViewer.d.mts +0 -6
  73. package/dist/components/viewers/TextViewer.d.ts +0 -6
  74. package/dist/components/viewers/TextViewer.js +0 -10
  75. package/dist/components/viewers/TextViewer.js.map +0 -1
  76. package/dist/components/viewers/TextViewer.mjs +0 -10
  77. package/dist/components/viewers/TextViewer.mjs.map +0 -1
  78. package/dist/components/viewers/VideoViewer.d.mts +0 -6
  79. package/dist/components/viewers/VideoViewer.d.ts +0 -6
  80. package/dist/components/viewers/VideoViewer.js +0 -10
  81. package/dist/components/viewers/VideoViewer.js.map +0 -1
  82. package/dist/components/viewers/VideoViewer.mjs +0 -10
  83. package/dist/components/viewers/VideoViewer.mjs.map +0 -1
  84. package/dist/index.d.mts +0 -75
  85. package/dist/index.d.ts +0 -75
  86. package/dist/index.js +0 -305
  87. package/dist/index.js.map +0 -1
  88. package/dist/index.mjs +0 -305
  89. package/dist/index.mjs.map +0 -1
  90. package/dist/types-BYTxtKEc.d.mts +0 -100
  91. package/dist/types-BYTxtKEc.d.ts +0 -100
@@ -1,329 +0,0 @@
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
@@ -1 +0,0 @@
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"]}