* feat: adding create bot functionality Signed-off-by: James <james@jan.ai> * update the temperature progress bar Signed-off-by: James <james@jan.ai> * WIP baselayout * Mapping plugins with available preferences * Added loader component * WIP working another screen * Cleanup types and avoid import one by one * Prepare bottom bar * Add css variables colors to enable user select the accent * Enable change accent color * Seperate css variable * Fix conflict * Add blank state of my model empty * Restyle explore models page * Enable user config left sidebar * Restyle my models page * WIP styling chat page * Restyling chat message * Fix conflict * Adde form preferences setting plugins * Fixed form bot info * Sidebar bot chat * Showing rightbar for both setting when user created bot * Fix style bot info * Using overflow auto intead of scroll * Remove script built UI from root package * Fix missig import * Resolve error linter * fix e2e tests Signed-off-by: James <james@jan.ai> --------- Signed-off-by: James <james@jan.ai> Co-authored-by: James <james@jan.ai>
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
import { currentConversationAtom } from '@helpers/atoms/Conversation.atom'
|
|
import {
|
|
leftSideBarExpandStateAtom,
|
|
rightSideBarExpandStateAtom,
|
|
} from '@helpers/atoms/SideBarExpand.atom'
|
|
import { showConfirmDeleteConversationModalAtom } from '@helpers/atoms/Modal.atom'
|
|
import { ChartPieIcon, TrashIcon } from '@heroicons/react/24/outline'
|
|
import { useAtomValue, useSetAtom } from 'jotai'
|
|
import React from 'react'
|
|
import { Trash2 } from 'lucide-react'
|
|
|
|
const MainHeader: React.FC = () => {
|
|
const setLeftSideBarVisibility = useSetAtom(leftSideBarExpandStateAtom)
|
|
const setRightSideBarVisibility = useSetAtom(rightSideBarExpandStateAtom)
|
|
const setShowConfirmDeleteConversationModal = useSetAtom(
|
|
showConfirmDeleteConversationModalAtom
|
|
)
|
|
const activeConversation = useAtomValue(currentConversationAtom)
|
|
|
|
const currentConvo = useAtomValue(currentConversationAtom)
|
|
let title = currentConvo?.name ?? ''
|
|
|
|
if (!activeConversation) return null
|
|
|
|
return (
|
|
<div className="sticky top-0 border-b border-border bg-background/90 px-4 py-2">
|
|
<span className="font-semibold text-muted-foreground">{title}</span>
|
|
|
|
{/* right most */}
|
|
<div className="absolute right-4 top-2">
|
|
<Trash2
|
|
role="button"
|
|
size={16}
|
|
onClick={() => setShowConfirmDeleteConversationModal(true)}
|
|
/>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default MainHeader
|