@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,501 +0,0 @@
1
- import { Command, CommandInput, CommandList, CommandEmpty, CommandGroup, CommandItem, CommandSeparator } from './chunk-XA7M72ZO.mjs';
2
- import { Label } from './chunk-5EJ5XOGP.mjs';
3
- import { Button } from './chunk-2NURR2DX.mjs';
4
- import { use_autosize_textarea_default } from './chunk-ND5PXTAW.mjs';
5
- import { streamPromiseFlatten } from './chunk-FN7GDKKG.mjs';
6
- import { __objRest, __spreadProps, __spreadValues, __async } from './chunk-MRXNTQOX.mjs';
7
- import { useState, useRef, useEffect } from 'react';
8
- import { Calendar, Smile, Calculator } from 'lucide-react';
9
- import Chip from '@mui/material/Chip';
10
- import Avatar from '@mui/material/Avatar';
11
- import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
12
-
13
- var HoveringInsertionPromptBoxCore = ({ performInsertion, state, insertionOrEditingFunction }) => {
14
- const [editSuggestion, setEditSuggestion] = useState("");
15
- const [suggestionIsLoading, setSuggestionIsLoading] = useState(false);
16
- const [adjustmentPrompt, setAdjustmentPrompt] = useState("");
17
- const [generatingSuggestion, setGeneratingSuggestion] = useState(null);
18
- const adjustmentTextAreaRef = useRef(null);
19
- const suggestionTextAreaRef = useRef(null);
20
- const [filePointers, setFilePointers] = useState([]);
21
- use_autosize_textarea_default(suggestionTextAreaRef, editSuggestion || "");
22
- use_autosize_textarea_default(adjustmentTextAreaRef, adjustmentPrompt || "");
23
- useEffect(() => {
24
- var _a;
25
- (_a = adjustmentTextAreaRef.current) == null ? void 0 : _a.focus();
26
- }, []);
27
- useEffect(() => {
28
- if (!generatingSuggestion) {
29
- return;
30
- }
31
- if (generatingSuggestion.locked) {
32
- return;
33
- }
34
- setEditSuggestion("");
35
- const reader = generatingSuggestion.getReader();
36
- const read = () => __async(void 0, null, function* () {
37
- setSuggestionIsLoading(true);
38
- while (true) {
39
- const { done, value } = yield reader.read();
40
- if (done) {
41
- break;
42
- }
43
- setEditSuggestion((prev) => {
44
- const newSuggestion = prev + value;
45
- if (suggestionTextAreaRef.current) {
46
- suggestionTextAreaRef.current.scrollTop = suggestionTextAreaRef.current.scrollHeight;
47
- }
48
- return newSuggestion;
49
- });
50
- }
51
- setSuggestionIsLoading(false);
52
- });
53
- read();
54
- return () => {
55
- const releaseLockIfNotClosed = () => __async(void 0, null, function* () {
56
- try {
57
- yield reader.closed;
58
- } catch (e) {
59
- reader.releaseLock();
60
- }
61
- });
62
- releaseLockIfNotClosed();
63
- };
64
- }, [generatingSuggestion]);
65
- const begingGeneratingAdjustment = () => __async(void 0, null, function* () {
66
- if (!adjustmentPrompt.trim()) {
67
- return;
68
- }
69
- let editorState = state.editorState;
70
- if (editSuggestion !== "") {
71
- editorState.selectedText = editSuggestion;
72
- }
73
- const adjustmentSuggestionTextStreamPromise = insertionOrEditingFunction(
74
- editorState,
75
- adjustmentPrompt,
76
- new AbortController().signal
77
- );
78
- const adjustmentSuggestionTextStream = streamPromiseFlatten(
79
- adjustmentSuggestionTextStreamPromise
80
- );
81
- setGeneratingSuggestion(adjustmentSuggestionTextStream);
82
- });
83
- const isLoading = suggestionIsLoading;
84
- const textToEdit = editSuggestion || state.editorState.selectedText;
85
- const adjustmentLabel = textToEdit === "" ? "Describe the text you want to insert" : "Describe adjustments to the suggested text";
86
- const placeholder = textToEdit === "" ? "e.g. 'summarize the client's top 3 pain-points from @CallTranscript'" : "e.g. 'make it more formal', 'be more specific', ...";
87
- const AdjustmentPromptComponent = /* @__PURE__ */ jsxs(Fragment, {
88
- children: [
89
- /* @__PURE__ */ jsx(Label, {
90
- className: "",
91
- children: adjustmentLabel
92
- }),
93
- /* @__PURE__ */ jsxs("div", {
94
- className: "relative w-full flex items-center",
95
- children: [
96
- /* @__PURE__ */ jsx("textarea", {
97
- disabled: suggestionIsLoading,
98
- ref: adjustmentTextAreaRef,
99
- value: adjustmentPrompt,
100
- onChange: (e) => setAdjustmentPrompt(e.target.value),
101
- onKeyDown: (e) => {
102
- if (e.key === "Enter" && e.shiftKey) {
103
- e.preventDefault();
104
- setAdjustmentPrompt(adjustmentPrompt + "\n");
105
- } else if (e.key === "Enter") {
106
- e.preventDefault();
107
- begingGeneratingAdjustment();
108
- }
109
- },
110
- placeholder,
111
- style: { minHeight: "3rem" },
112
- className: "w-full bg-slate-100 h-auto h-min-14 text-sm p-2 rounded-md resize-none overflow-visible focus:outline-none focus:ring-0 focus:border-non pr-[3rem]",
113
- rows: 1
114
- }),
115
- /* @__PURE__ */ jsx("button", {
116
- onClick: begingGeneratingAdjustment,
117
- className: "absolute right-2 bg-blue-500 text-white w-8 h-8 rounded-full flex items-center justify-center",
118
- children: /* @__PURE__ */ jsx("i", {
119
- className: "material-icons",
120
- children: "arrow_forward"
121
- })
122
- })
123
- ]
124
- })
125
- ]
126
- });
127
- const SuggestionComponent = /* @__PURE__ */ jsxs(Fragment, {
128
- children: [
129
- /* @__PURE__ */ jsxs("div", {
130
- className: "flex justify-between items-end w-full",
131
- children: [
132
- /* @__PURE__ */ jsx(Label, {
133
- className: "mt-4",
134
- children: "Suggested:"
135
- }),
136
- /* @__PURE__ */ jsx("div", {
137
- className: "ml-auto",
138
- children: isLoading && /* @__PURE__ */ jsx("div", {
139
- className: "flex justify-center items-center",
140
- children: /* @__PURE__ */ jsx("div", {
141
- className: "inline-block h-4 w-4 animate-spin rounded-full border-4 border-solid border-current border-r-transparent align-[-0.125em] motion-reduce:animate-[spin_1.5s_linear_infinite]",
142
- role: "status",
143
- children: /* @__PURE__ */ jsx("span", {
144
- className: "!absolute !-m-px !h-px !w-px !overflow-hidden !whitespace-nowrap !border-0 !p-0 ![clip:rect(0,0,0,0)]",
145
- children: "Loading..."
146
- })
147
- })
148
- })
149
- })
150
- ]
151
- }),
152
- /* @__PURE__ */ jsx("textarea", {
153
- ref: suggestionTextAreaRef,
154
- value: editSuggestion,
155
- disabled: suggestionIsLoading,
156
- onChange: (e) => setEditSuggestion(e.target.value),
157
- className: "w-full text-base p-2 border border-gray-300 rounded-md resize-none bg-green-50",
158
- style: { overflow: "auto", maxHeight: "10em" }
159
- })
160
- ]
161
- });
162
- const SubmitComponent = /* @__PURE__ */ jsx("div", {
163
- className: "flex w-full gap-4 justify-start",
164
- children: /* @__PURE__ */ jsxs(Button, {
165
- className: " bg-green-700 text-white",
166
- onClick: () => {
167
- performInsertion(editSuggestion);
168
- },
169
- children: [
170
- "Insert ",
171
- /* @__PURE__ */ jsx("i", {
172
- className: "material-icons",
173
- children: "check"
174
- })
175
- ]
176
- })
177
- });
178
- const sourceSearchCandidate = adjustmentPrompt.split(" ").pop();
179
- const sourceSearchWord = (sourceSearchCandidate == null ? void 0 : sourceSearchCandidate.startsWith("@")) ? sourceSearchCandidate.slice(1) : void 0;
180
- return /* @__PURE__ */ jsxs("div", {
181
- className: "w-full flex flex-col items-start relative gap-2",
182
- children: [
183
- AdjustmentPromptComponent,
184
- filePointers.length > 0 && /* @__PURE__ */ jsx(IncludedFilesPreview, {
185
- includedFiles: filePointers,
186
- setIncludedFiles: setFilePointers
187
- }),
188
- sourceSearchWord !== void 0 && /* @__PURE__ */ jsx(SourceSearchBox, {
189
- searchTerm: sourceSearchWord,
190
- recentFiles: mockFiles,
191
- onSelectedFile: (filePointer) => {
192
- var _a;
193
- setAdjustmentPrompt(
194
- adjustmentPrompt.replace(new RegExp(`@${sourceSearchWord}$`), "")
195
- );
196
- setFilePointers((prev) => [...prev, filePointer]);
197
- (_a = adjustmentTextAreaRef.current) == null ? void 0 : _a.focus();
198
- }
199
- }),
200
- generatingSuggestion ? SuggestionComponent : null,
201
- generatingSuggestion ? SubmitComponent : null
202
- ]
203
- });
204
- };
205
- var IncludedFilesPreview = ({
206
- includedFiles,
207
- setIncludedFiles
208
- }) => {
209
- return /* @__PURE__ */ jsxs("div", {
210
- className: "flex flex-col gap-2 mt-2",
211
- children: [
212
- /* @__PURE__ */ jsx(Label, {
213
- className: "",
214
- children: "Included context:"
215
- }),
216
- /* @__PURE__ */ jsx("div", {
217
- className: "flex flex-wrap gap-2",
218
- children: includedFiles.map((filePointer, index) => {
219
- return /* @__PURE__ */ jsx(FileChipPreview, {
220
- filePointer,
221
- onDelete: () => {
222
- setIncludedFiles(
223
- (prev) => prev.filter((fp) => fp !== filePointer)
224
- );
225
- }
226
- }, `file-${filePointer.sourceApplication}.${filePointer.name}`);
227
- })
228
- })
229
- ]
230
- });
231
- };
232
- var FileChipPreview = ({
233
- filePointer,
234
- onDelete
235
- }) => {
236
- return /* @__PURE__ */ jsx(Chip, {
237
- label: filePointer.name,
238
- onDelete,
239
- avatar: /* @__PURE__ */ jsx(Avatar, {
240
- sx: { backgroundColor: "transparent" },
241
- children: /* @__PURE__ */ jsx(IconForFilePointer, {
242
- filePointer,
243
- className: "w-4 h-1 object-contain"
244
- })
245
- })
246
- });
247
- };
248
- function IconForFilePointer({
249
- filePointer,
250
- className
251
- }) {
252
- if (filePointer.sourceApplication === "Salesforce") {
253
- return /* @__PURE__ */ jsx(IconSalesforce, {
254
- className
255
- });
256
- } else if (filePointer.sourceApplication === "GoogleDocs") {
257
- return /* @__PURE__ */ jsx(IconGoogleDocs, {
258
- className
259
- });
260
- } else {
261
- return /* @__PURE__ */ jsx(IconSalesforce, {
262
- className
263
- });
264
- }
265
- }
266
- function IconSalesforce(_a) {
267
- var _b = _a, props = __objRest(_b, ["className"]);
268
- return /* @__PURE__ */ jsxs("svg", __spreadProps(__spreadValues({
269
- xmlns: "http://www.w3.org/2000/svg",
270
- xmlnsXlink: "http://www.w3.org/1999/xlink",
271
- preserveAspectRatio: "xMidYMid meet",
272
- viewBox: "0 0 273 191"
273
- }, props), {
274
- children: [
275
- /* @__PURE__ */ jsx("title", {
276
- children: "Salesforce.com logo"
277
- }),
278
- /* @__PURE__ */ jsx("defs", {
279
- children: /* @__PURE__ */ jsx("path", {
280
- id: "a",
281
- d: "M.06.5h272v190H.06z"
282
- })
283
- }),
284
- /* @__PURE__ */ jsxs("g", {
285
- fillRule: "evenodd",
286
- children: [
287
- /* @__PURE__ */ jsx("mask", {
288
- id: "b",
289
- fill: "#fff",
290
- children: /* @__PURE__ */ jsx("use", {
291
- xlinkHref: "#a"
292
- })
293
- }),
294
- /* @__PURE__ */ jsx("path", {
295
- fill: "#00A1E0",
296
- d: "M113 21.3c8.78-9.14 21-14.8 34.5-14.8 18 0 33.6 10 42 24.9a58 58 0 0 1 23.7-5.05c32.4 0 58.7 26.5 58.7 59.2s-26.3 59.2-58.7 59.2c-3.96 0-7.82-.398-11.6-1.15-7.35 13.1-21.4 22-37.4 22a42.7 42.7 0 0 1-18.8-4.32c-7.45 17.5-24.8 29.8-45 29.8-21.1 0-39-13.3-45.9-32a45.1 45.1 0 0 1-9.34.972c-25.1 0-45.4-20.6-45.4-45.9 0-17 9.14-31.8 22.7-39.8a52.6 52.6 0 0 1-4.35-21c0-29.2 23.7-52.8 52.9-52.8 17.1 0 32.4 8.15 42 20.8",
297
- mask: "url(#b)"
298
- }),
299
- /* @__PURE__ */ jsx("path", {
300
- fill: "#FFFFFE",
301
- d: "M39.4 99.3c-.171.446.061.539.116.618.511.37 1.03.638 1.55.939 2.78 1.47 5.4 1.9 8.14 1.9 5.58 0 9.05-2.97 9.05-7.75v-.094c0-4.42-3.92-6.03-7.58-7.18l-.479-.155c-2.77-.898-5.16-1.68-5.16-3.5v-.093c0-1.56 1.4-2.71 3.56-2.71 2.4 0 5.26.799 7.09 1.81 0 0 .542.35.739-.173.107-.283 1.04-2.78 1.14-3.06.106-.293-.08-.514-.271-.628-2.1-1.28-5-2.15-8-2.15l-.557.002c-5.11 0-8.68 3.09-8.68 7.51v.095c0 4.66 3.94 6.18 7.62 7.23l.592.184c2.68.824 5 1.54 5 3.42v.094c0 1.73-1.51 3.02-3.93 3.02-.941 0-3.94-.016-7.19-2.07-.393-.229-.617-.394-.92-.579-.16-.097-.56-.272-.734.252l-1.1 3.06m81.7 0c-.171.446.061.539.118.618.509.37 1.03.638 1.55.939 2.78 1.47 5.4 1.9 8.14 1.9 5.58 0 9.05-2.97 9.05-7.75v-.094c0-4.42-3.91-6.03-7.58-7.18l-.479-.155c-2.77-.898-5.16-1.68-5.16-3.5v-.093c0-1.56 1.4-2.71 3.56-2.71 2.4 0 5.25.799 7.09 1.81 0 0 .542.35.74-.173.106-.283 1.04-2.78 1.13-3.06.107-.293-.08-.514-.27-.628-2.1-1.28-5-2.15-8-2.15l-.558.002c-5.11 0-8.68 3.09-8.68 7.51v.095c0 4.66 3.94 6.18 7.62 7.23l.591.184c2.69.824 5 1.54 5 3.42v.094c0 1.73-1.51 3.02-3.93 3.02-.943 0-3.95-.016-7.19-2.07-.393-.229-.623-.387-.921-.579-.101-.064-.572-.248-.733.252l-1.1 3.06m55.8-9.36c0 2.7-.504 4.83-1.49 6.34-.984 1.49-2.47 2.22-4.54 2.22s-3.55-.724-4.52-2.21c-.977-1.5-1.47-3.64-1.47-6.34 0-2.7.496-4.82 1.47-6.31.968-1.48 2.44-2.19 4.52-2.19s3.56.717 4.54 2.19c.992 1.49 1.49 3.61 1.49 6.31m4.66-5.01c-.459-1.55-1.17-2.91-2.12-4.05a10.151 10.151 0 0 0-3.58-2.72c-1.42-.665-3.1-1-5-1s-3.57.337-5 1c-1.42.664-2.63 1.58-3.58 2.72-.948 1.14-1.66 2.5-2.12 4.05-.455 1.54-.686 3.22-.686 5.01 0 1.79.231 3.47.686 5.01.457 1.55 1.17 2.91 2.12 4.05.951 1.14 2.16 2.05 3.58 2.7 1.43.648 3.11.978 5 .978 1.89 0 3.57-.33 4.99-.978 1.42-.648 2.63-1.56 3.58-2.7.949-1.14 1.66-2.5 2.12-4.05.454-1.54.685-3.22.685-5.01 0-1.78-.231-3.47-.685-5.01m38.3 12.8c-.153-.453-.595-.282-.595-.282-.677.259-1.4.499-2.17.619-.776.122-1.64.183-2.55.183-2.25 0-4.05-.671-5.33-2-1.29-1.33-2.01-3.47-2-6.37.007-2.64.645-4.62 1.79-6.14 1.13-1.5 2.87-2.28 5.17-2.28 1.92 0 3.39.223 4.93.705 0 0 .365.159.54-.322.409-1.13.711-1.94 1.15-3.18.124-.355-.18-.505-.291-.548-.604-.236-2.03-.623-3.11-.786-1.01-.154-2.18-.234-3.5-.234-1.96 0-3.7.335-5.19.999-1.49.663-2.75 1.58-3.75 2.72-1 1.14-1.76 2.5-2.27 4.05-.505 1.54-.76 3.23-.76 5.02 0 3.86 1.04 6.99 3.1 9.28 2.06 2.3 5.16 3.46 9.2 3.46 2.39 0 4.84-.483 6.6-1.18 0 0 .336-.162.19-.554l-1.15-3.16m8.15-10.4c.223-1.5.634-2.75 1.28-3.72.967-1.48 2.44-2.29 4.51-2.29s3.44.814 4.42 2.29c.65.975.934 2.27 1.04 3.72l-11.3-.002zm15.7-3.3c-.397-1.49-1.38-3-2.02-3.69-1.02-1.09-2.01-1.86-3-2.28a11.5 11.5 0 0 0-4.52-.917c-1.97 0-3.76.333-5.21 1.01-1.45.682-2.67 1.61-3.63 2.77-.959 1.16-1.68 2.53-2.14 4.1-.46 1.55-.692 3.25-.692 5.03 0 1.82.241 3.51.715 5.04.479 1.54 1.25 2.89 2.29 4.01 1.04 1.13 2.37 2.01 3.97 2.63 1.59.615 3.52.934 5.73.927 4.56-.015 6.96-1.03 7.94-1.58.175-.098.34-.267.134-.754l-1.03-2.89c-.158-.431-.594-.275-.594-.275-1.13.422-2.73 1.18-6.48 1.17-2.45-.004-4.26-.727-5.4-1.86-1.16-1.16-1.74-2.85-1.83-5.25l15.8.012s.416-.004.459-.41c.017-.168.541-3.24-.471-6.79zm-142 3.3c.223-1.5.635-2.75 1.28-3.72.968-1.48 2.44-2.29 4.51-2.29s3.44.814 4.42 2.29c.649.975.933 2.27 1.04 3.72l-11.3-.002zm15.7-3.3c-.396-1.49-1.38-3-2.02-3.69-1.02-1.09-2.01-1.86-3-2.28a11.5 11.5 0 0 0-4.52-.917c-1.97 0-3.76.333-5.21 1.01-1.45.682-2.67 1.61-3.63 2.77-.957 1.16-1.68 2.53-2.14 4.1-.459 1.55-.69 3.25-.69 5.03 0 1.82.239 3.51.716 5.04.478 1.54 1.25 2.89 2.28 4.01 1.04 1.13 2.37 2.01 3.97 2.63 1.59.615 3.51.934 5.73.927 4.56-.015 6.96-1.03 7.94-1.58.174-.098.34-.267.133-.754l-1.03-2.89c-.159-.431-.595-.275-.595-.275-1.13.422-2.73 1.18-6.48 1.17-2.44-.004-4.26-.727-5.4-1.86-1.16-1.16-1.74-2.85-1.83-5.25l15.8.012s.416-.004.459-.41c.017-.168.541-3.24-.472-6.79zm-49.8 13.6c-.619-.494-.705-.615-.91-.936-.313-.483-.473-1.17-.473-2.05 0-1.38.46-2.38 1.41-3.05-.01.002 1.36-1.18 4.58-1.14a32 32 0 0 1 4.28.365v7.17h.002s-2 .431-4.26.567c-3.21.193-4.63-.924-4.62-.921zm6.28-11.1c-.64-.047-1.47-.07-2.46-.07-1.35 0-2.66.168-3.88.498-1.23.332-2.34.846-3.29 1.53a7.63 7.63 0 0 0-2.29 2.6c-.559 1.04-.844 2.26-.844 3.64 0 1.4.243 2.61.723 3.6a6.54 6.54 0 0 0 2.06 2.47c.877.638 1.96 1.11 3.21 1.39 1.24.283 2.64.426 4.18.426 1.62 0 3.23-.136 4.79-.399a95.1 95.1 0 0 0 3.97-.772c.526-.121 1.11-.28 1.11-.28.39-.099.36-.516.36-.516l-.009-14.4c0-3.16-.844-5.51-2.51-6.96-1.66-1.45-4.09-2.18-7.24-2.18-1.18 0-3.09.16-4.23.389 0 0-3.44.668-4.86 1.78 0 0-.312.192-.142.627l1.12 3c.139.389.518.256.518.256s.119-.047.259-.13c3.03-1.65 6.87-1.6 6.87-1.6 1.7 0 3.02.345 3.9 1.02.861.661 1.3 1.66 1.3 3.76v.667c-1.35-.196-2.6-.309-2.6-.309zm127-8.13a.428.428 0 0 0-.237-.568c-.269-.102-1.61-.385-2.64-.449-1.98-.124-3.08.21-4.07.654-.978.441-2.06 1.15-2.66 1.97l-.002-1.92c0-.264-.187-.477-.453-.477h-4.04c-.262 0-.452.213-.452.477v23.5a.48.48 0 0 0 .479.479h4.14a.479.479 0 0 0 .478-.479v-11.8c0-1.58.174-3.15.521-4.14.342-.979.807-1.76 1.38-2.32a4.79 4.79 0 0 1 1.95-1.17 7.68 7.68 0 0 1 2.12-.298c.825 0 1.73.212 1.73.212.304.034.473-.152.576-.426.271-.721 1.04-2.88 1.19-3.31"
302
- }),
303
- /* @__PURE__ */ jsx("path", {
304
- fill: "#FFFFFE",
305
- d: "M162.201 67.548a13.258 13.258 0 0 0-1.559-.37 12.217 12.217 0 0 0-2.144-.166c-2.853 0-5.102.806-6.681 2.398-1.568 1.58-2.635 3.987-3.17 7.154l-.193 1.069h-3.581s-.437-.018-.529.459l-.588 3.28c-.041.314.094.51.514.508h3.486l-3.537 19.743c-.277 1.59-.594 2.898-.945 3.889-.346.978-.684 1.711-1.1 2.243-.403.515-.785.894-1.444 1.115-.544.183-1.17.267-1.856.267-.382 0-.89-.064-1.265-.139-.375-.074-.57-.158-.851-.276 0 0-.409-.156-.57.254-.131.335-1.06 2.89-1.17 3.206-.112.312.045.558.243.629.464.166.809.272 1.441.421.878.207 1.618.22 2.311.22 1.452 0 2.775-.204 3.872-.6 1.104-.399 2.065-1.094 2.915-2.035.919-1.015 1.497-2.078 2.05-3.528.547-1.437 1.013-3.221 1.386-5.3l3.554-20.109h5.196s.438.016.529-.459l.588-3.28c.041-.314-.093-.51-.515-.508h-5.043c.025-.114.254-1.888.833-3.558.247-.713.712-1.288 1.106-1.683a3.273 3.273 0 0 1 1.321-.822 5.48 5.48 0 0 1 1.693-.244c.475 0 .941.057 1.296.131.489.104.679.159.807.197.514.157.583.005.684-.244l1.206-3.312c.124-.356-.178-.506-.29-.55m-70.474 34.117c0 .264-.188.479-.452.479h-4.183c-.265 0-.453-.215-.453-.479V67.997c0-.263.188-.476.453-.476h4.183c.264 0 .452.213.452.476v33.668"
306
- })
307
- ]
308
- })
309
- ]
310
- }));
311
- }
312
- function IconGoogleDocs(_a) {
313
- var _b = _a, props = __objRest(_b, ["className"]);
314
- return /* @__PURE__ */ jsxs("svg", __spreadProps(__spreadValues({
315
- xmlns: "http://www.w3.org/2000/svg",
316
- xmlSpace: "preserve",
317
- viewBox: "0 0 64 88"
318
- }, props), {
319
- children: [
320
- /* @__PURE__ */ jsx("path", {
321
- d: "M58 88H6c-3.3 0-6-2.7-6-6V6c0-3.3 2.7-6 6-6h36l22 22v60c0 3.3-2.7 6-6 6z",
322
- style: {
323
- fill: "#3086f6"
324
- }
325
- }),
326
- /* @__PURE__ */ jsx("path", {
327
- d: "m42 0 22 22H42V0z",
328
- style: {
329
- fill: "#0c67d6"
330
- }
331
- }),
332
- /* @__PURE__ */ jsx("path", {
333
- d: "M50 39H14v-5h36v5zm0 7H14v5h36v-5zM40 58H14v5h26v-5z",
334
- style: {
335
- fill: "#fdffff"
336
- }
337
- })
338
- ]
339
- }));
340
- }
341
- var mockFiles = [
342
- {
343
- name: "CopilotTextarea README",
344
- sourceApplication: "GoogleDocs",
345
- getContents: () => __async(void 0, null, function* () {
346
- return "some contents";
347
- })
348
- },
349
- {
350
- name: "prospecting call transcript",
351
- sourceApplication: "Salesforce",
352
- getContents: () => __async(void 0, null, function* () {
353
- return "some contents";
354
- })
355
- },
356
- {
357
- name: "customer feedback",
358
- sourceApplication: "Zendesk",
359
- getContents: () => __async(void 0, null, function* () {
360
- return "some contents";
361
- })
362
- },
363
- {
364
- name: "product specifications",
365
- sourceApplication: "Google Docs",
366
- getContents: () => __async(void 0, null, function* () {
367
- return "some contents";
368
- })
369
- },
370
- {
371
- name: "meeting minutes",
372
- sourceApplication: "Microsoft Teams",
373
- getContents: () => __async(void 0, null, function* () {
374
- return "some contents";
375
- })
376
- },
377
- {
378
- name: "project plan",
379
- sourceApplication: "Trello",
380
- getContents: () => __async(void 0, null, function* () {
381
- return "some contents";
382
- })
383
- },
384
- {
385
- name: "code review comments",
386
- sourceApplication: "Github",
387
- getContents: () => __async(void 0, null, function* () {
388
- return "some contents";
389
- })
390
- }
391
- ];
392
- function SourceSearchBox(props) {
393
- const [selectedValue, setSelectedValue] = useState("");
394
- return /* @__PURE__ */ jsxs(Command, {
395
- className: "rounded-lg border shadow-md",
396
- value: selectedValue,
397
- onValueChange: (value) => {
398
- setSelectedValue(value);
399
- },
400
- filter: (value, search) => {
401
- if (props.searchTerm === "")
402
- return 1;
403
- if (value.startsWith(props.searchTerm))
404
- return 1;
405
- return 0;
406
- },
407
- children: [
408
- /* @__PURE__ */ jsx(CommandInput, {
409
- value: props.searchTerm,
410
- className: "rounded-t-lg hidden",
411
- placeholder: "Search for a command..."
412
- }),
413
- /* @__PURE__ */ jsxs(CommandList, {
414
- children: [
415
- /* @__PURE__ */ jsx(CommandEmpty, {
416
- children: "No results found."
417
- }),
418
- /* @__PURE__ */ jsx(CommandGroup, {
419
- heading: "Recents",
420
- children: props.recentFiles.map((filePointer) => {
421
- return /* @__PURE__ */ jsx(CommandItem, {
422
- value: filePointer.name,
423
- onSelect: (value) => {
424
- console.log(filePointer.name);
425
- props.onSelectedFile(filePointer);
426
- },
427
- children: /* @__PURE__ */ jsxs("div", {
428
- className: "flex flex-row gap-3 items-center",
429
- children: [
430
- /* @__PURE__ */ jsx(Logo, {
431
- size: "30px",
432
- children: /* @__PURE__ */ jsx(IconForFilePointer, {
433
- filePointer,
434
- className: "mx-auto my-auto"
435
- })
436
- }),
437
- filePointer.name
438
- ]
439
- })
440
- }, `word-${filePointer.sourceApplication}.${filePointer.name}`);
441
- })
442
- }),
443
- /* @__PURE__ */ jsxs(CommandGroup, {
444
- heading: "Suggestions",
445
- children: [
446
- /* @__PURE__ */ jsxs(CommandItem, {
447
- onSelect: (value) => {
448
- console.log(value);
449
- console.log(value);
450
- },
451
- children: [
452
- /* @__PURE__ */ jsx(Calendar, {
453
- className: "mr-2 h-4 w-4"
454
- }),
455
- /* @__PURE__ */ jsx("span", {
456
- children: "Calendar"
457
- })
458
- ]
459
- }),
460
- /* @__PURE__ */ jsxs(CommandItem, {
461
- children: [
462
- /* @__PURE__ */ jsx(Smile, {
463
- className: "mr-2 h-4 w-4"
464
- }),
465
- /* @__PURE__ */ jsx("span", {
466
- children: "Search Emoji"
467
- })
468
- ]
469
- }),
470
- /* @__PURE__ */ jsxs(CommandItem, {
471
- children: [
472
- /* @__PURE__ */ jsx(Calculator, {
473
- className: "mr-2 h-4 w-4"
474
- }),
475
- /* @__PURE__ */ jsx("span", {
476
- children: "Calculator"
477
- })
478
- ]
479
- })
480
- ]
481
- }),
482
- /* @__PURE__ */ jsx(CommandSeparator, {})
483
- ]
484
- })
485
- ]
486
- });
487
- }
488
- function Logo({
489
- children,
490
- size = "30px"
491
- }) {
492
- return /* @__PURE__ */ jsx("div", {
493
- className: "flex items-center justify-center",
494
- style: { width: size, height: size },
495
- children
496
- });
497
- }
498
-
499
- export { FileChipPreview, HoveringInsertionPromptBoxCore, IconForFilePointer, IncludedFilesPreview, Logo, SourceSearchBox };
500
- //# sourceMappingURL=out.js.map
501
- //# sourceMappingURL=chunk-XYXKONR4.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/source-search-box/source-search-box.tsx","../src/components/hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core.tsx"],"names":["useState","jsx","jsxs"],"mappings":"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","sourcesContent":["import { useState } from \"react\";\nimport {\n Command,\n CommandDialog,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n CommandSeparator,\n CommandShortcut,\n} from \"../ui/command\";\n\nimport {\n Calculator,\n Calendar,\n CreditCard,\n Settings,\n Smile,\n User,\n} from \"lucide-react\";\nimport { IconForFilePointer } from \"../hovering-toolbar/text-insertion-prompt-box/hovering-insertion-prompt-box-core\";\n\nexport interface FilePointer {\n name: string;\n sourceApplication: string;\n getContents: () => Promise<string>;\n}\n\nexport interface SourceSearchBoxProps {\n searchTerm: string;\n recentFiles: FilePointer[];\n onSelectedFile: (filePointer: FilePointer) => void;\n}\n\nexport function SourceSearchBox(props: SourceSearchBoxProps) {\n const [selectedValue, setSelectedValue] = useState<string>(\"\");\n\n return (\n <Command\n className=\"rounded-lg border shadow-md\"\n value={selectedValue}\n onValueChange={(value) => {\n setSelectedValue(value);\n }}\n filter={(value, search) => {\n // if the search term is empty, show all commands\n if (props.searchTerm === \"\") return 1;\n\n // if the search term is a prefix of the command, show it\n if (value.startsWith(props.searchTerm)) return 1;\n\n // otherwise, don't show it\n return 0;\n }}\n >\n <CommandInput\n value={props.searchTerm}\n className=\"rounded-t-lg hidden\"\n placeholder=\"Search for a command...\"\n />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n\n <CommandGroup heading=\"Recents\">\n {props.recentFiles.map((filePointer) => {\n return (\n <CommandItem\n key={`word-${filePointer.sourceApplication}.${filePointer.name}`}\n value={filePointer.name}\n onSelect={(value) => {\n console.log(filePointer.name);\n props.onSelectedFile(filePointer);\n }}\n >\n <div className=\"flex flex-row gap-3 items-center\">\n <Logo size=\"30px\">\n <IconForFilePointer\n filePointer={filePointer}\n className=\"mx-auto my-auto\"\n />\n </Logo>\n {filePointer.name}\n </div>\n </CommandItem>\n );\n })}\n </CommandGroup>\n\n <CommandGroup heading=\"Suggestions\">\n <CommandItem\n onSelect={(value) => {\n console.log(value);\n console.log(value);\n }}\n >\n <Calendar className=\"mr-2 h-4 w-4\" />\n <span>Calendar</span>\n </CommandItem>\n <CommandItem>\n <Smile className=\"mr-2 h-4 w-4\" />\n <span>Search Emoji</span>\n </CommandItem>\n <CommandItem>\n <Calculator className=\"mr-2 h-4 w-4\" />\n <span>Calculator</span>\n </CommandItem>\n </CommandGroup>\n <CommandSeparator />\n </CommandList>\n </Command>\n );\n}\n\nexport function Logo({\n children,\n size = \"30px\",\n}: {\n children: React.ReactNode;\n size?: string;\n}) {\n return (\n <div\n className=\"flex items-center justify-center\"\n style={{ width: size, height: size }}\n >\n {children}\n </div>\n );\n}\n","import useAutosizeTextArea from \"../../../hooks/misc/use-autosize-textarea\";\nimport { MinimalChatGPTMessage } from \"../../../types\";\nimport {\n EditingEditorState,\n Generator_InsertionOrEditingSuggestion,\n} from \"../../../types/base/autosuggestions-bare-function\";\nimport {\n FilePointer,\n SourceSearchBox,\n} from \"../../source-search-box/source-search-box\";\nimport { Button } from \"../../ui/button\";\nimport { Label } from \"../../ui/label\";\nimport React, { useEffect, useRef, useState } from \"react\";\n\nimport Chip from \"@mui/material/Chip\";\nimport Avatar from \"@mui/material/Avatar\";\nimport { streamPromiseFlatten } from \"../../../lib/stream-promise-flatten\";\n\nexport type SuggestionState = {\n editorState: EditingEditorState;\n};\n\nexport interface HoveringInsertionPromptBoxCoreProps {\n state: SuggestionState;\n performInsertion: (insertedText: string) => void;\n insertionOrEditingFunction: Generator_InsertionOrEditingSuggestion;\n}\n\nexport const HoveringInsertionPromptBoxCore: React.FC<\n HoveringInsertionPromptBoxCoreProps\n> = ({ performInsertion, state, insertionOrEditingFunction }) => {\n const [editSuggestion, setEditSuggestion] = useState<string>(\"\");\n const [suggestionIsLoading, setSuggestionIsLoading] =\n useState<boolean>(false);\n\n const [adjustmentPrompt, setAdjustmentPrompt] = useState<string>(\"\");\n\n const [generatingSuggestion, setGeneratingSuggestion] =\n useState<ReadableStream<string> | null>(null);\n\n const adjustmentTextAreaRef = useRef<HTMLTextAreaElement>(null);\n const suggestionTextAreaRef = useRef<HTMLTextAreaElement>(null);\n\n const [filePointers, setFilePointers] = useState<FilePointer[]>([]);\n\n useAutosizeTextArea(suggestionTextAreaRef, editSuggestion || \"\");\n useAutosizeTextArea(adjustmentTextAreaRef, adjustmentPrompt || \"\");\n\n // initially focus on the adjustment prompt text area\n useEffect(() => {\n adjustmentTextAreaRef.current?.focus();\n }, []);\n\n useEffect(() => {\n // if no generating suggestion, do nothing\n if (!generatingSuggestion) {\n return;\n }\n\n // Check if the stream is already locked (i.e. already reading from it)\n if (generatingSuggestion.locked) {\n return;\n }\n\n // reset the edit suggestion\n setEditSuggestion(\"\");\n\n // read the generating suggestion stream and continuously update the edit suggestion\n const reader = generatingSuggestion.getReader();\n\n const read = async () => {\n setSuggestionIsLoading(true);\n while (true) {\n const { done, value } = await reader.read();\n if (done) {\n break;\n }\n setEditSuggestion((prev) => {\n const newSuggestion = prev + value;\n\n // Scroll to the bottom of the textarea. We call this here to make sure scroll-to-bottom is synchronous with the state update.\n if (suggestionTextAreaRef.current) {\n suggestionTextAreaRef.current.scrollTop =\n suggestionTextAreaRef.current.scrollHeight;\n }\n return newSuggestion;\n });\n }\n\n setSuggestionIsLoading(false);\n };\n read();\n\n return () => {\n const releaseLockIfNotClosed = async () => {\n try {\n await reader.closed;\n } catch {\n reader.releaseLock();\n }\n };\n\n releaseLockIfNotClosed();\n };\n }, [generatingSuggestion]);\n\n const begingGeneratingAdjustment = async () => {\n // don't generate text if the prompt is empty\n if (!adjustmentPrompt.trim()) {\n return;\n }\n\n // if the current edit suggestion is not empty, then use it as the selected text instead of the editor state's selected text\n let editorState = state.editorState;\n if (editSuggestion !== \"\") {\n editorState.selectedText = editSuggestion;\n }\n\n const adjustmentSuggestionTextStreamPromise = insertionOrEditingFunction(\n editorState,\n adjustmentPrompt,\n new AbortController().signal\n );\n const adjustmentSuggestionTextStream = streamPromiseFlatten(\n adjustmentSuggestionTextStreamPromise\n );\n\n setGeneratingSuggestion(adjustmentSuggestionTextStream);\n };\n\n const isLoading = suggestionIsLoading;\n\n const textToEdit = editSuggestion || state.editorState.selectedText;\n const adjustmentLabel =\n textToEdit === \"\"\n ? \"Describe the text you want to insert\"\n : \"Describe adjustments to the suggested text\";\n const placeholder =\n textToEdit === \"\"\n ? \"e.g. 'summarize the client's top 3 pain-points from @CallTranscript'\"\n : \"e.g. 'make it more formal', 'be more specific', ...\";\n\n const AdjustmentPromptComponent = (\n <>\n <Label className=\"\">{adjustmentLabel}</Label>\n <div className=\"relative w-full flex items-center\">\n <textarea\n disabled={suggestionIsLoading}\n ref={adjustmentTextAreaRef}\n value={adjustmentPrompt}\n onChange={(e) => setAdjustmentPrompt(e.target.value)}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" && e.shiftKey) {\n e.preventDefault();\n setAdjustmentPrompt(adjustmentPrompt + \"\\n\");\n } else if (e.key === \"Enter\") {\n e.preventDefault();\n begingGeneratingAdjustment();\n }\n }}\n placeholder={placeholder}\n style={{ minHeight: \"3rem\" }}\n className=\"w-full bg-slate-100 h-auto h-min-14 text-sm p-2 rounded-md resize-none overflow-visible focus:outline-none focus:ring-0 focus:border-non pr-[3rem]\"\n rows={1}\n />\n <button\n onClick={begingGeneratingAdjustment}\n className=\"absolute right-2 bg-blue-500 text-white w-8 h-8 rounded-full flex items-center justify-center\"\n >\n <i className=\"material-icons\">arrow_forward</i>\n </button>\n </div>\n </>\n );\n\n const SuggestionComponent = (\n <>\n <div className=\"flex justify-between items-end w-full\">\n <Label className=\"mt-4\">Suggested:</Label>\n <div className=\"ml-auto\">\n {isLoading && (\n <div className=\"flex justify-center items-center\">\n <div\n className=\"inline-block h-4 w-4 animate-spin rounded-full border-4 border-solid border-current border-r-transparent align-[-0.125em] motion-reduce:animate-[spin_1.5s_linear_infinite]\"\n role=\"status\"\n >\n <span className=\"!absolute !-m-px !h-px !w-px !overflow-hidden !whitespace-nowrap !border-0 !p-0 ![clip:rect(0,0,0,0)]\">\n Loading...\n </span>\n </div>\n </div>\n )}\n </div>\n </div>\n <textarea\n ref={suggestionTextAreaRef}\n value={editSuggestion}\n disabled={suggestionIsLoading}\n onChange={(e) => setEditSuggestion(e.target.value)}\n className=\"w-full text-base p-2 border border-gray-300 rounded-md resize-none bg-green-50\"\n style={{ overflow: \"auto\", maxHeight: \"10em\" }}\n />\n </>\n );\n\n const SubmitComponent = (\n <div className=\"flex w-full gap-4 justify-start\">\n <Button\n className=\" bg-green-700 text-white\"\n onClick={() => {\n performInsertion(editSuggestion);\n }}\n >\n Insert <i className=\"material-icons\">check</i>\n </Button>\n </div>\n );\n\n // show source search if the last word in the adjustment prompt BEGINS with an @\n const sourceSearchCandidate = adjustmentPrompt.split(\" \").pop();\n // if the candidate is @someCandidate, then 'someCandidate', otherwise undefined\n const sourceSearchWord = sourceSearchCandidate?.startsWith(\"@\")\n ? sourceSearchCandidate.slice(1)\n : undefined;\n\n return (\n <div className=\"w-full flex flex-col items-start relative gap-2\">\n {AdjustmentPromptComponent}\n {filePointers.length > 0 && (\n <IncludedFilesPreview\n includedFiles={filePointers}\n setIncludedFiles={setFilePointers}\n />\n )}\n {sourceSearchWord !== undefined && (\n <SourceSearchBox\n searchTerm={sourceSearchWord}\n recentFiles={mockFiles}\n onSelectedFile={(filePointer) => {\n setAdjustmentPrompt(\n adjustmentPrompt.replace(new RegExp(`@${sourceSearchWord}$`), \"\")\n );\n setFilePointers((prev) => [...prev, filePointer]);\n\n // focus back on the adjustment prompt, and move the cursor to the end\n adjustmentTextAreaRef.current?.focus();\n }}\n />\n )}\n {generatingSuggestion ? SuggestionComponent : null}\n {generatingSuggestion ? SubmitComponent : null}\n </div>\n );\n};\n\ninterface IncludedFilesPreviewProps {\n includedFiles: FilePointer[];\n setIncludedFiles: React.Dispatch<React.SetStateAction<FilePointer[]>>;\n}\n\nexport const IncludedFilesPreview: React.FC<IncludedFilesPreviewProps> = ({\n includedFiles,\n setIncludedFiles,\n}) => {\n return (\n <div className=\"flex flex-col gap-2 mt-2\">\n <Label className=\"\">Included context:</Label>\n <div className=\"flex flex-wrap gap-2\">\n {includedFiles.map((filePointer, index) => {\n return (\n <FileChipPreview\n key={`file-${filePointer.sourceApplication}.${filePointer.name}`}\n filePointer={filePointer}\n onDelete={() => {\n setIncludedFiles((prev) =>\n prev.filter((fp) => fp !== filePointer)\n );\n }}\n />\n );\n })}\n </div>\n </div>\n );\n};\n\nexport interface FileChipPreviewProp {\n filePointer: FilePointer;\n onDelete: () => void;\n}\n\nexport const FileChipPreview: React.FC<FileChipPreviewProp> = ({\n filePointer,\n onDelete,\n}) => {\n return (\n <Chip\n label={filePointer.name}\n onDelete={onDelete}\n avatar={\n <Avatar sx={{ backgroundColor: \"transparent\" }}>\n <IconForFilePointer\n filePointer={filePointer}\n className=\"w-4 h-1 object-contain\"\n />\n </Avatar>\n }\n />\n );\n};\n\nexport function IconForFilePointer({\n filePointer,\n className,\n}: {\n filePointer: FilePointer;\n className: string;\n}): JSX.Element {\n if (filePointer.sourceApplication === \"Salesforce\") {\n return <IconSalesforce className={className} />;\n } else if (filePointer.sourceApplication === \"GoogleDocs\") {\n return <IconGoogleDocs className={className} />;\n } else {\n return <IconSalesforce className={className} />;\n }\n}\n\nfunction IconSalesforce({ className, ...props }: React.ComponentProps<\"svg\">) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlnsXlink=\"http://www.w3.org/1999/xlink\"\n preserveAspectRatio=\"xMidYMid meet\"\n viewBox=\"0 0 273 191\"\n {...props}\n >\n <title>{\"Salesforce.com logo\"}</title>\n <defs>\n <path id=\"a\" d=\"M.06.5h272v190H.06z\" />\n </defs>\n <g fillRule=\"evenodd\">\n <mask id=\"b\" fill=\"#fff\">\n <use xlinkHref=\"#a\" />\n </mask>\n <path\n fill=\"#00A1E0\"\n d=\"M113 21.3c8.78-9.14 21-14.8 34.5-14.8 18 0 33.6 10 42 24.9a58 58 0 0 1 23.7-5.05c32.4 0 58.7 26.5 58.7 59.2s-26.3 59.2-58.7 59.2c-3.96 0-7.82-.398-11.6-1.15-7.35 13.1-21.4 22-37.4 22a42.7 42.7 0 0 1-18.8-4.32c-7.45 17.5-24.8 29.8-45 29.8-21.1 0-39-13.3-45.9-32a45.1 45.1 0 0 1-9.34.972c-25.1 0-45.4-20.6-45.4-45.9 0-17 9.14-31.8 22.7-39.8a52.6 52.6 0 0 1-4.35-21c0-29.2 23.7-52.8 52.9-52.8 17.1 0 32.4 8.15 42 20.8\"\n mask=\"url(#b)\"\n />\n <path\n fill=\"#FFFFFE\"\n d=\"M39.4 99.3c-.171.446.061.539.116.618.511.37 1.03.638 1.55.939 2.78 1.47 5.4 1.9 8.14 1.9 5.58 0 9.05-2.97 9.05-7.75v-.094c0-4.42-3.92-6.03-7.58-7.18l-.479-.155c-2.77-.898-5.16-1.68-5.16-3.5v-.093c0-1.56 1.4-2.71 3.56-2.71 2.4 0 5.26.799 7.09 1.81 0 0 .542.35.739-.173.107-.283 1.04-2.78 1.14-3.06.106-.293-.08-.514-.271-.628-2.1-1.28-5-2.15-8-2.15l-.557.002c-5.11 0-8.68 3.09-8.68 7.51v.095c0 4.66 3.94 6.18 7.62 7.23l.592.184c2.68.824 5 1.54 5 3.42v.094c0 1.73-1.51 3.02-3.93 3.02-.941 0-3.94-.016-7.19-2.07-.393-.229-.617-.394-.92-.579-.16-.097-.56-.272-.734.252l-1.1 3.06m81.7 0c-.171.446.061.539.118.618.509.37 1.03.638 1.55.939 2.78 1.47 5.4 1.9 8.14 1.9 5.58 0 9.05-2.97 9.05-7.75v-.094c0-4.42-3.91-6.03-7.58-7.18l-.479-.155c-2.77-.898-5.16-1.68-5.16-3.5v-.093c0-1.56 1.4-2.71 3.56-2.71 2.4 0 5.25.799 7.09 1.81 0 0 .542.35.74-.173.106-.283 1.04-2.78 1.13-3.06.107-.293-.08-.514-.27-.628-2.1-1.28-5-2.15-8-2.15l-.558.002c-5.11 0-8.68 3.09-8.68 7.51v.095c0 4.66 3.94 6.18 7.62 7.23l.591.184c2.69.824 5 1.54 5 3.42v.094c0 1.73-1.51 3.02-3.93 3.02-.943 0-3.95-.016-7.19-2.07-.393-.229-.623-.387-.921-.579-.101-.064-.572-.248-.733.252l-1.1 3.06m55.8-9.36c0 2.7-.504 4.83-1.49 6.34-.984 1.49-2.47 2.22-4.54 2.22s-3.55-.724-4.52-2.21c-.977-1.5-1.47-3.64-1.47-6.34 0-2.7.496-4.82 1.47-6.31.968-1.48 2.44-2.19 4.52-2.19s3.56.717 4.54 2.19c.992 1.49 1.49 3.61 1.49 6.31m4.66-5.01c-.459-1.55-1.17-2.91-2.12-4.05a10.151 10.151 0 0 0-3.58-2.72c-1.42-.665-3.1-1-5-1s-3.57.337-5 1c-1.42.664-2.63 1.58-3.58 2.72-.948 1.14-1.66 2.5-2.12 4.05-.455 1.54-.686 3.22-.686 5.01 0 1.79.231 3.47.686 5.01.457 1.55 1.17 2.91 2.12 4.05.951 1.14 2.16 2.05 3.58 2.7 1.43.648 3.11.978 5 .978 1.89 0 3.57-.33 4.99-.978 1.42-.648 2.63-1.56 3.58-2.7.949-1.14 1.66-2.5 2.12-4.05.454-1.54.685-3.22.685-5.01 0-1.78-.231-3.47-.685-5.01m38.3 12.8c-.153-.453-.595-.282-.595-.282-.677.259-1.4.499-2.17.619-.776.122-1.64.183-2.55.183-2.25 0-4.05-.671-5.33-2-1.29-1.33-2.01-3.47-2-6.37.007-2.64.645-4.62 1.79-6.14 1.13-1.5 2.87-2.28 5.17-2.28 1.92 0 3.39.223 4.93.705 0 0 .365.159.54-.322.409-1.13.711-1.94 1.15-3.18.124-.355-.18-.505-.291-.548-.604-.236-2.03-.623-3.11-.786-1.01-.154-2.18-.234-3.5-.234-1.96 0-3.7.335-5.19.999-1.49.663-2.75 1.58-3.75 2.72-1 1.14-1.76 2.5-2.27 4.05-.505 1.54-.76 3.23-.76 5.02 0 3.86 1.04 6.99 3.1 9.28 2.06 2.3 5.16 3.46 9.2 3.46 2.39 0 4.84-.483 6.6-1.18 0 0 .336-.162.19-.554l-1.15-3.16m8.15-10.4c.223-1.5.634-2.75 1.28-3.72.967-1.48 2.44-2.29 4.51-2.29s3.44.814 4.42 2.29c.65.975.934 2.27 1.04 3.72l-11.3-.002zm15.7-3.3c-.397-1.49-1.38-3-2.02-3.69-1.02-1.09-2.01-1.86-3-2.28a11.5 11.5 0 0 0-4.52-.917c-1.97 0-3.76.333-5.21 1.01-1.45.682-2.67 1.61-3.63 2.77-.959 1.16-1.68 2.53-2.14 4.1-.46 1.55-.692 3.25-.692 5.03 0 1.82.241 3.51.715 5.04.479 1.54 1.25 2.89 2.29 4.01 1.04 1.13 2.37 2.01 3.97 2.63 1.59.615 3.52.934 5.73.927 4.56-.015 6.96-1.03 7.94-1.58.175-.098.34-.267.134-.754l-1.03-2.89c-.158-.431-.594-.275-.594-.275-1.13.422-2.73 1.18-6.48 1.17-2.45-.004-4.26-.727-5.4-1.86-1.16-1.16-1.74-2.85-1.83-5.25l15.8.012s.416-.004.459-.41c.017-.168.541-3.24-.471-6.79zm-142 3.3c.223-1.5.635-2.75 1.28-3.72.968-1.48 2.44-2.29 4.51-2.29s3.44.814 4.42 2.29c.649.975.933 2.27 1.04 3.72l-11.3-.002zm15.7-3.3c-.396-1.49-1.38-3-2.02-3.69-1.02-1.09-2.01-1.86-3-2.28a11.5 11.5 0 0 0-4.52-.917c-1.97 0-3.76.333-5.21 1.01-1.45.682-2.67 1.61-3.63 2.77-.957 1.16-1.68 2.53-2.14 4.1-.459 1.55-.69 3.25-.69 5.03 0 1.82.239 3.51.716 5.04.478 1.54 1.25 2.89 2.28 4.01 1.04 1.13 2.37 2.01 3.97 2.63 1.59.615 3.51.934 5.73.927 4.56-.015 6.96-1.03 7.94-1.58.174-.098.34-.267.133-.754l-1.03-2.89c-.159-.431-.595-.275-.595-.275-1.13.422-2.73 1.18-6.48 1.17-2.44-.004-4.26-.727-5.4-1.86-1.16-1.16-1.74-2.85-1.83-5.25l15.8.012s.416-.004.459-.41c.017-.168.541-3.24-.472-6.79zm-49.8 13.6c-.619-.494-.705-.615-.91-.936-.313-.483-.473-1.17-.473-2.05 0-1.38.46-2.38 1.41-3.05-.01.002 1.36-1.18 4.58-1.14a32 32 0 0 1 4.28.365v7.17h.002s-2 .431-4.26.567c-3.21.193-4.63-.924-4.62-.921zm6.28-11.1c-.64-.047-1.47-.07-2.46-.07-1.35 0-2.66.168-3.88.498-1.23.332-2.34.846-3.29 1.53a7.63 7.63 0 0 0-2.29 2.6c-.559 1.04-.844 2.26-.844 3.64 0 1.4.243 2.61.723 3.6a6.54 6.54 0 0 0 2.06 2.47c.877.638 1.96 1.11 3.21 1.39 1.24.283 2.64.426 4.18.426 1.62 0 3.23-.136 4.79-.399a95.1 95.1 0 0 0 3.97-.772c.526-.121 1.11-.28 1.11-.28.39-.099.36-.516.36-.516l-.009-14.4c0-3.16-.844-5.51-2.51-6.96-1.66-1.45-4.09-2.18-7.24-2.18-1.18 0-3.09.16-4.23.389 0 0-3.44.668-4.86 1.78 0 0-.312.192-.142.627l1.12 3c.139.389.518.256.518.256s.119-.047.259-.13c3.03-1.65 6.87-1.6 6.87-1.6 1.7 0 3.02.345 3.9 1.02.861.661 1.3 1.66 1.3 3.76v.667c-1.35-.196-2.6-.309-2.6-.309zm127-8.13a.428.428 0 0 0-.237-.568c-.269-.102-1.61-.385-2.64-.449-1.98-.124-3.08.21-4.07.654-.978.441-2.06 1.15-2.66 1.97l-.002-1.92c0-.264-.187-.477-.453-.477h-4.04c-.262 0-.452.213-.452.477v23.5a.48.48 0 0 0 .479.479h4.14a.479.479 0 0 0 .478-.479v-11.8c0-1.58.174-3.15.521-4.14.342-.979.807-1.76 1.38-2.32a4.79 4.79 0 0 1 1.95-1.17 7.68 7.68 0 0 1 2.12-.298c.825 0 1.73.212 1.73.212.304.034.473-.152.576-.426.271-.721 1.04-2.88 1.19-3.31\"\n />\n <path\n fill=\"#FFFFFE\"\n d=\"M162.201 67.548a13.258 13.258 0 0 0-1.559-.37 12.217 12.217 0 0 0-2.144-.166c-2.853 0-5.102.806-6.681 2.398-1.568 1.58-2.635 3.987-3.17 7.154l-.193 1.069h-3.581s-.437-.018-.529.459l-.588 3.28c-.041.314.094.51.514.508h3.486l-3.537 19.743c-.277 1.59-.594 2.898-.945 3.889-.346.978-.684 1.711-1.1 2.243-.403.515-.785.894-1.444 1.115-.544.183-1.17.267-1.856.267-.382 0-.89-.064-1.265-.139-.375-.074-.57-.158-.851-.276 0 0-.409-.156-.57.254-.131.335-1.06 2.89-1.17 3.206-.112.312.045.558.243.629.464.166.809.272 1.441.421.878.207 1.618.22 2.311.22 1.452 0 2.775-.204 3.872-.6 1.104-.399 2.065-1.094 2.915-2.035.919-1.015 1.497-2.078 2.05-3.528.547-1.437 1.013-3.221 1.386-5.3l3.554-20.109h5.196s.438.016.529-.459l.588-3.28c.041-.314-.093-.51-.515-.508h-5.043c.025-.114.254-1.888.833-3.558.247-.713.712-1.288 1.106-1.683a3.273 3.273 0 0 1 1.321-.822 5.48 5.48 0 0 1 1.693-.244c.475 0 .941.057 1.296.131.489.104.679.159.807.197.514.157.583.005.684-.244l1.206-3.312c.124-.356-.178-.506-.29-.55m-70.474 34.117c0 .264-.188.479-.452.479h-4.183c-.265 0-.453-.215-.453-.479V67.997c0-.263.188-.476.453-.476h4.183c.264 0 .452.213.452.476v33.668\"\n />\n </g>\n </svg>\n );\n}\n\nfunction IconGoogleDocs({ className, ...props }: React.ComponentProps<\"svg\">) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlSpace=\"preserve\"\n viewBox=\"0 0 64 88\"\n {...props}\n >\n <path\n d=\"M58 88H6c-3.3 0-6-2.7-6-6V6c0-3.3 2.7-6 6-6h36l22 22v60c0 3.3-2.7 6-6 6z\"\n style={{\n fill: \"#3086f6\",\n }}\n />\n <path\n d=\"m42 0 22 22H42V0z\"\n style={{\n fill: \"#0c67d6\",\n }}\n />\n <path\n d=\"M50 39H14v-5h36v5zm0 7H14v5h36v-5zM40 58H14v5h26v-5z\"\n style={{\n fill: \"#fdffff\",\n }}\n />\n </svg>\n );\n}\n\nconst mockFiles: FilePointer[] = [\n {\n name: \"CopilotTextarea README\",\n sourceApplication: \"GoogleDocs\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n {\n name: \"prospecting call transcript\",\n sourceApplication: \"Salesforce\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n {\n name: \"customer feedback\",\n sourceApplication: \"Zendesk\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n {\n name: \"product specifications\",\n sourceApplication: \"Google Docs\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n {\n name: \"meeting minutes\",\n sourceApplication: \"Microsoft Teams\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n {\n name: \"project plan\",\n sourceApplication: \"Trello\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n {\n name: \"code review comments\",\n sourceApplication: \"Github\",\n getContents: async () => {\n return \"some contents\";\n },\n },\n];\n"]}
@@ -1,83 +0,0 @@
1
- import { replaceEditorText } from './chunk-RQHOUUXQ.mjs';
2
- import { getFullEditorTextWithNewlines } from './chunk-IXJ2HCOA.mjs';
3
- import React from 'react';
4
- import { ReactEditor } from 'slate-react';
5
-
6
- function usePopulateCopilotTextareaRef(editor, ref) {
7
- React.useImperativeHandle(
8
- ref,
9
- () => {
10
- class Combined {
11
- constructor(customMethods2, editorHtmlElement2) {
12
- this.customMethods = customMethods2;
13
- this.editorHtmlElement = editorHtmlElement2;
14
- }
15
- get(target, propKey) {
16
- if (this.isKeyOfCustomMethods(propKey)) {
17
- const value = this.customMethods[propKey];
18
- if (typeof value === "function") {
19
- return value.bind(this.customMethods);
20
- }
21
- return value;
22
- } else if (this.isKeyOfHTMLElement(propKey)) {
23
- const value = this.editorHtmlElement[propKey];
24
- if (typeof value === "function") {
25
- return value.bind(this.editorHtmlElement);
26
- }
27
- return value;
28
- }
29
- }
30
- set(target, propKey, value) {
31
- if (this.isKeyOfCustomMethods(propKey)) {
32
- this.customMethods[propKey] = value;
33
- } else if (this.isKeyOfHTMLElement(propKey)) {
34
- this.editorHtmlElement[propKey] = value;
35
- } else {
36
- target[propKey] = value;
37
- }
38
- return true;
39
- }
40
- isKeyOfCustomMethods(key) {
41
- return key in this.customMethods;
42
- }
43
- isKeyOfHTMLElement(key) {
44
- return key in this.editorHtmlElement;
45
- }
46
- }
47
- const handler = {
48
- get(target, propKey) {
49
- return target.get(target, propKey);
50
- },
51
- set(target, propKey, value) {
52
- return target.set(target, propKey, value);
53
- }
54
- };
55
- class CustomMethods {
56
- constructor(editor2) {
57
- this.editor = editor2;
58
- }
59
- focus() {
60
- ReactEditor.focus(this.editor);
61
- }
62
- blur() {
63
- ReactEditor.blur(this.editor);
64
- }
65
- get value() {
66
- return getFullEditorTextWithNewlines(this.editor);
67
- }
68
- set value(value) {
69
- replaceEditorText(this.editor, value);
70
- }
71
- }
72
- const editorHtmlElement = ReactEditor.toDOMNode(editor, editor);
73
- const customMethods = new CustomMethods(editor);
74
- const combined = new Combined(customMethods, editorHtmlElement);
75
- return new Proxy(combined, handler);
76
- },
77
- [editor]
78
- );
79
- }
80
-
81
- export { usePopulateCopilotTextareaRef };
82
- //# sourceMappingURL=out.js.map
83
- //# sourceMappingURL=chunk-YQU7WG7T.mjs.map