[dyad] Make upload area a dedicated dropzone - wrote 1 file(s)
This commit is contained in:
@@ -244,25 +244,19 @@ export function ImageConverter() {
|
|||||||
<div className="lg:col-span-2 flex flex-col gap-8">
|
<div className="lg:col-span-2 flex flex-col gap-8">
|
||||||
<div
|
<div
|
||||||
className={cn(
|
className={cn(
|
||||||
"w-full aspect-video rounded-lg border-2 border-dashed flex items-center justify-center relative transition-colors p-1",
|
"w-full aspect-video rounded-lg border-2 border-dashed flex items-center justify-center relative transition-colors p-1 cursor-pointer",
|
||||||
isDraggingOver ? "border-primary bg-accent" : "border-input"
|
isDraggingOver ? "border-primary bg-accent" : "border-input"
|
||||||
)}
|
)}
|
||||||
onDragOver={handleDragOver}
|
onDragOver={handleDragOver}
|
||||||
onDragLeave={handleDragLeave}
|
onDragLeave={handleDragLeave}
|
||||||
onDrop={handleDrop}
|
onDrop={handleDrop}
|
||||||
>
|
|
||||||
{isImageSelected && previewUrls[selectedImageIndex] ? (
|
|
||||||
<img src={previewUrls[selectedImageIndex]} alt="Selected image preview" className="max-w-full max-h-full object-contain rounded-md" />
|
|
||||||
) : (
|
|
||||||
<div
|
|
||||||
className="w-full h-full flex flex-col items-center justify-center text-center cursor-pointer text-muted-foreground hover:text-primary transition-colors"
|
|
||||||
onClick={() => fileInputRef.current?.click()}
|
onClick={() => fileInputRef.current?.click()}
|
||||||
>
|
>
|
||||||
|
<div className="flex flex-col items-center justify-center text-center text-muted-foreground">
|
||||||
<Upload className="w-10 h-10 mb-4" />
|
<Upload className="w-10 h-10 mb-4" />
|
||||||
<p className="text-lg font-semibold">Click to upload or drag and drop</p>
|
<p className="text-lg font-semibold">Click to upload or drag and drop</p>
|
||||||
<p className="text-sm">Select files from your computer</p>
|
<p className="text-sm">Select files from your computer</p>
|
||||||
</div>
|
</div>
|
||||||
)}
|
|
||||||
<Input type="file" ref={fileInputRef} onChange={handleImageChange} className="hidden" accept="image/*" multiple />
|
<Input type="file" ref={fileInputRef} onChange={handleImageChange} className="hidden" accept="image/*" multiple />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user