@copilotkit/react-textarea 1.3.0 → 1.3.1

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 (335) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/chunk-224UKA7C.mjs +38 -0
  3. package/dist/chunk-224UKA7C.mjs.map +1 -0
  4. package/dist/chunk-23Q6A46J.mjs +103 -0
  5. package/dist/chunk-23Q6A46J.mjs.map +1 -0
  6. package/dist/chunk-2C7O2EVM.mjs +27 -0
  7. package/dist/chunk-2C7O2EVM.mjs.map +1 -0
  8. package/dist/chunk-2QDCE7PD.mjs +32 -0
  9. package/dist/chunk-2QDCE7PD.mjs.map +1 -0
  10. package/dist/chunk-2XDYLKPH.mjs +181 -0
  11. package/dist/chunk-2XDYLKPH.mjs.map +1 -0
  12. package/dist/chunk-3PQ7GSFE.mjs +17 -0
  13. package/dist/chunk-3PQ7GSFE.mjs.map +1 -0
  14. package/dist/chunk-4AMCUMC7.mjs +124 -0
  15. package/dist/chunk-4AMCUMC7.mjs.map +1 -0
  16. package/dist/chunk-4CVSOOJY.mjs +30 -0
  17. package/dist/chunk-4CVSOOJY.mjs.map +1 -0
  18. package/dist/chunk-4NHVQZ67.mjs +108 -0
  19. package/dist/chunk-4NHVQZ67.mjs.map +1 -0
  20. package/dist/chunk-4PDYALMP.mjs +52 -0
  21. package/dist/chunk-4PDYALMP.mjs.map +1 -0
  22. package/dist/chunk-5UNJXFUO.mjs +29 -0
  23. package/dist/chunk-5UNJXFUO.mjs.map +1 -0
  24. package/dist/chunk-7LSRNPNI.mjs +59 -0
  25. package/dist/chunk-7LSRNPNI.mjs.map +1 -0
  26. package/dist/chunk-AJ5OMEXM.mjs +13 -0
  27. package/dist/chunk-AJ5OMEXM.mjs.map +1 -0
  28. package/dist/chunk-CF5GISTC.mjs +113 -0
  29. package/dist/chunk-CF5GISTC.mjs.map +1 -0
  30. package/dist/chunk-D2SUDM2O.mjs +99 -0
  31. package/dist/chunk-D2SUDM2O.mjs.map +1 -0
  32. package/dist/chunk-D47EKHIF.mjs +26 -0
  33. package/dist/chunk-D47EKHIF.mjs.map +1 -0
  34. package/dist/chunk-DE5K76I2.mjs +1 -0
  35. package/dist/chunk-DE5K76I2.mjs.map +1 -0
  36. package/dist/chunk-DFTV4TST.mjs +36 -0
  37. package/dist/chunk-DFTV4TST.mjs.map +1 -0
  38. package/dist/chunk-DRV2FOHZ.mjs +70 -0
  39. package/dist/chunk-DRV2FOHZ.mjs.map +1 -0
  40. package/dist/chunk-ECR45NSD.mjs +104 -0
  41. package/dist/chunk-ECR45NSD.mjs.map +1 -0
  42. package/dist/chunk-EJGGLWWR.mjs +82 -0
  43. package/dist/chunk-EJGGLWWR.mjs.map +1 -0
  44. package/dist/chunk-FYCQE57K.mjs +60 -0
  45. package/dist/chunk-FYCQE57K.mjs.map +1 -0
  46. package/dist/chunk-GQN2HYFJ.mjs +22 -0
  47. package/dist/chunk-GQN2HYFJ.mjs.map +1 -0
  48. package/dist/chunk-H4VKQGVU.mjs +1 -0
  49. package/dist/chunk-H4VKQGVU.mjs.map +1 -0
  50. package/dist/chunk-HL7EF7KA.mjs +32 -0
  51. package/dist/chunk-HL7EF7KA.mjs.map +1 -0
  52. package/dist/chunk-I3SPIGAI.mjs +31 -0
  53. package/dist/chunk-I3SPIGAI.mjs.map +1 -0
  54. package/dist/chunk-I72DKFHD.mjs +114 -0
  55. package/dist/chunk-I72DKFHD.mjs.map +1 -0
  56. package/dist/chunk-IU3WTXLQ.mjs +1 -0
  57. package/dist/chunk-IU3WTXLQ.mjs.map +1 -0
  58. package/dist/chunk-J62KUPFZ.mjs +264 -0
  59. package/dist/chunk-J62KUPFZ.mjs.map +1 -0
  60. package/dist/chunk-KMVGEY7Q.mjs +51 -0
  61. package/dist/chunk-KMVGEY7Q.mjs.map +1 -0
  62. package/dist/chunk-KNQIEOFP.mjs +19 -0
  63. package/dist/chunk-KNQIEOFP.mjs.map +1 -0
  64. package/dist/chunk-L7VVZH4Q.mjs +1 -0
  65. package/dist/chunk-L7VVZH4Q.mjs.map +1 -0
  66. package/dist/chunk-LQ2OWQU7.mjs +49 -0
  67. package/dist/chunk-LQ2OWQU7.mjs.map +1 -0
  68. package/dist/chunk-LYB4B6MK.mjs +19 -0
  69. package/dist/chunk-LYB4B6MK.mjs.map +1 -0
  70. package/dist/chunk-MCNXIA4Q.mjs +75 -0
  71. package/dist/chunk-MCNXIA4Q.mjs.map +1 -0
  72. package/dist/chunk-MMVDU6DF.mjs +1 -0
  73. package/dist/chunk-MMVDU6DF.mjs.map +1 -0
  74. package/dist/chunk-MRXNTQOX.mjs +59 -0
  75. package/dist/chunk-MRXNTQOX.mjs.map +1 -0
  76. package/dist/chunk-QJNFNPWH.mjs +85 -0
  77. package/dist/chunk-QJNFNPWH.mjs.map +1 -0
  78. package/dist/chunk-RUV6NBIF.mjs +1 -0
  79. package/dist/chunk-RUV6NBIF.mjs.map +1 -0
  80. package/dist/chunk-SDHH6DI6.mjs +63 -0
  81. package/dist/chunk-SDHH6DI6.mjs.map +1 -0
  82. package/dist/chunk-T6MTDQZ7.mjs +45 -0
  83. package/dist/chunk-T6MTDQZ7.mjs.map +1 -0
  84. package/dist/chunk-UGEKMSRR.mjs +225 -0
  85. package/dist/chunk-UGEKMSRR.mjs.map +1 -0
  86. package/dist/chunk-VSVQZUPW.mjs +124 -0
  87. package/dist/chunk-VSVQZUPW.mjs.map +1 -0
  88. package/dist/chunk-WADHCMPK.mjs +1 -0
  89. package/dist/chunk-WADHCMPK.mjs.map +1 -0
  90. package/dist/chunk-WGWQRALG.mjs +83 -0
  91. package/dist/chunk-WGWQRALG.mjs.map +1 -0
  92. package/dist/chunk-WJHSY5T6.mjs +1 -0
  93. package/dist/chunk-WJHSY5T6.mjs.map +1 -0
  94. package/dist/chunk-XW3ICO4S.mjs +25 -0
  95. package/dist/chunk-XW3ICO4S.mjs.map +1 -0
  96. package/dist/chunk-YLFAIYRY.mjs +50 -0
  97. package/dist/chunk-YLFAIYRY.mjs.map +1 -0
  98. package/dist/components/base-copilot-textarea/base-copilot-textarea.css +9 -0
  99. package/dist/components/base-copilot-textarea/base-copilot-textarea.css.map +1 -0
  100. package/dist/components/base-copilot-textarea/base-copilot-textarea.d.ts +1 -1
  101. package/dist/components/base-copilot-textarea/base-copilot-textarea.js +114 -49
  102. package/dist/components/base-copilot-textarea/base-copilot-textarea.js.map +1 -1
  103. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +36 -1687
  104. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs.map +1 -1
  105. package/dist/components/base-copilot-textarea/render-element.d.ts +1 -1
  106. package/dist/components/base-copilot-textarea/render-element.mjs +4 -48
  107. package/dist/components/base-copilot-textarea/render-element.mjs.map +1 -1
  108. package/dist/components/base-copilot-textarea/render-placeholder.d.ts +1 -1
  109. package/dist/components/base-copilot-textarea/render-placeholder.mjs +4 -46
  110. package/dist/components/base-copilot-textarea/render-placeholder.mjs.map +1 -1
  111. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.js +4 -2
  112. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.js.map +1 -1
  113. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs +5 -81
  114. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs.map +1 -1
  115. package/dist/components/base-copilot-textarea/use-add-branding-css.js.map +1 -1
  116. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs +4 -54
  117. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs.map +1 -1
  118. package/dist/components/copilot-textarea/copilot-textarea.css +9 -0
  119. package/dist/components/copilot-textarea/copilot-textarea.css.map +1 -0
  120. package/dist/components/copilot-textarea/copilot-textarea.d.ts +9 -3
  121. package/dist/components/copilot-textarea/copilot-textarea.js +116 -51
  122. package/dist/components/copilot-textarea/copilot-textarea.js.map +1 -1
  123. package/dist/components/copilot-textarea/copilot-textarea.mjs +44 -2212
  124. package/dist/components/copilot-textarea/copilot-textarea.mjs.map +1 -1
  125. package/dist/components/hovering-toolbar/hovering-editor-provider.d.ts +1 -1
  126. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs +5 -13
  127. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs.map +1 -1
  128. package/dist/components/hovering-toolbar/hovering-toolbar-components.d.ts +2 -1
  129. package/dist/components/hovering-toolbar/hovering-toolbar-components.js +21 -0
  130. package/dist/components/hovering-toolbar/hovering-toolbar-components.js.map +1 -1
  131. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs +9 -111
  132. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs.map +1 -1
  133. package/dist/components/hovering-toolbar/hovering-toolbar.d.ts +1 -1
  134. package/dist/components/hovering-toolbar/hovering-toolbar.js +94 -31
  135. package/dist/components/hovering-toolbar/hovering-toolbar.js.map +1 -1
  136. package/dist/components/hovering-toolbar/hovering-toolbar.mjs +19 -808
  137. package/dist/components/hovering-toolbar/hovering-toolbar.mjs.map +1 -1
  138. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.d.ts +1 -1
  139. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.js +65 -21
  140. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.js.map +1 -1
  141. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs +14 -520
  142. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs.map +1 -1
  143. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.d.ts +1 -1
  144. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.js +68 -24
  145. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.js.map +1 -1
  146. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs +15 -543
  147. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs.map +1 -1
  148. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.d.ts +16 -0
  149. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.js +133 -0
  150. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.js.map +1 -0
  151. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs +12 -0
  152. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs.map +1 -0
  153. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.js +68 -24
  154. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.js.map +1 -1
  155. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs +16 -543
  156. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs.map +1 -1
  157. package/dist/components/index.css +9 -0
  158. package/dist/components/index.css.map +1 -0
  159. package/dist/components/index.js +116 -51
  160. package/dist/components/index.js.map +1 -1
  161. package/dist/components/index.mjs +46 -2211
  162. package/dist/components/index.mjs.map +1 -1
  163. package/dist/components/manual-ui/chip-with-icon.d.ts +1 -1
  164. package/dist/components/manual-ui/chip-with-icon.mjs +2 -0
  165. package/dist/components/manual-ui/chip-with-icon.mjs.map +1 -1
  166. package/dist/components/source-search-box/source-search-box.d.ts +1 -1
  167. package/dist/components/source-search-box/source-search-box.js +4 -2
  168. package/dist/components/source-search-box/source-search-box.js.map +1 -1
  169. package/dist/components/source-search-box/source-search-box.mjs +8 -200
  170. package/dist/components/source-search-box/source-search-box.mjs.map +1 -1
  171. package/dist/components/ui/button.d.ts +1 -1
  172. package/dist/components/ui/button.mjs +6 -76
  173. package/dist/components/ui/button.mjs.map +1 -1
  174. package/dist/components/ui/command.mjs +14 -233
  175. package/dist/components/ui/command.mjs.map +1 -1
  176. package/dist/components/ui/dialog.mjs +11 -135
  177. package/dist/components/ui/dialog.mjs.map +1 -1
  178. package/dist/components/ui/label.mjs +5 -51
  179. package/dist/components/ui/label.mjs.map +1 -1
  180. package/dist/context/index.d.ts +1 -1
  181. package/dist/context/index.mjs +1 -0
  182. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.d.ts +1 -1
  183. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.js.map +1 -1
  184. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs +7 -152
  185. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs.map +1 -1
  186. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs +5 -165
  187. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs.map +1 -1
  188. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.js.map +1 -1
  189. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs +6 -141
  190. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs.map +1 -1
  191. package/dist/hooks/index.d.ts +1 -1
  192. package/dist/hooks/index.mjs +1 -0
  193. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.js.map +1 -1
  194. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +4 -139
  195. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map +1 -1
  196. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.js.map +1 -1
  197. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs +4 -221
  198. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs.map +1 -1
  199. package/dist/hooks/misc/use-autosize-textarea.mjs +4 -12
  200. package/dist/hooks/misc/use-autosize-textarea.mjs.map +1 -1
  201. package/dist/index.css +644 -1
  202. package/dist/index.css.map +1 -0
  203. package/dist/index.js +116 -58
  204. package/dist/index.js.map +1 -1
  205. package/dist/index.mjs +54 -2218
  206. package/dist/index.mjs.map +1 -1
  207. package/dist/lib/debouncer.d.ts +1 -1
  208. package/dist/lib/debouncer.js.map +1 -1
  209. package/dist/lib/debouncer.mjs +4 -48
  210. package/dist/lib/debouncer.mjs.map +1 -1
  211. package/dist/lib/editor-to-text.mjs +4 -40
  212. package/dist/lib/editor-to-text.mjs.map +1 -1
  213. package/dist/lib/get-text-around-cursor.d.ts +1 -1
  214. package/dist/lib/get-text-around-cursor.mjs +7 -96
  215. package/dist/lib/get-text-around-cursor.mjs.map +1 -1
  216. package/dist/lib/retry.mjs +4 -14
  217. package/dist/lib/retry.mjs.map +1 -1
  218. package/dist/lib/slatejs-edits/add-autocompletions.mjs +4 -22
  219. package/dist/lib/slatejs-edits/add-autocompletions.mjs.map +1 -1
  220. package/dist/lib/slatejs-edits/clear-autocompletions.js.map +1 -1
  221. package/dist/lib/slatejs-edits/clear-autocompletions.mjs +4 -17
  222. package/dist/lib/slatejs-edits/clear-autocompletions.mjs.map +1 -1
  223. package/dist/lib/slatejs-edits/replace-text.mjs +4 -24
  224. package/dist/lib/slatejs-edits/replace-text.mjs.map +1 -1
  225. package/dist/lib/slatejs-edits/with-partial-history.d.ts +1 -1
  226. package/dist/lib/slatejs-edits/with-partial-history.mjs +5 -102
  227. package/dist/lib/slatejs-edits/with-partial-history.mjs.map +1 -1
  228. package/dist/lib/stream-promise-flatten.js.map +1 -1
  229. package/dist/lib/stream-promise-flatten.mjs +4 -44
  230. package/dist/lib/stream-promise-flatten.mjs.map +1 -1
  231. package/dist/lib/utils.mjs +8 -58
  232. package/dist/lib/utils.mjs.map +1 -1
  233. package/dist/lib/utils.test.d.ts +1 -1
  234. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.d.ts +1 -1
  235. package/dist/types/autosuggestions-config/autosuggestions-config.d.ts +1 -1
  236. package/dist/types/autosuggestions-config/autosuggestions-config.js.map +1 -1
  237. package/dist/types/autosuggestions-config/autosuggestions-config.mjs +9 -258
  238. package/dist/types/autosuggestions-config/autosuggestions-config.mjs.map +1 -1
  239. package/dist/types/autosuggestions-config/editing-api-config.d.ts +1 -1
  240. package/dist/types/autosuggestions-config/editing-api-config.js.map +1 -1
  241. package/dist/types/autosuggestions-config/editing-api-config.mjs +6 -75
  242. package/dist/types/autosuggestions-config/editing-api-config.mjs.map +1 -1
  243. package/dist/types/autosuggestions-config/index.js.map +1 -1
  244. package/dist/types/autosuggestions-config/index.mjs +10 -258
  245. package/dist/types/autosuggestions-config/index.mjs.map +1 -1
  246. package/dist/types/autosuggestions-config/insertions-api-config.d.ts +1 -1
  247. package/dist/types/autosuggestions-config/insertions-api-config.js.map +1 -1
  248. package/dist/types/autosuggestions-config/insertions-api-config.mjs +6 -68
  249. package/dist/types/autosuggestions-config/insertions-api-config.mjs.map +1 -1
  250. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.d.ts +1 -1
  251. package/dist/types/autosuggestions-config/suggestions-api-config.d.ts +1 -1
  252. package/dist/types/autosuggestions-config/suggestions-api-config.js.map +1 -1
  253. package/dist/types/autosuggestions-config/suggestions-api-config.mjs +6 -56
  254. package/dist/types/autosuggestions-config/suggestions-api-config.mjs.map +1 -1
  255. package/dist/types/base/autosuggestion-state.d.ts +1 -1
  256. package/dist/types/base/autosuggestions-bare-function.d.ts +1 -1
  257. package/dist/types/base/base-autosuggestions-config.d.ts +1 -1
  258. package/dist/types/base/base-autosuggestions-config.mjs +4 -25
  259. package/dist/types/base/base-autosuggestions-config.mjs.map +1 -1
  260. package/dist/types/base/custom-editor.d.ts +1 -1
  261. package/dist/types/base/editor-autocomplete-state.d.ts +1 -1
  262. package/dist/types/base/editor-autocomplete-state.mjs +5 -9
  263. package/dist/types/base/editor-autocomplete-state.mjs.map +1 -1
  264. package/dist/types/base/index.d.ts +1 -1
  265. package/dist/types/base/index.mjs +5 -25
  266. package/dist/types/base/index.mjs.map +1 -1
  267. package/dist/types/html-copilot-textarea-element.d.ts +1 -1
  268. package/dist/types/html-copilot-textarea-element.mjs +1 -0
  269. package/dist/types/index.js.map +1 -1
  270. package/dist/types/index.mjs +14 -258
  271. package/dist/types/index.mjs.map +1 -1
  272. package/package.json +11 -17
  273. package/src/components/base-copilot-textarea/base-copilot-textarea.css +9 -0
  274. package/src/components/base-copilot-textarea/base-copilot-textarea.tsx +1 -0
  275. package/src/components/copilot-textarea/copilot-textarea.tsx +8 -2
  276. package/src/components/hovering-toolbar/hovering-toolbar-components.tsx +17 -0
  277. package/src/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.tsx +7 -4
  278. package/src/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.tsx +55 -0
  279. package/src/styles.css +2 -9
  280. package/tsup.config.ts +15 -63
  281. package/dist/components/base-copilot-textarea/base-copilot-textarea.d.mts +0 -43
  282. package/dist/components/base-copilot-textarea/render-element.d.mts +0 -6
  283. package/dist/components/base-copilot-textarea/render-placeholder.d.mts +0 -6
  284. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.d.mts +0 -8
  285. package/dist/components/base-copilot-textarea/use-add-branding-css.d.mts +0 -3
  286. package/dist/components/copilot-textarea/copilot-textarea.d.mts +0 -165
  287. package/dist/components/hovering-toolbar/hovering-editor-provider.d.mts +0 -18
  288. package/dist/components/hovering-toolbar/hovering-toolbar-components.d.mts +0 -17
  289. package/dist/components/hovering-toolbar/hovering-toolbar.d.mts +0 -12
  290. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.d.mts +0 -16
  291. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.d.mts +0 -14
  292. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.d.mts +0 -4
  293. package/dist/components/index.d.mts +0 -15
  294. package/dist/components/manual-ui/chip-with-icon.d.mts +0 -10
  295. package/dist/components/source-search-box/source-search-box.d.mts +0 -16
  296. package/dist/components/ui/button.d.mts +0 -14
  297. package/dist/components/ui/command.d.mts +0 -53
  298. package/dist/components/ui/dialog.d.mts +0 -19
  299. package/dist/components/ui/label.d.mts +0 -8
  300. package/dist/context/index.d.mts +0 -2
  301. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.d.mts +0 -15
  302. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.d.mts +0 -8
  303. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.d.mts +0 -7
  304. package/dist/hooks/index.d.mts +0 -2
  305. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.d.mts +0 -22
  306. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.d.mts +0 -23
  307. package/dist/hooks/misc/use-autosize-textarea.d.mts +0 -5
  308. package/dist/index.d.mts +0 -15
  309. package/dist/lib/debouncer.d.mts +0 -11
  310. package/dist/lib/editor-to-text.d.mts +0 -7
  311. package/dist/lib/get-text-around-cursor.d.mts +0 -15
  312. package/dist/lib/retry.d.mts +0 -3
  313. package/dist/lib/slatejs-edits/add-autocompletions.d.mts +0 -8
  314. package/dist/lib/slatejs-edits/clear-autocompletions.d.mts +0 -8
  315. package/dist/lib/slatejs-edits/replace-text.d.mts +0 -5
  316. package/dist/lib/slatejs-edits/with-partial-history.d.mts +0 -8
  317. package/dist/lib/stream-promise-flatten.d.mts +0 -12
  318. package/dist/lib/utils.d.mts +0 -9
  319. package/dist/lib/utils.test.d.mts +0 -2
  320. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.d.mts +0 -23
  321. package/dist/types/autosuggestions-config/autosuggestions-config.d.mts +0 -20
  322. package/dist/types/autosuggestions-config/editing-api-config.d.mts +0 -15
  323. package/dist/types/autosuggestions-config/index.d.mts +0 -10
  324. package/dist/types/autosuggestions-config/insertions-api-config.d.mts +0 -15
  325. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.d.mts +0 -3
  326. package/dist/types/autosuggestions-config/suggestions-api-config.d.mts +0 -14
  327. package/dist/types/base/autosuggestion-state.d.mts +0 -8
  328. package/dist/types/base/autosuggestions-bare-function.d.mts +0 -19
  329. package/dist/types/base/base-autosuggestions-config.d.mts +0 -83
  330. package/dist/types/base/base-copilot-textarea-props.d.mts +0 -5
  331. package/dist/types/base/custom-editor.d.mts +0 -29
  332. package/dist/types/base/editor-autocomplete-state.d.mts +0 -10
  333. package/dist/types/base/index.d.mts +0 -54
  334. package/dist/types/html-copilot-textarea-element.d.mts +0 -7
  335. package/dist/types/index.d.mts +0 -13
package/CHANGELOG.md CHANGED
@@ -1,5 +1,15 @@
1
1
  # ui
2
2
 
3
+ ## 1.3.1
4
+
5
+ ### Patch Changes
6
+
7
+ - Revert CSS injection
8
+ - Updated dependencies
9
+ - @copilotkit/react-core@1.3.1
10
+ - @copilotkit/runtime-client-gql@1.3.1
11
+ - @copilotkit/shared@1.3.1
12
+
3
13
  ## 1.3.0
4
14
 
5
15
  ### Minor Changes
@@ -0,0 +1,38 @@
1
+ import {
2
+ __spreadProps,
3
+ __spreadValues
4
+ } from "./chunk-MRXNTQOX.mjs";
5
+
6
+ // src/components/base-copilot-textarea/render-element.tsx
7
+ import { jsx, jsxs } from "react/jsx-runtime";
8
+ function makeRenderElementFunction(suggestionsStyle) {
9
+ return (props) => {
10
+ switch (props.element.type) {
11
+ case "paragraph":
12
+ return /* @__PURE__ */ jsx(DefaultElement, __spreadValues({}, props));
13
+ case "suggestion":
14
+ return /* @__PURE__ */ jsx(SuggestionElement, __spreadProps(__spreadValues({}, props), { suggestionsStyle }));
15
+ }
16
+ };
17
+ }
18
+ var DefaultElement = (props) => {
19
+ return /* @__PURE__ */ jsx("div", __spreadProps(__spreadValues({}, props.attributes), { children: props.children }));
20
+ };
21
+ var SuggestionElement = (props) => {
22
+ return /* @__PURE__ */ jsxs(
23
+ "span",
24
+ __spreadProps(__spreadValues({}, props.attributes), {
25
+ style: __spreadValues({}, props.suggestionsStyle),
26
+ contentEditable: false,
27
+ children: [
28
+ props.children,
29
+ props.element.type === "suggestion" && props.element.content
30
+ ]
31
+ })
32
+ );
33
+ };
34
+
35
+ export {
36
+ makeRenderElementFunction
37
+ };
38
+ //# sourceMappingURL=chunk-224UKA7C.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/base-copilot-textarea/render-element.tsx"],"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 <SuggestionElement {...props} suggestionsStyle={suggestionsStyle} />;\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"],"mappings":";;;;;;AAUe,cAgBX,YAhBW;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,eAAO,oBAAC,oDAAsB,QAAtB,EAA6B,mBAAoC;AAAA,IAC7E;AAAA,EACF;AACF;AAEA,IAAM,iBAAiB,CAAC,UAA8B;AACpD,SAAO,oBAAC,wCAAQ,MAAM,aAAd,EAA2B,gBAAM,WAAS;AACpD;AACA,IAAM,oBAAoB,CACxB,UAGG;AACH,SACE;AAAA,IAAC;AAAA,qCACK,MAAM,aADX;AAAA,MAEC,OAAO,mBACF,MAAM;AAAA,MAEX,iBAAiB;AAAA,MAEhB;AAAA,cAAM;AAAA,QACN,MAAM,QAAQ,SAAS,gBAAgB,MAAM,QAAQ;AAAA;AAAA;AAAA,EACxD;AAEJ;","names":[]}
@@ -0,0 +1,103 @@
1
+ import {
2
+ areEqual_autocompleteState
3
+ } from "./chunk-AJ5OMEXM.mjs";
4
+ import {
5
+ nullableCompatibleEqualityCheck
6
+ } from "./chunk-YLFAIYRY.mjs";
7
+ import {
8
+ Debouncer
9
+ } from "./chunk-DFTV4TST.mjs";
10
+ import {
11
+ __async
12
+ } from "./chunk-MRXNTQOX.mjs";
13
+
14
+ // src/hooks/base-copilot-textarea-implementation/use-autosuggestions.ts
15
+ import { useCallback, useEffect, useMemo, useState } from "react";
16
+ function useAutosuggestions(debounceTime, shouldAcceptAutosuggestionOnKeyPress, shouldAcceptAutosuggestionOnTouch, autosuggestionFunction, insertAutocompleteSuggestion, disableWhenEmpty, disabled) {
17
+ const [previousAutocompleteState, setPreviousAutocompleteState] = useState(null);
18
+ const [currentAutocompleteSuggestion, setCurrentAutocompleteSuggestion] = useState(null);
19
+ const awaitForAndAppendSuggestion = useCallback(
20
+ (editorAutocompleteState, abortSignal) => __async(this, null, function* () {
21
+ if (disabled) {
22
+ return;
23
+ }
24
+ if (disableWhenEmpty && editorAutocompleteState.textBeforeCursor === "" && editorAutocompleteState.textAfterCursor === "") {
25
+ return;
26
+ }
27
+ const suggestion = yield autosuggestionFunction(editorAutocompleteState, abortSignal);
28
+ if (!suggestion || abortSignal.aborted) {
29
+ throw new DOMException("Aborted", "AbortError");
30
+ }
31
+ setCurrentAutocompleteSuggestion({
32
+ text: suggestion,
33
+ point: editorAutocompleteState.cursorPoint
34
+ });
35
+ }),
36
+ [autosuggestionFunction, setCurrentAutocompleteSuggestion, disableWhenEmpty, disabled]
37
+ );
38
+ const debouncedFunction = useMemo(
39
+ () => new Debouncer(debounceTime),
40
+ [debounceTime]
41
+ );
42
+ useEffect(() => {
43
+ return () => {
44
+ debouncedFunction.cancel();
45
+ setCurrentAutocompleteSuggestion(null);
46
+ };
47
+ }, [debouncedFunction, disabled]);
48
+ const onChange = useCallback(
49
+ (newEditorState) => {
50
+ const editorStateHasChanged = !nullableCompatibleEqualityCheck(
51
+ areEqual_autocompleteState,
52
+ previousAutocompleteState,
53
+ newEditorState
54
+ );
55
+ setPreviousAutocompleteState(newEditorState);
56
+ if (!editorStateHasChanged) {
57
+ return;
58
+ }
59
+ setCurrentAutocompleteSuggestion(null);
60
+ if (newEditorState) {
61
+ debouncedFunction.debounce(awaitForAndAppendSuggestion, newEditorState);
62
+ } else {
63
+ debouncedFunction.cancel();
64
+ }
65
+ },
66
+ [
67
+ previousAutocompleteState,
68
+ setPreviousAutocompleteState,
69
+ debouncedFunction,
70
+ awaitForAndAppendSuggestion,
71
+ setCurrentAutocompleteSuggestion
72
+ ]
73
+ );
74
+ const keyDownOrTouchHandler = useCallback(
75
+ (event) => {
76
+ if (currentAutocompleteSuggestion) {
77
+ const shouldAcceptSuggestion = event.type === "touchstart" ? shouldAcceptAutosuggestionOnTouch(event) : shouldAcceptAutosuggestionOnKeyPress(event);
78
+ if (shouldAcceptSuggestion) {
79
+ event.preventDefault();
80
+ insertAutocompleteSuggestion(currentAutocompleteSuggestion);
81
+ setCurrentAutocompleteSuggestion(null);
82
+ }
83
+ }
84
+ },
85
+ [
86
+ currentAutocompleteSuggestion,
87
+ setCurrentAutocompleteSuggestion,
88
+ insertAutocompleteSuggestion,
89
+ shouldAcceptAutosuggestionOnKeyPress
90
+ ]
91
+ );
92
+ return {
93
+ currentAutocompleteSuggestion,
94
+ onChangeHandler: onChange,
95
+ onKeyDownHandler: keyDownOrTouchHandler,
96
+ onTouchStartHandler: keyDownOrTouchHandler
97
+ };
98
+ }
99
+
100
+ export {
101
+ useAutosuggestions
102
+ };
103
+ //# sourceMappingURL=chunk-23Q6A46J.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/hooks/base-copilot-textarea-implementation/use-autosuggestions.ts"],"sourcesContent":["import { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { Debouncer } from \"../../lib/debouncer\";\nimport { nullableCompatibleEqualityCheck } from \"../../lib/utils\";\nimport { AutosuggestionsBareFunction } from \"../../types/base\";\nimport { AutosuggestionState } from \"../../types/base/autosuggestion-state\";\nimport {\n EditorAutocompleteState,\n areEqual_autocompleteState,\n} from \"../../types/base/editor-autocomplete-state\";\n\nexport interface UseAutosuggestionsResult {\n currentAutocompleteSuggestion: AutosuggestionState | null;\n onChangeHandler: (newEditorState: EditorAutocompleteState | null) => void;\n onKeyDownHandler: (event: React.KeyboardEvent<HTMLDivElement>) => void;\n onTouchStartHandler: (event: React.TouchEvent<HTMLDivElement>) => void;\n}\n\nexport function useAutosuggestions(\n debounceTime: number,\n shouldAcceptAutosuggestionOnKeyPress: (event: React.KeyboardEvent<HTMLDivElement>) => boolean,\n shouldAcceptAutosuggestionOnTouch: (event: React.TouchEvent<HTMLDivElement>) => boolean,\n autosuggestionFunction: AutosuggestionsBareFunction,\n insertAutocompleteSuggestion: (suggestion: AutosuggestionState) => void,\n disableWhenEmpty: boolean,\n disabled: boolean,\n): UseAutosuggestionsResult {\n const [previousAutocompleteState, setPreviousAutocompleteState] =\n useState<EditorAutocompleteState | null>(null);\n\n const [currentAutocompleteSuggestion, setCurrentAutocompleteSuggestion] =\n useState<AutosuggestionState | null>(null);\n\n const awaitForAndAppendSuggestion: (\n editorAutocompleteState: EditorAutocompleteState,\n abortSignal: AbortSignal,\n ) => Promise<void> = useCallback(\n async (editorAutocompleteState: EditorAutocompleteState, abortSignal: AbortSignal) => {\n // early return if disabled\n if (disabled) {\n return;\n }\n\n if (\n disableWhenEmpty &&\n editorAutocompleteState.textBeforeCursor === \"\" &&\n editorAutocompleteState.textAfterCursor === \"\"\n ) {\n return;\n }\n\n // fetch the suggestion\n const suggestion = await autosuggestionFunction(editorAutocompleteState, abortSignal);\n\n // We'll assume for now that the autocomplete function might or might not respect the abort signal.\n if (!suggestion || abortSignal.aborted) {\n throw new DOMException(\"Aborted\", \"AbortError\");\n }\n\n setCurrentAutocompleteSuggestion({\n text: suggestion,\n point: editorAutocompleteState.cursorPoint,\n });\n },\n [autosuggestionFunction, setCurrentAutocompleteSuggestion, disableWhenEmpty, disabled],\n );\n\n const debouncedFunction = useMemo(\n () => new Debouncer<[editorAutocompleteState: EditorAutocompleteState]>(debounceTime),\n [debounceTime],\n );\n\n // clean current state when unmounting or disabling\n useEffect(() => {\n return () => {\n debouncedFunction.cancel();\n setCurrentAutocompleteSuggestion(null);\n };\n }, [debouncedFunction, disabled]);\n\n const onChange = useCallback(\n (newEditorState: EditorAutocompleteState | null) => {\n const editorStateHasChanged = !nullableCompatibleEqualityCheck(\n areEqual_autocompleteState,\n previousAutocompleteState,\n newEditorState,\n );\n setPreviousAutocompleteState(newEditorState);\n\n // if no change, do nothing\n if (!editorStateHasChanged) {\n return;\n }\n\n // if change, then first null out the current suggestion\n setCurrentAutocompleteSuggestion(null);\n\n // then try to get a new suggestion, debouncing to avoid too many requests while typing\n if (newEditorState) {\n debouncedFunction.debounce(awaitForAndAppendSuggestion, newEditorState);\n } else {\n debouncedFunction.cancel();\n }\n },\n [\n previousAutocompleteState,\n setPreviousAutocompleteState,\n debouncedFunction,\n awaitForAndAppendSuggestion,\n setCurrentAutocompleteSuggestion,\n ],\n );\n\n const keyDownOrTouchHandler = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement> | React.TouchEvent<HTMLDivElement>) => {\n if (currentAutocompleteSuggestion) {\n const shouldAcceptSuggestion =\n event.type === \"touchstart\"\n ? shouldAcceptAutosuggestionOnTouch(event as React.TouchEvent<HTMLDivElement>)\n : shouldAcceptAutosuggestionOnKeyPress(event as React.KeyboardEvent<HTMLDivElement>);\n\n if (shouldAcceptSuggestion) {\n event.preventDefault();\n insertAutocompleteSuggestion(currentAutocompleteSuggestion);\n setCurrentAutocompleteSuggestion(null);\n }\n }\n },\n [\n currentAutocompleteSuggestion,\n setCurrentAutocompleteSuggestion,\n insertAutocompleteSuggestion,\n shouldAcceptAutosuggestionOnKeyPress,\n ],\n );\n\n return {\n currentAutocompleteSuggestion,\n onChangeHandler: onChange,\n onKeyDownHandler: keyDownOrTouchHandler,\n onTouchStartHandler: keyDownOrTouchHandler,\n };\n}\n"],"mappings":";;;;;;;;;;;;;;AAAA,SAAS,aAAa,WAAW,SAAS,gBAAgB;AAiBnD,SAAS,mBACd,cACA,sCACA,mCACA,wBACA,8BACA,kBACA,UAC0B;AAC1B,QAAM,CAAC,2BAA2B,4BAA4B,IAC5D,SAAyC,IAAI;AAE/C,QAAM,CAAC,+BAA+B,gCAAgC,IACpE,SAAqC,IAAI;AAE3C,QAAM,8BAGe;AAAA,IACnB,CAAO,yBAAkD,gBAA6B;AAEpF,UAAI,UAAU;AACZ;AAAA,MACF;AAEA,UACE,oBACA,wBAAwB,qBAAqB,MAC7C,wBAAwB,oBAAoB,IAC5C;AACA;AAAA,MACF;AAGA,YAAM,aAAa,MAAM,uBAAuB,yBAAyB,WAAW;AAGpF,UAAI,CAAC,cAAc,YAAY,SAAS;AACtC,cAAM,IAAI,aAAa,WAAW,YAAY;AAAA,MAChD;AAEA,uCAAiC;AAAA,QAC/B,MAAM;AAAA,QACN,OAAO,wBAAwB;AAAA,MACjC,CAAC;AAAA,IACH;AAAA,IACA,CAAC,wBAAwB,kCAAkC,kBAAkB,QAAQ;AAAA,EACvF;AAEA,QAAM,oBAAoB;AAAA,IACxB,MAAM,IAAI,UAA8D,YAAY;AAAA,IACpF,CAAC,YAAY;AAAA,EACf;AAGA,YAAU,MAAM;AACd,WAAO,MAAM;AACX,wBAAkB,OAAO;AACzB,uCAAiC,IAAI;AAAA,IACvC;AAAA,EACF,GAAG,CAAC,mBAAmB,QAAQ,CAAC;AAEhC,QAAM,WAAW;AAAA,IACf,CAAC,mBAAmD;AAClD,YAAM,wBAAwB,CAAC;AAAA,QAC7B;AAAA,QACA;AAAA,QACA;AAAA,MACF;AACA,mCAA6B,cAAc;AAG3C,UAAI,CAAC,uBAAuB;AAC1B;AAAA,MACF;AAGA,uCAAiC,IAAI;AAGrC,UAAI,gBAAgB;AAClB,0BAAkB,SAAS,6BAA6B,cAAc;AAAA,MACxE,OAAO;AACL,0BAAkB,OAAO;AAAA,MAC3B;AAAA,IACF;AAAA,IACA;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,QAAM,wBAAwB;AAAA,IAC5B,CAAC,UAAkF;AACjF,UAAI,+BAA+B;AACjC,cAAM,yBACJ,MAAM,SAAS,eACX,kCAAkC,KAAyC,IAC3E,qCAAqC,KAA4C;AAEvF,YAAI,wBAAwB;AAC1B,gBAAM,eAAe;AACrB,uCAA6B,6BAA6B;AAC1D,2CAAiC,IAAI;AAAA,QACvC;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL;AAAA,IACA,iBAAiB;AAAA,IACjB,kBAAkB;AAAA,IAClB,qBAAqB;AAAA,EACvB;AACF;","names":[]}
@@ -0,0 +1,27 @@
1
+ // src/lib/slatejs-edits/add-autocompletions.ts
2
+ import { Transforms } from "slate";
3
+ function addAutocompletionsToEditor(editor, newSuggestion, point) {
4
+ const editorPosition = editor.selection;
5
+ Transforms.insertNodes(
6
+ editor,
7
+ [
8
+ {
9
+ type: "suggestion",
10
+ inline: true,
11
+ content: newSuggestion,
12
+ children: [{ text: "" }]
13
+ }
14
+ ],
15
+ {
16
+ at: point
17
+ }
18
+ );
19
+ if (editorPosition) {
20
+ editor.selection = editorPosition;
21
+ }
22
+ }
23
+
24
+ export {
25
+ addAutocompletionsToEditor
26
+ };
27
+ //# sourceMappingURL=chunk-2C7O2EVM.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/slatejs-edits/add-autocompletions.ts"],"sourcesContent":["import { BasePoint, Transforms } from \"slate\";\nimport { CustomEditor } from \"../../types/base/custom-editor\";\n\nexport function addAutocompletionsToEditor(\n editor: CustomEditor,\n newSuggestion: string,\n point: BasePoint,\n) {\n const editorPosition = editor.selection;\n\n Transforms.insertNodes(\n editor,\n [\n {\n type: \"suggestion\",\n inline: true,\n content: newSuggestion,\n children: [{ text: \"\" }],\n },\n ],\n {\n at: point,\n },\n );\n\n // restore cursor position\n if (editorPosition) {\n editor.selection = editorPosition;\n }\n}\n"],"mappings":";AAAA,SAAoB,kBAAkB;AAG/B,SAAS,2BACd,QACA,eACA,OACA;AACA,QAAM,iBAAiB,OAAO;AAE9B,aAAW;AAAA,IACT;AAAA,IACA;AAAA,MACE;AAAA,QACE,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,SAAS;AAAA,QACT,UAAU,CAAC,EAAE,MAAM,GAAG,CAAC;AAAA,MACzB;AAAA,IACF;AAAA,IACA;AAAA,MACE,IAAI;AAAA,IACN;AAAA,EACF;AAGA,MAAI,gBAAgB;AAClB,WAAO,YAAY;AAAA,EACrB;AACF;","names":[]}
@@ -0,0 +1,32 @@
1
+ import {
2
+ __async
3
+ } from "./chunk-MRXNTQOX.mjs";
4
+
5
+ // src/lib/stream-promise-flatten.ts
6
+ function streamPromiseFlatten(promise) {
7
+ return new ReadableStream({
8
+ start(controller) {
9
+ return __async(this, null, function* () {
10
+ try {
11
+ const stream = yield promise;
12
+ const reader = stream.getReader();
13
+ while (true) {
14
+ const { done, value } = yield reader.read();
15
+ if (done) {
16
+ controller.close();
17
+ return;
18
+ }
19
+ controller.enqueue(value);
20
+ }
21
+ } catch (error) {
22
+ controller.error(error);
23
+ }
24
+ });
25
+ }
26
+ });
27
+ }
28
+
29
+ export {
30
+ streamPromiseFlatten
31
+ };
32
+ //# sourceMappingURL=chunk-2QDCE7PD.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/stream-promise-flatten.ts"],"sourcesContent":["/**\n * Flatten a promise of a stream, into a stream.\n *\n * Useful because a stream already includes the notion of async value delivery,\n * so it often makes sense to simply await the values rather than the generator of the values.\n *\n * @param {Promise<ReadableStream<A>>} promise - The promise to flatten.\n * @returns {ReadableStream<A>} - The flattened stream.\n */\n\nexport function streamPromiseFlatten<A>(promise: Promise<ReadableStream<A>>): ReadableStream<A> {\n return new ReadableStream<A>({\n async start(controller) {\n try {\n const stream = await promise;\n const reader = stream.getReader();\n\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n controller.close();\n return;\n }\n\n controller.enqueue(value);\n }\n } catch (error) {\n controller.error(error);\n }\n },\n });\n}\n"],"mappings":";;;;;AAUO,SAAS,qBAAwB,SAAwD;AAC9F,SAAO,IAAI,eAAkB;AAAA,IACrB,MAAM,YAAY;AAAA;AACtB,YAAI;AACF,gBAAM,SAAS,MAAM;AACrB,gBAAM,SAAS,OAAO,UAAU;AAEhC,iBAAO,MAAM;AACX,kBAAM,EAAE,MAAM,MAAM,IAAI,MAAM,OAAO,KAAK;AAE1C,gBAAI,MAAM;AACR,yBAAW,MAAM;AACjB;AAAA,YACF;AAEA,uBAAW,QAAQ,KAAK;AAAA,UAC1B;AAAA,QACF,SAAS,OAAP;AACA,qBAAW,MAAM,KAAK;AAAA,QACxB;AAAA,MACF;AAAA;AAAA,EACF,CAAC;AACH;","names":[]}
@@ -0,0 +1,181 @@
1
+ import {
2
+ retry
3
+ } from "./chunk-KNQIEOFP.mjs";
4
+ import {
5
+ __async,
6
+ __spreadValues
7
+ } from "./chunk-MRXNTQOX.mjs";
8
+
9
+ // src/hooks/make-autosuggestions-function/use-make-standard-insertion-function.tsx
10
+ import { COPILOT_CLOUD_PUBLIC_API_KEY_HEADER } from "@copilotkit/shared";
11
+ import { useCopilotContext } from "@copilotkit/react-core";
12
+ import { useCallback } from "react";
13
+ import {
14
+ CopilotRuntimeClient,
15
+ Role,
16
+ TextMessage,
17
+ convertGqlOutputToMessages,
18
+ convertMessagesToGqlInput,
19
+ filterAgentStateMessages,
20
+ CopilotRequestType
21
+ } from "@copilotkit/runtime-client-gql";
22
+ function useMakeStandardInsertionOrEditingFunction(textareaPurpose, contextCategories, insertionApiConfig, editingApiConfig) {
23
+ const { getContextString, copilotApiConfig } = useCopilotContext();
24
+ const headers = __spreadValues({}, copilotApiConfig.publicApiKey ? { [COPILOT_CLOUD_PUBLIC_API_KEY_HEADER]: copilotApiConfig.publicApiKey } : {});
25
+ const runtimeClient = new CopilotRuntimeClient({
26
+ url: copilotApiConfig.chatApiEndpoint,
27
+ publicApiKey: copilotApiConfig.publicApiKey,
28
+ headers,
29
+ credentials: copilotApiConfig.credentials
30
+ });
31
+ function runtimeClientResponseToStringStream(responsePromise) {
32
+ return __async(this, null, function* () {
33
+ const messagesStream = yield CopilotRuntimeClient.asStream(responsePromise);
34
+ return new ReadableStream({
35
+ start(controller) {
36
+ return __async(this, null, function* () {
37
+ const reader = messagesStream.getReader();
38
+ let sentContent = "";
39
+ while (true) {
40
+ const { done, value } = yield reader.read();
41
+ if (done) {
42
+ break;
43
+ }
44
+ const messages = convertGqlOutputToMessages(value.generateCopilotResponse.messages);
45
+ let newContent = "";
46
+ for (const message of messages) {
47
+ if (message instanceof TextMessage) {
48
+ newContent += message.content;
49
+ }
50
+ }
51
+ if (newContent) {
52
+ const contentToSend = newContent.slice(sentContent.length);
53
+ controller.enqueue(contentToSend);
54
+ sentContent += contentToSend;
55
+ }
56
+ }
57
+ controller.close();
58
+ });
59
+ }
60
+ });
61
+ });
62
+ }
63
+ const insertionFunction = useCallback(
64
+ (editorState, insertionPrompt, documents, abortSignal) => __async(this, null, function* () {
65
+ const res = yield retry(() => __async(this, null, function* () {
66
+ const messages = [
67
+ new TextMessage({
68
+ role: Role.System,
69
+ content: insertionApiConfig.makeSystemPrompt(
70
+ textareaPurpose,
71
+ getContextString(documents, contextCategories)
72
+ )
73
+ }),
74
+ ...insertionApiConfig.fewShotMessages,
75
+ new TextMessage({
76
+ role: Role.User,
77
+ content: `<TextAfterCursor>${editorState.textAfterCursor}</TextAfterCursor>`
78
+ }),
79
+ new TextMessage({
80
+ role: Role.User,
81
+ content: `<TextBeforeCursor>${editorState.textBeforeCursor}</TextBeforeCursor>`
82
+ }),
83
+ new TextMessage({
84
+ role: Role.User,
85
+ content: `<InsertionPrompt>${insertionPrompt}</InsertionPrompt>`
86
+ })
87
+ ];
88
+ return runtimeClientResponseToStringStream(
89
+ runtimeClient.generateCopilotResponse({
90
+ data: {
91
+ frontend: {
92
+ actions: [],
93
+ url: window.location.href
94
+ },
95
+ messages: convertMessagesToGqlInput(filterAgentStateMessages(messages)),
96
+ metadata: {
97
+ requestType: CopilotRequestType.TextareaCompletion
98
+ }
99
+ },
100
+ properties: copilotApiConfig.properties,
101
+ signal: abortSignal
102
+ })
103
+ );
104
+ }));
105
+ return res;
106
+ }),
107
+ [insertionApiConfig, getContextString, contextCategories, textareaPurpose]
108
+ );
109
+ const editingFunction = useCallback(
110
+ (editorState, editingPrompt, documents, abortSignal) => __async(this, null, function* () {
111
+ const res = yield retry(() => __async(this, null, function* () {
112
+ const messages = [
113
+ new TextMessage({
114
+ role: Role.System,
115
+ content: editingApiConfig.makeSystemPrompt(
116
+ textareaPurpose,
117
+ getContextString(documents, contextCategories)
118
+ )
119
+ }),
120
+ ...editingApiConfig.fewShotMessages,
121
+ new TextMessage({
122
+ role: Role.User,
123
+ content: `<TextBeforeCursor>${editorState.textBeforeCursor}</TextBeforeCursor>`
124
+ }),
125
+ new TextMessage({
126
+ role: Role.User,
127
+ content: `<TextToEdit>${editorState.selectedText}</TextToEdit>`
128
+ }),
129
+ new TextMessage({
130
+ role: Role.User,
131
+ content: `<TextAfterCursor>${editorState.textAfterCursor}</TextAfterCursor>`
132
+ }),
133
+ new TextMessage({
134
+ role: Role.User,
135
+ content: `<EditingPrompt>${editingPrompt}</EditingPrompt>`
136
+ })
137
+ ];
138
+ const runtimeClient2 = new CopilotRuntimeClient({
139
+ url: copilotApiConfig.chatApiEndpoint,
140
+ publicApiKey: copilotApiConfig.publicApiKey,
141
+ headers,
142
+ credentials: copilotApiConfig.credentials
143
+ });
144
+ return runtimeClientResponseToStringStream(
145
+ runtimeClient2.generateCopilotResponse({
146
+ data: {
147
+ frontend: {
148
+ actions: [],
149
+ url: window.location.href
150
+ },
151
+ messages: convertMessagesToGqlInput(filterAgentStateMessages(messages)),
152
+ metadata: {
153
+ requestType: CopilotRequestType.TextareaCompletion
154
+ }
155
+ },
156
+ properties: copilotApiConfig.properties,
157
+ signal: abortSignal
158
+ })
159
+ );
160
+ }));
161
+ return res;
162
+ }),
163
+ [editingApiConfig, getContextString, contextCategories, textareaPurpose]
164
+ );
165
+ const insertionOrEditingFunction = useCallback(
166
+ (editorState, insertionPrompt, documents, abortSignal) => __async(this, null, function* () {
167
+ if (editorState.selectedText === "") {
168
+ return yield insertionFunction(editorState, insertionPrompt, documents, abortSignal);
169
+ } else {
170
+ return yield editingFunction(editorState, insertionPrompt, documents, abortSignal);
171
+ }
172
+ }),
173
+ [insertionFunction, editingFunction]
174
+ );
175
+ return insertionOrEditingFunction;
176
+ }
177
+
178
+ export {
179
+ useMakeStandardInsertionOrEditingFunction
180
+ };
181
+ //# sourceMappingURL=chunk-2XDYLKPH.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/hooks/make-autosuggestions-function/use-make-standard-insertion-function.tsx"],"sourcesContent":["import { COPILOT_CLOUD_PUBLIC_API_KEY_HEADER } from \"@copilotkit/shared\";\nimport { useCopilotContext } from \"@copilotkit/react-core\";\nimport { useCallback } from \"react\";\nimport {\n CopilotRuntimeClient,\n Message,\n Role,\n TextMessage,\n convertGqlOutputToMessages,\n convertMessagesToGqlInput,\n filterAgentStateMessages,\n CopilotRequestType,\n} from \"@copilotkit/runtime-client-gql\";\nimport { retry } from \"../../lib/retry\";\nimport {\n EditingEditorState,\n Generator_InsertionOrEditingSuggestion,\n} from \"../../types/base/autosuggestions-bare-function\";\nimport { InsertionsApiConfig } from \"../../types/autosuggestions-config/insertions-api-config\";\nimport { EditingApiConfig } from \"../../types/autosuggestions-config/editing-api-config\";\nimport { DocumentPointer } from \"@copilotkit/react-core\";\n\n/**\n * Returns a memoized function that sends a request to the specified API endpoint to get an autosuggestion for the user's input.\n * The function takes in the text before and after the cursor, and an abort signal.\n * It sends a POST request to the API endpoint with the messages array containing the system message, few shot messages, and user messages.\n * The function returns the suggestion from the API response.\n *\n * @param textareaPurpose - The purpose of the textarea. This is included in the system message.\n * @param apiEndpoint - The API endpoint to send the autosuggestion request to.\n * @param makeSystemMessage - A function that takes in a context string and returns a system message to include in the autosuggestion request.\n * @param fewShotMessages - An array of few shot messages to include in the autosuggestion request.\n * @param contextCategories - The categories of context strings we want to include. By default, we include the (default) \"global\" context category.\n * @returns A memoized function that sends a request to the specified API endpoint to get an autosuggestion for the user's input.\n */\nexport function useMakeStandardInsertionOrEditingFunction(\n textareaPurpose: string,\n contextCategories: string[],\n insertionApiConfig: InsertionsApiConfig,\n editingApiConfig: EditingApiConfig,\n): Generator_InsertionOrEditingSuggestion {\n const { getContextString, copilotApiConfig } = useCopilotContext();\n const headers = {\n ...(copilotApiConfig.publicApiKey\n ? { [COPILOT_CLOUD_PUBLIC_API_KEY_HEADER]: copilotApiConfig.publicApiKey }\n : {}),\n };\n\n const runtimeClient = new CopilotRuntimeClient({\n url: copilotApiConfig.chatApiEndpoint,\n publicApiKey: copilotApiConfig.publicApiKey,\n headers,\n credentials: copilotApiConfig.credentials,\n });\n\n async function runtimeClientResponseToStringStream(\n responsePromise: ReturnType<typeof runtimeClient.generateCopilotResponse>,\n ) {\n const messagesStream = await CopilotRuntimeClient.asStream(responsePromise);\n\n return new ReadableStream({\n async start(controller) {\n const reader = messagesStream.getReader();\n let sentContent = \"\";\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) {\n break;\n }\n\n const messages = convertGqlOutputToMessages(value.generateCopilotResponse.messages);\n\n let newContent = \"\";\n\n for (const message of messages) {\n if (message instanceof TextMessage) {\n newContent += message.content;\n }\n }\n if (newContent) {\n const contentToSend = newContent.slice(sentContent.length);\n controller.enqueue(contentToSend);\n sentContent += contentToSend;\n }\n }\n controller.close();\n },\n });\n }\n\n const insertionFunction = useCallback(\n async (\n editorState: EditingEditorState,\n insertionPrompt: string,\n documents: DocumentPointer[],\n abortSignal: AbortSignal,\n ) => {\n const res = await retry(async () => {\n const messages: Message[] = [\n new TextMessage({\n role: Role.System,\n content: insertionApiConfig.makeSystemPrompt(\n textareaPurpose,\n getContextString(documents, contextCategories),\n ),\n }),\n ...insertionApiConfig.fewShotMessages,\n new TextMessage({\n role: Role.User,\n content: `<TextAfterCursor>${editorState.textAfterCursor}</TextAfterCursor>`,\n }),\n new TextMessage({\n role: Role.User,\n content: `<TextBeforeCursor>${editorState.textBeforeCursor}</TextBeforeCursor>`,\n }),\n new TextMessage({\n role: Role.User,\n content: `<InsertionPrompt>${insertionPrompt}</InsertionPrompt>`,\n }),\n ];\n\n return runtimeClientResponseToStringStream(\n runtimeClient.generateCopilotResponse({\n data: {\n frontend: {\n actions: [],\n url: window.location.href,\n },\n messages: convertMessagesToGqlInput(filterAgentStateMessages(messages)),\n metadata: {\n requestType: CopilotRequestType.TextareaCompletion,\n },\n },\n properties: copilotApiConfig.properties,\n signal: abortSignal,\n }),\n );\n });\n\n return res;\n },\n [insertionApiConfig, getContextString, contextCategories, textareaPurpose],\n );\n\n const editingFunction = useCallback(\n async (\n editorState: EditingEditorState,\n editingPrompt: string,\n documents: DocumentPointer[],\n abortSignal: AbortSignal,\n ) => {\n const res = await retry(async () => {\n const messages: Message[] = [\n new TextMessage({\n role: Role.System,\n content: editingApiConfig.makeSystemPrompt(\n textareaPurpose,\n getContextString(documents, contextCategories),\n ),\n }),\n ...editingApiConfig.fewShotMessages,\n new TextMessage({\n role: Role.User,\n content: `<TextBeforeCursor>${editorState.textBeforeCursor}</TextBeforeCursor>`,\n }),\n new TextMessage({\n role: Role.User,\n content: `<TextToEdit>${editorState.selectedText}</TextToEdit>`,\n }),\n new TextMessage({\n role: Role.User,\n content: `<TextAfterCursor>${editorState.textAfterCursor}</TextAfterCursor>`,\n }),\n new TextMessage({\n role: Role.User,\n content: `<EditingPrompt>${editingPrompt}</EditingPrompt>`,\n }),\n ];\n\n const runtimeClient = new CopilotRuntimeClient({\n url: copilotApiConfig.chatApiEndpoint,\n publicApiKey: copilotApiConfig.publicApiKey,\n headers,\n credentials: copilotApiConfig.credentials,\n });\n\n return runtimeClientResponseToStringStream(\n runtimeClient.generateCopilotResponse({\n data: {\n frontend: {\n actions: [],\n url: window.location.href,\n },\n messages: convertMessagesToGqlInput(filterAgentStateMessages(messages)),\n metadata: {\n requestType: CopilotRequestType.TextareaCompletion,\n },\n },\n properties: copilotApiConfig.properties,\n signal: abortSignal,\n }),\n );\n });\n\n return res;\n },\n [editingApiConfig, getContextString, contextCategories, textareaPurpose],\n );\n\n const insertionOrEditingFunction = useCallback(\n async (\n editorState: EditingEditorState,\n insertionPrompt: string,\n documents: DocumentPointer[],\n abortSignal: AbortSignal,\n ) => {\n if (editorState.selectedText === \"\") {\n return await insertionFunction(editorState, insertionPrompt, documents, abortSignal);\n } else {\n return await editingFunction(editorState, insertionPrompt, documents, abortSignal);\n }\n },\n [insertionFunction, editingFunction],\n );\n\n return insertionOrEditingFunction;\n}\n"],"mappings":"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","names":["runtimeClient"]}
@@ -0,0 +1,17 @@
1
+ // src/hooks/misc/use-autosize-textarea.tsx
2
+ import { useEffect } from "react";
3
+ var useAutosizeTextArea = (textAreaRef, value) => {
4
+ useEffect(() => {
5
+ if (textAreaRef.current !== null) {
6
+ textAreaRef.current.style.height = "0px";
7
+ const scrollHeight = textAreaRef.current.scrollHeight;
8
+ textAreaRef.current.style.height = scrollHeight + "px";
9
+ }
10
+ }, [textAreaRef, value]);
11
+ };
12
+ var use_autosize_textarea_default = useAutosizeTextArea;
13
+
14
+ export {
15
+ use_autosize_textarea_default
16
+ };
17
+ //# sourceMappingURL=chunk-3PQ7GSFE.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/hooks/misc/use-autosize-textarea.tsx"],"sourcesContent":["import { Ref, RefObject, useEffect } from \"react\";\n\n// Updates the height of a <textarea> when the value changes.\nconst useAutosizeTextArea = (textAreaRef: RefObject<HTMLTextAreaElement>, value: string) => {\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"],"mappings":";AAAA,SAAyB,iBAAiB;AAG1C,IAAM,sBAAsB,CAAC,aAA6C,UAAkB;AAC1F,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;","names":[]}
@@ -0,0 +1,124 @@
1
+ import {
2
+ HoveringInsertionPromptBox
3
+ } from "./chunk-I3SPIGAI.mjs";
4
+ import {
5
+ useHoveringEditorContext
6
+ } from "./chunk-LYB4B6MK.mjs";
7
+ import {
8
+ Menu,
9
+ Portal
10
+ } from "./chunk-CF5GISTC.mjs";
11
+ import {
12
+ getFullEditorTextWithNewlines,
13
+ getTextAroundSelection
14
+ } from "./chunk-ECR45NSD.mjs";
15
+
16
+ // src/components/hovering-toolbar/hovering-toolbar.tsx
17
+ import { useEffect, useRef, useState } from "react";
18
+ import { Transforms } from "slate";
19
+ import { useSlate, useSlateSelection } from "slate-react";
20
+ import { jsx } from "react/jsx-runtime";
21
+ var HoveringToolbar = (props) => {
22
+ const ref = useRef(null);
23
+ const editor = useSlate();
24
+ const selection = useSlateSelection();
25
+ const { isDisplayed, setIsDisplayed } = useHoveringEditorContext();
26
+ const [isClient, setIsClient] = useState(false);
27
+ useEffect(() => {
28
+ setIsClient(true);
29
+ }, []);
30
+ useEffect(() => {
31
+ const el = ref.current;
32
+ const { selection: selection2 } = editor;
33
+ if (!el) {
34
+ return;
35
+ }
36
+ if (!selection2) {
37
+ el.removeAttribute("style");
38
+ return;
39
+ }
40
+ const domSelection = window.getSelection();
41
+ if (!domSelection || domSelection.rangeCount === 0) {
42
+ return;
43
+ }
44
+ const domRange = domSelection.getRangeAt(0);
45
+ const rect = domRange.getBoundingClientRect();
46
+ if (rect.top === 0 && rect.left === 0 && rect.width === 0 && rect.height === 0) {
47
+ return;
48
+ }
49
+ const minGapFromEdge = 60;
50
+ const verticalOffsetFromCorner = 35;
51
+ const horizontalOffsetFromCorner = 15;
52
+ let top = rect.top + window.scrollY - el.offsetHeight + verticalOffsetFromCorner;
53
+ if (top < minGapFromEdge) {
54
+ top = rect.bottom + window.scrollY + minGapFromEdge;
55
+ } else if (top + el.offsetHeight > window.innerHeight - minGapFromEdge) {
56
+ top = rect.top + window.scrollY - el.offsetHeight - minGapFromEdge;
57
+ }
58
+ let left = rect.left + window.scrollX - el.offsetWidth / 2 + rect.width / 2 + horizontalOffsetFromCorner;
59
+ if (left < minGapFromEdge) {
60
+ left = minGapFromEdge;
61
+ } else if (left + el.offsetWidth > window.innerWidth - minGapFromEdge) {
62
+ left = window.innerWidth - el.offsetWidth - minGapFromEdge;
63
+ }
64
+ el.style.opacity = "1";
65
+ el.style.position = "absolute";
66
+ el.style.top = `${top}px`;
67
+ el.style.left = `${left}px`;
68
+ });
69
+ useEffect(() => {
70
+ const handleClickOutside = (event) => {
71
+ if (ref.current && !ref.current.contains(event.target)) {
72
+ setIsDisplayed(false);
73
+ }
74
+ };
75
+ document.addEventListener("mousedown", handleClickOutside);
76
+ return () => {
77
+ document.removeEventListener("mousedown", handleClickOutside);
78
+ };
79
+ }, [ref, setIsDisplayed]);
80
+ if (!isClient) {
81
+ return null;
82
+ }
83
+ return /* @__PURE__ */ jsx(Portal, { children: /* @__PURE__ */ jsx(
84
+ Menu,
85
+ {
86
+ ref,
87
+ className: "copilot-kit-textarea-css-scope " + (props.hoverMenuClassname || "p-2 absolute z-10 top-[-10000px] left-[-10000px] mt-[-6px] opacity-0 transition-opacity duration-700"),
88
+ children: isDisplayed && selection && /* @__PURE__ */ jsx(
89
+ HoveringInsertionPromptBox,
90
+ {
91
+ editorState: editorState(editor, selection),
92
+ apiConfig: props.apiConfig,
93
+ closeWindow: () => {
94
+ setIsDisplayed(false);
95
+ },
96
+ performInsertion: (insertedText) => {
97
+ Transforms.delete(editor, { at: selection });
98
+ Transforms.insertText(editor, insertedText, {
99
+ at: selection
100
+ });
101
+ setIsDisplayed(false);
102
+ },
103
+ contextCategories: props.contextCategories
104
+ }
105
+ )
106
+ }
107
+ ) });
108
+ };
109
+ function editorState(editor, selection) {
110
+ const textAroundCursor = getTextAroundSelection(editor);
111
+ if (textAroundCursor) {
112
+ return textAroundCursor;
113
+ }
114
+ return {
115
+ textBeforeCursor: getFullEditorTextWithNewlines(editor),
116
+ textAfterCursor: "",
117
+ selectedText: ""
118
+ };
119
+ }
120
+
121
+ export {
122
+ HoveringToolbar
123
+ };
124
+ //# sourceMappingURL=chunk-4AMCUMC7.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/hovering-toolbar/hovering-toolbar.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from \"react\";\nimport { Editor, Location, Transforms } from \"slate\";\nimport { useSlate, useSlateSelection } from \"slate-react\";\nimport { HoveringInsertionPromptBox } from \"./text-insertion-prompt-box\";\nimport { Menu, Portal } from \"./hovering-toolbar-components\";\nimport { useHoveringEditorContext } from \"./hovering-editor-provider\";\nimport {\n getFullEditorTextWithNewlines,\n getTextAroundSelection,\n} from \"../../lib/get-text-around-cursor\";\nimport {\n EditingEditorState,\n InsertionEditorApiConfig,\n} from \"../../types/base/autosuggestions-bare-function\";\n\nexport interface HoveringToolbarProps {\n apiConfig: InsertionEditorApiConfig;\n contextCategories: string[];\n hoverMenuClassname: string | undefined;\n}\n\nexport const HoveringToolbar = (props: HoveringToolbarProps) => {\n const ref = useRef<HTMLDivElement>(null);\n const editor = useSlate();\n const selection = useSlateSelection();\n const { isDisplayed, setIsDisplayed } = useHoveringEditorContext();\n\n // only render on client\n const [isClient, setIsClient] = useState(false);\n useEffect(() => {\n setIsClient(true);\n }, []);\n\n useEffect(() => {\n const el = ref.current;\n const { selection } = editor;\n\n if (!el) {\n return;\n }\n\n if (!selection) {\n el.removeAttribute(\"style\");\n return;\n }\n\n const domSelection = window.getSelection();\n if (!domSelection || domSelection.rangeCount === 0) {\n return;\n }\n\n const domRange = domSelection.getRangeAt(0);\n const rect = domRange.getBoundingClientRect();\n\n // We use window = (0,0,0,0) as a signal that the selection is not in the original copilot-textarea,\n // but inside the hovering window.\n //\n // in such case, we simply do nothing.\n if (rect.top === 0 && rect.left === 0 && rect.width === 0 && rect.height === 0) {\n return;\n }\n const minGapFromEdge = 60;\n const verticalOffsetFromCorner = 35;\n const horizontalOffsetFromCorner = 15;\n let top = rect.top + window.scrollY - el.offsetHeight + verticalOffsetFromCorner;\n // make sure top is in the viewport and not too close to the edge\n if (top < minGapFromEdge) {\n top = rect.bottom + window.scrollY + minGapFromEdge;\n } else if (top + el.offsetHeight > window.innerHeight - minGapFromEdge) {\n top = rect.top + window.scrollY - el.offsetHeight - minGapFromEdge;\n }\n\n let left =\n rect.left + window.scrollX - el.offsetWidth / 2 + rect.width / 2 + horizontalOffsetFromCorner;\n // make sure left is in the viewport and not too close to the edge\n if (left < minGapFromEdge) {\n left = minGapFromEdge;\n } else if (left + el.offsetWidth > window.innerWidth - minGapFromEdge) {\n left = window.innerWidth - el.offsetWidth - minGapFromEdge;\n }\n\n el.style.opacity = \"1\";\n el.style.position = \"absolute\";\n\n el.style.top = `${top}px`;\n el.style.left = `${left}px`;\n });\n\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n setIsDisplayed(false);\n }\n };\n\n document.addEventListener(\"mousedown\", handleClickOutside);\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n };\n }, [ref, setIsDisplayed]);\n\n if (!isClient) {\n return null;\n }\n\n return (\n <Portal>\n <Menu\n ref={ref}\n className={\n \"copilot-kit-textarea-css-scope \" +\n (props.hoverMenuClassname ||\n \"p-2 absolute z-10 top-[-10000px] left-[-10000px] mt-[-6px] opacity-0 transition-opacity duration-700\")\n }\n >\n {isDisplayed && selection && (\n <HoveringInsertionPromptBox\n editorState={editorState(editor, selection)}\n apiConfig={props.apiConfig}\n closeWindow={() => {\n setIsDisplayed(false);\n }}\n performInsertion={(insertedText) => {\n // replace the selection with the inserted text\n Transforms.delete(editor, { at: selection });\n Transforms.insertText(editor, insertedText, {\n at: selection,\n });\n setIsDisplayed(false);\n }}\n contextCategories={props.contextCategories}\n />\n )}\n </Menu>\n </Portal>\n );\n};\n\nfunction editorState(editor: Editor, selection: Location): EditingEditorState {\n const textAroundCursor = getTextAroundSelection(editor);\n if (textAroundCursor) {\n return textAroundCursor;\n }\n\n return {\n textBeforeCursor: getFullEditorTextWithNewlines(editor),\n textAfterCursor: \"\",\n selectedText: \"\",\n };\n}\n"],"mappings":"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","names":["selection"]}
@@ -0,0 +1,30 @@
1
+ // src/types/base/base-autosuggestions-config.tsx
2
+ import { defaultCopilotContextCategories } from "@copilotkit/react-core";
3
+ var defaultShouldToggleHoveringEditorOnKeyPress = (event, shortcut) => {
4
+ if (event.key === shortcut && event.metaKey) {
5
+ return true;
6
+ }
7
+ return false;
8
+ };
9
+ var defaultShouldAcceptAutosuggestionOnKeyPress = (event) => {
10
+ if (event.key === "Tab") {
11
+ return true;
12
+ }
13
+ return false;
14
+ };
15
+ var defaultShouldAcceptAutosuggestionOnTouch = () => false;
16
+ var defaultBaseAutosuggestionsConfig = {
17
+ debounceTime: 250,
18
+ contextCategories: defaultCopilotContextCategories,
19
+ disableWhenEmpty: true,
20
+ disabled: false,
21
+ temporarilyDisableWhenMovingCursorWithoutChangingText: true,
22
+ shouldToggleHoveringEditorOnKeyPress: defaultShouldToggleHoveringEditorOnKeyPress,
23
+ shouldAcceptAutosuggestionOnKeyPress: defaultShouldAcceptAutosuggestionOnKeyPress,
24
+ shouldAcceptAutosuggestionOnTouch: defaultShouldAcceptAutosuggestionOnTouch
25
+ };
26
+
27
+ export {
28
+ defaultBaseAutosuggestionsConfig
29
+ };
30
+ //# sourceMappingURL=chunk-4CVSOOJY.mjs.map