Faisal Amir 539b467141
ui: interface revamp (#429)
* 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>
2023-10-24 10:59:12 +07:00

59 lines
1.6 KiB
TypeScript

import { activeBotAtom } from '@helpers/atoms/Bot.atom'
import {
MainViewState,
setMainViewStateAtom,
} from '@helpers/atoms/MainView.atom'
import useCreateConversation from '@hooks/useCreateConversation'
import useDeleteBot from '@hooks/useDeleteBot'
import { useAtomValue, useSetAtom } from 'jotai'
import React from 'react'
import PrimaryButton from '../PrimaryButton'
import ExpandableHeader from '../ExpandableHeader'
const BotInfo: React.FC = () => {
const { deleteBot } = useDeleteBot()
const { createConvoByBot } = useCreateConversation()
const setMainView = useSetAtom(setMainViewStateAtom)
const botInfo = useAtomValue(activeBotAtom)
if (!botInfo) return null
const onNewChatClicked = () => {
if (!botInfo) {
alert('No bot selected')
return
}
createConvoByBot(botInfo)
}
const onDeleteBotClick = async () => {
// TODO: display confirmation diaglog
const result = await deleteBot(botInfo._id)
if (result === 'success') {
setMainView(MainViewState.Welcome)
}
}
return (
<div className="mx-1 my-1 flex flex-col gap-2">
<ExpandableHeader title="BOT INFO" />
<div className="flex flex-col">
<label className="mb-2">{botInfo.name}</label>
<span className="text-muted-foreground">{botInfo.description}</span>
</div>
<div className="flex w-full flex-col space-y-2">
<PrimaryButton onClick={onNewChatClicked} title="New chat" />
<PrimaryButton
title="Delete bot"
onClick={onDeleteBotClick}
className="bg-red-500 hover:bg-red-400"
/>
</div>
</div>
)
}
export default BotInfo