@ai-stack/payloadcms 3.0.0-beta.104.2 → 3.0.0-beta.65.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (194) hide show
  1. package/README.md +2 -16
  2. package/dist/ai/{schemas → editor}/lexical.schema.d.ts +2 -2
  3. package/dist/ai/editor/lexical.schema.d.ts.map +1 -0
  4. package/dist/ai/editor/lexical.schema.js.map +1 -0
  5. package/dist/ai/models/anthropic/generateRichText.js.map +1 -1
  6. package/dist/ai/models/anthropic/index.d.ts.map +1 -1
  7. package/dist/ai/models/anthropic/index.js +3 -3
  8. package/dist/ai/models/anthropic/index.js.map +1 -1
  9. package/dist/ai/models/elevenLabs/index.d.ts.map +1 -1
  10. package/dist/ai/models/elevenLabs/index.js +11 -1
  11. package/dist/ai/models/elevenLabs/index.js.map +1 -1
  12. package/dist/ai/models/index.js +2 -2
  13. package/dist/ai/models/index.js.map +1 -1
  14. package/dist/ai/models/openai/generateRichText.js.map +1 -1
  15. package/dist/ai/models/openai/index.d.ts.map +1 -1
  16. package/dist/ai/models/openai/index.js +2 -3
  17. package/dist/ai/models/openai/index.js.map +1 -1
  18. package/dist/ai/models/style.d.ts +2 -0
  19. package/dist/ai/models/style.d.ts.map +1 -0
  20. package/dist/ai/models/style.js +31 -0
  21. package/dist/ai/models/style.js.map +1 -0
  22. package/dist/ai/prompts.d.ts +0 -1
  23. package/dist/ai/prompts.d.ts.map +1 -1
  24. package/dist/ai/prompts.js +2 -8
  25. package/dist/ai/prompts.js.map +1 -1
  26. package/dist/ai/utils/generateFileNameByPrompt.js.map +1 -1
  27. package/dist/collections/Instructions.d.ts.map +1 -1
  28. package/dist/collections/Instructions.js +12 -9
  29. package/dist/collections/Instructions.js.map +1 -1
  30. package/dist/defaults.d.ts +1 -1
  31. package/dist/defaults.d.ts.map +1 -1
  32. package/dist/defaults.js +1 -1
  33. package/dist/defaults.js.map +1 -1
  34. package/dist/endpoints/index.d.ts +1 -1
  35. package/dist/endpoints/index.d.ts.map +1 -1
  36. package/dist/endpoints/index.js +51 -17
  37. package/dist/endpoints/index.js.map +1 -1
  38. package/dist/exports/fields.d.ts +1 -3
  39. package/dist/exports/fields.d.ts.map +1 -1
  40. package/dist/exports/fields.js +0 -3
  41. package/dist/exports/fields.js.map +1 -1
  42. package/dist/fields/DescriptionField/DescriptionField.d.ts +3 -0
  43. package/dist/fields/DescriptionField/DescriptionField.d.ts.map +1 -0
  44. package/dist/fields/DescriptionField/DescriptionField.js +15 -0
  45. package/dist/fields/DescriptionField/DescriptionField.js.map +1 -0
  46. package/dist/fields/DescriptionField/DescriptionFieldComponent.d.ts +4 -0
  47. package/dist/fields/DescriptionField/DescriptionFieldComponent.d.ts.map +1 -0
  48. package/dist/fields/{ComposeField/ComposeField.js → DescriptionField/DescriptionFieldComponent.js} +5 -5
  49. package/dist/fields/DescriptionField/DescriptionFieldComponent.js.map +1 -0
  50. package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts +2 -0
  51. package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts.map +1 -0
  52. package/dist/fields/LexicalEditor/{ComposeFeatureComponent.js → ActionsFeatureComponent.js} +5 -5
  53. package/dist/fields/LexicalEditor/ActionsFeatureComponent.js.map +1 -0
  54. package/dist/fields/LexicalEditor/feature.client.d.ts +4 -1
  55. package/dist/fields/LexicalEditor/feature.client.d.ts.map +1 -1
  56. package/dist/fields/LexicalEditor/feature.client.js +2 -2
  57. package/dist/fields/LexicalEditor/feature.client.js.map +1 -1
  58. package/dist/fields/LexicalEditor/feature.server.d.ts +7 -1
  59. package/dist/fields/LexicalEditor/feature.server.d.ts.map +1 -1
  60. package/dist/fields/LexicalEditor/feature.server.js +11 -3
  61. package/dist/fields/LexicalEditor/feature.server.js.map +1 -1
  62. package/dist/fields/PromptEditorField/PromptEditorField.d.ts +2 -2
  63. package/dist/fields/PromptEditorField/PromptEditorField.d.ts.map +1 -1
  64. package/dist/fields/PromptEditorField/PromptEditorField.js +51 -32
  65. package/dist/fields/PromptEditorField/PromptEditorField.js.map +1 -1
  66. package/dist/fields/SelectField/SelectField.d.ts +2 -9
  67. package/dist/fields/SelectField/SelectField.d.ts.map +1 -1
  68. package/dist/fields/SelectField/SelectField.js +23 -26
  69. package/dist/fields/SelectField/SelectField.js.map +1 -1
  70. package/dist/index.d.ts +2 -2
  71. package/dist/index.d.ts.map +1 -1
  72. package/dist/index.js +3 -3
  73. package/dist/index.js.map +1 -1
  74. package/dist/init.d.ts +1 -2
  75. package/dist/init.d.ts.map +1 -1
  76. package/dist/init.js +9 -26
  77. package/dist/init.js.map +1 -1
  78. package/dist/plugin.d.ts.map +1 -1
  79. package/dist/plugin.js +8 -27
  80. package/dist/plugin.js.map +1 -1
  81. package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts +3 -1
  82. package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts.map +1 -1
  83. package/dist/providers/InstructionsProvider/InstructionsProvider.js.map +1 -1
  84. package/dist/providers/InstructionsProvider/hook.d.ts +9 -0
  85. package/dist/providers/InstructionsProvider/hook.d.ts.map +1 -0
  86. package/dist/providers/InstructionsProvider/hook.js +17 -0
  87. package/dist/providers/InstructionsProvider/hook.js.map +1 -0
  88. package/dist/providers/InstructionsProvider/index.d.ts +5 -0
  89. package/dist/providers/InstructionsProvider/index.d.ts.map +1 -0
  90. package/dist/providers/InstructionsProvider/index.js +10 -0
  91. package/dist/providers/InstructionsProvider/index.js.map +1 -0
  92. package/dist/types.d.ts +1 -2
  93. package/dist/types.d.ts.map +1 -1
  94. package/dist/types.js.map +1 -1
  95. package/dist/ui/Actions/Actions.d.ts +5 -0
  96. package/dist/ui/Actions/Actions.d.ts.map +1 -0
  97. package/dist/ui/{Compose/Compose.js → Actions/Actions.js} +9 -9
  98. package/dist/ui/Actions/Actions.js.map +1 -0
  99. package/dist/ui/{Compose → Actions}/UndoRedoActions.d.ts.map +1 -1
  100. package/dist/ui/{Compose → Actions}/UndoRedoActions.js +2 -15
  101. package/dist/ui/Actions/UndoRedoActions.js.map +1 -0
  102. package/dist/ui/{Compose → Actions}/hooks/menu/Item.d.ts.map +1 -1
  103. package/dist/ui/{Compose → Actions}/hooks/menu/Item.js.map +1 -1
  104. package/dist/ui/Actions/hooks/menu/TranslateMenu.d.ts.map +1 -0
  105. package/dist/ui/{Compose → Actions}/hooks/menu/TranslateMenu.js.map +1 -1
  106. package/dist/ui/{Compose → Actions}/hooks/menu/items.d.ts.map +1 -1
  107. package/dist/ui/{Compose → Actions}/hooks/menu/items.js.map +1 -1
  108. package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.d.ts.map +1 -1
  109. package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.js.map +1 -1
  110. package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.d.ts.map +1 -1
  111. package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.js.map +1 -1
  112. package/dist/ui/{Compose → Actions}/hooks/useGenerate.d.ts.map +1 -1
  113. package/dist/ui/{Compose → Actions}/hooks/useGenerate.js +6 -5
  114. package/dist/ui/Actions/hooks/useGenerate.js.map +1 -0
  115. package/dist/ui/Actions/hooks/useHistory.d.ts.map +1 -0
  116. package/dist/ui/{Compose → Actions}/hooks/useHistory.js +1 -3
  117. package/dist/ui/Actions/hooks/useHistory.js.map +1 -0
  118. package/dist/ui/Floatype/Floatype.d.ts +21 -0
  119. package/dist/ui/Floatype/Floatype.d.ts.map +1 -0
  120. package/dist/ui/Floatype/Floatype.js +245 -0
  121. package/dist/ui/Floatype/Floatype.js.map +1 -0
  122. package/dist/ui/Floatype/floatype.module.css +25 -0
  123. package/dist/utilities/getFieldBySchemaPath.d.ts +2 -2
  124. package/dist/utilities/getFieldBySchemaPath.d.ts.map +1 -1
  125. package/dist/utilities/getFieldBySchemaPath.js.map +1 -1
  126. package/dist/utilities/updateFieldsConfig.d.ts.map +1 -1
  127. package/dist/utilities/updateFieldsConfig.js +8 -14
  128. package/dist/utilities/updateFieldsConfig.js.map +1 -1
  129. package/package.json +30 -49
  130. package/dist/ai/schemas/lexical.schema.d.ts.map +0 -1
  131. package/dist/ai/schemas/lexical.schema.js.map +0 -1
  132. package/dist/exports/client.d.ts +0 -3
  133. package/dist/exports/client.d.ts.map +0 -1
  134. package/dist/exports/client.js +0 -4
  135. package/dist/exports/client.js.map +0 -1
  136. package/dist/fields/ComposeField/ComposeField.d.ts +0 -4
  137. package/dist/fields/ComposeField/ComposeField.d.ts.map +0 -1
  138. package/dist/fields/ComposeField/ComposeField.js.map +0 -1
  139. package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts +0 -2
  140. package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts.map +0 -1
  141. package/dist/fields/LexicalEditor/ComposeFeatureComponent.js.map +0 -1
  142. package/dist/libraries/autocomplete/AutocompleteTextArea.d.ts +0 -8
  143. package/dist/libraries/autocomplete/AutocompleteTextArea.d.ts.map +0 -1
  144. package/dist/libraries/autocomplete/AutocompleteTextArea.js +0 -437
  145. package/dist/libraries/autocomplete/AutocompleteTextArea.js.map +0 -1
  146. package/dist/libraries/autocomplete/AutocompleteTextArea.module.scss +0 -35
  147. package/dist/libraries/handlebars/asyncHandlebars.d.ts +0 -2
  148. package/dist/libraries/handlebars/asyncHandlebars.d.ts.map +0 -1
  149. package/dist/libraries/handlebars/asyncHandlebars.js +0 -5
  150. package/dist/libraries/handlebars/asyncHandlebars.js.map +0 -1
  151. package/dist/libraries/handlebars/helpers.d.ts +0 -2
  152. package/dist/libraries/handlebars/helpers.d.ts.map +0 -1
  153. package/dist/libraries/handlebars/helpers.js +0 -22
  154. package/dist/libraries/handlebars/helpers.js.map +0 -1
  155. package/dist/libraries/handlebars/helpersMap.d.ts +0 -12
  156. package/dist/libraries/handlebars/helpersMap.d.ts.map +0 -1
  157. package/dist/libraries/handlebars/helpersMap.js +0 -13
  158. package/dist/libraries/handlebars/helpersMap.js.map +0 -1
  159. package/dist/libraries/handlebars/replacePlaceholders.d.ts +0 -2
  160. package/dist/libraries/handlebars/replacePlaceholders.d.ts.map +0 -1
  161. package/dist/libraries/handlebars/replacePlaceholders.js +0 -8
  162. package/dist/libraries/handlebars/replacePlaceholders.js.map +0 -1
  163. package/dist/providers/InstructionsProvider/useInstructions.d.ts +0 -4
  164. package/dist/providers/InstructionsProvider/useInstructions.d.ts.map +0 -1
  165. package/dist/providers/InstructionsProvider/useInstructions.js +0 -38
  166. package/dist/providers/InstructionsProvider/useInstructions.js.map +0 -1
  167. package/dist/ui/Compose/Compose.d.ts +0 -9
  168. package/dist/ui/Compose/Compose.d.ts.map +0 -1
  169. package/dist/ui/Compose/Compose.js.map +0 -1
  170. package/dist/ui/Compose/UndoRedoActions.js.map +0 -1
  171. package/dist/ui/Compose/hooks/menu/TranslateMenu.d.ts.map +0 -1
  172. package/dist/ui/Compose/hooks/useGenerate.js.map +0 -1
  173. package/dist/ui/Compose/hooks/useHistory.d.ts.map +0 -1
  174. package/dist/ui/Compose/hooks/useHistory.js.map +0 -1
  175. package/dist/utilities/getFieldInfo.d.ts +0 -3
  176. package/dist/utilities/getFieldInfo.d.ts.map +0 -1
  177. package/dist/utilities/getFieldInfo.js +0 -14
  178. package/dist/utilities/getFieldInfo.js.map +0 -1
  179. /package/dist/ai/{schemas → editor}/lexical.schema.js +0 -0
  180. /package/dist/ui/{Compose → Actions}/UndoRedoActions.d.ts +0 -0
  181. /package/dist/ui/{Compose/compose.module.scss → Actions/actions.module.scss} +0 -0
  182. /package/dist/ui/{Compose → Actions}/hooks/menu/Item.d.ts +0 -0
  183. /package/dist/ui/{Compose → Actions}/hooks/menu/Item.js +0 -0
  184. /package/dist/ui/{Compose → Actions}/hooks/menu/TranslateMenu.d.ts +0 -0
  185. /package/dist/ui/{Compose → Actions}/hooks/menu/TranslateMenu.js +0 -0
  186. /package/dist/ui/{Compose → Actions}/hooks/menu/items.d.ts +0 -0
  187. /package/dist/ui/{Compose → Actions}/hooks/menu/items.js +0 -0
  188. /package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.d.ts +0 -0
  189. /package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.js +0 -0
  190. /package/dist/ui/{Compose → Actions}/hooks/menu/menu.module.scss +0 -0
  191. /package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.d.ts +0 -0
  192. /package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.js +0 -0
  193. /package/dist/ui/{Compose → Actions}/hooks/useGenerate.d.ts +0 -0
  194. /package/dist/ui/{Compose → Actions}/hooks/useHistory.d.ts +0 -0
@@ -1,8 +0,0 @@
1
- /**
2
- * Credit: Yury Dymov
3
- * Github: https://github.com/yury-dymov/react-autocomplete-input
4
- *
5
- * Modified to only be use for PromptEditorField
6
- */
7
- export declare const AutocompleteTextField: (props: any) => import("react/jsx-runtime").JSX.Element;
8
- //# sourceMappingURL=AutocompleteTextArea.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"AutocompleteTextArea.d.ts","sourceRoot":"","sources":["../../../src/libraries/autocomplete/AutocompleteTextArea.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAmBH,eAAO,MAAM,qBAAqB,yDAkgBjC,CAAA"}
@@ -1,437 +0,0 @@
1
- /**
2
- * Credit: Yury Dymov
3
- * Github: https://github.com/yury-dymov/react-autocomplete-input
4
- *
5
- * Modified to only be use for PromptEditorField
6
- */ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
7
- import * as inputSelection from 'get-input-selection';
8
- import isEqual from 'lodash.isequal';
9
- import React, { useCallback, useEffect, useRef, useState } from 'react';
10
- import scrollIntoView from 'scroll-into-view-if-needed';
11
- import getCaretCoordinates from 'textarea-caret';
12
- import styles from './AutocompleteTextArea.module.scss';
13
- const KEY_UP = 38;
14
- const KEY_DOWN = 40;
15
- const KEY_RETURN = 13;
16
- const KEY_ENTER = 14;
17
- const KEY_ESCAPE = 27;
18
- const KEY_TAB = 9;
19
- const OPTION_LIST_MIN_WIDTH = 100;
20
- export const AutocompleteTextField = (props)=>{
21
- const { changeOnSelect = (trigger, slug)=>trigger + slug, defaultValue = '', disabled = false, matchAny = false, maxOptions = 10, minChars = 0, offsetX = 0, offsetY = 0, onBlur = (e)=>{}, onChange = (e)=>{}, onKeyDown = (e)=>{}, onRequestOptions = (e)=>{}, onSelect = (e)=>{}, options = [], passThroughEnter = false, passThroughTab = true, regex = '^[A-Za-z0-9\\-_]+$', requestOnlyIfNoOptions = true, spaceRemovers = [
22
- ',',
23
- '.',
24
- '!',
25
- '?'
26
- ], spacer = ' ', trigger = '@', triggerCaseInsensitive = false, triggerMatchWholeWord = false, value: propValue = null, ...rest } = props;
27
- const [helperVisible, setHelperVisible] = useState(false);
28
- const [left, setLeft] = useState(0);
29
- const [top, setTop] = useState(0);
30
- const [triggerChar, setTriggerChar] = useState(null);
31
- const [matchLength, setMatchLength] = useState(0);
32
- const [matchStart, setMatchStart] = useState(0);
33
- const [selection, setSelection] = useState(0);
34
- const [value, setValue] = useState(null);
35
- const [caret, setCaret] = useState(0);
36
- const [currentOptions, setCurrentOptions] = useState([]);
37
- const recentValue = useRef(defaultValue);
38
- const enableSpaceRemovers = useRef(false);
39
- const inputRef = useRef(null);
40
- const currentRef = useRef(null);
41
- const parentRef = useRef(null);
42
- useEffect(()=>{
43
- window.addEventListener('resize', handleResize);
44
- window.addEventListener('scroll', handleResize);
45
- return ()=>{
46
- window.removeEventListener('resize', handleResize);
47
- window.removeEventListener('scroll', handleResize);
48
- };
49
- }, []);
50
- useEffect(()=>{
51
- if (!isEqual(options, currentOptions)) {
52
- updateHelper(recentValue.current, caret, options);
53
- }
54
- }, [
55
- options,
56
- caret
57
- ]);
58
- useEffect(()=>{
59
- if (helperVisible && currentRef.current) {
60
- scrollIntoView(currentRef.current, {
61
- boundary: parentRef.current,
62
- scrollMode: 'if-needed'
63
- });
64
- }
65
- }, [
66
- helperVisible,
67
- selection
68
- ]);
69
- const handleResize = useCallback(()=>{
70
- setHelperVisible(false);
71
- }, []);
72
- const isTrigger = useCallback((triggerStr, str, i)=>{
73
- if (!triggerStr || !triggerStr.length) {
74
- return true;
75
- }
76
- if (triggerMatchWholeWord && i > 0 && str.charAt(i - 1).match(/\w/)) {
77
- return false;
78
- }
79
- if (str.substr(i, triggerStr.length) === triggerStr || triggerCaseInsensitive && str.substr(i, triggerStr.length).toLowerCase() === triggerStr.toLowerCase()) {
80
- return true;
81
- }
82
- return false;
83
- }, [
84
- triggerMatchWholeWord,
85
- triggerCaseInsensitive
86
- ]);
87
- const arrayTriggerMatch = useCallback((triggers, re)=>{
88
- return triggers.map((trigger)=>({
89
- triggerLength: trigger.length,
90
- triggerMatch: trigger.match(re),
91
- triggerStr: trigger
92
- }));
93
- }, []);
94
- const getMatch = useCallback((str, caret, providedOptions)=>{
95
- const re = new RegExp(regex);
96
- const triggers = Array.isArray(trigger) ? trigger : [
97
- trigger
98
- ];
99
- triggers.sort();
100
- const providedOptionsObject = Array.isArray(providedOptions) ? triggers.reduce((acc, triggerStr)=>({
101
- ...acc,
102
- [triggerStr]: providedOptions
103
- }), {}) : providedOptions;
104
- const triggersMatch = arrayTriggerMatch(triggers, re);
105
- let slugData = null;
106
- for(let triggersIndex = 0; triggersIndex < triggersMatch.length; triggersIndex++){
107
- const { triggerLength, triggerMatch, triggerStr } = triggersMatch[triggersIndex];
108
- for(let i = caret - 1; i >= 0; --i){
109
- const substr = str.substring(i, caret);
110
- const match = substr.match(re);
111
- let matchStart = -1;
112
- if (triggerLength > 0) {
113
- const triggerIdx = triggerMatch ? i : i - triggerLength + 1;
114
- if (triggerIdx < 0) {
115
- break;
116
- }
117
- if (isTrigger(triggerStr, str, triggerIdx)) {
118
- matchStart = triggerIdx + triggerLength;
119
- }
120
- if (!match && matchStart < 0) {
121
- break;
122
- }
123
- } else {
124
- if (match && i > 0) {
125
- continue;
126
- }
127
- matchStart = i === 0 && match ? 0 : i + 1;
128
- if (caret - matchStart === 0) {
129
- break;
130
- }
131
- }
132
- if (matchStart >= 0) {
133
- const triggerOptions = providedOptionsObject[triggerStr];
134
- if (triggerOptions == null) {
135
- continue;
136
- }
137
- const matchedSlug = str.substring(matchStart, caret);
138
- const filteredOptions = triggerOptions.filter((slug)=>{
139
- const idx = slug.toLowerCase().indexOf(matchedSlug.toLowerCase());
140
- return idx !== -1 && (matchAny || idx === 0);
141
- });
142
- const currTrigger = triggerStr;
143
- const matchLength = matchedSlug.length;
144
- slugData = {
145
- matchLength,
146
- matchStart,
147
- options: filteredOptions,
148
- trigger: currTrigger
149
- };
150
- }
151
- }
152
- }
153
- return slugData;
154
- }, [
155
- regex,
156
- trigger,
157
- arrayTriggerMatch,
158
- isTrigger,
159
- matchAny
160
- ]);
161
- const updateCaretPosition = useCallback((newCaret)=>{
162
- requestAnimationFrame(()=>{
163
- setCaret(newCaret);
164
- inputSelection.default.setCaretPosition(inputRef.current, newCaret);
165
- });
166
- }, []);
167
- const updateHelper = useCallback((str, caretPos, helperOptions)=>{
168
- const slug = getMatch(str, caretPos, helperOptions);
169
- if (slug) {
170
- const caretCoordinates = getCaretCoordinates(inputRef.current, caretPos);
171
- const rect = inputRef.current.getBoundingClientRect();
172
- const newTop = caretCoordinates.top + rect.top - inputRef.current.scrollTop;
173
- const newLeft = Math.min(caretCoordinates.left + rect.left - inputRef.current.scrollLeft, window.innerWidth - OPTION_LIST_MIN_WIDTH);
174
- if (slug.matchLength >= minChars && (slug.options.length > 1 || slug.options.length === 1 && (slug.options[0].length !== slug.matchLength || slug.options[0].length === 1))) {
175
- setHelperVisible(true);
176
- setTop(newTop);
177
- setLeft(newLeft);
178
- setTriggerChar(slug.trigger);
179
- setMatchLength(slug.matchLength);
180
- setMatchStart(slug.matchStart);
181
- setCurrentOptions(slug.options);
182
- } else {
183
- if (!requestOnlyIfNoOptions || !slug.options.length) {
184
- onRequestOptions(str.substr(slug.matchStart, slug.matchLength));
185
- }
186
- resetHelper();
187
- }
188
- updateCaretPosition(caretPos);
189
- } else {
190
- resetHelper();
191
- }
192
- }, [
193
- getMatch,
194
- minChars,
195
- requestOnlyIfNoOptions,
196
- onRequestOptions,
197
- updateCaretPosition
198
- ]);
199
- const resetHelper = useCallback(()=>{
200
- setHelperVisible(false);
201
- setSelection(0);
202
- }, []);
203
- const handleChange = useCallback((e)=>{
204
- const str = e.target.value;
205
- const caretPos = inputSelection.default.default(e.target).end;
206
- if (!str.length) {
207
- setHelperVisible(false);
208
- }
209
- recentValue.current = str;
210
- if (!str.length || !caretPos) {
211
- return onChange(e.target.value);
212
- }
213
- // Space removers logic
214
- if (enableSpaceRemovers.current && spaceRemovers.length && str.length > 2 && spacer.length) {
215
- for(let i = 0; i < Math.max(recentValue.current.length, str.length); ++i){
216
- if (recentValue.current[i] !== str[i]) {
217
- if (i >= 2 && str[i - 1] === spacer && spaceRemovers.indexOf(str[i - 2]) === -1 && spaceRemovers.indexOf(str[i]) !== -1 && getMatch(str.substring(0, i - 2), caretPos - 3, options)) {
218
- const newValue = `${str.slice(0, i - 1)}${str.slice(i, i + 1)}${str.slice(i - 1, i)}${str.slice(i + 1)}`;
219
- updateCaretPosition(i + 1);
220
- inputRef.current.value = newValue;
221
- if (!propValue) {
222
- setValue(newValue);
223
- }
224
- return onChange(newValue);
225
- }
226
- break;
227
- }
228
- }
229
- enableSpaceRemovers.current = false;
230
- }
231
- updateHelper(str, caretPos, options);
232
- if (!propValue) {
233
- setValue(e.target.value);
234
- }
235
- return onChange(e.target.value);
236
- }, [
237
- onChange,
238
- propValue,
239
- spaceRemovers,
240
- spacer,
241
- options,
242
- updateCaretPosition,
243
- updateHelper,
244
- getMatch
245
- ]);
246
- const handleBlur = useCallback((e)=>{
247
- resetHelper();
248
- onBlur(e);
249
- }, [
250
- onBlur,
251
- resetHelper
252
- ]);
253
- const handleSelection = useCallback((idx)=>{
254
- const slug = currentOptions[idx];
255
- const value = recentValue.current;
256
- const part1 = triggerChar.length === 0 ? '' : value.substring(0, matchStart - triggerChar.length);
257
- const part2 = value.substring(matchStart + matchLength);
258
- const event = {
259
- target: inputRef.current
260
- };
261
- const changedStr = changeOnSelect(triggerChar, slug);
262
- event.target.value = `${part1}${changedStr}${spacer}${part2}`;
263
- handleChange(event);
264
- onSelect(event.target.value);
265
- resetHelper();
266
- const advanceCaretDistance = part1.length + changedStr.length + (spacer ? spacer.length : 1);
267
- updateCaretPosition(advanceCaretDistance);
268
- enableSpaceRemovers.current = true;
269
- }, [
270
- currentOptions,
271
- triggerChar,
272
- matchStart,
273
- matchLength,
274
- changeOnSelect,
275
- spacer,
276
- handleChange,
277
- onSelect,
278
- resetHelper,
279
- updateCaretPosition
280
- ]);
281
- const handleKeyDown = useCallback((event)=>{
282
- const optionsCount = maxOptions > 0 ? Math.min(currentOptions.length, maxOptions) : currentOptions.length;
283
- if (helperVisible) {
284
- switch(event.keyCode){
285
- case KEY_ESCAPE:
286
- event.preventDefault();
287
- resetHelper();
288
- break;
289
- case KEY_UP:
290
- event.preventDefault();
291
- if (optionsCount > 0) {
292
- setSelection((prevSelection)=>Math.max(0, optionsCount + prevSelection - 1) % optionsCount);
293
- }
294
- break;
295
- case KEY_DOWN:
296
- event.preventDefault();
297
- if (optionsCount > 0) {
298
- setSelection((prevSelection)=>(prevSelection + 1) % optionsCount);
299
- }
300
- break;
301
- case KEY_ENTER:
302
- case KEY_RETURN:
303
- if (!passThroughEnter) {
304
- event.preventDefault();
305
- }
306
- handleSelection(selection);
307
- break;
308
- case KEY_TAB:
309
- if (!passThroughTab) {
310
- event.preventDefault();
311
- }
312
- handleSelection(selection);
313
- break;
314
- default:
315
- onKeyDown(event);
316
- break;
317
- }
318
- } else {
319
- onKeyDown(event);
320
- }
321
- }, [
322
- helperVisible,
323
- currentOptions,
324
- maxOptions,
325
- passThroughEnter,
326
- passThroughTab,
327
- selection,
328
- onKeyDown,
329
- resetHelper,
330
- handleSelection
331
- ]);
332
- const renderAutocompleteList = useCallback(()=>{
333
- if (!helperVisible || currentOptions.length === 0) {
334
- return null;
335
- }
336
- if (selection >= currentOptions.length) {
337
- setSelection(0);
338
- return null;
339
- }
340
- const optionNumber = maxOptions === 0 ? currentOptions.length : maxOptions;
341
- const helperOptions = currentOptions.slice(0, optionNumber).map((val, idx)=>{
342
- let [helper, value] = val.split(' ');
343
- if (!value) {
344
- helper = undefined;
345
- value = val;
346
- }
347
- const renderHighlightedText = (text)=>{
348
- const highlightStart = text.toLowerCase().indexOf(recentValue.current.substr(matchStart, matchLength).toLowerCase());
349
- const highlightedText = text.substr(highlightStart, matchLength);
350
- if (!val.startsWith(text)) {
351
- return text;
352
- }
353
- return /*#__PURE__*/ _jsxs(_Fragment, {
354
- children: [
355
- text.slice(0, highlightStart),
356
- /*#__PURE__*/ _jsx("strong", {
357
- children: highlightedText
358
- }),
359
- text.slice(highlightStart + matchLength)
360
- ]
361
- });
362
- };
363
- return /*#__PURE__*/ _jsxs("li", {
364
- className: idx === selection ? styles.active : null,
365
- onClick: ()=>{
366
- handleSelection(idx);
367
- },
368
- onMouseDown: (e)=>{
369
- e.preventDefault();
370
- },
371
- onMouseEnter: ()=>{
372
- setSelection(idx);
373
- },
374
- ref: idx === selection ? currentRef : null,
375
- role: "presentation",
376
- children: [
377
- helper && /*#__PURE__*/ _jsx("code", {
378
- className: styles.helper,
379
- children: renderHighlightedText(helper)
380
- }),
381
- renderHighlightedText(value)
382
- ]
383
- }, val);
384
- });
385
- const maxWidth = window.innerWidth - left - offsetX - 5;
386
- const maxHeight = window.innerHeight - top - offsetY - 5;
387
- return /*#__PURE__*/ _jsx("ul", {
388
- className: styles.autocompleteInput + ' ' + 'popup__content',
389
- ref: parentRef,
390
- style: {
391
- left: left + offsetX,
392
- maxHeight,
393
- maxWidth,
394
- opacity: 'initial',
395
- pointerEvents: 'initial',
396
- position: 'fixed',
397
- top: top + offsetY,
398
- visibility: 'initial'
399
- },
400
- children: helperOptions
401
- });
402
- }, [
403
- helperVisible,
404
- currentOptions,
405
- selection,
406
- maxOptions,
407
- left,
408
- top,
409
- offsetX,
410
- offsetY,
411
- matchStart,
412
- matchLength,
413
- handleSelection
414
- ]);
415
- return /*#__PURE__*/ _jsxs("div", {
416
- className: "popup",
417
- children: [
418
- /*#__PURE__*/ _jsx("textarea", {
419
- className: "textarea-outer",
420
- disabled: disabled,
421
- onBlur: handleBlur,
422
- onChange: handleChange,
423
- onKeyDown: handleKeyDown,
424
- ref: inputRef,
425
- rows: 6,
426
- style: {
427
- overflow: 'auto'
428
- },
429
- value: propValue !== null ? propValue : value || defaultValue,
430
- ...rest
431
- }),
432
- renderAutocompleteList()
433
- ]
434
- });
435
- };
436
-
437
- //# sourceMappingURL=AutocompleteTextArea.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/libraries/autocomplete/AutocompleteTextArea.tsx"],"sourcesContent":["/**\n * Credit: Yury Dymov\n * Github: https://github.com/yury-dymov/react-autocomplete-input\n *\n * Modified to only be use for PromptEditorField\n */\n\nimport * as inputSelection from 'get-input-selection'\nimport isEqual from 'lodash.isequal'\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\nimport scrollIntoView from 'scroll-into-view-if-needed'\nimport getCaretCoordinates from 'textarea-caret'\n\nimport styles from './AutocompleteTextArea.module.scss'\n\nconst KEY_UP = 38\nconst KEY_DOWN = 40\nconst KEY_RETURN = 13\nconst KEY_ENTER = 14\nconst KEY_ESCAPE = 27\nconst KEY_TAB = 9\n\nconst OPTION_LIST_MIN_WIDTH = 100\n\nexport const AutocompleteTextField = (props) => {\n const {\n changeOnSelect = (trigger, slug) => trigger + slug,\n defaultValue = '',\n disabled = false,\n matchAny = false,\n maxOptions = 10,\n minChars = 0,\n offsetX = 0,\n offsetY = 0,\n onBlur = (e: any) => {},\n onChange = (e: any) => {},\n onKeyDown = (e: any) => {},\n onRequestOptions = (e: any) => {},\n onSelect = (e: any) => {},\n options = [],\n passThroughEnter = false,\n passThroughTab = true,\n regex = '^[A-Za-z0-9\\\\-_]+$',\n requestOnlyIfNoOptions = true,\n spaceRemovers = [',', '.', '!', '?'],\n spacer = ' ',\n trigger = '@',\n triggerCaseInsensitive = false,\n triggerMatchWholeWord = false,\n value: propValue = null,\n ...rest\n } = props\n\n const [helperVisible, setHelperVisible] = useState(false)\n const [left, setLeft] = useState(0)\n const [top, setTop] = useState(0)\n const [triggerChar, setTriggerChar] = useState(null)\n const [matchLength, setMatchLength] = useState(0)\n const [matchStart, setMatchStart] = useState(0)\n const [selection, setSelection] = useState(0)\n const [value, setValue] = useState(null)\n const [caret, setCaret] = useState(0)\n const [currentOptions, setCurrentOptions] = useState([])\n\n const recentValue = useRef(defaultValue)\n const enableSpaceRemovers = useRef(false)\n const inputRef = useRef(null)\n const currentRef = useRef(null)\n const parentRef = useRef(null)\n\n useEffect(() => {\n window.addEventListener('resize', handleResize)\n window.addEventListener('scroll', handleResize)\n\n return () => {\n window.removeEventListener('resize', handleResize)\n window.removeEventListener('scroll', handleResize)\n }\n }, [])\n\n useEffect(() => {\n if (!isEqual(options, currentOptions)) {\n updateHelper(recentValue.current, caret, options)\n }\n }, [options, caret])\n\n useEffect(() => {\n if (helperVisible && currentRef.current) {\n scrollIntoView(currentRef.current, { boundary: parentRef.current, scrollMode: 'if-needed' })\n }\n }, [helperVisible, selection])\n\n const handleResize = useCallback(() => {\n setHelperVisible(false)\n }, [])\n\n const isTrigger = useCallback(\n (triggerStr, str, i) => {\n if (!triggerStr || !triggerStr.length) {\n return true\n }\n\n if (triggerMatchWholeWord && i > 0 && str.charAt(i - 1).match(/\\w/)) {\n return false\n }\n\n if (\n str.substr(i, triggerStr.length) === triggerStr ||\n (triggerCaseInsensitive &&\n str.substr(i, triggerStr.length).toLowerCase() === triggerStr.toLowerCase())\n ) {\n return true\n }\n\n return false\n },\n [triggerMatchWholeWord, triggerCaseInsensitive],\n )\n\n const arrayTriggerMatch = useCallback((triggers, re) => {\n return triggers.map((trigger) => ({\n triggerLength: trigger.length,\n triggerMatch: trigger.match(re),\n triggerStr: trigger,\n }))\n }, [])\n\n const getMatch = useCallback(\n (str, caret, providedOptions) => {\n const re = new RegExp(regex)\n const triggers = Array.isArray(trigger) ? trigger : [trigger]\n triggers.sort()\n\n const providedOptionsObject = Array.isArray(providedOptions)\n ? triggers.reduce((acc, triggerStr) => ({ ...acc, [triggerStr]: providedOptions }), {})\n : providedOptions\n\n const triggersMatch = arrayTriggerMatch(triggers, re)\n let slugData = null\n\n for (let triggersIndex = 0; triggersIndex < triggersMatch.length; triggersIndex++) {\n const { triggerLength, triggerMatch, triggerStr } = triggersMatch[triggersIndex]\n\n for (let i = caret - 1; i >= 0; --i) {\n const substr = str.substring(i, caret)\n const match = substr.match(re)\n let matchStart = -1\n\n if (triggerLength > 0) {\n const triggerIdx = triggerMatch ? i : i - triggerLength + 1\n\n if (triggerIdx < 0) {\n break\n }\n\n if (isTrigger(triggerStr, str, triggerIdx)) {\n matchStart = triggerIdx + triggerLength\n }\n\n if (!match && matchStart < 0) {\n break\n }\n } else {\n if (match && i > 0) {\n continue\n }\n matchStart = i === 0 && match ? 0 : i + 1\n\n if (caret - matchStart === 0) {\n break\n }\n }\n\n if (matchStart >= 0) {\n const triggerOptions = providedOptionsObject[triggerStr]\n if (triggerOptions == null) {\n continue\n }\n\n const matchedSlug = str.substring(matchStart, caret)\n\n const filteredOptions = triggerOptions.filter((slug) => {\n const idx = slug.toLowerCase().indexOf(matchedSlug.toLowerCase())\n return idx !== -1 && (matchAny || idx === 0)\n })\n\n const currTrigger = triggerStr\n const matchLength = matchedSlug.length\n\n slugData = {\n matchLength,\n matchStart,\n options: filteredOptions,\n trigger: currTrigger,\n }\n }\n }\n }\n\n return slugData\n },\n [regex, trigger, arrayTriggerMatch, isTrigger, matchAny],\n )\n\n const updateCaretPosition = useCallback((newCaret) => {\n requestAnimationFrame(() => {\n setCaret(newCaret)\n inputSelection.default.setCaretPosition(inputRef.current, newCaret)\n })\n }, [])\n\n const updateHelper = useCallback(\n (str, caretPos, helperOptions) => {\n const slug = getMatch(str, caretPos, helperOptions)\n\n if (slug) {\n const caretCoordinates = getCaretCoordinates(inputRef.current, caretPos)\n const rect = inputRef.current.getBoundingClientRect()\n\n const newTop = caretCoordinates.top + rect.top - inputRef.current.scrollTop\n const newLeft = Math.min(\n caretCoordinates.left + rect.left - inputRef.current.scrollLeft,\n window.innerWidth - OPTION_LIST_MIN_WIDTH,\n )\n\n if (\n slug.matchLength >= minChars &&\n (slug.options.length > 1 ||\n (slug.options.length === 1 &&\n (slug.options[0].length !== slug.matchLength || slug.options[0].length === 1)))\n ) {\n setHelperVisible(true)\n setTop(newTop)\n setLeft(newLeft)\n setTriggerChar(slug.trigger)\n setMatchLength(slug.matchLength)\n setMatchStart(slug.matchStart)\n setCurrentOptions(slug.options)\n } else {\n if (!requestOnlyIfNoOptions || !slug.options.length) {\n onRequestOptions(str.substr(slug.matchStart, slug.matchLength))\n }\n resetHelper()\n }\n updateCaretPosition(caretPos)\n } else {\n resetHelper()\n }\n },\n [getMatch, minChars, requestOnlyIfNoOptions, onRequestOptions, updateCaretPosition],\n )\n\n const resetHelper = useCallback(() => {\n setHelperVisible(false)\n setSelection(0)\n }, [])\n\n const handleChange = useCallback(\n (e) => {\n const str = e.target.value\n const caretPos = inputSelection.default.default(e.target).end\n\n if (!str.length) {\n setHelperVisible(false)\n }\n\n recentValue.current = str\n\n if (!str.length || !caretPos) {\n return onChange(e.target.value)\n }\n\n // Space removers logic\n if (enableSpaceRemovers.current && spaceRemovers.length && str.length > 2 && spacer.length) {\n for (let i = 0; i < Math.max(recentValue.current.length, str.length); ++i) {\n if (recentValue.current[i] !== str[i]) {\n if (\n i >= 2 &&\n str[i - 1] === spacer &&\n spaceRemovers.indexOf(str[i - 2]) === -1 &&\n spaceRemovers.indexOf(str[i]) !== -1 &&\n getMatch(str.substring(0, i - 2), caretPos - 3, options)\n ) {\n const newValue = `${str.slice(0, i - 1)}${str.slice(i, i + 1)}${str.slice(i - 1, i)}${str.slice(i + 1)}`\n\n updateCaretPosition(i + 1)\n inputRef.current.value = newValue\n\n if (!propValue) {\n setValue(newValue)\n }\n\n return onChange(newValue)\n }\n\n break\n }\n }\n\n enableSpaceRemovers.current = false\n }\n\n updateHelper(str, caretPos, options)\n\n if (!propValue) {\n setValue(e.target.value)\n }\n\n return onChange(e.target.value)\n },\n [\n onChange,\n propValue,\n spaceRemovers,\n spacer,\n options,\n updateCaretPosition,\n updateHelper,\n getMatch,\n ],\n )\n\n const handleBlur = useCallback(\n (e) => {\n resetHelper()\n onBlur(e)\n },\n [onBlur, resetHelper],\n )\n\n const handleSelection = useCallback(\n (idx) => {\n const slug = currentOptions[idx]\n const value = recentValue.current\n const part1 =\n triggerChar.length === 0 ? '' : value.substring(0, matchStart - triggerChar.length)\n const part2 = value.substring(matchStart + matchLength)\n\n const event = { target: inputRef.current }\n const changedStr = changeOnSelect(triggerChar, slug)\n\n event.target.value = `${part1}${changedStr}${spacer}${part2}`\n handleChange(event)\n onSelect(event.target.value)\n\n resetHelper()\n\n const advanceCaretDistance = part1.length + changedStr.length + (spacer ? spacer.length : 1)\n updateCaretPosition(advanceCaretDistance)\n\n enableSpaceRemovers.current = true\n },\n [\n currentOptions,\n triggerChar,\n matchStart,\n matchLength,\n changeOnSelect,\n spacer,\n handleChange,\n onSelect,\n resetHelper,\n updateCaretPosition,\n ],\n )\n\n const handleKeyDown = useCallback(\n (event) => {\n const optionsCount =\n maxOptions > 0 ? Math.min(currentOptions.length, maxOptions) : currentOptions.length\n\n if (helperVisible) {\n switch (event.keyCode) {\n case KEY_ESCAPE:\n event.preventDefault()\n resetHelper()\n break\n case KEY_UP:\n event.preventDefault()\n if (optionsCount > 0) {\n setSelection(\n (prevSelection) => Math.max(0, optionsCount + prevSelection - 1) % optionsCount,\n )\n }\n break\n case KEY_DOWN:\n event.preventDefault()\n if (optionsCount > 0) {\n setSelection((prevSelection) => (prevSelection + 1) % optionsCount)\n }\n break\n case KEY_ENTER:\n case KEY_RETURN:\n if (!passThroughEnter) {\n event.preventDefault()\n }\n handleSelection(selection)\n break\n case KEY_TAB:\n if (!passThroughTab) {\n event.preventDefault()\n }\n handleSelection(selection)\n break\n default:\n onKeyDown(event)\n break\n }\n } else {\n onKeyDown(event)\n }\n },\n [\n helperVisible,\n currentOptions,\n maxOptions,\n passThroughEnter,\n passThroughTab,\n selection,\n onKeyDown,\n resetHelper,\n handleSelection,\n ],\n )\n\n const renderAutocompleteList = useCallback(() => {\n if (!helperVisible || currentOptions.length === 0) {\n return null\n }\n\n if (selection >= currentOptions.length) {\n setSelection(0)\n return null\n }\n\n const optionNumber = maxOptions === 0 ? currentOptions.length : maxOptions\n\n const helperOptions = currentOptions.slice(0, optionNumber).map((val, idx) => {\n let [helper, value] = val.split(' ')\n if (!value) {\n helper = undefined\n value = val\n }\n\n const renderHighlightedText = (text) => {\n const highlightStart = text\n .toLowerCase()\n .indexOf(recentValue.current.substr(matchStart, matchLength).toLowerCase())\n\n const highlightedText = text.substr(highlightStart, matchLength)\n\n if (!val.startsWith(text)) {\n return text\n }\n\n return (\n <>\n {text.slice(0, highlightStart)}\n <strong>{highlightedText}</strong>\n {text.slice(highlightStart + matchLength)}\n </>\n )\n }\n\n return (\n <li\n className={idx === selection ? styles.active : null}\n key={val}\n onClick={() => {\n handleSelection(idx)\n }}\n onMouseDown={(e) => {\n e.preventDefault()\n }}\n onMouseEnter={() => {\n setSelection(idx)\n }}\n ref={idx === selection ? currentRef : null}\n role=\"presentation\"\n >\n {helper && <code className={styles.helper}>{renderHighlightedText(helper)}</code>}\n {renderHighlightedText(value)}\n </li>\n )\n })\n\n const maxWidth = window.innerWidth - left - offsetX - 5\n const maxHeight = window.innerHeight - top - offsetY - 5\n\n return (\n <ul\n className={styles.autocompleteInput + ' ' + 'popup__content'}\n ref={parentRef}\n style={{\n left: left + offsetX,\n maxHeight,\n maxWidth,\n opacity: 'initial',\n pointerEvents: 'initial',\n position: 'fixed',\n top: top + offsetY,\n visibility: 'initial',\n }}\n >\n {helperOptions}\n </ul>\n )\n }, [\n helperVisible,\n currentOptions,\n selection,\n maxOptions,\n left,\n top,\n offsetX,\n offsetY,\n matchStart,\n matchLength,\n handleSelection,\n ])\n\n return (\n <div className=\"popup\">\n <textarea\n className=\"textarea-outer\"\n disabled={disabled}\n onBlur={handleBlur}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n ref={inputRef}\n rows={6}\n style={{ overflow: 'auto' }}\n value={propValue !== null ? propValue : value || defaultValue}\n {...rest}\n />\n {renderAutocompleteList()}\n </div>\n )\n}\n"],"names":["inputSelection","isEqual","React","useCallback","useEffect","useRef","useState","scrollIntoView","getCaretCoordinates","styles","KEY_UP","KEY_DOWN","KEY_RETURN","KEY_ENTER","KEY_ESCAPE","KEY_TAB","OPTION_LIST_MIN_WIDTH","AutocompleteTextField","props","changeOnSelect","trigger","slug","defaultValue","disabled","matchAny","maxOptions","minChars","offsetX","offsetY","onBlur","e","onChange","onKeyDown","onRequestOptions","onSelect","options","passThroughEnter","passThroughTab","regex","requestOnlyIfNoOptions","spaceRemovers","spacer","triggerCaseInsensitive","triggerMatchWholeWord","value","propValue","rest","helperVisible","setHelperVisible","left","setLeft","top","setTop","triggerChar","setTriggerChar","matchLength","setMatchLength","matchStart","setMatchStart","selection","setSelection","setValue","caret","setCaret","currentOptions","setCurrentOptions","recentValue","enableSpaceRemovers","inputRef","currentRef","parentRef","window","addEventListener","handleResize","removeEventListener","updateHelper","current","boundary","scrollMode","isTrigger","triggerStr","str","i","length","charAt","match","substr","toLowerCase","arrayTriggerMatch","triggers","re","map","triggerLength","triggerMatch","getMatch","providedOptions","RegExp","Array","isArray","sort","providedOptionsObject","reduce","acc","triggersMatch","slugData","triggersIndex","substring","triggerIdx","triggerOptions","matchedSlug","filteredOptions","filter","idx","indexOf","currTrigger","updateCaretPosition","newCaret","requestAnimationFrame","default","setCaretPosition","caretPos","helperOptions","caretCoordinates","rect","getBoundingClientRect","newTop","scrollTop","newLeft","Math","min","scrollLeft","innerWidth","resetHelper","handleChange","target","end","max","newValue","slice","handleBlur","handleSelection","part1","part2","event","changedStr","advanceCaretDistance","handleKeyDown","optionsCount","keyCode","preventDefault","prevSelection","renderAutocompleteList","optionNumber","val","helper","split","undefined","renderHighlightedText","text","highlightStart","highlightedText","startsWith","strong","li","className","active","onClick","onMouseDown","onMouseEnter","ref","role","code","maxWidth","maxHeight","innerHeight","ul","autocompleteInput","style","opacity","pointerEvents","position","visibility","div","textarea","rows","overflow"],"mappings":"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"}
@@ -1,35 +0,0 @@
1
- .autocompleteInput {
2
- background-clip: padding-box;
3
- border: 1px solid rgba(0,0,0,0.15);
4
- bottom: auto;
5
- box-shadow: 0 6px 12px rgba(0,0,0,0.175);
6
- display: block;
7
- font-size: 14px;
8
- list-style: none;
9
- position: fixed;
10
- text-align: left;
11
- z-index: 20000;
12
- overflow-y: auto;
13
- margin-top: 1em;
14
-
15
- padding: var(--popup-padding)
16
- }
17
-
18
- .autocompleteInput > li {
19
- cursor: pointer;
20
- padding: 4px 8px;
21
- min-width: 110px;
22
- color: var(--theme-elevation-800);
23
- }
24
-
25
- .autocompleteInput > li.active {
26
- background-color: var(--theme-elevation-100);
27
- }
28
-
29
- .helper {
30
- padding: 0.2em;
31
- font-size: 12px;
32
- margin-right: 0.5em;
33
- background: rgb(0 255 111 / 10%);
34
- border-radius: 4px;
35
- }
@@ -1,2 +0,0 @@
1
- export declare const asyncHandlebars: any;
2
- //# sourceMappingURL=asyncHandlebars.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"asyncHandlebars.d.ts","sourceRoot":"","sources":["../../../src/libraries/handlebars/asyncHandlebars.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,eAAe,KAA2B,CAAA"}
@@ -1,5 +0,0 @@
1
- import Handlebars from 'handlebars/dist/handlebars.js';
2
- import asyncHelpers from 'handlebars-async-helpers';
3
- export const asyncHandlebars = asyncHelpers(Handlebars);
4
-
5
- //# sourceMappingURL=asyncHandlebars.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/libraries/handlebars/asyncHandlebars.ts"],"sourcesContent":["import Handlebars from 'handlebars/dist/handlebars.js'\nimport asyncHelpers from 'handlebars-async-helpers'\n\nexport const asyncHandlebars = asyncHelpers(Handlebars)\n"],"names":["Handlebars","asyncHelpers","asyncHandlebars"],"mappings":"AAAA,OAAOA,gBAAgB,gCAA+B;AACtD,OAAOC,kBAAkB,2BAA0B;AAEnD,OAAO,MAAMC,kBAAkBD,aAAaD,YAAW"}
@@ -1,2 +0,0 @@
1
- export declare const registerEditorHelper: (payload: any, schemaPath: any) => void;
2
- //# sourceMappingURL=helpers.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/libraries/handlebars/helpers.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,oBAAoB,yCAqBhC,CAAA"}
@@ -1,22 +0,0 @@
1
- import { getFieldInfo } from '../../utilities/getFieldInfo.js';
2
- import { lexicalToHTML } from '../../utilities/lexicalToHTML.js';
3
- import { asyncHandlebars } from './asyncHandlebars.js';
4
- import { handlebarsHelpersMap } from './helpersMap.js';
5
- export const registerEditorHelper = (payload, schemaPath)=>{
6
- //TODO: add autocomplete ability using handlebars template on PromptEditorField and include custom helpers in dropdown
7
- let fieldInfo = getFieldInfo(payload.collections, schemaPath);
8
- const schemaPathChunks = schemaPath.split('.');
9
- asyncHandlebars.registerHelper(handlebarsHelpersMap.toHTML.name, async function(content, options) {
10
- const collectionSlug = schemaPathChunks[0];
11
- const { ids } = options;
12
- for (const id of ids){
13
- //TODO: Find a better way to get schemaPath of defined field in prompt editor
14
- const path = `${collectionSlug}.${id}`;
15
- fieldInfo = getFieldInfo(payload.collections, path);
16
- }
17
- const html = await lexicalToHTML(content, fieldInfo.editor?.editorConfig);
18
- return new asyncHandlebars.SafeString(html);
19
- });
20
- };
21
-
22
- //# sourceMappingURL=helpers.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/libraries/handlebars/helpers.ts"],"sourcesContent":["import type { SerializedEditorState } from 'lexical'\n\nimport { getFieldInfo } from '../../utilities/getFieldInfo.js'\nimport { lexicalToHTML } from '../../utilities/lexicalToHTML.js'\nimport { asyncHandlebars } from './asyncHandlebars.js'\nimport { handlebarsHelpersMap } from './helpersMap.js'\n\nexport const registerEditorHelper = (payload, schemaPath) => {\n //TODO: add autocomplete ability using handlebars template on PromptEditorField and include custom helpers in dropdown\n\n let fieldInfo = getFieldInfo(payload.collections, schemaPath)\n const schemaPathChunks = schemaPath.split('.')\n\n asyncHandlebars.registerHelper(\n handlebarsHelpersMap.toHTML.name,\n async function (content: SerializedEditorState, options) {\n const collectionSlug = schemaPathChunks[0]\n const { ids } = options\n for (const id of ids) {\n //TODO: Find a better way to get schemaPath of defined field in prompt editor\n const path = `${collectionSlug}.${id}`\n fieldInfo = getFieldInfo(payload.collections, path)\n }\n\n const html = await lexicalToHTML(content, fieldInfo.editor?.editorConfig)\n return new asyncHandlebars.SafeString(html)\n },\n )\n}\n"],"names":["getFieldInfo","lexicalToHTML","asyncHandlebars","handlebarsHelpersMap","registerEditorHelper","payload","schemaPath","fieldInfo","collections","schemaPathChunks","split","registerHelper","toHTML","name","content","options","collectionSlug","ids","id","path","html","editor","editorConfig","SafeString"],"mappings":"AAEA,SAASA,YAAY,QAAQ,kCAAiC;AAC9D,SAASC,aAAa,QAAQ,mCAAkC;AAChE,SAASC,eAAe,QAAQ,uBAAsB;AACtD,SAASC,oBAAoB,QAAQ,kBAAiB;AAEtD,OAAO,MAAMC,uBAAuB,CAACC,SAASC;IAC5C,sHAAsH;IAEtH,IAAIC,YAAYP,aAAaK,QAAQG,WAAW,EAAEF;IAClD,MAAMG,mBAAmBH,WAAWI,KAAK,CAAC;IAE1CR,gBAAgBS,cAAc,CAC5BR,qBAAqBS,MAAM,CAACC,IAAI,EAChC,eAAgBC,OAA8B,EAAEC,OAAO;QACrD,MAAMC,iBAAiBP,gBAAgB,CAAC,EAAE;QAC1C,MAAM,EAAEQ,GAAG,EAAE,GAAGF;QAChB,KAAK,MAAMG,MAAMD,IAAK;YACpB,6EAA6E;YAC7E,MAAME,OAAO,GAAGH,eAAe,CAAC,EAAEE,IAAI;YACtCX,YAAYP,aAAaK,QAAQG,WAAW,EAAEW;QAChD;QAEA,MAAMC,OAAO,MAAMnB,cAAca,SAASP,UAAUc,MAAM,EAAEC;QAC5D,OAAO,IAAIpB,gBAAgBqB,UAAU,CAACH;IACxC;AAEJ,EAAC"}
@@ -1,12 +0,0 @@
1
- type SupportedHelpers = 'toHTML' | 'toText';
2
- interface HelperFieldConfig {
3
- field: string;
4
- name: string;
5
- }
6
- type HandlebarsHelpers = {
7
- [K in SupportedHelpers]: HelperFieldConfig;
8
- };
9
- export declare const handlebarsHelpersMap: HandlebarsHelpers;
10
- export declare const handlebarsHelpers: string[];
11
- export {};
12
- //# sourceMappingURL=helpersMap.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"helpersMap.d.ts","sourceRoot":"","sources":["../../../src/libraries/handlebars/helpersMap.ts"],"names":[],"mappings":"AAAA,KAAK,gBAAgB,GAAG,QAAQ,GAAG,QAAQ,CAAA;AAE3C,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,MAAM,CAAA;CACb;AAED,KAAK,iBAAiB,GAAG;KACtB,CAAC,IAAI,gBAAgB,GAAG,iBAAiB;CAC3C,CAAA;AAED,eAAO,MAAM,oBAAoB,EAAE,iBASlC,CAAA;AAED,eAAO,MAAM,iBAAiB,UAAoC,CAAA"}
@@ -1,13 +0,0 @@
1
- export const handlebarsHelpersMap = {
2
- toHTML: {
3
- name: 'toHTML',
4
- field: 'richText'
5
- },
6
- toText: {
7
- name: 'toText',
8
- field: '-'
9
- }
10
- };
11
- export const handlebarsHelpers = Object.keys(handlebarsHelpersMap);
12
-
13
- //# sourceMappingURL=helpersMap.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/libraries/handlebars/helpersMap.ts"],"sourcesContent":["type SupportedHelpers = 'toHTML' | 'toText'\n\ninterface HelperFieldConfig {\n field: string\n name: string\n}\n\ntype HandlebarsHelpers = {\n [K in SupportedHelpers]: HelperFieldConfig\n}\n\nexport const handlebarsHelpersMap: HandlebarsHelpers = {\n toHTML: {\n name: 'toHTML',\n field: 'richText',\n },\n toText: {\n name: 'toText',\n field: '-',\n },\n}\n\nexport const handlebarsHelpers = Object.keys(handlebarsHelpersMap)\n"],"names":["handlebarsHelpersMap","toHTML","name","field","toText","handlebarsHelpers","Object","keys"],"mappings":"AAWA,OAAO,MAAMA,uBAA0C;IACrDC,QAAQ;QACNC,MAAM;QACNC,OAAO;IACT;IACAC,QAAQ;QACNF,MAAM;QACNC,OAAO;IACT;AACF,EAAC;AAED,OAAO,MAAME,oBAAoBC,OAAOC,IAAI,CAACP,sBAAqB"}
@@ -1,2 +0,0 @@
1
- export declare const replacePlaceholders: (prompt: string, values: object) => any;
2
- //# sourceMappingURL=replacePlaceholders.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"replacePlaceholders.d.ts","sourceRoot":"","sources":["../../../src/libraries/handlebars/replacePlaceholders.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,mBAAmB,WAAY,MAAM,UAAU,MAAM,QAEjE,CAAA"}