@assistant-ui/react-native 0.1.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.md +29 -0
- package/dist/adapters/LocalStorageThreadListAdapter.d.ts +15 -0
- package/dist/adapters/LocalStorageThreadListAdapter.d.ts.map +1 -0
- package/dist/adapters/LocalStorageThreadListAdapter.js +154 -0
- package/dist/adapters/LocalStorageThreadListAdapter.js.map +1 -0
- package/dist/adapters/TitleGenerationAdapter.d.ts +6 -0
- package/dist/adapters/TitleGenerationAdapter.d.ts.map +1 -0
- package/dist/adapters/TitleGenerationAdapter.js +15 -0
- package/dist/adapters/TitleGenerationAdapter.js.map +1 -0
- package/dist/adapters/index.d.ts +3 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +3 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/context/AssistantContext.d.ts +8 -0
- package/dist/context/AssistantContext.d.ts.map +1 -0
- package/dist/context/AssistantContext.js +21 -0
- package/dist/context/AssistantContext.js.map +1 -0
- package/dist/context/index.d.ts +2 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +2 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context/providers/RuntimeAdapterProvider.d.ts +15 -0
- package/dist/context/providers/RuntimeAdapterProvider.d.ts.map +1 -0
- package/dist/context/providers/RuntimeAdapterProvider.js +14 -0
- package/dist/context/providers/RuntimeAdapterProvider.js.map +1 -0
- package/dist/context/providers/ThreadListItemRuntimeProvider.d.ts +6 -0
- package/dist/context/providers/ThreadListItemRuntimeProvider.d.ts.map +1 -0
- package/dist/context/providers/ThreadListItemRuntimeProvider.js +10 -0
- package/dist/context/providers/ThreadListItemRuntimeProvider.js.map +1 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +6 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useComposer.d.ts +4 -0
- package/dist/hooks/useComposer.d.ts.map +1 -0
- package/dist/hooks/useComposer.js +5 -0
- package/dist/hooks/useComposer.js.map +1 -0
- package/dist/hooks/useContentPart.d.ts +2 -0
- package/dist/hooks/useContentPart.d.ts.map +1 -0
- package/dist/hooks/useContentPart.js +5 -0
- package/dist/hooks/useContentPart.js.map +1 -0
- package/dist/hooks/useMessage.d.ts +4 -0
- package/dist/hooks/useMessage.d.ts.map +1 -0
- package/dist/hooks/useMessage.js +5 -0
- package/dist/hooks/useMessage.js.map +1 -0
- package/dist/hooks/useThread.d.ts +4 -0
- package/dist/hooks/useThread.d.ts.map +1 -0
- package/dist/hooks/useThread.js +5 -0
- package/dist/hooks/useThread.js.map +1 -0
- package/dist/hooks/useThreadList.d.ts +4 -0
- package/dist/hooks/useThreadList.d.ts.map +1 -0
- package/dist/hooks/useThreadList.js +5 -0
- package/dist/hooks/useThreadList.js.map +1 -0
- package/dist/index.d.ts +17 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/dist/internal.d.ts +4 -0
- package/dist/internal.d.ts.map +1 -0
- package/dist/internal.js +3 -0
- package/dist/internal.js.map +1 -0
- package/dist/primitive-hooks/index.d.ts +14 -0
- package/dist/primitive-hooks/index.d.ts.map +1 -0
- package/dist/primitive-hooks/index.js +14 -0
- package/dist/primitive-hooks/index.js.map +1 -0
- package/dist/primitive-hooks/useActionBarCopy.d.ts +10 -0
- package/dist/primitive-hooks/useActionBarCopy.d.ts.map +1 -0
- package/dist/primitive-hooks/useActionBarCopy.js +26 -0
- package/dist/primitive-hooks/useActionBarCopy.js.map +1 -0
- package/dist/primitive-hooks/useActionBarEdit.d.ts +5 -0
- package/dist/primitive-hooks/useActionBarEdit.d.ts.map +1 -0
- package/dist/primitive-hooks/useActionBarEdit.js +11 -0
- package/dist/primitive-hooks/useActionBarEdit.js.map +1 -0
- package/dist/primitive-hooks/useActionBarFeedback.d.ts +9 -0
- package/dist/primitive-hooks/useActionBarFeedback.d.ts.map +1 -0
- package/dist/primitive-hooks/useActionBarFeedback.js +19 -0
- package/dist/primitive-hooks/useActionBarFeedback.js.map +1 -0
- package/dist/primitive-hooks/useActionBarReload.d.ts +5 -0
- package/dist/primitive-hooks/useActionBarReload.d.ts.map +1 -0
- package/dist/primitive-hooks/useActionBarReload.js +13 -0
- package/dist/primitive-hooks/useActionBarReload.js.map +1 -0
- package/dist/primitive-hooks/useComposerCancel.d.ts +5 -0
- package/dist/primitive-hooks/useComposerCancel.d.ts.map +1 -0
- package/dist/primitive-hooks/useComposerCancel.js +11 -0
- package/dist/primitive-hooks/useComposerCancel.js.map +1 -0
- package/dist/primitive-hooks/useComposerSend.d.ts +5 -0
- package/dist/primitive-hooks/useComposerSend.d.ts.map +1 -0
- package/dist/primitive-hooks/useComposerSend.js +11 -0
- package/dist/primitive-hooks/useComposerSend.js.map +1 -0
- package/dist/primitive-hooks/useEditComposerCancel.d.ts +4 -0
- package/dist/primitive-hooks/useEditComposerCancel.d.ts.map +1 -0
- package/dist/primitive-hooks/useEditComposerCancel.js +10 -0
- package/dist/primitive-hooks/useEditComposerCancel.js.map +1 -0
- package/dist/primitive-hooks/useEditComposerSend.d.ts +5 -0
- package/dist/primitive-hooks/useEditComposerSend.d.ts.map +1 -0
- package/dist/primitive-hooks/useEditComposerSend.js +11 -0
- package/dist/primitive-hooks/useEditComposerSend.js.map +1 -0
- package/dist/primitive-hooks/useMessageBranching.d.ts +7 -0
- package/dist/primitive-hooks/useMessageBranching.d.ts.map +1 -0
- package/dist/primitive-hooks/useMessageBranching.js +15 -0
- package/dist/primitive-hooks/useMessageBranching.js.map +1 -0
- package/dist/primitive-hooks/useMessageReload.d.ts +5 -0
- package/dist/primitive-hooks/useMessageReload.d.ts.map +1 -0
- package/dist/primitive-hooks/useMessageReload.js +11 -0
- package/dist/primitive-hooks/useMessageReload.js.map +1 -0
- package/dist/primitive-hooks/useThreadIsEmpty.d.ts +2 -0
- package/dist/primitive-hooks/useThreadIsEmpty.d.ts.map +1 -0
- package/dist/primitive-hooks/useThreadIsEmpty.js +5 -0
- package/dist/primitive-hooks/useThreadIsEmpty.js.map +1 -0
- package/dist/primitive-hooks/useThreadIsRunning.d.ts +2 -0
- package/dist/primitive-hooks/useThreadIsRunning.d.ts.map +1 -0
- package/dist/primitive-hooks/useThreadIsRunning.js +5 -0
- package/dist/primitive-hooks/useThreadIsRunning.js.map +1 -0
- package/dist/primitive-hooks/useThreadMessages.d.ts +3 -0
- package/dist/primitive-hooks/useThreadMessages.d.ts.map +1 -0
- package/dist/primitive-hooks/useThreadMessages.js +5 -0
- package/dist/primitive-hooks/useThreadMessages.js.map +1 -0
- package/dist/primitives/actionBar/ActionBarCopy.d.ts +10 -0
- package/dist/primitives/actionBar/ActionBarCopy.d.ts.map +1 -0
- package/dist/primitives/actionBar/ActionBarCopy.js +11 -0
- package/dist/primitives/actionBar/ActionBarCopy.js.map +1 -0
- package/dist/primitives/actionBar/ActionBarEdit.d.ts +7 -0
- package/dist/primitives/actionBar/ActionBarEdit.d.ts.map +1 -0
- package/dist/primitives/actionBar/ActionBarEdit.js +8 -0
- package/dist/primitives/actionBar/ActionBarEdit.js.map +1 -0
- package/dist/primitives/actionBar/ActionBarFeedbackNegative.d.ts +9 -0
- package/dist/primitives/actionBar/ActionBarFeedbackNegative.d.ts.map +1 -0
- package/dist/primitives/actionBar/ActionBarFeedbackNegative.js +8 -0
- package/dist/primitives/actionBar/ActionBarFeedbackNegative.js.map +1 -0
- package/dist/primitives/actionBar/ActionBarFeedbackPositive.d.ts +9 -0
- package/dist/primitives/actionBar/ActionBarFeedbackPositive.d.ts.map +1 -0
- package/dist/primitives/actionBar/ActionBarFeedbackPositive.js +8 -0
- package/dist/primitives/actionBar/ActionBarFeedbackPositive.js.map +1 -0
- package/dist/primitives/actionBar/ActionBarReload.d.ts +7 -0
- package/dist/primitives/actionBar/ActionBarReload.d.ts.map +1 -0
- package/dist/primitives/actionBar/ActionBarReload.js +8 -0
- package/dist/primitives/actionBar/ActionBarReload.js.map +1 -0
- package/dist/primitives/actionBar/index.d.ts +6 -0
- package/dist/primitives/actionBar/index.d.ts.map +1 -0
- package/dist/primitives/actionBar/index.js +6 -0
- package/dist/primitives/actionBar/index.js.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerCount.d.ts +4 -0
- package/dist/primitives/branchPicker/BranchPickerCount.d.ts.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerCount.js +8 -0
- package/dist/primitives/branchPicker/BranchPickerCount.js.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerNext.d.ts +7 -0
- package/dist/primitives/branchPicker/BranchPickerNext.d.ts.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerNext.js +20 -0
- package/dist/primitives/branchPicker/BranchPickerNext.js.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerNumber.d.ts +4 -0
- package/dist/primitives/branchPicker/BranchPickerNumber.d.ts.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerNumber.js +8 -0
- package/dist/primitives/branchPicker/BranchPickerNumber.js.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerPrevious.d.ts +7 -0
- package/dist/primitives/branchPicker/BranchPickerPrevious.d.ts.map +1 -0
- package/dist/primitives/branchPicker/BranchPickerPrevious.js +20 -0
- package/dist/primitives/branchPicker/BranchPickerPrevious.js.map +1 -0
- package/dist/primitives/branchPicker/index.d.ts +5 -0
- package/dist/primitives/branchPicker/index.d.ts.map +1 -0
- package/dist/primitives/branchPicker/index.js +5 -0
- package/dist/primitives/branchPicker/index.js.map +1 -0
- package/dist/primitives/composer/ComposerCancel.d.ts +7 -0
- package/dist/primitives/composer/ComposerCancel.d.ts.map +1 -0
- package/dist/primitives/composer/ComposerCancel.js +8 -0
- package/dist/primitives/composer/ComposerCancel.js.map +1 -0
- package/dist/primitives/composer/ComposerInput.d.ts +4 -0
- package/dist/primitives/composer/ComposerInput.d.ts.map +1 -0
- package/dist/primitives/composer/ComposerInput.js +13 -0
- package/dist/primitives/composer/ComposerInput.js.map +1 -0
- package/dist/primitives/composer/ComposerRoot.d.ts +7 -0
- package/dist/primitives/composer/ComposerRoot.d.ts.map +1 -0
- package/dist/primitives/composer/ComposerRoot.js +6 -0
- package/dist/primitives/composer/ComposerRoot.js.map +1 -0
- package/dist/primitives/composer/ComposerSend.d.ts +7 -0
- package/dist/primitives/composer/ComposerSend.d.ts.map +1 -0
- package/dist/primitives/composer/ComposerSend.js +8 -0
- package/dist/primitives/composer/ComposerSend.js.map +1 -0
- package/dist/primitives/composer/EditComposerCancel.d.ts +7 -0
- package/dist/primitives/composer/EditComposerCancel.d.ts.map +1 -0
- package/dist/primitives/composer/EditComposerCancel.js +8 -0
- package/dist/primitives/composer/EditComposerCancel.js.map +1 -0
- package/dist/primitives/composer/EditComposerInput.d.ts +4 -0
- package/dist/primitives/composer/EditComposerInput.d.ts.map +1 -0
- package/dist/primitives/composer/EditComposerInput.js +13 -0
- package/dist/primitives/composer/EditComposerInput.js.map +1 -0
- package/dist/primitives/composer/EditComposerSend.d.ts +7 -0
- package/dist/primitives/composer/EditComposerSend.d.ts.map +1 -0
- package/dist/primitives/composer/EditComposerSend.js +8 -0
- package/dist/primitives/composer/EditComposerSend.js.map +1 -0
- package/dist/primitives/composer/index.d.ts +8 -0
- package/dist/primitives/composer/index.d.ts.map +1 -0
- package/dist/primitives/composer/index.js +8 -0
- package/dist/primitives/composer/index.js.map +1 -0
- package/dist/primitives/message/MessageContent.d.ts +50 -0
- package/dist/primitives/message/MessageContent.d.ts.map +1 -0
- package/dist/primitives/message/MessageContent.js +44 -0
- package/dist/primitives/message/MessageContent.js.map +1 -0
- package/dist/primitives/message/MessageIf.d.ts +10 -0
- package/dist/primitives/message/MessageIf.d.ts.map +1 -0
- package/dist/primitives/message/MessageIf.js +24 -0
- package/dist/primitives/message/MessageIf.js.map +1 -0
- package/dist/primitives/message/MessageRoot.d.ts +7 -0
- package/dist/primitives/message/MessageRoot.d.ts.map +1 -0
- package/dist/primitives/message/MessageRoot.js +6 -0
- package/dist/primitives/message/MessageRoot.js.map +1 -0
- package/dist/primitives/message/index.d.ts +4 -0
- package/dist/primitives/message/index.d.ts.map +1 -0
- package/dist/primitives/message/index.js +4 -0
- package/dist/primitives/message/index.js.map +1 -0
- package/dist/primitives/thread/ThreadEmpty.d.ts +6 -0
- package/dist/primitives/thread/ThreadEmpty.d.ts.map +1 -0
- package/dist/primitives/thread/ThreadEmpty.js +9 -0
- package/dist/primitives/thread/ThreadEmpty.js.map +1 -0
- package/dist/primitives/thread/ThreadIf.d.ts +8 -0
- package/dist/primitives/thread/ThreadIf.d.ts.map +1 -0
- package/dist/primitives/thread/ThreadIf.js +16 -0
- package/dist/primitives/thread/ThreadIf.js.map +1 -0
- package/dist/primitives/thread/ThreadMessages.d.ts +11 -0
- package/dist/primitives/thread/ThreadMessages.d.ts.map +1 -0
- package/dist/primitives/thread/ThreadMessages.js +23 -0
- package/dist/primitives/thread/ThreadMessages.js.map +1 -0
- package/dist/primitives/thread/ThreadRoot.d.ts +7 -0
- package/dist/primitives/thread/ThreadRoot.d.ts.map +1 -0
- package/dist/primitives/thread/ThreadRoot.js +6 -0
- package/dist/primitives/thread/ThreadRoot.js.map +1 -0
- package/dist/primitives/thread/index.d.ts +5 -0
- package/dist/primitives/thread/index.d.ts.map +1 -0
- package/dist/primitives/thread/index.js +5 -0
- package/dist/primitives/thread/index.js.map +1 -0
- package/dist/primitives/threadList/ThreadListItems.d.ts +10 -0
- package/dist/primitives/threadList/ThreadListItems.d.ts.map +1 -0
- package/dist/primitives/threadList/ThreadListItems.js +13 -0
- package/dist/primitives/threadList/ThreadListItems.js.map +1 -0
- package/dist/primitives/threadList/ThreadListNew.d.ts +7 -0
- package/dist/primitives/threadList/ThreadListNew.d.ts.map +1 -0
- package/dist/primitives/threadList/ThreadListNew.js +12 -0
- package/dist/primitives/threadList/ThreadListNew.js.map +1 -0
- package/dist/primitives/threadList/ThreadListRoot.d.ts +7 -0
- package/dist/primitives/threadList/ThreadListRoot.d.ts.map +1 -0
- package/dist/primitives/threadList/ThreadListRoot.js +6 -0
- package/dist/primitives/threadList/ThreadListRoot.js.map +1 -0
- package/dist/primitives/threadList/index.d.ts +4 -0
- package/dist/primitives/threadList/index.d.ts.map +1 -0
- package/dist/primitives/threadList/index.js +4 -0
- package/dist/primitives/threadList/index.js.map +1 -0
- package/dist/runtimes/RemoteThreadListHookInstanceManager.d.ts +96 -0
- package/dist/runtimes/RemoteThreadListHookInstanceManager.d.ts.map +1 -0
- package/dist/runtimes/RemoteThreadListHookInstanceManager.js +110 -0
- package/dist/runtimes/RemoteThreadListHookInstanceManager.js.map +1 -0
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.d.ts +112 -0
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.d.ts.map +1 -0
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.js +434 -0
- package/dist/runtimes/RemoteThreadListThreadListRuntimeCore.js.map +1 -0
- package/dist/runtimes/index.d.ts +3 -0
- package/dist/runtimes/index.d.ts.map +1 -0
- package/dist/runtimes/index.js +3 -0
- package/dist/runtimes/index.js.map +1 -0
- package/dist/runtimes/runtime-adapter.d.ts +3 -0
- package/dist/runtimes/runtime-adapter.d.ts.map +1 -0
- package/dist/runtimes/runtime-adapter.js +44 -0
- package/dist/runtimes/runtime-adapter.js.map +1 -0
- package/dist/runtimes/useLocalRuntime.d.ts +18 -0
- package/dist/runtimes/useLocalRuntime.d.ts.map +1 -0
- package/dist/runtimes/useLocalRuntime.js +57 -0
- package/dist/runtimes/useLocalRuntime.js.map +1 -0
- package/dist/runtimes/useRemoteThreadListRuntime.d.ts +4 -0
- package/dist/runtimes/useRemoteThreadListRuntime.d.ts.map +1 -0
- package/dist/runtimes/useRemoteThreadListRuntime.js +37 -0
- package/dist/runtimes/useRemoteThreadListRuntime.js.map +1 -0
- package/package.json +77 -0
- package/src/adapters/LocalStorageThreadListAdapter.tsx +227 -0
- package/src/adapters/TitleGenerationAdapter.ts +20 -0
- package/src/adapters/index.ts +5 -0
- package/src/context/AssistantContext.tsx +44 -0
- package/src/context/index.ts +1 -0
- package/src/context/providers/RuntimeAdapterProvider.tsx +40 -0
- package/src/context/providers/ThreadListItemRuntimeProvider.tsx +16 -0
- package/src/hooks/index.ts +5 -0
- package/src/hooks/useComposer.ts +14 -0
- package/src/hooks/useContentPart.ts +5 -0
- package/src/hooks/useMessage.ts +14 -0
- package/src/hooks/useThread.ts +14 -0
- package/src/hooks/useThreadList.ts +14 -0
- package/src/index.ts +122 -0
- package/src/internal.ts +22 -0
- package/src/primitive-hooks/index.ts +19 -0
- package/src/primitive-hooks/useActionBarCopy.ts +38 -0
- package/src/primitive-hooks/useActionBarEdit.ts +13 -0
- package/src/primitive-hooks/useActionBarFeedback.ts +28 -0
- package/src/primitive-hooks/useActionBarReload.ts +18 -0
- package/src/primitive-hooks/useComposerCancel.ts +13 -0
- package/src/primitive-hooks/useComposerSend.ts +13 -0
- package/src/primitive-hooks/useEditComposerCancel.ts +12 -0
- package/src/primitive-hooks/useEditComposerSend.ts +13 -0
- package/src/primitive-hooks/useMessageBranching.ts +18 -0
- package/src/primitive-hooks/useMessageReload.ts +13 -0
- package/src/primitive-hooks/useThreadIsEmpty.ts +5 -0
- package/src/primitive-hooks/useThreadIsRunning.ts +5 -0
- package/src/primitive-hooks/useThreadMessages.ts +6 -0
- package/src/primitives/actionBar/ActionBarCopy.tsx +34 -0
- package/src/primitives/actionBar/ActionBarEdit.tsx +25 -0
- package/src/primitives/actionBar/ActionBarFeedbackNegative.tsx +23 -0
- package/src/primitives/actionBar/ActionBarFeedbackPositive.tsx +23 -0
- package/src/primitives/actionBar/ActionBarReload.tsx +25 -0
- package/src/primitives/actionBar/index.ts +11 -0
- package/src/primitives/branchPicker/BranchPickerCount.tsx +9 -0
- package/src/primitives/branchPicker/BranchPickerNext.tsx +37 -0
- package/src/primitives/branchPicker/BranchPickerNumber.tsx +9 -0
- package/src/primitives/branchPicker/BranchPickerPrevious.tsx +37 -0
- package/src/primitives/branchPicker/index.ts +16 -0
- package/src/primitives/composer/ComposerCancel.tsx +25 -0
- package/src/primitives/composer/ComposerInput.tsx +19 -0
- package/src/primitives/composer/ComposerRoot.tsx +10 -0
- package/src/primitives/composer/ComposerSend.tsx +25 -0
- package/src/primitives/composer/EditComposerCancel.tsx +20 -0
- package/src/primitives/composer/EditComposerInput.tsx +22 -0
- package/src/primitives/composer/EditComposerSend.tsx +25 -0
- package/src/primitives/composer/index.ts +16 -0
- package/src/primitives/message/MessageContent.tsx +108 -0
- package/src/primitives/message/MessageIf.tsx +40 -0
- package/src/primitives/message/MessageRoot.tsx +10 -0
- package/src/primitives/message/index.ts +3 -0
- package/src/primitives/thread/ThreadEmpty.tsx +12 -0
- package/src/primitives/thread/ThreadIf.tsx +23 -0
- package/src/primitives/thread/ThreadMessages.tsx +61 -0
- package/src/primitives/thread/ThreadRoot.tsx +10 -0
- package/src/primitives/thread/index.ts +4 -0
- package/src/primitives/threadList/ThreadListItems.tsx +35 -0
- package/src/primitives/threadList/ThreadListNew.tsx +24 -0
- package/src/primitives/threadList/ThreadListRoot.tsx +13 -0
- package/src/primitives/threadList/index.ts +3 -0
- package/src/runtimes/RemoteThreadListHookInstanceManager.tsx +180 -0
- package/src/runtimes/RemoteThreadListThreadListRuntimeCore.tsx +528 -0
- package/src/runtimes/index.ts +2 -0
- package/src/runtimes/runtime-adapter.ts +63 -0
- package/src/runtimes/useLocalRuntime.ts +100 -0
- package/src/runtimes/useRemoteThreadListRuntime.ts +64 -0
package/src/internal.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
// Re-export from @assistant-ui/core
|
|
2
|
+
export type {
|
|
3
|
+
ThreadRuntimeCore,
|
|
4
|
+
ThreadListRuntimeCore,
|
|
5
|
+
} from "@assistant-ui/core";
|
|
6
|
+
|
|
7
|
+
// Re-export from @assistant-ui/core/internal
|
|
8
|
+
export {
|
|
9
|
+
DefaultThreadComposerRuntimeCore,
|
|
10
|
+
CompositeContextProvider,
|
|
11
|
+
MessageRepository,
|
|
12
|
+
BaseAssistantRuntimeCore,
|
|
13
|
+
generateId,
|
|
14
|
+
AssistantRuntimeImpl,
|
|
15
|
+
ThreadRuntimeImpl,
|
|
16
|
+
fromThreadMessageLike,
|
|
17
|
+
getAutoStatus,
|
|
18
|
+
} from "@assistant-ui/core/internal";
|
|
19
|
+
export type {
|
|
20
|
+
ThreadRuntimeCoreBinding,
|
|
21
|
+
ThreadListItemRuntimeBinding,
|
|
22
|
+
} from "@assistant-ui/core/internal";
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export { useThreadMessages } from "./useThreadMessages";
|
|
2
|
+
export { useThreadIsRunning } from "./useThreadIsRunning";
|
|
3
|
+
export { useThreadIsEmpty } from "./useThreadIsEmpty";
|
|
4
|
+
export { useComposerSend } from "./useComposerSend";
|
|
5
|
+
export { useComposerCancel } from "./useComposerCancel";
|
|
6
|
+
export { useMessageReload } from "./useMessageReload";
|
|
7
|
+
export { useMessageBranching } from "./useMessageBranching";
|
|
8
|
+
export {
|
|
9
|
+
useActionBarCopy,
|
|
10
|
+
type UseActionBarCopyOptions,
|
|
11
|
+
} from "./useActionBarCopy";
|
|
12
|
+
export { useActionBarEdit } from "./useActionBarEdit";
|
|
13
|
+
export { useActionBarReload } from "./useActionBarReload";
|
|
14
|
+
export {
|
|
15
|
+
useActionBarFeedbackPositive,
|
|
16
|
+
useActionBarFeedbackNegative,
|
|
17
|
+
} from "./useActionBarFeedback";
|
|
18
|
+
export { useEditComposerSend } from "./useEditComposerSend";
|
|
19
|
+
export { useEditComposerCancel } from "./useEditComposerCancel";
|
|
@@ -0,0 +1,38 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import {
|
|
4
|
+
useActionBarCopy,
|
|
5
|
+
type UseActionBarCopyOptions,
|
|
6
|
+
} from "../../primitive-hooks/useActionBarCopy";
|
|
7
|
+
|
|
8
|
+
export type ActionBarCopyProps = Omit<PressableProps, "onPress" | "children"> &
|
|
9
|
+
UseActionBarCopyOptions & {
|
|
10
|
+
children: ReactNode | ((props: { isCopied: boolean }) => ReactNode);
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const ActionBarCopy = ({
|
|
14
|
+
children,
|
|
15
|
+
disabled: disabledProp,
|
|
16
|
+
copiedDuration,
|
|
17
|
+
copyToClipboard,
|
|
18
|
+
...pressableProps
|
|
19
|
+
}: ActionBarCopyProps) => {
|
|
20
|
+
const { copy, disabled, isCopied } = useActionBarCopy({
|
|
21
|
+
copiedDuration,
|
|
22
|
+
copyToClipboard,
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
return (
|
|
26
|
+
<Pressable
|
|
27
|
+
onPress={copy}
|
|
28
|
+
disabled={disabledProp ?? disabled}
|
|
29
|
+
{...pressableProps}
|
|
30
|
+
>
|
|
31
|
+
{typeof children === "function" ? children({ isCopied }) : children}
|
|
32
|
+
</Pressable>
|
|
33
|
+
);
|
|
34
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useActionBarEdit } from "../../primitive-hooks/useActionBarEdit";
|
|
4
|
+
|
|
5
|
+
export type ActionBarEditProps = Omit<PressableProps, "onPress"> & {
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export const ActionBarEdit = ({
|
|
10
|
+
children,
|
|
11
|
+
disabled: disabledProp,
|
|
12
|
+
...pressableProps
|
|
13
|
+
}: ActionBarEditProps) => {
|
|
14
|
+
const { edit, disabled } = useActionBarEdit();
|
|
15
|
+
|
|
16
|
+
return (
|
|
17
|
+
<Pressable
|
|
18
|
+
onPress={edit}
|
|
19
|
+
disabled={disabledProp ?? disabled}
|
|
20
|
+
{...pressableProps}
|
|
21
|
+
>
|
|
22
|
+
{children}
|
|
23
|
+
</Pressable>
|
|
24
|
+
);
|
|
25
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useActionBarFeedbackNegative } from "../../primitive-hooks/useActionBarFeedback";
|
|
4
|
+
|
|
5
|
+
export type ActionBarFeedbackNegativeProps = Omit<
|
|
6
|
+
PressableProps,
|
|
7
|
+
"onPress" | "children"
|
|
8
|
+
> & {
|
|
9
|
+
children: ReactNode | ((props: { isSubmitted: boolean }) => ReactNode);
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export const ActionBarFeedbackNegative = ({
|
|
13
|
+
children,
|
|
14
|
+
...pressableProps
|
|
15
|
+
}: ActionBarFeedbackNegativeProps) => {
|
|
16
|
+
const { submit, isSubmitted } = useActionBarFeedbackNegative();
|
|
17
|
+
|
|
18
|
+
return (
|
|
19
|
+
<Pressable onPress={submit} {...pressableProps}>
|
|
20
|
+
{typeof children === "function" ? children({ isSubmitted }) : children}
|
|
21
|
+
</Pressable>
|
|
22
|
+
);
|
|
23
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useActionBarFeedbackPositive } from "../../primitive-hooks/useActionBarFeedback";
|
|
4
|
+
|
|
5
|
+
export type ActionBarFeedbackPositiveProps = Omit<
|
|
6
|
+
PressableProps,
|
|
7
|
+
"onPress" | "children"
|
|
8
|
+
> & {
|
|
9
|
+
children: ReactNode | ((props: { isSubmitted: boolean }) => ReactNode);
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export const ActionBarFeedbackPositive = ({
|
|
13
|
+
children,
|
|
14
|
+
...pressableProps
|
|
15
|
+
}: ActionBarFeedbackPositiveProps) => {
|
|
16
|
+
const { submit, isSubmitted } = useActionBarFeedbackPositive();
|
|
17
|
+
|
|
18
|
+
return (
|
|
19
|
+
<Pressable onPress={submit} {...pressableProps}>
|
|
20
|
+
{typeof children === "function" ? children({ isSubmitted }) : children}
|
|
21
|
+
</Pressable>
|
|
22
|
+
);
|
|
23
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useActionBarReload } from "../../primitive-hooks/useActionBarReload";
|
|
4
|
+
|
|
5
|
+
export type ActionBarReloadProps = Omit<PressableProps, "onPress"> & {
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export const ActionBarReload = ({
|
|
10
|
+
children,
|
|
11
|
+
disabled: disabledProp,
|
|
12
|
+
...pressableProps
|
|
13
|
+
}: ActionBarReloadProps) => {
|
|
14
|
+
const { reload, disabled } = useActionBarReload();
|
|
15
|
+
|
|
16
|
+
return (
|
|
17
|
+
<Pressable
|
|
18
|
+
onPress={reload}
|
|
19
|
+
disabled={disabledProp ?? disabled}
|
|
20
|
+
{...pressableProps}
|
|
21
|
+
>
|
|
22
|
+
{children}
|
|
23
|
+
</Pressable>
|
|
24
|
+
);
|
|
25
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { ActionBarCopy, type ActionBarCopyProps } from "./ActionBarCopy";
|
|
2
|
+
export { ActionBarEdit, type ActionBarEditProps } from "./ActionBarEdit";
|
|
3
|
+
export { ActionBarReload, type ActionBarReloadProps } from "./ActionBarReload";
|
|
4
|
+
export {
|
|
5
|
+
ActionBarFeedbackPositive,
|
|
6
|
+
type ActionBarFeedbackPositiveProps,
|
|
7
|
+
} from "./ActionBarFeedbackPositive";
|
|
8
|
+
export {
|
|
9
|
+
ActionBarFeedbackNegative,
|
|
10
|
+
type ActionBarFeedbackNegativeProps,
|
|
11
|
+
} from "./ActionBarFeedbackNegative";
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Text, type TextProps } from "react-native";
|
|
2
|
+
import { useAuiState } from "@assistant-ui/store";
|
|
3
|
+
|
|
4
|
+
export type BranchPickerCountProps = TextProps;
|
|
5
|
+
|
|
6
|
+
export const BranchPickerCount = (props: BranchPickerCountProps) => {
|
|
7
|
+
const branchCount = useAuiState((s) => s.message.branchCount);
|
|
8
|
+
return <Text {...props}>{branchCount}</Text>;
|
|
9
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useCallback } from "react";
|
|
4
|
+
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
5
|
+
|
|
6
|
+
export type BranchPickerNextProps = Omit<PressableProps, "onPress"> & {
|
|
7
|
+
children: ReactNode;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export const BranchPickerNext = ({
|
|
11
|
+
children,
|
|
12
|
+
disabled: disabledProp,
|
|
13
|
+
...pressableProps
|
|
14
|
+
}: BranchPickerNextProps) => {
|
|
15
|
+
const aui = useAui();
|
|
16
|
+
const disabled = useAuiState((s) => {
|
|
17
|
+
if (s.message.branchNumber >= s.message.branchCount) return true;
|
|
18
|
+
if (s.thread.isRunning && !s.thread.capabilities.switchBranchDuringRun) {
|
|
19
|
+
return true;
|
|
20
|
+
}
|
|
21
|
+
return false;
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const goToNext = useCallback(() => {
|
|
25
|
+
aui.message().switchToBranch({ position: "next" });
|
|
26
|
+
}, [aui]);
|
|
27
|
+
|
|
28
|
+
return (
|
|
29
|
+
<Pressable
|
|
30
|
+
onPress={goToNext}
|
|
31
|
+
disabled={disabledProp ?? disabled}
|
|
32
|
+
{...pressableProps}
|
|
33
|
+
>
|
|
34
|
+
{children}
|
|
35
|
+
</Pressable>
|
|
36
|
+
);
|
|
37
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Text, type TextProps } from "react-native";
|
|
2
|
+
import { useAuiState } from "@assistant-ui/store";
|
|
3
|
+
|
|
4
|
+
export type BranchPickerNumberProps = TextProps;
|
|
5
|
+
|
|
6
|
+
export const BranchPickerNumber = (props: BranchPickerNumberProps) => {
|
|
7
|
+
const branchNumber = useAuiState((s) => s.message.branchNumber);
|
|
8
|
+
return <Text {...props}>{branchNumber}</Text>;
|
|
9
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useCallback } from "react";
|
|
4
|
+
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
5
|
+
|
|
6
|
+
export type BranchPickerPreviousProps = Omit<PressableProps, "onPress"> & {
|
|
7
|
+
children: ReactNode;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export const BranchPickerPrevious = ({
|
|
11
|
+
children,
|
|
12
|
+
disabled: disabledProp,
|
|
13
|
+
...pressableProps
|
|
14
|
+
}: BranchPickerPreviousProps) => {
|
|
15
|
+
const aui = useAui();
|
|
16
|
+
const disabled = useAuiState((s) => {
|
|
17
|
+
if (s.message.branchNumber <= 1) return true;
|
|
18
|
+
if (s.thread.isRunning && !s.thread.capabilities.switchBranchDuringRun) {
|
|
19
|
+
return true;
|
|
20
|
+
}
|
|
21
|
+
return false;
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const goToPrevious = useCallback(() => {
|
|
25
|
+
aui.message().switchToBranch({ position: "previous" });
|
|
26
|
+
}, [aui]);
|
|
27
|
+
|
|
28
|
+
return (
|
|
29
|
+
<Pressable
|
|
30
|
+
onPress={goToPrevious}
|
|
31
|
+
disabled={disabledProp ?? disabled}
|
|
32
|
+
{...pressableProps}
|
|
33
|
+
>
|
|
34
|
+
{children}
|
|
35
|
+
</Pressable>
|
|
36
|
+
);
|
|
37
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export {
|
|
2
|
+
BranchPickerPrevious,
|
|
3
|
+
type BranchPickerPreviousProps,
|
|
4
|
+
} from "./BranchPickerPrevious";
|
|
5
|
+
export {
|
|
6
|
+
BranchPickerNext,
|
|
7
|
+
type BranchPickerNextProps,
|
|
8
|
+
} from "./BranchPickerNext";
|
|
9
|
+
export {
|
|
10
|
+
BranchPickerNumber,
|
|
11
|
+
type BranchPickerNumberProps,
|
|
12
|
+
} from "./BranchPickerNumber";
|
|
13
|
+
export {
|
|
14
|
+
BranchPickerCount,
|
|
15
|
+
type BranchPickerCountProps,
|
|
16
|
+
} from "./BranchPickerCount";
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useComposerCancel } from "../../primitive-hooks/useComposerCancel";
|
|
4
|
+
|
|
5
|
+
export type ComposerCancelProps = Omit<PressableProps, "onPress"> & {
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export const ComposerCancel = ({
|
|
10
|
+
children,
|
|
11
|
+
disabled,
|
|
12
|
+
...pressableProps
|
|
13
|
+
}: ComposerCancelProps) => {
|
|
14
|
+
const { cancel, canCancel } = useComposerCancel();
|
|
15
|
+
|
|
16
|
+
return (
|
|
17
|
+
<Pressable
|
|
18
|
+
onPress={cancel}
|
|
19
|
+
disabled={disabled ?? !canCancel}
|
|
20
|
+
{...pressableProps}
|
|
21
|
+
>
|
|
22
|
+
{children}
|
|
23
|
+
</Pressable>
|
|
24
|
+
);
|
|
25
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { useCallback } from "react";
|
|
2
|
+
import { TextInput, type TextInputProps } from "react-native";
|
|
3
|
+
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
4
|
+
|
|
5
|
+
export type ComposerInputProps = Omit<TextInputProps, "value" | "onChangeText">;
|
|
6
|
+
|
|
7
|
+
export const ComposerInput = (props: ComposerInputProps) => {
|
|
8
|
+
const aui = useAui();
|
|
9
|
+
const text = useAuiState((s) => s.composer.text);
|
|
10
|
+
|
|
11
|
+
const onChangeText = useCallback(
|
|
12
|
+
(value: string) => {
|
|
13
|
+
aui.composer().setText(value);
|
|
14
|
+
},
|
|
15
|
+
[aui],
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
return <TextInput value={text} onChangeText={onChangeText} {...props} />;
|
|
19
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { View, type ViewProps } from "react-native";
|
|
3
|
+
|
|
4
|
+
export type ComposerRootProps = ViewProps & {
|
|
5
|
+
children: ReactNode;
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
export const ComposerRoot = ({ children, ...viewProps }: ComposerRootProps) => {
|
|
9
|
+
return <View {...viewProps}>{children}</View>;
|
|
10
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useComposerSend } from "../../primitive-hooks/useComposerSend";
|
|
4
|
+
|
|
5
|
+
export type ComposerSendProps = Omit<PressableProps, "onPress"> & {
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export const ComposerSend = ({
|
|
10
|
+
children,
|
|
11
|
+
disabled,
|
|
12
|
+
...pressableProps
|
|
13
|
+
}: ComposerSendProps) => {
|
|
14
|
+
const { send, canSend } = useComposerSend();
|
|
15
|
+
|
|
16
|
+
return (
|
|
17
|
+
<Pressable
|
|
18
|
+
onPress={send}
|
|
19
|
+
disabled={disabled ?? !canSend}
|
|
20
|
+
{...pressableProps}
|
|
21
|
+
>
|
|
22
|
+
{children}
|
|
23
|
+
</Pressable>
|
|
24
|
+
);
|
|
25
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
import { Pressable, type PressableProps } from "react-native";
|
|
3
|
+
import { useEditComposerCancel } from "../../primitive-hooks/useEditComposerCancel";
|
|
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
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { useCallback } from "react";
|
|
2
|
+
import { TextInput, type TextInputProps } from "react-native";
|
|
3
|
+
import { useAui, useAuiState } from "@assistant-ui/store";
|
|
4
|
+
|
|
5
|
+
export type EditComposerInputProps = Omit<
|
|
6
|
+
TextInputProps,
|
|
7
|
+
"value" | "onChangeText"
|
|
8
|
+
>;
|
|
9
|
+
|
|
10
|
+
export const EditComposerInput = (props: EditComposerInputProps) => {
|
|
11
|
+
const aui = useAui();
|
|
12
|
+
const text = useAuiState((s) => s.composer.text);
|
|
13
|
+
|
|
14
|
+
const onChangeText = useCallback(
|
|
15
|
+
(value: string) => {
|
|
16
|
+
aui.composer().setText(value);
|
|
17
|
+
},
|
|
18
|
+
[aui],
|
|
19
|
+
);
|
|
20
|
+
|
|
21
|
+
return <TextInput value={text} onChangeText={onChangeText} {...props} />;
|
|
22
|
+
};
|