@assistant-ui/react-ink 0.0.1 → 0.0.4
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/LICENSE +21 -0
- package/README.md +86 -0
- package/dist/context/AssistantContext.d.ts +1 -7
- package/dist/context/AssistantContext.d.ts.map +1 -1
- package/dist/context/AssistantContext.js +1 -15
- package/dist/context/AssistantContext.js.map +1 -1
- package/dist/context/index.d.ts +1 -1
- package/dist/context/index.d.ts.map +1 -1
- package/dist/context/index.js +1 -1
- package/dist/context/index.js.map +1 -1
- package/dist/index.d.ts +13 -14
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +13 -16
- package/dist/index.js.map +1 -1
- package/dist/primitives/actionBar/ActionBarCopy.d.ts +1 -1
- package/dist/primitives/actionBar/ActionBarCopy.d.ts.map +1 -1
- package/dist/primitives/actionBar/ActionBarCopy.js +1 -1
- package/dist/primitives/actionBar/ActionBarCopy.js.map +1 -1
- package/dist/primitives/actionBar/ActionBarEdit.js +1 -1
- package/dist/primitives/actionBar/ActionBarEdit.js.map +1 -1
- package/dist/primitives/actionBar/ActionBarFeedbackNegative.js +1 -1
- package/dist/primitives/actionBar/ActionBarFeedbackNegative.js.map +1 -1
- package/dist/primitives/actionBar/ActionBarFeedbackPositive.js +1 -1
- package/dist/primitives/actionBar/ActionBarFeedbackPositive.js.map +1 -1
- package/dist/primitives/actionBar/ActionBarReload.js +1 -1
- package/dist/primitives/actionBar/ActionBarReload.js.map +1 -1
- package/dist/primitives/actionBar/index.d.ts +5 -5
- package/dist/primitives/actionBar/index.d.ts.map +1 -1
- package/dist/primitives/actionBar/index.js +5 -5
- package/dist/primitives/actionBar/index.js.map +1 -1
- package/dist/primitives/attachment/index.d.ts +4 -4
- package/dist/primitives/attachment/index.d.ts.map +1 -1
- package/dist/primitives/attachment/index.js +4 -4
- package/dist/primitives/attachment/index.js.map +1 -1
- package/dist/primitives/branchPicker/index.d.ts +4 -4
- package/dist/primitives/branchPicker/index.d.ts.map +1 -1
- package/dist/primitives/branchPicker/index.js +4 -4
- package/dist/primitives/branchPicker/index.js.map +1 -1
- package/dist/primitives/chainOfThought/index.d.ts +3 -3
- package/dist/primitives/chainOfThought/index.d.ts.map +1 -1
- package/dist/primitives/chainOfThought/index.js +3 -3
- package/dist/primitives/chainOfThought/index.js.map +1 -1
- package/dist/primitives/composer/ComposerAddAttachment.d.ts.map +1 -1
- package/dist/primitives/composer/ComposerAddAttachment.js +3 -5
- package/dist/primitives/composer/ComposerAddAttachment.js.map +1 -1
- package/dist/primitives/composer/ComposerCancel.js +3 -3
- package/dist/primitives/composer/ComposerCancel.js.map +1 -1
- package/dist/primitives/composer/ComposerSend.js +3 -3
- package/dist/primitives/composer/ComposerSend.js.map +1 -1
- package/dist/primitives/composer/index.d.ts +7 -10
- package/dist/primitives/composer/index.d.ts.map +1 -1
- package/dist/primitives/composer/index.js +7 -10
- package/dist/primitives/composer/index.js.map +1 -1
- package/dist/primitives/message/MessageContent.d.ts.map +1 -1
- package/dist/primitives/message/MessageContent.js +9 -3
- package/dist/primitives/message/MessageContent.js.map +1 -1
- package/dist/primitives/message/index.d.ts +5 -5
- package/dist/primitives/message/index.d.ts.map +1 -1
- package/dist/primitives/message/index.js +5 -5
- package/dist/primitives/message/index.js.map +1 -1
- package/dist/primitives/suggestion/index.d.ts +3 -3
- package/dist/primitives/suggestion/index.d.ts.map +1 -1
- package/dist/primitives/suggestion/index.js +3 -3
- package/dist/primitives/suggestion/index.js.map +1 -1
- package/dist/primitives/thread/ThreadEmpty.js +1 -1
- package/dist/primitives/thread/ThreadEmpty.js.map +1 -1
- package/dist/primitives/thread/ThreadMessages.d.ts +23 -7
- package/dist/primitives/thread/ThreadMessages.d.ts.map +1 -1
- package/dist/primitives/thread/ThreadMessages.js +67 -13
- package/dist/primitives/thread/ThreadMessages.js.map +1 -1
- package/dist/primitives/thread/index.d.ts +7 -7
- package/dist/primitives/thread/index.d.ts.map +1 -1
- package/dist/primitives/thread/index.js +7 -7
- package/dist/primitives/thread/index.js.map +1 -1
- package/dist/primitives/threadList/index.d.ts +3 -3
- package/dist/primitives/threadList/index.d.ts.map +1 -1
- package/dist/primitives/threadList/index.js +3 -3
- package/dist/primitives/threadList/index.js.map +1 -1
- package/dist/primitives/threadListItem/index.d.ts +6 -6
- package/dist/primitives/threadListItem/index.d.ts.map +1 -1
- package/dist/primitives/threadListItem/index.js +6 -6
- package/dist/primitives/threadListItem/index.js.map +1 -1
- package/dist/primitives/toolCall/ToolFallback.d.ts +33 -0
- package/dist/primitives/toolCall/ToolFallback.d.ts.map +1 -0
- package/dist/primitives/toolCall/ToolFallback.js +103 -0
- package/dist/primitives/toolCall/ToolFallback.js.map +1 -0
- package/dist/primitives/toolCall/index.d.ts +2 -0
- package/dist/primitives/toolCall/index.d.ts.map +1 -0
- package/dist/primitives/toolCall/index.js +2 -0
- package/dist/primitives/toolCall/index.js.map +1 -0
- package/dist/runtimes/RemoteThreadListHookInstanceManager.d.ts +1 -95
- package/dist/runtimes/RemoteThreadListHookInstanceManager.d.ts.map +1 -1
- package/dist/runtimes/RemoteThreadListHookInstanceManager.js +1 -109
- package/dist/runtimes/RemoteThreadListHookInstanceManager.js.map +1 -1
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.d.ts +1 -112
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.d.ts.map +1 -1
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.js +1 -439
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.js.map +1 -1
- package/dist/runtimes/useLocalRuntime.d.ts +1 -17
- package/dist/runtimes/useLocalRuntime.d.ts.map +1 -1
- package/dist/runtimes/useLocalRuntime.js +1 -61
- package/dist/runtimes/useLocalRuntime.js.map +1 -1
- package/dist/runtimes/useRemoteThreadListRuntime.d.ts +1 -3
- package/dist/runtimes/useRemoteThreadListRuntime.d.ts.map +1 -1
- package/dist/runtimes/useRemoteThreadListRuntime.js +1 -46
- package/dist/runtimes/useRemoteThreadListRuntime.js.map +1 -1
- package/package.json +13 -11
- package/src/context/AssistantContext.tsx +4 -31
- package/src/context/index.ts +4 -1
- package/src/index.ts +13 -39
- package/src/primitives/actionBar/ActionBarCopy.tsx +1 -1
- package/src/primitives/actionBar/ActionBarEdit.tsx +1 -1
- package/src/primitives/actionBar/ActionBarFeedbackNegative.tsx +1 -1
- package/src/primitives/actionBar/ActionBarFeedbackPositive.tsx +1 -1
- package/src/primitives/actionBar/ActionBarReload.tsx +1 -1
- package/src/primitives/actionBar/index.ts +16 -7
- package/src/primitives/attachment/index.ts +14 -5
- package/src/primitives/branchPicker/index.ts +8 -8
- package/src/primitives/chainOfThought/index.ts +5 -5
- package/src/primitives/composer/ComposerAddAttachment.tsx +3 -5
- package/src/primitives/composer/ComposerCancel.tsx +3 -3
- package/src/primitives/composer/ComposerSend.tsx +3 -3
- package/src/primitives/composer/index.ts +19 -19
- package/src/primitives/message/MessageContent.test.tsx +83 -0
- package/src/primitives/message/MessageContent.tsx +21 -15
- package/src/primitives/message/index.ts +13 -7
- package/src/primitives/suggestion/index.ts +6 -6
- package/src/primitives/thread/ThreadEmpty.tsx +1 -1
- package/src/primitives/thread/ThreadMessages.tsx +122 -27
- package/src/primitives/thread/index.ts +17 -11
- package/src/primitives/threadList/index.ts +12 -3
- package/src/primitives/threadListItem/index.ts +11 -11
- package/src/primitives/toolCall/ToolFallback.test.tsx +40 -0
- package/src/primitives/toolCall/ToolFallback.tsx +227 -0
- package/src/primitives/toolCall/index.ts +5 -0
- package/src/runtimes/RemoteThreadListHookInstanceManager.tsx +1 -180
- package/src/runtimes/RemoteThreadListThreadListRuntimeCore.tsx +1 -538
- package/src/runtimes/useLocalRuntime.ts +4 -105
- package/src/runtimes/useRemoteThreadListRuntime.ts +1 -80
- package/dist/adapters/LocalStorageThreadListAdapter.d.ts +0 -15
- package/dist/adapters/LocalStorageThreadListAdapter.d.ts.map +0 -1
- package/dist/adapters/LocalStorageThreadListAdapter.js +0 -154
- package/dist/adapters/LocalStorageThreadListAdapter.js.map +0 -1
- package/dist/adapters/TitleGenerationAdapter.d.ts +0 -6
- package/dist/adapters/TitleGenerationAdapter.d.ts.map +0 -1
- package/dist/adapters/TitleGenerationAdapter.js +0 -15
- package/dist/adapters/TitleGenerationAdapter.js.map +0 -1
- package/dist/adapters/index.d.ts +0 -3
- package/dist/adapters/index.d.ts.map +0 -1
- package/dist/adapters/index.js +0 -3
- package/dist/adapters/index.js.map +0 -1
- package/dist/primitive-hooks/index.d.ts +0 -15
- package/dist/primitive-hooks/index.d.ts.map +0 -1
- package/dist/primitive-hooks/index.js +0 -15
- package/dist/primitive-hooks/index.js.map +0 -1
- package/dist/primitive-hooks/useActionBarCopy.d.ts +0 -10
- package/dist/primitive-hooks/useActionBarCopy.d.ts.map +0 -1
- package/dist/primitive-hooks/useActionBarCopy.js +0 -26
- package/dist/primitive-hooks/useActionBarCopy.js.map +0 -1
- package/dist/primitive-hooks/useActionBarEdit.d.ts +0 -5
- package/dist/primitive-hooks/useActionBarEdit.d.ts.map +0 -1
- package/dist/primitive-hooks/useActionBarEdit.js +0 -11
- package/dist/primitive-hooks/useActionBarEdit.js.map +0 -1
- package/dist/primitive-hooks/useActionBarFeedback.d.ts +0 -9
- package/dist/primitive-hooks/useActionBarFeedback.d.ts.map +0 -1
- package/dist/primitive-hooks/useActionBarFeedback.js +0 -19
- package/dist/primitive-hooks/useActionBarFeedback.js.map +0 -1
- package/dist/primitive-hooks/useActionBarReload.d.ts +0 -5
- package/dist/primitive-hooks/useActionBarReload.d.ts.map +0 -1
- package/dist/primitive-hooks/useActionBarReload.js +0 -13
- package/dist/primitive-hooks/useActionBarReload.js.map +0 -1
- package/dist/primitive-hooks/useComposerAddAttachment.d.ts +0 -5
- package/dist/primitive-hooks/useComposerAddAttachment.d.ts.map +0 -1
- package/dist/primitive-hooks/useComposerAddAttachment.js +0 -10
- package/dist/primitive-hooks/useComposerAddAttachment.js.map +0 -1
- package/dist/primitive-hooks/useComposerCancel.d.ts +0 -5
- package/dist/primitive-hooks/useComposerCancel.d.ts.map +0 -1
- package/dist/primitive-hooks/useComposerCancel.js +0 -11
- package/dist/primitive-hooks/useComposerCancel.js.map +0 -1
- package/dist/primitive-hooks/useComposerSend.d.ts +0 -5
- package/dist/primitive-hooks/useComposerSend.d.ts.map +0 -1
- package/dist/primitive-hooks/useComposerSend.js +0 -11
- package/dist/primitive-hooks/useComposerSend.js.map +0 -1
- package/dist/primitive-hooks/useEditComposerCancel.d.ts +0 -4
- package/dist/primitive-hooks/useEditComposerCancel.d.ts.map +0 -1
- package/dist/primitive-hooks/useEditComposerCancel.js +0 -10
- package/dist/primitive-hooks/useEditComposerCancel.js.map +0 -1
- package/dist/primitive-hooks/useEditComposerSend.d.ts +0 -5
- package/dist/primitive-hooks/useEditComposerSend.d.ts.map +0 -1
- package/dist/primitive-hooks/useEditComposerSend.js +0 -11
- package/dist/primitive-hooks/useEditComposerSend.js.map +0 -1
- package/dist/primitive-hooks/useMessageBranching.d.ts +0 -7
- package/dist/primitive-hooks/useMessageBranching.d.ts.map +0 -1
- package/dist/primitive-hooks/useMessageBranching.js +0 -15
- package/dist/primitive-hooks/useMessageBranching.js.map +0 -1
- package/dist/primitive-hooks/useMessageReload.d.ts +0 -5
- package/dist/primitive-hooks/useMessageReload.d.ts.map +0 -1
- package/dist/primitive-hooks/useMessageReload.js +0 -11
- package/dist/primitive-hooks/useMessageReload.js.map +0 -1
- package/dist/primitive-hooks/useThreadIsEmpty.d.ts +0 -2
- package/dist/primitive-hooks/useThreadIsEmpty.d.ts.map +0 -1
- package/dist/primitive-hooks/useThreadIsEmpty.js +0 -5
- package/dist/primitive-hooks/useThreadIsEmpty.js.map +0 -1
- package/dist/primitive-hooks/useThreadIsRunning.d.ts +0 -2
- package/dist/primitive-hooks/useThreadIsRunning.d.ts.map +0 -1
- package/dist/primitive-hooks/useThreadIsRunning.js +0 -5
- package/dist/primitive-hooks/useThreadIsRunning.js.map +0 -1
- package/dist/primitive-hooks/useThreadMessages.d.ts +0 -3
- package/dist/primitive-hooks/useThreadMessages.d.ts.map +0 -1
- package/dist/primitive-hooks/useThreadMessages.js +0 -5
- package/dist/primitive-hooks/useThreadMessages.js.map +0 -1
- package/dist/primitives/composer/EditComposerCancel.d.ts +0 -7
- package/dist/primitives/composer/EditComposerCancel.d.ts.map +0 -1
- package/dist/primitives/composer/EditComposerCancel.js +0 -8
- package/dist/primitives/composer/EditComposerCancel.js.map +0 -1
- package/dist/primitives/composer/EditComposerInput.d.ts +0 -10
- package/dist/primitives/composer/EditComposerInput.d.ts.map +0 -1
- package/dist/primitives/composer/EditComposerInput.js +0 -19
- package/dist/primitives/composer/EditComposerInput.js.map +0 -1
- package/dist/primitives/composer/EditComposerSend.d.ts +0 -7
- package/dist/primitives/composer/EditComposerSend.d.ts.map +0 -1
- package/dist/primitives/composer/EditComposerSend.js +0 -8
- package/dist/primitives/composer/EditComposerSend.js.map +0 -1
- package/src/adapters/LocalStorageThreadListAdapter.tsx +0 -227
- package/src/adapters/TitleGenerationAdapter.ts +0 -20
- package/src/adapters/index.ts +0 -5
- package/src/primitive-hooks/index.ts +0 -20
- package/src/primitive-hooks/useActionBarCopy.ts +0 -38
- package/src/primitive-hooks/useActionBarEdit.ts +0 -13
- package/src/primitive-hooks/useActionBarFeedback.ts +0 -28
- package/src/primitive-hooks/useActionBarReload.ts +0 -18
- package/src/primitive-hooks/useComposerAddAttachment.ts +0 -16
- package/src/primitive-hooks/useComposerCancel.ts +0 -13
- package/src/primitive-hooks/useComposerSend.ts +0 -13
- package/src/primitive-hooks/useEditComposerCancel.ts +0 -12
- package/src/primitive-hooks/useEditComposerSend.ts +0 -13
- package/src/primitive-hooks/useMessageBranching.ts +0 -18
- package/src/primitive-hooks/useMessageReload.ts +0 -13
- package/src/primitive-hooks/useThreadIsEmpty.ts +0 -5
- package/src/primitive-hooks/useThreadIsRunning.ts +0 -5
- package/src/primitive-hooks/useThreadMessages.ts +0 -6
- package/src/primitives/composer/EditComposerCancel.tsx +0 -20
- package/src/primitives/composer/EditComposerInput.tsx +0 -40
- package/src/primitives/composer/EditComposerSend.tsx +0 -25
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export type UseActionBarCopyOptions = {
|
|
5
|
-
copiedDuration?: number | undefined;
|
|
6
|
-
copyToClipboard?: ((text: string) => void | Promise<void>) | undefined;
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export const useActionBarCopy = ({
|
|
10
|
-
copiedDuration = 3000,
|
|
11
|
-
copyToClipboard,
|
|
12
|
-
}: UseActionBarCopyOptions = {}) => {
|
|
13
|
-
const aui = useAui();
|
|
14
|
-
const disabled = useAuiState((s) => {
|
|
15
|
-
return !(
|
|
16
|
-
(s.message.role !== "assistant" ||
|
|
17
|
-
s.message.status?.type !== "running") &&
|
|
18
|
-
s.message.parts.some((c) => c.type === "text" && c.text.length > 0)
|
|
19
|
-
);
|
|
20
|
-
});
|
|
21
|
-
const isCopied = useAuiState((s) => s.message.isCopied);
|
|
22
|
-
const isEditing = useAuiState((s) => s.composer.isEditing);
|
|
23
|
-
const composerValue = useAuiState((s) => s.composer.text);
|
|
24
|
-
|
|
25
|
-
const copy = useCallback(() => {
|
|
26
|
-
const valueToCopy = isEditing ? composerValue : aui.message().getCopyText();
|
|
27
|
-
if (!valueToCopy) return;
|
|
28
|
-
|
|
29
|
-
const write = copyToClipboard ?? (() => {});
|
|
30
|
-
const result = write(valueToCopy);
|
|
31
|
-
Promise.resolve(result).then(() => {
|
|
32
|
-
aui.message().setIsCopied(true);
|
|
33
|
-
setTimeout(() => aui.message().setIsCopied(false), copiedDuration);
|
|
34
|
-
});
|
|
35
|
-
}, [aui, isEditing, composerValue, copiedDuration, copyToClipboard]);
|
|
36
|
-
|
|
37
|
-
return { copy, disabled, isCopied };
|
|
38
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useActionBarEdit = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const disabled = useAuiState((s) => s.composer.isEditing);
|
|
7
|
-
|
|
8
|
-
const edit = useCallback(() => {
|
|
9
|
-
aui.composer().beginEdit();
|
|
10
|
-
}, [aui]);
|
|
11
|
-
|
|
12
|
-
return { edit, disabled };
|
|
13
|
-
};
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useActionBarFeedbackPositive = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const isSubmitted = useAuiState(
|
|
7
|
-
(s) => s.message.metadata.submittedFeedback?.type === "positive",
|
|
8
|
-
);
|
|
9
|
-
|
|
10
|
-
const submit = useCallback(() => {
|
|
11
|
-
aui.message().submitFeedback({ type: "positive" });
|
|
12
|
-
}, [aui]);
|
|
13
|
-
|
|
14
|
-
return { submit, isSubmitted };
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
export const useActionBarFeedbackNegative = () => {
|
|
18
|
-
const aui = useAui();
|
|
19
|
-
const isSubmitted = useAuiState(
|
|
20
|
-
(s) => s.message.metadata.submittedFeedback?.type === "negative",
|
|
21
|
-
);
|
|
22
|
-
|
|
23
|
-
const submit = useCallback(() => {
|
|
24
|
-
aui.message().submitFeedback({ type: "negative" });
|
|
25
|
-
}, [aui]);
|
|
26
|
-
|
|
27
|
-
return { submit, isSubmitted };
|
|
28
|
-
};
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useActionBarReload = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const disabled = useAuiState(
|
|
7
|
-
(s) =>
|
|
8
|
-
s.thread.isRunning ||
|
|
9
|
-
s.thread.isDisabled ||
|
|
10
|
-
s.message.role !== "assistant",
|
|
11
|
-
);
|
|
12
|
-
|
|
13
|
-
const reload = useCallback(() => {
|
|
14
|
-
aui.message().reload();
|
|
15
|
-
}, [aui]);
|
|
16
|
-
|
|
17
|
-
return { reload, disabled };
|
|
18
|
-
};
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui } from "@assistant-ui/store";
|
|
3
|
-
import type { CreateAttachment } from "@assistant-ui/core";
|
|
4
|
-
|
|
5
|
-
export const useComposerAddAttachment = () => {
|
|
6
|
-
const aui = useAui();
|
|
7
|
-
|
|
8
|
-
const addAttachment = useCallback(
|
|
9
|
-
(file: File | CreateAttachment) => {
|
|
10
|
-
return aui.composer().addAttachment(file);
|
|
11
|
-
},
|
|
12
|
-
[aui],
|
|
13
|
-
);
|
|
14
|
-
|
|
15
|
-
return { addAttachment };
|
|
16
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useComposerCancel = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const canCancel = useAuiState((s) => s.thread.isRunning);
|
|
7
|
-
|
|
8
|
-
const cancel = useCallback(() => {
|
|
9
|
-
aui.threads().thread("main").cancelRun();
|
|
10
|
-
}, [aui]);
|
|
11
|
-
|
|
12
|
-
return { cancel, canCancel };
|
|
13
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useComposerSend = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const canSend = useAuiState((s) => !s.composer.isEmpty);
|
|
7
|
-
|
|
8
|
-
const send = useCallback(() => {
|
|
9
|
-
aui.composer().send();
|
|
10
|
-
}, [aui]);
|
|
11
|
-
|
|
12
|
-
return { send, canSend };
|
|
13
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useEditComposerCancel = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
|
|
7
|
-
const cancel = useCallback(() => {
|
|
8
|
-
aui.composer().cancel();
|
|
9
|
-
}, [aui]);
|
|
10
|
-
|
|
11
|
-
return { cancel };
|
|
12
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useEditComposerSend = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const disabled = useAuiState((s) => s.composer.isEmpty);
|
|
7
|
-
|
|
8
|
-
const send = useCallback(() => {
|
|
9
|
-
aui.composer().send();
|
|
10
|
-
}, [aui]);
|
|
11
|
-
|
|
12
|
-
return { send, disabled };
|
|
13
|
-
};
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useMessageBranching = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const branchNumber = useAuiState((s) => s.message.branchNumber);
|
|
7
|
-
const branchCount = useAuiState((s) => s.message.branchCount);
|
|
8
|
-
|
|
9
|
-
const goToPrev = useCallback(() => {
|
|
10
|
-
aui.message().switchToBranch({ position: "previous" });
|
|
11
|
-
}, [aui]);
|
|
12
|
-
|
|
13
|
-
const goToNext = useCallback(() => {
|
|
14
|
-
aui.message().switchToBranch({ position: "next" });
|
|
15
|
-
}, [aui]);
|
|
16
|
-
|
|
17
|
-
return { branchNumber, branchCount, goToPrev, goToNext };
|
|
18
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { useCallback } from "react";
|
|
2
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
3
|
-
|
|
4
|
-
export const useMessageReload = () => {
|
|
5
|
-
const aui = useAui();
|
|
6
|
-
const canReload = useAuiState((s) => s.message.role === "assistant");
|
|
7
|
-
|
|
8
|
-
const reload = useCallback(() => {
|
|
9
|
-
aui.message().reload();
|
|
10
|
-
}, [aui]);
|
|
11
|
-
|
|
12
|
-
return { reload, canReload };
|
|
13
|
-
};
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import type { ReactNode } from "react";
|
|
2
|
-
import { useEditComposerCancel } from "../../primitive-hooks/useEditComposerCancel";
|
|
3
|
-
import { Pressable, type PressableProps } from "../internal/Pressable";
|
|
4
|
-
|
|
5
|
-
export type EditComposerCancelProps = Omit<PressableProps, "onPress"> & {
|
|
6
|
-
children: ReactNode;
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export const EditComposerCancel = ({
|
|
10
|
-
children,
|
|
11
|
-
...pressableProps
|
|
12
|
-
}: EditComposerCancelProps) => {
|
|
13
|
-
const { cancel } = useEditComposerCancel();
|
|
14
|
-
|
|
15
|
-
return (
|
|
16
|
-
<Pressable onPress={cancel} {...pressableProps}>
|
|
17
|
-
{children}
|
|
18
|
-
</Pressable>
|
|
19
|
-
);
|
|
20
|
-
};
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import type { ComponentProps } from "react";
|
|
2
|
-
import { Box, Text, useFocus, useInput } from "ink";
|
|
3
|
-
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
4
|
-
|
|
5
|
-
export type EditComposerInputProps = ComponentProps<typeof Box> & {
|
|
6
|
-
/** Placeholder text shown when the input is empty. */
|
|
7
|
-
placeholder?: string | undefined;
|
|
8
|
-
/** Whether this input should receive focus automatically. @default true */
|
|
9
|
-
autoFocus?: boolean | undefined;
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
export const EditComposerInput = ({
|
|
13
|
-
placeholder = "",
|
|
14
|
-
autoFocus = true,
|
|
15
|
-
...boxProps
|
|
16
|
-
}: EditComposerInputProps) => {
|
|
17
|
-
const aui = useAui();
|
|
18
|
-
const text = useAuiState((s) => s.composer.text);
|
|
19
|
-
const { isFocused } = useFocus({ autoFocus });
|
|
20
|
-
|
|
21
|
-
useInput(
|
|
22
|
-
(input, key) => {
|
|
23
|
-
if (key.backspace || key.delete) {
|
|
24
|
-
aui.composer().setText(text.slice(0, -1));
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
if (input && !key.ctrl && !key.meta && !key.return) {
|
|
28
|
-
aui.composer().setText(text + input);
|
|
29
|
-
}
|
|
30
|
-
},
|
|
31
|
-
{ isActive: isFocused },
|
|
32
|
-
);
|
|
33
|
-
|
|
34
|
-
return (
|
|
35
|
-
<Box {...boxProps}>
|
|
36
|
-
<Text dimColor={!text && !!placeholder}>{text || placeholder}</Text>
|
|
37
|
-
{isFocused && <Text>▋</Text>}
|
|
38
|
-
</Box>
|
|
39
|
-
);
|
|
40
|
-
};
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import type { ReactNode } from "react";
|
|
2
|
-
import { useEditComposerSend } from "../../primitive-hooks/useEditComposerSend";
|
|
3
|
-
import { Pressable, type PressableProps } from "../internal/Pressable";
|
|
4
|
-
|
|
5
|
-
export type EditComposerSendProps = Omit<PressableProps, "onPress"> & {
|
|
6
|
-
children: ReactNode;
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export const EditComposerSend = ({
|
|
10
|
-
children,
|
|
11
|
-
disabled: disabledProp,
|
|
12
|
-
...pressableProps
|
|
13
|
-
}: EditComposerSendProps) => {
|
|
14
|
-
const { send, disabled } = useEditComposerSend();
|
|
15
|
-
|
|
16
|
-
return (
|
|
17
|
-
<Pressable
|
|
18
|
-
onPress={send}
|
|
19
|
-
disabled={disabledProp ?? disabled}
|
|
20
|
-
{...pressableProps}
|
|
21
|
-
>
|
|
22
|
-
{children}
|
|
23
|
-
</Pressable>
|
|
24
|
-
);
|
|
25
|
-
};
|