@copilotkit/react-textarea 0.6.0 → 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (135) hide show
  1. package/.turbo/turbo-build.log +192 -116
  2. package/CHANGELOG.md +6 -0
  3. package/dist/{chunk-JJASB23A.mjs → chunk-24IOWJS4.mjs} +2 -2
  4. package/dist/chunk-24IOWJS4.mjs.map +1 -0
  5. package/dist/{chunk-X4FJ6WVZ.mjs → chunk-3UQM3NLM.mjs} +1 -1
  6. package/dist/chunk-3UQM3NLM.mjs.map +1 -0
  7. package/dist/{chunk-RVJAOO4S.mjs → chunk-4XYYSJ5C.mjs} +1 -1
  8. package/dist/{chunk-RVJAOO4S.mjs.map → chunk-4XYYSJ5C.mjs.map} +1 -1
  9. package/dist/{chunk-5SJM4R4K.mjs → chunk-6LKDH2UJ.mjs} +2 -2
  10. package/dist/chunk-6LKDH2UJ.mjs.map +1 -0
  11. package/dist/{chunk-Y5BUWZOI.mjs → chunk-6Q4X3YEO.mjs} +1 -1
  12. package/dist/chunk-6Q4X3YEO.mjs.map +1 -0
  13. package/dist/{chunk-L24ZN4LL.mjs → chunk-6SYD77G6.mjs} +1 -1
  14. package/dist/chunk-6SYD77G6.mjs.map +1 -0
  15. package/dist/chunk-AZQCUNBV.mjs +3 -0
  16. package/dist/{chunk-GOAPCQCR.mjs → chunk-CHK3DSAA.mjs} +9 -9
  17. package/dist/chunk-CHK3DSAA.mjs.map +1 -0
  18. package/dist/chunk-FD6FGKYY.mjs +3 -0
  19. package/dist/chunk-MMVDU6DF.mjs +3 -0
  20. package/dist/{chunk-KKG2RK2T.mjs → chunk-OELUUJZY.mjs} +1 -1
  21. package/dist/chunk-OELUUJZY.mjs.map +1 -0
  22. package/dist/chunk-RJDWVMCN.mjs +85 -0
  23. package/dist/chunk-RJDWVMCN.mjs.map +1 -0
  24. package/dist/{chunk-4LJAS777.mjs → chunk-UW3ITU2Y.mjs} +2 -2
  25. package/dist/chunk-UW3ITU2Y.mjs.map +1 -0
  26. package/dist/chunk-VF6DFXKX.mjs +25 -0
  27. package/dist/chunk-VF6DFXKX.mjs.map +1 -0
  28. package/dist/chunk-WJHSY5T6.mjs +3 -0
  29. package/dist/{chunk-ETGKLURC.mjs → chunk-WJYQWL4I.mjs} +1 -1
  30. package/dist/chunk-WJYQWL4I.mjs.map +1 -0
  31. package/dist/chunk-ZPACRCJ6.mjs +69 -0
  32. package/dist/chunk-ZPACRCJ6.mjs.map +1 -0
  33. package/dist/components/{copilot-textarea/base-copilot-textarea → base-copilot-textarea}/base-copilot-textarea.d.ts +2 -2
  34. package/dist/components/base-copilot-textarea/base-copilot-textarea.mjs +18 -0
  35. package/dist/components/base-copilot-textarea/render-element.mjs +4 -0
  36. package/dist/components/base-copilot-textarea/render-placeholder.mjs +4 -0
  37. package/dist/components/copilot-textarea/copilot-textarea.d.ts +15 -0
  38. package/dist/components/copilot-textarea/copilot-textarea.mjs +22 -0
  39. package/dist/components/index.d.ts +6 -3
  40. package/dist/components/index.mjs +16 -11
  41. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.d.ts +23 -0
  42. package/dist/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs +4 -0
  43. package/dist/hooks/use-autosuggestions.d.ts +3 -3
  44. package/dist/hooks/use-autosuggestions.mjs +2 -2
  45. package/dist/hooks/use-copilot-textarea-editor.d.ts +1 -1
  46. package/dist/hooks/use-copilot-textarea-editor.mjs +1 -1
  47. package/dist/index.d.ts +6 -3
  48. package/dist/index.mjs +18 -13
  49. package/dist/lib/editor-to-text.mjs.map +1 -1
  50. package/dist/lib/get-text-around-cursor.d.ts +1 -1
  51. package/dist/lib/get-text-around-cursor.mjs +1 -1
  52. package/dist/lib/slatejs-edits/add-autocompletions.d.ts +1 -1
  53. package/dist/lib/slatejs-edits/add-autocompletions.mjs +1 -1
  54. package/dist/lib/slatejs-edits/clear-autocompletions.d.ts +1 -1
  55. package/dist/lib/slatejs-edits/clear-autocompletions.mjs +1 -1
  56. package/dist/lib/slatejs-edits/with-partial-history.d.ts +1 -1
  57. package/dist/types/base/autosuggestions-bare-function.mjs.map +1 -0
  58. package/dist/types/base/base-autosuggestions-config.mjs +4 -0
  59. package/dist/types/base/base-autosuggestions-config.mjs.map +1 -0
  60. package/dist/types/base/custom-editor.mjs.map +1 -0
  61. package/dist/types/base/editor-autocomplete-state.mjs +5 -0
  62. package/dist/types/base/editor-autocomplete-state.mjs.map +1 -0
  63. package/dist/types/base/index.d.ts +2 -0
  64. package/dist/types/base/index.mjs +5 -0
  65. package/dist/types/base/index.mjs.map +1 -0
  66. package/dist/types/index.d.ts +4 -2
  67. package/dist/types/index.mjs +5 -2
  68. package/dist/types/standard-autosuggestions/autosuggestions-config.d.ts +18 -0
  69. package/dist/types/standard-autosuggestions/autosuggestions-config.mjs +6 -0
  70. package/dist/types/standard-autosuggestions/autosuggestions-config.mjs.map +1 -0
  71. package/dist/types/standard-autosuggestions/index.d.ts +3 -0
  72. package/dist/types/standard-autosuggestions/index.mjs +7 -0
  73. package/dist/types/standard-autosuggestions/index.mjs.map +1 -0
  74. package/dist/types/standard-autosuggestions/minimal-chat-gpt-message.d.ts +7 -0
  75. package/dist/types/standard-autosuggestions/minimal-chat-gpt-message.mjs +3 -0
  76. package/dist/types/standard-autosuggestions/minimal-chat-gpt-message.mjs.map +1 -0
  77. package/package.json +4 -3
  78. package/src/components/{copilot-textarea/base-copilot-textarea → base-copilot-textarea}/base-copilot-textarea.tsx +9 -9
  79. package/src/components/copilot-textarea/copilot-textarea.tsx +40 -0
  80. package/src/components/index.ts +5 -2
  81. package/src/hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.tsx +101 -0
  82. package/src/hooks/use-autosuggestions.ts +3 -3
  83. package/src/hooks/use-copilot-textarea-editor.tsx +1 -1
  84. package/src/lib/editor-to-text.ts +1 -1
  85. package/src/lib/get-text-around-cursor.ts +1 -1
  86. package/src/lib/slatejs-edits/add-autocompletions.ts +1 -1
  87. package/src/lib/slatejs-edits/clear-autocompletions.ts +1 -1
  88. package/src/types/{editor-autocomplete-state.ts → base/editor-autocomplete-state.ts} +1 -1
  89. package/src/types/base/index.ts +4 -0
  90. package/src/types/index.ts +2 -4
  91. package/src/types/standard-autosuggestions/autosuggestions-config.tsx +94 -0
  92. package/src/types/standard-autosuggestions/index.ts +11 -0
  93. package/src/types/standard-autosuggestions/minimal-chat-gpt-message.tsx +5 -0
  94. package/dist/chunk-4LJAS777.mjs.map +0 -1
  95. package/dist/chunk-5SJM4R4K.mjs.map +0 -1
  96. package/dist/chunk-ETGKLURC.mjs.map +0 -1
  97. package/dist/chunk-GOAPCQCR.mjs.map +0 -1
  98. package/dist/chunk-JD7BAH7U.mjs +0 -3
  99. package/dist/chunk-JJASB23A.mjs.map +0 -1
  100. package/dist/chunk-KKG2RK2T.mjs.map +0 -1
  101. package/dist/chunk-L24ZN4LL.mjs.map +0 -1
  102. package/dist/chunk-X4FJ6WVZ.mjs.map +0 -1
  103. package/dist/chunk-Y5BUWZOI.mjs.map +0 -1
  104. package/dist/chunk-YPBKY4KY.mjs +0 -3
  105. package/dist/components/copilot-textarea/base-copilot-textarea/base-copilot-textarea.mjs +0 -17
  106. package/dist/components/copilot-textarea/base-copilot-textarea/render-element.mjs +0 -4
  107. package/dist/components/copilot-textarea/base-copilot-textarea/render-placeholder.mjs +0 -4
  108. package/dist/types/base-autosuggestions-config.mjs +0 -4
  109. package/dist/types/editor-autocomplete-state.mjs +0 -5
  110. /package/dist/{chunk-JD7BAH7U.mjs.map → chunk-AZQCUNBV.mjs.map} +0 -0
  111. /package/dist/{chunk-YPBKY4KY.mjs.map → chunk-FD6FGKYY.mjs.map} +0 -0
  112. /package/dist/{components/copilot-textarea/base-copilot-textarea/base-copilot-textarea.mjs.map → chunk-MMVDU6DF.mjs.map} +0 -0
  113. /package/dist/{components/copilot-textarea/base-copilot-textarea/render-element.mjs.map → chunk-WJHSY5T6.mjs.map} +0 -0
  114. /package/dist/components/{copilot-textarea/base-copilot-textarea/render-placeholder.mjs.map → base-copilot-textarea/base-copilot-textarea.mjs.map} +0 -0
  115. /package/dist/components/{copilot-textarea/base-copilot-textarea → base-copilot-textarea}/render-element.d.ts +0 -0
  116. /package/dist/{types/autosuggestion-state.mjs.map → components/base-copilot-textarea/render-element.mjs.map} +0 -0
  117. /package/dist/components/{copilot-textarea/base-copilot-textarea → base-copilot-textarea}/render-placeholder.d.ts +0 -0
  118. /package/dist/{types/autosuggestions-bare-function.mjs.map → components/base-copilot-textarea/render-placeholder.mjs.map} +0 -0
  119. /package/dist/{types/base-autosuggestions-config.mjs.map → components/copilot-textarea/copilot-textarea.mjs.map} +0 -0
  120. /package/dist/{types/custom-editor.mjs.map → hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function.mjs.map} +0 -0
  121. /package/dist/types/{autosuggestion-state.d.ts → base/autosuggestion-state.d.ts} +0 -0
  122. /package/dist/types/{autosuggestion-state.mjs → base/autosuggestion-state.mjs} +0 -0
  123. /package/dist/types/{editor-autocomplete-state.mjs.map → base/autosuggestion-state.mjs.map} +0 -0
  124. /package/dist/types/{autosuggestions-bare-function.d.ts → base/autosuggestions-bare-function.d.ts} +0 -0
  125. /package/dist/types/{autosuggestions-bare-function.mjs → base/autosuggestions-bare-function.mjs} +0 -0
  126. /package/dist/types/{base-autosuggestions-config.d.ts → base/base-autosuggestions-config.d.ts} +0 -0
  127. /package/dist/types/{custom-editor.d.ts → base/custom-editor.d.ts} +0 -0
  128. /package/dist/types/{custom-editor.mjs → base/custom-editor.mjs} +0 -0
  129. /package/dist/types/{editor-autocomplete-state.d.ts → base/editor-autocomplete-state.d.ts} +0 -0
  130. /package/src/components/{copilot-textarea/base-copilot-textarea → base-copilot-textarea}/render-element.tsx +0 -0
  131. /package/src/components/{copilot-textarea/base-copilot-textarea → base-copilot-textarea}/render-placeholder.tsx +0 -0
  132. /package/src/types/{autosuggestion-state.ts → base/autosuggestion-state.ts} +0 -0
  133. /package/src/types/{autosuggestions-bare-function.ts → base/autosuggestions-bare-function.ts} +0 -0
  134. /package/src/types/{base-autosuggestions-config.tsx → base/base-autosuggestions-config.tsx} +0 -0
  135. /package/src/types/{custom-editor.tsx → base/custom-editor.tsx} +0 -0
@@ -1,2 +1,4 @@
1
- export { BaseAutosuggestionsConfig, defaultBaseAutosuggestionsConfig } from './base-autosuggestions-config.js';
2
- export { AutosuggestionsBareFunction } from './autosuggestions-bare-function.js';
1
+ export { BaseAutosuggestionsConfig, defaultBaseAutosuggestionsConfig } from './base/base-autosuggestions-config.js';
2
+ export { AutosuggestionsBareFunction } from './base/autosuggestions-bare-function.js';
3
+ export { AutosuggestionsConfig, MakeSystemPrompt, defaultAutosuggestionsConfig, defaultFewShotMessages, defaultMakeSystemPrompt } from './standard-autosuggestions/autosuggestions-config.js';
4
+ export { MinimalChatGPTMessage } from './standard-autosuggestions/minimal-chat-gpt-message.js';
@@ -1,5 +1,8 @@
1
- import '../chunk-YPBKY4KY.mjs';
2
- export { defaultBaseAutosuggestionsConfig } from '../chunk-5SJM4R4K.mjs';
1
+ import '../chunk-FD6FGKYY.mjs';
2
+ import '../chunk-AZQCUNBV.mjs';
3
+ export { defaultAutosuggestionsConfig, defaultFewShotMessages, defaultMakeSystemPrompt } from '../chunk-ZPACRCJ6.mjs';
4
+ import '../chunk-WJHSY5T6.mjs';
5
+ export { defaultBaseAutosuggestionsConfig } from '../chunk-6LKDH2UJ.mjs';
3
6
  import '../chunk-MRXNTQOX.mjs';
4
7
  //# sourceMappingURL=out.js.map
5
8
  //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,18 @@
1
+ import { BaseAutosuggestionsConfig } from '../base/base-autosuggestions-config.js';
2
+ import { MinimalChatGPTMessage } from './minimal-chat-gpt-message.js';
3
+
4
+ type MakeSystemPrompt = (purposePrompt: string, contextString: string) => string;
5
+ interface AutosuggestionsConfig extends BaseAutosuggestionsConfig {
6
+ apiEndpoint: string;
7
+ externalContextCategories: string[] | undefined;
8
+ makeSystemPrompt: MakeSystemPrompt;
9
+ fewShotMessages: MinimalChatGPTMessage[];
10
+ forwardedParams: {
11
+ [key: string]: any;
12
+ } | undefined;
13
+ }
14
+ declare const defaultMakeSystemPrompt: MakeSystemPrompt;
15
+ declare const defaultFewShotMessages: MinimalChatGPTMessage[];
16
+ declare const defaultAutosuggestionsConfig: Omit<AutosuggestionsConfig, "purposePrompt">;
17
+
18
+ export { AutosuggestionsConfig, MakeSystemPrompt, defaultAutosuggestionsConfig, defaultFewShotMessages, defaultMakeSystemPrompt };
@@ -0,0 +1,6 @@
1
+ export { defaultAutosuggestionsConfig, defaultFewShotMessages, defaultMakeSystemPrompt } from '../../chunk-ZPACRCJ6.mjs';
2
+ import '../../chunk-WJHSY5T6.mjs';
3
+ import '../../chunk-6LKDH2UJ.mjs';
4
+ import '../../chunk-MRXNTQOX.mjs';
5
+ //# sourceMappingURL=out.js.map
6
+ //# sourceMappingURL=autosuggestions-config.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ export { AutosuggestionsConfig, MakeSystemPrompt, defaultAutosuggestionsConfig, defaultFewShotMessages, defaultMakeSystemPrompt } from './autosuggestions-config.js';
2
+ export { MinimalChatGPTMessage } from './minimal-chat-gpt-message.js';
3
+ import '../base/base-autosuggestions-config.js';
@@ -0,0 +1,7 @@
1
+ import '../../chunk-AZQCUNBV.mjs';
2
+ export { defaultAutosuggestionsConfig, defaultFewShotMessages, defaultMakeSystemPrompt } from '../../chunk-ZPACRCJ6.mjs';
3
+ import '../../chunk-WJHSY5T6.mjs';
4
+ import '../../chunk-6LKDH2UJ.mjs';
5
+ import '../../chunk-MRXNTQOX.mjs';
6
+ //# sourceMappingURL=out.js.map
7
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ interface MinimalChatGPTMessage {
2
+ role: string;
3
+ content: string;
4
+ name?: string;
5
+ }
6
+
7
+ export { MinimalChatGPTMessage };
@@ -0,0 +1,3 @@
1
+
2
+ //# sourceMappingURL=out.js.map
3
+ //# sourceMappingURL=minimal-chat-gpt-message.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
package/package.json CHANGED
@@ -4,7 +4,7 @@
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
7
- "version": "0.6.0",
7
+ "version": "0.7.0",
8
8
  "sideEffects": [
9
9
  "**/*.css"
10
10
  ],
@@ -27,9 +27,10 @@
27
27
  "tailwindcss": "^3.3.0",
28
28
  "tsup": "^6.1.3",
29
29
  "typescript": "^4.9.4",
30
- "eslint-config-custom": "0.2.0",
30
+ "@copilotkit/react-core": "0.6.0",
31
+ "tailwind-config": "0.1.0",
31
32
  "tsconfig": "0.3.0",
32
- "tailwind-config": "0.1.0"
33
+ "eslint-config-custom": "0.2.0"
33
34
  },
34
35
  "dependencies": {
35
36
  "ai": "^2.1.22",
@@ -9,21 +9,21 @@ import {
9
9
  import { Descendant, Editor } from "slate";
10
10
  import { Editable, Slate } from "slate-react";
11
11
  import { twMerge } from "tailwind-merge";
12
- import { useAutosuggestions } from "../../../hooks/use-autosuggestions";
13
- import { AutosuggestionsBareFunction } from "../../../types/autosuggestions-bare-function";
14
- import { useCopilotTextareaEditor } from "../../../hooks/use-copilot-textarea-editor";
12
+ import { useAutosuggestions } from "../../hooks/use-autosuggestions";
13
+ import { useCopilotTextareaEditor } from "../../hooks/use-copilot-textarea-editor";
15
14
  import {
16
15
  getFullEditorTextWithNewlines,
17
16
  getTextAroundCursor,
18
- } from "../../../lib/get-text-around-cursor";
19
- import { addAutocompletionsToEditor } from "../../../lib/slatejs-edits/add-autocompletions";
20
- import { clearAutocompletionsFromEditor } from "../../../lib/slatejs-edits/clear-autocompletions";
21
- import { replaceEditorText } from "../../../lib/slatejs-edits/replace-text";
22
- import { AutosuggestionState } from "../../../types/autosuggestion-state";
17
+ } from "../../lib/get-text-around-cursor";
18
+ import { addAutocompletionsToEditor } from "../../lib/slatejs-edits/add-autocompletions";
19
+ import { clearAutocompletionsFromEditor } from "../../lib/slatejs-edits/clear-autocompletions";
20
+ import { replaceEditorText } from "../../lib/slatejs-edits/replace-text";
23
21
  import {
22
+ AutosuggestionsBareFunction,
24
23
  BaseAutosuggestionsConfig,
25
24
  defaultBaseAutosuggestionsConfig,
26
- } from "../../../types/base-autosuggestions-config";
25
+ } from "../../types/base";
26
+ import { AutosuggestionState } from "../../types/base/autosuggestion-state";
27
27
  import { makeRenderElementFunction } from "./render-element";
28
28
  import { makeRenderPlaceholderFunction } from "./render-placeholder";
29
29
 
@@ -0,0 +1,40 @@
1
+ // This example is for an Editor with `ReactEditor` and `HistoryEditor`
2
+ import { useMakeStandardAutosuggestionFunction } from "../../hooks/make-autosuggestions-function/use-make-standard-autosuggestions-function";
3
+ import {
4
+ AutosuggestionsConfig,
5
+ defaultAutosuggestionsConfig,
6
+ } from "../../types/standard-autosuggestions";
7
+ import {
8
+ BaseCopilotTextarea,
9
+ BaseCopilotTextareaProps,
10
+ } from "../base-copilot-textarea/base-copilot-textarea";
11
+
12
+ export interface CopilotTextareaProps extends BaseCopilotTextareaProps {
13
+ autosuggestionsConfig: Partial<AutosuggestionsConfig> & {
14
+ purposePrompt: string;
15
+ };
16
+ }
17
+
18
+ export function CopilotTextarea(props: CopilotTextareaProps): JSX.Element {
19
+ const autosuggestionsConfig: AutosuggestionsConfig = {
20
+ ...defaultAutosuggestionsConfig,
21
+ ...props.autosuggestionsConfig,
22
+ };
23
+
24
+ const autosuggestionsFunction = useMakeStandardAutosuggestionFunction(
25
+ autosuggestionsConfig.purposePrompt,
26
+ autosuggestionsConfig.apiEndpoint,
27
+ autosuggestionsConfig.makeSystemPrompt,
28
+ autosuggestionsConfig.fewShotMessages,
29
+ autosuggestionsConfig.externalContextCategories,
30
+ autosuggestionsConfig.forwardedParams
31
+ );
32
+
33
+ return (
34
+ <BaseCopilotTextarea
35
+ {...props}
36
+ autosuggestionsConfig={autosuggestionsConfig}
37
+ autosuggestionsFunction={autosuggestionsFunction}
38
+ />
39
+ );
40
+ }
@@ -1,2 +1,5 @@
1
- export { BaseCopilotTextarea } from "./copilot-textarea/base-copilot-textarea/base-copilot-textarea";
2
- export type { BaseCopilotTextareaProps } from "./copilot-textarea/base-copilot-textarea/base-copilot-textarea";
1
+ export { BaseCopilotTextarea } from "./base-copilot-textarea/base-copilot-textarea";
2
+ export type { BaseCopilotTextareaProps } from "./base-copilot-textarea/base-copilot-textarea";
3
+
4
+ export { CopilotTextarea } from "./copilot-textarea/copilot-textarea";
5
+ export type { CopilotTextareaProps } from "./copilot-textarea/copilot-textarea";
@@ -0,0 +1,101 @@
1
+ import { CopilotContext } from "@copilotkit/react-core";
2
+ import { useCallback, useContext } from "react";
3
+ import {
4
+ AutosuggestionsBareFunction,
5
+ MakeSystemPrompt,
6
+ MinimalChatGPTMessage,
7
+ } from "../../types";
8
+ /**
9
+ * Returns a memoized function that sends a request to the specified API endpoint to get an autosuggestion for the user's input.
10
+ * The function takes in the text before and after the cursor, and an abort signal.
11
+ * It sends a POST request to the API endpoint with the messages array containing the system message, few shot messages, and user messages.
12
+ * The function returns the suggestion from the API response.
13
+ *
14
+ * @param purposePrompt - The purpose of the textarea. This is included in the system message.
15
+ * @param apiEndpoint - The API endpoint to send the autosuggestion request to.
16
+ * @param makeSystemMessage - A function that takes in a context string and returns a system message to include in the autosuggestion request.
17
+ * @param fewShotMessages - An array of few shot messages to include in the autosuggestion request.
18
+ * @param contextCategories - The categories of context strings we want to include. By default, we include the (default) "global" context category.
19
+ * @returns A memoized function that sends a request to the specified API endpoint to get an autosuggestion for the user's input.
20
+ */
21
+ export function useMakeStandardAutosuggestionFunction(
22
+ purposePrompt: string,
23
+ apiEndpoint: string,
24
+ makeSystemPrompt: MakeSystemPrompt,
25
+ fewShotMessages: MinimalChatGPTMessage[],
26
+ contextCategories: string[] | undefined,
27
+ forwardedProps?: { [key: string]: any }
28
+ ): AutosuggestionsBareFunction {
29
+ const { getContextString } = useContext(CopilotContext);
30
+
31
+ return useCallback(
32
+ async (beforeText: string, afterText: string, abortSignal: AbortSignal) => {
33
+ const res = await retry(async () => {
34
+ return await fetch(apiEndpoint, {
35
+ method: "POST",
36
+ body: JSON.stringify({
37
+ ...forwardedProps,
38
+ messages: [
39
+ {
40
+ role: "system",
41
+ content: makeSystemPrompt(
42
+ purposePrompt,
43
+ getContextString(contextCategories)
44
+ ),
45
+ },
46
+ ...fewShotMessages,
47
+ {
48
+ role: "user",
49
+ name: "TextAfterCursor",
50
+ content: afterText,
51
+ },
52
+ {
53
+ role: "user",
54
+ name: "TextBeforeCursor",
55
+ content: beforeText,
56
+ },
57
+ ],
58
+ }),
59
+ signal: abortSignal,
60
+ });
61
+ });
62
+
63
+ const json = await res.json();
64
+ const suggestion = json.choices[0].message.content;
65
+
66
+ return suggestion;
67
+ },
68
+ [
69
+ apiEndpoint,
70
+ makeSystemPrompt,
71
+ fewShotMessages,
72
+ getContextString,
73
+ contextCategories,
74
+ purposePrompt,
75
+ ]
76
+ );
77
+ }
78
+
79
+ function retry<T>(
80
+ fn: () => Promise<T>,
81
+ retriesLeft: number = 2,
82
+ interval: number = 200,
83
+ backoff: number = 1.5
84
+ ): Promise<T> {
85
+ return new Promise((resolve, reject) => {
86
+ fn()
87
+ .then(resolve)
88
+ .catch((error) => {
89
+ if (retriesLeft === 1) {
90
+ reject(error);
91
+ return;
92
+ }
93
+
94
+ setTimeout(() => {
95
+ retry(fn, retriesLeft - 1, interval * backoff, backoff)
96
+ .then(resolve)
97
+ .catch(reject);
98
+ }, interval);
99
+ });
100
+ });
101
+ }
@@ -1,12 +1,12 @@
1
1
  import { useCallback, useMemo, useState } from "react";
2
2
  import { Debouncer } from "../lib/debouncer";
3
3
  import { nullableCompatibleEqualityCheck } from "../lib/utils";
4
- import { AutosuggestionState } from "../types/autosuggestion-state";
4
+ import { AutosuggestionsBareFunction } from "../types/base";
5
+ import { AutosuggestionState } from "../types/base/autosuggestion-state";
5
6
  import {
6
7
  EditorAutocompleteState,
7
8
  areEqual_autocompleteState,
8
- } from "../types/editor-autocomplete-state";
9
- import { AutosuggestionsBareFunction } from "../types/autosuggestions-bare-function";
9
+ } from "../types/base/editor-autocomplete-state";
10
10
 
11
11
  export interface UseAutosuggestionsResult {
12
12
  currentAutocompleteSuggestion: AutosuggestionState | null;
@@ -1,12 +1,12 @@
1
1
  import { createEditor, Element } from "slate";
2
2
  import { withReact } from "slate-react";
3
3
  import { useMemo } from "react";
4
- import { CustomEditor } from "../types/custom-editor";
5
4
  import {
6
5
  withPartialHistory,
7
6
  ShouldSaveToHistory,
8
7
  defaultShouldSave,
9
8
  } from "../lib/slatejs-edits/with-partial-history";
9
+ import { CustomEditor } from "../types/base/custom-editor";
10
10
 
11
11
  const shouldSave: ShouldSaveToHistory = (op, prev) => {
12
12
  const excludedNodeType = "suggestion";
@@ -1,7 +1,7 @@
1
1
  import { BaseEditor, Descendant, Element } from "slate";
2
2
  import { HistoryEditor } from "slate-history";
3
3
  import { ReactEditor } from "slate-react";
4
- import { SuggestionAwareText } from "../types/custom-editor";
4
+ import { SuggestionAwareText } from "../types/base/custom-editor";
5
5
 
6
6
  function nodeChildrenToTextComponents(
7
7
  editor: BaseEditor & ReactEditor & HistoryEditor,
@@ -1,5 +1,5 @@
1
1
  import { Editor, Node, Path, Range, Text, Element } from "slate";
2
- import { EditorAutocompleteState } from "../types/editor-autocomplete-state";
2
+ import { EditorAutocompleteState } from "../types/base/editor-autocomplete-state";
3
3
 
4
4
  export function getTextAroundCursor(
5
5
  editor: Editor
@@ -1,5 +1,5 @@
1
1
  import { BasePoint, Transforms } from "slate";
2
- import { CustomEditor } from "../../types/custom-editor";
2
+ import { CustomEditor } from "../../types/base/custom-editor";
3
3
 
4
4
  export function addAutocompletionsToEditor(
5
5
  editor: CustomEditor,
@@ -1,5 +1,5 @@
1
1
  import { Path, Node, Element, Transforms } from "slate";
2
- import { CustomEditor } from "../../types/custom-editor";
2
+ import { CustomEditor } from "../../types/base/custom-editor";
3
3
 
4
4
  export function clearAutocompletionsFromEditor(editor: CustomEditor) {
5
5
  // clear previous suggestion
@@ -1,5 +1,5 @@
1
1
  import { BasePoint } from "slate";
2
- import { arraysAreEqual } from "../lib/utils";
2
+ import { arraysAreEqual } from "../../lib/utils";
3
3
 
4
4
  export interface EditorAutocompleteState {
5
5
  cursorPoint: BasePoint;
@@ -0,0 +1,4 @@
1
+ export { defaultBaseAutosuggestionsConfig } from "./base-autosuggestions-config";
2
+
3
+ export type { BaseAutosuggestionsConfig } from "./base-autosuggestions-config";
4
+ export type { AutosuggestionsBareFunction } from "./autosuggestions-bare-function";
@@ -1,4 +1,2 @@
1
- export { defaultBaseAutosuggestionsConfig } from "./base-autosuggestions-config";
2
-
3
- export type { BaseAutosuggestionsConfig } from "./base-autosuggestions-config";
4
- export type { AutosuggestionsBareFunction } from "./autosuggestions-bare-function";
1
+ export * from "./base";
2
+ export * from "./standard-autosuggestions";
@@ -0,0 +1,94 @@
1
+ import {
2
+ BaseAutosuggestionsConfig,
3
+ defaultBaseAutosuggestionsConfig,
4
+ } from "../base";
5
+ import { MinimalChatGPTMessage } from "./minimal-chat-gpt-message";
6
+
7
+ export type MakeSystemPrompt = (
8
+ purposePrompt: string,
9
+ contextString: string
10
+ ) => string;
11
+
12
+ export interface AutosuggestionsConfig extends BaseAutosuggestionsConfig {
13
+ apiEndpoint: string;
14
+ externalContextCategories: string[] | undefined;
15
+ makeSystemPrompt: MakeSystemPrompt;
16
+ fewShotMessages: MinimalChatGPTMessage[];
17
+ forwardedParams: { [key: string]: any } | undefined;
18
+ }
19
+
20
+ export const defaultMakeSystemPrompt: MakeSystemPrompt = (
21
+ purposePrompt,
22
+ contextString
23
+ ) => {
24
+ return `You are a versatile writing assistant.
25
+
26
+ The user is writing some text.
27
+ The purpose is: \"${purposePrompt}\"
28
+
29
+ Your job is to guess what the user will write next AS BEST YOU CAN.
30
+ Only guess a SHORT distance ahead. Usually 1 sentence, or at most 1 paragraph.
31
+
32
+ Adjust yourself to the user's style and implied intent.
33
+
34
+ The user will provide both the text before and after the cursor. You should use this to infer what the user is likely to write next.
35
+ <TextAfterCursor>
36
+ <TextBeforeCursor>
37
+ <YourSuggestion>
38
+
39
+ If we need to add a whitespace character to the suggested text, make sure to explicitly add it in.
40
+
41
+ The following external context is also provided. Use it to help you make better suggestions!!!
42
+ \`\`\`
43
+ ${contextString}
44
+ \`\`\`
45
+ `;
46
+ };
47
+
48
+ export const defaultFewShotMessages: MinimalChatGPTMessage[] = [
49
+ {
50
+ role: "user",
51
+ name: "TextAfterCursor",
52
+ content:
53
+ "While I was there I also picked up some apples, oranges, and bananas.",
54
+ },
55
+ {
56
+ role: "user",
57
+ name: "TextBeforeCursor",
58
+ content: "This morning I woke up and went straight to the grocery store.",
59
+ },
60
+ {
61
+ role: "assistant",
62
+ content:
63
+ " When I arrived I went straight to the produce section and picked out a big watermelon. ",
64
+ },
65
+ {
66
+ role: "user",
67
+ name: "TextAfterCursor",
68
+ content:
69
+ "and (iii) to the appointment of the Equityholders' Representative pursuant to Section 10.7 of the Merger Agreement and to the provisions thereof.",
70
+ },
71
+ {
72
+ role: "user",
73
+ name: "TextBeforeCursor",
74
+ content:
75
+ 'The Optionholder, in the Optionholder\'s capacity as a holder of vested Options, hereby irrevocably and unconditionally agrees: (i) that the Optionholder shall be deemed an "Equityholder" under the Merger Agreement and shall be entitled to the rights and benefits, and subject to the obligations, of an "Equityholder" thereunder;',
76
+ },
77
+ {
78
+ role: "assistant",
79
+ content:
80
+ ' (ii) that, for purposes of this Agreement and the Merger Agreement, the applicable percentage set forth opposite the name of the Optionholder in the Distribution Waterfall shall be such the Optionholder\'s "Pro Rata Share"; ',
81
+ },
82
+ ];
83
+ export const defaultAutosuggestionsConfig: Omit<
84
+ AutosuggestionsConfig,
85
+ "purposePrompt"
86
+ > = {
87
+ ...defaultBaseAutosuggestionsConfig,
88
+
89
+ apiEndpoint: "api/autosuggestions",
90
+ makeSystemPrompt: defaultMakeSystemPrompt,
91
+ fewShotMessages: defaultFewShotMessages,
92
+ externalContextCategories: undefined,
93
+ forwardedParams: undefined,
94
+ };
@@ -0,0 +1,11 @@
1
+ export type {
2
+ AutosuggestionsConfig,
3
+ MakeSystemPrompt,
4
+ } from "./autosuggestions-config";
5
+ export {
6
+ defaultMakeSystemPrompt,
7
+ defaultFewShotMessages,
8
+ defaultAutosuggestionsConfig,
9
+ } from "./autosuggestions-config";
10
+
11
+ export type { MinimalChatGPTMessage } from "./minimal-chat-gpt-message";
@@ -0,0 +1,5 @@
1
+ export interface MinimalChatGPTMessage {
2
+ role: string;
3
+ content: string;
4
+ name?: string;
5
+ }
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/types/editor-autocomplete-state.ts"],"names":[],"mappings":";;;;;AAQO,SAAS,2BACd,MACA,MACA;AACA,SACE,KAAK,YAAY,WAAW,KAAK,YAAY,UAC7C,eAAe,KAAK,YAAY,MAAM,KAAK,YAAY,IAAI,KAC3D,KAAK,qBAAqB,KAAK,oBAC/B,KAAK,oBAAoB,KAAK;AAElC","sourcesContent":["import { BasePoint } from \"slate\";\nimport { arraysAreEqual } from \"../lib/utils\";\n\nexport interface EditorAutocompleteState {\n cursorPoint: BasePoint;\n textBeforeCursor: string;\n textAfterCursor: string;\n}\nexport function areEqual_autocompleteState(\n prev: EditorAutocompleteState,\n next: EditorAutocompleteState\n) {\n return (\n prev.cursorPoint.offset === next.cursorPoint.offset &&\n arraysAreEqual(prev.cursorPoint.path, next.cursorPoint.path) &&\n prev.textBeforeCursor === next.textBeforeCursor &&\n prev.textAfterCursor === next.textAfterCursor\n );\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/types/base-autosuggestions-config.tsx"],"names":[],"mappings":";AAOO,IAAM,mCAGT;AAAA,EACF,cAAc;AAAA,EACd,yBAAyB;AAAA,EACzB,kBAAkB;AACpB","sourcesContent":["export interface BaseAutosuggestionsConfig {\n purposePrompt: string;\n debounceTime: number;\n acceptAutosuggestionKey: string;\n disableWhenEmpty: boolean;\n}\n\nexport const defaultBaseAutosuggestionsConfig: Omit<\n BaseAutosuggestionsConfig,\n \"purposePrompt\"\n> = {\n debounceTime: 500,\n acceptAutosuggestionKey: \"Tab\",\n disableWhenEmpty: true,\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/slatejs-edits/add-autocompletions.ts"],"names":[],"mappings":";AAAA,SAAoB,kBAAkB;AAG/B,SAAS,2BACd,QACA,eACA,OACA;AACA,QAAM,iBAAiB,OAAO;AAE9B,aAAW;AAAA,IACT;AAAA,IACA;AAAA,MACE;AAAA,QACE,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,SAAS;AAAA,QACT,UAAU,CAAC,EAAE,MAAM,GAAG,CAAC;AAAA,MACzB;AAAA,IACF;AAAA,IACA;AAAA,MACE,IAAI;AAAA,IACN;AAAA,EACF;AAGA,MAAI,gBAAgB;AAClB,WAAO,YAAY;AAAA,EACrB;AACF","sourcesContent":["import { BasePoint, Transforms } from \"slate\";\nimport { CustomEditor } from \"../../types/custom-editor\";\n\nexport function addAutocompletionsToEditor(\n editor: CustomEditor,\n newSuggestion: string,\n point: BasePoint\n) {\n const editorPosition = editor.selection;\n\n Transforms.insertNodes(\n editor,\n [\n {\n type: \"suggestion\",\n inline: true,\n content: newSuggestion,\n children: [{ text: \"\" }],\n },\n ],\n {\n at: point,\n }\n );\n\n // restore cursor position\n if (editorPosition) {\n editor.selection = editorPosition;\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/copilot-textarea/base-copilot-textarea/base-copilot-textarea.tsx"],"names":["_a","value"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;AAAA,EAEE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAqB,cAAc;AACnC,SAAS,UAAU,aAAa;AAChC,SAAS,eAAe;AA2JlB;AA7HC,SAAS,oBACd,OAGa;AACb,QAAM,wBAAmD,kCACpD,mCACA,MAAM;AAGX,QAAM,uBAAuB,QAAQ,MAAG;AAlD1C,QAAAA;AAkD6C,YAAAA,MAAA,MAAM,UAAN,OAAAA,MAAe;AAAA,KAAI,CAAC,CAAC;AAChE,QAAM,CAAC,yBAAyB,0BAA0B,IACxD,SAAS,oBAAoB;AAE/B,QAAM,eAA6B,QAAQ,MAAM;AAC/C,WAAO;AAAA,MACL;AAAA,QACE,MAAM;AAAA,QACN,UAAU,CAAC,EAAE,MAAM,qBAAqB,CAAC;AAAA,MAC3C;AAAA,IACF;AAAA,EACF,GAAG,CAAC,oBAAoB,CAAC;AAEzB,QAAM,SAAS,yBAAyB;AAExC,QAAM,aAAa;AAAA,IACjB,CAAC,mBAAwC;AACvC,aAAO,WAAW,QAAQ,eAAe,MAAM;AAAA,QAC7C,IAAI,eAAe;AAAA,MACrB,CAAC;AAAA,IACH;AAAA,IACA,CAAC,MAAM;AAAA,EACT;AAEA,QAAM;AAAA,IACJ;AAAA,IACA,iBAAiB;AAAA,IACjB,kBAAkB;AAAA,EACpB,IAAI;AAAA,IACF,sBAAsB;AAAA,IACtB,sBAAsB;AAAA,IACtB,MAAM;AAAA,IACN;AAAA,IACA,sBAAsB;AAAA,EACxB;AAGA,YAAU,MAAM;AACd,mCAA+B,MAAM;AACrC,QAAI,+BAA+B;AACjC;AAAA,QACE;AAAA,QACA,8BAA8B;AAAA,QAC9B,8BAA8B;AAAA,MAChC;AAAA,IACF;AAAA,EACF,GAAG,CAAC,6BAA6B,CAAC;AAElC,QAAM,wBAAwB,QAAQ,MAAM;AAC1C,UAAM,2BAAgD,mBACjD,MAAM;AAGX,WAAO,0BAA0B,wBAAwB;AAAA,EAC3D,GAAG,CAAC,MAAM,gBAAgB,CAAC;AAE3B,QAAM,4BAA4B,QAAQ,MAAM;AAE9C,UAAM,mCAAwD;AAAA,MAC5D,KAAK;AAAA,IACP;AAEA,UAAM,4BAAiD,kCAClD,mCACA,MAAM;AAGX,WAAO,8BAA8B,yBAAyB;AAAA,EAChE,GAAG,CAAC,MAAM,gBAAgB,CAAC;AAG3B,YAAU,MAAM;AAzHlB,QAAAA,KAAA;AA0HI,QAAI,MAAM,UAAU,yBAAyB;AAC3C;AAAA,IACF;AAEA,gCAA2BA,MAAA,MAAM,UAAN,OAAAA,MAAe,EAAE;AAC5C,sBAAkB,SAAQ,WAAM,UAAN,YAAe,EAAE;AAAA,EAC7C,GAAG,CAAC,MAAM,KAAK,CAAC;AAGhB,QAQI,YAPF;AAAA;AAAA,IACA;AAAA,IACA;AAAA,IACA,uBAAuB;AAAA,IACvB;AAAA,IACA;AAAA,EAzIJ,IA2IM,IADC,2BACD,IADC;AAAA,IANH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AAIF,QAAM,mBAAmB,MAAM;AAC7B,UAAM,gBAAgB;AACtB,UAAM,2BAA2B;AACjC,UAAM,kBAAkB,QAAQ,0BAA0B,gCAAa,EAAE;AACzE,WAAO,GAAG,iBAAiB;AAAA,EAC7B,GAAG;AAEH,SAEE,oBAAC;AAAA,IACC;AAAA,IACA;AAAA,IACA,UAAU,CAACC,WAAU;AAzJ3B,UAAAD;AA0JQ,YAAM,iBAAiB,oBAAoB,MAAM;AAEjD,YAAM,iBAAiB,iBACnB,eAAe,mBAAmB,eAAe,kBACjD,8BAA8B,MAAM;AAExC,iCAA2B,cAAc;AACzC,qCAA+B,cAAc;AAC7C,OAAAA,MAAA,MAAM,kBAAN,gBAAAA,IAAA,YAAsB;AAAA,IACxB;AAAA,IAEA,8BAAC;AAAA,MACC,eAAe;AAAA,MACf,mBAAmB;AAAA,MACnB,WAAW;AAAA,MACX,WAAW;AAAA,OACP,eACN;AAAA,GACF;AAEJ","sourcesContent":["// This example is for an Editor with `ReactEditor` and `HistoryEditor`\nimport {\n TextareaHTMLAttributes,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { Descendant, Editor } from \"slate\";\nimport { Editable, Slate } from \"slate-react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useAutosuggestions } from \"../../../hooks/use-autosuggestions\";\nimport { AutosuggestionsBareFunction } from \"../../../types/autosuggestions-bare-function\";\nimport { useCopilotTextareaEditor } from \"../../../hooks/use-copilot-textarea-editor\";\nimport {\n getFullEditorTextWithNewlines,\n getTextAroundCursor,\n} from \"../../../lib/get-text-around-cursor\";\nimport { addAutocompletionsToEditor } from \"../../../lib/slatejs-edits/add-autocompletions\";\nimport { clearAutocompletionsFromEditor } from \"../../../lib/slatejs-edits/clear-autocompletions\";\nimport { replaceEditorText } from \"../../../lib/slatejs-edits/replace-text\";\nimport { AutosuggestionState } from \"../../../types/autosuggestion-state\";\nimport {\n BaseAutosuggestionsConfig,\n defaultBaseAutosuggestionsConfig,\n} from \"../../../types/base-autosuggestions-config\";\nimport { makeRenderElementFunction } from \"./render-element\";\nimport { makeRenderPlaceholderFunction } from \"./render-placeholder\";\n\nexport interface BaseCopilotTextareaProps\n extends TextareaHTMLAttributes<HTMLDivElement> {\n placeholderStyle?: React.CSSProperties;\n suggestionsStyle?: React.CSSProperties;\n value?: string;\n onValueChange?: (value: string) => void;\n autosuggestionsConfig: Partial<BaseAutosuggestionsConfig> & {\n purposePrompt: string;\n };\n}\n\nexport function BaseCopilotTextarea(\n props: BaseCopilotTextareaProps & {\n autosuggestionsFunction: AutosuggestionsBareFunction;\n }\n): JSX.Element {\n const autosuggestionsConfig: BaseAutosuggestionsConfig = {\n ...defaultBaseAutosuggestionsConfig,\n ...props.autosuggestionsConfig,\n };\n\n const valueOnInitialRender = useMemo(() => props.value ?? \"\", []);\n const [lastKnownFullEditorText, setLastKnownFullEditorText] =\n useState(valueOnInitialRender);\n\n const initialValue: Descendant[] = useMemo(() => {\n return [\n {\n type: \"paragraph\",\n children: [{ text: valueOnInitialRender }],\n },\n ];\n }, [valueOnInitialRender]);\n\n const editor = useCopilotTextareaEditor();\n\n const insertText = useCallback(\n (autosuggestion: AutosuggestionState) => {\n Editor.insertText(editor, autosuggestion.text, {\n at: autosuggestion.point,\n });\n },\n [editor]\n );\n\n const {\n currentAutocompleteSuggestion,\n onChangeHandler: onChangeHandlerForAutocomplete,\n onKeyDownHandler: onKeyDownHandlerForAutocomplete,\n } = useAutosuggestions(\n autosuggestionsConfig.debounceTime,\n autosuggestionsConfig.acceptAutosuggestionKey,\n props.autosuggestionsFunction,\n insertText,\n autosuggestionsConfig.disableWhenEmpty\n );\n\n // sync autosuggestions state with the editor\n useEffect(() => {\n clearAutocompletionsFromEditor(editor);\n if (currentAutocompleteSuggestion) {\n addAutocompletionsToEditor(\n editor,\n currentAutocompleteSuggestion.text,\n currentAutocompleteSuggestion.point\n );\n }\n }, [currentAutocompleteSuggestion]);\n\n const renderElementMemoized = useMemo(() => {\n const suggestionStyleAugmented: React.CSSProperties = {\n ...props.suggestionsStyle,\n };\n\n return makeRenderElementFunction(suggestionStyleAugmented);\n }, [props.suggestionsStyle]);\n\n const renderPlaceholderMemoized = useMemo(() => {\n // For some reason slateJS specifies a top value of 0, which makes for strange styling. We override this here.\n const placeholderStyleSlatejsOverrides: React.CSSProperties = {\n top: undefined,\n };\n\n const placeholderStyleAugmented: React.CSSProperties = {\n ...placeholderStyleSlatejsOverrides,\n ...props.placeholderStyle,\n };\n\n return makeRenderPlaceholderFunction(placeholderStyleAugmented);\n }, [props.placeholderStyle]);\n\n // update the editor text, but only when the value changes from outside the component\n useEffect(() => {\n if (props.value === lastKnownFullEditorText) {\n return;\n }\n\n setLastKnownFullEditorText(props.value ?? \"\");\n replaceEditorText(editor, props.value ?? \"\");\n }, [props.value]);\n\n // separate into TextareaHTMLAttributes<HTMLDivElement> and CopilotTextareaProps\n const {\n placeholderStyle,\n value,\n onValueChange,\n autosuggestionsConfig: autosuggestionsConfigFromProps,\n autosuggestionsFunction,\n className,\n ...propsToForward\n } = props;\n\n const moddedClassName = (() => {\n const baseClassName = \"copilot-textarea\";\n const defaultTailwindClassName = \"bg-white overflow-y-auto resize-y\";\n const mergedClassName = twMerge(defaultTailwindClassName, className ?? \"\");\n return `${baseClassName} ${mergedClassName}`;\n })();\n\n return (\n // Add the editable component inside the context.\n <Slate\n editor={editor}\n initialValue={initialValue}\n onChange={(value) => {\n const newEditorState = getTextAroundCursor(editor);\n\n const fullEditorText = newEditorState\n ? newEditorState.textBeforeCursor + newEditorState.textAfterCursor\n : getFullEditorTextWithNewlines(editor); // we don't double-parse the editor. When `newEditorState` is null, we didn't parse the editor yet.\n\n setLastKnownFullEditorText(fullEditorText);\n onChangeHandlerForAutocomplete(newEditorState);\n props.onValueChange?.(fullEditorText);\n }}\n >\n <Editable\n renderElement={renderElementMemoized}\n renderPlaceholder={renderPlaceholderMemoized}\n onKeyDown={onKeyDownHandlerForAutocomplete}\n className={moddedClassName}\n {...propsToForward}\n />\n </Slate>\n );\n}\n"]}
@@ -1,3 +0,0 @@
1
-
2
- //# sourceMappingURL=out.js.map
3
- //# sourceMappingURL=chunk-JD7BAH7U.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/hooks/use-autosuggestions.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,SAAS,aAAa,SAAS,gBAAgB;AAgBxC,SAAS,mBACd,cACA,yBACA,wBACA,8BACA,kBAC0B;AAC1B,QAAM,CAAC,2BAA2B,4BAA4B,IAC5D,SAAyC,IAAI;AAE/C,QAAM,CAAC,+BAA+B,gCAAgC,IACpE,SAAqC,IAAI;AAE3C,QAAM,8BAGe;AAAA,IACnB,CACE,yBACA,gBACG;AACH,UACE,oBACA,wBAAwB,qBAAqB,MAC7C,wBAAwB,oBAAoB,IAC5C;AACA;AAAA,MACF;AAEA,YAAM,aAAa,MAAM;AAAA,QACvB,wBAAwB;AAAA,QACxB,wBAAwB;AAAA,QACxB;AAAA,MACF;AAGA,UAAI,CAAC,cAAc,YAAY,SAAS;AACtC,cAAM,IAAI,aAAa,WAAW,YAAY;AAAA,MAChD;AAEA,uCAAiC;AAAA,QAC/B,MAAM;AAAA,QACN,OAAO,wBAAwB;AAAA,MACjC,CAAC;AAAA,IACH;AAAA,IACA,CAAC,wBAAwB,kCAAkC,gBAAgB;AAAA,EAC7E;AAEA,QAAM,oBAAoB;AAAA,IACxB,MACE,IAAI;AAAA,MACF;AAAA,IACF;AAAA,IACF,CAAC,YAAY;AAAA,EACf;AAEA,QAAM,WAAW;AAAA,IACf,CAAC,mBAAmD;AAClD,YAAM,wBAAwB,CAAC;AAAA,QAC7B;AAAA,QACA;AAAA,QACA;AAAA,MACF;AACA,mCAA6B,cAAc;AAG3C,UAAI,CAAC,uBAAuB;AAC1B;AAAA,MACF;AAGA,uCAAiC,IAAI;AAGrC,UAAI,gBAAgB;AAClB,0BAAkB,SAAS,6BAA6B,cAAc;AAAA,MACxE,OAAO;AACL,0BAAkB,OAAO;AAAA,MAC3B;AAAA,IACF;AAAA,IACA;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,QAAM,iBAAiB;AAAA,IACrB,CAAC,UAA+C;AAC9C,UAAI,+BAA+B;AACjC,YAAI,MAAM,QAAQ,yBAAyB;AACzC,gBAAM,eAAe;AACrB,uCAA6B,6BAA6B;AAC1D,2CAAiC,IAAI;AAAA,QACvC;AAAA,MACF;AAAA,IACF;AAAA,IACA;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL;AAAA,IACA,iBAAiB;AAAA,IACjB,kBAAkB;AAAA,EACpB;AACF","sourcesContent":["import { useCallback, useMemo, useState } from \"react\";\nimport { Debouncer } from \"../lib/debouncer\";\nimport { nullableCompatibleEqualityCheck } from \"../lib/utils\";\nimport { AutosuggestionState } from \"../types/autosuggestion-state\";\nimport {\n EditorAutocompleteState,\n areEqual_autocompleteState,\n} from \"../types/editor-autocomplete-state\";\nimport { AutosuggestionsBareFunction } from \"../types/autosuggestions-bare-function\";\n\nexport interface UseAutosuggestionsResult {\n currentAutocompleteSuggestion: AutosuggestionState | null;\n onChangeHandler: (newEditorState: EditorAutocompleteState | null) => void;\n onKeyDownHandler: (event: React.KeyboardEvent<HTMLDivElement>) => void;\n}\n\nexport function useAutosuggestions(\n debounceTime: number,\n acceptAutosuggestionKey: string,\n autosuggestionFunction: AutosuggestionsBareFunction,\n insertAutocompleteSuggestion: (suggestion: AutosuggestionState) => void,\n disableWhenEmpty: boolean\n): UseAutosuggestionsResult {\n const [previousAutocompleteState, setPreviousAutocompleteState] =\n useState<EditorAutocompleteState | null>(null);\n\n const [currentAutocompleteSuggestion, setCurrentAutocompleteSuggestion] =\n useState<AutosuggestionState | null>(null);\n\n const awaitForAndAppendSuggestion: (\n editorAutocompleteState: EditorAutocompleteState,\n abortSignal: AbortSignal\n ) => Promise<void> = useCallback(\n async (\n editorAutocompleteState: EditorAutocompleteState,\n abortSignal: AbortSignal\n ) => {\n if (\n disableWhenEmpty &&\n editorAutocompleteState.textBeforeCursor === \"\" &&\n editorAutocompleteState.textAfterCursor === \"\"\n ) {\n return;\n }\n\n const suggestion = await autosuggestionFunction(\n editorAutocompleteState.textBeforeCursor,\n editorAutocompleteState.textAfterCursor,\n abortSignal\n );\n\n // We'll assume for now that the autocomplete function might or might not respect the abort signal.\n if (!suggestion || abortSignal.aborted) {\n throw new DOMException(\"Aborted\", \"AbortError\");\n }\n\n setCurrentAutocompleteSuggestion({\n text: suggestion,\n point: editorAutocompleteState.cursorPoint,\n });\n },\n [autosuggestionFunction, setCurrentAutocompleteSuggestion, disableWhenEmpty]\n );\n\n const debouncedFunction = useMemo(\n () =>\n new Debouncer<[editorAutocompleteState: EditorAutocompleteState]>(\n debounceTime\n ),\n [debounceTime]\n );\n\n const onChange = useCallback(\n (newEditorState: EditorAutocompleteState | null) => {\n const editorStateHasChanged = !nullableCompatibleEqualityCheck(\n areEqual_autocompleteState,\n previousAutocompleteState,\n newEditorState\n );\n setPreviousAutocompleteState(newEditorState);\n\n // if no change, do nothing\n if (!editorStateHasChanged) {\n return;\n }\n\n // if change, then first null out the current suggestion\n setCurrentAutocompleteSuggestion(null);\n\n // then try to get a new suggestion, debouncing to avoid too many requests while typing\n if (newEditorState) {\n debouncedFunction.debounce(awaitForAndAppendSuggestion, newEditorState);\n } else {\n debouncedFunction.cancel();\n }\n },\n [\n previousAutocompleteState,\n setPreviousAutocompleteState,\n debouncedFunction,\n awaitForAndAppendSuggestion,\n setCurrentAutocompleteSuggestion,\n ]\n );\n\n const keyDownHandler = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (currentAutocompleteSuggestion) {\n if (event.key === acceptAutosuggestionKey) {\n event.preventDefault();\n insertAutocompleteSuggestion(currentAutocompleteSuggestion);\n setCurrentAutocompleteSuggestion(null);\n }\n }\n },\n [\n currentAutocompleteSuggestion,\n setCurrentAutocompleteSuggestion,\n insertAutocompleteSuggestion,\n acceptAutosuggestionKey,\n ]\n );\n\n return {\n currentAutocompleteSuggestion,\n onChangeHandler: onChange,\n onKeyDownHandler: keyDownHandler,\n };\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/copilot-textarea/base-copilot-textarea/render-placeholder.tsx"],"names":[],"mappings":";;;;;;;AAaM;AAPC,SAAS,8BACd,kBAC2B;AAC3B,SAAO,CAAC,UAAkC;AACxC,UAAqC,WAAM,YAAnC,QAVZ,IAUyC,IAAnB,2BAAmB,IAAnB,CAAV;AAER,WACE,oBAAC,wCACK,iBADL;AAAA,MAEC,OAAO,kCACF,QACA;AAAA,MAGJ,gBAAM;AAAA,MACT;AAAA,EAEJ;AACF","sourcesContent":["import { RenderElementProps, RenderPlaceholderProps } from \"slate-react\";\n\nexport type RenderPlaceholderFunction = (\n props: RenderPlaceholderProps\n) => JSX.Element;\n\nexport function makeRenderPlaceholderFunction(\n placeholderStyle?: React.CSSProperties\n): RenderPlaceholderFunction {\n return (props: RenderPlaceholderProps) => {\n const { style, ...restAttributes } = props.attributes;\n\n return (\n <div\n {...restAttributes}\n style={{\n ...style,\n ...placeholderStyle,\n }}\n >\n {props.children}\n </div>\n );\n };\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/hooks/use-copilot-textarea-editor.tsx"],"names":["editor"],"mappings":";;;;;;AAAA,SAAS,cAAc,eAAe;AACtC,SAAS,iBAAiB;AAC1B,SAAS,eAAe;AAQxB,IAAM,aAAkC,CAAC,IAAI,SAAS;AACpD,QAAM,mBAAmB;AAEzB,MACE,GAAG,SAAS,iBACZ,QAAQ,UAAU,GAAG,IAAI,KACzB,GAAG,KAAK,SAAS,kBACjB;AACA,WAAO;AAAA,EACT;AAEA,MACE,GAAG,SAAS,iBACZ,QAAQ,UAAU,GAAG,IAAI,KACzB,GAAG,KAAK,SAAS,kBACjB;AACA,WAAO;AAAA,EACT;AAEA,MACE,GAAG,SAAS,cACZ,UAAU,GAAG,iBACb,GAAG,cAAc,SAAS,kBAC1B;AACA,WAAO;AAAA,EACT;AAEA,MACE,GAAG,QAAQ,cACX,UAAU,GAAG,cACb,GAAG,WAAW,SAAS,kBACvB;AACA,WAAO;AAAA,EACT;AAEA,MACE,GAAG,SAAS,gBACZ,UAAU,GAAG,cACb,GAAG,WAAW,SAAS,kBACvB;AACA,WAAO;AAAA,EACT;AAEA,MACE,GAAG,SAAS,gBACZ,UAAU,GAAG,cACb,GAAG,WAAW,SAAS,kBACvB;AACA,WAAO;AAAA,EACT;AAGA,SAAO,kBAAkB,IAAI,IAAI;AACnC;AAEO,SAAS,2BAAyC;AACvD,QAAM,SAAS,QAAQ,MAAM;AAC3B,UAAMA,UAAS,mBAAmB,UAAU,aAAa,CAAC,GAAG,UAAU;AAEvE,UAAM,EAAE,OAAO,IAAIA;AACnB,IAAAA,QAAO,SAAS,CAAC,YAAY;AAC3B,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK;AACH,iBAAO;AAAA,QACT;AACE,iBAAO,OAAO,OAAO;AAAA,MACzB;AAAA,IACF;AAEA,UAAM,EAAE,aAAa,IAAIA;AACzB,IAAAA,QAAO,eAAe,CAAC,YAAY;AACjC,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK;AACH,iBAAO;AAAA,QACT;AACE,iBAAO,aAAa,OAAO;AAAA,MAC/B;AAAA,IACF;AAEA,UAAM,EAAE,SAAS,IAAIA;AACrB,IAAAA,QAAO,WAAW,CAAC,YAAY;AAC7B,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK;AACH,iBAAO,QAAQ;AAAA,QACjB;AACE,iBAAO,SAAS,OAAO;AAAA,MAC3B;AAAA,IACF;AAEA,WAAOA;AAAA,EACT,GAAG,CAAC,CAAC;AAEL,SAAO;AACT","sourcesContent":["import { createEditor, Element } from \"slate\";\nimport { withReact } from \"slate-react\";\nimport { useMemo } from \"react\";\nimport { CustomEditor } from \"../types/custom-editor\";\nimport {\n withPartialHistory,\n ShouldSaveToHistory,\n defaultShouldSave,\n} from \"../lib/slatejs-edits/with-partial-history\";\n\nconst shouldSave: ShouldSaveToHistory = (op, prev) => {\n const excludedNodeType = \"suggestion\";\n // Check if the operation involves the suggestion inline node type\n if (\n op.type === \"insert_node\" &&\n Element.isElement(op.node) &&\n op.node.type === excludedNodeType\n ) {\n return false;\n }\n\n if (\n op.type === \"remove_node\" &&\n Element.isElement(op.node) &&\n op.node.type === excludedNodeType\n ) {\n return false;\n }\n\n if (\n op.type === \"set_node\" &&\n \"type\" in op.newProperties &&\n op.newProperties.type === excludedNodeType\n ) {\n return false;\n }\n\n if (\n op.type == \"set_node\" &&\n \"type\" in op.properties &&\n op.properties.type === excludedNodeType\n ) {\n return false;\n }\n\n if (\n op.type === \"merge_node\" &&\n \"type\" in op.properties &&\n op.properties.type === excludedNodeType\n ) {\n return false;\n }\n\n if (\n op.type === \"split_node\" &&\n \"type\" in op.properties &&\n op.properties.type === excludedNodeType\n ) {\n return false;\n }\n\n // Otherwise, save the operation to history\n return defaultShouldSave(op, prev);\n};\n\nexport function useCopilotTextareaEditor(): CustomEditor {\n const editor = useMemo(() => {\n const editor = withPartialHistory(withReact(createEditor()), shouldSave);\n\n const { isVoid } = editor;\n editor.isVoid = (element) => {\n switch (element.type) {\n case \"suggestion\":\n return true;\n default:\n return isVoid(element);\n }\n };\n\n const { markableVoid } = editor;\n editor.markableVoid = (element) => {\n switch (element.type) {\n case \"suggestion\":\n return true;\n default:\n return markableVoid(element);\n }\n };\n\n const { isInline } = editor;\n editor.isInline = (element) => {\n switch (element.type) {\n case \"suggestion\":\n return element.inline;\n default:\n return isInline(element);\n }\n };\n\n return editor;\n }, []);\n\n return editor;\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/get-text-around-cursor.ts"],"names":[],"mappings":";AAAA,SAAS,QAAc,MAAM,OAAO,MAAM,eAAe;AAGlD,SAAS,oBACd,QACgC;AAChC,QAAM,EAAE,UAAU,IAAI;AAEtB,MAAI,CAAC,aAAa,CAAC,MAAM,YAAY,SAAS,GAAG;AAC/C,WAAO;AAAA,EACT;AAEA,QAAM,cAAqB;AAAA,IACzB,QAAQ,OAAO,MAAM,QAAQ,CAAC,CAAC;AAAA,IAC/B,OAAO,UAAU;AAAA,EACnB;AACA,QAAM,aAAoB;AAAA,IACxB,QAAQ,UAAU;AAAA,IAClB,OAAO,OAAO,IAAI,QAAQ,CAAC,CAAC;AAAA,EAC9B;AAGA,QAAM,SAAS,wBAAwB,QAAQ,WAAW;AAC1D,QAAM,QAAQ,wBAAwB,QAAQ,UAAU;AAExD,SAAO;AAAA,IACL,aAAa,UAAU;AAAA,IACvB,kBAAkB;AAAA,IAClB,iBAAiB;AAAA,EACnB;AACF;AAEO,SAAS,8BAA8B,QAAwB;AACpE,QAAM,oBAA2B;AAAA,IAC/B,QAAQ,OAAO,MAAM,QAAQ,CAAC,CAAC;AAAA,IAC/B,OAAO,OAAO,IAAI,QAAQ,CAAC,CAAC;AAAA,EAC9B;AACA,SAAO,wBAAwB,QAAQ,iBAAiB;AAC1D;AAGO,SAAS,wBAAwB,QAAgB,OAAsB;AAC5E,QAAM,QAAQ;AACd,QAAM,CAAC,OAAO,GAAG,IAAI,MAAM,MAAM,KAAK;AACtC,MAAI,OAAO;AACX,MAAI,YAAyB;AAE7B,aAAW,CAAC,MAAM,IAAI,KAAK,OAAO,MAAM,QAAQ;AAAA,IAC9C,IAAI;AAAA,IACJ,OAAO,KAAK;AAAA,IACZ;AAAA,EACF,CAAC,GAAG;AACF,QAAI,IAAI,KAAK;AAGb,UAAM,CAAC,KAAK,IAAI,OAAO,MAAM,QAAQ;AAAA,MACnC,IAAI;AAAA,MACJ,OAAO,CAAC,MAAM,QAAQ,UAAU,CAAC,KAAK,EAAE,SAAS;AAAA,IACnD,CAAC,KAAK,CAAC,IAAI;AAGX,QAAI,cAAc,SAAS,OAAO;AAEhC,UAAI,WAAW;AACb,gBAAQ;AAAA,MACV;AACA,kBAAY;AAAA,IACd;AAEA,QAAI,KAAK,OAAO,MAAM,IAAI,IAAI,GAAG;AAC/B,UAAI,EAAE,MAAM,GAAG,IAAI,MAAM;AAAA,IAC3B;AAEA,QAAI,KAAK,OAAO,MAAM,MAAM,IAAI,GAAG;AACjC,UAAI,EAAE,MAAM,MAAM,MAAM;AAAA,IAC1B;AAEA,YAAQ;AAAA,EACV;AAEA,SAAO;AACT","sourcesContent":["import { Editor, Node, Path, Range, Text, Element } from \"slate\";\nimport { EditorAutocompleteState } from \"../types/editor-autocomplete-state\";\n\nexport function getTextAroundCursor(\n editor: Editor\n): EditorAutocompleteState | null {\n const { selection } = editor;\n\n if (!selection || !Range.isCollapsed(selection)) {\n return null;\n }\n // Create two ranges: one before the anchor and one after\n const beforeRange: Range = {\n anchor: Editor.start(editor, []),\n focus: selection.anchor,\n };\n const afterRange: Range = {\n anchor: selection.anchor,\n focus: Editor.end(editor, []),\n };\n\n // Extract text for these ranges\n const before = extractTextWithNewlines(editor, beforeRange);\n const after = extractTextWithNewlines(editor, afterRange);\n\n return {\n cursorPoint: selection.anchor,\n textBeforeCursor: before,\n textAfterCursor: after,\n };\n}\n\nexport function getFullEditorTextWithNewlines(editor: Editor): string {\n const fullDocumentRange: Range = {\n anchor: Editor.start(editor, []),\n focus: Editor.end(editor, []),\n };\n return extractTextWithNewlines(editor, fullDocumentRange);\n}\n\n// Helper function to extract text with newlines\nexport function extractTextWithNewlines(editor: Editor, range: Range): string {\n const voids = false;\n const [start, end] = Range.edges(range);\n let text = \"\";\n let lastBlock: Node | null = null;\n\n for (const [node, path] of Editor.nodes(editor, {\n at: range,\n match: Text.isText,\n voids,\n })) {\n let t = node.text;\n\n // Determine the parent block of the current text node\n const [block] = Editor.above(editor, {\n at: path,\n match: (n) => Element.isElement(n) && n.type === \"paragraph\",\n }) || [null];\n\n // If we encounter a new block, prepend a newline\n if (lastBlock !== block && block) {\n // check that lastBlock is not null to avoid adding a newline at the beginning\n if (lastBlock) {\n text += \"\\n\";\n }\n lastBlock = block;\n }\n\n if (Path.equals(path, end.path)) {\n t = t.slice(0, end.offset);\n }\n\n if (Path.equals(path, start.path)) {\n t = t.slice(start.offset);\n }\n\n text += t;\n }\n\n return text;\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/components/copilot-textarea/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;AAAA,MACL,WAAW;AAAA,MACX,OAAO;AAAA,OACJ,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 fontStyle: \"italic\",\n color: \"gray\",\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-YPBKY4KY.mjs.map
@@ -1,17 +0,0 @@
1
- export { BaseCopilotTextarea } from '../../../chunk-GOAPCQCR.mjs';
2
- import '../../../chunk-ETGKLURC.mjs';
3
- import '../../../chunk-RVJAOO4S.mjs';
4
- import '../../../chunk-TSF4AJIK.mjs';
5
- import '../../../chunk-Y5BUWZOI.mjs';
6
- import '../../../chunk-KKG2RK2T.mjs';
7
- import '../../../chunk-X4FJ6WVZ.mjs';
8
- import '../../../chunk-5SJM4R4K.mjs';
9
- import '../../../chunk-JJASB23A.mjs';
10
- import '../../../chunk-4LJAS777.mjs';
11
- import '../../../chunk-KGKLUWKW.mjs';
12
- import '../../../chunk-L24ZN4LL.mjs';
13
- import '../../../chunk-KCHYD3EB.mjs';
14
- import '../../../chunk-NKW5OU2S.mjs';
15
- import '../../../chunk-MRXNTQOX.mjs';
16
- //# sourceMappingURL=out.js.map
17
- //# sourceMappingURL=base-copilot-textarea.mjs.map
@@ -1,4 +0,0 @@
1
- export { makeRenderElementFunction } from '../../../chunk-Y5BUWZOI.mjs';
2
- import '../../../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
4
- //# sourceMappingURL=render-element.mjs.map
@@ -1,4 +0,0 @@
1
- export { makeRenderPlaceholderFunction } from '../../../chunk-KKG2RK2T.mjs';
2
- import '../../../chunk-MRXNTQOX.mjs';
3
- //# sourceMappingURL=out.js.map
4
- //# sourceMappingURL=render-placeholder.mjs.map