* 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>
62 lines
1.9 KiB
TypeScript
62 lines
1.9 KiB
TypeScript
import { currentPromptAtom } from '@helpers/JotaiWrapper'
|
|
import { execute } from '@services/pluginService'
|
|
import { useAtom, useAtomValue, useSetAtom } from 'jotai'
|
|
import { DataService } from '@janhq/core'
|
|
import { deleteConversationMessage } from '@helpers/atoms/ChatMessage.atom'
|
|
import {
|
|
userConversationsAtom,
|
|
getActiveConvoIdAtom,
|
|
setActiveConvoIdAtom,
|
|
} from '@helpers/atoms/Conversation.atom'
|
|
import {
|
|
showingProductDetailAtom,
|
|
showingAdvancedPromptAtom,
|
|
} from '@helpers/atoms/Modal.atom'
|
|
import {
|
|
MainViewState,
|
|
setMainViewStateAtom,
|
|
} from '@helpers/atoms/MainView.atom'
|
|
|
|
export default function useDeleteConversation() {
|
|
const [userConversations, setUserConversations] = useAtom(
|
|
userConversationsAtom
|
|
)
|
|
const setCurrentPrompt = useSetAtom(currentPromptAtom)
|
|
const setShowingProductDetail = useSetAtom(showingProductDetailAtom)
|
|
const setShowingAdvancedPrompt = useSetAtom(showingAdvancedPromptAtom)
|
|
const activeConvoId = useAtomValue(getActiveConvoIdAtom)
|
|
|
|
const setActiveConvoId = useSetAtom(setActiveConvoIdAtom)
|
|
const deleteMessages = useSetAtom(deleteConversationMessage)
|
|
const setMainViewState = useSetAtom(setMainViewStateAtom)
|
|
|
|
const deleteConvo = async () => {
|
|
if (activeConvoId) {
|
|
try {
|
|
await execute(DataService.DeleteConversation, activeConvoId)
|
|
const currentConversations = userConversations.filter(
|
|
(c) => c._id !== activeConvoId
|
|
)
|
|
setUserConversations(currentConversations)
|
|
deleteMessages(activeConvoId)
|
|
|
|
if (currentConversations.length > 0) {
|
|
setActiveConvoId(currentConversations[0]._id)
|
|
} else {
|
|
setMainViewState(MainViewState.Welcome)
|
|
setActiveConvoId(undefined)
|
|
}
|
|
setCurrentPrompt('')
|
|
setShowingProductDetail(false)
|
|
setShowingAdvancedPrompt(false)
|
|
} catch (err) {
|
|
console.error(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
return {
|
|
deleteConvo,
|
|
}
|
|
}
|