@copilotkit/react-textarea 0.19.0-alpha.7 → 0.19.0-alpha.9

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 (230) hide show
  1. package/.turbo/turbo-build.log +180 -178
  2. package/CHANGELOG.md +22 -0
  3. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +1734 -33
  4. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs.map +1 -1
  5. package/dist/components/base-copilot-textarea/render-element.mjs +52 -3
  6. package/dist/components/base-copilot-textarea/render-element.mjs.map +1 -1
  7. package/dist/components/base-copilot-textarea/render-placeholder.mjs +46 -3
  8. package/dist/components/base-copilot-textarea/render-placeholder.mjs.map +1 -1
  9. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs +86 -4
  10. package/dist/components/base-copilot-textarea/track-cursor-moved-since-last-text-change.mjs.map +1 -1
  11. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs +57 -3
  12. package/dist/components/base-copilot-textarea/use-add-branding-css.mjs.map +1 -1
  13. package/dist/components/copilot-textarea/copilot-textarea.mjs +2202 -45
  14. package/dist/components/copilot-textarea/copilot-textarea.mjs.map +1 -1
  15. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs +22 -3
  16. package/dist/components/hovering-toolbar/hovering-editor-provider.mjs.map +1 -1
  17. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs +125 -3
  18. package/dist/components/hovering-toolbar/hovering-toolbar-components.mjs.map +1 -1
  19. package/dist/components/hovering-toolbar/hovering-toolbar.d.ts +1 -0
  20. package/dist/components/hovering-toolbar/hovering-toolbar.mjs +877 -16
  21. package/dist/components/hovering-toolbar/hovering-toolbar.mjs.map +1 -1
  22. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.d.ts +6 -9
  23. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs +577 -10
  24. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.mjs.map +1 -1
  25. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.d.ts +1 -0
  26. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs +592 -11
  27. package/dist/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.mjs.map +1 -1
  28. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs +592 -12
  29. package/dist/components/hovering-toolbar/text-insertion-prompt-box/index.mjs.map +1 -1
  30. package/dist/components/index.mjs +2203 -46
  31. package/dist/components/index.mjs.map +1 -1
  32. package/dist/components/manual-ui/chip-with-icon.mjs +5 -6
  33. package/dist/components/manual-ui/chip-with-icon.mjs.map +1 -1
  34. package/dist/components/source-search-box/source-search-box.d.ts +5 -8
  35. package/dist/components/source-search-box/source-search-box.mjs +209 -10
  36. package/dist/components/source-search-box/source-search-box.mjs.map +1 -1
  37. package/dist/components/ui/button.mjs +88 -4
  38. package/dist/components/ui/button.mjs.map +1 -1
  39. package/dist/components/ui/card.mjs +53 -7
  40. package/dist/components/ui/card.mjs.map +1 -1
  41. package/dist/components/ui/command.mjs +266 -5
  42. package/dist/components/ui/command.mjs.map +1 -1
  43. package/dist/components/ui/dialog.mjs +164 -4
  44. package/dist/components/ui/dialog.mjs.map +1 -1
  45. package/dist/components/ui/label.mjs +63 -4
  46. package/dist/components/ui/label.mjs.map +1 -1
  47. package/dist/components/ui/separator.mjs +50 -8
  48. package/dist/components/ui/separator.mjs.map +1 -1
  49. package/dist/components/ui/textarea.mjs +48 -7
  50. package/dist/components/ui/textarea.mjs.map +1 -1
  51. package/dist/context/index.mjs +0 -2
  52. package/dist/context/index.mjs.map +1 -1
  53. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs +168 -6
  54. package/dist/hooks/base-copilot-textarea-implementation/use-autosuggestions.mjs.map +1 -1
  55. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs +168 -4
  56. package/dist/hooks/base-copilot-textarea-implementation/use-copilot-textarea-editor.mjs.map +1 -1
  57. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs +155 -5
  58. package/dist/hooks/base-copilot-textarea-implementation/use-populate-copilot-textarea-ref.mjs.map +1 -1
  59. package/dist/hooks/index.mjs +0 -2
  60. package/dist/hooks/index.mjs.map +1 -1
  61. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +145 -14
  62. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map +1 -1
  63. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs +199 -14
  64. package/dist/hooks/make-autosuggestions-function/use-make-standard-insertion-function.mjs.map +1 -1
  65. package/dist/hooks/misc/use-autosize-textarea.mjs +15 -3
  66. package/dist/hooks/misc/use-autosize-textarea.mjs.map +1 -1
  67. package/dist/index.css +4 -18
  68. package/dist/index.css.map +1 -1
  69. package/dist/index.mjs +2206 -48
  70. package/dist/index.mjs.map +1 -1
  71. package/dist/lib/debouncer.mjs +51 -3
  72. package/dist/lib/debouncer.mjs.map +1 -1
  73. package/dist/lib/editor-to-text.mjs +43 -3
  74. package/dist/lib/editor-to-text.mjs.map +1 -1
  75. package/dist/lib/get-text-around-cursor.mjs +109 -3
  76. package/dist/lib/get-text-around-cursor.mjs.map +1 -1
  77. package/dist/lib/retry.mjs +17 -3
  78. package/dist/lib/retry.mjs.map +1 -1
  79. package/dist/lib/slatejs-edits/add-autocompletions.mjs +25 -3
  80. package/dist/lib/slatejs-edits/add-autocompletions.mjs.map +1 -1
  81. package/dist/lib/slatejs-edits/clear-autocompletions.mjs +23 -3
  82. package/dist/lib/slatejs-edits/clear-autocompletions.mjs.map +1 -1
  83. package/dist/lib/slatejs-edits/replace-text.mjs +27 -3
  84. package/dist/lib/slatejs-edits/replace-text.mjs.map +1 -1
  85. package/dist/lib/slatejs-edits/with-partial-history.mjs +106 -3
  86. package/dist/lib/slatejs-edits/with-partial-history.mjs.map +1 -1
  87. package/dist/lib/stream-promise-flatten.mjs +47 -3
  88. package/dist/lib/stream-promise-flatten.mjs.map +1 -1
  89. package/dist/lib/utils.mjs +71 -3
  90. package/dist/lib/utils.mjs.map +1 -1
  91. package/dist/lib/utils.test.mjs +0 -1
  92. package/dist/lib/utils.test.mjs.map +1 -1
  93. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs +0 -2
  94. package/dist/types/autosuggestions-config/autosuggestions-config-user-specified.mjs.map +1 -1
  95. package/dist/types/autosuggestions-config/autosuggestions-config.mjs +254 -8
  96. package/dist/types/autosuggestions-config/autosuggestions-config.mjs.map +1 -1
  97. package/dist/types/autosuggestions-config/editing-api-config.mjs +83 -3
  98. package/dist/types/autosuggestions-config/editing-api-config.mjs.map +1 -1
  99. package/dist/types/autosuggestions-config/index.mjs +310 -10
  100. package/dist/types/autosuggestions-config/index.mjs.map +1 -1
  101. package/dist/types/autosuggestions-config/insertions-api-config.mjs +77 -3
  102. package/dist/types/autosuggestions-config/insertions-api-config.mjs.map +1 -1
  103. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs +77 -3
  104. package/dist/types/autosuggestions-config/subtypes/chatlike-api-endpoint.mjs.map +1 -1
  105. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs +0 -2
  106. package/dist/types/autosuggestions-config/subtypes/make-system-prompt.mjs.map +1 -1
  107. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs +0 -2
  108. package/dist/types/autosuggestions-config/subtypes/minimal-chat-gpt-message.mjs.map +1 -1
  109. package/dist/types/autosuggestions-config/suggestions-api-config.mjs +64 -3
  110. package/dist/types/autosuggestions-config/suggestions-api-config.mjs.map +1 -1
  111. package/dist/types/base/autosuggestion-state.mjs +0 -2
  112. package/dist/types/base/autosuggestion-state.mjs.map +1 -1
  113. package/dist/types/base/autosuggestions-bare-function.mjs +0 -2
  114. package/dist/types/base/autosuggestions-bare-function.mjs.map +1 -1
  115. package/dist/types/base/base-autosuggestions-config.d.ts +1 -0
  116. package/dist/types/base/base-autosuggestions-config.mjs +12 -3
  117. package/dist/types/base/base-autosuggestions-config.mjs.map +1 -1
  118. package/dist/types/base/base-copilot-textarea-props.mjs +0 -2
  119. package/dist/types/base/base-copilot-textarea-props.mjs.map +1 -1
  120. package/dist/types/base/custom-editor.mjs +0 -2
  121. package/dist/types/base/custom-editor.mjs.map +1 -1
  122. package/dist/types/base/editor-autocomplete-state.mjs +17 -4
  123. package/dist/types/base/editor-autocomplete-state.mjs.map +1 -1
  124. package/dist/types/base/index.mjs +12 -4
  125. package/dist/types/base/index.mjs.map +1 -1
  126. package/dist/types/html-copilot-textarea-element.mjs +0 -2
  127. package/dist/types/html-copilot-textarea-element.mjs.map +1 -1
  128. package/dist/types/index.mjs +311 -12
  129. package/dist/types/index.mjs.map +1 -1
  130. package/package.json +3 -3
  131. package/src/components/base-copilot-textarea/base-copilot-textarea.tsx +4 -1
  132. package/src/components/hovering-toolbar/hovering-toolbar.tsx +2 -0
  133. package/src/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.tsx +26 -152
  134. package/src/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box.tsx +2 -0
  135. package/src/components/source-search-box/source-search-box.tsx +13 -17
  136. package/src/types/base/base-autosuggestions-config.tsx +2 -0
  137. package/dist/chunk-2NURR2DX.mjs +0 -47
  138. package/dist/chunk-2NURR2DX.mjs.map +0 -1
  139. package/dist/chunk-2TQBFDO7.mjs +0 -19
  140. package/dist/chunk-2TQBFDO7.mjs.map +0 -1
  141. package/dist/chunk-4S5ZJH3I.mjs +0 -18
  142. package/dist/chunk-4S5ZJH3I.mjs.map +0 -1
  143. package/dist/chunk-5EJ5XOGP.mjs +0 -22
  144. package/dist/chunk-5EJ5XOGP.mjs.map +0 -1
  145. package/dist/chunk-5FO6ISW4.mjs +0 -3
  146. package/dist/chunk-5FO6ISW4.mjs.map +0 -1
  147. package/dist/chunk-66BDXIX4.mjs +0 -76
  148. package/dist/chunk-66BDXIX4.mjs.map +0 -1
  149. package/dist/chunk-7XKICWEE.mjs +0 -44
  150. package/dist/chunk-7XKICWEE.mjs.map +0 -1
  151. package/dist/chunk-CSGFJU3L.mjs +0 -65
  152. package/dist/chunk-CSGFJU3L.mjs.map +0 -1
  153. package/dist/chunk-D7SEV5PR.mjs +0 -12
  154. package/dist/chunk-D7SEV5PR.mjs.map +0 -1
  155. package/dist/chunk-DE5K76I2.mjs +0 -3
  156. package/dist/chunk-DE5K76I2.mjs.map +0 -1
  157. package/dist/chunk-F3MHL6ZY.mjs +0 -25
  158. package/dist/chunk-F3MHL6ZY.mjs.map +0 -1
  159. package/dist/chunk-FN7GDKKG.mjs +0 -29
  160. package/dist/chunk-FN7GDKKG.mjs.map +0 -1
  161. package/dist/chunk-H4VKQGVU.mjs +0 -3
  162. package/dist/chunk-H4VKQGVU.mjs.map +0 -1
  163. package/dist/chunk-HRTFMM7P.mjs +0 -82
  164. package/dist/chunk-HRTFMM7P.mjs.map +0 -1
  165. package/dist/chunk-IU3WTXLQ.mjs +0 -3
  166. package/dist/chunk-IU3WTXLQ.mjs.map +0 -1
  167. package/dist/chunk-IXJ2HCOA.mjs +0 -101
  168. package/dist/chunk-IXJ2HCOA.mjs.map +0 -1
  169. package/dist/chunk-JAFCXEPU.mjs +0 -10
  170. package/dist/chunk-JAFCXEPU.mjs.map +0 -1
  171. package/dist/chunk-JHTAOLEW.mjs +0 -63
  172. package/dist/chunk-JHTAOLEW.mjs.map +0 -1
  173. package/dist/chunk-K2AVA67P.mjs +0 -57
  174. package/dist/chunk-K2AVA67P.mjs.map +0 -1
  175. package/dist/chunk-KCHYD3EB.mjs +0 -107
  176. package/dist/chunk-KCHYD3EB.mjs.map +0 -1
  177. package/dist/chunk-KGKLUWKW.mjs +0 -47
  178. package/dist/chunk-KGKLUWKW.mjs.map +0 -1
  179. package/dist/chunk-KIRROE2K.mjs +0 -37
  180. package/dist/chunk-KIRROE2K.mjs.map +0 -1
  181. package/dist/chunk-L7VVZH4Q.mjs +0 -3
  182. package/dist/chunk-L7VVZH4Q.mjs.map +0 -1
  183. package/dist/chunk-LNAIMEB2.mjs +0 -34
  184. package/dist/chunk-LNAIMEB2.mjs.map +0 -1
  185. package/dist/chunk-MMVDU6DF.mjs +0 -3
  186. package/dist/chunk-MMVDU6DF.mjs.map +0 -1
  187. package/dist/chunk-MPME5BW2.mjs +0 -59
  188. package/dist/chunk-MPME5BW2.mjs.map +0 -1
  189. package/dist/chunk-MRXNTQOX.mjs +0 -55
  190. package/dist/chunk-MRXNTQOX.mjs.map +0 -1
  191. package/dist/chunk-ND5PXTAW.mjs +0 -17
  192. package/dist/chunk-ND5PXTAW.mjs.map +0 -1
  193. package/dist/chunk-NKA6K7FW.mjs +0 -201
  194. package/dist/chunk-NKA6K7FW.mjs.map +0 -1
  195. package/dist/chunk-NKW5OU2S.mjs +0 -33
  196. package/dist/chunk-NKW5OU2S.mjs.map +0 -1
  197. package/dist/chunk-O5OWT5GE.mjs +0 -114
  198. package/dist/chunk-O5OWT5GE.mjs.map +0 -1
  199. package/dist/chunk-OD7ZMOVE.mjs +0 -45
  200. package/dist/chunk-OD7ZMOVE.mjs.map +0 -1
  201. package/dist/chunk-OELUUJZY.mjs +0 -16
  202. package/dist/chunk-OELUUJZY.mjs.map +0 -1
  203. package/dist/chunk-OXPXFYUG.mjs +0 -111
  204. package/dist/chunk-OXPXFYUG.mjs.map +0 -1
  205. package/dist/chunk-RQHOUUXQ.mjs +0 -29
  206. package/dist/chunk-RQHOUUXQ.mjs.map +0 -1
  207. package/dist/chunk-U5AJ5PBH.mjs +0 -107
  208. package/dist/chunk-U5AJ5PBH.mjs.map +0 -1
  209. package/dist/chunk-UHD44NC5.mjs +0 -101
  210. package/dist/chunk-UHD44NC5.mjs.map +0 -1
  211. package/dist/chunk-WADHCMPK.mjs +0 -3
  212. package/dist/chunk-WADHCMPK.mjs.map +0 -1
  213. package/dist/chunk-WJHSY5T6.mjs +0 -3
  214. package/dist/chunk-WJHSY5T6.mjs.map +0 -1
  215. package/dist/chunk-WJYQWL4I.mjs +0 -27
  216. package/dist/chunk-WJYQWL4I.mjs.map +0 -1
  217. package/dist/chunk-XA7M72ZO.mjs +0 -106
  218. package/dist/chunk-XA7M72ZO.mjs.map +0 -1
  219. package/dist/chunk-XHUMROEY.mjs +0 -91
  220. package/dist/chunk-XHUMROEY.mjs.map +0 -1
  221. package/dist/chunk-XYXKONR4.mjs +0 -501
  222. package/dist/chunk-XYXKONR4.mjs.map +0 -1
  223. package/dist/chunk-YQU7WG7T.mjs +0 -83
  224. package/dist/chunk-YQU7WG7T.mjs.map +0 -1
  225. package/dist/chunk-YTOPHPSG.mjs +0 -45
  226. package/dist/chunk-YTOPHPSG.mjs.map +0 -1
  227. package/dist/chunk-YW3REYX6.mjs +0 -23
  228. package/dist/chunk-YW3REYX6.mjs.map +0 -1
  229. package/dist/chunk-ZA3R6NZI.mjs +0 -20
  230. package/dist/chunk-ZA3R6NZI.mjs.map +0 -1
@@ -1,107 +0,0 @@
1
- import { Transforms, Editor, Operation, Path } from 'slate';
2
- import { HistoryEditor } from 'slate-history';
3
-
4
- // src/lib/slatejs-edits/with-partial-history.ts
5
- var withPartialHistory = (editor, shouldSave) => {
6
- const e = editor;
7
- const { apply } = e;
8
- e.history = { undos: [], redos: [] };
9
- e.redo = () => {
10
- const { history } = e;
11
- const { redos } = history;
12
- if (redos.length > 0) {
13
- const batch = redos[redos.length - 1];
14
- if (batch.selectionBefore) {
15
- Transforms.setSelection(e, batch.selectionBefore);
16
- }
17
- HistoryEditor.withoutSaving(e, () => {
18
- Editor.withoutNormalizing(e, () => {
19
- for (const op of batch.operations) {
20
- e.apply(op);
21
- }
22
- });
23
- });
24
- history.redos.pop();
25
- e.writeHistory("undos", batch);
26
- }
27
- };
28
- e.undo = () => {
29
- const { history } = e;
30
- const { undos } = history;
31
- if (undos.length > 0) {
32
- const batch = undos[undos.length - 1];
33
- HistoryEditor.withoutSaving(e, () => {
34
- Editor.withoutNormalizing(e, () => {
35
- const inverseOps = batch.operations.map(Operation.inverse).reverse();
36
- for (const op of inverseOps) {
37
- e.apply(op);
38
- }
39
- if (batch.selectionBefore) {
40
- Transforms.setSelection(e, batch.selectionBefore);
41
- }
42
- });
43
- });
44
- e.writeHistory("redos", batch);
45
- history.undos.pop();
46
- }
47
- };
48
- e.apply = (op) => {
49
- const { operations, history } = e;
50
- const { undos } = history;
51
- const lastBatch = undos[undos.length - 1];
52
- const lastOp = lastBatch && lastBatch.operations[lastBatch.operations.length - 1];
53
- let save = HistoryEditor.isSaving(e);
54
- let merge = HistoryEditor.isMerging(e);
55
- if (save == null) {
56
- save = shouldSave(op, lastOp);
57
- }
58
- if (save) {
59
- if (merge == null) {
60
- if (lastBatch == null) {
61
- merge = false;
62
- } else if (operations.length !== 0) {
63
- merge = true;
64
- } else {
65
- merge = shouldMerge(op, lastOp);
66
- }
67
- }
68
- if (lastBatch && merge) {
69
- lastBatch.operations.push(op);
70
- } else {
71
- const batch = {
72
- operations: [op],
73
- selectionBefore: e.selection
74
- };
75
- e.writeHistory("undos", batch);
76
- }
77
- while (undos.length > 100) {
78
- undos.shift();
79
- }
80
- history.redos = [];
81
- }
82
- apply(op);
83
- };
84
- e.writeHistory = (stack, batch) => {
85
- e.history[stack].push(batch);
86
- };
87
- return e;
88
- };
89
- var shouldMerge = (op, prev) => {
90
- if (prev && op.type === "insert_text" && prev.type === "insert_text" && op.offset === prev.offset + prev.text.length && Path.equals(op.path, prev.path)) {
91
- return true;
92
- }
93
- if (prev && op.type === "remove_text" && prev.type === "remove_text" && op.offset + op.text.length === prev.offset && Path.equals(op.path, prev.path)) {
94
- return true;
95
- }
96
- return false;
97
- };
98
- var defaultShouldSave = (op, prev) => {
99
- if (op.type === "set_selection") {
100
- return false;
101
- }
102
- return true;
103
- };
104
-
105
- export { defaultShouldSave, withPartialHistory };
106
- //# sourceMappingURL=out.js.map
107
- //# sourceMappingURL=chunk-KCHYD3EB.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/slatejs-edits/with-partial-history.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Operation, Path, Range, Transforms } from \"slate\";\nimport { HistoryEditor } from \"slate-history\";\n\n// Copy-pasted from `https://github.com/ianstormtaylor/slate/blob/main/packages/slate-history/src/with-history.ts`\n// With one exception: the `shouldSave` function is passed in as an argument to `withPartialHistory` instead of being hardcoded\nexport type ShouldSaveToHistory = (\n op: Operation,\n prev: Operation | undefined\n) => boolean;\n\nexport const withPartialHistory = <T extends Editor>(\n editor: T,\n shouldSave: ShouldSaveToHistory\n) => {\n const e = editor as T & HistoryEditor;\n const { apply } = e;\n e.history = { undos: [], redos: [] };\n\n e.redo = () => {\n const { history } = e;\n const { redos } = history;\n\n if (redos.length > 0) {\n const batch = redos[redos.length - 1];\n\n if (batch.selectionBefore) {\n Transforms.setSelection(e, batch.selectionBefore);\n }\n\n HistoryEditor.withoutSaving(e, () => {\n Editor.withoutNormalizing(e, () => {\n for (const op of batch.operations) {\n e.apply(op);\n }\n });\n });\n\n history.redos.pop();\n e.writeHistory(\"undos\", batch);\n }\n };\n\n e.undo = () => {\n const { history } = e;\n const { undos } = history;\n\n if (undos.length > 0) {\n const batch = undos[undos.length - 1];\n\n HistoryEditor.withoutSaving(e, () => {\n Editor.withoutNormalizing(e, () => {\n const inverseOps = batch.operations.map(Operation.inverse).reverse();\n\n for (const op of inverseOps) {\n e.apply(op);\n }\n if (batch.selectionBefore) {\n Transforms.setSelection(e, batch.selectionBefore);\n }\n });\n });\n\n e.writeHistory(\"redos\", batch);\n history.undos.pop();\n }\n };\n\n e.apply = (op: Operation) => {\n const { operations, history } = e;\n const { undos } = history;\n const lastBatch = undos[undos.length - 1];\n const lastOp =\n lastBatch && lastBatch.operations[lastBatch.operations.length - 1];\n let save = HistoryEditor.isSaving(e);\n let merge = HistoryEditor.isMerging(e);\n\n if (save == null) {\n save = shouldSave(op, lastOp);\n }\n\n if (save) {\n if (merge == null) {\n if (lastBatch == null) {\n merge = false;\n } else if (operations.length !== 0) {\n merge = true;\n } else {\n merge = shouldMerge(op, lastOp);\n }\n }\n\n if (lastBatch && merge) {\n lastBatch.operations.push(op);\n } else {\n const batch = {\n operations: [op],\n selectionBefore: e.selection,\n };\n e.writeHistory(\"undos\", batch);\n }\n\n while (undos.length > 100) {\n undos.shift();\n }\n\n history.redos = [];\n }\n\n apply(op);\n };\n\n e.writeHistory = (stack: \"undos\" | \"redos\", batch: any) => {\n e.history[stack].push(batch);\n };\n\n return e;\n};\n\n/**\n * Check whether to merge an operation into the previous operation.\n */\n\nconst shouldMerge = (op: Operation, prev: Operation | undefined): boolean => {\n if (\n prev &&\n op.type === \"insert_text\" &&\n prev.type === \"insert_text\" &&\n op.offset === prev.offset + prev.text.length &&\n Path.equals(op.path, prev.path)\n ) {\n return true;\n }\n\n if (\n prev &&\n op.type === \"remove_text\" &&\n prev.type === \"remove_text\" &&\n op.offset + op.text.length === prev.offset &&\n Path.equals(op.path, prev.path)\n ) {\n return true;\n }\n\n return false;\n};\n\nexport const defaultShouldSave = (\n op: Operation,\n prev: Operation | undefined\n): boolean => {\n if (op.type === \"set_selection\") {\n return false;\n }\n\n return true;\n};\n"]}
@@ -1,47 +0,0 @@
1
- import { __async } from './chunk-MRXNTQOX.mjs';
2
- import { clsx } from 'clsx';
3
- import { customAlphabet } from 'nanoid';
4
- import { twMerge } from 'tailwind-merge';
5
-
6
- function cn(...inputs) {
7
- return twMerge(clsx(inputs));
8
- }
9
- var nanoid = customAlphabet(
10
- "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",
11
- 7
12
- );
13
- function fetcher(input, init) {
14
- return __async(this, null, function* () {
15
- const res = yield fetch(input, init);
16
- if (!res.ok) {
17
- const json = yield res.json();
18
- if (json.error) {
19
- const error = new Error(json.error);
20
- error.status = res.status;
21
- throw error;
22
- } else {
23
- throw new Error("An unexpected error occurred");
24
- }
25
- }
26
- return res.json();
27
- });
28
- }
29
- function formatDate(input) {
30
- const date = new Date(input);
31
- return date.toLocaleDateString("en-US", {
32
- month: "long",
33
- day: "numeric",
34
- year: "numeric"
35
- });
36
- }
37
- var arraysAreEqual = (arr1, arr2) => arr1.length === arr2.length && arr1.every((value, index) => value === arr2[index]);
38
- function nullableCompatibleEqualityCheck(naiveEqualityCheck, a, b) {
39
- if (a === null || a === void 0 || b === null || b === void 0) {
40
- return a === b;
41
- }
42
- return naiveEqualityCheck(a, b);
43
- }
44
-
45
- export { arraysAreEqual, cn, fetcher, formatDate, nanoid, nullableCompatibleEqualityCheck };
46
- //# sourceMappingURL=out.js.map
47
- //# sourceMappingURL=chunk-KGKLUWKW.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/utils.ts"],"names":[],"mappings":";;;;;AAAA,SAAS,YAA6B;AACtC,SAAS,sBAAsB;AAC/B,SAAS,eAAe;AAEjB,SAAS,MAAM,QAAsB;AAC1C,SAAO,QAAQ,KAAK,MAAM,CAAC;AAC7B;AAEO,IAAM,SAAS;AAAA,EACpB;AAAA,EACA;AACF;AAEA,SAAsB,QACpB,OACA,MACe;AAAA;AACf,UAAM,MAAM,MAAM,MAAM,OAAO,IAAI;AAEnC,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,UAAI,KAAK,OAAO;AACd,cAAM,QAAQ,IAAI,MAAM,KAAK,KAAK;AAGlC,cAAM,SAAS,IAAI;AACnB,cAAM;AAAA,MACR,OAAO;AACL,cAAM,IAAI,MAAM,8BAA8B;AAAA,MAChD;AAAA,IACF;AAEA,WAAO,IAAI,KAAK;AAAA,EAClB;AAAA;AAEO,SAAS,WAAW,OAAuC;AAChE,QAAM,OAAO,IAAI,KAAK,KAAK;AAC3B,SAAO,KAAK,mBAAmB,SAAS;AAAA,IACtC,OAAO;AAAA,IACP,KAAK;AAAA,IACL,MAAM;AAAA,EACR,CAAC;AACH;AAEO,IAAM,iBAAiB,CAAC,MAAgB,SAC7C,KAAK,WAAW,KAAK,UACrB,KAAK,MAAM,CAAC,OAAO,UAAU,UAAU,KAAK,MAAM;AAE7C,SAAS,gCACd,oBACA,GACA,GACS;AACT,MAAI,MAAM,QAAQ,MAAM,UAAa,MAAM,QAAQ,MAAM,QAAW;AAClE,WAAO,MAAM;AAAA,EACf;AAEA,SAAO,mBAAmB,GAAG,CAAC;AAChC","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { customAlphabet } from \"nanoid\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const nanoid = customAlphabet(\n \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\",\n 7\n); // 7-character random string\n\nexport async function fetcher<JSON = any>(\n input: RequestInfo,\n init?: RequestInit\n): Promise<JSON> {\n const res = await fetch(input, init);\n\n if (!res.ok) {\n const json = await res.json();\n if (json.error) {\n const error = new Error(json.error) as Error & {\n status: number;\n };\n error.status = res.status;\n throw error;\n } else {\n throw new Error(\"An unexpected error occurred\");\n }\n }\n\n return res.json();\n}\n\nexport function formatDate(input: string | number | Date): string {\n const date = new Date(input);\n return date.toLocaleDateString(\"en-US\", {\n month: \"long\",\n day: \"numeric\",\n year: \"numeric\",\n });\n}\n\nexport const arraysAreEqual = (arr1: number[], arr2: number[]): boolean =>\n arr1.length === arr2.length &&\n arr1.every((value, index) => value === arr2[index]);\n\nexport function nullableCompatibleEqualityCheck<T>(\n naiveEqualityCheck: (a: T, b: T) => boolean,\n a: T | null | undefined,\n b: T | null | undefined\n): boolean {\n if (a === null || a === undefined || b === null || b === undefined) {\n return a === b;\n }\n\n return naiveEqualityCheck(a, b);\n}\n"]}
@@ -1,37 +0,0 @@
1
- import { __async, __spreadProps, __spreadValues } from './chunk-MRXNTQOX.mjs';
2
- import { copilotApiConfigExtrapolator } from '@copilotkit/react-core';
3
-
4
- var ChatlikeApiEndpoint = class {
5
- constructor(run) {
6
- this.run = run;
7
- }
8
- static fromCopilotApiConfig(copilotApiConfig) {
9
- return new ChatlikeApiEndpoint(
10
- (abortSignal, messages, forwardedProps) => __async(this, null, function* () {
11
- const res = yield fetch(
12
- copilotApiConfigExtrapolator(copilotApiConfig).chatApiEndpoint,
13
- {
14
- method: "POST",
15
- body: JSON.stringify(__spreadProps(__spreadValues({}, forwardedProps), {
16
- messages
17
- })),
18
- signal: abortSignal
19
- }
20
- );
21
- const bodySteram = res.body;
22
- if (!bodySteram) {
23
- throw new Error("The response body is empty.");
24
- }
25
- const stringStream = bodySteram.pipeThrough(new TextDecoderStream());
26
- return stringStream;
27
- })
28
- );
29
- }
30
- static custom(run) {
31
- return new ChatlikeApiEndpoint(run);
32
- }
33
- };
34
-
35
- export { ChatlikeApiEndpoint };
36
- //# sourceMappingURL=out.js.map
37
- //# sourceMappingURL=chunk-KIRROE2K.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/types/autosuggestions-config/subtypes/chatlike-api-endpoint.tsx"],"names":[],"mappings":";;;;;;;AAAA;AAAA,EAEE;AAAA,OACK;AAeA,IAAM,sBAAN,MAA0B;AAAA,EAG/B,YAAY,KAAuC;AACjD,SAAK,MAAM;AAAA,EACb;AAAA,EAOA,OAAO,qBACL,kBACqB;AACrB,WAAO,IAAI;AAAA,MACT,CACE,aACA,UACA,mBACG;AACH,cAAM,MAAM,MAAM;AAAA,UAChB,6BAA6B,gBAAgB,EAAE;AAAA,UAC/C;AAAA,YACE,QAAQ;AAAA,YACR,MAAM,KAAK,UAAU,iCAChB,iBADgB;AAAA,cAEnB;AAAA,YACF,EAAC;AAAA,YACD,QAAQ;AAAA,UACV;AAAA,QACF;AAEA,cAAM,aAAgD,IAAI;AAC1D,YAAI,CAAC,YAAY;AACf,gBAAM,IAAI,MAAM,6BAA6B;AAAA,QAC/C;AAGA,cAAM,eAAe,WAAW,YAAY,IAAI,kBAAkB,CAAC;AAEnE,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF;AAAA,EAOA,OAAO,OAAO,KAA4D;AACxE,WAAO,IAAI,oBAAoB,GAAG;AAAA,EACpC;AACF","sourcesContent":["import {\n CopilotApiConfig,\n copilotApiConfigExtrapolator,\n} from \"@copilotkit/react-core\";\nimport { MinimalChatGPTMessage } from \"./minimal-chat-gpt-message\";\n\nexport type ChatlikeApiEndpointImpl = (\n abortSignal: AbortSignal,\n messages: MinimalChatGPTMessage[],\n forwardedProps?: { [key: string]: any }\n) => Promise<string>;\n\nexport type StreamingChatlikeApiEndpointImpl = (\n abortSignal: AbortSignal,\n messages: MinimalChatGPTMessage[],\n forwardedProps?: { [key: string]: any }\n) => Promise<ReadableStream<string>>;\n\nexport class ChatlikeApiEndpoint {\n public run: StreamingChatlikeApiEndpointImpl;\n\n constructor(run: StreamingChatlikeApiEndpointImpl) {\n this.run = run;\n }\n\n /**\n * Creates a new instance of ChatlikeApiEndpoint with the provided API endpoint.\n * @param apiEndpoint The URL of the OpenAI-compatible API endpoint.\n * @returns A new instance of ChatlikeApiEndpoint.\n */\n static fromCopilotApiConfig(\n copilotApiConfig: CopilotApiConfig\n ): ChatlikeApiEndpoint {\n return new ChatlikeApiEndpoint(\n async (\n abortSignal: AbortSignal,\n messages: MinimalChatGPTMessage[],\n forwardedProps?: { [key: string]: any }\n ) => {\n const res = await fetch(\n copilotApiConfigExtrapolator(copilotApiConfig).chatApiEndpoint,\n {\n method: \"POST\",\n body: JSON.stringify({\n ...forwardedProps,\n messages: messages,\n }),\n signal: abortSignal,\n }\n );\n\n const bodySteram: ReadableStream<Uint8Array> | null = res.body;\n if (!bodySteram) {\n throw new Error(\"The response body is empty.\");\n }\n\n // map the stream to a stream of strings\n const stringStream = bodySteram.pipeThrough(new TextDecoderStream());\n\n return stringStream;\n }\n );\n }\n\n /**\n * Creates a fully customized instance of ChatlikeApiEndpoint.\n * @param run - The implementation of the ChatlikeApiEndpointImpl interface.\n * @returns A new instance of ChatlikeApiEndpoint .\n */\n static custom(run: StreamingChatlikeApiEndpointImpl): ChatlikeApiEndpoint {\n return new ChatlikeApiEndpoint(run);\n }\n}\n"]}
@@ -1,3 +0,0 @@
1
-
2
- //# sourceMappingURL=out.js.map
3
- //# sourceMappingURL=chunk-L7VVZH4Q.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,34 +0,0 @@
1
- import { __spreadProps, __spreadValues } from './chunk-MRXNTQOX.mjs';
2
- import { jsx, jsxs } from 'react/jsx-runtime';
3
-
4
- function makeRenderElementFunction(suggestionsStyle) {
5
- return (props) => {
6
- switch (props.element.type) {
7
- case "paragraph":
8
- return /* @__PURE__ */ jsx(DefaultElement, __spreadValues({}, props));
9
- case "suggestion":
10
- return /* @__PURE__ */ jsx(SuggestionElement, __spreadProps(__spreadValues({}, props), {
11
- suggestionsStyle
12
- }));
13
- }
14
- };
15
- }
16
- var DefaultElement = (props) => {
17
- return /* @__PURE__ */ jsx("div", __spreadProps(__spreadValues({}, props.attributes), {
18
- children: props.children
19
- }));
20
- };
21
- var SuggestionElement = (props) => {
22
- return /* @__PURE__ */ jsxs("span", __spreadProps(__spreadValues({}, props.attributes), {
23
- style: __spreadValues({}, props.suggestionsStyle),
24
- contentEditable: false,
25
- children: [
26
- props.children,
27
- props.element.type === "suggestion" && props.element.content
28
- ]
29
- }));
30
- };
31
-
32
- export { makeRenderElementFunction };
33
- //# sourceMappingURL=out.js.map
34
- //# sourceMappingURL=chunk-LNAIMEB2.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/base-copilot-textarea/render-element.tsx"],"names":[],"mappings":";;;;;;AAUe,cAkBX,YAlBW;AANR,SAAS,0BACd,kBACuB;AACvB,SAAO,CAAC,UAA8B;AACpC,YAAQ,MAAM,QAAQ,MAAM;AAAA,MAC1B,KAAK;AACH,eAAO,oBAAC,mCAAmB,MAAO;AAAA,MACpC,KAAK;AACH,eACE,oBAAC,oDAAsB,QAAtB;AAAA,UAA6B;AAAA,UAAoC;AAAA,IAExE;AAAA,EACF;AACF;AAEA,IAAM,iBAAiB,CAAC,UAA8B;AACpD,SAAO,oBAAC,wCAAQ,MAAM,aAAd;AAAA,IAA2B,gBAAM;AAAA,IAAS;AACpD;AACA,IAAM,oBAAoB,CACxB,UAGG;AACH,SACE,qBAAC,yCACK,MAAM,aADX;AAAA,IAEC,OAAO,mBACF,MAAM;AAAA,IAEX,iBAAiB;AAAA,IAEhB;AAAA,YAAM;AAAA,MACN,MAAM,QAAQ,SAAS,gBAAgB,MAAM,QAAQ;AAAA;AAAA,IACxD;AAEJ","sourcesContent":["import { RenderElementProps } from \"slate-react\";\n\nexport type RenderElementFunction = (props: RenderElementProps) => JSX.Element;\n\nexport function makeRenderElementFunction(\n suggestionsStyle: React.CSSProperties\n): RenderElementFunction {\n return (props: RenderElementProps) => {\n switch (props.element.type) {\n case \"paragraph\":\n return <DefaultElement {...props} />;\n case \"suggestion\":\n return (\n <SuggestionElement {...props} suggestionsStyle={suggestionsStyle} />\n );\n }\n };\n}\n\nconst DefaultElement = (props: RenderElementProps) => {\n return <div {...props.attributes}>{props.children}</div>;\n};\nconst SuggestionElement = (\n props: RenderElementProps & {\n suggestionsStyle: React.CSSProperties;\n }\n) => {\n return (\n <span\n {...props.attributes}\n style={{\n ...props.suggestionsStyle,\n }}\n contentEditable={false}\n >\n {props.children /* https://github.com/ianstormtaylor/slate/issues/3930 */}\n {props.element.type === \"suggestion\" && props.element.content}\n </span>\n );\n};\n"]}
@@ -1,3 +0,0 @@
1
-
2
- //# sourceMappingURL=out.js.map
3
- //# sourceMappingURL=chunk-MMVDU6DF.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,59 +0,0 @@
1
- import { useEffect } from 'react';
2
-
3
- // src/components/base-copilot-textarea/use-add-branding-css.tsx
4
- function useAddBrandingCss(suggestionStyleAugmented, disableBranding) {
5
- const cssSelector = ".copilot-textarea.with-branding";
6
- useEffect(() => {
7
- if (disableBranding) {
8
- return;
9
- }
10
- const styleEl = document.createElement("style");
11
- styleEl.id = "dynamic-styles";
12
- let dynamicStyles = Object.entries(suggestionStyleAugmented).map(([key, value]) => {
13
- const kebabCaseKey = key.replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, "$1-$2").toLowerCase();
14
- return `${kebabCaseKey}: ${value};`;
15
- }).join(" ");
16
- dynamicStyles += `font-style: normal; font-size: x-small;`;
17
- dynamicStyles += `content: "CopilotKit";`;
18
- dynamicStyles += `bottom: 6px;`;
19
- dynamicStyles += `right: 6px;`;
20
- dynamicStyles += `pointer-events: none;`;
21
- dynamicStyles += `font-weight: 200;`;
22
- dynamicStyles += `padding: 0;`;
23
- dynamicStyles += `margin: 0;`;
24
- dynamicStyles += `border: 0;`;
25
- dynamicStyles += `line-height: 1;`;
26
- dynamicStyles += `position: absolute;`;
27
- styleEl.innerHTML = `
28
- ${cssSelector}::after {
29
- ${dynamicStyles}
30
- }
31
- `;
32
- document.head.appendChild(styleEl);
33
- const textarea = document.querySelector(cssSelector);
34
- const handleScroll = () => {
35
- const styleEl2 = document.getElementById("dynamic-styles");
36
- if (styleEl2 && textarea) {
37
- const offsetFromBottom = -textarea.scrollTop + 6;
38
- const offsetFromRight = -textarea.scrollLeft + 6;
39
- styleEl2.innerHTML = `
40
- ${cssSelector}::after {
41
- ${dynamicStyles}
42
- bottom: ${offsetFromBottom}px;
43
- right: ${offsetFromRight}px;
44
- }
45
- `;
46
- }
47
- };
48
- textarea == null ? void 0 : textarea.addEventListener("scroll", handleScroll);
49
- return () => {
50
- var _a;
51
- (_a = document.getElementById("dynamic-styles")) == null ? void 0 : _a.remove();
52
- textarea == null ? void 0 : textarea.removeEventListener("scroll", handleScroll);
53
- };
54
- }, [disableBranding, suggestionStyleAugmented]);
55
- }
56
-
57
- export { useAddBrandingCss };
58
- //# sourceMappingURL=out.js.map
59
- //# sourceMappingURL=chunk-MPME5BW2.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/base-copilot-textarea/use-add-branding-css.tsx"],"names":["styleEl"],"mappings":";AAAA,SAAS,iBAAiB;AAEnB,SAAS,kBACd,0BACA,iBACA;AACA,QAAM,cAAc;AACpB,YAAU,MAAM;AACd,QAAI,iBAAiB;AACnB;AAAA,IACF;AAIA,UAAM,UAAU,SAAS,cAAc,OAAO;AAC9C,YAAQ,KAAK;AAGb,QAAI,gBAAgB,OAAO,QAAQ,wBAAwB,EACxD,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AACrB,YAAM,eAAe,IAClB,QAAQ,gCAAgC,OAAO,EAC/C,YAAY;AACf,aAAO,GAAG,iBAAiB;AAAA,IAC7B,CAAC,EACA,KAAK,GAAG;AAGX,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AACjB,qBAAiB;AAGjB,YAAQ,YAAY;AAAA,QAChB;AAAA,UACE;AAAA;AAAA;AAIN,aAAS,KAAK,YAAY,OAAO;AAIjC,UAAM,WAAW,SAAS,cAAc,WAAW;AACnD,UAAM,eAAe,MAAM;AACzB,YAAMA,WAAU,SAAS,eAAe,gBAAgB;AACxD,UAAIA,YAAW,UAAU;AACvB,cAAM,mBAAmB,CAAC,SAAS,YAAY;AAC/C,cAAM,kBAAkB,CAAC,SAAS,aAAa;AAC/C,QAAAA,SAAQ,YAAY;AAAA,YAChB;AAAA,cACE;AAAA,sBACQ;AAAA,qBACD;AAAA;AAAA;AAAA,MAGf;AAAA,IACF;AAEA,yCAAU,iBAAiB,UAAU;AAGrC,WAAO,MAAM;AAtEjB;AAuEM,qBAAS,eAAe,gBAAgB,MAAxC,mBAA2C;AAC3C,2CAAU,oBAAoB,UAAU;AAAA,IAC1C;AAAA,EACF,GAAG,CAAC,iBAAiB,wBAAwB,CAAC;AAChD","sourcesContent":["import { useEffect } from \"react\";\n\nexport function useAddBrandingCss(\n suggestionStyleAugmented: React.CSSProperties,\n disableBranding: boolean | undefined\n) {\n const cssSelector = \".copilot-textarea.with-branding\";\n useEffect(() => {\n if (disableBranding) {\n return;\n }\n\n // ---\n // 1: Add the CSS to the DOM\n const styleEl = document.createElement(\"style\");\n styleEl.id = \"dynamic-styles\";\n\n // Build the CSS string dynamically\n let dynamicStyles = Object.entries(suggestionStyleAugmented)\n .map(([key, value]) => {\n const kebabCaseKey = key\n .replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, \"$1-$2\")\n .toLowerCase();\n return `${kebabCaseKey}: ${value};`;\n })\n .join(\" \");\n\n // Append overrides for italics and font-size\n dynamicStyles += `font-style: normal; font-size: x-small;`;\n dynamicStyles += `content: \"CopilotKit\";`;\n dynamicStyles += `bottom: 6px;`;\n dynamicStyles += `right: 6px;`;\n dynamicStyles += `pointer-events: none;`;\n dynamicStyles += `font-weight: 200;`;\n dynamicStyles += `padding: 0;`;\n dynamicStyles += `margin: 0;`;\n dynamicStyles += `border: 0;`;\n dynamicStyles += `line-height: 1;`;\n dynamicStyles += `position: absolute;`;\n\n // Append it to the ::after class\n styleEl.innerHTML = `\n ${cssSelector}::after {\n ${dynamicStyles}\n }\n `;\n\n document.head.appendChild(styleEl);\n\n // ---\n // 2: Add the scroll listener (to keep the branding in the bottom right as the textarea scrolls)\n const textarea = document.querySelector(cssSelector);\n const handleScroll = () => {\n const styleEl = document.getElementById(\"dynamic-styles\");\n if (styleEl && textarea) {\n const offsetFromBottom = -textarea.scrollTop + 6;\n const offsetFromRight = -textarea.scrollLeft + 6;\n styleEl.innerHTML = `\n ${cssSelector}::after {\n ${dynamicStyles}\n bottom: ${offsetFromBottom}px;\n right: ${offsetFromRight}px;\n }\n `;\n }\n };\n\n textarea?.addEventListener(\"scroll\", handleScroll);\n\n // Cleanup\n return () => {\n document.getElementById(\"dynamic-styles\")?.remove();\n textarea?.removeEventListener(\"scroll\", handleScroll);\n };\n }, [disableBranding, suggestionStyleAugmented]);\n}\n"]}
@@ -1,55 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- var __async = (__this, __arguments, generator) => {
33
- return new Promise((resolve, reject) => {
34
- var fulfilled = (value) => {
35
- try {
36
- step(generator.next(value));
37
- } catch (e) {
38
- reject(e);
39
- }
40
- };
41
- var rejected = (value) => {
42
- try {
43
- step(generator.throw(value));
44
- } catch (e) {
45
- reject(e);
46
- }
47
- };
48
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
49
- step((generator = generator.apply(__this, __arguments)).next());
50
- });
51
- };
52
-
53
- export { __async, __objRest, __spreadProps, __spreadValues };
54
- //# sourceMappingURL=out.js.map
55
- //# sourceMappingURL=chunk-MRXNTQOX.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -1,17 +0,0 @@
1
- import { useEffect } from 'react';
2
-
3
- // src/hooks/misc/use-autosize-textarea.tsx
4
- var useAutosizeTextArea = (textAreaRef, value) => {
5
- useEffect(() => {
6
- if (textAreaRef.current !== null) {
7
- textAreaRef.current.style.height = "0px";
8
- const scrollHeight = textAreaRef.current.scrollHeight;
9
- textAreaRef.current.style.height = scrollHeight + "px";
10
- }
11
- }, [textAreaRef, value]);
12
- };
13
- var use_autosize_textarea_default = useAutosizeTextArea;
14
-
15
- export { use_autosize_textarea_default };
16
- //# sourceMappingURL=out.js.map
17
- //# sourceMappingURL=chunk-ND5PXTAW.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/hooks/misc/use-autosize-textarea.tsx"],"names":[],"mappings":";AAAA,SAAyB,iBAAiB;AAG1C,IAAM,sBAAsB,CAC1B,aACA,UACG;AACH,YAAU,MAAM;AACd,QAAI,YAAY,YAAY,MAAM;AAEhC,kBAAY,QAAQ,MAAM,SAAS;AACnC,YAAM,eAAe,YAAY,QAAQ;AAIzC,kBAAY,QAAQ,MAAM,SAAS,eAAe;AAAA,IACpD;AAAA,EACF,GAAG,CAAC,aAAa,KAAK,CAAC;AACzB;AAEA,IAAO,gCAAQ","sourcesContent":["import { Ref, RefObject, useEffect } from \"react\";\n\n// Updates the height of a <textarea> when the value changes.\nconst useAutosizeTextArea = (\n textAreaRef: RefObject<HTMLTextAreaElement>,\n value: string\n) => {\n useEffect(() => {\n if (textAreaRef.current !== null) {\n // We need to reset the height momentarily to get the correct scrollHeight for the textarea\n textAreaRef.current.style.height = \"0px\";\n const scrollHeight = textAreaRef.current.scrollHeight;\n\n // We then set the height directly, outside of the render loop\n // Trying to set this with state or a ref will product an incorrect value.\n textAreaRef.current.style.height = scrollHeight + \"px\";\n }\n }, [textAreaRef, value]);\n};\n\nexport default useAutosizeTextArea;\n"]}
@@ -1,201 +0,0 @@
1
- import { addAutocompletionsToEditor } from './chunk-WJYQWL4I.mjs';
2
- import { clearAutocompletionsFromEditor } from './chunk-F3MHL6ZY.mjs';
3
- import { HoveringToolbar } from './chunk-U5AJ5PBH.mjs';
4
- import { useHoveringEditorContext, HoveringEditorProvider } from './chunk-YW3REYX6.mjs';
5
- import { makeRenderElementFunction } from './chunk-LNAIMEB2.mjs';
6
- import { makeRenderPlaceholderFunction } from './chunk-OELUUJZY.mjs';
7
- import { TrackerTextEditedSinceLastCursorMovement } from './chunk-OD7ZMOVE.mjs';
8
- import { useAddBrandingCss } from './chunk-MPME5BW2.mjs';
9
- import { defaultBaseAutosuggestionsConfig } from './chunk-D7SEV5PR.mjs';
10
- import { useAutosuggestions } from './chunk-UHD44NC5.mjs';
11
- import { useCopilotTextareaEditor } from './chunk-CSGFJU3L.mjs';
12
- import { usePopulateCopilotTextareaRef } from './chunk-YQU7WG7T.mjs';
13
- import { replaceEditorText } from './chunk-RQHOUUXQ.mjs';
14
- import { getTextAroundCollapsedCursor, getFullEditorTextWithNewlines } from './chunk-IXJ2HCOA.mjs';
15
- import { __spreadValues, __objRest, __spreadProps } from './chunk-MRXNTQOX.mjs';
16
- import React, { useMemo, useState, useCallback, useEffect } from 'react';
17
- import { Editor } from 'slate';
18
- import { Slate, Editable } from 'slate-react';
19
- import { twMerge } from 'tailwind-merge';
20
- import { jsxs, jsx } from 'react/jsx-runtime';
21
-
22
- var BaseCopilotTextareaWithHoveringContext = React.forwardRef(
23
- (props, ref) => {
24
- const autosuggestionsConfig = __spreadValues(__spreadValues({}, defaultBaseAutosuggestionsConfig), props.baseAutosuggestionsConfig);
25
- const valueOnInitialRender = useMemo(() => {
26
- var _a2;
27
- return (_a2 = props.value) != null ? _a2 : "";
28
- }, []);
29
- const [lastKnownFullEditorText, setLastKnownFullEditorText] = useState(valueOnInitialRender);
30
- const [cursorMovedSinceLastTextChange, setCursorMovedSinceLastTextChange] = useState(false);
31
- const initialValue = useMemo(() => {
32
- return [
33
- {
34
- type: "paragraph",
35
- children: [{ text: valueOnInitialRender }]
36
- }
37
- ];
38
- }, [valueOnInitialRender]);
39
- const editor = useCopilotTextareaEditor();
40
- const {
41
- isDisplayed: hoveringEditorIsDisplayed,
42
- setIsDisplayed: setHoveringEditorIsDisplayed
43
- } = useHoveringEditorContext();
44
- const insertText = useCallback(
45
- (autosuggestion) => {
46
- Editor.insertText(editor, autosuggestion.text, {
47
- at: autosuggestion.point
48
- });
49
- },
50
- [editor]
51
- );
52
- const {
53
- currentAutocompleteSuggestion,
54
- onChangeHandler: onChangeHandlerForAutocomplete,
55
- onKeyDownHandler: onKeyDownHandlerForAutocomplete
56
- } = useAutosuggestions(
57
- autosuggestionsConfig.debounceTime,
58
- autosuggestionsConfig.acceptAutosuggestionKey,
59
- autosuggestionsConfig.apiConfig.autosuggestionsFunction,
60
- insertText,
61
- autosuggestionsConfig.disableWhenEmpty,
62
- autosuggestionsConfig.disabled || hoveringEditorIsDisplayed || cursorMovedSinceLastTextChange && autosuggestionsConfig.temporarilyDisableWhenMovingCursorWithoutChangingText
63
- );
64
- const onKeyDownHandlerForHoveringEditor = useCallback(
65
- (event) => {
66
- if (event.key === "k" && event.metaKey) {
67
- event.preventDefault();
68
- setHoveringEditorIsDisplayed(!hoveringEditorIsDisplayed);
69
- }
70
- },
71
- [hoveringEditorIsDisplayed, setHoveringEditorIsDisplayed]
72
- );
73
- useEffect(() => {
74
- clearAutocompletionsFromEditor(editor);
75
- if (currentAutocompleteSuggestion) {
76
- addAutocompletionsToEditor(
77
- editor,
78
- currentAutocompleteSuggestion.text,
79
- currentAutocompleteSuggestion.point
80
- );
81
- }
82
- }, [currentAutocompleteSuggestion]);
83
- const suggestionStyleAugmented = useMemo(() => {
84
- return __spreadValues({
85
- fontStyle: "italic",
86
- color: "gray"
87
- }, props.suggestionsStyle);
88
- }, [props.suggestionsStyle]);
89
- const renderElementMemoized = useMemo(() => {
90
- return makeRenderElementFunction(suggestionStyleAugmented);
91
- }, [suggestionStyleAugmented]);
92
- const renderPlaceholderMemoized = useMemo(() => {
93
- const placeholderStyleSlatejsOverrides = {
94
- top: void 0
95
- };
96
- const placeholderStyleAugmented = __spreadValues(__spreadValues({}, placeholderStyleSlatejsOverrides), props.placeholderStyle);
97
- return makeRenderPlaceholderFunction(placeholderStyleAugmented);
98
- }, [props.placeholderStyle]);
99
- useEffect(() => {
100
- var _a2, _b;
101
- if (props.value === lastKnownFullEditorText) {
102
- return;
103
- }
104
- setLastKnownFullEditorText((_a2 = props.value) != null ? _a2 : "");
105
- replaceEditorText(editor, (_b = props.value) != null ? _b : "");
106
- }, [props.value]);
107
- const _a = props, {
108
- placeholderStyle,
109
- value,
110
- onValueChange,
111
- baseAutosuggestionsConfig: autosuggestionsConfigFromProps,
112
- className,
113
- onChange,
114
- onKeyDown,
115
- disableBranding
116
- } = _a, propsToForward = __objRest(_a, [
117
- "placeholderStyle",
118
- "value",
119
- "onValueChange",
120
- "baseAutosuggestionsConfig",
121
- "className",
122
- "onChange",
123
- "onKeyDown",
124
- "disableBranding"
125
- ]);
126
- useAddBrandingCss(suggestionStyleAugmented, disableBranding);
127
- usePopulateCopilotTextareaRef(editor, ref);
128
- const moddedClassName = (() => {
129
- const baseClassName = "copilot-textarea";
130
- const brandingClass = disableBranding ? "no-branding" : "with-branding";
131
- const defaultTailwindClassName = "bg-white overflow-y-auto resize-y";
132
- const mergedClassName = twMerge(
133
- defaultTailwindClassName,
134
- className != null ? className : ""
135
- );
136
- return `${baseClassName} ${brandingClass} ${mergedClassName}`;
137
- })();
138
- return /* @__PURE__ */ jsxs(Slate, {
139
- editor,
140
- initialValue,
141
- onChange: (value2) => {
142
- var _a2, _b;
143
- const newEditorState = getTextAroundCollapsedCursor(editor);
144
- const fullEditorText = newEditorState ? newEditorState.textBeforeCursor + newEditorState.textAfterCursor : getFullEditorTextWithNewlines(editor);
145
- setLastKnownFullEditorText((prev) => {
146
- if (prev !== fullEditorText) {
147
- setCursorMovedSinceLastTextChange(false);
148
- }
149
- return fullEditorText;
150
- });
151
- onChangeHandlerForAutocomplete(newEditorState);
152
- (_a2 = props.onValueChange) == null ? void 0 : _a2.call(props, fullEditorText);
153
- (_b = props.onChange) == null ? void 0 : _b.call(props, makeSemiFakeReactTextAreaEvent(fullEditorText));
154
- },
155
- children: [
156
- /* @__PURE__ */ jsx(TrackerTextEditedSinceLastCursorMovement, {
157
- setCursorMovedSinceLastTextChange
158
- }),
159
- /* @__PURE__ */ jsx(HoveringToolbar, {
160
- apiConfig: autosuggestionsConfig.apiConfig
161
- }),
162
- /* @__PURE__ */ jsx(Editable, __spreadValues({
163
- renderElement: renderElementMemoized,
164
- renderPlaceholder: renderPlaceholderMemoized,
165
- onKeyDown: (event) => {
166
- var _a2;
167
- onKeyDownHandlerForHoveringEditor(event);
168
- onKeyDownHandlerForAutocomplete(event);
169
- (_a2 = props.onKeyDown) == null ? void 0 : _a2.call(props, event);
170
- },
171
- className: moddedClassName
172
- }, propsToForward))
173
- ]
174
- });
175
- }
176
- );
177
- function makeSemiFakeReactTextAreaEvent(currentText) {
178
- return {
179
- target: {
180
- value: currentText,
181
- type: "copilot-textarea"
182
- },
183
- currentTarget: {
184
- value: currentText,
185
- type: "copilot-textarea"
186
- }
187
- };
188
- }
189
- var BaseCopilotTextarea = React.forwardRef(
190
- (props, ref) => {
191
- return /* @__PURE__ */ jsx(HoveringEditorProvider, {
192
- children: /* @__PURE__ */ jsx(BaseCopilotTextareaWithHoveringContext, __spreadProps(__spreadValues({}, props), {
193
- ref
194
- }))
195
- });
196
- }
197
- );
198
-
199
- export { BaseCopilotTextarea };
200
- //# sourceMappingURL=out.js.map
201
- //# sourceMappingURL=chunk-NKA6K7FW.mjs.map