@copilotkit/react-textarea 0.19.0-alpha.2 → 0.19.0-alpha.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.
Files changed (232) hide show
  1. package/.turbo/turbo-build.log +292 -288
  2. package/CHANGELOG.md +17 -0
  3. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +1870 -33
  4. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs.map +1 -1
  5. package/dist/components/base-copilot-textarea/render-element.mjs +52 -3
  6. package/dist/components/base-copilot-textarea/render-element.mjs.map +1 -1
  7. package/dist/components/base-copilot-textarea/render-placeholder.mjs +46 -3
  8. package/dist/components/base-copilot-textarea/render-placeholder.mjs.map +1 -1
  9. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs +86 -4
  10. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs.map +1 -1
  11. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs +57 -3
  12. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs.map +1 -1
  13. package/dist/components/copilot-textarea/copilot-textarea.mjs +2339 -43
  14. package/dist/components/copilot-textarea/copilot-textarea.mjs.map +1 -1
  15. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs +22 -3
  16. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs.map +1 -1
  17. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs +125 -3
  18. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs.map +1 -1
  19. package/dist/components/hovering-toolbar/hovering-toolbar.mjs +1015 -16
  20. package/dist/components/hovering-toolbar/hovering-toolbar.mjs.map +1 -1
  21. package/dist/components/hovering-toolbar/text-insertion-prompt-box/{mode-suggestion-appearing.d.ts → hovering-insertion-prompt-box-core.d.ts} +5 -13
  22. package/dist/{chunk-ITZHK3YV.mjs → components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs} +488 -243
  23. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs.map +1 -0
  24. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs +734 -11
  25. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs.map +1 -1
  26. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs +734 -12
  27. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs.map +1 -1
  28. package/dist/components/index.mjs +2340 -44
  29. package/dist/components/index.mjs.map +1 -1
  30. package/dist/components/manual-ui/chip-with-icon.mjs +5 -6
  31. package/dist/components/manual-ui/chip-with-icon.mjs.map +1 -1
  32. package/dist/components/source-search-box/source-search-box.mjs +323 -9
  33. package/dist/components/source-search-box/source-search-box.mjs.map +1 -1
  34. package/dist/components/ui/button.d.ts +1 -1
  35. package/dist/components/ui/button.mjs +88 -4
  36. package/dist/components/ui/button.mjs.map +1 -1
  37. package/dist/components/ui/card.mjs +53 -7
  38. package/dist/components/ui/card.mjs.map +1 -1
  39. package/dist/components/ui/command.mjs +266 -5
  40. package/dist/components/ui/command.mjs.map +1 -1
  41. package/dist/components/ui/dialog.mjs +164 -4
  42. package/dist/components/ui/dialog.mjs.map +1 -1
  43. package/dist/components/ui/label.mjs +63 -4
  44. package/dist/components/ui/label.mjs.map +1 -1
  45. package/dist/components/ui/separator.mjs +50 -8
  46. package/dist/components/ui/separator.mjs.map +1 -1
  47. package/dist/components/ui/textarea.mjs +48 -7
  48. package/dist/components/ui/textarea.mjs.map +1 -1
  49. package/dist/context/index.mjs +0 -2
  50. package/dist/context/index.mjs.map +1 -1
  51. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs +168 -6
  52. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs.map +1 -1
  53. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs +168 -4
  54. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs.map +1 -1
  55. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs +155 -5
  56. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs.map +1 -1
  57. package/dist/hooks/index.mjs +0 -2
  58. package/dist/hooks/index.mjs.map +1 -1
  59. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +90 -4
  60. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map +1 -1
  61. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs +143 -4
  62. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs.map +1 -1
  63. package/dist/hooks/misc/use-autosize-textarea.mjs +15 -3
  64. package/dist/hooks/misc/use-autosize-textarea.mjs.map +1 -1
  65. package/dist/index.css +3 -27
  66. package/dist/index.css.map +1 -1
  67. package/dist/index.mjs +2343 -48
  68. package/dist/index.mjs.map +1 -1
  69. package/dist/lib/debouncer.mjs +51 -3
  70. package/dist/lib/debouncer.mjs.map +1 -1
  71. package/dist/lib/editor-to-text.mjs +43 -3
  72. package/dist/lib/editor-to-text.mjs.map +1 -1
  73. package/dist/lib/get-text-around-cursor.mjs +109 -3
  74. package/dist/lib/get-text-around-cursor.mjs.map +1 -1
  75. package/dist/lib/retry.mjs +17 -3
  76. package/dist/lib/retry.mjs.map +1 -1
  77. package/dist/lib/slatejs-edits/add-autocompletions.mjs +25 -3
  78. package/dist/lib/slatejs-edits/add-autocompletions.mjs.map +1 -1
  79. package/dist/lib/slatejs-edits/clear-autocompletions.mjs +23 -3
  80. package/dist/lib/slatejs-edits/clear-autocompletions.mjs.map +1 -1
  81. package/dist/lib/slatejs-edits/replace-text.mjs +27 -3
  82. package/dist/lib/slatejs-edits/replace-text.mjs.map +1 -1
  83. package/dist/lib/slatejs-edits/with-partial-history.mjs +106 -3
  84. package/dist/lib/slatejs-edits/with-partial-history.mjs.map +1 -1
  85. package/dist/lib/stream-promise-flatten.d.ts +3 -0
  86. package/dist/lib/stream-promise-flatten.mjs +48 -0
  87. package/dist/lib/stream-promise-flatten.mjs.map +1 -0
  88. package/dist/lib/utils.mjs +71 -3
  89. package/dist/lib/utils.mjs.map +1 -1
  90. package/dist/lib/utils.test.mjs +0 -1
  91. package/dist/lib/utils.test.mjs.map +1 -1
  92. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs +0 -2
  93. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs.map +1 -1
  94. package/dist/types/autosuggestions-config/autosuggestions-config.mjs +312 -9
  95. package/dist/types/autosuggestions-config/autosuggestions-config.mjs.map +1 -1
  96. package/dist/types/autosuggestions-config/editing-api-config.mjs +155 -4
  97. package/dist/types/autosuggestions-config/editing-api-config.mjs.map +1 -1
  98. package/dist/types/autosuggestions-config/index.mjs +313 -10
  99. package/dist/types/autosuggestions-config/index.mjs.map +1 -1
  100. package/dist/types/autosuggestions-config/insertions-api-config.mjs +149 -4
  101. package/dist/types/autosuggestions-config/insertions-api-config.mjs.map +1 -1
  102. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs +71 -3
  103. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs.map +1 -1
  104. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs +0 -2
  105. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs.map +1 -1
  106. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs +0 -2
  107. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs.map +1 -1
  108. package/dist/types/autosuggestions-config/suggestions-api-config.mjs +137 -4
  109. package/dist/types/autosuggestions-config/suggestions-api-config.mjs.map +1 -1
  110. package/dist/types/base/autosuggestion-state.mjs +0 -2
  111. package/dist/types/base/autosuggestion-state.mjs.map +1 -1
  112. package/dist/types/base/autosuggestions-bare-function.mjs +0 -2
  113. package/dist/types/base/autosuggestions-bare-function.mjs.map +1 -1
  114. package/dist/types/base/base-autosuggestions-config.mjs +11 -3
  115. package/dist/types/base/base-autosuggestions-config.mjs.map +1 -1
  116. package/dist/types/base/base-copilot-textarea-props.mjs +0 -2
  117. package/dist/types/base/base-copilot-textarea-props.mjs.map +1 -1
  118. package/dist/types/base/custom-editor.mjs +0 -2
  119. package/dist/types/base/custom-editor.mjs.map +1 -1
  120. package/dist/types/base/editor-autocomplete-state.mjs +17 -4
  121. package/dist/types/base/editor-autocomplete-state.mjs.map +1 -1
  122. package/dist/types/base/index.mjs +11 -4
  123. package/dist/types/base/index.mjs.map +1 -1
  124. package/dist/types/html-copilot-textarea-element.mjs +0 -2
  125. package/dist/types/html-copilot-textarea-element.mjs.map +1 -1
  126. package/dist/types/index.mjs +314 -12
  127. package/dist/types/index.mjs.map +1 -1
  128. package/package.json +3 -3
  129. package/src/components/hovering-toolbar/text-insertion-prompt-box/{mode-suggestion-appearing.tsx → hovering-insertion-prompt-box-core.tsx} +59 -65
  130. package/src/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.tsx +9 -52
  131. package/src/components/source-search-box/source-search-box.tsx +7 -10
  132. package/src/components/ui/command.tsx +1 -1
  133. package/src/lib/stream-promise-flatten.ts +25 -0
  134. package/dist/chunk-2NURR2DX.mjs +0 -47
  135. package/dist/chunk-2NURR2DX.mjs.map +0 -1
  136. package/dist/chunk-3YJ63D5D.mjs +0 -106
  137. package/dist/chunk-3YJ63D5D.mjs.map +0 -1
  138. package/dist/chunk-4S5ZJH3I.mjs +0 -18
  139. package/dist/chunk-4S5ZJH3I.mjs.map +0 -1
  140. package/dist/chunk-55EGOC5T.mjs +0 -87
  141. package/dist/chunk-55EGOC5T.mjs.map +0 -1
  142. package/dist/chunk-5ARCOTW3.mjs +0 -34
  143. package/dist/chunk-5ARCOTW3.mjs.map +0 -1
  144. package/dist/chunk-5EJ5XOGP.mjs +0 -22
  145. package/dist/chunk-5EJ5XOGP.mjs.map +0 -1
  146. package/dist/chunk-5FO6ISW4.mjs +0 -3
  147. package/dist/chunk-5FO6ISW4.mjs.map +0 -1
  148. package/dist/chunk-7SMDOAG2.mjs +0 -201
  149. package/dist/chunk-7SMDOAG2.mjs.map +0 -1
  150. package/dist/chunk-A2RRLD23.mjs +0 -69
  151. package/dist/chunk-A2RRLD23.mjs.map +0 -1
  152. package/dist/chunk-CDB7HFCY.mjs +0 -65
  153. package/dist/chunk-CDB7HFCY.mjs.map +0 -1
  154. package/dist/chunk-CSGFJU3L.mjs +0 -65
  155. package/dist/chunk-CSGFJU3L.mjs.map +0 -1
  156. package/dist/chunk-D7SEV5PR.mjs +0 -12
  157. package/dist/chunk-D7SEV5PR.mjs.map +0 -1
  158. package/dist/chunk-DE5K76I2.mjs +0 -3
  159. package/dist/chunk-DE5K76I2.mjs.map +0 -1
  160. package/dist/chunk-F3MHL6ZY.mjs +0 -25
  161. package/dist/chunk-F3MHL6ZY.mjs.map +0 -1
  162. package/dist/chunk-H4VKQGVU.mjs +0 -3
  163. package/dist/chunk-H4VKQGVU.mjs.map +0 -1
  164. package/dist/chunk-HAFHLU4N.mjs +0 -55
  165. package/dist/chunk-HAFHLU4N.mjs.map +0 -1
  166. package/dist/chunk-ITZHK3YV.mjs.map +0 -1
  167. package/dist/chunk-IU3WTXLQ.mjs +0 -3
  168. package/dist/chunk-IU3WTXLQ.mjs.map +0 -1
  169. package/dist/chunk-IXJ2HCOA.mjs +0 -101
  170. package/dist/chunk-IXJ2HCOA.mjs.map +0 -1
  171. package/dist/chunk-JAFCXEPU.mjs +0 -10
  172. package/dist/chunk-JAFCXEPU.mjs.map +0 -1
  173. package/dist/chunk-KCHYD3EB.mjs +0 -107
  174. package/dist/chunk-KCHYD3EB.mjs.map +0 -1
  175. package/dist/chunk-KGKLUWKW.mjs +0 -47
  176. package/dist/chunk-KGKLUWKW.mjs.map +0 -1
  177. package/dist/chunk-L7VVZH4Q.mjs +0 -3
  178. package/dist/chunk-L7VVZH4Q.mjs.map +0 -1
  179. package/dist/chunk-LNAIMEB2.mjs +0 -34
  180. package/dist/chunk-LNAIMEB2.mjs.map +0 -1
  181. package/dist/chunk-MMVDU6DF.mjs +0 -3
  182. package/dist/chunk-MMVDU6DF.mjs.map +0 -1
  183. package/dist/chunk-MPME5BW2.mjs +0 -59
  184. package/dist/chunk-MPME5BW2.mjs.map +0 -1
  185. package/dist/chunk-MRXNTQOX.mjs +0 -55
  186. package/dist/chunk-MRXNTQOX.mjs.map +0 -1
  187. package/dist/chunk-ND5PXTAW.mjs +0 -17
  188. package/dist/chunk-ND5PXTAW.mjs.map +0 -1
  189. package/dist/chunk-NKW5OU2S.mjs +0 -33
  190. package/dist/chunk-NKW5OU2S.mjs.map +0 -1
  191. package/dist/chunk-O5OWT5GE.mjs +0 -114
  192. package/dist/chunk-O5OWT5GE.mjs.map +0 -1
  193. package/dist/chunk-OD7ZMOVE.mjs +0 -45
  194. package/dist/chunk-OD7ZMOVE.mjs.map +0 -1
  195. package/dist/chunk-OELUUJZY.mjs +0 -16
  196. package/dist/chunk-OELUUJZY.mjs.map +0 -1
  197. package/dist/chunk-OM5WQQOU.mjs +0 -47
  198. package/dist/chunk-OM5WQQOU.mjs.map +0 -1
  199. package/dist/chunk-PF3XRNDB.mjs +0 -44
  200. package/dist/chunk-PF3XRNDB.mjs.map +0 -1
  201. package/dist/chunk-QL2GYGG5.mjs +0 -19
  202. package/dist/chunk-QL2GYGG5.mjs.map +0 -1
  203. package/dist/chunk-RPDVSCLO.mjs +0 -107
  204. package/dist/chunk-RPDVSCLO.mjs.map +0 -1
  205. package/dist/chunk-RQHOUUXQ.mjs +0 -29
  206. package/dist/chunk-RQHOUUXQ.mjs.map +0 -1
  207. package/dist/chunk-UHD44NC5.mjs +0 -101
  208. package/dist/chunk-UHD44NC5.mjs.map +0 -1
  209. package/dist/chunk-VBIJPE3H.mjs +0 -108
  210. package/dist/chunk-VBIJPE3H.mjs.map +0 -1
  211. package/dist/chunk-WADHCMPK.mjs +0 -3
  212. package/dist/chunk-WADHCMPK.mjs.map +0 -1
  213. package/dist/chunk-WJHSY5T6.mjs +0 -3
  214. package/dist/chunk-WJHSY5T6.mjs.map +0 -1
  215. package/dist/chunk-WJYQWL4I.mjs +0 -27
  216. package/dist/chunk-WJYQWL4I.mjs.map +0 -1
  217. package/dist/chunk-XDT7BF3V.mjs +0 -81
  218. package/dist/chunk-XDT7BF3V.mjs.map +0 -1
  219. package/dist/chunk-XHUMROEY.mjs +0 -91
  220. package/dist/chunk-XHUMROEY.mjs.map +0 -1
  221. package/dist/chunk-YQU7WG7T.mjs +0 -83
  222. package/dist/chunk-YQU7WG7T.mjs.map +0 -1
  223. package/dist/chunk-YTOPHPSG.mjs +0 -45
  224. package/dist/chunk-YTOPHPSG.mjs.map +0 -1
  225. package/dist/chunk-YW3REYX6.mjs +0 -23
  226. package/dist/chunk-YW3REYX6.mjs.map +0 -1
  227. package/dist/components/hovering-toolbar/text-insertion-prompt-box/mode-pre-suggestion.d.ts +0 -16
  228. package/dist/components/hovering-toolbar/text-insertion-prompt-box/mode-pre-suggestion.mjs +0 -5
  229. package/dist/components/hovering-toolbar/text-insertion-prompt-box/mode-pre-suggestion.mjs.map +0 -1
  230. package/dist/components/hovering-toolbar/text-insertion-prompt-box/mode-suggestion-appearing.mjs +0 -10
  231. package/dist/components/hovering-toolbar/text-insertion-prompt-box/mode-suggestion-appearing.mjs.map +0 -1
  232. package/src/components/hovering-toolbar/text-insertion-prompt-box/mode-pre-suggestion.tsx +0 -83
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":["../../src/types/base/base-autosuggestions-config.tsx","../../src/types/autosuggestions-config/subtypes/chatlike-api-endpoint.tsx","../../src/types/autosuggestions-config/suggestions-api-config.tsx","../../src/types/autosuggestions-config/insertions-api-config.tsx","../../src/types/autosuggestions-config/editing-api-config.tsx","../../src/types/autosuggestions-config/autosuggestions-config.tsx"],"sourcesContent":["import { BaseCopilotTextareaApiConfig } from \"./autosuggestions-bare-function\";\n\nexport interface BaseAutosuggestionsConfig {\n textareaPurpose: string;\n debounceTime: number;\n acceptAutosuggestionKey: string;\n disableWhenEmpty: boolean;\n disabled: boolean;\n temporarilyDisableWhenMovingCursorWithoutChangingText: boolean;\n apiConfig: BaseCopilotTextareaApiConfig;\n}\n\nexport const defaultBaseAutosuggestionsConfig: Omit<\n BaseAutosuggestionsConfig,\n \"textareaPurpose\" | \"apiConfig\"\n> = {\n debounceTime: 250,\n acceptAutosuggestionKey: \"Tab\",\n disableWhenEmpty: true,\n disabled: false,\n temporarilyDisableWhenMovingCursorWithoutChangingText: true,\n};\n","import { MinimalChatGPTMessage } from \"./minimal-chat-gpt-message\";\n\nexport type ChatlikeApiEndpointImpl = (\n abortSignal: AbortSignal,\n messages: MinimalChatGPTMessage[],\n forwardedProps?: { [key: string]: any }\n) => Promise<string>;\n\nexport type StreamingChatlikeApiEndpointImpl = (\n abortSignal: AbortSignal,\n messages: MinimalChatGPTMessage[],\n forwardedProps?: { [key: string]: any }\n) => Promise<ReadableStream<string>>;\n\nexport class ChatlikeApiEndpoint {\n public run: StreamingChatlikeApiEndpointImpl;\n\n constructor(run: StreamingChatlikeApiEndpointImpl) {\n this.run = run;\n }\n\n /**\n * Creates a new instance of ChatlikeApiEndpoint with the provided API endpoint.\n * @param apiEndpoint The URL of the OpenAI-compatible API endpoint.\n * @returns A new instance of ChatlikeApiEndpoint.\n */\n static standardOpenAIEndpoint(apiEndpoint: string): ChatlikeApiEndpoint {\n return new ChatlikeApiEndpoint(\n async (\n abortSignal: AbortSignal,\n messages: MinimalChatGPTMessage[],\n forwardedProps?: { [key: string]: any }\n ) => {\n const res = await fetch(apiEndpoint, {\n method: \"POST\",\n body: JSON.stringify({\n ...forwardedProps,\n messages: messages,\n }),\n signal: abortSignal,\n });\n\n const bodySteram: ReadableStream<Uint8Array> | null = res.body;\n if (!bodySteram) {\n throw new Error(\"The response body is empty.\");\n }\n\n // map the stream to a stream of strings\n const stringStream = bodySteram.pipeThrough(new TextDecoderStream());\n\n return stringStream;\n }\n );\n }\n\n /**\n * Creates a fully customized instance of ChatlikeApiEndpoint.\n * @param run - The implementation of the ChatlikeApiEndpointImpl interface.\n * @returns A new instance of ChatlikeApiEndpoint .\n */\n static custom(run: StreamingChatlikeApiEndpointImpl): ChatlikeApiEndpoint {\n return new ChatlikeApiEndpoint(run);\n }\n}\n","import { MinimalChatGPTMessage } from \"./subtypes/minimal-chat-gpt-message\";\nimport { MakeSystemPrompt } from \"./subtypes/make-system-prompt\";\nimport { ChatlikeApiEndpoint } from \"./subtypes/chatlike-api-endpoint\";\n\nexport interface SuggestionsApiConfig {\n apiEndpoint: ChatlikeApiEndpoint;\n makeSystemPrompt: MakeSystemPrompt;\n fewShotMessages: MinimalChatGPTMessage[];\n forwardedParams: { [key: string]: any } | undefined;\n}\n\nexport const defaultSuggestionsMakeSystemPrompt: MakeSystemPrompt = (\n textareaPurpose,\n contextString\n) => {\n return `You are a versatile writing assistant.\n \nThe user is writing some text.\nThe purpose is: \\\"${textareaPurpose}\\\"\n\nYour job is to guess what the user will write next AS BEST YOU CAN.\nOnly guess a SHORT distance ahead. Usually 1 sentence, or at most 1 paragraph.\n\nAdjust yourself to the user's style and implied intent.\n\nThe user will provide both the text before and after the cursor. You should use this to infer what the user is likely to write next.\n<TextAfterCursor>\n<TextBeforeCursor>\n<YourSuggestion>\n\nIf we need to add a whitespace character to the suggested text, make sure to explicitly add it in.\n\nThe following external context is also provided. Use it to help you make better suggestions!!!\n\\`\\`\\`\n${contextString}\n\\`\\`\\`\n`;\n};\n\nexport const defaultSuggestionsFewShotMessages: MinimalChatGPTMessage[] = [\n {\n role: \"user\",\n name: \"TextAfterCursor\",\n content:\n \"While I was there I also picked up some apples, oranges, and bananas.\",\n },\n {\n role: \"user\",\n name: \"TextBeforeCursor\",\n content: \"This morning I woke up and went straight to the grocery store.\",\n },\n {\n role: \"assistant\",\n content:\n \" When I arrived I went straight to the produce section and picked out a big watermelon. \",\n },\n {\n role: \"user\",\n name: \"TextAfterCursor\",\n content:\n \"and (iii) to the appointment of the Equityholders' Representative pursuant to Section 10.7 of the Merger Agreement and to the provisions thereof.\",\n },\n {\n role: \"user\",\n name: \"TextBeforeCursor\",\n content:\n 'The Optionholder, in the Optionholder\\'s capacity as a holder of vested Options, hereby irrevocably and unconditionally agrees: (i) that the Optionholder shall be deemed an \"Equityholder\" under the Merger Agreement and shall be entitled to the rights and benefits, and subject to the obligations, of an \"Equityholder\" thereunder;',\n },\n {\n role: \"assistant\",\n content:\n ' (ii) that, for purposes of this Agreement and the Merger Agreement, the applicable percentage set forth opposite the name of the Optionholder in the Distribution Waterfall shall be such the Optionholder\\'s \"Pro Rata Share\"; ',\n },\n];\n\nexport const defaultSuggestionsApiConfig: SuggestionsApiConfig = {\n apiEndpoint: ChatlikeApiEndpoint.standardOpenAIEndpoint(\n \"/api/copilotkit_chatlike\"\n ),\n makeSystemPrompt: defaultSuggestionsMakeSystemPrompt,\n fewShotMessages: defaultSuggestionsFewShotMessages,\n forwardedParams: undefined,\n};\n","import { ChatlikeApiEndpoint } from \"./subtypes/chatlike-api-endpoint\";\nimport { MakeSystemPrompt } from \"./subtypes/make-system-prompt\";\nimport { MinimalChatGPTMessage } from \"./subtypes/minimal-chat-gpt-message\";\n\nexport interface InsertionsApiConfig {\n apiEndpoint: ChatlikeApiEndpoint;\n makeSystemPrompt: MakeSystemPrompt;\n fewShotMessages: MinimalChatGPTMessage[];\n forwardedParams: { [key: string]: any } | undefined;\n}\n\nexport const defaultInsertionsMakeSystemPrompt: MakeSystemPrompt = (\n textareaPurpose,\n contextString\n) => {\n return `You are a versatile writing assistant.\n \nThe user is writing some text.\nThe purpose is: \\\"${textareaPurpose}\\\"\n\nThe user also provides you with a prompt for INSERTIONS into the text they are writing. \nYour job is to come up with an INSERTION into the text that the user would like AS BEST YOU CAN.\nOnly guess a SHORT distance ahead. Usually 1 sentence, or at most 1 paragraph.\n\nAdjust yourself to the user's style and implied intent.\n\nThe user will provide the text before and after the cursor, as well as the insertion prompt. You should use this to infer the best relevant insertion.\n<TextAfterCursor>\n<TextBeforeCursor>\n<InsertionPrompt>\n<YourSuggestion>\n\nIf we need to add a whitespace character to the suggested text, make sure to explicitly add it in.\n\nThe following external context is also provided. Use it to help you make better suggestions!!!\n\\`\\`\\`\n${contextString}\n\\`\\`\\`\n`;\n};\n\nexport const defaultInsertionsFewShotMessages: MinimalChatGPTMessage[] = [\n {\n role: \"user\",\n name: \"TextAfterCursor\",\n content:\n \"While I was there I also picked up some apples, oranges, and bananas.\",\n },\n {\n role: \"user\",\n name: \"TextBeforeCursor\",\n content: \"This morning I woke up and went straight to the grocery store.\",\n },\n {\n role: \"user\",\n name: \"InsertionPrompt\",\n content: \"I bought a big watermelon\",\n },\n {\n role: \"assistant\",\n content:\n \" When I arrived I went straight to the produce section and picked out a big watermelon. \",\n },\n {\n role: \"user\",\n name: \"TextAfterCursor\",\n content:\n \"and (iii) to the appointment of the Equityholders' Representative pursuant to Section 10.7 of the Merger Agreement and to the provisions thereof.\",\n },\n {\n role: \"user\",\n name: \"TextBeforeCursor\",\n content:\n 'The Optionholder, in the Optionholder\\'s capacity as a holder of vested Options, hereby irrevocably and unconditionally agrees: (i) that the Optionholder shall be deemed an \"Equityholder\" under the Merger Agreement and shall be entitled to the rights and benefits, and subject to the obligations, of an \"Equityholder\" thereunder;',\n },\n {\n role: \"user\",\n name: \"InsertionPrompt\",\n content: \"add section about the optionholder's pro rata share\",\n },\n {\n role: \"assistant\",\n content:\n ' (ii) that, for purposes of this Agreement and the Merger Agreement, the applicable percentage set forth opposite the name of the Optionholder in the Distribution Waterfall shall be such the Optionholder\\'s \"Pro Rata Share\"; ',\n },\n];\n\nexport const defaultInsertionsApiConfig: InsertionsApiConfig = {\n apiEndpoint: ChatlikeApiEndpoint.standardOpenAIEndpoint(\n \"/api/copilotkit_chatlike\"\n ),\n makeSystemPrompt: defaultInsertionsMakeSystemPrompt,\n fewShotMessages: defaultInsertionsFewShotMessages,\n forwardedParams: undefined,\n};\n","import { ChatlikeApiEndpoint } from \"./subtypes/chatlike-api-endpoint\";\nimport { MakeSystemPrompt } from \"./subtypes/make-system-prompt\";\nimport { MinimalChatGPTMessage } from \"./subtypes/minimal-chat-gpt-message\";\n\nexport interface EditingApiConfig {\n apiEndpoint: ChatlikeApiEndpoint;\n makeSystemPrompt: MakeSystemPrompt;\n fewShotMessages: MinimalChatGPTMessage[];\n forwardedParams: { [key: string]: any } | undefined;\n}\n\nexport const defaultEditingMakeSystemPrompt: MakeSystemPrompt = (\n textareaPurpose,\n contextString\n) => {\n return `You are a versatile writing assistant.\n \nThe user is writing some text.\nThe purpose is: \\\"${textareaPurpose}\\\"\n\nThe user also provides you with a prompt for EDITING some text they are writing. \nYour job is to come up with an EDIT of the text that the user would like to use - AS BEST YOU CAN.\n\nAdjust yourself to the user's style and implied intent.\n\nThe user will provide the following information; use this to infer the best relevant EDIT:\n<TextBeforeCursor>\n<TextToEdit>\n<TextAfterCursor>\n<EditingPrompt>\n\n<YourEditSuggestion>\n\nIf we need to add a whitespace character to the suggested edit text, make sure to explicitly add it in.\n\nThe following external context is also provided. Use it to help you make better suggestions!!!\n\\`\\`\\`\n${contextString}\n\\`\\`\\`\n`;\n};\n\nexport const defaultEditingFewShotMessages: MinimalChatGPTMessage[] = [\n {\n role: \"user\",\n name: \"TextBeforeCursor\",\n content: \"This morning I woke up and went straight to the grocery store. \",\n },\n {\n role: \"user\",\n name: \"TextToEdit\",\n content:\n \"While I was there I also picked up some apples, oranges, and bananas. \",\n },\n {\n role: \"user\",\n name: \"TextAfterCursor\",\n content:\n \"The grocery store was having a sale on fruit, so I decided to stock up.\",\n },\n {\n role: \"user\",\n name: \"EditingPrompt\",\n content: \"I bought a big watermelon\",\n },\n {\n role: \"assistant\",\n content:\n \" When I arrived I went straight to the produce section and picked out a big watermelon. \",\n },\n {\n role: \"user\",\n name: \"TextAfterCursor\",\n content:\n \"and (iii) to the appointment of the Equityholders' Representative pursuant to Section 10.7 of the Merger Agreement and to the provisions thereof.\",\n },\n {\n role: \"user\",\n name: \"TextBeforeCursor\",\n content:\n 'The Optionholder, in the Optionholder\\'s capacity as a holder of vested Options, hereby irrevocably and unconditionally agrees: (i) that the Optionholder shall be deemed an \"Equityholder\" under the Merger Agreement and shall be entitled to the rights and benefits, and subject to the obligations, of an \"Equityholder\" thereunder;',\n },\n {\n role: \"user\",\n name: \"InsertionPrompt\",\n content: \"add section about the optionholder's pro rata share\",\n },\n {\n role: \"assistant\",\n content:\n ' (ii) that, for purposes of this Agreement and the Merger Agreement, the applicable percentage set forth opposite the name of the Optionholder in the Distribution Waterfall shall be such the Optionholder\\'s \"Pro Rata Share\"; ',\n },\n];\n\nexport const defaultEditingApiConfig: EditingApiConfig = {\n apiEndpoint: ChatlikeApiEndpoint.standardOpenAIEndpoint(\n \"/api/copilotkit_chatlike\"\n ),\n makeSystemPrompt: defaultEditingMakeSystemPrompt,\n fewShotMessages: defaultEditingFewShotMessages,\n forwardedParams: undefined,\n};\n","import {\n BaseAutosuggestionsConfig,\n defaultBaseAutosuggestionsConfig,\n} from \"../base\";\nimport {\n SuggestionsApiConfig,\n defaultSuggestionsApiConfig,\n} from \"./suggestions-api-config\";\nimport {\n InsertionsApiConfig,\n defaultInsertionsApiConfig,\n} from \"./insertions-api-config\";\nimport { ChatlikeApiEndpoint } from \".\";\nimport {\n EditingApiConfig,\n defaultEditingApiConfig,\n} from \"./editing-api-config\";\n\n// Like the base autosuggestions config, with 2 additional fields:\n// 1. externalContextCategories: string[] | undefined;\n// 2. instead of apiConfigs, we have chatApiConfigs: a higher-level abstraction that uses a ChatGPT-like API endpoint.\nexport interface AutosuggestionsConfig\n extends Omit<BaseAutosuggestionsConfig, \"apiConfig\"> {\n externalContextCategories: string[] | undefined;\n chatApiConfigs: {\n suggestionsApiConfig: SuggestionsApiConfig;\n insertionApiConfig: InsertionsApiConfig;\n editingApiConfig: EditingApiConfig;\n };\n}\n\nexport const defaultAutosuggestionsConfig: Omit<\n AutosuggestionsConfig,\n \"textareaPurpose\" | \"apiEndpoint\"\n> = {\n ...defaultBaseAutosuggestionsConfig,\n externalContextCategories: undefined,\n chatApiConfigs: {\n suggestionsApiConfig: defaultSuggestionsApiConfig,\n insertionApiConfig: defaultInsertionsApiConfig,\n editingApiConfig: defaultEditingApiConfig,\n },\n};\n"],"mappings":"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","names":[]}
package/package.json CHANGED
@@ -4,7 +4,7 @@
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
7
- "version": "0.19.0-alpha.2",
7
+ "version": "0.19.0-alpha.4",
8
8
  "sideEffects": [
9
9
  "**/*.css"
10
10
  ],
@@ -32,8 +32,8 @@
32
32
  "ts-jest": "^29.1.1",
33
33
  "tsup": "^6.1.3",
34
34
  "typescript": "^4.9.4",
35
- "tailwind-config": "0.1.0",
36
35
  "eslint-config-custom": "0.2.0",
36
+ "tailwind-config": "0.1.0",
37
37
  "tsconfig": "0.3.0"
38
38
  },
39
39
  "dependencies": {
@@ -60,7 +60,7 @@
60
60
  "slate-history": "^0.93.0",
61
61
  "slate-react": "^0.98.1",
62
62
  "tailwind-merge": "^1.13.2",
63
- "@copilotkit/react-core": "0.8.0-alpha.2"
63
+ "@copilotkit/react-core": "0.8.0-alpha.3"
64
64
  },
65
65
  "scripts": {
66
66
  "build": "tsup --treeshake",
@@ -4,7 +4,6 @@ import {
4
4
  EditingEditorState,
5
5
  Generator_InsertionOrEditingSuggestion,
6
6
  } from "../../../types/base/autosuggestions-bare-function";
7
- import { ChipWithIcon } from "../../manual-ui/chip-with-icon";
8
7
  import {
9
8
  FilePointer,
10
9
  SourceSearchBox,
@@ -15,71 +14,59 @@ import React, { useEffect, useRef, useState } from "react";
15
14
 
16
15
  import Chip from "@mui/material/Chip";
17
16
  import Avatar from "@mui/material/Avatar";
17
+ import { streamPromiseFlatten } from "../../../lib/stream-promise-flatten";
18
18
 
19
- export type State_SuggestionAppearing = {
20
- type: "suggestion-appearing";
21
- initialSuggestion: SuggestionSnapshot;
22
- };
23
-
24
- type SuggestionSnapshot = {
25
- adjustmentPrompt: string;
26
- generatingSuggestion: ReadableStream<string>;
19
+ export type SuggestionState = {
27
20
  editorState: EditingEditorState;
28
21
  };
29
22
 
30
- export interface SuggestionAppearingProps {
31
- state: State_SuggestionAppearing;
23
+ export interface HoveringInsertionPromptBoxCoreProps {
24
+ state: SuggestionState;
32
25
  performInsertion: (insertedText: string) => void;
33
- goBack: () => void;
34
26
  insertionOrEditingFunction: Generator_InsertionOrEditingSuggestion;
35
- onGeneratedText: (generatedText: ReadableStream<string>) => void;
36
27
  }
37
28
 
38
- export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
39
- performInsertion,
40
- state,
41
- goBack,
42
- insertionOrEditingFunction,
43
- onGeneratedText,
44
- }) => {
45
- const [adjustmentHistory, setAdjustmentHistory] = useState<
46
- SuggestionSnapshot[]
47
- >([state.initialSuggestion]);
48
-
29
+ export const HoveringInsertionPromptBoxCore: React.FC<
30
+ HoveringInsertionPromptBoxCoreProps
31
+ > = ({ performInsertion, state, insertionOrEditingFunction }) => {
49
32
  const [editSuggestion, setEditSuggestion] = useState<string>("");
50
33
  const [suggestionIsLoading, setSuggestionIsLoading] =
51
34
  useState<boolean>(false);
52
35
 
53
36
  const [adjustmentPrompt, setAdjustmentPrompt] = useState<string>("");
54
- const [adjustmentLoading, setAdjustmentLoading] = useState<boolean>(false);
55
37
 
56
- const suggestionTextAreaRef = useRef<HTMLTextAreaElement>(null);
38
+ const [generatingSuggestion, setGeneratingSuggestion] =
39
+ useState<ReadableStream<string> | null>(null);
40
+
57
41
  const adjustmentTextAreaRef = useRef<HTMLTextAreaElement>(null);
42
+ const suggestionTextAreaRef = useRef<HTMLTextAreaElement>(null);
58
43
 
59
44
  const [filePointers, setFilePointers] = useState<FilePointer[]>([]);
60
45
 
61
46
  useAutosizeTextArea(suggestionTextAreaRef, editSuggestion || "");
62
47
  useAutosizeTextArea(adjustmentTextAreaRef, adjustmentPrompt || "");
63
48
 
64
- // initially focus on the end of the suggestion text area
49
+ // initially focus on the adjustment prompt text area
65
50
  useEffect(() => {
66
- suggestionTextAreaRef.current?.focus();
67
- suggestionTextAreaRef.current?.setSelectionRange(
68
- editSuggestion.length,
69
- editSuggestion.length
70
- );
51
+ adjustmentTextAreaRef.current?.focus();
71
52
  }, []);
72
53
 
73
54
  useEffect(() => {
74
- // Check if the stream is already locked
75
- if (state.initialSuggestion.generatingSuggestion.locked) {
55
+ // if no generating suggestion, do nothing
56
+ if (!generatingSuggestion) {
57
+ return;
58
+ }
59
+
60
+ // Check if the stream is already locked (i.e. already reading from it)
61
+ if (generatingSuggestion.locked) {
76
62
  return;
77
63
  }
64
+
78
65
  // reset the edit suggestion
79
66
  setEditSuggestion("");
80
67
 
81
68
  // read the generating suggestion stream and continuously update the edit suggestion
82
- const reader = state.initialSuggestion.generatingSuggestion.getReader();
69
+ const reader = generatingSuggestion.getReader();
83
70
 
84
71
  const read = async () => {
85
72
  setSuggestionIsLoading(true);
@@ -90,6 +77,7 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
90
77
  }
91
78
  setEditSuggestion((prev) => {
92
79
  const newSuggestion = prev + value;
80
+
93
81
  // Scroll to the bottom of the textarea. We call this here to make sure scroll-to-bottom is synchronous with the state update.
94
82
  if (suggestionTextAreaRef.current) {
95
83
  suggestionTextAreaRef.current.scrollTop =
@@ -114,33 +102,47 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
114
102
 
115
103
  releaseLockIfNotClosed();
116
104
  };
117
- }, [state]);
105
+ }, [generatingSuggestion]);
118
106
 
119
- const generateAdjustment = async () => {
107
+ const begingGeneratingAdjustment = async () => {
120
108
  // don't generate text if the prompt is empty
121
109
  if (!adjustmentPrompt.trim()) {
122
110
  return;
123
111
  }
124
112
 
125
- setAdjustmentLoading(true);
126
- // use insertionOrEditingFunction
127
- const adjustmentSuggestionTextStream = await insertionOrEditingFunction(
128
- {
129
- ...state.initialSuggestion.editorState,
130
- selectedText: editSuggestion,
131
- },
113
+ // if the current edit suggestion is not empty, then use it as the selected text instead of the editor state's selected text
114
+ let editorState = state.editorState;
115
+ if (editSuggestion !== "") {
116
+ editorState.selectedText = editSuggestion;
117
+ }
118
+
119
+ const adjustmentSuggestionTextStreamPromise = insertionOrEditingFunction(
120
+ editorState,
132
121
  adjustmentPrompt,
133
122
  new AbortController().signal
134
123
  );
135
- setAdjustmentLoading(false);
136
- onGeneratedText(adjustmentSuggestionTextStream);
124
+ const adjustmentSuggestionTextStream = streamPromiseFlatten(
125
+ adjustmentSuggestionTextStreamPromise
126
+ );
127
+
128
+ setGeneratingSuggestion(adjustmentSuggestionTextStream);
137
129
  };
138
130
 
139
- const showLoading = suggestionIsLoading || adjustmentLoading;
131
+ const isLoading = suggestionIsLoading;
132
+
133
+ const textToEdit = editSuggestion || state.editorState.selectedText;
134
+ const adjustmentLabel =
135
+ textToEdit === ""
136
+ ? "Describe the text you want to insert"
137
+ : "Describe adjustments to the suggested text";
138
+ const placeholder =
139
+ textToEdit === ""
140
+ ? "e.g. 'summarize the client's top 3 pain-points from @CallTranscript'"
141
+ : "e.g. 'make it more formal', 'be more specific', ...";
140
142
 
141
143
  const AdjustmentPromptComponent = (
142
144
  <>
143
- <Label className="">Describe adjustments to the suggested text:</Label>
145
+ <Label className="">{adjustmentLabel}</Label>
144
146
  <div className="relative w-full flex items-center">
145
147
  <textarea
146
148
  disabled={suggestionIsLoading}
@@ -153,16 +155,16 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
153
155
  setAdjustmentPrompt(adjustmentPrompt + "\n");
154
156
  } else if (e.key === "Enter") {
155
157
  e.preventDefault();
156
- generateAdjustment();
158
+ begingGeneratingAdjustment();
157
159
  }
158
160
  }}
159
- placeholder={'"make it more formal", "be more specific", ...'}
161
+ placeholder={placeholder}
160
162
  style={{ minHeight: "3rem" }}
161
163
  className="w-full bg-slate-100 h-auto h-min-14 text-sm p-2 rounded-md resize-none overflow-visible focus:outline-none focus:ring-0 focus:border-non pr-[3rem]"
162
164
  rows={1}
163
165
  />
164
166
  <button
165
- onClick={generateAdjustment}
167
+ onClick={begingGeneratingAdjustment}
166
168
  className="absolute right-2 bg-blue-500 text-white w-8 h-8 rounded-full flex items-center justify-center"
167
169
  >
168
170
  <i className="material-icons">arrow_forward</i>
@@ -176,7 +178,7 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
176
178
  <div className="flex justify-between items-end w-full">
177
179
  <Label className="mt-4">Suggested:</Label>
178
180
  <div className="ml-auto">
179
- {showLoading && (
181
+ {isLoading && (
180
182
  <div className="flex justify-center items-center">
181
183
  <div
182
184
  className="inline-block h-4 w-4 animate-spin rounded-full border-4 border-solid border-current border-r-transparent align-[-0.125em] motion-reduce:animate-[spin_1.5s_linear_infinite]"
@@ -193,7 +195,7 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
193
195
  <textarea
194
196
  ref={suggestionTextAreaRef}
195
197
  value={editSuggestion}
196
- disabled={adjustmentLoading}
198
+ disabled={suggestionIsLoading}
197
199
  onChange={(e) => setEditSuggestion(e.target.value)}
198
200
  className="w-full text-base p-2 border border-gray-300 rounded-md resize-none bg-green-50"
199
201
  style={{ overflow: "auto", maxHeight: "10em" }}
@@ -203,15 +205,6 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
203
205
 
204
206
  const SubmitComponent = (
205
207
  <div className="flex w-full gap-4 justify-start">
206
- <Button
207
- className=" bg-gray-300"
208
- onClick={() => {
209
- goBack();
210
- }}
211
- >
212
- <i className="material-icons">arrow_back</i> Back
213
- </Button>
214
-
215
208
  <Button
216
209
  className=" bg-green-700 text-white"
217
210
  onClick={() => {
@@ -254,8 +247,8 @@ export const SuggestionAppearing: React.FC<SuggestionAppearingProps> = ({
254
247
  }}
255
248
  />
256
249
  )}
257
- {SuggestionComponent}
258
- {SubmitComponent}
250
+ {generatingSuggestion ? SuggestionComponent : null}
251
+ {generatingSuggestion ? SubmitComponent : null}
259
252
  </div>
260
253
  );
261
254
  };
@@ -270,7 +263,8 @@ export const IncludedFilesPreview: React.FC<IncludedFilesPreviewProps> = ({
270
263
  setIncludedFiles,
271
264
  }) => {
272
265
  return (
273
- <div className="flex flex-col gap-2">
266
+ <div className="flex flex-col gap-2 mt-2">
267
+ <Label className="">Included context:</Label>
274
268
  <div className="flex flex-wrap gap-2">
275
269
  {includedFiles.map((filePointer, index) => {
276
270
  return (
@@ -1,16 +1,10 @@
1
1
  import React, { useCallback, useState } from "react";
2
- import {
3
- State_SuggestionAppearing,
4
- SuggestionAppearing,
5
- } from "./mode-suggestion-appearing";
6
- import { PreSuggestion, State_PreSuggestion } from "./mode-pre-suggestion";
2
+ import { HoveringInsertionPromptBoxCore } from "./hovering-insertion-prompt-box-core";
7
3
  import {
8
4
  EditingEditorState,
9
5
  InsertionEditorApiConfig,
10
6
  } from "../../../types/base/autosuggestions-bare-function";
11
7
 
12
- type InsertionPromptState = State_PreSuggestion | State_SuggestionAppearing;
13
-
14
8
  export interface Props {
15
9
  editorState: EditingEditorState;
16
10
  apiConfig: InsertionEditorApiConfig;
@@ -19,55 +13,18 @@ export interface Props {
19
13
  }
20
14
 
21
15
  export const HoveringInsertionPromptBox: React.FC<Props> = (props) => {
22
- const [insertionPrompt, setInsertionPrompt] = useState<string>("");
23
- const [mode, setMode] = useState<InsertionPromptState>({
24
- type: "pre-suggestion",
25
- });
26
-
27
- const handleGeneratedText = useCallback(
28
- (generatingText: ReadableStream<string>) => {
29
- setMode({
30
- type: "suggestion-appearing",
31
- initialSuggestion: {
32
- editorState: props.editorState,
33
- adjustmentPrompt: insertionPrompt,
34
- generatingSuggestion: generatingText,
35
- },
36
- });
37
- },
38
- [setMode, insertionPrompt]
39
- );
40
-
41
- const goBack = () => {
42
- setMode({ type: "pre-suggestion" });
43
- };
44
-
45
16
  return (
46
17
  <div
47
18
  className="flex flex-col justify-center items-center space-y-4 rounded-md border shadow-lg p-4 border-gray- bg-white"
48
- style={{ width: "30rem" }}
19
+ style={{ width: "35rem" }}
49
20
  >
50
- {mode.type === "pre-suggestion" ? (
51
- <PreSuggestion
52
- {...props}
53
- insertionOrEditingFunction={
54
- props.apiConfig.insertionOrEditingFunction
55
- }
56
- insertionOrEditingPrompt={insertionPrompt}
57
- setInsertionOrEditingPrompt={setInsertionPrompt}
58
- onGeneratedText={handleGeneratedText}
59
- />
60
- ) : (
61
- <SuggestionAppearing
62
- {...props}
63
- state={mode}
64
- goBack={goBack}
65
- insertionOrEditingFunction={
66
- props.apiConfig.insertionOrEditingFunction
67
- }
68
- onGeneratedText={handleGeneratedText}
69
- />
70
- )}
21
+ <HoveringInsertionPromptBoxCore
22
+ state={{
23
+ editorState: props.editorState,
24
+ }}
25
+ performInsertion={props.performInsertion}
26
+ insertionOrEditingFunction={props.apiConfig.insertionOrEditingFunction}
27
+ />
71
28
  </div>
72
29
  );
73
30
  };
@@ -19,7 +19,7 @@ import {
19
19
  Smile,
20
20
  User,
21
21
  } from "lucide-react";
22
- import { IconForFilePointer } from "../hovering-toolbar/text-insertion-prompt-box/mode-suggestion-appearing";
22
+ import { IconForFilePointer } from "../hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core";
23
23
 
24
24
  export interface FilePointer {
25
25
  name: string;
@@ -73,8 +73,8 @@ export function SourceSearchBox(props: SourceSearchBoxProps) {
73
73
  props.onSelectedFile(filePointer);
74
74
  }}
75
75
  >
76
- <div className="flex flex-row gap-3 items-center bg-slate-400 ">
77
- <Logo size="40px">
76
+ <div className="flex flex-row gap-3 items-center">
77
+ <Logo size="30px">
78
78
  <IconForFilePointer
79
79
  filePointer={filePointer}
80
80
  className="mx-auto my-auto"
@@ -114,20 +114,17 @@ export function SourceSearchBox(props: SourceSearchBoxProps) {
114
114
 
115
115
  export function Logo({
116
116
  children,
117
- size = "20px",
117
+ size = "30px",
118
118
  }: {
119
119
  children: React.ReactNode;
120
120
  size?: string;
121
121
  }) {
122
122
  return (
123
123
  <div
124
- className={""}
125
- style={{
126
- width: size,
127
- height: size,
128
- }}
124
+ className="flex items-center justify-center"
125
+ style={{ width: size, height: size }}
129
126
  >
130
- <div className={""}>{children}</div>
127
+ {children}
131
128
  </div>
132
129
  );
133
130
  }
@@ -117,7 +117,7 @@ const CommandItem = React.forwardRef<
117
117
  <CommandPrimitive.Item
118
118
  ref={ref}
119
119
  className={cn(
120
- "relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none aria-selected:bg-accent aria-selected:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
120
+ "relative flex cursor-default select-none items-center rounded-sm text-sm outline-none aria-selected:bg-accent aria-selected:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
121
121
  className
122
122
  )}
123
123
  {...props}
@@ -0,0 +1,25 @@
1
+ export function streamPromiseFlatten<A>(
2
+ promise: Promise<ReadableStream<A>>
3
+ ): ReadableStream<A> {
4
+ return new ReadableStream<A>({
5
+ async start(controller) {
6
+ try {
7
+ const stream = await promise;
8
+ const reader = stream.getReader();
9
+
10
+ while (true) {
11
+ const { done, value } = await reader.read();
12
+
13
+ if (done) {
14
+ controller.close();
15
+ return;
16
+ }
17
+
18
+ controller.enqueue(value);
19
+ }
20
+ } catch (error) {
21
+ controller.error(error);
22
+ }
23
+ },
24
+ });
25
+ }
@@ -1,47 +0,0 @@
1
- import { cn } from './chunk-KGKLUWKW.mjs';
2
- import { __objRest, __spreadValues } from './chunk-MRXNTQOX.mjs';
3
- import * as React from 'react';
4
- import { Slot } from '@radix-ui/react-slot';
5
- import { cva } from 'class-variance-authority';
6
- import { jsx } from 'react/jsx-runtime';
7
-
8
- var buttonVariants = cva(
9
- "inline-flex items-center justify-center rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50",
10
- {
11
- variants: {
12
- variant: {
13
- default: "bg-primary text-primary-foreground hover:bg-primary/90",
14
- destructive: "bg-destructive text-destructive-foreground hover:bg-destructive/90",
15
- outline: "border border-input bg-background hover:bg-accent hover:text-accent-foreground",
16
- secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
17
- ghost: "hover:bg-accent hover:text-accent-foreground",
18
- link: "text-primary underline-offset-4 hover:underline"
19
- },
20
- size: {
21
- default: "h-10 px-4 py-2",
22
- sm: "h-9 rounded-md px-3",
23
- lg: "h-11 rounded-md px-8",
24
- icon: "h-10 w-10"
25
- }
26
- },
27
- defaultVariants: {
28
- variant: "default",
29
- size: "default"
30
- }
31
- }
32
- );
33
- var Button = React.forwardRef(
34
- (_a, ref) => {
35
- var _b = _a, { className, variant, size, asChild = false } = _b, props = __objRest(_b, ["className", "variant", "size", "asChild"]);
36
- const Comp = asChild ? Slot : "button";
37
- return /* @__PURE__ */ jsx(Comp, __spreadValues({
38
- className: cn(buttonVariants({ variant, size, className })),
39
- ref
40
- }, props));
41
- }
42
- );
43
- Button.displayName = "Button";
44
-
45
- export { Button, buttonVariants };
46
- //# sourceMappingURL=out.js.map
47
- //# sourceMappingURL=chunk-2NURR2DX.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/ui/button.tsx"],"names":[],"mappings":";;;;;;;;;AAAA,YAAY,WAAW;AACvB,SAAS,YAAY;AACrB,SAAS,WAA8B;AA2CjC;AAvCN,IAAM,iBAAiB;AAAA,EACrB;AAAA,EACA;AAAA,IACE,UAAU;AAAA,MACR,SAAS;AAAA,QACP,SAAS;AAAA,QACT,aACE;AAAA,QACF,SACE;AAAA,QACF,WACE;AAAA,QACF,OAAO;AAAA,QACP,MAAM;AAAA,MACR;AAAA,MACA,MAAM;AAAA,QACJ,SAAS;AAAA,QACT,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,MAAM;AAAA,MACR;AAAA,IACF;AAAA,IACA,iBAAiB;AAAA,MACf,SAAS;AAAA,MACT,MAAM;AAAA,IACR;AAAA,EACF;AACF;AAQA,IAAM,SAAe;AAAA,EACnB,CAAC,IAAyD,QAAQ;AAAjE,iBAAE,aAAW,SAAS,MAAM,UAAU,MA1CzC,IA0CG,IAAgD,kBAAhD,IAAgD,CAA9C,aAAW,WAAS,QAAM;AAC3B,UAAM,OAAO,UAAU,OAAO;AAC9B,WACE,oBAAC;AAAA,MACC,WAAW,GAAG,eAAe,EAAE,SAAS,MAAM,UAAU,CAAC,CAAC;AAAA,MAC1D;AAAA,OACI,MACN;AAAA,EAEJ;AACF;AACA,OAAO,cAAc","sourcesContent":["import * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"../../lib/utils\";\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n {\n variants: {\n variant: {\n default: \"bg-primary text-primary-foreground hover:bg-primary/90\",\n destructive:\n \"bg-destructive text-destructive-foreground hover:bg-destructive/90\",\n outline:\n \"border border-input bg-background hover:bg-accent hover:text-accent-foreground\",\n secondary:\n \"bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n ghost: \"hover:bg-accent hover:text-accent-foreground\",\n link: \"text-primary underline-offset-4 hover:underline\",\n },\n size: {\n default: \"h-10 px-4 py-2\",\n sm: \"h-9 rounded-md px-3\",\n lg: \"h-11 rounded-md px-8\",\n icon: \"h-10 w-10\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n ({ className, variant, size, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\";\n return (\n <Comp\n className={cn(buttonVariants({ variant, size, className }))}\n ref={ref}\n {...props}\n />\n );\n }\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n"]}
@@ -1,106 +0,0 @@
1
- import { Dialog, DialogContent } from './chunk-O5OWT5GE.mjs';
2
- import { cn } from './chunk-KGKLUWKW.mjs';
3
- import { __objRest, __spreadValues, __spreadProps } from './chunk-MRXNTQOX.mjs';
4
- import * as React from 'react';
5
- import { Command as Command$1 } from 'cmdk';
6
- import { jsx } from 'react/jsx-runtime';
7
-
8
- var Command = React.forwardRef((_a, ref) => {
9
- var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
10
- return /* @__PURE__ */ jsx(Command$1, __spreadValues({
11
- ref,
12
- className: cn(
13
- "flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",
14
- className
15
- )
16
- }, props));
17
- });
18
- Command.displayName = Command$1.displayName;
19
- var CommandDialog = (_a) => {
20
- var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
21
- return /* @__PURE__ */ jsx(Dialog, __spreadProps(__spreadValues({}, props), {
22
- children: /* @__PURE__ */ jsx(DialogContent, {
23
- className: "overflow-hidden p-0 shadow-lg",
24
- children: /* @__PURE__ */ jsx(Command, {
25
- className: "[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5",
26
- children
27
- })
28
- })
29
- }));
30
- };
31
- var CommandInput = React.forwardRef((_a, ref) => {
32
- var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
33
- return /* @__PURE__ */ jsx("div", {
34
- className: "flex items-center border-b px-3",
35
- "cmdk-input-wrapper": "",
36
- children: /* @__PURE__ */ jsx(Command$1.Input, __spreadValues({
37
- ref,
38
- className: cn(
39
- "flex h-11 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50",
40
- className
41
- )
42
- }, props))
43
- });
44
- });
45
- CommandInput.displayName = Command$1.Input.displayName;
46
- var CommandList = React.forwardRef((_a, ref) => {
47
- var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
48
- return /* @__PURE__ */ jsx(Command$1.List, __spreadValues({
49
- ref,
50
- className: cn("max-h-[300px] overflow-y-auto overflow-x-hidden", className)
51
- }, props));
52
- });
53
- CommandList.displayName = Command$1.List.displayName;
54
- var CommandEmpty = React.forwardRef((props, ref) => /* @__PURE__ */ jsx(Command$1.Empty, __spreadValues({
55
- ref,
56
- className: "py-6 text-center text-sm"
57
- }, props)));
58
- CommandEmpty.displayName = Command$1.Empty.displayName;
59
- var CommandGroup = React.forwardRef((_a, ref) => {
60
- var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
61
- return /* @__PURE__ */ jsx(Command$1.Group, __spreadValues({
62
- ref,
63
- className: cn(
64
- "overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",
65
- className
66
- )
67
- }, props));
68
- });
69
- CommandGroup.displayName = Command$1.Group.displayName;
70
- var CommandSeparator = React.forwardRef((_a, ref) => {
71
- var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
72
- return /* @__PURE__ */ jsx(Command$1.Separator, __spreadValues({
73
- ref,
74
- className: cn("-mx-1 h-px bg-border", className)
75
- }, props));
76
- });
77
- CommandSeparator.displayName = Command$1.Separator.displayName;
78
- var CommandItem = React.forwardRef((_a, ref) => {
79
- var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
80
- return /* @__PURE__ */ jsx(Command$1.Item, __spreadValues({
81
- ref,
82
- className: cn(
83
- "relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none aria-selected:bg-accent aria-selected:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
84
- className
85
- )
86
- }, props));
87
- });
88
- CommandItem.displayName = Command$1.Item.displayName;
89
- var CommandShortcut = (_a) => {
90
- var _b = _a, {
91
- className
92
- } = _b, props = __objRest(_b, [
93
- "className"
94
- ]);
95
- return /* @__PURE__ */ jsx("span", __spreadValues({
96
- className: cn(
97
- "ml-auto text-xs tracking-widest text-muted-foreground",
98
- className
99
- )
100
- }, props));
101
- };
102
- CommandShortcut.displayName = "CommandShortcut";
103
-
104
- export { Command, CommandDialog, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList, CommandSeparator, CommandShortcut };
105
- //# sourceMappingURL=out.js.map
106
- //# sourceMappingURL=chunk-3YJ63D5D.mjs.map