Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| daf0178330 | |||
| 3140d72e28 | |||
| 6117805467 | |||
| b002c053ae | |||
| e6044518d2 | |||
| fa2b02ad23 | |||
| 7e39683aa2 | |||
| f60dbe14e6 | |||
| 71da0243be | |||
| 86d41f6c2f |
@@ -84,8 +84,12 @@ export const createAppointment = async (req, res) => {
|
||||
<tr>
|
||||
<td style="padding: 8px 0;"><b>Date:</b></td>
|
||||
<td style="padding: 8px 0;">
|
||||
${new Date(date).toLocaleDateString()}
|
||||
</td>
|
||||
${new Date(date).toLocaleDateString("en-GB", {
|
||||
day: "2-digit",
|
||||
month: "long",
|
||||
year: "numeric",
|
||||
})}
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
|
||||
@@ -10,6 +10,7 @@ import Table from "@editorjs/table";
|
||||
import CodeTool from "@editorjs/code";
|
||||
import Embed from "@editorjs/embed";
|
||||
import Delimiter from "@editorjs/delimiter";
|
||||
import axios from "axios";
|
||||
|
||||
import {
|
||||
createBlogApi,
|
||||
@@ -23,6 +24,7 @@ import {Input} from "@/components/ui/input";
|
||||
import {Button} from "@/components/ui/button";
|
||||
|
||||
export default function BlogEditorPage() {
|
||||
const baseURL = import.meta.env.VITE_API_URL;
|
||||
const {id} = useParams();
|
||||
const navigate = useNavigate();
|
||||
|
||||
@@ -79,12 +81,41 @@ export default function BlogEditorPage() {
|
||||
config: {
|
||||
uploader: {
|
||||
uploadByFile: async (file: File) => {
|
||||
const res = await uploadImageApi(file);
|
||||
if (file.size > 5 * 1024 * 1024) {
|
||||
alert("File is too large (Max 5MB)");
|
||||
return {success: 0, file: {url: ""}};
|
||||
}
|
||||
|
||||
return {
|
||||
success: 1,
|
||||
file: {url: res.file.url},
|
||||
};
|
||||
const formData = new FormData();
|
||||
formData.append("file", file);
|
||||
formData.append("folderPath", "/blog");
|
||||
|
||||
try {
|
||||
const response = await axios.post(
|
||||
`${baseURL}/upload`,
|
||||
formData,
|
||||
{
|
||||
headers: {
|
||||
"Content-Type": "multipart/form-data",
|
||||
},
|
||||
},
|
||||
);
|
||||
|
||||
return {
|
||||
success: 1,
|
||||
file: {url: response.data.fileUrl},
|
||||
};
|
||||
} catch (e: any) {
|
||||
console.error("EditorJS Image Upload Error:", e);
|
||||
const errorMessage =
|
||||
e.response?.data?.error || e.message || "Upload failed";
|
||||
alert(`Upload Error: ${errorMessage}`);
|
||||
|
||||
return {
|
||||
success: 0,
|
||||
file: {url: ""},
|
||||
};
|
||||
}
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user