@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.
Files changed (99) hide show
  1. package/README.internal.md +467 -0
  2. package/README.md +503 -0
  3. package/changelog.md +2 -0
  4. package/dist/IoAssist.d.ts +12 -0
  5. package/dist/actions/abortActiveStream.d.ts +2 -0
  6. package/dist/actions/deleteThread.d.ts +2 -0
  7. package/dist/actions/elicitation.d.ts +13 -0
  8. package/dist/actions/initIoAiWeb.d.ts +3 -0
  9. package/dist/actions/initIoConnect.d.ts +9 -0
  10. package/dist/actions/mcpAppEvents.d.ts +4 -0
  11. package/dist/actions/newConversation.d.ts +2 -0
  12. package/dist/actions/processResponseStream.d.ts +3 -0
  13. package/dist/actions/renameThread.d.ts +2 -0
  14. package/dist/actions/sampling.d.ts +5 -0
  15. package/dist/actions/selectThread.d.ts +2 -0
  16. package/dist/actions/sendUserMessage.d.ts +3 -0
  17. package/dist/actions/toggleFavoritePrompt.d.ts +7 -0
  18. package/dist/actions/toggleTool.d.ts +2 -0
  19. package/dist/components/chat/ActivePanelModal.d.ts +6 -0
  20. package/dist/components/chat/AiDisclaimer.d.ts +6 -0
  21. package/dist/components/chat/Chat.d.ts +2 -0
  22. package/dist/components/chat/ConfirmModal.d.ts +8 -0
  23. package/dist/components/chat/WelcomeHeading.d.ts +6 -0
  24. package/dist/components/header/Header.d.ts +2 -0
  25. package/dist/components/input-area/InputArea.d.ts +8 -0
  26. package/dist/components/messages/AssistantMessage.d.ts +10 -0
  27. package/dist/components/messages/McpAppResource.d.ts +11 -0
  28. package/dist/components/messages/MdFormatter.d.ts +6 -0
  29. package/dist/components/messages/MessageArea.d.ts +7 -0
  30. package/dist/components/messages/ToolMessage.d.ts +9 -0
  31. package/dist/components/messages/ToolTraceMessage.d.ts +9 -0
  32. package/dist/components/messages/UserMessage.d.ts +9 -0
  33. package/dist/components/messages/mdUtils.d.ts +1 -0
  34. package/dist/components/messages/prismTwilightTheme.d.ts +2 -0
  35. package/dist/components/prompt/FavoritePromptList.d.ts +2 -0
  36. package/dist/components/prompt/PromptListItem.d.ts +8 -0
  37. package/dist/components/prompt/PromptListPanel.d.ts +6 -0
  38. package/dist/components/scroll-area/ScrollArea.d.ts +33 -0
  39. package/dist/components/shared/Icon.d.ts +8 -0
  40. package/dist/components/shared/IconButton.d.ts +11 -0
  41. package/dist/components/shared/Modal.d.ts +12 -0
  42. package/dist/components/shared/SearchInput.d.ts +8 -0
  43. package/dist/components/shared/ToggleInput.d.ts +8 -0
  44. package/dist/components/shared/Tooltip.d.ts +10 -0
  45. package/dist/components/shared/icons.d.ts +37 -0
  46. package/dist/components/threads/ThreadHistory.d.ts +6 -0
  47. package/dist/components/threads/ThreadHistoryListItem.d.ts +18 -0
  48. package/dist/components/threads/ThreadHistoryPanel.d.ts +7 -0
  49. package/dist/components/tool/ToolListItem.d.ts +8 -0
  50. package/dist/components/tool/ToolListPanel.d.ts +2 -0
  51. package/dist/components/working-context-panel/WorkingContextPanel.d.ts +2 -0
  52. package/dist/constants/modalActions.d.ts +11 -0
  53. package/dist/constants/uiStrings.d.ts +141 -0
  54. package/dist/context/IoAssistContext.d.ts +14 -0
  55. package/dist/files/inter-latin-wght-normal.woff2 +0 -0
  56. package/dist/hooks/useHoverMouseFollow.d.ts +27 -0
  57. package/dist/hooks/useIoAiWebApi.d.ts +19 -0
  58. package/dist/hooks/useIoAiWebBootstrap.d.ts +8 -0
  59. package/dist/hooks/useIoConnectApi.d.ts +12 -0
  60. package/dist/hooks/useIoConnectBootstrap.d.ts +10 -0
  61. package/dist/hooks/useIsMobileViewport.d.ts +1 -0
  62. package/dist/index.cjs +41 -0
  63. package/dist/index.cjs.map +1 -0
  64. package/dist/index.d.ts +2 -0
  65. package/dist/index.js +3624 -0
  66. package/dist/index.js.map +1 -0
  67. package/dist/stores/agent.d.ts +15 -0
  68. package/dist/stores/app-lifecycle.d.ts +21 -0
  69. package/dist/stores/confirm-modal.d.ts +29 -0
  70. package/dist/stores/index.d.ts +32 -0
  71. package/dist/stores/mcp-apps.d.ts +13 -0
  72. package/dist/stores/message.d.ts +33 -0
  73. package/dist/stores/prompt.d.ts +16 -0
  74. package/dist/stores/response-stream.d.ts +31 -0
  75. package/dist/stores/thread.d.ts +17 -0
  76. package/dist/stores/tool.d.ts +15 -0
  77. package/dist/stores/working-context.d.ts +16 -0
  78. package/dist/styles.css +1 -0
  79. package/dist/types/agent.d.ts +8 -0
  80. package/dist/types/config.d.ts +40 -0
  81. package/dist/types/icon.d.ts +5 -0
  82. package/dist/types/index.d.ts +15 -0
  83. package/dist/types/loading.d.ts +38 -0
  84. package/dist/types/message.d.ts +56 -0
  85. package/dist/types/panel.d.ts +6 -0
  86. package/dist/types/prompt.d.ts +17 -0
  87. package/dist/types/stream.d.ts +22 -0
  88. package/dist/types/thread.d.ts +15 -0
  89. package/dist/types/tool.d.ts +15 -0
  90. package/dist/utils/confirmModal.d.ts +5 -0
  91. package/dist/utils/ioModals.d.ts +21 -0
  92. package/dist/utils/logger.d.ts +34 -0
  93. package/dist/utils/mcpAppModal.d.ts +3 -0
  94. package/dist/utils/messageConverter.d.ts +3 -0
  95. package/dist/utils/messageUtils.d.ts +16 -0
  96. package/dist/utils/safeStringify.d.ts +1 -0
  97. package/dist/utils/streamUtils.d.ts +15 -0
  98. package/dist/utils/threadUtils.d.ts +16 -0
  99. 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>;
@@ -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,8 @@
1
+ import { IoAiWeb } from '@interopio/ai-web';
2
+ export type UIAgent = {
3
+ id: string;
4
+ name: string;
5
+ description?: string;
6
+ modelId?: string;
7
+ rawAgent: IoAiWeb.Agents.Agent;
8
+ };
@@ -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,5 @@
1
+ export type IconType = 'svg' | 'url' | 'data-url';
2
+ export type IconResource = {
3
+ type: IconType;
4
+ data: string;
5
+ };
@@ -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,6 @@
1
+ export declare const PANEL_CONTENT: {
2
+ readonly WORKING_CONTEXT: "working-context";
3
+ readonly PROMPTS: "prompts";
4
+ readonly TOOLS: "tools";
5
+ };
6
+ export type PanelContent = (typeof PANEL_CONTENT)[keyof typeof PANEL_CONTENT] | null;
@@ -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>;