Spaces:
Sleeping
Sleeping
File size: 2,525 Bytes
450060f |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
import { ReactNode, useState } from "react"
import { RxReload, RxPencil2 } from "react-icons/rx"
import { Button } from "@/components/ui/button"
import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger } from "@/components/ui/dialog"
import { Input } from "@/components/ui/input"
import { cn } from "@/lib/utils"
import { Textarea } from "@/components/ui/textarea"
export function EditModal({
existingPrompt,
isEnabled,
className,
children,
onSave,
}: {
existingPrompt: string;
isEnabled: boolean;
className?: string;
children?: ReactNode;
onSave: (newPrompt: string) => void;
}) {
const [draftPrompt, setDraftPrompt] = useState(existingPrompt)
const [isOpen, setOpen] = useState(false)
const handleSubmit = () => {
if (draftPrompt) {
onSave(draftPrompt)
setOpen(false)
}
}
return (
<Dialog open={isOpen} onOpenChange={(open) => {
if (!open || isEnabled) {
setOpen(open)
if (!open) {
setDraftPrompt(existingPrompt)
}
}
}}>
<DialogTrigger asChild>
{children}
</DialogTrigger>
<DialogContent className="sm:max-w-[425px] text-stone-800">
<DialogHeader>
<DialogDescription className="w-full text-center text-lg font-bold text-stone-800">
Edit Prompt
</DialogDescription>
</DialogHeader>
<div className="flex flex-row flex-grow w-full">
<Textarea
placeholder="Story"
rows={10}
className="w-full bg-neutral-300 text-neutral-800 dark:bg-neutral-300 dark:text-neutral-800 rounded-r-none"
// disabled={atLeastOnePanelIsBusy}
onChange={(e) => {
setDraftPrompt(e.target.value)
}}
onKeyDown={({ key }) => {
if (key === 'Enter') {
handleSubmit()
}
}}
value={draftPrompt}
/>
</div>
<DialogFooter>
<Button
type="button"
variant="outline"
onClick={() => {
setOpen(false)
setDraftPrompt(existingPrompt)
}}
>cancel</Button>
<Button
type="submit"
onClick={() => handleSubmit()}
disabled={!draftPrompt.length}
>Save</Button>
</DialogFooter>
</DialogContent>
</Dialog>
)
} |