@copilotkit/react-textarea 0.24.0 → 0.26.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (277) hide show
  1. package/.turbo/turbo-build.log +313 -309
  2. package/CHANGELOG.md +22 -0
  3. package/dist/components/base-copilot-textarea/base-copilot-textarea.d.ts +29 -0
  4. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +1745 -35
  5. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs.map +1 -1
  6. package/dist/components/base-copilot-textarea/render-element.mjs +51 -3
  7. package/dist/components/base-copilot-textarea/render-element.mjs.map +1 -1
  8. package/dist/components/base-copilot-textarea/render-placeholder.mjs +49 -3
  9. package/dist/components/base-copilot-textarea/render-placeholder.mjs.map +1 -1
  10. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs +86 -4
  11. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs.map +1 -1
  12. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs +57 -3
  13. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs.map +1 -1
  14. package/dist/components/copilot-textarea/copilot-textarea.d.ts +3 -0
  15. package/dist/components/copilot-textarea/copilot-textarea.mjs +2202 -47
  16. package/dist/components/copilot-textarea/copilot-textarea.mjs.map +1 -1
  17. package/dist/components/hovering-toolbar/hovering-editor-provider.d.ts +7 -3
  18. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs +17 -3
  19. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs.map +1 -1
  20. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs +137 -3
  21. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs.map +1 -1
  22. package/dist/components/hovering-toolbar/hovering-toolbar.mjs +875 -18
  23. package/dist/components/hovering-toolbar/hovering-toolbar.mjs.map +1 -1
  24. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs +558 -12
  25. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs.map +1 -1
  26. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs +581 -13
  27. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs.map +1 -1
  28. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs +102 -5
  29. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs.map +1 -1
  30. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs +581 -14
  31. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs.map +1 -1
  32. package/dist/components/index.mjs +2203 -48
  33. package/dist/components/index.mjs.map +1 -1
  34. package/dist/components/manual-ui/chip-with-icon.mjs +11 -27
  35. package/dist/components/manual-ui/chip-with-icon.mjs.map +1 -1
  36. package/dist/components/source-search-box/source-search-box.mjs +211 -6
  37. package/dist/components/source-search-box/source-search-box.mjs.map +1 -1
  38. package/dist/components/ui/button.mjs +85 -4
  39. package/dist/components/ui/button.mjs.map +1 -1
  40. package/dist/components/ui/card.mjs +96 -52
  41. package/dist/components/ui/card.mjs.map +1 -1
  42. package/dist/components/ui/command.mjs +244 -5
  43. package/dist/components/ui/command.mjs.map +1 -1
  44. package/dist/components/ui/dialog.mjs +144 -4
  45. package/dist/components/ui/dialog.mjs.map +1 -1
  46. package/dist/components/ui/label.mjs +60 -4
  47. package/dist/components/ui/label.mjs.map +1 -1
  48. package/dist/components/ui/separator.mjs +58 -15
  49. package/dist/components/ui/separator.mjs.map +1 -1
  50. package/dist/components/ui/textarea.mjs +58 -14
  51. package/dist/components/ui/textarea.mjs.map +1 -1
  52. package/dist/context/index.d.ts +1 -0
  53. package/dist/context/index.mjs +0 -2
  54. package/dist/context/index.mjs.map +1 -1
  55. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.d.ts +1 -1
  56. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs +158 -6
  57. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs.map +1 -1
  58. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs +168 -4
  59. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs.map +1 -1
  60. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs +148 -5
  61. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs.map +1 -1
  62. package/dist/hooks/index.d.ts +1 -0
  63. package/dist/hooks/index.mjs +0 -2
  64. package/dist/hooks/index.mjs.map +1 -1
  65. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +147 -14
  66. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map +1 -1
  67. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs +193 -14
  68. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs.map +1 -1
  69. package/dist/hooks/misc/use-autosize-textarea.mjs +15 -3
  70. package/dist/hooks/misc/use-autosize-textarea.mjs.map +1 -1
  71. package/dist/index.mjs +2206 -50
  72. package/dist/index.mjs.map +1 -1
  73. package/dist/lib/debouncer.mjs +51 -3
  74. package/dist/lib/debouncer.mjs.map +1 -1
  75. package/dist/lib/editor-to-text.mjs +43 -3
  76. package/dist/lib/editor-to-text.mjs.map +1 -1
  77. package/dist/lib/get-text-around-cursor.mjs +102 -3
  78. package/dist/lib/get-text-around-cursor.mjs.map +1 -1
  79. package/dist/lib/retry.mjs +17 -3
  80. package/dist/lib/retry.mjs.map +1 -1
  81. package/dist/lib/slatejs-edits/add-autocompletions.mjs +25 -3
  82. package/dist/lib/slatejs-edits/add-autocompletions.mjs.map +1 -1
  83. package/dist/lib/slatejs-edits/clear-autocompletions.mjs +20 -3
  84. package/dist/lib/slatejs-edits/clear-autocompletions.mjs.map +1 -1
  85. package/dist/lib/slatejs-edits/replace-text.mjs +27 -3
  86. package/dist/lib/slatejs-edits/replace-text.mjs.map +1 -1
  87. package/dist/lib/slatejs-edits/with-partial-history.mjs +106 -3
  88. package/dist/lib/slatejs-edits/with-partial-history.mjs.map +1 -1
  89. package/dist/lib/stream-promise-flatten.mjs +47 -3
  90. package/dist/lib/stream-promise-flatten.mjs.map +1 -1
  91. package/dist/lib/utils.mjs +71 -3
  92. package/dist/lib/utils.mjs.map +1 -1
  93. package/dist/lib/utils.test.d.ts +1 -0
  94. package/dist/lib/utils.test.mjs +0 -1
  95. package/dist/lib/utils.test.mjs.map +1 -1
  96. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs +0 -2
  97. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs.map +1 -1
  98. package/dist/types/autosuggestions-config/autosuggestions-config.mjs +265 -8
  99. package/dist/types/autosuggestions-config/autosuggestions-config.mjs.map +1 -1
  100. package/dist/types/autosuggestions-config/editing-api-config.mjs +81 -3
  101. package/dist/types/autosuggestions-config/editing-api-config.mjs.map +1 -1
  102. package/dist/types/autosuggestions-config/index.mjs +327 -10
  103. package/dist/types/autosuggestions-config/index.mjs.map +1 -1
  104. package/dist/types/autosuggestions-config/insertions-api-config.mjs +75 -3
  105. package/dist/types/autosuggestions-config/insertions-api-config.mjs.map +1 -1
  106. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs +83 -3
  107. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs.map +1 -1
  108. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs +0 -2
  109. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs.map +1 -1
  110. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs +0 -2
  111. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs.map +1 -1
  112. package/dist/types/autosuggestions-config/suggestions-api-config.mjs +64 -3
  113. package/dist/types/autosuggestions-config/suggestions-api-config.mjs.map +1 -1
  114. package/dist/types/base/autosuggestion-state.mjs +0 -2
  115. package/dist/types/base/autosuggestion-state.mjs.map +1 -1
  116. package/dist/types/base/autosuggestions-bare-function.mjs +0 -2
  117. package/dist/types/base/autosuggestions-bare-function.mjs.map +1 -1
  118. package/dist/types/base/base-autosuggestions-config.d.ts +55 -2
  119. package/dist/types/base/base-autosuggestions-config.mjs +26 -3
  120. package/dist/types/base/base-autosuggestions-config.mjs.map +1 -1
  121. package/dist/types/base/base-copilot-textarea-props.mjs +0 -2
  122. package/dist/types/base/base-copilot-textarea-props.mjs.map +1 -1
  123. package/dist/types/base/custom-editor.mjs +0 -2
  124. package/dist/types/base/custom-editor.mjs.map +1 -1
  125. package/dist/types/base/editor-autocomplete-state.mjs +17 -4
  126. package/dist/types/base/editor-autocomplete-state.mjs.map +1 -1
  127. package/dist/types/base/index.mjs +26 -4
  128. package/dist/types/base/index.mjs.map +1 -1
  129. package/dist/types/html-copilot-textarea-element.mjs +0 -2
  130. package/dist/types/html-copilot-textarea-element.mjs.map +1 -1
  131. package/dist/types/index.mjs +328 -12
  132. package/dist/types/index.mjs.map +1 -1
  133. package/package.json +7 -7
  134. package/src/components/base-copilot-textarea/base-copilot-textarea.tsx +79 -45
  135. package/src/components/base-copilot-textarea/render-element.tsx +3 -5
  136. package/src/components/base-copilot-textarea/render-placeholder.tsx +2 -4
  137. package/src/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.tsx +22 -3
  138. package/src/components/base-copilot-textarea/use-add-branding-css.tsx +2 -4
  139. package/src/components/copilot-textarea/copilot-textarea.tsx +14 -18
  140. package/src/components/hovering-toolbar/hovering-editor-provider.tsx +7 -5
  141. package/src/components/hovering-toolbar/hovering-toolbar-components.tsx +14 -31
  142. package/src/components/hovering-toolbar/hovering-toolbar.tsx +4 -16
  143. package/src/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.tsx +11 -25
  144. package/src/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.tsx +2 -7
  145. package/src/components/manual-ui/chip-with-icon.tsx +3 -12
  146. package/src/components/source-search-box/source-search-box.tsx +2 -12
  147. package/src/components/ui/button.tsx +6 -13
  148. package/src/components/ui/card.tsx +35 -65
  149. package/src/components/ui/command.tsx +8 -21
  150. package/src/components/ui/dialog.tsx +8 -29
  151. package/src/components/ui/label.tsx +3 -8
  152. package/src/components/ui/separator.tsx +13 -18
  153. package/src/components/ui/textarea.tsx +3 -4
  154. package/src/hooks/base-copilot-textarea-implementation/use-autosuggestions.ts +13 -27
  155. package/src/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.tsx +1 -5
  156. package/src/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.ts +4 -11
  157. package/src/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.tsx +5 -10
  158. package/src/hooks/make-autosuggestions-function/use-make-standard-insertion-function.tsx +15 -35
  159. package/src/hooks/misc/use-autosize-textarea.tsx +1 -4
  160. package/src/lib/debouncer.ts +1 -3
  161. package/src/lib/editor-to-text.ts +4 -7
  162. package/src/lib/get-text-around-cursor.ts +2 -14
  163. package/src/lib/retry.tsx +1 -1
  164. package/src/lib/slatejs-edits/add-autocompletions.ts +2 -2
  165. package/src/lib/slatejs-edits/clear-autocompletions.ts +1 -4
  166. package/src/lib/slatejs-edits/replace-text.ts +1 -1
  167. package/src/lib/slatejs-edits/with-partial-history.ts +4 -11
  168. package/src/lib/stream-promise-flatten.ts +1 -3
  169. package/src/lib/utils.ts +4 -8
  170. package/src/types/autosuggestions-config/autosuggestions-config-user-specified.tsx +3 -7
  171. package/src/types/autosuggestions-config/autosuggestions-config.tsx +5 -18
  172. package/src/types/autosuggestions-config/editing-api-config.tsx +3 -5
  173. package/src/types/autosuggestions-config/insertions-api-config.tsx +2 -3
  174. package/src/types/autosuggestions-config/subtypes/chatlike-api-endpoint.tsx +18 -26
  175. package/src/types/autosuggestions-config/subtypes/make-system-prompt.ts +1 -4
  176. package/src/types/autosuggestions-config/suggestions-api-config.tsx +2 -3
  177. package/src/types/base/autosuggestions-bare-function.ts +2 -2
  178. package/src/types/base/base-autosuggestions-config.tsx +80 -3
  179. package/src/types/base/editor-autocomplete-state.ts +1 -1
  180. package/dist/chunk-2NURR2DX.mjs +0 -47
  181. package/dist/chunk-2NURR2DX.mjs.map +0 -1
  182. package/dist/chunk-3L6CNVCE.mjs +0 -108
  183. package/dist/chunk-3L6CNVCE.mjs.map +0 -1
  184. package/dist/chunk-463BFNUP.mjs +0 -77
  185. package/dist/chunk-463BFNUP.mjs.map +0 -1
  186. package/dist/chunk-4HHYJGZE.mjs +0 -117
  187. package/dist/chunk-4HHYJGZE.mjs.map +0 -1
  188. package/dist/chunk-4LOLCQGR.mjs +0 -50
  189. package/dist/chunk-4LOLCQGR.mjs.map +0 -1
  190. package/dist/chunk-4S5ZJH3I.mjs +0 -18
  191. package/dist/chunk-4S5ZJH3I.mjs.map +0 -1
  192. package/dist/chunk-4UYKBG35.mjs +0 -57
  193. package/dist/chunk-4UYKBG35.mjs.map +0 -1
  194. package/dist/chunk-5EJ5XOGP.mjs +0 -22
  195. package/dist/chunk-5EJ5XOGP.mjs.map +0 -1
  196. package/dist/chunk-5FO6ISW4.mjs +0 -3
  197. package/dist/chunk-5FO6ISW4.mjs.map +0 -1
  198. package/dist/chunk-6Z2ATUNY.mjs +0 -15
  199. package/dist/chunk-6Z2ATUNY.mjs.map +0 -1
  200. package/dist/chunk-AQHORK66.mjs +0 -49
  201. package/dist/chunk-AQHORK66.mjs.map +0 -1
  202. package/dist/chunk-AXN37AHC.mjs +0 -80
  203. package/dist/chunk-AXN37AHC.mjs.map +0 -1
  204. package/dist/chunk-CSGFJU3L.mjs +0 -65
  205. package/dist/chunk-CSGFJU3L.mjs.map +0 -1
  206. package/dist/chunk-DE5K76I2.mjs +0 -3
  207. package/dist/chunk-DE5K76I2.mjs.map +0 -1
  208. package/dist/chunk-F3MHL6ZY.mjs +0 -25
  209. package/dist/chunk-F3MHL6ZY.mjs.map +0 -1
  210. package/dist/chunk-GCMQHIRF.mjs +0 -29
  211. package/dist/chunk-GCMQHIRF.mjs.map +0 -1
  212. package/dist/chunk-GIJ3JZ4P.mjs +0 -224
  213. package/dist/chunk-GIJ3JZ4P.mjs.map +0 -1
  214. package/dist/chunk-GUH3Y2H4.mjs +0 -19
  215. package/dist/chunk-GUH3Y2H4.mjs.map +0 -1
  216. package/dist/chunk-H4VKQGVU.mjs +0 -3
  217. package/dist/chunk-H4VKQGVU.mjs.map +0 -1
  218. package/dist/chunk-IU3WTXLQ.mjs +0 -3
  219. package/dist/chunk-IU3WTXLQ.mjs.map +0 -1
  220. package/dist/chunk-IXJ2HCOA.mjs +0 -101
  221. package/dist/chunk-IXJ2HCOA.mjs.map +0 -1
  222. package/dist/chunk-JAFCXEPU.mjs +0 -10
  223. package/dist/chunk-JAFCXEPU.mjs.map +0 -1
  224. package/dist/chunk-JHTAOLEW.mjs +0 -63
  225. package/dist/chunk-JHTAOLEW.mjs.map +0 -1
  226. package/dist/chunk-JYVC4AW3.mjs +0 -205
  227. package/dist/chunk-JYVC4AW3.mjs.map +0 -1
  228. package/dist/chunk-KCHYD3EB.mjs +0 -107
  229. package/dist/chunk-KCHYD3EB.mjs.map +0 -1
  230. package/dist/chunk-KGKLUWKW.mjs +0 -47
  231. package/dist/chunk-KGKLUWKW.mjs.map +0 -1
  232. package/dist/chunk-L7VVZH4Q.mjs +0 -3
  233. package/dist/chunk-L7VVZH4Q.mjs.map +0 -1
  234. package/dist/chunk-LNAIMEB2.mjs +0 -34
  235. package/dist/chunk-LNAIMEB2.mjs.map +0 -1
  236. package/dist/chunk-MMVDU6DF.mjs +0 -3
  237. package/dist/chunk-MMVDU6DF.mjs.map +0 -1
  238. package/dist/chunk-MPME5BW2.mjs +0 -59
  239. package/dist/chunk-MPME5BW2.mjs.map +0 -1
  240. package/dist/chunk-MRXNTQOX.mjs +0 -55
  241. package/dist/chunk-MRXNTQOX.mjs.map +0 -1
  242. package/dist/chunk-ND5PXTAW.mjs +0 -17
  243. package/dist/chunk-ND5PXTAW.mjs.map +0 -1
  244. package/dist/chunk-NKW5OU2S.mjs +0 -33
  245. package/dist/chunk-NKW5OU2S.mjs.map +0 -1
  246. package/dist/chunk-O4MHJSK2.mjs +0 -21
  247. package/dist/chunk-O4MHJSK2.mjs.map +0 -1
  248. package/dist/chunk-O5OWT5GE.mjs +0 -114
  249. package/dist/chunk-O5OWT5GE.mjs.map +0 -1
  250. package/dist/chunk-OD7ZMOVE.mjs +0 -45
  251. package/dist/chunk-OD7ZMOVE.mjs.map +0 -1
  252. package/dist/chunk-OELUUJZY.mjs +0 -16
  253. package/dist/chunk-OELUUJZY.mjs.map +0 -1
  254. package/dist/chunk-QJDMIGLU.mjs +0 -38
  255. package/dist/chunk-QJDMIGLU.mjs.map +0 -1
  256. package/dist/chunk-RQHOUUXQ.mjs +0 -29
  257. package/dist/chunk-RQHOUUXQ.mjs.map +0 -1
  258. package/dist/chunk-RR6OQGTI.mjs +0 -74
  259. package/dist/chunk-RR6OQGTI.mjs.map +0 -1
  260. package/dist/chunk-UHD44NC5.mjs +0 -101
  261. package/dist/chunk-UHD44NC5.mjs.map +0 -1
  262. package/dist/chunk-WADHCMPK.mjs +0 -3
  263. package/dist/chunk-WADHCMPK.mjs.map +0 -1
  264. package/dist/chunk-WJHSY5T6.mjs +0 -3
  265. package/dist/chunk-WJHSY5T6.mjs.map +0 -1
  266. package/dist/chunk-WJYQWL4I.mjs +0 -27
  267. package/dist/chunk-WJYQWL4I.mjs.map +0 -1
  268. package/dist/chunk-WLPYYGES.mjs +0 -109
  269. package/dist/chunk-WLPYYGES.mjs.map +0 -1
  270. package/dist/chunk-XHUMROEY.mjs +0 -91
  271. package/dist/chunk-XHUMROEY.mjs.map +0 -1
  272. package/dist/chunk-YQU7WG7T.mjs +0 -83
  273. package/dist/chunk-YQU7WG7T.mjs.map +0 -1
  274. package/dist/chunk-YTOPHPSG.mjs +0 -45
  275. package/dist/chunk-YTOPHPSG.mjs.map +0 -1
  276. package/dist/chunk-YW3REYX6.mjs +0 -23
  277. package/dist/chunk-YW3REYX6.mjs.map +0 -1
@@ -1,205 +0,0 @@
1
- import { useCopilotTextareaEditor } from './chunk-CSGFJU3L.mjs';
2
- import { usePopulateCopilotTextareaRef } from './chunk-YQU7WG7T.mjs';
3
- import { addAutocompletionsToEditor } from './chunk-WJYQWL4I.mjs';
4
- import { clearAutocompletionsFromEditor } from './chunk-F3MHL6ZY.mjs';
5
- import { replaceEditorText } from './chunk-RQHOUUXQ.mjs';
6
- import { useAutosuggestions } from './chunk-UHD44NC5.mjs';
7
- import { TrackerTextEditedSinceLastCursorMovement } from './chunk-OD7ZMOVE.mjs';
8
- import { useAddBrandingCss } from './chunk-MPME5BW2.mjs';
9
- import { HoveringToolbar } from './chunk-3L6CNVCE.mjs';
10
- import { useHoveringEditorContext, HoveringEditorProvider } from './chunk-YW3REYX6.mjs';
11
- import { defaultBaseAutosuggestionsConfig } from './chunk-6Z2ATUNY.mjs';
12
- import { makeRenderElementFunction } from './chunk-LNAIMEB2.mjs';
13
- import { makeRenderPlaceholderFunction } from './chunk-OELUUJZY.mjs';
14
- import { getTextAroundCollapsedCursor, getFullEditorTextWithNewlines } from './chunk-IXJ2HCOA.mjs';
15
- import { __spreadValues, __objRest, __spreadProps } from './chunk-MRXNTQOX.mjs';
16
- import React, { useMemo, useState, useCallback, useEffect } from 'react';
17
- import { Editor } from 'slate';
18
- import { Slate, Editable } from 'slate-react';
19
- import { twMerge } from 'tailwind-merge';
20
- import { jsxs, jsx } from 'react/jsx-runtime';
21
-
22
- var BaseCopilotTextareaWithHoveringContext = React.forwardRef(
23
- (props, ref) => {
24
- const autosuggestionsConfig = __spreadValues(__spreadValues({}, defaultBaseAutosuggestionsConfig), props.baseAutosuggestionsConfig);
25
- const valueOnInitialRender = useMemo(() => {
26
- var _a2;
27
- return (_a2 = props.value) != null ? _a2 : "";
28
- }, []);
29
- const [lastKnownFullEditorText, setLastKnownFullEditorText] = useState(valueOnInitialRender);
30
- const [cursorMovedSinceLastTextChange, setCursorMovedSinceLastTextChange] = useState(false);
31
- const initialValue = useMemo(() => {
32
- return [
33
- {
34
- type: "paragraph",
35
- children: [{ text: valueOnInitialRender }]
36
- }
37
- ];
38
- }, [valueOnInitialRender]);
39
- const editor = useCopilotTextareaEditor();
40
- const {
41
- isDisplayed: hoveringEditorIsDisplayed,
42
- setIsDisplayed: setHoveringEditorIsDisplayed
43
- } = useHoveringEditorContext();
44
- const insertText = useCallback(
45
- (autosuggestion) => {
46
- Editor.insertText(editor, autosuggestion.text, {
47
- at: autosuggestion.point
48
- });
49
- },
50
- [editor]
51
- );
52
- const {
53
- currentAutocompleteSuggestion,
54
- onChangeHandler: onChangeHandlerForAutocomplete,
55
- onKeyDownHandler: onKeyDownHandlerForAutocomplete
56
- } = useAutosuggestions(
57
- autosuggestionsConfig.debounceTime,
58
- autosuggestionsConfig.acceptAutosuggestionKey,
59
- autosuggestionsConfig.apiConfig.autosuggestionsFunction,
60
- insertText,
61
- autosuggestionsConfig.disableWhenEmpty,
62
- autosuggestionsConfig.disabled || hoveringEditorIsDisplayed || cursorMovedSinceLastTextChange && autosuggestionsConfig.temporarilyDisableWhenMovingCursorWithoutChangingText
63
- );
64
- const onKeyDownHandlerForHoveringEditor = useCallback(
65
- (event) => {
66
- if (event.key === "k" && event.metaKey) {
67
- event.preventDefault();
68
- setHoveringEditorIsDisplayed(!hoveringEditorIsDisplayed);
69
- }
70
- },
71
- [hoveringEditorIsDisplayed, setHoveringEditorIsDisplayed]
72
- );
73
- useEffect(() => {
74
- clearAutocompletionsFromEditor(editor);
75
- if (currentAutocompleteSuggestion) {
76
- addAutocompletionsToEditor(
77
- editor,
78
- currentAutocompleteSuggestion.text,
79
- currentAutocompleteSuggestion.point
80
- );
81
- }
82
- }, [currentAutocompleteSuggestion]);
83
- const suggestionStyleAugmented = useMemo(() => {
84
- return __spreadValues({
85
- fontStyle: "italic",
86
- color: "gray"
87
- }, props.suggestionsStyle);
88
- }, [props.suggestionsStyle]);
89
- const renderElementMemoized = useMemo(() => {
90
- return makeRenderElementFunction(suggestionStyleAugmented);
91
- }, [suggestionStyleAugmented]);
92
- const renderPlaceholderMemoized = useMemo(() => {
93
- const placeholderStyleSlatejsOverrides = {
94
- top: void 0
95
- };
96
- const placeholderStyleAugmented = __spreadValues(__spreadValues({}, placeholderStyleSlatejsOverrides), props.placeholderStyle);
97
- return makeRenderPlaceholderFunction(placeholderStyleAugmented);
98
- }, [props.placeholderStyle]);
99
- useEffect(() => {
100
- var _a2, _b;
101
- if (props.value === lastKnownFullEditorText) {
102
- return;
103
- }
104
- setLastKnownFullEditorText((_a2 = props.value) != null ? _a2 : "");
105
- replaceEditorText(editor, (_b = props.value) != null ? _b : "");
106
- }, [props.value]);
107
- const _a = props, {
108
- placeholderStyle,
109
- value,
110
- hoverMenuClassname,
111
- onValueChange,
112
- baseAutosuggestionsConfig: autosuggestionsConfigFromProps,
113
- className,
114
- onChange,
115
- onKeyDown,
116
- disableBranding
117
- } = _a, propsToForward = __objRest(_a, [
118
- "placeholderStyle",
119
- "value",
120
- "hoverMenuClassname",
121
- "onValueChange",
122
- "baseAutosuggestionsConfig",
123
- "className",
124
- "onChange",
125
- "onKeyDown",
126
- "disableBranding"
127
- ]);
128
- useAddBrandingCss(suggestionStyleAugmented, disableBranding);
129
- usePopulateCopilotTextareaRef(editor, ref);
130
- const moddedClassName = (() => {
131
- const baseClassName = "copilot-textarea";
132
- const brandingClass = disableBranding ? "no-branding" : "with-branding";
133
- const defaultTailwindClassName = "bg-white overflow-y-auto resize-y";
134
- const mergedClassName = twMerge(
135
- defaultTailwindClassName,
136
- className != null ? className : ""
137
- );
138
- return `${baseClassName} ${brandingClass} ${mergedClassName}`;
139
- })();
140
- return /* @__PURE__ */ jsxs(Slate, {
141
- editor,
142
- initialValue,
143
- onChange: (value2) => {
144
- var _a2, _b;
145
- const newEditorState = getTextAroundCollapsedCursor(editor);
146
- const fullEditorText = newEditorState ? newEditorState.textBeforeCursor + newEditorState.textAfterCursor : getFullEditorTextWithNewlines(editor);
147
- setLastKnownFullEditorText((prev) => {
148
- if (prev !== fullEditorText) {
149
- setCursorMovedSinceLastTextChange(false);
150
- }
151
- return fullEditorText;
152
- });
153
- onChangeHandlerForAutocomplete(newEditorState);
154
- (_a2 = props.onValueChange) == null ? void 0 : _a2.call(props, fullEditorText);
155
- (_b = props.onChange) == null ? void 0 : _b.call(props, makeSemiFakeReactTextAreaEvent(fullEditorText));
156
- },
157
- children: [
158
- /* @__PURE__ */ jsx(TrackerTextEditedSinceLastCursorMovement, {
159
- setCursorMovedSinceLastTextChange
160
- }),
161
- /* @__PURE__ */ jsx(HoveringToolbar, {
162
- apiConfig: autosuggestionsConfig.apiConfig,
163
- contextCategories: autosuggestionsConfig.contextCategories,
164
- hoverMenuClassname
165
- }),
166
- /* @__PURE__ */ jsx(Editable, __spreadValues({
167
- renderElement: renderElementMemoized,
168
- renderPlaceholder: renderPlaceholderMemoized,
169
- onKeyDown: (event) => {
170
- var _a2;
171
- onKeyDownHandlerForHoveringEditor(event);
172
- onKeyDownHandlerForAutocomplete(event);
173
- (_a2 = props.onKeyDown) == null ? void 0 : _a2.call(props, event);
174
- },
175
- className: moddedClassName
176
- }, propsToForward))
177
- ]
178
- });
179
- }
180
- );
181
- function makeSemiFakeReactTextAreaEvent(currentText) {
182
- return {
183
- target: {
184
- value: currentText,
185
- type: "copilot-textarea"
186
- },
187
- currentTarget: {
188
- value: currentText,
189
- type: "copilot-textarea"
190
- }
191
- };
192
- }
193
- var BaseCopilotTextarea = React.forwardRef(
194
- (props, ref) => {
195
- return /* @__PURE__ */ jsx(HoveringEditorProvider, {
196
- children: /* @__PURE__ */ jsx(BaseCopilotTextareaWithHoveringContext, __spreadProps(__spreadValues({}, props), {
197
- ref
198
- }))
199
- });
200
- }
201
- );
202
-
203
- export { BaseCopilotTextarea };
204
- //# sourceMappingURL=out.js.map
205
- //# sourceMappingURL=chunk-JYVC4AW3.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/base-copilot-textarea/base-copilot-textarea.tsx"],"names":["_a","value"],"mappings":"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","sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { Descendant, Editor } from \"slate\";\nimport { Editable, Slate } from \"slate-react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useAutosuggestions } from \"../../hooks/base-copilot-textarea-implementation/use-autosuggestions\";\nimport { useCopilotTextareaEditor } from \"../../hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor\";\nimport { usePopulateCopilotTextareaRef } from \"../../hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref\";\nimport {\n getFullEditorTextWithNewlines,\n getTextAroundCollapsedCursor,\n} from \"../../lib/get-text-around-cursor\";\nimport { addAutocompletionsToEditor } from \"../../lib/slatejs-edits/add-autocompletions\";\nimport { clearAutocompletionsFromEditor } from \"../../lib/slatejs-edits/clear-autocompletions\";\nimport { replaceEditorText } from \"../../lib/slatejs-edits/replace-text\";\nimport {\n BaseAutosuggestionsConfig,\n defaultBaseAutosuggestionsConfig,\n} from \"../../types/base\";\nimport { AutosuggestionState } from \"../../types/base/autosuggestion-state\";\nimport { BaseCopilotTextareaProps } from \"../../types/base/base-copilot-textarea-props\";\nimport \"./base-copilot-textarea.css\";\nimport { HoveringToolbar } from \"../hovering-toolbar/hovering-toolbar\";\nimport { makeRenderElementFunction } from \"./render-element\";\nimport { makeRenderPlaceholderFunction } from \"./render-placeholder\";\nimport { useAddBrandingCss } from \"./use-add-branding-css\";\nimport {\n HoveringEditorProvider,\n useHoveringEditorContext,\n} from \"../hovering-toolbar/hovering-editor-provider\";\nimport { EditorAutocompleteState } from \"../../types/base/editor-autocomplete-state\";\nimport { TrackerTextEditedSinceLastCursorMovement } from \"./track-cursor-moved-since-last-text-change\";\n\nexport interface HTMLCopilotTextAreaElement extends HTMLElement {\n value: string;\n focus: () => void;\n blur: () => void;\n}\n\nconst BaseCopilotTextareaWithHoveringContext = React.forwardRef(\n (\n props: BaseCopilotTextareaProps,\n ref: React.Ref<HTMLCopilotTextAreaElement>\n ): JSX.Element => {\n const autosuggestionsConfig: BaseAutosuggestionsConfig = {\n ...defaultBaseAutosuggestionsConfig,\n ...props.baseAutosuggestionsConfig,\n };\n\n const valueOnInitialRender = useMemo(() => props.value ?? \"\", []);\n const [lastKnownFullEditorText, setLastKnownFullEditorText] =\n useState(valueOnInitialRender);\n const [cursorMovedSinceLastTextChange, setCursorMovedSinceLastTextChange] =\n useState(false);\n\n // // When the editor text changes, we want to reset the `textEditedSinceLastCursorMovement` state.\n // useEffect(() => {\n // setCursorMovedSinceLastTextChange(false);\n // }, [lastKnownFullEditorText]);\n\n const initialValue: Descendant[] = useMemo(() => {\n return [\n {\n type: \"paragraph\",\n children: [{ text: valueOnInitialRender }],\n },\n ];\n }, [valueOnInitialRender]);\n\n const editor = useCopilotTextareaEditor();\n\n const {\n isDisplayed: hoveringEditorIsDisplayed,\n setIsDisplayed: setHoveringEditorIsDisplayed,\n } = useHoveringEditorContext();\n\n const insertText = useCallback(\n (autosuggestion: AutosuggestionState) => {\n Editor.insertText(editor, autosuggestion.text, {\n at: autosuggestion.point,\n });\n },\n [editor]\n );\n\n const {\n currentAutocompleteSuggestion,\n onChangeHandler: onChangeHandlerForAutocomplete,\n onKeyDownHandler: onKeyDownHandlerForAutocomplete,\n } = useAutosuggestions(\n autosuggestionsConfig.debounceTime,\n autosuggestionsConfig.acceptAutosuggestionKey,\n autosuggestionsConfig.apiConfig.autosuggestionsFunction,\n insertText,\n autosuggestionsConfig.disableWhenEmpty,\n autosuggestionsConfig.disabled ||\n hoveringEditorIsDisplayed || // disable autosuggestions when the hovering editor is displayed\n (cursorMovedSinceLastTextChange &&\n autosuggestionsConfig.temporarilyDisableWhenMovingCursorWithoutChangingText) // disable autosuggestions when the cursor has moved since the last text change\n );\n const onKeyDownHandlerForHoveringEditor = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n // if command-k, toggle the hovering editor\n if (event.key === \"k\" && event.metaKey) {\n event.preventDefault();\n setHoveringEditorIsDisplayed(!hoveringEditorIsDisplayed);\n }\n },\n [hoveringEditorIsDisplayed, setHoveringEditorIsDisplayed]\n );\n\n // sync autosuggestions state with the editor\n useEffect(() => {\n clearAutocompletionsFromEditor(editor);\n if (currentAutocompleteSuggestion) {\n addAutocompletionsToEditor(\n editor,\n currentAutocompleteSuggestion.text,\n currentAutocompleteSuggestion.point\n );\n }\n }, [currentAutocompleteSuggestion]);\n\n const suggestionStyleAugmented: React.CSSProperties = useMemo(() => {\n return {\n fontStyle: \"italic\",\n color: \"gray\",\n ...props.suggestionsStyle,\n };\n }, [props.suggestionsStyle]);\n\n const renderElementMemoized = useMemo(() => {\n return makeRenderElementFunction(suggestionStyleAugmented);\n }, [suggestionStyleAugmented]);\n\n const renderPlaceholderMemoized = useMemo(() => {\n // For some reason slateJS specifies a top value of 0, which makes for strange styling. We override this here.\n const placeholderStyleSlatejsOverrides: React.CSSProperties = {\n top: undefined,\n };\n\n const placeholderStyleAugmented: React.CSSProperties = {\n ...placeholderStyleSlatejsOverrides,\n ...props.placeholderStyle,\n };\n\n return makeRenderPlaceholderFunction(placeholderStyleAugmented);\n }, [props.placeholderStyle]);\n\n // update the editor text, but only when the value changes from outside the component\n useEffect(() => {\n if (props.value === lastKnownFullEditorText) {\n return;\n }\n\n setLastKnownFullEditorText(props.value ?? \"\");\n replaceEditorText(editor, props.value ?? \"\");\n }, [props.value]);\n\n // separate into TextareaHTMLAttributes<HTMLDivElement> and CopilotTextareaProps\n const {\n placeholderStyle,\n value,\n hoverMenuClassname,\n onValueChange,\n baseAutosuggestionsConfig: autosuggestionsConfigFromProps,\n className,\n onChange,\n onKeyDown,\n disableBranding,\n ...propsToForward\n } = props;\n\n useAddBrandingCss(suggestionStyleAugmented, disableBranding);\n usePopulateCopilotTextareaRef(editor, ref);\n\n const moddedClassName = (() => {\n const baseClassName = \"copilot-textarea\";\n const brandingClass = disableBranding ? \"no-branding\" : \"with-branding\";\n const defaultTailwindClassName = \"bg-white overflow-y-auto resize-y\";\n const mergedClassName = twMerge(\n defaultTailwindClassName,\n className ?? \"\"\n );\n return `${baseClassName} ${brandingClass} ${mergedClassName}`;\n })();\n\n return (\n <Slate\n editor={editor}\n initialValue={initialValue}\n onChange={(value) => {\n const newEditorState = getTextAroundCollapsedCursor(editor);\n\n const fullEditorText = newEditorState\n ? newEditorState.textBeforeCursor + newEditorState.textAfterCursor\n : getFullEditorTextWithNewlines(editor); // we don't double-parse the editor. When `newEditorState` is null, we didn't parse the editor yet.\n\n setLastKnownFullEditorText((prev) => {\n if (prev !== fullEditorText) {\n setCursorMovedSinceLastTextChange(false);\n }\n return fullEditorText;\n });\n onChangeHandlerForAutocomplete(newEditorState);\n\n props.onValueChange?.(fullEditorText);\n props.onChange?.(makeSemiFakeReactTextAreaEvent(fullEditorText));\n }}\n >\n <TrackerTextEditedSinceLastCursorMovement\n setCursorMovedSinceLastTextChange={setCursorMovedSinceLastTextChange}\n />\n <HoveringToolbar\n apiConfig={autosuggestionsConfig.apiConfig}\n contextCategories={autosuggestionsConfig.contextCategories}\n hoverMenuClassname={hoverMenuClassname}\n />\n <Editable\n renderElement={renderElementMemoized}\n renderPlaceholder={renderPlaceholderMemoized}\n onKeyDown={(event) => {\n onKeyDownHandlerForHoveringEditor(event); // forward the event for internal use\n onKeyDownHandlerForAutocomplete(event); // forward the event for internal use\n props.onKeyDown?.(event); // forward the event for external use\n }}\n className={moddedClassName}\n {...propsToForward}\n />\n </Slate>\n );\n }\n);\n\n// Consumers of <textarea> expect a `onChange: (React.ChangeEvent<HTMLTextAreaElement>) => void` event handler to be passed in.\n// This is *extremely* common, and we want to support it.\n//\n// We can't support the full functionality, but in 99% of cases, the consumer only cares about the `event.target.value` property --\n// that's how they get the new value of the textarea.\n//\n// So, the tradeoff we are making is minimizing compiler complaint, with a small chance of runtime error.\n// The alternative would be defining a different onChange entrypoint (we actually do have that in `onValueChange`),\n// And starting to explain subtleties to users the moment they try to use the component for the first time for very basic functionality.\n//\n// If this proves problematic, we can always revisit this decision.\nfunction makeSemiFakeReactTextAreaEvent(\n currentText: string\n): React.ChangeEvent<HTMLTextAreaElement> {\n return {\n target: {\n value: currentText,\n type: \"copilot-textarea\",\n },\n currentTarget: {\n value: currentText,\n type: \"copilot-textarea\",\n },\n } as React.ChangeEvent<HTMLTextAreaElement>;\n}\n\nexport const BaseCopilotTextarea = React.forwardRef(\n (\n props: BaseCopilotTextareaProps,\n ref: React.Ref<HTMLCopilotTextAreaElement>\n ): JSX.Element => {\n return (\n <HoveringEditorProvider>\n <BaseCopilotTextareaWithHoveringContext {...props} ref={ref} />\n </HoveringEditorProvider>\n );\n }\n);\n"]}
@@ -1,107 +0,0 @@
1
- import { Transforms, Editor, Operation, Path } from 'slate';
2
- import { HistoryEditor } from 'slate-history';
3
-
4
- // src/lib/slatejs-edits/with-partial-history.ts
5
- var withPartialHistory = (editor, shouldSave) => {
6
- const e = editor;
7
- const { apply } = e;
8
- e.history = { undos: [], redos: [] };
9
- e.redo = () => {
10
- const { history } = e;
11
- const { redos } = history;
12
- if (redos.length > 0) {
13
- const batch = redos[redos.length - 1];
14
- if (batch.selectionBefore) {
15
- Transforms.setSelection(e, batch.selectionBefore);
16
- }
17
- HistoryEditor.withoutSaving(e, () => {
18
- Editor.withoutNormalizing(e, () => {
19
- for (const op of batch.operations) {
20
- e.apply(op);
21
- }
22
- });
23
- });
24
- history.redos.pop();
25
- e.writeHistory("undos", batch);
26
- }
27
- };
28
- e.undo = () => {
29
- const { history } = e;
30
- const { undos } = history;
31
- if (undos.length > 0) {
32
- const batch = undos[undos.length - 1];
33
- HistoryEditor.withoutSaving(e, () => {
34
- Editor.withoutNormalizing(e, () => {
35
- const inverseOps = batch.operations.map(Operation.inverse).reverse();
36
- for (const op of inverseOps) {
37
- e.apply(op);
38
- }
39
- if (batch.selectionBefore) {
40
- Transforms.setSelection(e, batch.selectionBefore);
41
- }
42
- });
43
- });
44
- e.writeHistory("redos", batch);
45
- history.undos.pop();
46
- }
47
- };
48
- e.apply = (op) => {
49
- const { operations, history } = e;
50
- const { undos } = history;
51
- const lastBatch = undos[undos.length - 1];
52
- const lastOp = lastBatch && lastBatch.operations[lastBatch.operations.length - 1];
53
- let save = HistoryEditor.isSaving(e);
54
- let merge = HistoryEditor.isMerging(e);
55
- if (save == null) {
56
- save = shouldSave(op, lastOp);
57
- }
58
- if (save) {
59
- if (merge == null) {
60
- if (lastBatch == null) {
61
- merge = false;
62
- } else if (operations.length !== 0) {
63
- merge = true;
64
- } else {
65
- merge = shouldMerge(op, lastOp);
66
- }
67
- }
68
- if (lastBatch && merge) {
69
- lastBatch.operations.push(op);
70
- } else {
71
- const batch = {
72
- operations: [op],
73
- selectionBefore: e.selection
74
- };
75
- e.writeHistory("undos", batch);
76
- }
77
- while (undos.length > 100) {
78
- undos.shift();
79
- }
80
- history.redos = [];
81
- }
82
- apply(op);
83
- };
84
- e.writeHistory = (stack, batch) => {
85
- e.history[stack].push(batch);
86
- };
87
- return e;
88
- };
89
- var shouldMerge = (op, prev) => {
90
- if (prev && op.type === "insert_text" && prev.type === "insert_text" && op.offset === prev.offset + prev.text.length && Path.equals(op.path, prev.path)) {
91
- return true;
92
- }
93
- if (prev && op.type === "remove_text" && prev.type === "remove_text" && op.offset + op.text.length === prev.offset && Path.equals(op.path, prev.path)) {
94
- return true;
95
- }
96
- return false;
97
- };
98
- var defaultShouldSave = (op, prev) => {
99
- if (op.type === "set_selection") {
100
- return false;
101
- }
102
- return true;
103
- };
104
-
105
- export { defaultShouldSave, withPartialHistory };
106
- //# sourceMappingURL=out.js.map
107
- //# sourceMappingURL=chunk-KCHYD3EB.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/slatejs-edits/with-partial-history.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Operation, Path, Range, Transforms } from \"slate\";\nimport { HistoryEditor } from \"slate-history\";\n\n// Copy-pasted from `https://github.com/ianstormtaylor/slate/blob/main/packages/slate-history/src/with-history.ts`\n// With one exception: the `shouldSave` function is passed in as an argument to `withPartialHistory` instead of being hardcoded\nexport type ShouldSaveToHistory = (\n op: Operation,\n prev: Operation | undefined\n) => boolean;\n\nexport const withPartialHistory = <T extends Editor>(\n editor: T,\n shouldSave: ShouldSaveToHistory\n) => {\n const e = editor as T & HistoryEditor;\n const { apply } = e;\n e.history = { undos: [], redos: [] };\n\n e.redo = () => {\n const { history } = e;\n const { redos } = history;\n\n if (redos.length > 0) {\n const batch = redos[redos.length - 1];\n\n if (batch.selectionBefore) {\n Transforms.setSelection(e, batch.selectionBefore);\n }\n\n HistoryEditor.withoutSaving(e, () => {\n Editor.withoutNormalizing(e, () => {\n for (const op of batch.operations) {\n e.apply(op);\n }\n });\n });\n\n history.redos.pop();\n e.writeHistory(\"undos\", batch);\n }\n };\n\n e.undo = () => {\n const { history } = e;\n const { undos } = history;\n\n if (undos.length > 0) {\n const batch = undos[undos.length - 1];\n\n HistoryEditor.withoutSaving(e, () => {\n Editor.withoutNormalizing(e, () => {\n const inverseOps = batch.operations.map(Operation.inverse).reverse();\n\n for (const op of inverseOps) {\n e.apply(op);\n }\n if (batch.selectionBefore) {\n Transforms.setSelection(e, batch.selectionBefore);\n }\n });\n });\n\n e.writeHistory(\"redos\", batch);\n history.undos.pop();\n }\n };\n\n e.apply = (op: Operation) => {\n const { operations, history } = e;\n const { undos } = history;\n const lastBatch = undos[undos.length - 1];\n const lastOp =\n lastBatch && lastBatch.operations[lastBatch.operations.length - 1];\n let save = HistoryEditor.isSaving(e);\n let merge = HistoryEditor.isMerging(e);\n\n if (save == null) {\n save = shouldSave(op, lastOp);\n }\n\n if (save) {\n if (merge == null) {\n if (lastBatch == null) {\n merge = false;\n } else if (operations.length !== 0) {\n merge = true;\n } else {\n merge = shouldMerge(op, lastOp);\n }\n }\n\n if (lastBatch && merge) {\n lastBatch.operations.push(op);\n } else {\n const batch = {\n operations: [op],\n selectionBefore: e.selection,\n };\n e.writeHistory(\"undos\", batch);\n }\n\n while (undos.length > 100) {\n undos.shift();\n }\n\n history.redos = [];\n }\n\n apply(op);\n };\n\n e.writeHistory = (stack: \"undos\" | \"redos\", batch: any) => {\n e.history[stack].push(batch);\n };\n\n return e;\n};\n\n/**\n * Check whether to merge an operation into the previous operation.\n */\n\nconst shouldMerge = (op: Operation, prev: Operation | undefined): boolean => {\n if (\n prev &&\n op.type === \"insert_text\" &&\n prev.type === \"insert_text\" &&\n op.offset === prev.offset + prev.text.length &&\n Path.equals(op.path, prev.path)\n ) {\n return true;\n }\n\n if (\n prev &&\n op.type === \"remove_text\" &&\n prev.type === \"remove_text\" &&\n op.offset + op.text.length === prev.offset &&\n Path.equals(op.path, prev.path)\n ) {\n return true;\n }\n\n return false;\n};\n\nexport const defaultShouldSave = (\n op: Operation,\n prev: Operation | undefined\n): boolean => {\n if (op.type === \"set_selection\") {\n return false;\n }\n\n return true;\n};\n"]}
@@ -1,47 +0,0 @@
1
- import { __async } from './chunk-MRXNTQOX.mjs';
2
- import { clsx } from 'clsx';
3
- import { customAlphabet } from 'nanoid';
4
- import { twMerge } from 'tailwind-merge';
5
-
6
- function cn(...inputs) {
7
- return twMerge(clsx(inputs));
8
- }
9
- var nanoid = customAlphabet(
10
- "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",
11
- 7
12
- );
13
- function fetcher(input, init) {
14
- return __async(this, null, function* () {
15
- const res = yield fetch(input, init);
16
- if (!res.ok) {
17
- const json = yield res.json();
18
- if (json.error) {
19
- const error = new Error(json.error);
20
- error.status = res.status;
21
- throw error;
22
- } else {
23
- throw new Error("An unexpected error occurred");
24
- }
25
- }
26
- return res.json();
27
- });
28
- }
29
- function formatDate(input) {
30
- const date = new Date(input);
31
- return date.toLocaleDateString("en-US", {
32
- month: "long",
33
- day: "numeric",
34
- year: "numeric"
35
- });
36
- }
37
- var arraysAreEqual = (arr1, arr2) => arr1.length === arr2.length && arr1.every((value, index) => value === arr2[index]);
38
- function nullableCompatibleEqualityCheck(naiveEqualityCheck, a, b) {
39
- if (a === null || a === void 0 || b === null || b === void 0) {
40
- return a === b;
41
- }
42
- return naiveEqualityCheck(a, b);
43
- }
44
-
45
- export { arraysAreEqual, cn, fetcher, formatDate, nanoid, nullableCompatibleEqualityCheck };
46
- //# sourceMappingURL=out.js.map
47
- //# sourceMappingURL=chunk-KGKLUWKW.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/utils.ts"],"names":[],"mappings":";;;;;AAAA,SAAS,YAA6B;AACtC,SAAS,sBAAsB;AAC/B,SAAS,eAAe;AAEjB,SAAS,MAAM,QAAsB;AAC1C,SAAO,QAAQ,KAAK,MAAM,CAAC;AAC7B;AAEO,IAAM,SAAS;AAAA,EACpB;AAAA,EACA;AACF;AAEA,SAAsB,QACpB,OACA,MACe;AAAA;AACf,UAAM,MAAM,MAAM,MAAM,OAAO,IAAI;AAEnC,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,UAAI,KAAK,OAAO;AACd,cAAM,QAAQ,IAAI,MAAM,KAAK,KAAK;AAGlC,cAAM,SAAS,IAAI;AACnB,cAAM;AAAA,MACR,OAAO;AACL,cAAM,IAAI,MAAM,8BAA8B;AAAA,MAChD;AAAA,IACF;AAEA,WAAO,IAAI,KAAK;AAAA,EAClB;AAAA;AAEO,SAAS,WAAW,OAAuC;AAChE,QAAM,OAAO,IAAI,KAAK,KAAK;AAC3B,SAAO,KAAK,mBAAmB,SAAS;AAAA,IACtC,OAAO;AAAA,IACP,KAAK;AAAA,IACL,MAAM;AAAA,EACR,CAAC;AACH;AAEO,IAAM,iBAAiB,CAAC,MAAgB,SAC7C,KAAK,WAAW,KAAK,UACrB,KAAK,MAAM,CAAC,OAAO,UAAU,UAAU,KAAK,MAAM;AAE7C,SAAS,gCACd,oBACA,GACA,GACS;AACT,MAAI,MAAM,QAAQ,MAAM,UAAa,MAAM,QAAQ,MAAM,QAAW;AAClE,WAAO,MAAM;AAAA,EACf;AAEA,SAAO,mBAAmB,GAAG,CAAC;AAChC","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { customAlphabet } from \"nanoid\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const nanoid = customAlphabet(\n \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\",\n 7\n); // 7-character random string\n\nexport async function fetcher<JSON = any>(\n input: RequestInfo,\n init?: RequestInit\n): Promise<JSON> {\n const res = await fetch(input, init);\n\n if (!res.ok) {\n const json = await res.json();\n if (json.error) {\n const error = new Error(json.error) as Error & {\n status: number;\n };\n error.status = res.status;\n throw error;\n } else {\n throw new Error(\"An unexpected error occurred\");\n }\n }\n\n return res.json();\n}\n\nexport function formatDate(input: string | number | Date): string {\n const date = new Date(input);\n return date.toLocaleDateString(\"en-US\", {\n month: \"long\",\n day: \"numeric\",\n year: \"numeric\",\n });\n}\n\nexport const arraysAreEqual = (arr1: number[], arr2: number[]): boolean =>\n arr1.length === arr2.length &&\n arr1.every((value, index) => value === arr2[index]);\n\nexport function nullableCompatibleEqualityCheck<T>(\n naiveEqualityCheck: (a: T, b: T) => boolean,\n a: T | null | undefined,\n b: T | null | undefined\n): boolean {\n if (a === null || a === undefined || b === null || b === undefined) {\n return a === b;\n }\n\n return naiveEqualityCheck(a, b);\n}\n"]}
@@ -1,3 +0,0 @@
1
-
2
- //# sourceMappingURL=out.js.map
3
- //# sourceMappingURL=chunk-L7VVZH4Q.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,34 +0,0 @@
1
- import { __spreadProps, __spreadValues } from './chunk-MRXNTQOX.mjs';
2
- import { jsx, jsxs } from 'react/jsx-runtime';
3
-
4
- function makeRenderElementFunction(suggestionsStyle) {
5
- return (props) => {
6
- switch (props.element.type) {
7
- case "paragraph":
8
- return /* @__PURE__ */ jsx(DefaultElement, __spreadValues({}, props));
9
- case "suggestion":
10
- return /* @__PURE__ */ jsx(SuggestionElement, __spreadProps(__spreadValues({}, props), {
11
- suggestionsStyle
12
- }));
13
- }
14
- };
15
- }
16
- var DefaultElement = (props) => {
17
- return /* @__PURE__ */ jsx("div", __spreadProps(__spreadValues({}, props.attributes), {
18
- children: props.children
19
- }));
20
- };
21
- var SuggestionElement = (props) => {
22
- return /* @__PURE__ */ jsxs("span", __spreadProps(__spreadValues({}, props.attributes), {
23
- style: __spreadValues({}, props.suggestionsStyle),
24
- contentEditable: false,
25
- children: [
26
- props.children,
27
- props.element.type === "suggestion" && props.element.content
28
- ]
29
- }));
30
- };
31
-
32
- export { makeRenderElementFunction };
33
- //# sourceMappingURL=out.js.map
34
- //# sourceMappingURL=chunk-LNAIMEB2.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/base-copilot-textarea/render-element.tsx"],"names":[],"mappings":";;;;;;AAUe,cAkBX,YAlBW;AANR,SAAS,0BACd,kBACuB;AACvB,SAAO,CAAC,UAA8B;AACpC,YAAQ,MAAM,QAAQ,MAAM;AAAA,MAC1B,KAAK;AACH,eAAO,oBAAC,mCAAmB,MAAO;AAAA,MACpC,KAAK;AACH,eACE,oBAAC,oDAAsB,QAAtB;AAAA,UAA6B;AAAA,UAAoC;AAAA,IAExE;AAAA,EACF;AACF;AAEA,IAAM,iBAAiB,CAAC,UAA8B;AACpD,SAAO,oBAAC,wCAAQ,MAAM,aAAd;AAAA,IAA2B,gBAAM;AAAA,IAAS;AACpD;AACA,IAAM,oBAAoB,CACxB,UAGG;AACH,SACE,qBAAC,yCACK,MAAM,aADX;AAAA,IAEC,OAAO,mBACF,MAAM;AAAA,IAEX,iBAAiB;AAAA,IAEhB;AAAA,YAAM;AAAA,MACN,MAAM,QAAQ,SAAS,gBAAgB,MAAM,QAAQ;AAAA;AAAA,IACxD;AAEJ","sourcesContent":["import { RenderElementProps } from \"slate-react\";\n\nexport type RenderElementFunction = (props: RenderElementProps) => JSX.Element;\n\nexport function makeRenderElementFunction(\n suggestionsStyle: React.CSSProperties\n): RenderElementFunction {\n return (props: RenderElementProps) => {\n switch (props.element.type) {\n case \"paragraph\":\n return <DefaultElement {...props} />;\n case \"suggestion\":\n return (\n <SuggestionElement {...props} suggestionsStyle={suggestionsStyle} />\n );\n }\n };\n}\n\nconst DefaultElement = (props: RenderElementProps) => {\n return <div {...props.attributes}>{props.children}</div>;\n};\nconst SuggestionElement = (\n props: RenderElementProps & {\n suggestionsStyle: React.CSSProperties;\n }\n) => {\n return (\n <span\n {...props.attributes}\n style={{\n ...props.suggestionsStyle,\n }}\n contentEditable={false}\n >\n {props.children /* https://github.com/ianstormtaylor/slate/issues/3930 */}\n {props.element.type === \"suggestion\" && props.element.content}\n </span>\n );\n};\n"]}
@@ -1,3 +0,0 @@
1
-
2
- //# sourceMappingURL=out.js.map
3
- //# sourceMappingURL=chunk-MMVDU6DF.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,59 +0,0 @@
1
- import { useEffect } from 'react';
2
-
3
- // src/components/base-copilot-textarea/use-add-branding-css.tsx
4
- function useAddBrandingCss(suggestionStyleAugmented, disableBranding) {
5
- const cssSelector = ".copilot-textarea.with-branding";
6
- useEffect(() => {
7
- if (disableBranding) {
8
- return;
9
- }
10
- const styleEl = document.createElement("style");
11
- styleEl.id = "dynamic-styles";
12
- let dynamicStyles = Object.entries(suggestionStyleAugmented).map(([key, value]) => {
13
- const kebabCaseKey = key.replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, "$1-$2").toLowerCase();
14
- return `${kebabCaseKey}: ${value};`;
15
- }).join(" ");
16
- dynamicStyles += `font-style: normal; font-size: x-small;`;
17
- dynamicStyles += `content: "CopilotKit";`;
18
- dynamicStyles += `bottom: 6px;`;
19
- dynamicStyles += `right: 6px;`;
20
- dynamicStyles += `pointer-events: none;`;
21
- dynamicStyles += `font-weight: 200;`;
22
- dynamicStyles += `padding: 0;`;
23
- dynamicStyles += `margin: 0;`;
24
- dynamicStyles += `border: 0;`;
25
- dynamicStyles += `line-height: 1;`;
26
- dynamicStyles += `position: absolute;`;
27
- styleEl.innerHTML = `
28
- ${cssSelector}::after {
29
- ${dynamicStyles}
30
- }
31
- `;
32
- document.head.appendChild(styleEl);
33
- const textarea = document.querySelector(cssSelector);
34
- const handleScroll = () => {
35
- const styleEl2 = document.getElementById("dynamic-styles");
36
- if (styleEl2 && textarea) {
37
- const offsetFromBottom = -textarea.scrollTop + 6;
38
- const offsetFromRight = -textarea.scrollLeft + 6;
39
- styleEl2.innerHTML = `
40
- ${cssSelector}::after {
41
- ${dynamicStyles}
42
- bottom: ${offsetFromBottom}px;
43
- right: ${offsetFromRight}px;
44
- }
45
- `;
46
- }
47
- };
48
- textarea == null ? void 0 : textarea.addEventListener("scroll", handleScroll);
49
- return () => {
50
- var _a;
51
- (_a = document.getElementById("dynamic-styles")) == null ? void 0 : _a.remove();
52
- textarea == null ? void 0 : textarea.removeEventListener("scroll", handleScroll);
53
- };
54
- }, [disableBranding, suggestionStyleAugmented]);
55
- }
56
-
57
- export { useAddBrandingCss };
58
- //# sourceMappingURL=out.js.map
59
- //# sourceMappingURL=chunk-MPME5BW2.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/base-copilot-textarea/use-add-branding-css.tsx"],"names":["styleEl"],"mappings":";AAAA,SAAS,iBAAiB;AAEnB,SAAS,kBACd,0BACA,iBACA;AACA,QAAM,cAAc;AACpB,YAAU,MAAM;AACd,QAAI,iBAAiB;AACnB;AAAA,IACF;AAIA,UAAM,UAAU,SAAS,cAAc,OAAO;AAC9C,YAAQ,KAAK;AAGb,QAAI,gBAAgB,OAAO,QAAQ,wBAAwB,EACxD,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AACrB,YAAM,eAAe,IAClB,QAAQ,gCAAgC,OAAO,EAC/C,YAAY;AACf,aAAO,GAAG,iBAAiB;AAAA,IAC7B,CAAC,EACA,KAAK,GAAG;AAGX,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AAGjB,YAAQ,YAAY;AAAA,QAChB;AAAA,UACE;AAAA;AAAA;AAIN,aAAS,KAAK,YAAY,OAAO;AAIjC,UAAM,WAAW,SAAS,cAAc,WAAW;AACnD,UAAM,eAAe,MAAM;AACzB,YAAMA,WAAU,SAAS,eAAe,gBAAgB;AACxD,UAAIA,YAAW,UAAU;AACvB,cAAM,mBAAmB,CAAC,SAAS,YAAY;AAC/C,cAAM,kBAAkB,CAAC,SAAS,aAAa;AAC/C,QAAAA,SAAQ,YAAY;AAAA,YAChB;AAAA,cACE;AAAA,sBACQ;AAAA,qBACD;AAAA;AAAA;AAAA,MAGf;AAAA,IACF;AAEA,yCAAU,iBAAiB,UAAU;AAGrC,WAAO,MAAM;AAtEjB;AAuEM,qBAAS,eAAe,gBAAgB,MAAxC,mBAA2C;AAC3C,2CAAU,oBAAoB,UAAU;AAAA,IAC1C;AAAA,EACF,GAAG,CAAC,iBAAiB,wBAAwB,CAAC;AAChD","sourcesContent":["import { useEffect } from \"react\";\n\nexport function useAddBrandingCss(\n suggestionStyleAugmented: React.CSSProperties,\n disableBranding: boolean | undefined\n) {\n const cssSelector = \".copilot-textarea.with-branding\";\n useEffect(() => {\n if (disableBranding) {\n return;\n }\n\n // ---\n // 1: Add the CSS to the DOM\n const styleEl = document.createElement(\"style\");\n styleEl.id = \"dynamic-styles\";\n\n // Build the CSS string dynamically\n let dynamicStyles = Object.entries(suggestionStyleAugmented)\n .map(([key, value]) => {\n const kebabCaseKey = key\n .replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, \"$1-$2\")\n .toLowerCase();\n return `${kebabCaseKey}: ${value};`;\n })\n .join(\" \");\n\n // Append overrides for italics and font-size\n dynamicStyles += `font-style: normal; font-size: x-small;`;\n dynamicStyles += `content: \"CopilotKit\";`;\n dynamicStyles += `bottom: 6px;`;\n dynamicStyles += `right: 6px;`;\n dynamicStyles += `pointer-events: none;`;\n dynamicStyles += `font-weight: 200;`;\n dynamicStyles += `padding: 0;`;\n dynamicStyles += `margin: 0;`;\n dynamicStyles += `border: 0;`;\n dynamicStyles += `line-height: 1;`;\n dynamicStyles += `position: absolute;`;\n\n // Append it to the ::after class\n styleEl.innerHTML = `\n ${cssSelector}::after {\n ${dynamicStyles}\n }\n `;\n\n document.head.appendChild(styleEl);\n\n // ---\n // 2: Add the scroll listener (to keep the branding in the bottom right as the textarea scrolls)\n const textarea = document.querySelector(cssSelector);\n const handleScroll = () => {\n const styleEl = document.getElementById(\"dynamic-styles\");\n if (styleEl && textarea) {\n const offsetFromBottom = -textarea.scrollTop + 6;\n const offsetFromRight = -textarea.scrollLeft + 6;\n styleEl.innerHTML = `\n ${cssSelector}::after {\n ${dynamicStyles}\n bottom: ${offsetFromBottom}px;\n right: ${offsetFromRight}px;\n }\n `;\n }\n };\n\n textarea?.addEventListener(\"scroll\", handleScroll);\n\n // Cleanup\n return () => {\n document.getElementById(\"dynamic-styles\")?.remove();\n textarea?.removeEventListener(\"scroll\", handleScroll);\n };\n }, [disableBranding, suggestionStyleAugmented]);\n}\n"]}
@@ -1,55 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- var __async = (__this, __arguments, generator) => {
33
- return new Promise((resolve, reject) => {
34
- var fulfilled = (value) => {
35
- try {
36
- step(generator.next(value));
37
- } catch (e) {
38
- reject(e);
39
- }
40
- };
41
- var rejected = (value) => {
42
- try {
43
- step(generator.throw(value));
44
- } catch (e) {
45
- reject(e);
46
- }
47
- };
48
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
49
- step((generator = generator.apply(__this, __arguments)).next());
50
- });
51
- };
52
-
53
- export { __async, __objRest, __spreadProps, __spreadValues };
54
- //# sourceMappingURL=out.js.map
55
- //# sourceMappingURL=chunk-MRXNTQOX.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -1,17 +0,0 @@
1
- import { useEffect } from 'react';
2
-
3
- // src/hooks/misc/use-autosize-textarea.tsx
4
- var useAutosizeTextArea = (textAreaRef, value) => {
5
- useEffect(() => {
6
- if (textAreaRef.current !== null) {
7
- textAreaRef.current.style.height = "0px";
8
- const scrollHeight = textAreaRef.current.scrollHeight;
9
- textAreaRef.current.style.height = scrollHeight + "px";
10
- }
11
- }, [textAreaRef, value]);
12
- };
13
- var use_autosize_textarea_default = useAutosizeTextArea;
14
-
15
- export { use_autosize_textarea_default };
16
- //# sourceMappingURL=out.js.map
17
- //# sourceMappingURL=chunk-ND5PXTAW.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/hooks/misc/use-autosize-textarea.tsx"],"names":[],"mappings":";AAAA,SAAyB,iBAAiB;AAG1C,IAAM,sBAAsB,CAC1B,aACA,UACG;AACH,YAAU,MAAM;AACd,QAAI,YAAY,YAAY,MAAM;AAEhC,kBAAY,QAAQ,MAAM,SAAS;AACnC,YAAM,eAAe,YAAY,QAAQ;AAIzC,kBAAY,QAAQ,MAAM,SAAS,eAAe;AAAA,IACpD;AAAA,EACF,GAAG,CAAC,aAAa,KAAK,CAAC;AACzB;AAEA,IAAO,gCAAQ","sourcesContent":["import { Ref, RefObject, useEffect } from \"react\";\n\n// Updates the height of a <textarea> when the value changes.\nconst useAutosizeTextArea = (\n textAreaRef: RefObject<HTMLTextAreaElement>,\n value: string\n) => {\n useEffect(() => {\n if (textAreaRef.current !== null) {\n // We need to reset the height momentarily to get the correct scrollHeight for the textarea\n textAreaRef.current.style.height = \"0px\";\n const scrollHeight = textAreaRef.current.scrollHeight;\n\n // We then set the height directly, outside of the render loop\n // Trying to set this with state or a ref will product an incorrect value.\n textAreaRef.current.style.height = scrollHeight + \"px\";\n }\n }, [textAreaRef, value]);\n};\n\nexport default useAutosizeTextArea;\n"]}