mirror of
https://github.com/gabehf/Koito.git
synced 2026-03-13 01:20:26 -07:00
chore: initial public commit
This commit is contained in:
commit
fc9054b78c
250 changed files with 32809 additions and 0 deletions
53
client/app/components/ImageDropHandler.tsx
Normal file
53
client/app/components/ImageDropHandler.tsx
Normal file
|
|
@ -0,0 +1,53 @@
|
|||
import { replaceImage } from 'api/api';
|
||||
import { useEffect } from 'react';
|
||||
|
||||
interface Props {
|
||||
itemType: string,
|
||||
id: number,
|
||||
onComplete: Function
|
||||
}
|
||||
|
||||
export default function ImageDropHandler({ itemType, id, onComplete }: Props) {
|
||||
useEffect(() => {
|
||||
const handleDragOver = (e: DragEvent) => {
|
||||
console.log('dragover!!')
|
||||
e.preventDefault();
|
||||
};
|
||||
|
||||
const handleDrop = async (e: DragEvent) => {
|
||||
e.preventDefault();
|
||||
if (!e.dataTransfer?.files.length) return;
|
||||
|
||||
const imageFile = Array.from(e.dataTransfer.files).find(file =>
|
||||
file.type.startsWith('image/')
|
||||
);
|
||||
if (!imageFile) return;
|
||||
|
||||
const formData = new FormData();
|
||||
formData.append('image', imageFile);
|
||||
formData.append(itemType.toLowerCase()+'_id', String(id))
|
||||
replaceImage(formData).then((r) => {
|
||||
if (r.status >= 200 && r.status < 300) {
|
||||
onComplete()
|
||||
console.log("Replacement image uploaded successfully")
|
||||
} else {
|
||||
r.json().then((body) => {
|
||||
console.log(`Upload failed: ${r.statusText} - ${body}`)
|
||||
})
|
||||
}
|
||||
}).catch((err) => {
|
||||
console.log(`Upload failed: ${err}`)
|
||||
})
|
||||
};
|
||||
|
||||
window.addEventListener('dragover', handleDragOver);
|
||||
window.addEventListener('drop', handleDrop);
|
||||
|
||||
return () => {
|
||||
window.removeEventListener('dragover', handleDragOver);
|
||||
window.removeEventListener('drop', handleDrop);
|
||||
};
|
||||
}, []);
|
||||
|
||||
return null;
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue