@interopio/io-assist-react 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.internal.md +467 -0
- package/README.md +503 -0
- package/changelog.md +2 -0
- package/dist/IoAssist.d.ts +12 -0
- package/dist/actions/abortActiveStream.d.ts +2 -0
- package/dist/actions/deleteThread.d.ts +2 -0
- package/dist/actions/elicitation.d.ts +13 -0
- package/dist/actions/initIoAiWeb.d.ts +3 -0
- package/dist/actions/initIoConnect.d.ts +9 -0
- package/dist/actions/mcpAppEvents.d.ts +4 -0
- package/dist/actions/newConversation.d.ts +2 -0
- package/dist/actions/processResponseStream.d.ts +3 -0
- package/dist/actions/renameThread.d.ts +2 -0
- package/dist/actions/sampling.d.ts +5 -0
- package/dist/actions/selectThread.d.ts +2 -0
- package/dist/actions/sendUserMessage.d.ts +3 -0
- package/dist/actions/toggleFavoritePrompt.d.ts +7 -0
- package/dist/actions/toggleTool.d.ts +2 -0
- package/dist/components/chat/ActivePanelModal.d.ts +6 -0
- package/dist/components/chat/AiDisclaimer.d.ts +6 -0
- package/dist/components/chat/Chat.d.ts +2 -0
- package/dist/components/chat/ConfirmModal.d.ts +8 -0
- package/dist/components/chat/WelcomeHeading.d.ts +6 -0
- package/dist/components/header/Header.d.ts +2 -0
- package/dist/components/input-area/InputArea.d.ts +8 -0
- package/dist/components/messages/AssistantMessage.d.ts +10 -0
- package/dist/components/messages/McpAppResource.d.ts +11 -0
- package/dist/components/messages/MdFormatter.d.ts +6 -0
- package/dist/components/messages/MessageArea.d.ts +7 -0
- package/dist/components/messages/ToolMessage.d.ts +9 -0
- package/dist/components/messages/ToolTraceMessage.d.ts +9 -0
- package/dist/components/messages/UserMessage.d.ts +9 -0
- package/dist/components/messages/mdUtils.d.ts +1 -0
- package/dist/components/messages/prismTwilightTheme.d.ts +2 -0
- package/dist/components/prompt/FavoritePromptList.d.ts +2 -0
- package/dist/components/prompt/PromptListItem.d.ts +8 -0
- package/dist/components/prompt/PromptListPanel.d.ts +6 -0
- package/dist/components/scroll-area/ScrollArea.d.ts +33 -0
- package/dist/components/shared/Icon.d.ts +8 -0
- package/dist/components/shared/IconButton.d.ts +11 -0
- package/dist/components/shared/Modal.d.ts +12 -0
- package/dist/components/shared/SearchInput.d.ts +8 -0
- package/dist/components/shared/ToggleInput.d.ts +8 -0
- package/dist/components/shared/Tooltip.d.ts +10 -0
- package/dist/components/shared/icons.d.ts +37 -0
- package/dist/components/threads/ThreadHistory.d.ts +6 -0
- package/dist/components/threads/ThreadHistoryListItem.d.ts +18 -0
- package/dist/components/threads/ThreadHistoryPanel.d.ts +7 -0
- package/dist/components/tool/ToolListItem.d.ts +8 -0
- package/dist/components/tool/ToolListPanel.d.ts +2 -0
- package/dist/components/working-context-panel/WorkingContextPanel.d.ts +2 -0
- package/dist/constants/modalActions.d.ts +11 -0
- package/dist/constants/uiStrings.d.ts +141 -0
- package/dist/context/IoAssistContext.d.ts +14 -0
- package/dist/files/inter-latin-wght-normal.woff2 +0 -0
- package/dist/hooks/useHoverMouseFollow.d.ts +27 -0
- package/dist/hooks/useIoAiWebApi.d.ts +19 -0
- package/dist/hooks/useIoAiWebBootstrap.d.ts +8 -0
- package/dist/hooks/useIoConnectApi.d.ts +12 -0
- package/dist/hooks/useIoConnectBootstrap.d.ts +10 -0
- package/dist/hooks/useIsMobileViewport.d.ts +1 -0
- package/dist/index.cjs +41 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +3624 -0
- package/dist/index.js.map +1 -0
- package/dist/stores/agent.d.ts +15 -0
- package/dist/stores/app-lifecycle.d.ts +21 -0
- package/dist/stores/confirm-modal.d.ts +29 -0
- package/dist/stores/index.d.ts +32 -0
- package/dist/stores/mcp-apps.d.ts +13 -0
- package/dist/stores/message.d.ts +33 -0
- package/dist/stores/prompt.d.ts +16 -0
- package/dist/stores/response-stream.d.ts +31 -0
- package/dist/stores/thread.d.ts +17 -0
- package/dist/stores/tool.d.ts +15 -0
- package/dist/stores/working-context.d.ts +16 -0
- package/dist/styles.css +1 -0
- package/dist/types/agent.d.ts +8 -0
- package/dist/types/config.d.ts +40 -0
- package/dist/types/icon.d.ts +5 -0
- package/dist/types/index.d.ts +15 -0
- package/dist/types/loading.d.ts +38 -0
- package/dist/types/message.d.ts +56 -0
- package/dist/types/panel.d.ts +6 -0
- package/dist/types/prompt.d.ts +17 -0
- package/dist/types/stream.d.ts +22 -0
- package/dist/types/thread.d.ts +15 -0
- package/dist/types/tool.d.ts +15 -0
- package/dist/utils/confirmModal.d.ts +5 -0
- package/dist/utils/ioModals.d.ts +21 -0
- package/dist/utils/logger.d.ts +34 -0
- package/dist/utils/mcpAppModal.d.ts +3 -0
- package/dist/utils/messageConverter.d.ts +3 -0
- package/dist/utils/messageUtils.d.ts +16 -0
- package/dist/utils/safeStringify.d.ts +1 -0
- package/dist/utils/streamUtils.d.ts +15 -0
- package/dist/utils/threadUtils.d.ts +16 -0
- package/package.json +65 -0
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { LoadingState, UIAgent } from '../types';
|
|
4
|
+
export type AgentSlice = {
|
|
5
|
+
agents: UIAgent[];
|
|
6
|
+
selectedAgent: UIAgent | null;
|
|
7
|
+
agentsLoadingState: LoadingState;
|
|
8
|
+
setAgents: (agents: UIAgent[]) => void;
|
|
9
|
+
setSelectedAgent: (agent: UIAgent | null) => void;
|
|
10
|
+
setAgentsLoadingState: (state: LoadingState) => void;
|
|
11
|
+
};
|
|
12
|
+
export declare const createAgentSlice: StateCreator<IoAssistStore, [
|
|
13
|
+
['zustand/subscribeWithSelector', never]
|
|
14
|
+
], [
|
|
15
|
+
], AgentSlice>;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { IoAiWeb } from '@interopio/ai-web';
|
|
2
|
+
import { IOConnectBrowser } from '@interopio/browser';
|
|
3
|
+
import { StateCreator } from 'zustand';
|
|
4
|
+
import { IoAssistStore } from './index';
|
|
5
|
+
import { LoadingState } from '../types';
|
|
6
|
+
export type AppLifecycleSlice = {
|
|
7
|
+
appLoadingState: LoadingState;
|
|
8
|
+
isIoConnectReady: boolean;
|
|
9
|
+
isDarkMode: boolean;
|
|
10
|
+
ioConnectApi: IOConnectBrowser.API | null;
|
|
11
|
+
ioAiWebApi: IoAiWeb.API | null;
|
|
12
|
+
setAppLoadingState: (state: LoadingState) => void;
|
|
13
|
+
setIsIoConnectReady: (ready: boolean) => void;
|
|
14
|
+
setIsDarkMode: (dark: boolean) => void;
|
|
15
|
+
setIoConnectApi: (api: IOConnectBrowser.API | null) => void;
|
|
16
|
+
setIoAiWebApi: (api: IoAiWeb.API | null) => void;
|
|
17
|
+
};
|
|
18
|
+
export declare const createAppLifecycleSlice: StateCreator<IoAssistStore, [
|
|
19
|
+
['zustand/subscribeWithSelector', never]
|
|
20
|
+
], [
|
|
21
|
+
], AppLifecycleSlice>;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { PanelContent } from '../types';
|
|
4
|
+
export type ConfirmModalButton = {
|
|
5
|
+
id: string;
|
|
6
|
+
label: string;
|
|
7
|
+
variant: 'primary' | 'default';
|
|
8
|
+
};
|
|
9
|
+
export type ConfirmModalConfig = {
|
|
10
|
+
title: string;
|
|
11
|
+
heading: string;
|
|
12
|
+
text: string;
|
|
13
|
+
buttons: ConfirmModalButton[];
|
|
14
|
+
/** Show an X close icon in the header. Defaults to false (matches ng). */
|
|
15
|
+
isHeaderCloseButtonDisplayed?: boolean;
|
|
16
|
+
};
|
|
17
|
+
export type ConfirmModalSlice = {
|
|
18
|
+
isThreadHistoryVisible: boolean;
|
|
19
|
+
activePanelContent: PanelContent;
|
|
20
|
+
currentConfirmModal: ConfirmModalConfig | null;
|
|
21
|
+
setIsThreadHistoryVisible: (visible: boolean) => void;
|
|
22
|
+
setActivePanelContent: (content: PanelContent) => void;
|
|
23
|
+
showConfirmModal: (config: ConfirmModalConfig) => void;
|
|
24
|
+
closeConfirmModal: () => void;
|
|
25
|
+
};
|
|
26
|
+
export declare const createConfirmModalSlice: StateCreator<IoAssistStore, [
|
|
27
|
+
['zustand/subscribeWithSelector', never]
|
|
28
|
+
], [
|
|
29
|
+
], ConfirmModalSlice>;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { AgentSlice } from './agent';
|
|
2
|
+
import { AppLifecycleSlice } from './app-lifecycle';
|
|
3
|
+
import { ConfirmModalSlice } from './confirm-modal';
|
|
4
|
+
import { McpAppsSlice } from './mcp-apps';
|
|
5
|
+
import { MessageSlice } from './message';
|
|
6
|
+
import { PromptSlice } from './prompt';
|
|
7
|
+
import { ResponseStreamSlice } from './response-stream';
|
|
8
|
+
import { ThreadSlice } from './thread';
|
|
9
|
+
import { ToolSlice } from './tool';
|
|
10
|
+
import { WorkingContextSlice } from './working-context';
|
|
11
|
+
export type IoAssistStore = AppLifecycleSlice & AgentSlice & ThreadSlice & MessageSlice & ResponseStreamSlice & PromptSlice & ToolSlice & WorkingContextSlice & McpAppsSlice & ConfirmModalSlice;
|
|
12
|
+
export declare const createIoAssistStore: () => import('zustand').UseBoundStore<Omit<import('zustand').StoreApi<IoAssistStore>, "subscribe"> & {
|
|
13
|
+
subscribe: {
|
|
14
|
+
(listener: (selectedState: IoAssistStore, previousSelectedState: IoAssistStore) => void): () => void;
|
|
15
|
+
<U>(selector: (state: IoAssistStore) => U, listener: (selectedState: U, previousSelectedState: U) => void, options?: {
|
|
16
|
+
equalityFn?: ((a: U, b: U) => boolean) | undefined;
|
|
17
|
+
fireImmediately?: boolean;
|
|
18
|
+
} | undefined): () => void;
|
|
19
|
+
};
|
|
20
|
+
}>;
|
|
21
|
+
export declare const ioAssistStore: import('zustand').UseBoundStore<Omit<import('zustand').StoreApi<IoAssistStore>, "subscribe"> & {
|
|
22
|
+
subscribe: {
|
|
23
|
+
(listener: (selectedState: IoAssistStore, previousSelectedState: IoAssistStore) => void): () => void;
|
|
24
|
+
<U>(selector: (state: IoAssistStore) => U, listener: (selectedState: U, previousSelectedState: U) => void, options?: {
|
|
25
|
+
equalityFn?: ((a: U, b: U) => boolean) | undefined;
|
|
26
|
+
fireImmediately?: boolean;
|
|
27
|
+
} | undefined): () => void;
|
|
28
|
+
};
|
|
29
|
+
}>;
|
|
30
|
+
export type IoAssistStoreInstance = ReturnType<typeof createIoAssistStore>;
|
|
31
|
+
export type { ConfirmModalButton, ConfirmModalConfig } from './confirm-modal';
|
|
32
|
+
export type { StreamState } from './response-stream';
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { IoAiWeb } from '@interopio/ai-web';
|
|
2
|
+
import { StateCreator } from 'zustand';
|
|
3
|
+
import { IoAssistStore } from './index';
|
|
4
|
+
export type McpAppsSlice = {
|
|
5
|
+
mcpAppInstances: IoAiWeb.McpApps.AppInstance[];
|
|
6
|
+
addMcpApp: (instance: IoAiWeb.McpApps.AppInstance) => void;
|
|
7
|
+
removeMcpApp: (instanceId: string) => void;
|
|
8
|
+
resetMcpApps: () => void;
|
|
9
|
+
};
|
|
10
|
+
export declare const createMcpAppsSlice: StateCreator<IoAssistStore, [
|
|
11
|
+
['zustand/subscribeWithSelector', never]
|
|
12
|
+
], [
|
|
13
|
+
], McpAppsSlice>;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { MessagesLoadingState, ToolTraceState, UIMessage } from '../types';
|
|
4
|
+
export type MessageSlice = {
|
|
5
|
+
messages: UIMessage[];
|
|
6
|
+
isGeneratingResponse: boolean;
|
|
7
|
+
messageLoadingState: MessagesLoadingState;
|
|
8
|
+
isLastResponseSuccess: boolean;
|
|
9
|
+
toolTraceState: ToolTraceState[];
|
|
10
|
+
/**
|
|
11
|
+
* Monotonically-increasing counter incremented every time we want the chat
|
|
12
|
+
* to snap the latest content to the top of the visible viewport (imperative
|
|
13
|
+
* one-shot trigger, called from `sendUserMessage`). ScrollArea subscribes
|
|
14
|
+
* and reacts to each tick.
|
|
15
|
+
*/
|
|
16
|
+
scrollAnchorRequestId: number;
|
|
17
|
+
setMessages: (messages: UIMessage[]) => void;
|
|
18
|
+
addMessage: (message: UIMessage) => void;
|
|
19
|
+
updateMessage: (id: string, changes: Partial<UIMessage>) => void;
|
|
20
|
+
clearMessages: () => void;
|
|
21
|
+
setIsGeneratingResponse: (generating: boolean) => void;
|
|
22
|
+
setMessageLoadingState: (state: MessagesLoadingState) => void;
|
|
23
|
+
setIsLastResponseSuccess: (success: boolean) => void;
|
|
24
|
+
setToolTraceState: (state: ToolTraceState[]) => void;
|
|
25
|
+
toggleToolTrace: (messageId: string) => void;
|
|
26
|
+
toggleToolMessage: (toolMessageId: string, parentId: string) => void;
|
|
27
|
+
mergeAccumulatedStreamContent: (threadId: string) => void;
|
|
28
|
+
requestScrollAnchor: () => void;
|
|
29
|
+
};
|
|
30
|
+
export declare const createMessageSlice: StateCreator<IoAssistStore, [
|
|
31
|
+
['zustand/subscribeWithSelector', never]
|
|
32
|
+
], [
|
|
33
|
+
], MessageSlice>;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { Prompt } from '../types';
|
|
4
|
+
export type PromptSlice = {
|
|
5
|
+
allPrompts: Prompt[];
|
|
6
|
+
favoritePromptNames: string[];
|
|
7
|
+
selectedPrompt: Prompt | null;
|
|
8
|
+
setAllPrompts: (prompts: Prompt[]) => void;
|
|
9
|
+
setFavoritePromptNames: (names: string[]) => void;
|
|
10
|
+
toggleFavoritePrompt: (name: string) => void;
|
|
11
|
+
setSelectedPrompt: (prompt: Prompt | null) => void;
|
|
12
|
+
};
|
|
13
|
+
export declare const createPromptSlice: StateCreator<IoAssistStore, [
|
|
14
|
+
['zustand/subscribeWithSelector', never]
|
|
15
|
+
], [
|
|
16
|
+
], PromptSlice>;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { ResponseStreamStatus, UIToolMessage, UIUserMessage } from '../types';
|
|
4
|
+
export type StreamState = {
|
|
5
|
+
status: ResponseStreamStatus;
|
|
6
|
+
content: string;
|
|
7
|
+
messageId: string | null;
|
|
8
|
+
errorMessage?: string;
|
|
9
|
+
userMessage: UIUserMessage | null;
|
|
10
|
+
toolMessages: UIToolMessage[];
|
|
11
|
+
};
|
|
12
|
+
export type ResponseStreamSlice = {
|
|
13
|
+
streamsByThreadId: Record<string, StreamState>;
|
|
14
|
+
completionNotifications: string[];
|
|
15
|
+
startStream: (threadId: string, userMessage: UIUserMessage | null) => void;
|
|
16
|
+
updateStreamContent: (threadId: string, content: string, messageId: string) => void;
|
|
17
|
+
addStreamToolMessage: (threadId: string, toolMessage: UIToolMessage) => void;
|
|
18
|
+
completeStream: (threadId: string, shouldNotify: boolean) => void;
|
|
19
|
+
failStream: (threadId: string, errorMessage: string) => void;
|
|
20
|
+
abortStream: (threadId: string) => void;
|
|
21
|
+
untrackStream: (threadId: string) => void;
|
|
22
|
+
setStreamState: (threadId: string, state: Partial<StreamState>) => void;
|
|
23
|
+
clearStreamState: (threadId: string) => void;
|
|
24
|
+
addCompletionNotification: (threadId: string) => void;
|
|
25
|
+
clearCompletionNotification: (threadId: string) => void;
|
|
26
|
+
clearAllCompletionNotifications: () => void;
|
|
27
|
+
};
|
|
28
|
+
export declare const createResponseStreamSlice: StateCreator<IoAssistStore, [
|
|
29
|
+
['zustand/subscribeWithSelector', never]
|
|
30
|
+
], [
|
|
31
|
+
], ResponseStreamSlice>;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { LoadingState, UIThread } from '../types';
|
|
4
|
+
export type ThreadSlice = {
|
|
5
|
+
threads: UIThread[];
|
|
6
|
+
activeThreadId: string | null;
|
|
7
|
+
threadLoadingState: LoadingState;
|
|
8
|
+
setThreads: (threads: UIThread[]) => void;
|
|
9
|
+
updateThread: (id: string, changes: Partial<UIThread>) => void;
|
|
10
|
+
removeThread: (id: string) => void;
|
|
11
|
+
setActiveThreadId: (id: string | null) => void;
|
|
12
|
+
setThreadLoadingState: (state: LoadingState) => void;
|
|
13
|
+
};
|
|
14
|
+
export declare const createThreadSlice: StateCreator<IoAssistStore, [
|
|
15
|
+
['zustand/subscribeWithSelector', never]
|
|
16
|
+
], [
|
|
17
|
+
], ThreadSlice>;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { StateCreator } from 'zustand';
|
|
2
|
+
import { IoAssistStore } from './index';
|
|
3
|
+
import { LoadingState, UITool } from '../types';
|
|
4
|
+
export type ToolSlice = {
|
|
5
|
+
tools: UITool[];
|
|
6
|
+
toolLoadingState: LoadingState;
|
|
7
|
+
setTools: (tools: UITool[]) => void;
|
|
8
|
+
updateToolEnabled: (name: string, enabled: boolean) => void;
|
|
9
|
+
updateToolState: (name: string, toolState: UITool['state']) => void;
|
|
10
|
+
setToolLoadingState: (state: LoadingState) => void;
|
|
11
|
+
};
|
|
12
|
+
export declare const createToolSlice: StateCreator<IoAssistStore, [
|
|
13
|
+
['zustand/subscribeWithSelector', never]
|
|
14
|
+
], [
|
|
15
|
+
], ToolSlice>;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { IoIntelWorkingContext } from '@interopio/working-context';
|
|
2
|
+
import { StateCreator } from 'zustand';
|
|
3
|
+
import { IoAssistStore } from './index';
|
|
4
|
+
import { LoadingState } from '../types';
|
|
5
|
+
export type WorkingContextSlice = {
|
|
6
|
+
isWorkingContextEnabled: boolean;
|
|
7
|
+
workingContext: Record<string, IoIntelWorkingContext.Property> | null;
|
|
8
|
+
workingContextLoadingState: LoadingState;
|
|
9
|
+
setIsWorkingContextEnabled: (enabled: boolean) => void;
|
|
10
|
+
setWorkingContext: (ctx: Record<string, IoIntelWorkingContext.Property> | null) => void;
|
|
11
|
+
setWorkingContextLoadingState: (state: LoadingState) => void;
|
|
12
|
+
};
|
|
13
|
+
export declare const createWorkingContextSlice: StateCreator<IoAssistStore, [
|
|
14
|
+
['zustand/subscribeWithSelector', never]
|
|
15
|
+
], [
|
|
16
|
+
], WorkingContextSlice>;
|
package/dist/styles.css
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-orange-500:oklch(70.5% .213 47.604);--color-yellow-400:oklch(85.2% .199 91.936);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--leading-normal:1.5;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-app-background:var(--app-background);--color-app-background-secondary:var(--app-background-secondary);--color-app-accent-color-1:var(--app-accent-color-1);--spacing-spacing-3:var(--app-spacing-3);--spacing-spacing-6:var(--app-spacing-6);--font-default:"Inter Variable", sans-serif;--color-text-states-disabled:var(--app-text-states-disabled);--color-text-states-hover:var(--app-text-states-hover);--color-text-states-active:var(--app-text-states-active);--color-text-default:var(--app-text-default);--color-text-secondary:var(--app-text-secondary);--color-text-black-white:var(--app-text-black-white);--color-thread-list-item-hover-background:var(--app-thread-list-item-hover-background);--font-weight-weight-400:var(--app-font-weight-400);--font-weight-weight-600:var(--app-font-weight-600);--color-border-default:var(--app-border-default);--color-border-hover:var(--app-border-hover);--color-panel-background:var(--app-panel-background);--color-panel-border:var(--app-panel-border);--color-button-submit-background:var(--app-blue);--color-button-border-default:var(--app-button-border-default);--color-user-message-background:var(--app-user-message-background);--color-user-message-text:var(--app-user-message-text);--color-input-border:var(--app-input-border);--color-input-background:var(--app-input-background);--color-input-background-hover:var(--app-input-background-hover);--color-input-background-active:var(--app-input-background-active);--color-input-border-hover:var(--app-input-border-hover);--color-input-border-active:var(--app-input-border-active);--color-input-text:var(--app-input-text);--color-input-text-active:var(--app-input-text-active);--color-input-icon:var(--app-input-icon);--color-input-icon-active:var(--app-input-icon-active);--radius-input-radius:var(--app-border-radius-sm);--color-app-icon-background-hover:var(--app-icon-background-hover);--color-app-icon-background-disabled:var(--app-icon-background-disabled);--color-toggle-background-disabled:var(--app-toggle-background-disabled);--color-toggle-background-enabled:var(--app-toggle-background-enabled);--color-toggle-background-hover-disabled:var(--app-toggle-background-hover-disabled);--color-toggle-background-hover-enabled:var(--app-toggle-background-hover-enabled);--color-toggle-circle:var(--app-toggle-circle);--color-proto-text-default:var(--app-proto-text-default);--color-proto-text-disabled:var(--app-proto-text-disabled)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}html,body{width:100%;height:100%;margin:0;padding:0}:root{--app-red-700:#c92121;--app-red-800:#b01d1d;--app-orange:#f25f1f;--app-blue:#4b92fb;--app-blue-toggle:#356ec4;--app-yellow:#deaf37;--app-neutrals-0:#fff;--app-neutrals-25:#f7f7f7;--app-neutrals-50:#f2f2f2;--app-neutrals-75:#ededed;--app-neutrals-100:#eaeaeb;--app-neutrals-150:#dadbdd;--app-neutrals-200:#caccce;--app-neutrals-300:#b0b2b5;--app-neutrals-400:#95989d;--app-neutrals-500:#7b7e84;--app-neutrals-600:#62656a;--app-neutrals-650:#55585d;--app-neutrals-700:#494b50;--app-neutrals-750:#3d3f43;--app-neutrals-800:#36383b;--app-neutrals-850:#2e3033;--app-neutrals-900:#26272a;--app-neutrals-950:#18191b;--app-neutrals-1000:#000;--app-accent-color-1:var(--app-orange);--app-accent-color-2:var(--app-blue);--app-accent-color-3:var(--app-yellow);--app-spacing-1:2px;--app-spacing-2:4px;--app-spacing-3:6px;--app-spacing-4:8px;--app-spacing-5:10px;--app-spacing-6:12px;--app-border-radius-sm:8px;--app-font-size-10:10px;--app-font-size-12:12px;--app-line-height-13:13px;--app-letter-spacing-01:.1px;--app-border-error:var(--app-red-700);--app-border-size-1:1px;--app-font-weight-400:400;--app-font-weight-600:600;--app-default-box-shadow:0 3px 11px 6px #00000029;--prototype-temp-color-50:#f9f9f9;--prototype-temp-color-100:#f2f2f2;--prototype-temp-color-200:#e5e5e5;--prototype-temp-color-300:#ccc;--prototype-temp-color-400:#b3b3b3;--prototype-temp-color-500:#999;--prototype-temp-color-600:gray;--prototype-temp-color-700:#666;--prototype-temp-color-800:#4d4d4d;--prototype-temp-color-900:#333;--prototype-temp-color-1000:#1a1a1a}.dark{--app-background:var(--app-neutrals-900);--app-background-secondary:var(--app-neutrals-850);--app-border-default:var(--app-neutrals-700);--app-border-disabled-default:var(--app-neutrals-850);--app-input-border:var(--app-neutrals-900);--app-button-border-default:var(--app-neutrals-500);--app-background-disabled:var(--app-neutrals-900);--app-text-disabled:var(--app-neutrals-600);--app-icon-disabled:var(--app-neutrals-600);--app-icon-background-hover:var(--app-neutrals-800);--app-icon-background-disabled:var(--app-neutrals-700);--app-thread-list-item-hover-background:var(--app-neutrals-800);--app-text-black-white:var(--app-neutrals-0);--app-border-hover:var(--app-neutrals-600);--app-panel-background:var(--app-neutrals-900);--app-panel-border:var(--app-neutrals-700);--app-user-message-background:var(--app-neutrals-800);--app-user-message-text:var(--app-neutrals-300);--app-input-background-disabled:var(--app-neutrals-900);--app-input-background:var(--app-neutrals-850);--app-input-background-hover:var(--app-neutrals-800);--app-input-background-active:var(--app-neutrals-800);--app-input-border-hover:var(--app-neutrals-750);--app-input-border-active:var(--app-neutrals-600);--app-input-text:var(--app-neutrals-200);--app-input-text-active:var(--app-neutrals-0);--app-input-icon:var(--app-neutrals-200);--app-input-icon-active:var(--app-neutrals-0);--app-input-icon-disabled:var(--app-neutrals-600);--app-text-states-disabled:var(--app-neutrals-600);--app-text-states-hover:var(--app-neutrals-100);--app-text-states-active:var(--app-neutrals-0);--app-text-default:var(--app-neutrals-300);--app-text-secondary:var(--app-neutrals-500);--app-text-error:var(--app-red-700);--app-toggle-background-disabled:var(--app-neutrals-750);--app-toggle-background-enabled:var(--app-blue-toggle);--app-toggle-background-hover-disabled:var(--app-neutrals-700);--app-toggle-background-hover-enabled:var(--app-blue);--app-toggle-circle:var(--app-neutrals-0);--app-proto-background:var(--prototype-temp-color-1000);--app-proto-background-light:var(--prototype-temp-color-900);--app-proto-border-default:var(--prototype-temp-color-800);--app-proto-text-default:var(--prototype-temp-color-300);--app-proto-text-disabled:var(--prototype-temp-color-600)}.light{--app-background:var(--app-neutrals-0);--app-background-secondary:var(--app-neutrals-25);--app-border-default:var(--app-neutrals-150);--app-border-disabled-default:var(--app-neutrals-100);--app-input-border:var(--app-neutrals-150);--app-button-border-default:var(--app-neutrals-200);--app-background-disabled:var(--app-neutrals-50);--app-text-disabled:var(--app-neutrals-400);--app-icon-disabled:var(--app-neutrals-400);--app-icon-background-hover:var(--app-neutrals-25);--app-icon-background-disabled:var(--app-neutrals-100);--app-thread-list-item-hover-background:var(--app-neutrals-50);--app-text-black-white:var(--app-neutrals-150);--app-border-hover:var(--app-neutrals-150);--app-panel-background:var(--app-neutrals-0);--app-panel-border:var(--app-neutrals-700);--app-user-message-background:var(--app-neutrals-50);--app-user-message-text:var(--app-neutrals-700);--app-input-background-disabled:var(--app-neutrals-50);--app-input-background:var(--app-neutrals-0);--app-input-background-hover:var(--app-neutrals-100);--app-input-background-active:var(--app-neutrals-25);--app-input-border-hover:var(--app-neutrals-200);--app-input-border-active:var(--app-neutrals-400);--app-input-text:var(--app-neutrals-800);--app-input-text-active:var(--app-neutrals-900);--app-input-icon:var(--app-neutrals-700);--app-input-icon-active:var(--app-neutrals-900);--app-input-icon-disabled:var(--app-neutrals-400);--app-text-states-disabled:var(--app-neutrals-400);--app-text-states-hover:var(--app-neutrals-800);--app-text-states-active:var(--app-neutrals-900);--app-text-default:var(--app-neutrals-700);--app-text-secondary:var(--app-neutrals-500);--app-text-error:var(--app-red-700);--app-toggle-background-disabled:var(--app-neutrals-200);--app-toggle-background-enabled:var(--app-blue-toggle);--app-toggle-background-hover-disabled:var(--app-neutrals-300);--app-toggle-background-hover-enabled:var(--app-blue);--app-toggle-circle:var(--app-neutrals-0);--app-proto-background:var(--prototype-temp-color-50);--app-proto-background-light:var(--prototype-temp-color-100);--app-proto-border-default:var(--prototype-temp-color-300);--app-proto-text-default:var(--prototype-temp-color-700);--app-proto-text-disabled:var(--prototype-temp-color-400)}.custom-scrollbar::-webkit-scrollbar{scrollbar-width:thin;scrollbar-gutter:stable both-edges}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-button{width:0;height:0;display:none}.custom-scrollbar::-webkit-scrollbar-thumb{background:#00000040;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#00000059}.custom-scrollbar{scrollbar-width:thin;scrollbar-color:#0000004d transparent;scrollbar-gutter:stable both-edges}.safe-word-break{white-space:normal;overflow-wrap:break-word;word-break:normal;-webkit-hyphens:auto;hyphens:auto}.custom-scrollbar-no-gutter{scrollbar-gutter:unset}.io-assist-md *{padding-top:8px;padding-bottom:8px}.io-assist-md .io-assist-code-theme :not(pre){padding-top:0;padding-bottom:0}}@layer components{.io-assist-md .io-assist-code-theme{display:block;position:relative}.io-assist-md .io-assist-code-theme>pre{background:linear-gradient(#000,#000) padding-box,linear-gradient(90deg,var(--app-accent-color-1),var(--app-accent-color-2)) border-box!important;border:2px solid #0000!important}.working-context-panel .io-assist-code-theme>pre{height:30vh;max-height:620px}}@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.-top-1{top:calc(var(--spacing) * -1)}.top-0{top:calc(var(--spacing) * 0)}.top-\[-2px\]{top:-2px}.-right-1{right:calc(var(--spacing) * -1)}.bottom-5{bottom:calc(var(--spacing) * 5)}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-\[-2px\]{left:-2px}.left-\[2px\]{left:2px}.left-\[20px\]{left:20px}.isolate{isolation:isolate}.z-0{z-index:0}.z-1{z-index:1}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-50{z-index:50}.z-\[-1\]{z-index:-1}.z-\[-2\]{z-index:-2}.z-\[999999\]{z-index:999999}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.m-\[4px\]{margin:4px}.mx-auto{margin-inline:auto}.my-2{margin-block:calc(var(--spacing) * 2)}.my-4{margin-block:calc(var(--spacing) * 4)}.my-\[revert\]{margin-block:revert}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-auto{margin-top:auto}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.box-border{box-sizing:border-box}.block{display:block}.flex{display:flex}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.size-1\.5{width:calc(var(--spacing) * 1.5);height:calc(var(--spacing) * 1.5)}.size-2{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-3{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.size-5{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.size-\[calc\(100\%\+4px\)\]{width:calc(100% + 4px);height:calc(100% + 4px)}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-8{height:calc(var(--spacing) * 8)}.h-16{height:calc(var(--spacing) * 16)}.h-\[12px\]{height:12px}.h-\[16px\]{height:16px}.h-\[48px\]{height:48px}.h-full{height:100%}.h-px{height:1px}.max-h-\[90vh\]{max-height:90vh}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-48{min-height:calc(var(--spacing) * 48)}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-\[12px\]{width:12px}.w-\[34px\]{width:34px}.w-\[368px\]{width:368px}.w-auto{width:auto}.w-full{width:100%}.max-w-\[320px\]{max-width:320px}.max-w-\[368px\]{max-width:368px}.max-w-\[620px\]{max-width:620px}.max-w-\[920px\]{max-width:920px}.max-w-\[960px\]{max-width:960px}.max-w-full{max-width:100%}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[200px\]{min-width:200px}.min-w-\[240px\]{min-width:240px}.min-w-\[320px\]{min-width:320px}.min-w-\[368px\]{min-width:368px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.rotate-90{rotate:90deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.flex-col{flex-direction:column}.flex-row-reverse{flex-direction:row-reverse}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-0{gap:calc(var(--spacing) * 0)}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-12{gap:calc(var(--spacing) * 12)}.gap-\[2px\]{gap:2px}.gap-\[10px\]{gap:10px}.self-stretch{align-self:stretch}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.overflow-y-scroll{overflow-y:scroll}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[4px\]{border-radius:4px}.rounded-\[6px\]{border-radius:6px}.rounded-\[8px\]{border-radius:8px}.rounded-full{border-radius:3.40282e38px}.rounded-input-radius{border-radius:var(--radius-input-radius)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-\[1px\]{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-app-accent-color-1{border-color:var(--color-app-accent-color-1)}.border-border-default{border-color:var(--color-border-default)}.border-button-border-default{border-color:var(--color-button-border-default)}.border-input-border{border-color:var(--color-input-border)}.border-input-border-active{border-color:var(--color-input-border-active)}.border-panel-border{border-color:var(--color-panel-border)}.border-text-default{border-color:var(--color-text-default)}.bg-app-accent-color-1{background-color:var(--color-app-accent-color-1)}.bg-app-background{background-color:var(--color-app-background)}.bg-app-background-secondary{background-color:var(--color-app-background-secondary)}.bg-app-icon-background-disabled{background-color:var(--color-app-icon-background-disabled)}.bg-black\/45{background-color:#00000073}@supports (color:color-mix(in lab,red,red)){.bg-black\/45{background-color:color-mix(in oklab,var(--color-black) 45%,transparent)}}.bg-black\/\[0\.32\]{background-color:#00000052}@supports (color:color-mix(in lab,red,red)){.bg-black\/\[0\.32\]{background-color:color-mix(in oklab,var(--color-black) 32%,transparent)}}.bg-button-submit-background{background-color:var(--color-button-submit-background)}.bg-input-background{background-color:var(--color-input-background)}.bg-input-background-active{background-color:var(--color-input-background-active)}.bg-orange-500{background-color:var(--color-orange-500)}.bg-panel-background{background-color:var(--color-panel-background)}.bg-thread-list-item-hover-background{background-color:var(--color-thread-list-item-hover-background)}.bg-toggle-background-disabled{background-color:var(--color-toggle-background-disabled)}.bg-toggle-background-enabled{background-color:var(--color-toggle-background-enabled)}.bg-toggle-circle{background-color:var(--color-toggle-circle)}.bg-transparent{background-color:#0000}.bg-user-message-background{background-color:var(--color-user-message-background)}.bg-\[linear-gradient\(90deg\,var\(--app-accent-color-1\)\,var\(--app-accent-color-2\)\)\]{background-image:linear-gradient(90deg,var(--app-accent-color-1),var(--app-accent-color-2))}.p-0{padding:calc(var(--spacing) * 0)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-px{padding:1px}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-\[3px\]{padding-inline:3px}.px-spacing-6{padding-inline:var(--spacing-spacing-6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-\[5px\]{padding-block:5px}.py-spacing-3{padding-block:var(--spacing-spacing-3)}.ps-1{padding-inline-start:calc(var(--spacing) * 1)}.ps-2{padding-inline-start:calc(var(--spacing) * 2)}.pt-0{padding-top:calc(var(--spacing) * 0)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-24{padding-top:calc(var(--spacing) * 24)}.pt-\[160px\]{padding-top:160px}.pb-0{padding-bottom:calc(var(--spacing) * 0)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.pl-5{padding-left:calc(var(--spacing) * 5)}.text-center{text-align:center}.text-left{text-align:left}.font-\[revert\]{font-family:revert}.font-default{font-family:var(--font-default)}.font-mono{font-family:var(--font-mono)}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[28px\]{font-size:28px}.leading-4{--tw-leading:calc(var(--spacing) * 4);line-height:calc(var(--spacing) * 4)}.leading-\[12px\]{--tw-leading:12px;line-height:12px}.leading-\[13px\]{--tw-leading:13px;line-height:13px}.leading-\[17px\]{--tw-leading:17px;line-height:17px}.leading-\[18px\]{--tw-leading:18px;line-height:18px}.leading-\[19px\]{--tw-leading:19px;line-height:19px}.leading-\[24px\]{--tw-leading:24px;line-height:24px}.leading-\[100\%\]{--tw-leading:100%;line-height:100%}.leading-normal{--tw-leading:var(--leading-normal);line-height:var(--leading-normal)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.font-weight-400{--tw-font-weight:var(--font-weight-weight-400);font-weight:var(--font-weight-weight-400)}.font-weight-600{--tw-font-weight:var(--font-weight-weight-600);font-weight:var(--font-weight-weight-600)}.tracking-\[0\.1px\]{--tw-tracking:.1px;letter-spacing:.1px}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.break-words{overflow-wrap:break-word}.text-ellipsis{text-overflow:ellipsis}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[revert\]{color:revert}.text-app-accent-color-1{color:var(--color-app-accent-color-1)}.text-blue-500{color:var(--color-blue-500)}.text-input-icon{color:var(--color-input-icon)}.text-input-icon-active{color:var(--color-input-icon-active)}.text-input-text{color:var(--color-input-text)}.text-input-text-active{color:var(--color-input-text-active)}.text-proto-text-default{color:var(--color-proto-text-default)}.text-proto-text-disabled{color:var(--color-proto-text-disabled)}.text-text-black-white{color:var(--color-text-black-white)}.text-text-default{color:var(--color-text-default)}.text-text-secondary{color:var(--color-text-secondary)}.text-text-states-active{color:var(--color-text-states-active)}.text-text-states-disabled{color:var(--color-text-states-disabled)}.text-text-states-hover{color:var(--color-text-states-hover)}.text-user-message-text{color:var(--color-user-message-text)}.text-white{color:var(--color-white)}.text-yellow-400{color:var(--color-yellow-400)}.italic{font-style:italic}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-panel-box-shadow{--tw-shadow:var(--app-default-box-shadow);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.outline-none{--tw-outline-style:none;outline-style:none}@media(hover:hover){.group-hover\:flex:is(:where(.group):hover *){display:flex}}.placeholder\:text-text-states-disabled::placeholder{color:var(--color-text-states-disabled)}.first\:mt-0:first-child{margin-top:calc(var(--spacing) * 0)}.last\:mb-0:last-child{margin-bottom:calc(var(--spacing) * 0)}.odd\:bg-app-background:nth-child(odd){background-color:var(--color-app-background)}.even\:bg-app-background-secondary:nth-child(2n){background-color:var(--color-app-background-secondary)}@media(hover:hover){.hover\:border-border-hover:hover{border-color:var(--color-border-hover)}.hover\:border-input-border-hover:hover{border-color:var(--color-input-border-hover)}.hover\:bg-app-icon-background-hover:hover{background-color:var(--color-app-icon-background-hover)}.hover\:bg-input-background-hover:hover{background-color:var(--color-input-background-hover)}.hover\:bg-thread-list-item-hover-background:hover{background-color:var(--color-thread-list-item-hover-background)}.hover\:bg-toggle-background-hover-disabled:hover{background-color:var(--color-toggle-background-hover-disabled)}.hover\:bg-toggle-background-hover-enabled:hover{background-color:var(--color-toggle-background-hover-enabled)}.hover\:text-blue-600:hover{color:var(--color-blue-600)}.hover\:text-text-states-active:hover{color:var(--color-text-states-active)}.hover\:text-text-states-hover:hover{color:var(--color-text-states-hover)}.hover\:text-yellow-400:hover{color:var(--color-yellow-400)}.hover\:opacity-90:hover{opacity:.9}.hover\:opacity-95:hover{opacity:.95}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:48rem){.md\:w-auto{width:auto}.md\:max-w-\[352px\]{max-width:352px}.md\:max-w-\[720px\]{max-width:720px}.md\:min-w-\[250px\]{min-width:250px}.md\:min-w-\[540px\]{min-width:540px}.md\:flex-row{flex-direction:row}.md\:flex-wrap{flex-wrap:wrap}.md\:justify-center{justify-content:center}.md\:gap-14{gap:calc(var(--spacing) * 14)}.md\:pt-20{padding-top:calc(var(--spacing) * 20)}.md\:text-\[44px\]{font-size:44px}}}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(./files/inter-latin-wght-normal.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { IoAiWeb } from '@interopio/ai-web';
|
|
2
|
+
import { IOConnectBrowser, IOConnectBrowserFactoryFunction } from '@interopio/browser';
|
|
3
|
+
import { IOConnectDesktop } from '@interopio/desktop';
|
|
4
|
+
import { IoAssistPromptCategory } from './prompt';
|
|
5
|
+
export type IoAssistUserConfig = {
|
|
6
|
+
id: string;
|
|
7
|
+
name?: string;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* Runtime config passed as a prop to `<IoAssist config={...}>`.
|
|
11
|
+
* Populated after login with user identity and per-request auth headers.
|
|
12
|
+
*/
|
|
13
|
+
export type IoAssistDynamicConfig = {
|
|
14
|
+
user: IoAssistUserConfig;
|
|
15
|
+
agentServer?: {
|
|
16
|
+
/** Request headers sent with every agent call (e.g., per-user auth tokens). */
|
|
17
|
+
headers?: Record<string, string>;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export type IoConnectBrowserFactoryEntry = {
|
|
21
|
+
factory: IOConnectBrowserFactoryFunction;
|
|
22
|
+
config?: IOConnectBrowser.Config;
|
|
23
|
+
};
|
|
24
|
+
export type IoConnectDesktopFactoryEntry = {
|
|
25
|
+
factory: (config?: IOConnectDesktop.Config) => Promise<IOConnectDesktop.API>;
|
|
26
|
+
config?: IOConnectDesktop.Config;
|
|
27
|
+
};
|
|
28
|
+
export type IoAssistStaticConfig = {
|
|
29
|
+
connectConfig: {
|
|
30
|
+
browser?: IoConnectBrowserFactoryEntry;
|
|
31
|
+
desktop?: IoConnectDesktopFactoryEntry;
|
|
32
|
+
};
|
|
33
|
+
aiWebConfig: {
|
|
34
|
+
agentServer: IoAiWeb.AgentServerConfig;
|
|
35
|
+
mcp?: IoAiWeb.MCPConfig;
|
|
36
|
+
};
|
|
37
|
+
defaultAgentName?: string;
|
|
38
|
+
workingContext?: IoAiWeb.WorkingContextConfig;
|
|
39
|
+
defaultPrompts?: IoAssistPromptCategory[];
|
|
40
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export type { IconType, IconResource } from './icon';
|
|
2
|
+
export type { IoAssistPrompt, IoAssistPromptCategory, Prompt } from './prompt';
|
|
3
|
+
export type { IoAssistUserConfig, IoAssistDynamicConfig, IoAssistStaticConfig, IoConnectBrowserFactoryEntry, IoConnectDesktopFactoryEntry, } from './config';
|
|
4
|
+
export { UI_MESSAGE_ROLES, TOOL_RESULT_TYPES } from './message';
|
|
5
|
+
export type { UIMessageRole, ToolResultType, UIMessageBase, UIUserMessage, UIAssistantMessage, UIToolMessage, UIMessage, ToolTextResult, ToolImageResult, ToolAudioResult, ToolResult, ToolTraceState, } from './message';
|
|
6
|
+
export type { UIAgent } from './agent';
|
|
7
|
+
export type { UIThread } from './thread';
|
|
8
|
+
export { TOOL_STATES } from './tool';
|
|
9
|
+
export type { ToolState, UITool } from './tool';
|
|
10
|
+
export { PANEL_CONTENT } from './panel';
|
|
11
|
+
export type { PanelContent } from './panel';
|
|
12
|
+
export { RESPONSE_STREAM_STATUS } from './stream';
|
|
13
|
+
export type { GetResponseParams, ResponseStreamStatus } from './stream';
|
|
14
|
+
export { LOADING_STATES, MESSAGES_LOADING_STATE } from './loading';
|
|
15
|
+
export type { LoadingState, MessagesLoadingState } from './loading';
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export declare const LOADING_STATES: {
|
|
2
|
+
readonly NOT_STARTED: "not-started";
|
|
3
|
+
readonly LOADING: "loading";
|
|
4
|
+
readonly SUCCESS: "success";
|
|
5
|
+
readonly ERROR: "error";
|
|
6
|
+
};
|
|
7
|
+
export type LoadingState = {
|
|
8
|
+
type: typeof LOADING_STATES.NOT_STARTED;
|
|
9
|
+
} | {
|
|
10
|
+
type: typeof LOADING_STATES.LOADING;
|
|
11
|
+
} | {
|
|
12
|
+
type: typeof LOADING_STATES.SUCCESS;
|
|
13
|
+
} | {
|
|
14
|
+
type: typeof LOADING_STATES.ERROR;
|
|
15
|
+
message: string;
|
|
16
|
+
};
|
|
17
|
+
export declare const MESSAGES_LOADING_STATE: {
|
|
18
|
+
readonly NOT_STARTED: "NOT_STARTED";
|
|
19
|
+
readonly LOADING_RESPONSE: "LOADING_RESPONSE";
|
|
20
|
+
readonly LOADING_FROM_THREAD: "LOADING_FROM_THREAD";
|
|
21
|
+
readonly GET_RESPONSE_SUCCESS: "GET_RESPONSE_SUCCESS";
|
|
22
|
+
readonly FETCH_MESSAGES_FROM_THREAD_SUCCESS: "FETCH_MESSAGES_FROM_THREAD_SUCCESS";
|
|
23
|
+
readonly ERROR: "ERROR";
|
|
24
|
+
};
|
|
25
|
+
export type MessagesLoadingState = {
|
|
26
|
+
type: typeof MESSAGES_LOADING_STATE.NOT_STARTED;
|
|
27
|
+
} | {
|
|
28
|
+
type: typeof MESSAGES_LOADING_STATE.LOADING_RESPONSE;
|
|
29
|
+
} | {
|
|
30
|
+
type: typeof MESSAGES_LOADING_STATE.LOADING_FROM_THREAD;
|
|
31
|
+
} | {
|
|
32
|
+
type: typeof MESSAGES_LOADING_STATE.GET_RESPONSE_SUCCESS;
|
|
33
|
+
} | {
|
|
34
|
+
type: typeof MESSAGES_LOADING_STATE.FETCH_MESSAGES_FROM_THREAD_SUCCESS;
|
|
35
|
+
} | {
|
|
36
|
+
type: typeof MESSAGES_LOADING_STATE.ERROR;
|
|
37
|
+
message: string;
|
|
38
|
+
};
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
export declare const UI_MESSAGE_ROLES: {
|
|
2
|
+
readonly USER: "user";
|
|
3
|
+
readonly ASSISTANT: "assistant";
|
|
4
|
+
readonly TOOL: "tool";
|
|
5
|
+
};
|
|
6
|
+
export type UIMessageRole = (typeof UI_MESSAGE_ROLES)[keyof typeof UI_MESSAGE_ROLES];
|
|
7
|
+
export declare const TOOL_RESULT_TYPES: {
|
|
8
|
+
readonly TEXT: "text";
|
|
9
|
+
readonly IMAGE: "image";
|
|
10
|
+
readonly AUDIO: "audio";
|
|
11
|
+
};
|
|
12
|
+
export type ToolResultType = (typeof TOOL_RESULT_TYPES)[keyof typeof TOOL_RESULT_TYPES];
|
|
13
|
+
export type UIMessageBase = {
|
|
14
|
+
id: string;
|
|
15
|
+
role: UIMessageRole;
|
|
16
|
+
content?: string;
|
|
17
|
+
displayFooter?: boolean;
|
|
18
|
+
responseForUserQueryId?: string;
|
|
19
|
+
isLastMessage?: boolean;
|
|
20
|
+
isNew?: boolean;
|
|
21
|
+
};
|
|
22
|
+
export type UIUserMessage = UIMessageBase & {
|
|
23
|
+
role: typeof UI_MESSAGE_ROLES.USER;
|
|
24
|
+
};
|
|
25
|
+
export type UIAssistantMessage = UIMessageBase & {
|
|
26
|
+
role: typeof UI_MESSAGE_ROLES.ASSISTANT;
|
|
27
|
+
};
|
|
28
|
+
export type ToolTextResult = {
|
|
29
|
+
type: typeof TOOL_RESULT_TYPES.TEXT;
|
|
30
|
+
text: string;
|
|
31
|
+
};
|
|
32
|
+
export type ToolImageResult = {
|
|
33
|
+
type: typeof TOOL_RESULT_TYPES.IMAGE;
|
|
34
|
+
data: string;
|
|
35
|
+
mimeType: string;
|
|
36
|
+
};
|
|
37
|
+
export type ToolAudioResult = {
|
|
38
|
+
type: typeof TOOL_RESULT_TYPES.AUDIO;
|
|
39
|
+
data: string;
|
|
40
|
+
mimeType: string;
|
|
41
|
+
};
|
|
42
|
+
export type ToolResult = ToolTextResult | ToolImageResult | ToolAudioResult;
|
|
43
|
+
export type UIToolMessage = UIMessageBase & {
|
|
44
|
+
toolName: string;
|
|
45
|
+
role: typeof UI_MESSAGE_ROLES.TOOL;
|
|
46
|
+
args?: Record<string, unknown>;
|
|
47
|
+
result?: ToolResult | [ToolResult];
|
|
48
|
+
isExpanded?: boolean;
|
|
49
|
+
};
|
|
50
|
+
export type UIMessage = UIUserMessage | UIAssistantMessage | UIToolMessage;
|
|
51
|
+
export type ToolTraceState = {
|
|
52
|
+
stateForMessageId: string;
|
|
53
|
+
executedTools: UIToolMessage[];
|
|
54
|
+
uiMessage: string;
|
|
55
|
+
isExpanded?: boolean;
|
|
56
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { IconResource } from './icon';
|
|
2
|
+
export type IoAssistPrompt = {
|
|
3
|
+
name: string;
|
|
4
|
+
prompt: string;
|
|
5
|
+
iconResource?: IconResource;
|
|
6
|
+
};
|
|
7
|
+
export type IoAssistPromptCategory = {
|
|
8
|
+
category?: string;
|
|
9
|
+
prompts: IoAssistPrompt[];
|
|
10
|
+
};
|
|
11
|
+
export type Prompt = {
|
|
12
|
+
id: string;
|
|
13
|
+
name: string;
|
|
14
|
+
description: string;
|
|
15
|
+
category?: string;
|
|
16
|
+
iconResource?: IconResource;
|
|
17
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { IoAiWeb } from '@interopio/ai-web';
|
|
2
|
+
export type GetResponseParams = {
|
|
3
|
+
messages: IoAiWeb.Agents.AgentMessage[];
|
|
4
|
+
instructions?: string;
|
|
5
|
+
system?: string;
|
|
6
|
+
memory?: {
|
|
7
|
+
thread: string;
|
|
8
|
+
resource: string;
|
|
9
|
+
};
|
|
10
|
+
modelSettings?: {
|
|
11
|
+
maxTokens?: number;
|
|
12
|
+
temperature?: number;
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
export declare const RESPONSE_STREAM_STATUS: {
|
|
16
|
+
readonly IDLE: "idle";
|
|
17
|
+
readonly STREAMING: "streaming";
|
|
18
|
+
readonly COMPLETED: "completed";
|
|
19
|
+
readonly ERROR: "error";
|
|
20
|
+
readonly ABORTED: "aborted";
|
|
21
|
+
};
|
|
22
|
+
export type ResponseStreamStatus = (typeof RESPONSE_STREAM_STATUS)[keyof typeof RESPONSE_STREAM_STATUS];
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { IoAiWeb } from '@interopio/ai-web';
|
|
2
|
+
export type UIThread = {
|
|
3
|
+
id: string;
|
|
4
|
+
title: string;
|
|
5
|
+
createdAt: Date;
|
|
6
|
+
updatedAt?: Date;
|
|
7
|
+
rawThread: IoAiWeb.Threads.Thread;
|
|
8
|
+
update(params: {
|
|
9
|
+
title: string;
|
|
10
|
+
}): Promise<void>;
|
|
11
|
+
delete(): Promise<void>;
|
|
12
|
+
getMessages(params: {
|
|
13
|
+
limit: number;
|
|
14
|
+
}): Promise<IoAiWeb.Threads.GetMessagesResponse>;
|
|
15
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { IoAiWeb } from '@interopio/ai-web';
|
|
2
|
+
export declare const TOOL_STATES: {
|
|
3
|
+
readonly IDLE: "IDLE";
|
|
4
|
+
readonly ENABLING_DISABLING: "ENABLING_DISABLING";
|
|
5
|
+
};
|
|
6
|
+
export type ToolState = (typeof TOOL_STATES)[keyof typeof TOOL_STATES];
|
|
7
|
+
export type UITool = {
|
|
8
|
+
name: string;
|
|
9
|
+
description: string;
|
|
10
|
+
enabled: boolean;
|
|
11
|
+
icon?: string;
|
|
12
|
+
mcpServerName?: string;
|
|
13
|
+
state: ToolState;
|
|
14
|
+
rawTool: IoAiWeb.Tools.Tool;
|
|
15
|
+
};
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ConfirmModalConfig } from '../stores';
|
|
2
|
+
export declare const MODAL_PREEMPTED: unique symbol;
|
|
3
|
+
export type ConfirmModalResult = string | null | typeof MODAL_PREEMPTED;
|
|
4
|
+
export declare function showConfirmModal(config: ConfirmModalConfig): Promise<ConfirmModalResult>;
|
|
5
|
+
export declare function resolveConfirmModal(buttonId: string | null): void;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type ModalsDialogButton = {
|
|
2
|
+
variant: 'primary' | 'outline';
|
|
3
|
+
text: string;
|
|
4
|
+
id: string;
|
|
5
|
+
};
|
|
6
|
+
export type ModalsDialogRequest = {
|
|
7
|
+
templateName: 'noInputsConfirmationDialog';
|
|
8
|
+
variables: {
|
|
9
|
+
title: string;
|
|
10
|
+
heading: string;
|
|
11
|
+
text: string;
|
|
12
|
+
actionButtons: ModalsDialogButton[];
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
export type ModalsDialogResponse = {
|
|
16
|
+
responseButtonClicked?: {
|
|
17
|
+
id: string;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export declare function isModalsAvailable(): Promise<boolean>;
|
|
21
|
+
export declare function requestModalDialog(options: ModalsDialogRequest): Promise<ModalsDialogResponse>;
|