@bosonprotocol/react-kit 0.33.0-alpha.9 → 0.33.1-alpha.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 (196) hide show
  1. package/dist/cjs/components/buttons/BaseButton.d.ts +1 -0
  2. package/dist/cjs/components/buttons/BaseButton.d.ts.map +1 -1
  3. package/dist/cjs/components/buttons/BaseButton.js +1 -0
  4. package/dist/cjs/components/buttons/BaseButton.js.map +1 -1
  5. package/dist/cjs/components/buttons/CommitButtonView.d.ts.map +1 -1
  6. package/dist/cjs/components/buttons/CommitButtonView.js +4 -0
  7. package/dist/cjs/components/buttons/CommitButtonView.js.map +1 -1
  8. package/dist/cjs/components/datepicker/DatePicker.style.d.ts +2 -2
  9. package/dist/cjs/components/error/SimpleError.d.ts +2 -2
  10. package/dist/cjs/components/error/SimpleError.d.ts.map +1 -1
  11. package/dist/cjs/components/error/SimpleError.js.map +1 -1
  12. package/dist/cjs/components/form/BaseCheckbox.d.ts +5 -0
  13. package/dist/cjs/components/form/BaseCheckbox.d.ts.map +1 -0
  14. package/dist/cjs/components/form/BaseCheckbox.js +69 -0
  15. package/dist/cjs/components/form/BaseCheckbox.js.map +1 -0
  16. package/dist/cjs/components/form/Checkbox.d.ts +13 -2
  17. package/dist/cjs/components/form/Checkbox.d.ts.map +1 -1
  18. package/dist/cjs/components/form/Checkbox.js +18 -61
  19. package/dist/cjs/components/form/Checkbox.js.map +1 -1
  20. package/dist/cjs/components/form/CountrySelect.d.ts +26 -11
  21. package/dist/cjs/components/form/CountrySelect.d.ts.map +1 -1
  22. package/dist/cjs/components/form/CountrySelect.js +64 -31
  23. package/dist/cjs/components/form/CountrySelect.js.map +1 -1
  24. package/dist/cjs/components/form/Field.styles.d.ts +36 -2
  25. package/dist/cjs/components/form/Field.styles.d.ts.map +1 -1
  26. package/dist/cjs/components/form/Field.styles.js +83 -24
  27. package/dist/cjs/components/form/Field.styles.js.map +1 -1
  28. package/dist/cjs/components/form/FormField.d.ts +2 -1
  29. package/dist/cjs/components/form/FormField.d.ts.map +1 -1
  30. package/dist/cjs/components/form/FormField.js +14 -2
  31. package/dist/cjs/components/form/FormField.js.map +1 -1
  32. package/dist/cjs/components/form/Select.d.ts +2 -1
  33. package/dist/cjs/components/form/Select.d.ts.map +1 -1
  34. package/dist/cjs/components/form/Select.js +32 -20
  35. package/dist/cjs/components/form/Select.js.map +1 -1
  36. package/dist/cjs/components/form/Upload/BaseUpload.d.ts +71 -0
  37. package/dist/cjs/components/form/Upload/BaseUpload.d.ts.map +1 -0
  38. package/dist/cjs/components/form/Upload/BaseUpload.js +264 -0
  39. package/dist/cjs/components/form/Upload/BaseUpload.js.map +1 -0
  40. package/dist/cjs/components/form/Upload/Upload.d.ts +3 -41
  41. package/dist/cjs/components/form/Upload/Upload.d.ts.map +1 -1
  42. package/dist/cjs/components/form/Upload/Upload.js +7 -258
  43. package/dist/cjs/components/form/Upload/Upload.js.map +1 -1
  44. package/dist/cjs/components/form/Upload/UploadedFile.js +2 -2
  45. package/dist/cjs/components/form/Upload/UploadedFile.js.map +1 -1
  46. package/dist/cjs/components/form/Upload/WithUploadToIpfs.d.ts.map +1 -1
  47. package/dist/cjs/components/form/Upload/WithUploadToIpfs.js +9 -12
  48. package/dist/cjs/components/form/Upload/WithUploadToIpfs.js.map +1 -1
  49. package/dist/cjs/components/form/index.d.ts +6 -4
  50. package/dist/cjs/components/form/index.d.ts.map +1 -1
  51. package/dist/cjs/components/form/index.js +7 -3
  52. package/dist/cjs/components/form/index.js.map +1 -1
  53. package/dist/cjs/components/form/types.d.ts +31 -3
  54. package/dist/cjs/components/form/types.d.ts.map +1 -1
  55. package/dist/cjs/components/ui/IpfsImage.d.ts +4 -3
  56. package/dist/cjs/components/ui/IpfsImage.d.ts.map +1 -1
  57. package/dist/cjs/components/ui/IpfsImage.js +2 -2
  58. package/dist/cjs/components/ui/IpfsImage.js.map +1 -1
  59. package/dist/cjs/components/ui/Video.d.ts +3 -3
  60. package/dist/cjs/components/ui/Video.d.ts.map +1 -1
  61. package/dist/cjs/components/ui/Video.js +7 -3
  62. package/dist/cjs/components/ui/Video.js.map +1 -1
  63. package/dist/cjs/hooks/ipfs/useIpfsStorage.d.ts.map +1 -1
  64. package/dist/cjs/hooks/ipfs/useIpfsStorage.js +2 -1
  65. package/dist/cjs/hooks/ipfs/useIpfsStorage.js.map +1 -1
  66. package/dist/cjs/hooks/transactions/usePendingTransactionsWithContext.d.ts +1 -1
  67. package/dist/cjs/hooks/useIpfsMetadataStorage.d.ts +2 -2
  68. package/dist/cjs/hooks/useIpfsMetadataStorage.d.ts.map +1 -1
  69. package/dist/cjs/hooks/useIpfsMetadataStorage.js +6 -6
  70. package/dist/cjs/hooks/useIpfsMetadataStorage.js.map +1 -1
  71. package/dist/cjs/hooks/useIpfsStorage.d.ts.map +1 -1
  72. package/dist/cjs/hooks/useIpfsStorage.js +2 -1
  73. package/dist/cjs/hooks/useIpfsStorage.js.map +1 -1
  74. package/dist/cjs/index.d.ts +63 -60
  75. package/dist/cjs/index.d.ts.map +1 -1
  76. package/dist/cjs/index.js +70 -66
  77. package/dist/cjs/index.js.map +1 -1
  78. package/dist/cjs/lib/bytes/bytesToSize.d.ts +1 -1
  79. package/dist/cjs/lib/bytes/bytesToSize.d.ts.map +1 -1
  80. package/dist/cjs/lib/bytes/bytesToSize.js +2 -1
  81. package/dist/cjs/lib/bytes/bytesToSize.js.map +1 -1
  82. package/dist/cjs/lib/const/chainInfo.d.ts.map +1 -1
  83. package/dist/cjs/lib/const/chainInfo.js +10 -0
  84. package/dist/cjs/lib/const/chainInfo.js.map +1 -1
  85. package/dist/esm/components/buttons/BaseButton.d.ts +1 -0
  86. package/dist/esm/components/buttons/BaseButton.d.ts.map +1 -1
  87. package/dist/esm/components/buttons/BaseButton.js +1 -0
  88. package/dist/esm/components/buttons/BaseButton.js.map +1 -1
  89. package/dist/esm/components/buttons/CommitButtonView.d.ts.map +1 -1
  90. package/dist/esm/components/buttons/CommitButtonView.js +4 -0
  91. package/dist/esm/components/buttons/CommitButtonView.js.map +1 -1
  92. package/dist/esm/components/datepicker/DatePicker.style.d.ts +2 -2
  93. package/dist/esm/components/error/SimpleError.d.ts +2 -2
  94. package/dist/esm/components/error/SimpleError.d.ts.map +1 -1
  95. package/dist/esm/components/error/SimpleError.js.map +1 -1
  96. package/dist/esm/components/form/BaseCheckbox.d.ts +5 -0
  97. package/dist/esm/components/form/BaseCheckbox.d.ts.map +1 -0
  98. package/dist/esm/components/form/BaseCheckbox.js +27 -0
  99. package/dist/esm/components/form/BaseCheckbox.js.map +1 -0
  100. package/dist/esm/components/form/Checkbox.d.ts +13 -2
  101. package/dist/esm/components/form/Checkbox.d.ts.map +1 -1
  102. package/dist/esm/components/form/Checkbox.js +16 -25
  103. package/dist/esm/components/form/Checkbox.js.map +1 -1
  104. package/dist/esm/components/form/CountrySelect.d.ts +26 -11
  105. package/dist/esm/components/form/CountrySelect.d.ts.map +1 -1
  106. package/dist/esm/components/form/CountrySelect.js +97 -67
  107. package/dist/esm/components/form/CountrySelect.js.map +1 -1
  108. package/dist/esm/components/form/Field.styles.d.ts +36 -2
  109. package/dist/esm/components/form/Field.styles.d.ts.map +1 -1
  110. package/dist/esm/components/form/Field.styles.js +58 -20
  111. package/dist/esm/components/form/Field.styles.js.map +1 -1
  112. package/dist/esm/components/form/FormField.d.ts +2 -1
  113. package/dist/esm/components/form/FormField.d.ts.map +1 -1
  114. package/dist/esm/components/form/FormField.js +2 -2
  115. package/dist/esm/components/form/FormField.js.map +1 -1
  116. package/dist/esm/components/form/Select.d.ts +2 -1
  117. package/dist/esm/components/form/Select.d.ts.map +1 -1
  118. package/dist/esm/components/form/Select.js +52 -30
  119. package/dist/esm/components/form/Select.js.map +1 -1
  120. package/dist/esm/components/form/Upload/BaseUpload.d.ts +71 -0
  121. package/dist/esm/components/form/Upload/BaseUpload.d.ts.map +1 -0
  122. package/dist/esm/components/form/Upload/BaseUpload.js +226 -0
  123. package/dist/esm/components/form/Upload/BaseUpload.js.map +1 -0
  124. package/dist/esm/components/form/Upload/Upload.d.ts +3 -41
  125. package/dist/esm/components/form/Upload/Upload.d.ts.map +1 -1
  126. package/dist/esm/components/form/Upload/Upload.js +5 -225
  127. package/dist/esm/components/form/Upload/Upload.js.map +1 -1
  128. package/dist/esm/components/form/Upload/UploadedFile.js +1 -1
  129. package/dist/esm/components/form/Upload/UploadedFile.js.map +1 -1
  130. package/dist/esm/components/form/Upload/WithUploadToIpfs.d.ts.map +1 -1
  131. package/dist/esm/components/form/Upload/WithUploadToIpfs.js +8 -11
  132. package/dist/esm/components/form/Upload/WithUploadToIpfs.js.map +1 -1
  133. package/dist/esm/components/form/index.d.ts +6 -4
  134. package/dist/esm/components/form/index.d.ts.map +1 -1
  135. package/dist/esm/components/form/index.js +4 -2
  136. package/dist/esm/components/form/index.js.map +1 -1
  137. package/dist/esm/components/form/types.d.ts +31 -3
  138. package/dist/esm/components/form/types.d.ts.map +1 -1
  139. package/dist/esm/components/ui/IpfsImage.d.ts +4 -3
  140. package/dist/esm/components/ui/IpfsImage.d.ts.map +1 -1
  141. package/dist/esm/components/ui/IpfsImage.js +2 -2
  142. package/dist/esm/components/ui/IpfsImage.js.map +1 -1
  143. package/dist/esm/components/ui/Video.d.ts +3 -3
  144. package/dist/esm/components/ui/Video.d.ts.map +1 -1
  145. package/dist/esm/components/ui/Video.js +5 -3
  146. package/dist/esm/components/ui/Video.js.map +1 -1
  147. package/dist/esm/hooks/ipfs/useIpfsStorage.d.ts.map +1 -1
  148. package/dist/esm/hooks/ipfs/useIpfsStorage.js +2 -1
  149. package/dist/esm/hooks/ipfs/useIpfsStorage.js.map +1 -1
  150. package/dist/esm/hooks/transactions/usePendingTransactionsWithContext.d.ts +1 -1
  151. package/dist/esm/hooks/useIpfsMetadataStorage.d.ts +2 -2
  152. package/dist/esm/hooks/useIpfsMetadataStorage.d.ts.map +1 -1
  153. package/dist/esm/hooks/useIpfsMetadataStorage.js +6 -6
  154. package/dist/esm/hooks/useIpfsMetadataStorage.js.map +1 -1
  155. package/dist/esm/hooks/useIpfsStorage.d.ts.map +1 -1
  156. package/dist/esm/hooks/useIpfsStorage.js +2 -1
  157. package/dist/esm/hooks/useIpfsStorage.js.map +1 -1
  158. package/dist/esm/index.d.ts +63 -60
  159. package/dist/esm/index.d.ts.map +1 -1
  160. package/dist/esm/index.js +63 -60
  161. package/dist/esm/index.js.map +1 -1
  162. package/dist/esm/lib/bytes/bytesToSize.d.ts +1 -1
  163. package/dist/esm/lib/bytes/bytesToSize.d.ts.map +1 -1
  164. package/dist/esm/lib/bytes/bytesToSize.js +1 -1
  165. package/dist/esm/lib/bytes/bytesToSize.js.map +1 -1
  166. package/dist/esm/lib/const/chainInfo.d.ts.map +1 -1
  167. package/dist/esm/lib/const/chainInfo.js +10 -0
  168. package/dist/esm/lib/const/chainInfo.js.map +1 -1
  169. package/package.json +5 -5
  170. package/src/components/buttons/BaseButton.tsx +4 -0
  171. package/src/components/buttons/CommitButtonView.tsx +4 -0
  172. package/src/components/error/SimpleError.tsx +2 -2
  173. package/src/components/form/BaseCheckbox.tsx +50 -0
  174. package/src/components/form/Checkbox.tsx +17 -40
  175. package/src/components/form/CountrySelect.tsx +178 -130
  176. package/src/components/form/Field.styles.ts +113 -24
  177. package/src/components/form/FormField.tsx +4 -1
  178. package/src/components/form/Select.tsx +65 -34
  179. package/src/components/form/Upload/BaseUpload.tsx +367 -0
  180. package/src/components/form/Upload/Upload.tsx +8 -360
  181. package/src/components/form/Upload/UploadedFile.tsx +1 -1
  182. package/src/components/form/Upload/WithUploadToIpfs.tsx +8 -11
  183. package/src/components/form/index.ts +6 -4
  184. package/src/components/form/types.ts +31 -3
  185. package/src/components/ui/IpfsImage.tsx +14 -7
  186. package/src/components/ui/Video.tsx +7 -5
  187. package/src/hooks/ipfs/useIpfsStorage.ts +2 -0
  188. package/src/hooks/useIpfsMetadataStorage.tsx +6 -4
  189. package/src/hooks/useIpfsStorage.ts +2 -0
  190. package/src/index.tsx +67 -64
  191. package/src/lib/bytes/bytesToSize.ts +1 -1
  192. package/src/lib/const/chainInfo.ts +10 -1
  193. package/src/stories/buttons/Upload.stories.tsx +8 -0
  194. package/src/stories/form/BaseCheckbox.stories.tsx +113 -0
  195. package/src/stories/selects/CountrySelect.stories.tsx +49 -11
  196. package/src/stories/selects/Select.stories.tsx +117 -0
@@ -0,0 +1,367 @@
1
+ import * as Sentry from "@sentry/browser";
2
+ import { useField } from "formik";
3
+ import { Image, Trash, VideoCamera } from "phosphor-react";
4
+ import React, { useCallback, useEffect, useRef, useState } from "react";
5
+ import { loadAndSetMedia } from "../../../lib/base64/base64";
6
+ import { bytesToSize } from "../../../lib/bytes/bytesToSize";
7
+ import { theme } from "../../../theme";
8
+
9
+ import Loading from "../../ui/loading/LoadingWrapper";
10
+ import ThemedButton from "../../ui/ThemedButton";
11
+ import { Typography } from "../../ui/Typography";
12
+ import Error from "../Error";
13
+ import {
14
+ FieldFileUploadWrapper,
15
+ FieldInput,
16
+ FileUploadWrapper,
17
+ ImagePreview,
18
+ VideoPreview
19
+ } from "../Field.styles";
20
+ import type {
21
+ UploadFileType,
22
+ UploadProps as UploadPropsWithNoIpfs,
23
+ FileProps
24
+ } from "../types";
25
+ import UploadedFiles from "./UploadedFiles";
26
+ import { WithUploadToIpfs, WithUploadToIpfsProps } from "./WithUploadToIpfs";
27
+ import { useModal } from "../../modal/useModal";
28
+ import { ImageEditorModal } from "./ImageEditorModal/ImageEditorModal";
29
+ const colors = theme.colors.light;
30
+ export type BaseUploadProps = UploadPropsWithNoIpfs;
31
+ function BaseUpload({
32
+ name,
33
+ accept = "image/*",
34
+ disabled,
35
+ maxSize,
36
+ multiple = false,
37
+ trigger,
38
+ onFilesSelect,
39
+ placeholder,
40
+ wrapperProps,
41
+ onLoadSinglePreviewImage,
42
+ withUpload,
43
+ withEditor,
44
+ saveToIpfs,
45
+ loadMedia,
46
+ onLoading,
47
+ width,
48
+ height,
49
+ borderRadius,
50
+ borderRadiusUnit = "px",
51
+ imgPreviewStyle,
52
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
53
+ removeFile,
54
+ saveButtonTheme,
55
+ theme,
56
+ ...props
57
+ }: UploadPropsWithNoIpfs & WithUploadToIpfsProps) {
58
+ const { updateProps, store } = useModal();
59
+ const [showEditor, setShowEditor] = useState<boolean>(false);
60
+ const [isLoading, setIsLoading] = useState<boolean>(false);
61
+ const [preview, setPreview] = useState<string | null>();
62
+ const [field, meta, helpers] = useField(name);
63
+
64
+ const handleLoading = useCallback(
65
+ (loadingValue: boolean) => {
66
+ onLoading?.(loadingValue);
67
+ setIsLoading(loadingValue);
68
+ },
69
+ [onLoading]
70
+ );
71
+
72
+ const errorMessage = meta.error && meta.touched ? meta.error : "";
73
+ const displayError = typeof errorMessage === "string" && errorMessage !== "";
74
+
75
+ const inputRef = useRef<HTMLInputElement | null>(null);
76
+ const [nativeFiles, setNativeFiles] = useState<File[] | null>(null);
77
+ const setFiles = useCallback(
78
+ (value: unknown) => {
79
+ helpers.setValue(value);
80
+ },
81
+ [helpers]
82
+ );
83
+
84
+ const files = field.value as UploadFileType[];
85
+ const mimetypes = accept.split(",").map((acc) => acc.trim());
86
+ const isImageOnly = mimetypes.every((mimetype) =>
87
+ mimetype.startsWith("image/")
88
+ );
89
+ const isVideoOnly = mimetypes.every((mimetype) =>
90
+ mimetype.startsWith("video/")
91
+ );
92
+
93
+ useEffect(() => {
94
+ onFilesSelect?.(files);
95
+ helpers.setValue(files);
96
+
97
+ if (!multiple && files && files?.length !== 0) {
98
+ if (isImageOnly) {
99
+ if (withUpload) {
100
+ loadIpfsImagePreview(files[0] as FileProps);
101
+ } else {
102
+ loadAndSetMedia(files[0] as File, (base64Uri) => {
103
+ setPreview(base64Uri);
104
+ onLoadSinglePreviewImage?.(base64Uri);
105
+ });
106
+ }
107
+ } else if (isVideoOnly) {
108
+ if (withUpload) {
109
+ loadIpfsVideo(files[0] as FileProps);
110
+ } else {
111
+ loadAndSetMedia(files[0] as File, (base64Uri) => {
112
+ setPreview(base64Uri);
113
+ });
114
+ }
115
+ }
116
+ }
117
+ }, [files]); // eslint-disable-line
118
+
119
+ const loadIpfsVideo = async (file: FileProps) => {
120
+ const fileSrc = file && file?.src ? file?.src : false;
121
+ if (!fileSrc) {
122
+ return false;
123
+ }
124
+ handleLoading(true);
125
+ try {
126
+ const imagePreview = await loadMedia(fileSrc || "");
127
+ if (imagePreview) {
128
+ setPreview(imagePreview);
129
+ } else {
130
+ console.warn(
131
+ `imagePreview ${imagePreview} is falsy in loadIpfsImagePreview`
132
+ );
133
+ }
134
+ } catch (error) {
135
+ console.error(error);
136
+ Sentry.captureException(error);
137
+ } finally {
138
+ handleLoading(false);
139
+ }
140
+ };
141
+
142
+ const loadIpfsImagePreview = async (file: FileProps) => {
143
+ const fileSrc = file && file?.src ? file?.src : false;
144
+ if (!fileSrc) {
145
+ return false;
146
+ }
147
+ try {
148
+ handleLoading(true);
149
+ const imagePreview = await loadMedia(fileSrc || "");
150
+ if (imagePreview) {
151
+ setPreview(imagePreview);
152
+ onLoadSinglePreviewImage?.(imagePreview);
153
+ } else {
154
+ console.warn(
155
+ `imagePreview ${imagePreview} is falsy in loadIpfsImagePreview`
156
+ );
157
+ }
158
+ } catch (error) {
159
+ console.error(error);
160
+ Sentry.captureException(error);
161
+ } finally {
162
+ handleLoading(false);
163
+ }
164
+ };
165
+
166
+ const handleChooseFile = () => {
167
+ const input = inputRef.current;
168
+ if (input) {
169
+ input.click();
170
+ }
171
+ };
172
+
173
+ const handleRemoveAllFiles = () => {
174
+ if (disabled) {
175
+ return;
176
+ }
177
+ setFiles([]);
178
+ setPreview(null);
179
+ };
180
+
181
+ const handleRemoveFile = (index: number) => {
182
+ const newArray = files.filter(
183
+ (i: File | FileProps, k: number) => k !== index
184
+ );
185
+ setFiles(newArray);
186
+ };
187
+
188
+ const handleChange = useCallback(
189
+ async (filesArray: File[] | null) => {
190
+ if (!meta.touched) {
191
+ helpers.setTouched(true);
192
+ }
193
+
194
+ if (!filesArray) {
195
+ return;
196
+ }
197
+ for (const file of filesArray) {
198
+ if (maxSize) {
199
+ if (file.size > maxSize) {
200
+ const error = `File size cannot exceed more than ${bytesToSize(
201
+ maxSize
202
+ )}`;
203
+ // TODO: change to notification
204
+ console.error(error);
205
+ }
206
+ }
207
+ }
208
+ setFiles(filesArray);
209
+ },
210
+ [helpers, maxSize, meta.touched, setFiles]
211
+ );
212
+
213
+ const handleSave = useCallback(
214
+ async (efiles: File[] | null) => {
215
+ if (!meta.touched) {
216
+ helpers.setTouched(true);
217
+ }
218
+ handleLoading(true);
219
+ const files = await saveToIpfs(efiles);
220
+ if (files) {
221
+ setFiles(files);
222
+ } else {
223
+ setFiles([]);
224
+ console.warn(
225
+ `There has been an error because 'files' ${files} is falsy in handleSave`
226
+ );
227
+ }
228
+ handleLoading(false);
229
+ },
230
+ [meta.touched, handleLoading, saveToIpfs, helpers, setFiles]
231
+ );
232
+ const saveFn = withUpload ? handleSave : handleChange;
233
+ const style = {
234
+ borderRadius: borderRadius ? `${borderRadius}${borderRadiusUnit}` : "",
235
+ width: width ? `100%` : ""
236
+ };
237
+ return (
238
+ <>
239
+ {withEditor && showEditor && (
240
+ <ImageEditorModal
241
+ saveButtonTheme={saveButtonTheme}
242
+ files={nativeFiles}
243
+ borderRadius={borderRadius}
244
+ width={width}
245
+ height={height}
246
+ hideModal={async (fileList) => {
247
+ if (fileList) {
248
+ await saveFn(fileList);
249
+ }
250
+
251
+ setShowEditor(false);
252
+ updateProps({
253
+ ...store,
254
+ modalType: store.modalType,
255
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
256
+ // @ts-ignore
257
+ modalProps: {
258
+ ...store.modalProps,
259
+ hidden: false
260
+ }
261
+ });
262
+ }}
263
+ />
264
+ )}
265
+ <FieldFileUploadWrapper {...wrapperProps} $disabled={!!disabled}>
266
+ <FieldInput
267
+ {...props}
268
+ hidden
269
+ type="file"
270
+ accept={accept}
271
+ multiple={multiple}
272
+ onChange={async (e) => {
273
+ const files = e.target.files
274
+ ? Object.values(e.target.files)
275
+ : e.target.files;
276
+
277
+ if (files && withEditor) {
278
+ setNativeFiles(files);
279
+ setShowEditor(true);
280
+ updateProps({
281
+ ...store,
282
+ modalType: store.modalType,
283
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
284
+ // @ts-ignore
285
+ modalProps: {
286
+ ...store.modalProps,
287
+ hidden: true
288
+ }
289
+ });
290
+ } else {
291
+ await saveFn(files);
292
+ }
293
+ e.target.value = ""; // allow user to select the same file again
294
+ }}
295
+ ref={(ref) => {
296
+ inputRef.current = ref;
297
+ }}
298
+ disabled={disabled}
299
+ />
300
+ {trigger ? (
301
+ <ThemedButton onClick={handleChooseFile} type="button">
302
+ <>{trigger}</>
303
+ </ThemedButton>
304
+ ) : (
305
+ <FileUploadWrapper
306
+ data-disabled={disabled}
307
+ onClick={handleChooseFile}
308
+ $error={errorMessage}
309
+ style={style}
310
+ theme={theme?.triggerTheme}
311
+ >
312
+ {isLoading ? (
313
+ <Loading size={2} />
314
+ ) : (
315
+ <>
316
+ {field.value && field.value?.length !== 0 && preview ? (
317
+ <>
318
+ {isVideoOnly ? (
319
+ <VideoPreview
320
+ src={
321
+ preview?.startsWith("http")
322
+ ? preview
323
+ : "data:video/mp4;base64," +
324
+ preview?.substring(
325
+ "data:application/octet-stream;base64,".length
326
+ )
327
+ }
328
+ autoPlay
329
+ muted
330
+ loop
331
+ />
332
+ ) : (
333
+ <ImagePreview
334
+ style={{ ...imgPreviewStyle }}
335
+ src={preview}
336
+ />
337
+ )}
338
+ </>
339
+ ) : isVideoOnly ? (
340
+ <VideoCamera size={24} />
341
+ ) : (
342
+ <Image size={24} />
343
+ )}
344
+ {placeholder && (
345
+ <Typography tag="p" marginBottom={0} textAlign="center">
346
+ {placeholder}
347
+ </Typography>
348
+ )}
349
+ </>
350
+ )}
351
+ </FileUploadWrapper>
352
+ )}
353
+ {!disabled && field.value && field.value?.length !== 0 && preview && (
354
+ <div onClick={handleRemoveAllFiles} data-remove style={style}>
355
+ <Trash size={24} color={colors.white} />
356
+ </div>
357
+ )}
358
+ {multiple && (
359
+ <UploadedFiles files={files} handleRemoveFile={handleRemoveFile} />
360
+ )}
361
+ </FieldFileUploadWrapper>
362
+ <Error display={displayError} message={errorMessage} />
363
+ </>
364
+ );
365
+ }
366
+
367
+ export default WithUploadToIpfs(BaseUpload);