Spaces:
Runtime error
Runtime error
File size: 1,531 Bytes
0971cc4 |
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 |
"use client";
import { Dispatch, SetStateAction, useEffect, useState } from "react";
import { toast } from "sonner";
import { useDebounce } from "use-debounce";
import { useHasMounted } from "@/lib/utils";
import { ChatOptions } from "./chat/chat-options";
import { Textarea } from "./ui/textarea";
export interface SystemPromptProps {
chatOptions: ChatOptions;
setChatOptions: Dispatch<SetStateAction<ChatOptions>>;
}
export default function SystemPrompt({
chatOptions,
setChatOptions,
}: SystemPromptProps) {
const hasMounted = useHasMounted();
const systemPrompt = chatOptions ? chatOptions.systemPrompt : "";
const [text, setText] = useState<string>(systemPrompt || "");
const [debouncedText] = useDebounce(text, 500);
useEffect(() => {
if (!hasMounted) {
return;
}
if (debouncedText !== systemPrompt) {
setChatOptions({ ...chatOptions, systemPrompt: debouncedText });
toast.success("System prompt updated", { duration: 1000 });
}
}, [hasMounted, debouncedText]);
return (
<div>
<div className="justify-start gap-2 w-full rounded-sm px-2 text-xs">
<p>System prompt</p>
</div>
<div className="m-2">
<Textarea
className="resize-none bg-white/20 dark:bg-card/35"
autoComplete="off"
rows={7}
value={text}
onChange={(e) => setText(e.currentTarget.value)}
name="systemPrompt"
placeholder="You are a helpful assistant."
/>
</div>
</div>
);
}
|