@bosonprotocol/react-kit 0.34.0-alpha.25 → 0.34.0-alpha.27
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.
- package/dist/cjs/components/form/Field.styles.d.ts +1 -0
- package/dist/cjs/components/form/Field.styles.d.ts.map +1 -1
- package/dist/cjs/components/form/Field.styles.js +1 -0
- package/dist/cjs/components/form/Field.styles.js.map +1 -1
- package/dist/cjs/components/form/Select.d.ts.map +1 -1
- package/dist/cjs/components/form/Select.js +2 -2
- package/dist/cjs/components/form/Select.js.map +1 -1
- package/dist/cjs/components/form/Upload/BaseUpload.d.ts +6 -0
- package/dist/cjs/components/form/Upload/BaseUpload.d.ts.map +1 -1
- package/dist/cjs/components/form/Upload/BaseUpload.js +23 -8
- package/dist/cjs/components/form/Upload/BaseUpload.js.map +1 -1
- package/dist/cjs/components/form/Upload/WithUploadToIpfs.d.ts +3 -1
- package/dist/cjs/components/form/Upload/WithUploadToIpfs.d.ts.map +1 -1
- package/dist/cjs/components/form/Upload/WithUploadToIpfs.js +5 -1
- package/dist/cjs/components/form/Upload/WithUploadToIpfs.js.map +1 -1
- package/dist/cjs/components/form/types.d.ts +7 -4
- package/dist/cjs/components/form/types.d.ts.map +1 -1
- package/dist/cjs/theme.d.ts +1 -0
- package/dist/cjs/theme.d.ts.map +1 -1
- package/dist/cjs/theme.js +2 -1
- package/dist/cjs/theme.js.map +1 -1
- package/dist/esm/components/form/Field.styles.d.ts +1 -0
- package/dist/esm/components/form/Field.styles.d.ts.map +1 -1
- package/dist/esm/components/form/Field.styles.js +1 -0
- package/dist/esm/components/form/Field.styles.js.map +1 -1
- package/dist/esm/components/form/Select.d.ts.map +1 -1
- package/dist/esm/components/form/Select.js +2 -2
- package/dist/esm/components/form/Select.js.map +1 -1
- package/dist/esm/components/form/Upload/BaseUpload.d.ts +6 -0
- package/dist/esm/components/form/Upload/BaseUpload.d.ts.map +1 -1
- package/dist/esm/components/form/Upload/BaseUpload.js +25 -10
- package/dist/esm/components/form/Upload/BaseUpload.js.map +1 -1
- package/dist/esm/components/form/Upload/WithUploadToIpfs.d.ts +3 -1
- package/dist/esm/components/form/Upload/WithUploadToIpfs.d.ts.map +1 -1
- package/dist/esm/components/form/Upload/WithUploadToIpfs.js +5 -1
- package/dist/esm/components/form/Upload/WithUploadToIpfs.js.map +1 -1
- package/dist/esm/components/form/types.d.ts +7 -4
- package/dist/esm/components/form/types.d.ts.map +1 -1
- package/dist/esm/theme.d.ts +1 -0
- package/dist/esm/theme.d.ts.map +1 -1
- package/dist/esm/theme.js +2 -1
- package/dist/esm/theme.js.map +1 -1
- package/package.json +5 -5
- package/src/components/form/Field.styles.ts +5 -1
- package/src/components/form/Select.tsx +3 -2
- package/src/components/form/Upload/BaseUpload.tsx +24 -11
- package/src/components/form/Upload/WithUploadToIpfs.tsx +8 -2
- package/src/components/form/types.ts +22 -6
- package/src/theme.ts +2 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseUpload.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/Upload/BaseUpload.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAmD,MAAM,OAAO,CAAC;AAgBxE,OAAO,KAAK,EACV,cAAc,EACd,WAAW,IAAI,qBAAqB,EAErC,MAAM,UAAU,CAAC;AAElB,OAAO,EAAoB,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAI7E,MAAM,MAAM,eAAe,GAAG,qBAAqB,CAAC
|
|
1
|
+
{"version":3,"file":"BaseUpload.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/Upload/BaseUpload.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAmD,MAAM,OAAO,CAAC;AAgBxE,OAAO,KAAK,EACV,cAAc,EACd,WAAW,IAAI,qBAAqB,EAErC,MAAM,UAAU,CAAC;AAElB,OAAO,EAAoB,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAI7E,MAAM,MAAM,eAAe,GAAG,qBAAqB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmWpD,wBAA4C"}
|
|
@@ -8,7 +8,7 @@ import { theme } from "../../../theme";
|
|
|
8
8
|
import Loading from "../../ui/loading/LoadingWrapper";
|
|
9
9
|
import ThemedButton from "../../ui/ThemedButton";
|
|
10
10
|
import { Typography } from "../../ui/Typography";
|
|
11
|
-
import
|
|
11
|
+
import ErrorComponent from "../Error";
|
|
12
12
|
import { FieldFileUploadWrapper, FieldInput, FileUploadWrapper, ImagePreview, VideoPreview } from "../Field.styles";
|
|
13
13
|
import UploadedFiles from "./UploadedFiles";
|
|
14
14
|
import { WithUploadToIpfs } from "./WithUploadToIpfs";
|
|
@@ -17,12 +17,13 @@ import { ImageEditorModal } from "./ImageEditorModal/ImageEditorModal";
|
|
|
17
17
|
const colors = theme.colors.light;
|
|
18
18
|
function BaseUpload({ name, accept = "image/*", disabled, maxSize, multiple = false, trigger, onFilesSelect, placeholder, wrapperProps, onLoadSinglePreviewImage, withUpload, withEditor, saveToIpfs, loadMedia, onLoading, width, height, borderRadius, borderRadiusUnit = "px", imgPreviewStyle,
|
|
19
19
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
20
|
-
removeFile, saveButtonTheme, theme, ...props }) {
|
|
20
|
+
removeFile, saveButtonTheme, errorComponent, theme, ...props }) {
|
|
21
21
|
const { updateProps, store } = useModal();
|
|
22
22
|
const [showEditor, setShowEditor] = useState(false);
|
|
23
23
|
const [isLoading, setIsLoading] = useState(false);
|
|
24
24
|
const [preview, setPreview] = useState();
|
|
25
25
|
const [field, meta, helpers] = useField(name);
|
|
26
|
+
const [errorMesage, setErrorMessage] = useState();
|
|
26
27
|
const handleLoading = useCallback((loadingValue) => {
|
|
27
28
|
onLoading?.(loadingValue);
|
|
28
29
|
setIsLoading(loadingValue);
|
|
@@ -152,15 +153,28 @@ removeFile, saveButtonTheme, theme, ...props }) {
|
|
|
152
153
|
helpers.setTouched(true);
|
|
153
154
|
}
|
|
154
155
|
handleLoading(true);
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
156
|
+
try {
|
|
157
|
+
const files = await saveToIpfs(efiles, { throwOnError: true });
|
|
158
|
+
setErrorMessage(undefined);
|
|
159
|
+
if (files) {
|
|
160
|
+
setFiles(files);
|
|
161
|
+
}
|
|
162
|
+
else {
|
|
163
|
+
setFiles([]);
|
|
164
|
+
console.warn(`There has been an error because 'files' ${files} is falsy in handleSave`);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
catch (err) {
|
|
168
|
+
if (err instanceof Error) {
|
|
169
|
+
setErrorMessage(err.message);
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
setErrorMessage("Something went wrong");
|
|
173
|
+
}
|
|
158
174
|
}
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
console.warn(`There has been an error because 'files' ${files} is falsy in handleSave`);
|
|
175
|
+
finally {
|
|
176
|
+
handleLoading(false);
|
|
162
177
|
}
|
|
163
|
-
handleLoading(false);
|
|
164
178
|
}, [meta.touched, handleLoading, saveToIpfs, helpers, setFiles]);
|
|
165
179
|
const saveFn = withUpload ? handleSave : handleChange;
|
|
166
180
|
const style = {
|
|
@@ -185,6 +199,7 @@ removeFile, saveButtonTheme, theme, ...props }) {
|
|
|
185
199
|
}
|
|
186
200
|
});
|
|
187
201
|
} })),
|
|
202
|
+
errorMesage && errorComponent?.(errorMesage),
|
|
188
203
|
React.createElement(FieldFileUploadWrapper, { ...wrapperProps, "$disabled": !!disabled },
|
|
189
204
|
React.createElement(FieldInput, { ...props, hidden: true, type: "file", accept: accept, multiple: multiple, onChange: async (e) => {
|
|
190
205
|
const files = e.target.files
|
|
@@ -223,7 +238,7 @@ removeFile, saveButtonTheme, theme, ...props }) {
|
|
|
223
238
|
!disabled && field.value && field.value?.length !== 0 && preview && (React.createElement("div", { onClick: handleRemoveAllFiles, "data-remove": true, style: style },
|
|
224
239
|
React.createElement(Trash, { size: 24, color: colors.white }))),
|
|
225
240
|
multiple && (React.createElement(UploadedFiles, { files: files, handleRemoveFile: handleRemoveFile }))),
|
|
226
|
-
React.createElement(
|
|
241
|
+
React.createElement(ErrorComponent, { display: displayError, message: errorMessage })));
|
|
227
242
|
}
|
|
228
243
|
export default WithUploadToIpfs(BaseUpload);
|
|
229
244
|
//# sourceMappingURL=BaseUpload.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseUpload.js","sourceRoot":"","sources":["../../../../../src/components/form/Upload/BaseUpload.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,OAAO,OAAO,MAAM,iCAAiC,CAAC;AACtD,OAAO,YAAY,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,
|
|
1
|
+
{"version":3,"file":"BaseUpload.js","sourceRoot":"","sources":["../../../../../src/components/form/Upload/BaseUpload.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,9 @@ import { FileProps, UploadProps } from "../types";
|
|
|
3
3
|
export declare const MAX_FILE_SIZE: number;
|
|
4
4
|
export declare const SUPPORTED_FORMATS: string[];
|
|
5
5
|
export interface WithUploadToIpfsProps {
|
|
6
|
-
saveToIpfs: (files: File[] | null
|
|
6
|
+
saveToIpfs: (files: File[] | null, options?: {
|
|
7
|
+
throwOnError?: boolean;
|
|
8
|
+
}) => Promise<false | FileProps[] | undefined>;
|
|
7
9
|
loadMedia: (src: string) => Promise<string | undefined>;
|
|
8
10
|
removeFile: (src: string) => Promise<void>;
|
|
9
11
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WithUploadToIpfs.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/Upload/WithUploadToIpfs.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA+B,MAAM,OAAO,CAAC;AAQpD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAMlD,eAAO,MAAM,aAAa,QAAmB,CAAC;AAC9C,eAAO,MAAM,iBAAiB,UAM7B,CAAC;AACF,MAAM,WAAW,qBAAqB;IACpC,UAAU,EAAE,CACV,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"WithUploadToIpfs.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/Upload/WithUploadToIpfs.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA+B,MAAM,OAAO,CAAC;AAQpD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAMlD,eAAO,MAAM,aAAa,QAAmB,CAAC;AAC9C,eAAO,MAAM,iBAAiB,UAM7B,CAAC;AACF,MAAM,WAAW,qBAAqB;IACpC,UAAU,EAAE,CACV,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,EACpB,OAAO,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,OAAO,CAAA;KAAE,KACjC,OAAO,CAAC,KAAK,GAAG,SAAS,EAAE,GAAG,SAAS,CAAC,CAAC;IAC9C,SAAS,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC;IACxD,UAAU,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC5C;AACD,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,qBAAqB,EAC9D,gBAAgB,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,WAG/B,KAAK,CAAC,GAAG,WAAW,EAAE,MAAM,qBAAqB,CAAC,iBA6F5D"}
|
|
@@ -22,7 +22,7 @@ export function WithUploadToIpfs(WrappedComponent) {
|
|
|
22
22
|
const accept = props.accept || SUPPORTED_FORMATS.join(",");
|
|
23
23
|
const maxSize = Number(props.maxSize) || MAX_FILE_SIZE;
|
|
24
24
|
const { saveFile, loadMedia, removeFile } = useSaveImageToIpfs();
|
|
25
|
-
const saveToIpfs = useCallback(async (filesArray) => {
|
|
25
|
+
const saveToIpfs = useCallback(async (filesArray, options = {}) => {
|
|
26
26
|
if (!filesArray) {
|
|
27
27
|
return;
|
|
28
28
|
}
|
|
@@ -32,10 +32,14 @@ export function WithUploadToIpfs(WrappedComponent) {
|
|
|
32
32
|
const formatValidation = accept.split(",").map((acc) => acc.trim());
|
|
33
33
|
if (file?.size > sizeValidation) {
|
|
34
34
|
const err = `File ${file?.name} size cannot exceed more than ${bytesToSize(sizeValidation)}!`;
|
|
35
|
+
if (options?.throwOnError)
|
|
36
|
+
throw new Error(err);
|
|
35
37
|
filesErrors.push(err);
|
|
36
38
|
}
|
|
37
39
|
if (!formatValidation.includes(file?.type)) {
|
|
38
40
|
const err = `Uploaded file has unsupported format of ${file?.type}!`;
|
|
41
|
+
if (options?.throwOnError)
|
|
42
|
+
throw new Error(err);
|
|
39
43
|
filesErrors.push(err);
|
|
40
44
|
}
|
|
41
45
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WithUploadToIpfs.js","sourceRoot":"","sources":["../../../../../src/components/form/Upload/WithUploadToIpfs.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,KAAK,MAAM,iBAAiB,CAAC;AAEpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,UAAU,MAAM,gCAAgC,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAE7D,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;AAElC,MAAM,CAAC,MAAM,aAAa,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC;AAC9C,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,WAAW;IACX,YAAY;IACZ,WAAW;IACX,WAAW;IACX,YAAY;CACb,CAAC;
|
|
1
|
+
{"version":3,"file":"WithUploadToIpfs.js","sourceRoot":"","sources":["../../../../../src/components/form/Upload/WithUploadToIpfs.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { ReactNode } from "react";
|
|
2
|
-
import { CSSObjectWithLabel, MultiValue, SingleValue } from "react-select";
|
|
2
|
+
import { ActionMeta, CSSObjectWithLabel, MultiValue, SingleValue } from "react-select";
|
|
3
3
|
import { CSSProperties } from "styled-components";
|
|
4
4
|
import { ImageEditorModalProps } from "./Upload/ImageEditorModal/ImageEditorModal";
|
|
5
5
|
import type { CheckboxTheme, FileUploadWrapperTheme, TextAreaTheme } from "./Field.styles";
|
|
6
6
|
import type { GridProps } from "../ui/Grid";
|
|
7
|
+
import { StateManagerProps } from "react-select/dist/declarations/src/useStateManager";
|
|
7
8
|
export interface BaseProps {
|
|
8
9
|
name: string;
|
|
9
10
|
placeholder?: string;
|
|
@@ -65,14 +66,14 @@ export interface BaseSelectProps {
|
|
|
65
66
|
defaultValue?: SelectDataProps | null;
|
|
66
67
|
onChange?: OnChange;
|
|
67
68
|
}
|
|
68
|
-
export
|
|
69
|
+
export type SelectProps<M extends boolean | undefined = false> = BaseProps & {
|
|
69
70
|
isMulti?: M;
|
|
70
71
|
disabled?: boolean;
|
|
71
72
|
isClearable?: boolean;
|
|
72
73
|
isSearchable?: boolean;
|
|
73
74
|
options: Array<SelectDataProps> | Readonly<Array<SelectDataProps>>;
|
|
74
75
|
errorMessage?: string;
|
|
75
|
-
onChange?: (option: M extends true ? MultiValue<SelectDataProps<string>> : SingleValue<SelectDataProps<string>>) => void;
|
|
76
|
+
onChange?: (option: M extends true ? MultiValue<SelectDataProps<string>> : SingleValue<SelectDataProps<string>>, actionMeta?: ActionMeta<SelectDataProps<string>>) => void;
|
|
76
77
|
label?: string;
|
|
77
78
|
theme?: Partial<{
|
|
78
79
|
control: Partial<CSSProperties> & Partial<{
|
|
@@ -96,7 +97,7 @@ export interface SelectProps<M extends boolean | undefined = false> extends Base
|
|
|
96
97
|
error: CSSObjectWithLabel;
|
|
97
98
|
}>;
|
|
98
99
|
}>;
|
|
99
|
-
}
|
|
100
|
+
} & Pick<StateManagerProps<SelectDataProps<string>, M extends undefined ? false : boolean>, "formatGroupLabel" | "formatOptionLabel">;
|
|
100
101
|
export type UploadProps = BaseProps & {
|
|
101
102
|
accept?: string;
|
|
102
103
|
multiple?: boolean;
|
|
@@ -112,9 +113,11 @@ export type UploadProps = BaseProps & {
|
|
|
112
113
|
borderRadiusUnit?: "px" | "%";
|
|
113
114
|
width?: number;
|
|
114
115
|
height?: number;
|
|
116
|
+
errorComponent?: (errorMessage: string) => React.ReactNode;
|
|
115
117
|
imgPreviewStyle?: Pick<CSSProperties, "objectFit">;
|
|
116
118
|
theme?: Partial<{
|
|
117
119
|
triggerTheme: FileUploadWrapperTheme;
|
|
120
|
+
overrides: React.CSSProperties;
|
|
118
121
|
}>;
|
|
119
122
|
} & ({
|
|
120
123
|
withEditor: true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/form/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAClC,OAAO,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/form/types.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/theme.d.ts
CHANGED
package/dist/esm/theme.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/theme.ts"],"names":[],"mappings":"AAAA,OAAO,mBAAmB,CAAC;AAE3B,eAAO,MAAM,KAAK
|
|
1
|
+
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/theme.ts"],"names":[],"mappings":"AAAA,OAAO,mBAAmB,CAAC;AAE3B,eAAO,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6CR,CAAC"}
|
package/dist/esm/theme.js
CHANGED
package/dist/esm/theme.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme.js","sourceRoot":"","sources":["../../src/theme.ts"],"names":[],"mappings":"AAAA,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,MAAM,EAAE;QACN,KAAK,EAAE;YACL,OAAO,EAAE,SAAS;YAClB,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,SAAS;YACjB,KAAK,EAAE,SAAS;YAChB,SAAS,EAAE,SAAS;YACpB,QAAQ,EAAE,SAAS;YACnB,KAAK,EAAE,SAAS;YAChB,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE,SAAS;YACd,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,SAAS;YACjB,IAAI,EAAE,SAAS;YACf,QAAQ,EAAE,SAAS;YACnB,MAAM,EAAE,WAAW;YACnB,OAAO,EAAE,SAAS;YAClB,cAAc,EAAE,SAAS;YACzB,UAAU,EAAE,YAAY;YACxB,KAAK,EAAE,SAAS;YAChB,YAAY,EAAE,SAAS;YACvB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,SAAS;YAClB,IAAI,EAAE,SAAS;YACf,eAAe,EAAE,SAAS;YAC1B,iBAAiB,EAAE,SAAS;YAC5B,UAAU,EAAE,SAAS;
|
|
1
|
+
{"version":3,"file":"theme.js","sourceRoot":"","sources":["../../src/theme.ts"],"names":[],"mappings":"AAAA,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,MAAM,EAAE;QACN,KAAK,EAAE;YACL,OAAO,EAAE,SAAS;YAClB,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,SAAS;YACjB,KAAK,EAAE,SAAS;YAChB,SAAS,EAAE,SAAS;YACpB,QAAQ,EAAE,SAAS;YACnB,KAAK,EAAE,SAAS;YAChB,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE,SAAS;YACd,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,SAAS;YACjB,IAAI,EAAE,SAAS;YACf,QAAQ,EAAE,SAAS;YACnB,MAAM,EAAE,WAAW;YACnB,OAAO,EAAE,SAAS;YAClB,cAAc,EAAE,SAAS;YACzB,UAAU,EAAE,YAAY;YACxB,KAAK,EAAE,SAAS;YAChB,YAAY,EAAE,SAAS;YACvB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,SAAS;YAClB,IAAI,EAAE,SAAS;YACf,eAAe,EAAE,SAAS;YAC1B,iBAAiB,EAAE,SAAS;YAC5B,UAAU,EAAE,SAAS;YACrB,QAAQ,EAAE,wBAAwB;SACnC;KACF;IACD,MAAM,EAAE,OAAO;IACf,MAAM,EAAE,QAAQ;IAChB,SAAS,EAAE;QACT,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;QACd,KAAK,EAAE,MAAM;KACd;IACD,UAAU,EAAE;QACV,IAAI,EAAE,OAAO;QACb,MAAM,EAAE,aAAa;KACtB;CACO,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bosonprotocol/react-kit",
|
|
3
3
|
"description": "React toolkit with smart components and hooks for building on top of the Boson Protocol.",
|
|
4
|
-
"version": "0.34.0-alpha.
|
|
4
|
+
"version": "0.34.0-alpha.27",
|
|
5
5
|
"main": "./dist/cjs/index.js",
|
|
6
6
|
"module": "./dist/esm/index.js",
|
|
7
7
|
"types": "./dist/cjs/index.d.ts",
|
|
@@ -15,9 +15,9 @@
|
|
|
15
15
|
"license": "Apache-2.0",
|
|
16
16
|
"dependencies": {
|
|
17
17
|
"@bosonprotocol/chat-sdk": "^1.3.1-alpha.9",
|
|
18
|
-
"@bosonprotocol/core-sdk": "^1.41.0-alpha.
|
|
19
|
-
"@bosonprotocol/ethers-sdk": "^1.15.0-alpha.
|
|
20
|
-
"@bosonprotocol/ipfs-storage": "^1.12.0-alpha.
|
|
18
|
+
"@bosonprotocol/core-sdk": "^1.41.0-alpha.29",
|
|
19
|
+
"@bosonprotocol/ethers-sdk": "^1.15.0-alpha.15",
|
|
20
|
+
"@bosonprotocol/ipfs-storage": "^1.12.0-alpha.27",
|
|
21
21
|
"@davatar/react": "1.11.1",
|
|
22
22
|
"@ethersproject/units": "5.6.0",
|
|
23
23
|
"@glidejs/glide": "3.6.0",
|
|
@@ -188,5 +188,5 @@
|
|
|
188
188
|
"overrides": {
|
|
189
189
|
"typescript": "^5.1.6"
|
|
190
190
|
},
|
|
191
|
-
"gitHead": "
|
|
191
|
+
"gitHead": "6896e3ed8e353fcdc8a6377ea5a89e6feee055f6"
|
|
192
192
|
}
|
|
@@ -125,6 +125,7 @@ export type FileUploadWrapperTheme = Partial<{
|
|
|
125
125
|
error: Partial<{
|
|
126
126
|
borderColor: CSSProperties["borderColor"];
|
|
127
127
|
}>;
|
|
128
|
+
overrides: Partial<CSSProperties>;
|
|
128
129
|
}>;
|
|
129
130
|
export const FileUploadWrapper = styled.div<{
|
|
130
131
|
$error: unknown;
|
|
@@ -188,13 +189,16 @@ export const FileUploadWrapper = styled.div<{
|
|
|
188
189
|
cursor: not-allowed;
|
|
189
190
|
opacity: 0.5;
|
|
190
191
|
}
|
|
192
|
+
${({ theme: { overrides } }) => overrides}
|
|
191
193
|
`;
|
|
192
194
|
|
|
193
195
|
export const FieldFileUpload = styled(FieldInput)`
|
|
194
196
|
display: none;
|
|
195
197
|
`;
|
|
196
198
|
|
|
197
|
-
export const FieldFileUploadWrapper = styled.div<{
|
|
199
|
+
export const FieldFileUploadWrapper = styled.div<{
|
|
200
|
+
$disabled: boolean;
|
|
201
|
+
}>`
|
|
198
202
|
position: relative;
|
|
199
203
|
display: inline-block;
|
|
200
204
|
${({ $disabled }) =>
|
|
@@ -126,13 +126,14 @@ export default function SelectComponent<M extends boolean>({
|
|
|
126
126
|
typeof displayErrorMessage === "string" && displayErrorMessage !== "";
|
|
127
127
|
|
|
128
128
|
const handleChange = (
|
|
129
|
-
option: Parameters<NonNullable<typeof onChange>>[0]
|
|
129
|
+
option: Parameters<NonNullable<typeof onChange>>[0],
|
|
130
|
+
actionMeta: Parameters<NonNullable<typeof onChange>>[1]
|
|
130
131
|
) => {
|
|
131
132
|
if (!meta.touched) {
|
|
132
133
|
helpers.setTouched(true);
|
|
133
134
|
}
|
|
134
135
|
helpers.setValue(option);
|
|
135
|
-
onChange?.(option);
|
|
136
|
+
onChange?.(option, actionMeta);
|
|
136
137
|
};
|
|
137
138
|
const handleBlur = () => {
|
|
138
139
|
if (!meta.touched) {
|
|
@@ -9,7 +9,7 @@ import { theme } from "../../../theme";
|
|
|
9
9
|
import Loading from "../../ui/loading/LoadingWrapper";
|
|
10
10
|
import ThemedButton from "../../ui/ThemedButton";
|
|
11
11
|
import { Typography } from "../../ui/Typography";
|
|
12
|
-
import
|
|
12
|
+
import ErrorComponent from "../Error";
|
|
13
13
|
import {
|
|
14
14
|
FieldFileUploadWrapper,
|
|
15
15
|
FieldInput,
|
|
@@ -52,6 +52,7 @@ function BaseUpload({
|
|
|
52
52
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
53
53
|
removeFile,
|
|
54
54
|
saveButtonTheme,
|
|
55
|
+
errorComponent,
|
|
55
56
|
theme,
|
|
56
57
|
...props
|
|
57
58
|
}: UploadPropsWithNoIpfs & WithUploadToIpfsProps) {
|
|
@@ -60,6 +61,7 @@ function BaseUpload({
|
|
|
60
61
|
const [isLoading, setIsLoading] = useState<boolean>(false);
|
|
61
62
|
const [preview, setPreview] = useState<string | null>();
|
|
62
63
|
const [field, meta, helpers] = useField(name);
|
|
64
|
+
const [errorMesage, setErrorMessage] = useState<string>();
|
|
63
65
|
|
|
64
66
|
const handleLoading = useCallback(
|
|
65
67
|
(loadingValue: boolean) => {
|
|
@@ -216,16 +218,26 @@ function BaseUpload({
|
|
|
216
218
|
helpers.setTouched(true);
|
|
217
219
|
}
|
|
218
220
|
handleLoading(true);
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
221
|
+
try {
|
|
222
|
+
const files = await saveToIpfs(efiles, { throwOnError: true });
|
|
223
|
+
setErrorMessage(undefined);
|
|
224
|
+
if (files) {
|
|
225
|
+
setFiles(files);
|
|
226
|
+
} else {
|
|
227
|
+
setFiles([]);
|
|
228
|
+
console.warn(
|
|
229
|
+
`There has been an error because 'files' ${files} is falsy in handleSave`
|
|
230
|
+
);
|
|
231
|
+
}
|
|
232
|
+
} catch (err) {
|
|
233
|
+
if (err instanceof Error) {
|
|
234
|
+
setErrorMessage(err.message);
|
|
235
|
+
} else {
|
|
236
|
+
setErrorMessage("Something went wrong");
|
|
237
|
+
}
|
|
238
|
+
} finally {
|
|
239
|
+
handleLoading(false);
|
|
227
240
|
}
|
|
228
|
-
handleLoading(false);
|
|
229
241
|
},
|
|
230
242
|
[meta.touched, handleLoading, saveToIpfs, helpers, setFiles]
|
|
231
243
|
);
|
|
@@ -263,6 +275,7 @@ function BaseUpload({
|
|
|
263
275
|
}}
|
|
264
276
|
/>
|
|
265
277
|
)}
|
|
278
|
+
{errorMesage && errorComponent?.(errorMesage)}
|
|
266
279
|
<FieldFileUploadWrapper {...wrapperProps} $disabled={!!disabled}>
|
|
267
280
|
<FieldInput
|
|
268
281
|
{...props}
|
|
@@ -364,7 +377,7 @@ function BaseUpload({
|
|
|
364
377
|
<UploadedFiles files={files} handleRemoveFile={handleRemoveFile} />
|
|
365
378
|
)}
|
|
366
379
|
</FieldFileUploadWrapper>
|
|
367
|
-
<
|
|
380
|
+
<ErrorComponent display={displayError} message={errorMessage} />
|
|
368
381
|
</>
|
|
369
382
|
);
|
|
370
383
|
}
|
|
@@ -22,7 +22,8 @@ export const SUPPORTED_FORMATS = [
|
|
|
22
22
|
];
|
|
23
23
|
export interface WithUploadToIpfsProps {
|
|
24
24
|
saveToIpfs: (
|
|
25
|
-
files: File[] | null
|
|
25
|
+
files: File[] | null,
|
|
26
|
+
options?: { throwOnError?: boolean }
|
|
26
27
|
) => Promise<false | FileProps[] | undefined>;
|
|
27
28
|
loadMedia: (src: string) => Promise<string | undefined>;
|
|
28
29
|
removeFile: (src: string) => Promise<void>;
|
|
@@ -39,7 +40,10 @@ export function WithUploadToIpfs<P extends WithUploadToIpfsProps>(
|
|
|
39
40
|
const { saveFile, loadMedia, removeFile } = useSaveImageToIpfs();
|
|
40
41
|
|
|
41
42
|
const saveToIpfs: WithUploadToIpfsProps["saveToIpfs"] = useCallback(
|
|
42
|
-
async (
|
|
43
|
+
async (
|
|
44
|
+
filesArray: File[] | null,
|
|
45
|
+
options: { throwOnError?: boolean } = {}
|
|
46
|
+
) => {
|
|
43
47
|
if (!filesArray) {
|
|
44
48
|
return;
|
|
45
49
|
}
|
|
@@ -53,10 +57,12 @@ export function WithUploadToIpfs<P extends WithUploadToIpfsProps>(
|
|
|
53
57
|
const err = `File ${
|
|
54
58
|
file?.name
|
|
55
59
|
} size cannot exceed more than ${bytesToSize(sizeValidation)}!`;
|
|
60
|
+
if (options?.throwOnError) throw new Error(err);
|
|
56
61
|
filesErrors.push(err);
|
|
57
62
|
}
|
|
58
63
|
if (!formatValidation.includes(file?.type)) {
|
|
59
64
|
const err = `Uploaded file has unsupported format of ${file?.type}!`;
|
|
65
|
+
if (options?.throwOnError) throw new Error(err);
|
|
60
66
|
filesErrors.push(err);
|
|
61
67
|
}
|
|
62
68
|
}
|
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
import { ReactNode } from "react";
|
|
2
|
-
import {
|
|
2
|
+
import {
|
|
3
|
+
ActionMeta,
|
|
4
|
+
CSSObjectWithLabel,
|
|
5
|
+
MultiValue,
|
|
6
|
+
SingleValue
|
|
7
|
+
} from "react-select";
|
|
3
8
|
import { CSSProperties } from "styled-components";
|
|
4
9
|
import { ImageEditorModalProps } from "./Upload/ImageEditorModal/ImageEditorModal";
|
|
5
10
|
import type {
|
|
@@ -8,6 +13,7 @@ import type {
|
|
|
8
13
|
TextAreaTheme
|
|
9
14
|
} from "./Field.styles";
|
|
10
15
|
import type { GridProps } from "../ui/Grid";
|
|
16
|
+
import { StateManagerProps } from "react-select/dist/declarations/src/useStateManager";
|
|
11
17
|
|
|
12
18
|
export interface BaseProps {
|
|
13
19
|
name: string;
|
|
@@ -86,8 +92,7 @@ export interface BaseSelectProps {
|
|
|
86
92
|
onChange?: OnChange;
|
|
87
93
|
}
|
|
88
94
|
|
|
89
|
-
export
|
|
90
|
-
extends BaseProps {
|
|
95
|
+
export type SelectProps<M extends boolean | undefined = false> = BaseProps & {
|
|
91
96
|
isMulti?: M;
|
|
92
97
|
disabled?: boolean;
|
|
93
98
|
isClearable?: boolean;
|
|
@@ -97,7 +102,8 @@ export interface SelectProps<M extends boolean | undefined = false>
|
|
|
97
102
|
onChange?: (
|
|
98
103
|
option: M extends true
|
|
99
104
|
? MultiValue<SelectDataProps<string>>
|
|
100
|
-
: SingleValue<SelectDataProps<string
|
|
105
|
+
: SingleValue<SelectDataProps<string>>,
|
|
106
|
+
actionMeta?: ActionMeta<SelectDataProps<string>>
|
|
101
107
|
) => void;
|
|
102
108
|
label?: string;
|
|
103
109
|
theme?: Partial<{
|
|
@@ -120,7 +126,13 @@ export interface SelectProps<M extends boolean | undefined = false>
|
|
|
120
126
|
singleValue: Partial<CSSProperties> &
|
|
121
127
|
Partial<{ error: CSSObjectWithLabel }>;
|
|
122
128
|
}>;
|
|
123
|
-
}
|
|
129
|
+
} & Pick<
|
|
130
|
+
StateManagerProps<
|
|
131
|
+
SelectDataProps<string>,
|
|
132
|
+
M extends undefined ? false : boolean
|
|
133
|
+
>,
|
|
134
|
+
"formatGroupLabel" | "formatOptionLabel"
|
|
135
|
+
>;
|
|
124
136
|
|
|
125
137
|
export type UploadProps = BaseProps & {
|
|
126
138
|
accept?: string;
|
|
@@ -137,8 +149,12 @@ export type UploadProps = BaseProps & {
|
|
|
137
149
|
borderRadiusUnit?: "px" | "%";
|
|
138
150
|
width?: number;
|
|
139
151
|
height?: number;
|
|
152
|
+
errorComponent?: (errorMessage: string) => React.ReactNode;
|
|
140
153
|
imgPreviewStyle?: Pick<CSSProperties, "objectFit">;
|
|
141
|
-
theme?: Partial<{
|
|
154
|
+
theme?: Partial<{
|
|
155
|
+
triggerTheme: FileUploadWrapperTheme;
|
|
156
|
+
overrides: React.CSSProperties;
|
|
157
|
+
}>;
|
|
142
158
|
} & (
|
|
143
159
|
| {
|
|
144
160
|
withEditor: true;
|