@copilotkit/react-textarea 0.27.0-alpha.2 → 0.27.0-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (237) hide show
  1. package/.turbo/turbo-build.log +153 -154
  2. package/CHANGELOG.md +35 -6
  3. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +1745 -35
  4. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs.map +1 -1
  5. package/dist/components/base-copilot-textarea/render-element.mjs +51 -3
  6. package/dist/components/base-copilot-textarea/render-element.mjs.map +1 -1
  7. package/dist/components/base-copilot-textarea/render-placeholder.mjs +49 -3
  8. package/dist/components/base-copilot-textarea/render-placeholder.mjs.map +1 -1
  9. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs +86 -4
  10. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs.map +1 -1
  11. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs +57 -3
  12. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs.map +1 -1
  13. package/dist/components/copilot-textarea/copilot-textarea.mjs +2192 -47
  14. package/dist/components/copilot-textarea/copilot-textarea.mjs.map +1 -1
  15. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs +17 -3
  16. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs.map +1 -1
  17. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs +137 -3
  18. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs.map +1 -1
  19. package/dist/components/hovering-toolbar/hovering-toolbar.mjs +875 -18
  20. package/dist/components/hovering-toolbar/hovering-toolbar.mjs.map +1 -1
  21. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs +558 -12
  22. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs.map +1 -1
  23. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs +581 -13
  24. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs.map +1 -1
  25. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs +102 -5
  26. package/dist/components/hovering-toolbar/text-insertion-prompt-box/included-files-preview.mjs.map +1 -1
  27. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs +581 -14
  28. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs.map +1 -1
  29. package/dist/components/index.mjs +2193 -48
  30. package/dist/components/index.mjs.map +1 -1
  31. package/dist/components/manual-ui/chip-with-icon.mjs +5 -6
  32. package/dist/components/manual-ui/chip-with-icon.mjs.map +1 -1
  33. package/dist/components/source-search-box/source-search-box.mjs +211 -6
  34. package/dist/components/source-search-box/source-search-box.mjs.map +1 -1
  35. package/dist/components/ui/button.mjs +85 -4
  36. package/dist/components/ui/button.mjs.map +1 -1
  37. package/dist/components/ui/card.mjs +53 -7
  38. package/dist/components/ui/card.mjs.map +1 -1
  39. package/dist/components/ui/command.mjs +244 -5
  40. package/dist/components/ui/command.mjs.map +1 -1
  41. package/dist/components/ui/dialog.mjs +144 -4
  42. package/dist/components/ui/dialog.mjs.map +1 -1
  43. package/dist/components/ui/label.mjs +60 -4
  44. package/dist/components/ui/label.mjs.map +1 -1
  45. package/dist/components/ui/separator.mjs +50 -8
  46. package/dist/components/ui/separator.mjs.map +1 -1
  47. package/dist/components/ui/textarea.mjs +48 -7
  48. package/dist/components/ui/textarea.mjs.map +1 -1
  49. package/dist/context/index.mjs +0 -2
  50. package/dist/context/index.mjs.map +1 -1
  51. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs +158 -6
  52. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs.map +1 -1
  53. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs +168 -4
  54. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs.map +1 -1
  55. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs +148 -5
  56. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs.map +1 -1
  57. package/dist/hooks/index.mjs +0 -2
  58. package/dist/hooks/index.mjs.map +1 -1
  59. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +114 -14
  60. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map +1 -1
  61. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs +166 -14
  62. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs.map +1 -1
  63. package/dist/hooks/misc/use-autosize-textarea.mjs +15 -3
  64. package/dist/hooks/misc/use-autosize-textarea.mjs.map +1 -1
  65. package/dist/index.css +0 -3
  66. package/dist/index.css.map +1 -1
  67. package/dist/index.d.ts +0 -1
  68. package/dist/index.mjs +2195 -50
  69. package/dist/index.mjs.map +1 -1
  70. package/dist/lib/debouncer.mjs +51 -3
  71. package/dist/lib/debouncer.mjs.map +1 -1
  72. package/dist/lib/editor-to-text.mjs +43 -3
  73. package/dist/lib/editor-to-text.mjs.map +1 -1
  74. package/dist/lib/get-text-around-cursor.mjs +102 -3
  75. package/dist/lib/get-text-around-cursor.mjs.map +1 -1
  76. package/dist/lib/retry.mjs +17 -3
  77. package/dist/lib/retry.mjs.map +1 -1
  78. package/dist/lib/slatejs-edits/add-autocompletions.mjs +25 -3
  79. package/dist/lib/slatejs-edits/add-autocompletions.mjs.map +1 -1
  80. package/dist/lib/slatejs-edits/clear-autocompletions.mjs +20 -3
  81. package/dist/lib/slatejs-edits/clear-autocompletions.mjs.map +1 -1
  82. package/dist/lib/slatejs-edits/replace-text.mjs +27 -3
  83. package/dist/lib/slatejs-edits/replace-text.mjs.map +1 -1
  84. package/dist/lib/slatejs-edits/with-partial-history.mjs +106 -3
  85. package/dist/lib/slatejs-edits/with-partial-history.mjs.map +1 -1
  86. package/dist/lib/stream-promise-flatten.mjs +47 -3
  87. package/dist/lib/stream-promise-flatten.mjs.map +1 -1
  88. package/dist/lib/utils.mjs +71 -3
  89. package/dist/lib/utils.mjs.map +1 -1
  90. package/dist/lib/utils.test.mjs +0 -1
  91. package/dist/lib/utils.test.mjs.map +1 -1
  92. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs +0 -2
  93. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs.map +1 -1
  94. package/dist/types/autosuggestions-config/autosuggestions-config.mjs +274 -8
  95. package/dist/types/autosuggestions-config/autosuggestions-config.mjs.map +1 -1
  96. package/dist/types/autosuggestions-config/editing-api-config.mjs +87 -3
  97. package/dist/types/autosuggestions-config/editing-api-config.mjs.map +1 -1
  98. package/dist/types/autosuggestions-config/index.d.ts +0 -1
  99. package/dist/types/autosuggestions-config/index.mjs +274 -10
  100. package/dist/types/autosuggestions-config/index.mjs.map +1 -1
  101. package/dist/types/autosuggestions-config/insertions-api-config.mjs +78 -3
  102. package/dist/types/autosuggestions-config/insertions-api-config.mjs.map +1 -1
  103. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs +0 -2
  104. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs.map +1 -1
  105. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs +0 -2
  106. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs.map +1 -1
  107. package/dist/types/autosuggestions-config/suggestions-api-config.mjs +64 -3
  108. package/dist/types/autosuggestions-config/suggestions-api-config.mjs.map +1 -1
  109. package/dist/types/base/autosuggestion-state.mjs +0 -2
  110. package/dist/types/base/autosuggestion-state.mjs.map +1 -1
  111. package/dist/types/base/autosuggestions-bare-function.mjs +0 -2
  112. package/dist/types/base/autosuggestions-bare-function.mjs.map +1 -1
  113. package/dist/types/base/base-autosuggestions-config.mjs +26 -3
  114. package/dist/types/base/base-autosuggestions-config.mjs.map +1 -1
  115. package/dist/types/base/base-copilot-textarea-props.mjs +0 -2
  116. package/dist/types/base/base-copilot-textarea-props.mjs.map +1 -1
  117. package/dist/types/base/custom-editor.mjs +0 -2
  118. package/dist/types/base/custom-editor.mjs.map +1 -1
  119. package/dist/types/base/editor-autocomplete-state.mjs +17 -4
  120. package/dist/types/base/editor-autocomplete-state.mjs.map +1 -1
  121. package/dist/types/base/index.mjs +26 -4
  122. package/dist/types/base/index.mjs.map +1 -1
  123. package/dist/types/html-copilot-textarea-element.mjs +0 -2
  124. package/dist/types/html-copilot-textarea-element.mjs.map +1 -1
  125. package/dist/types/index.d.ts +0 -1
  126. package/dist/types/index.mjs +275 -12
  127. package/dist/types/index.mjs.map +1 -1
  128. package/package.json +3 -4
  129. package/src/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.tsx +15 -9
  130. package/src/hooks/make-autosuggestions-function/use-make-standard-insertion-function.tsx +22 -6
  131. package/src/types/autosuggestions-config/autosuggestions-config-user-specified.tsx +1 -1
  132. package/src/types/autosuggestions-config/autosuggestions-config.tsx +0 -1
  133. package/src/types/autosuggestions-config/editing-api-config.tsx +22 -17
  134. package/src/types/autosuggestions-config/index.ts +0 -2
  135. package/src/types/autosuggestions-config/insertions-api-config.tsx +11 -6
  136. package/dist/chunk-224UKA7C.mjs +0 -33
  137. package/dist/chunk-224UKA7C.mjs.map +0 -1
  138. package/dist/chunk-22SLIB4K.mjs +0 -46
  139. package/dist/chunk-22SLIB4K.mjs.map +0 -1
  140. package/dist/chunk-2C7O2EVM.mjs +0 -27
  141. package/dist/chunk-2C7O2EVM.mjs.map +0 -1
  142. package/dist/chunk-2QDCE7PD.mjs +0 -29
  143. package/dist/chunk-2QDCE7PD.mjs.map +0 -1
  144. package/dist/chunk-3PQ7GSFE.mjs +0 -17
  145. package/dist/chunk-3PQ7GSFE.mjs.map +0 -1
  146. package/dist/chunk-47L4PLG4.mjs +0 -45
  147. package/dist/chunk-47L4PLG4.mjs.map +0 -1
  148. package/dist/chunk-4NHVQZ67.mjs +0 -107
  149. package/dist/chunk-4NHVQZ67.mjs.map +0 -1
  150. package/dist/chunk-5FO6ISW4.mjs +0 -3
  151. package/dist/chunk-5FO6ISW4.mjs.map +0 -1
  152. package/dist/chunk-5UNJXFUO.mjs +0 -29
  153. package/dist/chunk-5UNJXFUO.mjs.map +0 -1
  154. package/dist/chunk-5ZCVCVRZ.mjs +0 -19
  155. package/dist/chunk-5ZCVCVRZ.mjs.map +0 -1
  156. package/dist/chunk-6TZ6V3QI.mjs +0 -217
  157. package/dist/chunk-6TZ6V3QI.mjs.map +0 -1
  158. package/dist/chunk-72P3KOHZ.mjs +0 -91
  159. package/dist/chunk-72P3KOHZ.mjs.map +0 -1
  160. package/dist/chunk-7LSRNPNI.mjs +0 -59
  161. package/dist/chunk-7LSRNPNI.mjs.map +0 -1
  162. package/dist/chunk-7SUZ6CXM.mjs +0 -47
  163. package/dist/chunk-7SUZ6CXM.mjs.map +0 -1
  164. package/dist/chunk-COUN55HQ.mjs +0 -53
  165. package/dist/chunk-COUN55HQ.mjs.map +0 -1
  166. package/dist/chunk-DE5K76I2.mjs +0 -3
  167. package/dist/chunk-DE5K76I2.mjs.map +0 -1
  168. package/dist/chunk-DRV2FOHZ.mjs +0 -65
  169. package/dist/chunk-DRV2FOHZ.mjs.map +0 -1
  170. package/dist/chunk-ECR45NSD.mjs +0 -101
  171. package/dist/chunk-ECR45NSD.mjs.map +0 -1
  172. package/dist/chunk-EPBVNDKE.mjs +0 -46
  173. package/dist/chunk-EPBVNDKE.mjs.map +0 -1
  174. package/dist/chunk-FJNUPSQK.mjs +0 -72
  175. package/dist/chunk-FJNUPSQK.mjs.map +0 -1
  176. package/dist/chunk-FP2EKU3L.mjs +0 -28
  177. package/dist/chunk-FP2EKU3L.mjs.map +0 -1
  178. package/dist/chunk-GQN2HYFJ.mjs +0 -22
  179. package/dist/chunk-GQN2HYFJ.mjs.map +0 -1
  180. package/dist/chunk-H4VKQGVU.mjs +0 -3
  181. package/dist/chunk-H4VKQGVU.mjs.map +0 -1
  182. package/dist/chunk-HSCZA5TS.mjs +0 -27
  183. package/dist/chunk-HSCZA5TS.mjs.map +0 -1
  184. package/dist/chunk-IU3WTXLQ.mjs +0 -3
  185. package/dist/chunk-IU3WTXLQ.mjs.map +0 -1
  186. package/dist/chunk-JJLQVT7S.mjs +0 -10
  187. package/dist/chunk-JJLQVT7S.mjs.map +0 -1
  188. package/dist/chunk-K5LNB36H.mjs +0 -80
  189. package/dist/chunk-K5LNB36H.mjs.map +0 -1
  190. package/dist/chunk-KDVMG3XF.mjs +0 -63
  191. package/dist/chunk-KDVMG3XF.mjs.map +0 -1
  192. package/dist/chunk-KFQZHRPJ.mjs +0 -19
  193. package/dist/chunk-KFQZHRPJ.mjs.map +0 -1
  194. package/dist/chunk-KNQIEOFP.mjs +0 -18
  195. package/dist/chunk-KNQIEOFP.mjs.map +0 -1
  196. package/dist/chunk-KTTN5H7S.mjs +0 -202
  197. package/dist/chunk-KTTN5H7S.mjs.map +0 -1
  198. package/dist/chunk-L7VVZH4Q.mjs +0 -3
  199. package/dist/chunk-L7VVZH4Q.mjs.map +0 -1
  200. package/dist/chunk-LQZBI6XD.mjs +0 -112
  201. package/dist/chunk-LQZBI6XD.mjs.map +0 -1
  202. package/dist/chunk-M2DR4KVB.mjs +0 -33
  203. package/dist/chunk-M2DR4KVB.mjs.map +0 -1
  204. package/dist/chunk-MMVDU6DF.mjs +0 -3
  205. package/dist/chunk-MMVDU6DF.mjs.map +0 -1
  206. package/dist/chunk-MRXNTQOX.mjs +0 -55
  207. package/dist/chunk-MRXNTQOX.mjs.map +0 -1
  208. package/dist/chunk-OHO4G6DR.mjs +0 -19
  209. package/dist/chunk-OHO4G6DR.mjs.map +0 -1
  210. package/dist/chunk-P4QVFRLY.mjs +0 -103
  211. package/dist/chunk-P4QVFRLY.mjs.map +0 -1
  212. package/dist/chunk-PTZVE6NC.mjs +0 -94
  213. package/dist/chunk-PTZVE6NC.mjs.map +0 -1
  214. package/dist/chunk-QDFAIRQF.mjs +0 -45
  215. package/dist/chunk-QDFAIRQF.mjs.map +0 -1
  216. package/dist/chunk-RBR32FWA.mjs +0 -74
  217. package/dist/chunk-RBR32FWA.mjs.map +0 -1
  218. package/dist/chunk-SBV2KVF5.mjs +0 -99
  219. package/dist/chunk-SBV2KVF5.mjs.map +0 -1
  220. package/dist/chunk-T6MTDQZ7.mjs +0 -45
  221. package/dist/chunk-T6MTDQZ7.mjs.map +0 -1
  222. package/dist/chunk-VPEH6V7T.mjs +0 -83
  223. package/dist/chunk-VPEH6V7T.mjs.map +0 -1
  224. package/dist/chunk-WADHCMPK.mjs +0 -3
  225. package/dist/chunk-WADHCMPK.mjs.map +0 -1
  226. package/dist/chunk-WFTAAA7R.mjs +0 -44
  227. package/dist/chunk-WFTAAA7R.mjs.map +0 -1
  228. package/dist/chunk-WJHSY5T6.mjs +0 -3
  229. package/dist/chunk-WJHSY5T6.mjs.map +0 -1
  230. package/dist/chunk-WTASPE2W.mjs +0 -105
  231. package/dist/chunk-WTASPE2W.mjs.map +0 -1
  232. package/dist/chunk-XV7MLLXQ.mjs +0 -18
  233. package/dist/chunk-XV7MLLXQ.mjs.map +0 -1
  234. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.d.ts +0 -27
  235. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs +0 -4
  236. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs.map +0 -1
  237. package/src/types/autosuggestions-config/subtypes/chatlike-api-endpoint.tsx +0 -69
@@ -1,4 +1,18 @@
1
- export { retry } from '../chunk-KNQIEOFP.mjs';
2
- import '../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
1
+ // src/lib/retry.tsx
2
+ function retry(fn, retriesLeft = 2, interval = 200, backoff = 1.5) {
3
+ return new Promise((resolve, reject) => {
4
+ fn().then(resolve).catch((error) => {
5
+ if (retriesLeft === 1) {
6
+ reject(error);
7
+ return;
8
+ }
9
+ setTimeout(() => {
10
+ retry(fn, retriesLeft - 1, interval * backoff, backoff).then(resolve).catch(reject);
11
+ }, interval);
12
+ });
13
+ });
14
+ }
15
+ export {
16
+ retry
17
+ };
4
18
  //# sourceMappingURL=retry.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":["../../src/lib/retry.tsx"],"sourcesContent":["export function retry<T>(\n fn: () => Promise<T>,\n retriesLeft: number = 2,\n interval: number = 200,\n backoff: number = 1.5,\n): Promise<T> {\n return new Promise((resolve, reject) => {\n fn()\n .then(resolve)\n .catch((error) => {\n if (retriesLeft === 1) {\n reject(error);\n return;\n }\n\n setTimeout(() => {\n retry(fn, retriesLeft - 1, interval * backoff, backoff)\n .then(resolve)\n .catch(reject);\n }, interval);\n });\n });\n}\n"],"mappings":";AAAO,SAAS,MACd,IACA,cAAsB,GACtB,WAAmB,KACnB,UAAkB,KACN;AACZ,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,OAAG,EACA,KAAK,OAAO,EACZ,MAAM,CAAC,UAAU;AAChB,UAAI,gBAAgB,GAAG;AACrB,eAAO,KAAK;AACZ;AAAA,MACF;AAEA,iBAAW,MAAM;AACf,cAAM,IAAI,cAAc,GAAG,WAAW,SAAS,OAAO,EACnD,KAAK,OAAO,EACZ,MAAM,MAAM;AAAA,MACjB,GAAG,QAAQ;AAAA,IACb,CAAC;AAAA,EACL,CAAC;AACH;","names":[]}
@@ -1,4 +1,26 @@
1
- export { addAutocompletionsToEditor } from '../../chunk-2C7O2EVM.mjs';
2
- import '../../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
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
+ export {
24
+ addAutocompletionsToEditor
25
+ };
4
26
  //# sourceMappingURL=add-autocompletions.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
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":[]}
@@ -1,4 +1,21 @@
1
- export { clearAutocompletionsFromEditor } from '../../chunk-GQN2HYFJ.mjs';
2
- import '../../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
1
+ // src/lib/slatejs-edits/clear-autocompletions.ts
2
+ import { Element, Node, Transforms } from "slate";
3
+ function clearAutocompletionsFromEditor(editor) {
4
+ const paths = [];
5
+ for (const [node, path] of Node.nodes(editor)) {
6
+ if (Element.isElement(node) && node.type === "suggestion") {
7
+ paths.push(path);
8
+ }
9
+ }
10
+ for (const path of paths) {
11
+ try {
12
+ Transforms.removeNodes(editor, { at: path });
13
+ } catch (e) {
14
+ console.log("CopilotTextarea.clearAutocompletionsFromEditor: error removing node", e);
15
+ }
16
+ }
17
+ }
18
+ export {
19
+ clearAutocompletionsFromEditor
20
+ };
4
21
  //# sourceMappingURL=clear-autocompletions.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":["../../../src/lib/slatejs-edits/clear-autocompletions.ts"],"sourcesContent":["import { Element, Node, Path, Transforms } from \"slate\";\nimport { CustomEditor } from \"../../types/base/custom-editor\";\n\nexport function clearAutocompletionsFromEditor(editor: CustomEditor) {\n // clear previous suggestion\n const paths: Path[] = [];\n for (const [node, path] of Node.nodes(editor)) {\n if (Element.isElement(node) && node.type === \"suggestion\") {\n paths.push(path);\n }\n }\n for (const path of paths) {\n try {\n Transforms.removeNodes(editor, { at: path });\n } catch (e) {\n console.log(\"CopilotTextarea.clearAutocompletionsFromEditor: error removing node\", e);\n }\n }\n}\n"],"mappings":";AAAA,SAAS,SAAS,MAAY,kBAAkB;AAGzC,SAAS,+BAA+B,QAAsB;AAEnE,QAAM,QAAgB,CAAC;AACvB,aAAW,CAAC,MAAM,IAAI,KAAK,KAAK,MAAM,MAAM,GAAG;AAC7C,QAAI,QAAQ,UAAU,IAAI,KAAK,KAAK,SAAS,cAAc;AACzD,YAAM,KAAK,IAAI;AAAA,IACjB;AAAA,EACF;AACA,aAAW,QAAQ,OAAO;AACxB,QAAI;AACF,iBAAW,YAAY,QAAQ,EAAE,IAAI,KAAK,CAAC;AAAA,IAC7C,SAAS,GAAP;AACA,cAAQ,IAAI,uEAAuE,CAAC;AAAA,IACtF;AAAA,EACF;AACF;","names":[]}
@@ -1,4 +1,28 @@
1
- export { replaceEditorText } from '../../chunk-5UNJXFUO.mjs';
2
- import '../../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
1
+ // src/lib/slatejs-edits/replace-text.ts
2
+ import { Editor, Transforms } from "slate";
3
+ function replaceEditorText(editor, newText) {
4
+ Transforms.delete(editor, {
5
+ at: {
6
+ anchor: Editor.start(editor, []),
7
+ focus: Editor.end(editor, [])
8
+ }
9
+ });
10
+ if (newText && newText !== "") {
11
+ Transforms.insertNodes(
12
+ editor,
13
+ [
14
+ {
15
+ type: "paragraph",
16
+ children: [{ text: newText }]
17
+ }
18
+ ],
19
+ {
20
+ at: [0]
21
+ }
22
+ );
23
+ }
24
+ }
25
+ export {
26
+ replaceEditorText
27
+ };
4
28
  //# sourceMappingURL=replace-text.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":["../../../src/lib/slatejs-edits/replace-text.ts"],"sourcesContent":["import { Editor, Transforms } from \"slate\";\n\nexport function replaceEditorText(editor: Editor, newText: string) {\n // clear all previous text\n Transforms.delete(editor, {\n at: {\n anchor: Editor.start(editor, []),\n focus: Editor.end(editor, []),\n },\n });\n\n // insert new text\n if (newText && newText !== \"\") {\n // don't insert empty text - results in strange visual behavior\n Transforms.insertNodes(\n editor,\n [\n {\n type: \"paragraph\",\n children: [{ text: newText }],\n },\n ],\n {\n at: [0],\n },\n );\n }\n}\n"],"mappings":";AAAA,SAAS,QAAQ,kBAAkB;AAE5B,SAAS,kBAAkB,QAAgB,SAAiB;AAEjE,aAAW,OAAO,QAAQ;AAAA,IACxB,IAAI;AAAA,MACF,QAAQ,OAAO,MAAM,QAAQ,CAAC,CAAC;AAAA,MAC/B,OAAO,OAAO,IAAI,QAAQ,CAAC,CAAC;AAAA,IAC9B;AAAA,EACF,CAAC;AAGD,MAAI,WAAW,YAAY,IAAI;AAE7B,eAAW;AAAA,MACT;AAAA,MACA;AAAA,QACE;AAAA,UACE,MAAM;AAAA,UACN,UAAU,CAAC,EAAE,MAAM,QAAQ,CAAC;AAAA,QAC9B;AAAA,MACF;AAAA,MACA;AAAA,QACE,IAAI,CAAC,CAAC;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
@@ -1,4 +1,107 @@
1
- export { defaultShouldSave, withPartialHistory } from '../../chunk-4NHVQZ67.mjs';
2
- import '../../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
1
+ // src/lib/slatejs-edits/with-partial-history.ts
2
+ import { Editor, Operation, Path, Transforms } from "slate";
3
+ import { HistoryEditor } from "slate-history";
4
+ var withPartialHistory = (editor, shouldSave) => {
5
+ const e = editor;
6
+ const { apply } = e;
7
+ e.history = { undos: [], redos: [] };
8
+ e.redo = () => {
9
+ const { history } = e;
10
+ const { redos } = history;
11
+ if (redos.length > 0) {
12
+ const batch = redos[redos.length - 1];
13
+ if (batch.selectionBefore) {
14
+ Transforms.setSelection(e, batch.selectionBefore);
15
+ }
16
+ HistoryEditor.withoutSaving(e, () => {
17
+ Editor.withoutNormalizing(e, () => {
18
+ for (const op of batch.operations) {
19
+ e.apply(op);
20
+ }
21
+ });
22
+ });
23
+ history.redos.pop();
24
+ e.writeHistory("undos", batch);
25
+ }
26
+ };
27
+ e.undo = () => {
28
+ const { history } = e;
29
+ const { undos } = history;
30
+ if (undos.length > 0) {
31
+ const batch = undos[undos.length - 1];
32
+ HistoryEditor.withoutSaving(e, () => {
33
+ Editor.withoutNormalizing(e, () => {
34
+ const inverseOps = batch.operations.map(Operation.inverse).reverse();
35
+ for (const op of inverseOps) {
36
+ e.apply(op);
37
+ }
38
+ if (batch.selectionBefore) {
39
+ Transforms.setSelection(e, batch.selectionBefore);
40
+ }
41
+ });
42
+ });
43
+ e.writeHistory("redos", batch);
44
+ history.undos.pop();
45
+ }
46
+ };
47
+ e.apply = (op) => {
48
+ const { operations, history } = e;
49
+ const { undos } = history;
50
+ const lastBatch = undos[undos.length - 1];
51
+ const lastOp = lastBatch && lastBatch.operations[lastBatch.operations.length - 1];
52
+ let save = HistoryEditor.isSaving(e);
53
+ let merge = HistoryEditor.isMerging(e);
54
+ if (save == null) {
55
+ save = shouldSave(op, lastOp);
56
+ }
57
+ if (save) {
58
+ if (merge == null) {
59
+ if (lastBatch == null) {
60
+ merge = false;
61
+ } else if (operations.length !== 0) {
62
+ merge = true;
63
+ } else {
64
+ merge = shouldMerge(op, lastOp);
65
+ }
66
+ }
67
+ if (lastBatch && merge) {
68
+ lastBatch.operations.push(op);
69
+ } else {
70
+ const batch = {
71
+ operations: [op],
72
+ selectionBefore: e.selection
73
+ };
74
+ e.writeHistory("undos", batch);
75
+ }
76
+ while (undos.length > 100) {
77
+ undos.shift();
78
+ }
79
+ history.redos = [];
80
+ }
81
+ apply(op);
82
+ };
83
+ e.writeHistory = (stack, batch) => {
84
+ e.history[stack].push(batch);
85
+ };
86
+ return e;
87
+ };
88
+ var shouldMerge = (op, prev) => {
89
+ if (prev && op.type === "insert_text" && prev.type === "insert_text" && op.offset === prev.offset + prev.text.length && Path.equals(op.path, prev.path)) {
90
+ return true;
91
+ }
92
+ if (prev && op.type === "remove_text" && prev.type === "remove_text" && op.offset + op.text.length === prev.offset && Path.equals(op.path, prev.path)) {
93
+ return true;
94
+ }
95
+ return false;
96
+ };
97
+ var defaultShouldSave = (op, prev) => {
98
+ if (op.type === "set_selection") {
99
+ return false;
100
+ }
101
+ return true;
102
+ };
103
+ export {
104
+ defaultShouldSave,
105
+ withPartialHistory
106
+ };
4
107
  //# sourceMappingURL=with-partial-history.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":["../../../src/lib/slatejs-edits/with-partial-history.ts"],"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 = (op: Operation, prev: Operation | undefined) => 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 = 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 = (op: Operation, prev: Operation | undefined): boolean => {\n if (op.type === \"set_selection\") {\n return false;\n }\n\n return true;\n};\n"],"mappings":"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","names":[]}
@@ -1,4 +1,48 @@
1
- export { streamPromiseFlatten } from '../chunk-2QDCE7PD.mjs';
2
- import '../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
1
+ var __async = (__this, __arguments, generator) => {
2
+ return new Promise((resolve, reject) => {
3
+ var fulfilled = (value) => {
4
+ try {
5
+ step(generator.next(value));
6
+ } catch (e) {
7
+ reject(e);
8
+ }
9
+ };
10
+ var rejected = (value) => {
11
+ try {
12
+ step(generator.throw(value));
13
+ } catch (e) {
14
+ reject(e);
15
+ }
16
+ };
17
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
18
+ step((generator = generator.apply(__this, __arguments)).next());
19
+ });
20
+ };
21
+
22
+ // src/lib/stream-promise-flatten.ts
23
+ function streamPromiseFlatten(promise) {
24
+ return new ReadableStream({
25
+ start(controller) {
26
+ return __async(this, null, function* () {
27
+ try {
28
+ const stream = yield promise;
29
+ const reader = stream.getReader();
30
+ while (true) {
31
+ const { done, value } = yield reader.read();
32
+ if (done) {
33
+ controller.close();
34
+ return;
35
+ }
36
+ controller.enqueue(value);
37
+ }
38
+ } catch (error) {
39
+ controller.error(error);
40
+ }
41
+ });
42
+ }
43
+ });
44
+ }
45
+ export {
46
+ streamPromiseFlatten
47
+ };
4
48
  //# sourceMappingURL=stream-promise-flatten.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
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":[]}
@@ -1,4 +1,72 @@
1
- export { arraysAreEqual, cn, fetcher, formatDate, nanoid, nullableCompatibleEqualityCheck } from '../chunk-7SUZ6CXM.mjs';
2
- import '../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
1
+ var __async = (__this, __arguments, generator) => {
2
+ return new Promise((resolve, reject) => {
3
+ var fulfilled = (value) => {
4
+ try {
5
+ step(generator.next(value));
6
+ } catch (e) {
7
+ reject(e);
8
+ }
9
+ };
10
+ var rejected = (value) => {
11
+ try {
12
+ step(generator.throw(value));
13
+ } catch (e) {
14
+ reject(e);
15
+ }
16
+ };
17
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
18
+ step((generator = generator.apply(__this, __arguments)).next());
19
+ });
20
+ };
21
+
22
+ // src/lib/utils.ts
23
+ import { clsx } from "clsx";
24
+ import { customAlphabet } from "nanoid";
25
+ import { twMerge } from "tailwind-merge";
26
+ function cn(...inputs) {
27
+ return twMerge(clsx(inputs));
28
+ }
29
+ var nanoid = customAlphabet(
30
+ "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",
31
+ 7
32
+ );
33
+ function fetcher(input, init) {
34
+ return __async(this, null, function* () {
35
+ const res = yield fetch(input, init);
36
+ if (!res.ok) {
37
+ const json = yield res.json();
38
+ if (json.error) {
39
+ const error = new Error(json.error);
40
+ error.status = res.status;
41
+ throw error;
42
+ } else {
43
+ throw new Error("An unexpected error occurred");
44
+ }
45
+ }
46
+ return res.json();
47
+ });
48
+ }
49
+ function formatDate(input) {
50
+ const date = new Date(input);
51
+ return date.toLocaleDateString("en-US", {
52
+ month: "long",
53
+ day: "numeric",
54
+ year: "numeric"
55
+ });
56
+ }
57
+ var arraysAreEqual = (arr1, arr2) => arr1.length === arr2.length && arr1.every((value, index) => value === arr2[index]);
58
+ function nullableCompatibleEqualityCheck(naiveEqualityCheck, a, b) {
59
+ if (a === null || a === void 0 || b === null || b === void 0) {
60
+ return a === b;
61
+ }
62
+ return naiveEqualityCheck(a, b);
63
+ }
64
+ export {
65
+ arraysAreEqual,
66
+ cn,
67
+ fetcher,
68
+ formatDate,
69
+ nanoid,
70
+ nullableCompatibleEqualityCheck
71
+ };
4
72
  //# sourceMappingURL=utils.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":["../../src/lib/utils.ts"],"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>(input: RequestInfo, init?: RequestInit): 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 && 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"],"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,QAAoB,OAAoB,MAAmC;AAAA;AAC/F,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,UAAU,KAAK,MAAM,CAAC,OAAO,UAAU,UAAU,KAAK,KAAK,CAAC;AAE5E,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;","names":[]}
@@ -4,5 +4,4 @@ describe("emptyTest", () => {
4
4
  expect(true).toBeTruthy();
5
5
  });
6
6
  });
7
- //# sourceMappingURL=out.js.map
8
7
  //# sourceMappingURL=utils.test.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/utils.test.ts"],"names":[],"mappings":";AAEA,SAAS,aAAa,MAAM;AAC1B,KAAG,oBAAoB,MAAM;AAC3B,WAAO,IAAI,EAAE,WAAW;AAAA,EAC1B,CAAC;AACH,CAAC","sourcesContent":["import * as utils from \"./utils\";\n\ndescribe(\"emptyTest\", () => {\n it(\"should be truthy\", () => {\n expect(true).toBeTruthy();\n });\n});\n"]}
1
+ {"version":3,"sources":["../../src/lib/utils.test.ts"],"sourcesContent":["import * as utils from \"./utils\";\n\ndescribe(\"emptyTest\", () => {\n it(\"should be truthy\", () => {\n expect(true).toBeTruthy();\n });\n});\n"],"mappings":";AAEA,SAAS,aAAa,MAAM;AAC1B,KAAG,oBAAoB,MAAM;AAC3B,WAAO,IAAI,EAAE,WAAW;AAAA,EAC1B,CAAC;AACH,CAAC;","names":[]}
@@ -1,3 +1 @@
1
-
2
- //# sourceMappingURL=out.js.map
3
1
  //# sourceMappingURL=autosuggestions-config-user-specified.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}