ar-design 0.1.65 → 0.1.67
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/assets/css/components/navigation/menu/core/open-or-close.css +0 -1
- package/dist/assets/css/components/navigation/menu/menu.css +1 -0
- package/dist/components/form/upload/Props.d.ts +2 -2
- package/dist/components/form/upload/index.js +12 -14
- package/dist/libs/core/service/Api.d.ts +2 -1
- package/dist/libs/core/service/Api.js +19 -8
- package/dist/libs/core/service/index.d.ts +2 -2
- package/package.json +1 -1
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { IValidation } from "../../../libs/types/IGlobalProps";
|
|
2
2
|
interface IMultiple {
|
|
3
|
-
file:
|
|
3
|
+
file: File[];
|
|
4
4
|
onChange: (formData: FormData, files: File[]) => void;
|
|
5
5
|
multiple: true;
|
|
6
6
|
}
|
|
7
7
|
interface ISingle {
|
|
8
|
-
file:
|
|
8
|
+
file: File | undefined;
|
|
9
9
|
onChange: (formData: FormData | undefined, files: File | null) => void;
|
|
10
10
|
multiple?: false;
|
|
11
11
|
}
|
|
@@ -12,6 +12,7 @@ const Upload = ({ file, onChange, multiple }) => {
|
|
|
12
12
|
// states
|
|
13
13
|
const [open, setOpen] = useState(false);
|
|
14
14
|
const [selectedFiles, setSelectedFiles] = useState([]);
|
|
15
|
+
const [selectedFile, setSelectedFile] = useState(undefined);
|
|
15
16
|
// methods
|
|
16
17
|
const handleClickOutSide = (event) => {
|
|
17
18
|
const target = event.target;
|
|
@@ -79,14 +80,13 @@ const Upload = ({ file, onChange, multiple }) => {
|
|
|
79
80
|
}, [selectedFiles]);
|
|
80
81
|
useEffect(() => {
|
|
81
82
|
if (_input.current) {
|
|
82
|
-
|
|
83
|
-
_input.current.files = dataTransfer.files;
|
|
83
|
+
multiple ? setSelectedFiles(file) : setSelectedFile(file);
|
|
84
84
|
}
|
|
85
85
|
}, [file]);
|
|
86
86
|
useEffect(() => {
|
|
87
87
|
if (open) {
|
|
88
88
|
handlePosition();
|
|
89
|
-
|
|
89
|
+
window.addEventListener("blur", () => setOpen(false));
|
|
90
90
|
document.addEventListener("click", handleClickOutSide);
|
|
91
91
|
document.addEventListener("keydown", handleKeys);
|
|
92
92
|
}
|
|
@@ -99,22 +99,20 @@ const Upload = ({ file, onChange, multiple }) => {
|
|
|
99
99
|
return (React.createElement("div", { ref: _arUplaod, className: "ar-upload" },
|
|
100
100
|
React.createElement("input", { ref: _input, type: "file", onChange: handleFileChange, multiple: multiple }),
|
|
101
101
|
React.createElement("div", { className: "ar-upload-button" },
|
|
102
|
-
React.createElement("span", { ref: _count, className: "count", onClick: () => setOpen((prev) => !prev) }, selectedFiles.length),
|
|
102
|
+
React.createElement("span", { ref: _count, className: "count", onClick: () => setOpen((prev) => !prev) }, selectedFiles.length === 0 ? (selectedFile ? 1 : 0) : selectedFiles.length),
|
|
103
103
|
React.createElement("button", { onClick: () => {
|
|
104
104
|
if (_input.current)
|
|
105
105
|
_input.current.click();
|
|
106
106
|
} },
|
|
107
107
|
React.createElement(ARIcon, { variant: "bulk", icon: "Upload", fill: "var(--success)" }),
|
|
108
108
|
React.createElement("span", null, "Dosya Y\u00FCkle"))),
|
|
109
|
-
open &&
|
|
110
|
-
selectedFiles.
|
|
111
|
-
|
|
112
|
-
React.createElement("
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
} },
|
|
118
|
-
React.createElement(ARIcon, { variant: "bulk", icon: "Trash", fill: "var(--danger)", size: 16 }))))))), document.body)));
|
|
109
|
+
open && selectedFiles.length > 0 ? (ReactDOM.createPortal(React.createElement("div", { ref: _arUplaodFiles, className: "ar-upload-files" },
|
|
110
|
+
React.createElement("ul", null, selectedFiles.map((selectedFile, index) => (React.createElement("li", { key: index },
|
|
111
|
+
React.createElement("span", null, selectedFile.name),
|
|
112
|
+
React.createElement("span", { onClick: (event) => {
|
|
113
|
+
event.stopPropagation();
|
|
114
|
+
handleFileRemove(selectedFile);
|
|
115
|
+
} },
|
|
116
|
+
React.createElement(ARIcon, { variant: "bulk", icon: "Trash", fill: "var(--danger)", size: 16 }))))))), document.body)) : (React.createElement("span", null, selectedFile?.name))));
|
|
119
117
|
};
|
|
120
118
|
export default Upload;
|
|
@@ -34,6 +34,8 @@ declare class Api {
|
|
|
34
34
|
input?: RequestInfo;
|
|
35
35
|
headers?: HeadersInit;
|
|
36
36
|
}): Promise<Response>;
|
|
37
|
+
private HeaderProperties;
|
|
38
|
+
private Cookies;
|
|
37
39
|
/**
|
|
38
40
|
* Burada bir fetch işlemi gerçekleştirilmekte fakat farklı olarak burayı `interceptor` olarak kullanmaktayız.
|
|
39
41
|
* @param input
|
|
@@ -41,6 +43,5 @@ declare class Api {
|
|
|
41
43
|
* @returns
|
|
42
44
|
*/
|
|
43
45
|
private CustomFetch;
|
|
44
|
-
private HeaderProperties;
|
|
45
46
|
}
|
|
46
47
|
export default Api;
|
|
@@ -60,6 +60,24 @@ class Api {
|
|
|
60
60
|
});
|
|
61
61
|
return response;
|
|
62
62
|
}
|
|
63
|
+
HeaderProperties = () => {
|
|
64
|
+
return {
|
|
65
|
+
Accept: "application/json",
|
|
66
|
+
"Content-Type": "application/json",
|
|
67
|
+
...(this._token && { Authorization: `Bearer ${this.Cookies(this._token)}` }),
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
Cookies = (name) => {
|
|
71
|
+
if (typeof window === "undefined")
|
|
72
|
+
return undefined;
|
|
73
|
+
const cookies = document.cookie.split("; ");
|
|
74
|
+
const cookieObject = [];
|
|
75
|
+
cookies.forEach((cookie) => {
|
|
76
|
+
const [key, value] = cookie.split("=");
|
|
77
|
+
cookieObject.push({ key: key, value: value });
|
|
78
|
+
});
|
|
79
|
+
return decodeURIComponent(cookieObject.find((x) => x.key === name)?.value ?? "");
|
|
80
|
+
};
|
|
63
81
|
/**
|
|
64
82
|
* Burada bir fetch işlemi gerçekleştirilmekte fakat farklı olarak burayı `interceptor` olarak kullanmaktayız.
|
|
65
83
|
* @param input
|
|
@@ -84,7 +102,7 @@ class Api {
|
|
|
84
102
|
console.error("404");
|
|
85
103
|
break;
|
|
86
104
|
default:
|
|
87
|
-
|
|
105
|
+
console.error(`Unexpected Error: ${request.status}`);
|
|
88
106
|
}
|
|
89
107
|
}
|
|
90
108
|
// Return
|
|
@@ -94,12 +112,5 @@ class Api {
|
|
|
94
112
|
throw error;
|
|
95
113
|
}
|
|
96
114
|
}
|
|
97
|
-
HeaderProperties = () => {
|
|
98
|
-
return {
|
|
99
|
-
Accept: "application/json",
|
|
100
|
-
"Content-Type": "application/json",
|
|
101
|
-
...(this._token && { Authorization: `Bearer ${this._token}` }),
|
|
102
|
-
};
|
|
103
|
-
};
|
|
104
115
|
}
|
|
105
116
|
export default Api;
|
|
@@ -6,11 +6,11 @@ type Result<TResponse> = {
|
|
|
6
6
|
};
|
|
7
7
|
declare class Service {
|
|
8
8
|
private _api;
|
|
9
|
-
private _endPoint
|
|
9
|
+
private _endPoint?;
|
|
10
10
|
constructor(values: {
|
|
11
11
|
host?: string;
|
|
12
12
|
core?: string;
|
|
13
|
-
endPoint
|
|
13
|
+
endPoint?: string;
|
|
14
14
|
token?: string;
|
|
15
15
|
});
|
|
16
16
|
Get<TResponse>(values?: {
|