@cannyminds/dms-file-viewers 0.13.0 → 0.15.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 (97) hide show
  1. package/dist/chunk-42VHR3EK.mjs +714 -0
  2. package/dist/chunk-42VHR3EK.mjs.map +1 -0
  3. package/dist/{chunk-J3JKVSAM.js → chunk-AYVTSFZA.js} +2 -1
  4. package/dist/chunk-AYVTSFZA.js.map +1 -0
  5. package/dist/chunk-C4L2R2QY.mjs +277 -0
  6. package/dist/chunk-C4L2R2QY.mjs.map +1 -0
  7. package/dist/chunk-DBXSX2B6.js +277 -0
  8. package/dist/chunk-DBXSX2B6.js.map +1 -0
  9. package/dist/chunk-DPSRGULQ.mjs +247 -0
  10. package/dist/chunk-DPSRGULQ.mjs.map +1 -0
  11. package/dist/chunk-FK6RYOAZ.mjs +297 -0
  12. package/dist/chunk-FK6RYOAZ.mjs.map +1 -0
  13. package/dist/chunk-FZVXQGA7.mjs +466 -0
  14. package/dist/chunk-FZVXQGA7.mjs.map +1 -0
  15. package/dist/chunk-GSRAK2YV.js +266 -0
  16. package/dist/chunk-GSRAK2YV.js.map +1 -0
  17. package/dist/chunk-HYRQBGAX.js +466 -0
  18. package/dist/chunk-HYRQBGAX.js.map +1 -0
  19. package/dist/chunk-RKDOWWQD.js +247 -0
  20. package/dist/chunk-RKDOWWQD.js.map +1 -0
  21. package/dist/chunk-TMAHQICY.mjs +1842 -0
  22. package/dist/chunk-TMAHQICY.mjs.map +1 -0
  23. package/dist/chunk-VBJVOB45.mjs +266 -0
  24. package/dist/chunk-VBJVOB45.mjs.map +1 -0
  25. package/dist/{chunk-DFBVN4MO.mjs → chunk-WR5SJ3LM.mjs} +2 -1
  26. package/dist/chunk-WR5SJ3LM.mjs.map +1 -0
  27. package/dist/chunk-XSXOX4MV.js +297 -0
  28. package/dist/chunk-XSXOX4MV.js.map +1 -0
  29. package/dist/chunk-XWWMHRVU.js +1842 -0
  30. package/dist/chunk-XWWMHRVU.js.map +1 -0
  31. package/dist/chunk-YU535XRJ.js +714 -0
  32. package/dist/chunk-YU535XRJ.js.map +1 -0
  33. package/dist/components/viewers/AudioViewer.d.mts +1 -1
  34. package/dist/components/viewers/AudioViewer.d.ts +1 -1
  35. package/dist/components/viewers/AudioViewer.js +3 -3
  36. package/dist/components/viewers/AudioViewer.mjs +2 -2
  37. package/dist/components/viewers/DefaultViewer.d.mts +1 -1
  38. package/dist/components/viewers/DefaultViewer.d.ts +1 -1
  39. package/dist/components/viewers/DefaultViewer.js +3 -3
  40. package/dist/components/viewers/DefaultViewer.mjs +2 -2
  41. package/dist/components/viewers/ImageViewer.d.mts +1 -1
  42. package/dist/components/viewers/ImageViewer.d.ts +1 -1
  43. package/dist/components/viewers/ImageViewer.js +3 -3
  44. package/dist/components/viewers/ImageViewer.mjs +2 -2
  45. package/dist/components/viewers/PDFViewer.d.mts +1 -1
  46. package/dist/components/viewers/PDFViewer.d.ts +1 -1
  47. package/dist/components/viewers/PDFViewer.js +3 -3
  48. package/dist/components/viewers/PDFViewer.mjs +2 -2
  49. package/dist/components/viewers/TIFFViewer.d.mts +1 -1
  50. package/dist/components/viewers/TIFFViewer.d.ts +1 -1
  51. package/dist/components/viewers/TIFFViewer.js +3 -3
  52. package/dist/components/viewers/TIFFViewer.mjs +2 -2
  53. package/dist/components/viewers/TextViewer.d.mts +1 -1
  54. package/dist/components/viewers/TextViewer.d.ts +1 -1
  55. package/dist/components/viewers/TextViewer.js +3 -3
  56. package/dist/components/viewers/TextViewer.mjs +2 -2
  57. package/dist/components/viewers/VideoViewer.d.mts +1 -1
  58. package/dist/components/viewers/VideoViewer.d.ts +1 -1
  59. package/dist/components/viewers/VideoViewer.js +3 -3
  60. package/dist/components/viewers/VideoViewer.mjs +2 -2
  61. package/dist/index.d.mts +2 -2
  62. package/dist/index.d.ts +2 -2
  63. package/dist/index.js +9 -9
  64. package/dist/index.mjs +8 -8
  65. package/dist/{types-DNrkDJdK.d.mts → types-DxRCbIFP.d.mts} +4 -2
  66. package/dist/{types-DNrkDJdK.d.ts → types-DxRCbIFP.d.ts} +4 -2
  67. package/package.json +1 -1
  68. package/dist/chunk-7QRYWFCO.js +0 -639
  69. package/dist/chunk-7QRYWFCO.js.map +0 -1
  70. package/dist/chunk-7R2KG3PE.mjs +0 -210
  71. package/dist/chunk-7R2KG3PE.mjs.map +0 -1
  72. package/dist/chunk-CFYOPDCG.mjs +0 -235
  73. package/dist/chunk-CFYOPDCG.mjs.map +0 -1
  74. package/dist/chunk-D74R4IKW.mjs +0 -341
  75. package/dist/chunk-D74R4IKW.mjs.map +0 -1
  76. package/dist/chunk-DFBVN4MO.mjs.map +0 -1
  77. package/dist/chunk-EXZCEYLI.js +0 -247
  78. package/dist/chunk-EXZCEYLI.js.map +0 -1
  79. package/dist/chunk-J3JKVSAM.js.map +0 -1
  80. package/dist/chunk-NXVIRFGL.mjs +0 -247
  81. package/dist/chunk-NXVIRFGL.mjs.map +0 -1
  82. package/dist/chunk-P2VNW6OE.mjs +0 -180
  83. package/dist/chunk-P2VNW6OE.mjs.map +0 -1
  84. package/dist/chunk-P5FH7LK7.mjs +0 -639
  85. package/dist/chunk-P5FH7LK7.mjs.map +0 -1
  86. package/dist/chunk-PZJSY6OF.mjs +0 -1736
  87. package/dist/chunk-PZJSY6OF.mjs.map +0 -1
  88. package/dist/chunk-RVHIXSUP.js +0 -235
  89. package/dist/chunk-RVHIXSUP.js.map +0 -1
  90. package/dist/chunk-TGVFAAIP.js +0 -341
  91. package/dist/chunk-TGVFAAIP.js.map +0 -1
  92. package/dist/chunk-VOLQW3NF.js +0 -1736
  93. package/dist/chunk-VOLQW3NF.js.map +0 -1
  94. package/dist/chunk-VSGX22FQ.js +0 -180
  95. package/dist/chunk-VSGX22FQ.js.map +0 -1
  96. package/dist/chunk-WCAXWJE7.js +0 -210
  97. package/dist/chunk-WCAXWJE7.js.map +0 -1
@@ -0,0 +1,297 @@
1
+ "use client";
2
+ import {
3
+ getFileExtension
4
+ } from "./chunk-M57PSU4O.mjs";
5
+ import {
6
+ FileIcon_default,
7
+ mergeToolbarConfig
8
+ } from "./chunk-WR5SJ3LM.mjs";
9
+
10
+ // src/components/viewers/VideoViewer.tsx
11
+ import {
12
+ useEffect,
13
+ useMemo,
14
+ useRef,
15
+ useState
16
+ } from "react";
17
+ import {
18
+ Box,
19
+ Card,
20
+ CardContent,
21
+ CardHeader,
22
+ LinearProgress,
23
+ Typography,
24
+ Stack,
25
+ IconButton,
26
+ Tooltip
27
+ } from "@mui/material";
28
+ import DownloadIcon from "@mui/icons-material/Download";
29
+ import PrintIcon from "@mui/icons-material/Print";
30
+ import FullscreenIcon from "@mui/icons-material/Fullscreen";
31
+ import InfoIcon from "@mui/icons-material/Info";
32
+ import DescriptionIcon from "@mui/icons-material/Description";
33
+ import { jsx, jsxs } from "react/jsx-runtime";
34
+ var VideoViewer = ({
35
+ file,
36
+ url,
37
+ fileName,
38
+ className = "",
39
+ style = {},
40
+ width = "100%",
41
+ height = "100%",
42
+ onLoad,
43
+ onError,
44
+ onDownloadClick,
45
+ onPrintClick,
46
+ onMetadataClick,
47
+ onTagsClick,
48
+ onPropertiesClick,
49
+ showDownload = true,
50
+ showPrint = false,
51
+ showMetadata = false,
52
+ showTags = false,
53
+ showProperties = false,
54
+ // Extract props that shouldn't be passed to DOM elements
55
+ mimeType,
56
+ fileSize,
57
+ showPageCount,
58
+ showPageNavigation,
59
+ showZoomControls,
60
+ showSearch,
61
+ customRegistry,
62
+ initialSearchText,
63
+ initialSearchPages,
64
+ autoOpenSearch,
65
+ autoExecuteSearch,
66
+ onSearchComplete,
67
+ toolbarActions,
68
+ ...props
69
+ }) => {
70
+ const videoRef = useRef(null);
71
+ const containerRef = useRef(null);
72
+ const [videoSource, setVideoSource] = useState(null);
73
+ const [isLoading, setIsLoading] = useState(false);
74
+ const [error, setError] = useState(null);
75
+ const [videoDimensions, setVideoDimensions] = useState(null);
76
+ const [isFullScreen, setIsFullScreen] = useState(false);
77
+ useEffect(() => {
78
+ let objectUrl = null;
79
+ if (file) {
80
+ objectUrl = URL.createObjectURL(file);
81
+ setVideoSource(objectUrl);
82
+ setIsLoading(true);
83
+ } else if (url) {
84
+ setVideoSource(url);
85
+ } else {
86
+ setVideoSource(null);
87
+ }
88
+ setError(null);
89
+ return () => {
90
+ if (objectUrl) {
91
+ URL.revokeObjectURL(objectUrl);
92
+ }
93
+ };
94
+ }, [file, url]);
95
+ useEffect(() => {
96
+ const element = videoRef.current;
97
+ if (!element) {
98
+ return;
99
+ }
100
+ const handleLoaded = () => {
101
+ setIsLoading(false);
102
+ setVideoDimensions({
103
+ width: element.videoWidth,
104
+ height: element.videoHeight
105
+ });
106
+ onLoad?.();
107
+ };
108
+ const handleError = () => {
109
+ const message = "Failed to load video resource";
110
+ setIsLoading(false);
111
+ setError(message);
112
+ onError?.(new Error(message));
113
+ };
114
+ element.addEventListener("loadedmetadata", handleLoaded);
115
+ element.addEventListener("error", handleError);
116
+ return () => {
117
+ element.removeEventListener("loadedmetadata", handleLoaded);
118
+ element.removeEventListener("error", handleError);
119
+ };
120
+ }, [onLoad, onError, videoSource]);
121
+ const resolvedFileName = useMemo(
122
+ () => fileName || file?.name || (url ? url.split("/").pop() : "video"),
123
+ [fileName, file, url]
124
+ );
125
+ const fileExtension = useMemo(
126
+ () => getFileExtension(resolvedFileName || ""),
127
+ [resolvedFileName]
128
+ );
129
+ const handleToggleFullScreen = () => {
130
+ if (!isFullScreen && containerRef.current?.requestFullscreen) {
131
+ containerRef.current.requestFullscreen();
132
+ setIsFullScreen(true);
133
+ } else if (isFullScreen && document.exitFullscreen) {
134
+ document.exitFullscreen();
135
+ setIsFullScreen(false);
136
+ }
137
+ };
138
+ const toolbar = mergeToolbarConfig({
139
+ showDownload,
140
+ showPrint,
141
+ showMetadata,
142
+ showTags,
143
+ showProperties,
144
+ onDownloadClick,
145
+ onPrintClick,
146
+ onMetadataClick,
147
+ onTagsClick,
148
+ onPropertiesClick,
149
+ toolbarActions
150
+ });
151
+ return /* @__PURE__ */ jsx(
152
+ Box,
153
+ {
154
+ ref: containerRef,
155
+ className: `video-viewer ${className}`,
156
+ sx: { width, height, ...style },
157
+ ...props,
158
+ children: /* @__PURE__ */ jsxs(
159
+ Card,
160
+ {
161
+ sx: { height: "100%", display: "flex", flexDirection: "column" },
162
+ elevation: 1,
163
+ children: [
164
+ /* @__PURE__ */ jsx(
165
+ CardHeader,
166
+ {
167
+ avatar: /* @__PURE__ */ jsx(FileIcon_default, { ext: fileExtension, size: 32 }),
168
+ title: /* @__PURE__ */ jsx(Typography, { variant: "subtitle1", fontWeight: 500, children: resolvedFileName }),
169
+ action: /* @__PURE__ */ jsxs(Stack, { direction: "row", spacing: 1, children: [
170
+ !toolbar.isHidden("download") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("download") || "Download", children: /* @__PURE__ */ jsx(
171
+ IconButton,
172
+ {
173
+ size: "small",
174
+ onClick: toolbar.getHandler("download", onDownloadClick),
175
+ disabled: toolbar.isDisabled("download"),
176
+ "aria-label": "Download video",
177
+ children: toolbar.getIcon("download") || /* @__PURE__ */ jsx(DownloadIcon, {})
178
+ }
179
+ ) }),
180
+ !toolbar.isHidden("print") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("print") || "Print", children: /* @__PURE__ */ jsx(
181
+ IconButton,
182
+ {
183
+ size: "small",
184
+ onClick: toolbar.getHandler("print", onPrintClick),
185
+ disabled: toolbar.isDisabled("print"),
186
+ "aria-label": "Print video",
187
+ children: toolbar.getIcon("print") || /* @__PURE__ */ jsx(PrintIcon, {})
188
+ }
189
+ ) }),
190
+ !toolbar.isHidden("fullscreen") && /* @__PURE__ */ jsx(Tooltip, { title: toolbar.getLabel("fullscreen") || "Fullscreen", children: /* @__PURE__ */ jsx(
191
+ IconButton,
192
+ {
193
+ size: "small",
194
+ onClick: toolbar.getHandler(
195
+ "fullscreen",
196
+ handleToggleFullScreen
197
+ ),
198
+ disabled: toolbar.isDisabled("fullscreen"),
199
+ "aria-label": "Toggle fullscreen",
200
+ children: toolbar.getIcon("fullscreen") || /* @__PURE__ */ jsx(FullscreenIcon, {})
201
+ }
202
+ ) }),
203
+ !toolbar.isHidden("metadata") && /* @__PURE__ */ jsx(
204
+ Tooltip,
205
+ {
206
+ title: toolbar.getLabel("metadata") || "Document Metadata",
207
+ children: /* @__PURE__ */ jsx(
208
+ IconButton,
209
+ {
210
+ size: "small",
211
+ onClick: toolbar.getHandler("metadata", onMetadataClick),
212
+ disabled: toolbar.isDisabled("metadata"),
213
+ "aria-label": "View document metadata",
214
+ children: toolbar.getIcon("metadata") || /* @__PURE__ */ jsx(DescriptionIcon, {})
215
+ }
216
+ )
217
+ }
218
+ ),
219
+ !toolbar.isHidden("properties") && /* @__PURE__ */ jsx(
220
+ Tooltip,
221
+ {
222
+ title: toolbar.getLabel("properties") || "Document Properties",
223
+ children: /* @__PURE__ */ jsx(
224
+ IconButton,
225
+ {
226
+ size: "small",
227
+ onClick: toolbar.getHandler(
228
+ "properties",
229
+ onPropertiesClick
230
+ ),
231
+ disabled: toolbar.isDisabled("properties"),
232
+ "aria-label": "View document properties",
233
+ children: toolbar.getIcon("properties") || /* @__PURE__ */ jsx(InfoIcon, {})
234
+ }
235
+ )
236
+ }
237
+ )
238
+ ] }),
239
+ sx: { pb: 1.5 }
240
+ }
241
+ ),
242
+ isLoading && /* @__PURE__ */ jsx(LinearProgress, { sx: { mx: 3, mb: 2 } }),
243
+ error && /* @__PURE__ */ jsx(Typography, { color: "error", variant: "body2", sx: { px: 3, pb: 1 }, children: error }),
244
+ /* @__PURE__ */ jsx(
245
+ CardContent,
246
+ {
247
+ sx: {
248
+ flexGrow: 1,
249
+ display: "flex",
250
+ alignItems: "center",
251
+ justifyContent: "center",
252
+ p: 2,
253
+ overflow: "hidden"
254
+ },
255
+ children: videoSource ? /* @__PURE__ */ jsx(
256
+ Box,
257
+ {
258
+ sx: {
259
+ width: "100%",
260
+ height: "100%",
261
+ display: "flex",
262
+ alignItems: "center",
263
+ justifyContent: "center",
264
+ backgroundColor: "#000",
265
+ borderRadius: 2
266
+ },
267
+ children: /* @__PURE__ */ jsx(
268
+ "video",
269
+ {
270
+ ref: videoRef,
271
+ controls: true,
272
+ controlsList: "nodownload",
273
+ style: {
274
+ maxWidth: "100%",
275
+ maxHeight: "100%",
276
+ width: "auto",
277
+ height: "auto",
278
+ objectFit: "contain"
279
+ },
280
+ src: videoSource
281
+ }
282
+ )
283
+ }
284
+ ) : /* @__PURE__ */ jsx(Typography, { variant: "body2", color: "text.secondary", children: "No video source provided." })
285
+ }
286
+ )
287
+ ]
288
+ }
289
+ )
290
+ }
291
+ );
292
+ };
293
+
294
+ export {
295
+ VideoViewer
296
+ };
297
+ //# sourceMappingURL=chunk-FK6RYOAZ.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/viewers/VideoViewer.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 Card,\r\n CardContent,\r\n CardHeader,\r\n LinearProgress,\r\n Typography,\r\n Stack,\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 InfoIcon from \"@mui/icons-material/Info\";\r\nimport DescriptionIcon from \"@mui/icons-material/Description\";\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\nexport const VideoViewer: React.FC<FileViewerProps> = ({\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 onTagsClick,\r\n onPropertiesClick,\r\n showDownload = true,\r\n showPrint = false,\r\n showMetadata = false,\r\n showTags = 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 videoRef = useRef<HTMLVideoElement | null>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const [videoSource, setVideoSource] = useState<string | null>(null);\r\n const [isLoading, setIsLoading] = useState(false);\r\n const [error, setError] = useState<string | null>(null);\r\n const [videoDimensions, setVideoDimensions] = useState<{\r\n width: number;\r\n height: number;\r\n } | null>(null);\r\n const [isFullScreen, setIsFullScreen] = useState(false);\r\n\r\n useEffect(() => {\r\n let objectUrl: string | null = null;\r\n\r\n if (file) {\r\n objectUrl = URL.createObjectURL(file);\r\n setVideoSource(objectUrl);\r\n setIsLoading(true);\r\n } else if (url) {\r\n setVideoSource(url);\r\n } else {\r\n setVideoSource(null);\r\n }\r\n\r\n setError(null);\r\n\r\n return () => {\r\n if (objectUrl) {\r\n URL.revokeObjectURL(objectUrl);\r\n }\r\n };\r\n }, [file, url]);\r\n\r\n useEffect(() => {\r\n const element = videoRef.current;\r\n if (!element) {\r\n return;\r\n }\r\n\r\n const handleLoaded = () => {\r\n setIsLoading(false);\r\n // Capture video dimensions\r\n setVideoDimensions({\r\n width: element.videoWidth,\r\n height: element.videoHeight,\r\n });\r\n onLoad?.();\r\n };\r\n\r\n const handleError = () => {\r\n const message = \"Failed to load video resource\";\r\n setIsLoading(false);\r\n setError(message);\r\n onError?.(new Error(message));\r\n };\r\n\r\n element.addEventListener(\"loadedmetadata\", handleLoaded);\r\n element.addEventListener(\"error\", handleError);\r\n\r\n return () => {\r\n element.removeEventListener(\"loadedmetadata\", handleLoaded);\r\n element.removeEventListener(\"error\", handleError);\r\n };\r\n }, [onLoad, onError, videoSource]);\r\n\r\n const resolvedFileName = useMemo(\r\n () => fileName || file?.name || (url ? url.split(\"/\").pop() : \"video\"),\r\n [fileName, file, url]\r\n );\r\n\r\n const fileExtension = useMemo(\r\n () => getFileExtension(resolvedFileName || \"\"),\r\n [resolvedFileName]\r\n );\r\n\r\n const handleToggleFullScreen = () => {\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 };\r\n\r\n const toolbar = mergeToolbarConfig({\r\n showDownload,\r\n showPrint,\r\n showMetadata,\r\n showTags,\r\n showProperties,\r\n onDownloadClick,\r\n onPrintClick,\r\n onMetadataClick,\r\n onTagsClick,\r\n onPropertiesClick,\r\n toolbarActions,\r\n });\r\n\r\n return (\r\n <Box\r\n ref={containerRef}\r\n className={`video-viewer ${className}`}\r\n sx={{ width, height, ...style }}\r\n {...props}\r\n >\r\n <Card\r\n sx={{ height: \"100%\", display: \"flex\", flexDirection: \"column\" }}\r\n elevation={1}\r\n >\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 action={\r\n <Stack direction=\"row\" spacing={1}>\r\n {!toolbar.isHidden(\"download\") && (\r\n <Tooltip title={toolbar.getLabel(\"download\") || \"Download\"}>\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler(\"download\", onDownloadClick)}\r\n disabled={toolbar.isDisabled(\"download\")}\r\n aria-label=\"Download video\"\r\n >\r\n {toolbar.getIcon(\"download\") || <DownloadIcon />}\r\n </IconButton>\r\n </Tooltip>\r\n )}\r\n {!toolbar.isHidden(\"print\") && (\r\n <Tooltip title={toolbar.getLabel(\"print\") || \"Print\"}>\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler(\"print\", onPrintClick)}\r\n disabled={toolbar.isDisabled(\"print\")}\r\n aria-label=\"Print video\"\r\n >\r\n {toolbar.getIcon(\"print\") || <PrintIcon />}\r\n </IconButton>\r\n </Tooltip>\r\n )}\r\n {!toolbar.isHidden(\"fullscreen\") && (\r\n <Tooltip title={toolbar.getLabel(\"fullscreen\") || \"Fullscreen\"}>\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler(\r\n \"fullscreen\",\r\n handleToggleFullScreen\r\n )}\r\n disabled={toolbar.isDisabled(\"fullscreen\")}\r\n aria-label=\"Toggle fullscreen\"\r\n >\r\n {toolbar.getIcon(\"fullscreen\") || <FullscreenIcon />}\r\n </IconButton>\r\n </Tooltip>\r\n )}\r\n {!toolbar.isHidden(\"metadata\") && (\r\n <Tooltip\r\n title={toolbar.getLabel(\"metadata\") || \"Document Metadata\"}\r\n >\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler(\"metadata\", onMetadataClick)}\r\n disabled={toolbar.isDisabled(\"metadata\")}\r\n aria-label=\"View document metadata\"\r\n >\r\n {toolbar.getIcon(\"metadata\") || <DescriptionIcon />}\r\n </IconButton>\r\n </Tooltip>\r\n )}\r\n {!toolbar.isHidden(\"properties\") && (\r\n <Tooltip\r\n title={\r\n toolbar.getLabel(\"properties\") || \"Document Properties\"\r\n }\r\n >\r\n <IconButton\r\n size=\"small\"\r\n onClick={toolbar.getHandler(\r\n \"properties\",\r\n onPropertiesClick\r\n )}\r\n disabled={toolbar.isDisabled(\"properties\")}\r\n aria-label=\"View document properties\"\r\n >\r\n {toolbar.getIcon(\"properties\") || <InfoIcon />}\r\n </IconButton>\r\n </Tooltip>\r\n )}\r\n </Stack>\r\n }\r\n sx={{ pb: 1.5 }}\r\n />\r\n {isLoading && <LinearProgress sx={{ mx: 3, mb: 2 }} />}\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 <CardContent\r\n sx={{\r\n flexGrow: 1,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n p: 2,\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {videoSource ? (\r\n <Box\r\n sx={{\r\n width: \"100%\",\r\n height: \"100%\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n backgroundColor: \"#000\",\r\n borderRadius: 2,\r\n }}\r\n >\r\n <video\r\n ref={videoRef}\r\n controls\r\n controlsList=\"nodownload\"\r\n style={{\r\n maxWidth: \"100%\",\r\n maxHeight: \"100%\",\r\n width: \"auto\",\r\n height: \"auto\",\r\n objectFit: \"contain\",\r\n }}\r\n src={videoSource}\r\n />\r\n </Box>\r\n ) : (\r\n <Typography variant=\"body2\" color=\"text.secondary\">\r\n No video source provided.\r\n </Typography>\r\n )}\r\n </CardContent>\r\n </Card>\r\n </Box>\r\n );\r\n};\r\n"],"mappings":"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","names":[]}