@bit.rhplus/ui.upload-files-sheet 0.0.2
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/index.d.ts +3 -0
- package/dist/index.js +38 -0
- package/dist/index.js.map +1 -0
- package/dist/preview-1727868917903.js +7 -0
- package/dist/uploadFiles.d.ts +4 -0
- package/dist/uploadFiles.js +66 -0
- package/dist/uploadFiles.js.map +1 -0
- package/index.jsx +91 -0
- package/package.json +31 -0
- package/types/asset.d.ts +43 -0
- package/types/style.d.ts +42 -0
- package/uploadFiles.js +73 -0
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
// eslint-disable-next-line import/no-unresolved
|
|
4
|
+
import * as F7 from 'framework7-react';
|
|
5
|
+
import { ErrorIcon, LoadingIcon, SuccessIcon } from '@rhplus/wieldy.animate-icons';
|
|
6
|
+
import prettyBytes from 'pretty-bytes';
|
|
7
|
+
import useUploadFiles from './uploadFiles';
|
|
8
|
+
const UploadFilesSheet = React.forwardRef((props, ref) => {
|
|
9
|
+
const { autoClose = true, closeTimeout = 4000 } = props;
|
|
10
|
+
const { uploadFiles } = useUploadFiles(props.api);
|
|
11
|
+
const [opened, setOpened] = React.useState(false);
|
|
12
|
+
const [progressFiles, setProgressFiles] = React.useState({});
|
|
13
|
+
const { files: uploadedFiles = [] } = progressFiles || {};
|
|
14
|
+
const onInternalClose = () => {
|
|
15
|
+
setOpened(false);
|
|
16
|
+
};
|
|
17
|
+
const onProgress = (progress) => setProgressFiles(progress);
|
|
18
|
+
const handleFilesSelected = (selectedFiles) => {
|
|
19
|
+
setOpened(true);
|
|
20
|
+
uploadFiles(selectedFiles, onProgress);
|
|
21
|
+
};
|
|
22
|
+
React.useImperativeHandle(ref, () => ({
|
|
23
|
+
handleFilesSelected,
|
|
24
|
+
}));
|
|
25
|
+
React.useEffect(() => {
|
|
26
|
+
if (uploadedFiles.length > 0 &&
|
|
27
|
+
uploadedFiles.every(file => file.state === 'success') &&
|
|
28
|
+
opened &&
|
|
29
|
+
autoClose) {
|
|
30
|
+
setTimeout(() => {
|
|
31
|
+
setOpened(false);
|
|
32
|
+
}, closeTimeout || 0);
|
|
33
|
+
}
|
|
34
|
+
}, [uploadedFiles, opened]);
|
|
35
|
+
return (_jsxs(F7.Sheet, { className: "demo-sheet-swipe-to-step", style: { height: 'auto' }, swipeToClose: true, swipeToStep: true, push: true, backdrop: true, opened: opened, onSheetClose: onInternalClose, children: [_jsx("div", { className: "swipe-handler" }), _jsxs("div", { className: "sheet-modal-swipe-step", children: [_jsx(F7.BlockTitle, { children: "Odes\u00EDl\u00E1m ..." }), _jsx(F7.Block, { children: _jsx(F7.List, { dividersIos: true, outlineIos: true, strongIos: true, children: uploadedFiles.map(({ name, size, state }) => (_jsx(F7.ListItem, { header: "Soubor", title: name, after: prettyBytes(size), children: _jsx("div", { className: "item-title-row2", children: _jsxs("div", { className: "item-title2", children: [state === 'success' && (_jsx(SuccessIcon, { loop: false, animate: true, height: 30, state: state })), state === 'loading' && (_jsx(LoadingIcon, { loop: true, animate: true, height: 30, state: state })), state === 'error' && (_jsx(ErrorIcon, { loop: false, animate: true, height: 30, state: state }))] }) }) }, name))) }) }), _jsx(F7.Block, {})] })] }));
|
|
36
|
+
});
|
|
37
|
+
export default UploadFilesSheet;
|
|
38
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.jsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import useData from '@rhplus/wieldy.data';
|
|
2
|
+
const StateEnum = {
|
|
3
|
+
Waiting: 'waiting',
|
|
4
|
+
Loading: 'loading',
|
|
5
|
+
Success: 'success',
|
|
6
|
+
Error: 'error',
|
|
7
|
+
};
|
|
8
|
+
const useUploadFiles = (api) => {
|
|
9
|
+
const { fetchData } = useData();
|
|
10
|
+
const uploadFiles = async (event, onProgress) => {
|
|
11
|
+
if (!event.target.files || event.target.files.length === 0)
|
|
12
|
+
return;
|
|
13
|
+
const files = Array.from(event.target.files);
|
|
14
|
+
const total = files.length;
|
|
15
|
+
let progress = {
|
|
16
|
+
current: 0,
|
|
17
|
+
total,
|
|
18
|
+
files: files.map(({ name, size, type }) => ({
|
|
19
|
+
name,
|
|
20
|
+
size,
|
|
21
|
+
type,
|
|
22
|
+
state: StateEnum.Waiting,
|
|
23
|
+
})),
|
|
24
|
+
};
|
|
25
|
+
onProgress(progress);
|
|
26
|
+
const uploadFile = async (file, index) => {
|
|
27
|
+
progress = {
|
|
28
|
+
...progress,
|
|
29
|
+
files: progress.files.map((f, i) => {
|
|
30
|
+
if (i === index)
|
|
31
|
+
return { ...f, state: StateEnum.Loading };
|
|
32
|
+
return f;
|
|
33
|
+
}),
|
|
34
|
+
};
|
|
35
|
+
onProgress(progress);
|
|
36
|
+
try {
|
|
37
|
+
const formData = new FormData();
|
|
38
|
+
formData.append('Files', file);
|
|
39
|
+
await fetchData(api, formData);
|
|
40
|
+
progress = {
|
|
41
|
+
...progress,
|
|
42
|
+
files: progress.files.map((f, i) => {
|
|
43
|
+
if (i === index)
|
|
44
|
+
return { ...f, state: StateEnum.Success };
|
|
45
|
+
return f;
|
|
46
|
+
}),
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
progress = {
|
|
51
|
+
...progress,
|
|
52
|
+
files: progress.files.map((f, i) => {
|
|
53
|
+
if (i === index)
|
|
54
|
+
return { ...f, state: StateEnum.Error };
|
|
55
|
+
return f;
|
|
56
|
+
}),
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
onProgress(progress);
|
|
60
|
+
};
|
|
61
|
+
await Promise.all(files.map((file, index) => uploadFile(file, index)));
|
|
62
|
+
};
|
|
63
|
+
return { uploadFiles };
|
|
64
|
+
};
|
|
65
|
+
export default useUploadFiles;
|
|
66
|
+
//# sourceMappingURL=uploadFiles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"uploadFiles.js","sourceRoot":"","sources":["../uploadFiles.js"],"names":[],"mappings":"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"}
|
package/index.jsx
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
// eslint-disable-next-line import/no-unresolved
|
|
3
|
+
import * as F7 from 'framework7-react';
|
|
4
|
+
import { ErrorIcon, LoadingIcon, SuccessIcon } from '@rhplus/wieldy.animate-icons';
|
|
5
|
+
import prettyBytes from 'pretty-bytes';
|
|
6
|
+
import useUploadFiles from './uploadFiles';
|
|
7
|
+
|
|
8
|
+
const UploadFilesSheet = React.forwardRef((props, ref) => {
|
|
9
|
+
const { autoClose = true, closeTimeout = 4000 } = props;
|
|
10
|
+
const { uploadFiles } = useUploadFiles(props.api);
|
|
11
|
+
const [opened, setOpened] = React.useState(false);
|
|
12
|
+
const [progressFiles, setProgressFiles] = React.useState({});
|
|
13
|
+
|
|
14
|
+
const { files: uploadedFiles = [] } = progressFiles || {};
|
|
15
|
+
|
|
16
|
+
const onInternalClose = () => {
|
|
17
|
+
setOpened(false);
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
const onProgress = (progress) => setProgressFiles(progress);
|
|
21
|
+
|
|
22
|
+
const handleFilesSelected = (selectedFiles) => {
|
|
23
|
+
setOpened(true);
|
|
24
|
+
uploadFiles(selectedFiles, onProgress);
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
React.useImperativeHandle(ref, () => ({
|
|
28
|
+
handleFilesSelected,
|
|
29
|
+
}));
|
|
30
|
+
|
|
31
|
+
React.useEffect(() => {
|
|
32
|
+
if (
|
|
33
|
+
uploadedFiles.length > 0 &&
|
|
34
|
+
uploadedFiles.every(file => file.state === 'success') &&
|
|
35
|
+
opened &&
|
|
36
|
+
autoClose
|
|
37
|
+
) {
|
|
38
|
+
setTimeout(() => {
|
|
39
|
+
setOpened(false);
|
|
40
|
+
}, closeTimeout || 0);
|
|
41
|
+
}
|
|
42
|
+
}, [uploadedFiles, opened]);
|
|
43
|
+
|
|
44
|
+
return (
|
|
45
|
+
<F7.Sheet
|
|
46
|
+
className="demo-sheet-swipe-to-step"
|
|
47
|
+
style={{ height: 'auto' }}
|
|
48
|
+
swipeToClose
|
|
49
|
+
swipeToStep
|
|
50
|
+
push
|
|
51
|
+
backdrop
|
|
52
|
+
opened={opened}
|
|
53
|
+
onSheetClose={onInternalClose}
|
|
54
|
+
>
|
|
55
|
+
<div className="swipe-handler" />
|
|
56
|
+
<div className="sheet-modal-swipe-step">
|
|
57
|
+
<F7.BlockTitle>Odesílám ...</F7.BlockTitle>
|
|
58
|
+
<F7.Block>
|
|
59
|
+
<F7.List dividersIos outlineIos strongIos>
|
|
60
|
+
{uploadedFiles.map(({ name, size, state }) => (
|
|
61
|
+
<F7.ListItem
|
|
62
|
+
key={name}
|
|
63
|
+
header="Soubor"
|
|
64
|
+
title={name}
|
|
65
|
+
after={prettyBytes(size)}
|
|
66
|
+
>
|
|
67
|
+
<div className="item-title-row2">
|
|
68
|
+
<div className="item-title2">
|
|
69
|
+
{state === 'success' && (
|
|
70
|
+
<SuccessIcon loop={false} animate height={30} state={state} />
|
|
71
|
+
)}
|
|
72
|
+
{state === 'loading' && (
|
|
73
|
+
<LoadingIcon loop animate height={30} state={state} />
|
|
74
|
+
)}
|
|
75
|
+
{state === 'error' && (
|
|
76
|
+
<ErrorIcon loop={false} animate height={30} state={state} />
|
|
77
|
+
)}
|
|
78
|
+
</div>
|
|
79
|
+
</div>
|
|
80
|
+
</F7.ListItem>
|
|
81
|
+
))}
|
|
82
|
+
</F7.List>
|
|
83
|
+
</F7.Block>
|
|
84
|
+
<F7.Block />
|
|
85
|
+
</div>
|
|
86
|
+
</F7.Sheet>
|
|
87
|
+
);
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
|
|
91
|
+
export default UploadFilesSheet;
|
package/package.json
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@bit.rhplus/ui.upload-files-sheet",
|
|
3
|
+
"version": "0.0.2",
|
|
4
|
+
"homepage": "https://bit.cloud/remote-scope/ui/upload-files-sheet",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"componentId": {
|
|
7
|
+
"scope": "remote-scope",
|
|
8
|
+
"name": "ui/upload-files-sheet",
|
|
9
|
+
"version": "0.0.2"
|
|
10
|
+
},
|
|
11
|
+
"dependencies": {
|
|
12
|
+
"pretty-bytes": "^6.1.1",
|
|
13
|
+
"@rhplus/wieldy.animate-icons": "0.0.14",
|
|
14
|
+
"@rhplus/wieldy.data": "0.0.5"
|
|
15
|
+
},
|
|
16
|
+
"devDependencies": {
|
|
17
|
+
"@teambit/react.react-env": "1.0.98"
|
|
18
|
+
},
|
|
19
|
+
"peerDependencies": {
|
|
20
|
+
"framework7-react": "^8.3.3",
|
|
21
|
+
"react": "^17.0.0 || ^18.0.0"
|
|
22
|
+
},
|
|
23
|
+
"license": "SEE LICENSE IN UNLICENSED",
|
|
24
|
+
"optionalDependencies": {},
|
|
25
|
+
"peerDependenciesMeta": {},
|
|
26
|
+
"private": false,
|
|
27
|
+
"publishConfig": {
|
|
28
|
+
"scope": "@bit.rhplus",
|
|
29
|
+
"registry": "https://registry.npmjs.org/"
|
|
30
|
+
}
|
|
31
|
+
}
|
package/types/asset.d.ts
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
declare module '*.png' {
|
|
2
|
+
const value: any;
|
|
3
|
+
export = value;
|
|
4
|
+
}
|
|
5
|
+
declare module '*.svg' {
|
|
6
|
+
import type { FunctionComponent, SVGProps } from 'react';
|
|
7
|
+
|
|
8
|
+
export const ReactComponent: FunctionComponent<
|
|
9
|
+
SVGProps<SVGSVGElement> & { title?: string }
|
|
10
|
+
>;
|
|
11
|
+
const src: string;
|
|
12
|
+
export default src;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// @TODO Gilad
|
|
16
|
+
declare module '*.jpg' {
|
|
17
|
+
const value: any;
|
|
18
|
+
export = value;
|
|
19
|
+
}
|
|
20
|
+
declare module '*.jpeg' {
|
|
21
|
+
const value: any;
|
|
22
|
+
export = value;
|
|
23
|
+
}
|
|
24
|
+
declare module '*.gif' {
|
|
25
|
+
const value: any;
|
|
26
|
+
export = value;
|
|
27
|
+
}
|
|
28
|
+
declare module '*.bmp' {
|
|
29
|
+
const value: any;
|
|
30
|
+
export = value;
|
|
31
|
+
}
|
|
32
|
+
declare module '*.otf' {
|
|
33
|
+
const value: any;
|
|
34
|
+
export = value;
|
|
35
|
+
}
|
|
36
|
+
declare module '*.woff' {
|
|
37
|
+
const value: any;
|
|
38
|
+
export = value;
|
|
39
|
+
}
|
|
40
|
+
declare module '*.woff2' {
|
|
41
|
+
const value: any;
|
|
42
|
+
export = value;
|
|
43
|
+
}
|
package/types/style.d.ts
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
declare module '*.module.css' {
|
|
2
|
+
const classes: { readonly [key: string]: string };
|
|
3
|
+
export default classes;
|
|
4
|
+
}
|
|
5
|
+
declare module '*.module.scss' {
|
|
6
|
+
const classes: { readonly [key: string]: string };
|
|
7
|
+
export default classes;
|
|
8
|
+
}
|
|
9
|
+
declare module '*.module.sass' {
|
|
10
|
+
const classes: { readonly [key: string]: string };
|
|
11
|
+
export default classes;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
declare module '*.module.less' {
|
|
15
|
+
const classes: { readonly [key: string]: string };
|
|
16
|
+
export default classes;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
declare module '*.less' {
|
|
20
|
+
const classes: { readonly [key: string]: string };
|
|
21
|
+
export default classes;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
declare module '*.css' {
|
|
25
|
+
const classes: { readonly [key: string]: string };
|
|
26
|
+
export default classes;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
declare module '*.sass' {
|
|
30
|
+
const classes: { readonly [key: string]: string };
|
|
31
|
+
export default classes;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
declare module '*.scss' {
|
|
35
|
+
const classes: { readonly [key: string]: string };
|
|
36
|
+
export default classes;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
declare module '*.mdx' {
|
|
40
|
+
const component: any;
|
|
41
|
+
export default component;
|
|
42
|
+
}
|
package/uploadFiles.js
ADDED
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import useData from '@rhplus/wieldy.data';
|
|
2
|
+
|
|
3
|
+
const StateEnum = {
|
|
4
|
+
Waiting: 'waiting',
|
|
5
|
+
Loading: 'loading',
|
|
6
|
+
Success: 'success',
|
|
7
|
+
Error: 'error',
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
const useUploadFiles = (api) => {
|
|
11
|
+
const { fetchData } = useData();
|
|
12
|
+
|
|
13
|
+
const uploadFiles = async (event, onProgress) => {
|
|
14
|
+
if (!event.target.files || event.target.files.length === 0) return;
|
|
15
|
+
|
|
16
|
+
const files = Array.from(event.target.files);
|
|
17
|
+
const total = files.length;
|
|
18
|
+
|
|
19
|
+
let progress = {
|
|
20
|
+
current: 0,
|
|
21
|
+
total,
|
|
22
|
+
files: files.map(({ name, size, type }) => ({
|
|
23
|
+
name,
|
|
24
|
+
size,
|
|
25
|
+
type,
|
|
26
|
+
state: StateEnum.Waiting,
|
|
27
|
+
})),
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
onProgress(progress);
|
|
31
|
+
|
|
32
|
+
const uploadFile = async (file, index) => {
|
|
33
|
+
progress = {
|
|
34
|
+
...progress,
|
|
35
|
+
files: progress.files.map((f, i) => {
|
|
36
|
+
if (i === index) return { ...f, state: StateEnum.Loading };
|
|
37
|
+
return f;
|
|
38
|
+
}),
|
|
39
|
+
};
|
|
40
|
+
onProgress(progress);
|
|
41
|
+
|
|
42
|
+
try {
|
|
43
|
+
const formData = new FormData();
|
|
44
|
+
formData.append('Files', file);
|
|
45
|
+
await fetchData(api, formData);
|
|
46
|
+
|
|
47
|
+
progress = {
|
|
48
|
+
...progress,
|
|
49
|
+
files: progress.files.map((f, i) => {
|
|
50
|
+
if (i === index) return { ...f, state: StateEnum.Success };
|
|
51
|
+
return f;
|
|
52
|
+
}),
|
|
53
|
+
};
|
|
54
|
+
} catch (error) {
|
|
55
|
+
progress = {
|
|
56
|
+
...progress,
|
|
57
|
+
files: progress.files.map((f, i) => {
|
|
58
|
+
if (i === index) return { ...f, state: StateEnum.Error };
|
|
59
|
+
return f;
|
|
60
|
+
}),
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
onProgress(progress);
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
await Promise.all(files.map((file, index) => uploadFile(file, index)));
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
return { uploadFiles };
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export default useUploadFiles;
|