Faisal Amir b662c25007
fix: adjustment minor UI from qa feedback (#2963)
* feat: update minor ui from feedback

* fix: adjust spacing import model

* feat: edit title thread (#2964)

* feat: edit title thread

* fix: fix copies

* fix copies

* fix copies
2024-05-30 10:53:40 +07:00

72 lines
1.9 KiB
TypeScript

import { useCallback, memo, useState } from 'react'
import { Thread } from '@janhq/core'
import { Modal, ModalClose, Button, Input } from '@janhq/joi'
import { PencilIcon } from 'lucide-react'
import { useCreateNewThread } from '@/hooks/useCreateNewThread'
type Props = {
thread: Thread
}
const ModalEditTitleThread = ({ thread }: Props) => {
const [title, setTitle] = useState(thread.title)
const { updateThreadMetadata } = useCreateNewThread()
const onUpdateTitle = useCallback(
(e: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {
e.stopPropagation()
updateThreadMetadata({
...thread,
title: title || 'New Thread',
})
},
[thread, title, updateThreadMetadata]
)
return (
<Modal
title="Edit title thread"
trigger={
<div
className="flex cursor-pointer items-center space-x-2 px-4 py-2 hover:bg-[hsla(var(--dropdown-menu-hover-bg))]"
onClick={(e) => e.stopPropagation()}
>
<PencilIcon size={16} className="text-[hsla(var(--secondary))]" />
<span className="text-bold text-[hsla(var(--secondary))]">
Edit title
</span>
</div>
}
content={
<form className="mt-4">
<Input
value={title}
onChange={(e) => setTitle(e.target.value)}
autoFocus
/>
<div className="mt-4 flex justify-end gap-x-2">
<ModalClose asChild onClick={(e) => e.stopPropagation()}>
<Button theme="ghost">Cancel</Button>
</ModalClose>
<ModalClose asChild>
<Button
type="submit"
onClick={onUpdateTitle}
disabled={title.length === 0}
>
Save
</Button>
</ModalClose>
</div>
</form>
}
/>
)
}
export default memo(ModalEditTitleThread)