diff --git a/package-lock.json b/package-lock.json index 18744bf..c56c088 100644 --- a/package-lock.json +++ b/package-lock.json @@ -8741,7 +8741,6 @@ "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.11.tgz", "integrity": "sha512-c7jFQRklXua0mTzneGW9QVyxFjUgwcihC4bXEtujIo2ouWCe1Ajt/amn2PCxYnhYfd5k09JX3SB7OYWFKYqj8Q==", "dev": true, - "license": "MIT", "dependencies": { "esbuild": "^0.21.3", "postcss": "^8.4.43", diff --git a/src/components/DataTable.tsx b/src/components/DataTable.tsx index 5d4db35..ad11740 100644 --- a/src/components/DataTable.tsx +++ b/src/components/DataTable.tsx @@ -57,9 +57,7 @@ export default function DataTable({ {getFileNameWithoutExtension(file.mcap_files[0].file_name)} {file.date} {file.location} - - {/* Change back to notes once notes field is implemented in the server */} - {file.car_model} + {file.notes} )) ); diff --git a/src/components/PreviewCard.tsx b/src/components/PreviewCard.tsx index a17756b..f86df15 100644 --- a/src/components/PreviewCard.tsx +++ b/src/components/PreviewCard.tsx @@ -8,6 +8,7 @@ import { Table, ScrollArea, TextInput, + Notification, } from "@mantine/core"; import { IconDownload, @@ -23,6 +24,39 @@ interface PreviewCardProps { } function PreviewCard({ selectedData }: PreviewCardProps) { + const [loading, setLoading] = useState(false); + const [error, setError] = useState(null); + const [success, setSuccess] = useState(null); + + const handleDelete = async () => { + setLoading(true) + setError(null); + setSuccess(null) + try { + const response = await fetch(`${import.meta.env.VITE_API_URL}/mcaps/${selectedData?.id}`, { + method: 'DELETE', + }); + + if (!response.ok) { + if (response.status === 503) { + const errorMsg = await response.text(); + setError(`Failed to delete: ${errorMsg} \nTry again in a few minutes!`); + } else { + const errorMsg = await response.text(); + setError(`Failed to delete: ${errorMsg}`); + } + } else { + const result = await response.json(); + setSuccess('File deleted successfully!'); + console.log('Delete successful:', result); + } + } catch (error) { + console.error('Error sending Delete request:', error); + setError('An error occurred during file deletion.'); + } + setLoading(false) + } + const formatDate = (dateString: string) => { const date = new Date(dateString); return date.toLocaleDateString("en-US", { @@ -101,23 +135,37 @@ function PreviewCard({ selectedData }: PreviewCardProps) { bottom: 0, left: 0, padding: 20, - gap: "10px", + gap: "8px", }} > - {selectedData.mcap_files.map((item) => ( - - ))} - {selectedData.mat_files.map((item) => ( - - ))} +
+ {selectedData.mcap_files.map((item) => ( + + ))} + {selectedData.mat_files.map((item) => ( + + ))} + + {success && ( + setSuccess(null)} style={{ marginTop: 10 }}> + {success} + + )} + {error && ( + setError(null)} style={{ marginTop: 10 }}> + {error} + + )} +
+ ) : (