import React from 'react' import { Editor } from '@tiptap/core'; import learnhouseAI_icon from "public/learnhouse_ai_simple.png"; import Image from 'next/image'; import { BookOpen, FormInput, Languages, MoreVertical } from 'lucide-react'; import { BubbleMenu } from '@tiptap/react'; import ToolTip from '@components/StyledElements/Tooltip/Tooltip'; import { AIChatBotStateTypes, useAIChatBot, useAIChatBotDispatch } from '@components/Contexts/AI/AIChatBotContext'; import { sendActivityAIChatMessage, startActivityAIChatSession } from '@services/ai/ai'; type AICanvaToolkitProps = { editor: Editor, activity: any } function AICanvaToolkit(props: AICanvaToolkitProps) { return (
AI
) } function AIActionButton(props: { editor: Editor, label: string, activity: any }) { const dispatchAIChatBot = useAIChatBotDispatch() as any; const aiChatBotState = useAIChatBot() as AIChatBotStateTypes; async function handleAction(label: string) { const selection = getTipTapEditorSelectedText(); const prompt = getPrompt(label, selection); dispatchAIChatBot({ type: 'setIsModalOpen' }); await sendMessage(prompt); } const getTipTapEditorSelectedText = () => { const selection = props.editor.state.selection; const from = selection.from; const to = selection.to; const text = props.editor.state.doc.textBetween(from, to); return text; } const getPrompt = (label: string, selection: string) => { if (label === 'Explain') { return `Explain this part of the course "${selection}" keep this course context in mind.` } else if (label === 'Summarize') { return `Summarize this "${selection}" with the course context in mind.` } else if (label === 'Translate') { return `Translate "${selection}" to another language.` } else { return `Give examples to understand "${selection}" better, if possible give context in the course.` } } const sendMessage = async (message: string) => { if (aiChatBotState.aichat_uuid) { await dispatchAIChatBot({ type: 'addMessage', payload: { sender: 'user', message: message, type: 'user' } }); await dispatchAIChatBot({ type: 'setIsWaitingForResponse' }); const response = await sendActivityAIChatMessage(message, aiChatBotState.aichat_uuid, props.activity.activity_uuid) await dispatchAIChatBot({ type: 'setIsNoLongerWaitingForResponse' }); await dispatchAIChatBot({ type: 'setChatInputValue', payload: '' }); await dispatchAIChatBot({ type: 'addMessage', payload: { sender: 'ai', message: response.message, type: 'ai' } }); } else { await dispatchAIChatBot({ type: 'addMessage', payload: { sender: 'user', message: message, type: 'user' } }); await dispatchAIChatBot({ type: 'setIsWaitingForResponse' }); const response = await startActivityAIChatSession(message, props.activity.activity_uuid) await dispatchAIChatBot({ type: 'setAichat_uuid', payload: response.aichat_uuid }); await dispatchAIChatBot({ type: 'setIsNoLongerWaitingForResponse' }); await dispatchAIChatBot({ type: 'setChatInputValue', payload: '' }); await dispatchAIChatBot({ type: 'addMessage', payload: { sender: 'ai', message: response.message, type: 'ai' } }); } } const tooltipLabel = props.label === 'Explain' ? 'Explain a word or a sentence with AI' : props.label === 'Summarize' ? 'Summarize a long paragraph or text with AI' : props.label === 'Translate' ? 'Translate to different languages with AI' : 'Give examples to understand better with AI' return (
) } export default AICanvaToolkit