@ai-stack/payloadcms 3.0.0-beta.95.2 → 3.2.3-beta

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 (195) hide show
  1. package/LICENSE.md +1 -1
  2. package/README.md +25 -16
  3. package/dist/ai/models/anthropic/generateRichText.d.ts.map +1 -1
  4. package/dist/ai/models/anthropic/generateRichText.js +2 -2
  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 +8 -32
  8. package/dist/ai/models/anthropic/index.js.map +1 -1
  9. package/dist/ai/models/elevenLabs/generateVoice.d.ts +1 -1
  10. package/dist/ai/models/elevenLabs/index.d.ts.map +1 -1
  11. package/dist/ai/models/elevenLabs/index.js +4 -3
  12. package/dist/ai/models/elevenLabs/index.js.map +1 -1
  13. package/dist/ai/models/openai/generateImage.d.ts +1 -1
  14. package/dist/ai/models/openai/generateImage.d.ts.map +1 -1
  15. package/dist/ai/models/openai/generateImage.js +0 -1
  16. package/dist/ai/models/openai/generateImage.js.map +1 -1
  17. package/dist/ai/models/openai/generateRichText.d.ts +1 -1
  18. package/dist/ai/models/openai/generateRichText.d.ts.map +1 -1
  19. package/dist/ai/models/openai/generateRichText.js +16 -9
  20. package/dist/ai/models/openai/generateRichText.js.map +1 -1
  21. package/dist/ai/models/openai/generateVoice.d.ts +1 -1
  22. package/dist/ai/models/openai/index.d.ts.map +1 -1
  23. package/dist/ai/models/openai/index.js +9 -35
  24. package/dist/ai/models/openai/index.js.map +1 -1
  25. package/dist/ai/prompts.d.ts +1 -1
  26. package/dist/ai/prompts.d.ts.map +1 -1
  27. package/dist/ai/prompts.js +6 -3
  28. package/dist/ai/prompts.js.map +1 -1
  29. package/dist/ai/schemas/lexicalJsonSchema.d.ts +371 -0
  30. package/dist/ai/schemas/lexicalJsonSchema.d.ts.map +1 -0
  31. package/dist/ai/schemas/lexicalJsonSchema.js +650 -0
  32. package/dist/ai/schemas/lexicalJsonSchema.js.map +1 -0
  33. package/dist/ai/utils/generateFileNameByPrompt.js.map +1 -1
  34. package/dist/ai/utils/systemGenerate.d.ts +5 -0
  35. package/dist/ai/utils/systemGenerate.d.ts.map +1 -0
  36. package/dist/ai/utils/{generateSeedPrompt.js → systemGenerate.js} +2 -2
  37. package/dist/ai/utils/systemGenerate.js.map +1 -0
  38. package/dist/collections/Instructions.d.ts +1 -1
  39. package/dist/collections/Instructions.d.ts.map +1 -1
  40. package/dist/collections/Instructions.js +177 -85
  41. package/dist/collections/Instructions.js.map +1 -1
  42. package/dist/defaults.d.ts +1 -1
  43. package/dist/defaults.d.ts.map +1 -1
  44. package/dist/defaults.js +1 -1
  45. package/dist/defaults.js.map +1 -1
  46. package/dist/endpoints/fetchFields.d.ts +3 -0
  47. package/dist/endpoints/fetchFields.d.ts.map +1 -0
  48. package/dist/endpoints/fetchFields.js +21 -0
  49. package/dist/endpoints/fetchFields.js.map +1 -0
  50. package/dist/endpoints/index.d.ts.map +1 -1
  51. package/dist/endpoints/index.js +12 -18
  52. package/dist/endpoints/index.js.map +1 -1
  53. package/dist/exports/fields.d.ts +2 -1
  54. package/dist/exports/fields.d.ts.map +1 -1
  55. package/dist/exports/fields.js +2 -1
  56. package/dist/exports/fields.js.map +1 -1
  57. package/dist/fields/ComposeField/ComposeField.d.ts +3 -0
  58. package/dist/fields/ComposeField/ComposeField.d.ts.map +1 -0
  59. package/dist/fields/ComposeField/ComposeField.js +24 -0
  60. package/dist/fields/ComposeField/ComposeField.js.map +1 -0
  61. package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts +2 -0
  62. package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts.map +1 -0
  63. package/dist/fields/LexicalEditor/ComposeFeatureComponent.js +28 -0
  64. package/dist/fields/LexicalEditor/ComposeFeatureComponent.js.map +1 -0
  65. package/dist/fields/LexicalEditor/feature.client.d.ts +4 -1
  66. package/dist/fields/LexicalEditor/feature.client.d.ts.map +1 -1
  67. package/dist/fields/LexicalEditor/feature.client.js +19 -7
  68. package/dist/fields/LexicalEditor/feature.client.js.map +1 -1
  69. package/dist/fields/PromptEditorField/PromptEditorField.d.ts +2 -2
  70. package/dist/fields/PromptEditorField/PromptEditorField.d.ts.map +1 -1
  71. package/dist/fields/PromptEditorField/PromptEditorField.js +4 -8
  72. package/dist/fields/PromptEditorField/PromptEditorField.js.map +1 -1
  73. package/dist/fields/SelectField/SelectField.d.ts +3 -2
  74. package/dist/fields/SelectField/SelectField.d.ts.map +1 -1
  75. package/dist/fields/SelectField/SelectField.js +2 -3
  76. package/dist/fields/SelectField/SelectField.js.map +1 -1
  77. package/dist/index.d.ts +1 -6
  78. package/dist/index.d.ts.map +1 -1
  79. package/dist/index.js +1 -6
  80. package/dist/index.js.map +1 -1
  81. package/dist/init.d.ts +2 -1
  82. package/dist/init.d.ts.map +1 -1
  83. package/dist/init.js +22 -21
  84. package/dist/init.js.map +1 -1
  85. package/dist/libraries/autocomplete/AutocompleteTextArea.js +9 -7
  86. package/dist/libraries/autocomplete/AutocompleteTextArea.js.map +1 -1
  87. package/dist/libraries/handlebars/asyncHandlebars.js +1 -1
  88. package/dist/libraries/handlebars/asyncHandlebars.js.map +1 -1
  89. package/dist/libraries/handlebars/helpers.js.map +1 -1
  90. package/dist/plugin.d.ts.map +1 -1
  91. package/dist/plugin.js +56 -41
  92. package/dist/plugin.js.map +1 -1
  93. package/dist/providers/FieldProvider/FieldProvider.d.ts +15 -0
  94. package/dist/providers/FieldProvider/FieldProvider.d.ts.map +1 -0
  95. package/dist/providers/FieldProvider/FieldProvider.js +33 -0
  96. package/dist/providers/FieldProvider/FieldProvider.js.map +1 -0
  97. package/dist/providers/FieldProvider/useFieldProps.d.ts +6 -0
  98. package/dist/providers/FieldProvider/useFieldProps.d.ts.map +1 -0
  99. package/dist/providers/FieldProvider/useFieldProps.js +12 -0
  100. package/dist/providers/FieldProvider/useFieldProps.js.map +1 -0
  101. package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts +5 -1
  102. package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts.map +1 -1
  103. package/dist/providers/InstructionsProvider/InstructionsProvider.js +12 -7
  104. package/dist/providers/InstructionsProvider/InstructionsProvider.js.map +1 -1
  105. package/dist/providers/InstructionsProvider/useInstructions.d.ts +2 -2
  106. package/dist/providers/InstructionsProvider/useInstructions.d.ts.map +1 -1
  107. package/dist/providers/InstructionsProvider/useInstructions.js +17 -4
  108. package/dist/providers/InstructionsProvider/useInstructions.js.map +1 -1
  109. package/dist/types.d.ts +11 -41
  110. package/dist/types.d.ts.map +1 -1
  111. package/dist/types.js +1 -4
  112. package/dist/types.js.map +1 -1
  113. package/dist/ui/Compose/Compose.d.ts +9 -0
  114. package/dist/ui/Compose/Compose.d.ts.map +1 -0
  115. package/dist/ui/{Actions/Actions.js → Compose/Compose.js} +51 -40
  116. package/dist/ui/Compose/Compose.js.map +1 -0
  117. package/dist/ui/{Actions → Compose}/UndoRedoActions.d.ts.map +1 -1
  118. package/dist/ui/{Actions → Compose}/UndoRedoActions.js +15 -2
  119. package/dist/ui/Compose/UndoRedoActions.js.map +1 -0
  120. package/dist/ui/{Actions/actions.module.scss → Compose/compose.module.css} +7 -7
  121. package/dist/ui/{Actions → Compose}/hooks/menu/Item.d.ts +1 -1
  122. package/dist/ui/{Actions → Compose}/hooks/menu/Item.d.ts.map +1 -1
  123. package/dist/ui/{Actions → Compose}/hooks/menu/Item.js +2 -2
  124. package/dist/ui/{Actions → Compose}/hooks/menu/Item.js.map +1 -1
  125. package/dist/ui/Compose/hooks/menu/TranslateMenu.d.ts.map +1 -0
  126. package/dist/ui/{Actions → Compose}/hooks/menu/TranslateMenu.js +11 -11
  127. package/dist/ui/Compose/hooks/menu/TranslateMenu.js.map +1 -0
  128. package/dist/ui/{Actions → Compose}/hooks/menu/items.d.ts +8 -8
  129. package/dist/ui/{Actions → Compose}/hooks/menu/items.d.ts.map +1 -1
  130. package/dist/ui/{Actions → Compose}/hooks/menu/items.js.map +1 -1
  131. package/dist/ui/{Actions → Compose}/hooks/menu/itemsMap.d.ts +1 -1
  132. package/dist/ui/Compose/hooks/menu/itemsMap.d.ts.map +1 -0
  133. package/dist/ui/{Actions → Compose}/hooks/menu/itemsMap.js +1 -2
  134. package/dist/ui/Compose/hooks/menu/itemsMap.js.map +1 -0
  135. package/dist/ui/{Actions → Compose}/hooks/menu/useMenu.d.ts +2 -1
  136. package/dist/ui/Compose/hooks/menu/useMenu.d.ts.map +1 -0
  137. package/dist/ui/{Actions → Compose}/hooks/menu/useMenu.js +16 -4
  138. package/dist/ui/Compose/hooks/menu/useMenu.js.map +1 -0
  139. package/dist/ui/{Actions → Compose}/hooks/useGenerate.d.ts +4 -1
  140. package/dist/ui/Compose/hooks/useGenerate.d.ts.map +1 -0
  141. package/dist/ui/{Actions → Compose}/hooks/useGenerate.js +58 -34
  142. package/dist/ui/Compose/hooks/useGenerate.js.map +1 -0
  143. package/dist/ui/Compose/hooks/useHistory.d.ts.map +1 -0
  144. package/dist/ui/{Actions → Compose}/hooks/useHistory.js +6 -3
  145. package/dist/ui/Compose/hooks/useHistory.js.map +1 -0
  146. package/dist/utilities/editorSchemaValidator.d.ts +3 -0
  147. package/dist/utilities/editorSchemaValidator.d.ts.map +1 -0
  148. package/dist/utilities/editorSchemaValidator.js +31 -0
  149. package/dist/utilities/editorSchemaValidator.js.map +1 -0
  150. package/dist/utilities/setSafeLexicalState.d.ts +2 -2
  151. package/dist/utilities/setSafeLexicalState.d.ts.map +1 -1
  152. package/dist/utilities/setSafeLexicalState.js +5 -12
  153. package/dist/utilities/setSafeLexicalState.js.map +1 -1
  154. package/dist/utilities/updateFieldsConfig.d.ts.map +1 -1
  155. package/dist/utilities/updateFieldsConfig.js +18 -6
  156. package/dist/utilities/updateFieldsConfig.js.map +1 -1
  157. package/package.json +35 -64
  158. package/dist/ai/schemas/lexical.schema.d.ts +0 -31
  159. package/dist/ai/schemas/lexical.schema.d.ts.map +0 -1
  160. package/dist/ai/schemas/lexical.schema.js +0 -102
  161. package/dist/ai/schemas/lexical.schema.js.map +0 -1
  162. package/dist/ai/utils/generateSeedPrompt.d.ts +0 -5
  163. package/dist/ai/utils/generateSeedPrompt.d.ts.map +0 -1
  164. package/dist/ai/utils/generateSeedPrompt.js.map +0 -1
  165. package/dist/fields/DescriptionField/DescriptionField.d.ts +0 -4
  166. package/dist/fields/DescriptionField/DescriptionField.d.ts.map +0 -1
  167. package/dist/fields/DescriptionField/DescriptionField.js +0 -18
  168. package/dist/fields/DescriptionField/DescriptionField.js.map +0 -1
  169. package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts +0 -2
  170. package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts.map +0 -1
  171. package/dist/fields/LexicalEditor/ActionsFeatureComponent.js +0 -15
  172. package/dist/fields/LexicalEditor/ActionsFeatureComponent.js.map +0 -1
  173. package/dist/ui/Actions/Actions.d.ts +0 -5
  174. package/dist/ui/Actions/Actions.d.ts.map +0 -1
  175. package/dist/ui/Actions/Actions.js.map +0 -1
  176. package/dist/ui/Actions/UndoRedoActions.js.map +0 -1
  177. package/dist/ui/Actions/hooks/menu/TranslateMenu.d.ts.map +0 -1
  178. package/dist/ui/Actions/hooks/menu/TranslateMenu.js.map +0 -1
  179. package/dist/ui/Actions/hooks/menu/itemsMap.d.ts.map +0 -1
  180. package/dist/ui/Actions/hooks/menu/itemsMap.js.map +0 -1
  181. package/dist/ui/Actions/hooks/menu/useMenu.d.ts.map +0 -1
  182. package/dist/ui/Actions/hooks/menu/useMenu.js.map +0 -1
  183. package/dist/ui/Actions/hooks/useGenerate.d.ts.map +0 -1
  184. package/dist/ui/Actions/hooks/useGenerate.js.map +0 -1
  185. package/dist/ui/Actions/hooks/useHistory.d.ts.map +0 -1
  186. package/dist/ui/Actions/hooks/useHistory.js.map +0 -1
  187. package/dist/utilities/jsonToZod.d.ts +0 -3
  188. package/dist/utilities/jsonToZod.d.ts.map +0 -1
  189. package/dist/utilities/jsonToZod.js +0 -33
  190. package/dist/utilities/jsonToZod.js.map +0 -1
  191. /package/dist/ui/{Actions → Compose}/UndoRedoActions.d.ts +0 -0
  192. /package/dist/ui/{Actions → Compose}/hooks/menu/TranslateMenu.d.ts +0 -0
  193. /package/dist/ui/{Actions → Compose}/hooks/menu/items.js +0 -0
  194. /package/dist/ui/{Actions → Compose}/hooks/menu/menu.module.scss +0 -0
  195. /package/dist/ui/{Actions → Compose}/hooks/useHistory.d.ts +0 -0
package/dist/types.d.ts CHANGED
@@ -1,17 +1,19 @@
1
+ import type { JSONSchema } from 'openai/lib/jsonschema';
1
2
  import type { Endpoint, Field, GroupField } from 'payload';
2
- import { CSSProperties, MouseEventHandler } from 'react';
3
- import { LexicalBaseNode } from './ai/schemas/lexical.schema.js';
3
+ import type { CSSProperties, MouseEventHandler } from 'react';
4
4
  export interface PluginConfig {
5
5
  collections: {
6
6
  [key: string]: boolean;
7
7
  };
8
+ debugging?: boolean;
9
+ disableSponsorMessage?: boolean;
10
+ editorConfig?: {
11
+ nodes: JSONSchema[];
12
+ };
8
13
  fields?: Field[];
14
+ generatePromptOnInit?: boolean;
9
15
  globals?: string[];
10
16
  interfaceName?: string;
11
- editorConfig?: {
12
- nodes: (typeof LexicalBaseNode)[];
13
- };
14
- debugging?: boolean;
15
17
  }
16
18
  export interface GenerationModel {
17
19
  fields: string[];
@@ -50,44 +52,12 @@ export type BaseItemProps<T = any> = {
50
52
  children?: React.ReactNode;
51
53
  disabled?: boolean;
52
54
  hideIcon?: boolean;
55
+ isActive?: boolean;
56
+ isMenu?: boolean;
53
57
  onClick: (data?: unknown) => void;
54
58
  onMouseEnter?: MouseEventHandler<T> | undefined;
55
59
  onMouseLeave?: MouseEventHandler<T> | undefined;
56
60
  style?: CSSProperties | undefined;
57
- isMenu?: boolean;
58
- isActive?: boolean;
61
+ title?: string;
59
62
  };
60
- /**
61
- * This interface was referenced by `Config`'s JSON-Schema
62
- * via the `definition` "plugin-ai-instructions".
63
- */
64
- export interface PluginAiInstruction {
65
- id: string;
66
- 'schema-path'?: string | null;
67
- 'field-type'?: ('text' | 'textarea' | 'upload' | 'richText') | null;
68
- 'model-id'?: ('openai-gpt-text' | 'dall-e' | 'tts' | 'openai-gpt-object') | null;
69
- prompt?: string | null;
70
- 'openai-gpt-text-settings'?: {
71
- model?: ('gpt-4o' | 'gpt-4-turbo' | 'gpt-4o-mini' | 'gpt-3.5-turbo') | null;
72
- };
73
- 'dalle-e-settings'?: {
74
- version?: ('dall-e-3' | 'dall-e-2') | null;
75
- size?: ('256x256' | '512x512' | '1024x1024' | '1792x1024' | '1024x1792') | null;
76
- style?: ('vivid' | 'natural') | null;
77
- 'enable-prompt-optimization'?: boolean | null;
78
- };
79
- 'openai-tts-settings'?: {
80
- voice?: ('alloy' | 'echo' | 'fable' | 'onyx' | 'nova' | 'shimmer') | null;
81
- model?: ('tts-1' | 'tts-1-hd') | null;
82
- response_format?: ('mp3' | 'opus' | 'aac' | 'flac' | 'wav' | 'pcm') | null;
83
- speed?: number | null;
84
- };
85
- 'openai-gpt-object-settings'?: {
86
- model?: ('gpt-4o' | 'gpt-4-turbo' | 'gpt-4o-mini' | 'gpt-4o-2024-08-06') | null;
87
- system?: string | null;
88
- layout?: string | null;
89
- };
90
- updatedAt: string;
91
- createdAt: string;
92
- }
93
63
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/dist/types.js CHANGED
@@ -1,6 +1,3 @@
1
- /**
2
- * This interface was referenced by `Config`'s JSON-Schema
3
- * via the `definition` "plugin-ai-instructions".
4
- */ export { };
1
+ export { };
5
2
 
6
3
  //# sourceMappingURL=types.js.map
package/dist/types.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { Collection, Endpoint, Field, GroupField } from 'payload'\nimport { CSSProperties, MouseEventHandler } from 'react'\nimport { LexicalBaseNode } from './ai/schemas/lexical.schema.js'\n\nexport interface PluginConfig {\n collections: {\n [key: string]: boolean\n }\n fields?: Field[]\n globals?: string[]\n interfaceName?: string\n editorConfig?: { nodes: (typeof LexicalBaseNode)[] }\n debugging?: boolean\n}\n\nexport interface GenerationModel {\n fields: string[]\n handler?: (payload: any, options: any) => Promise<any>\n id: string\n name: string\n output: 'audio' | 'file' | 'image' | 'json' | 'text' | 'video'\n settings?: GroupField\n supportsPromptOptimization?: boolean\n}\n\nexport interface GenerationConfig {\n models: GenerationModel[]\n provider: string\n}\n\nexport type GenerateTextarea<T = any> = (args: {\n doc: T\n locale?: string\n options?: any\n}) => Promise<string> | string\n\nexport interface Instructions {\n 'collection-slug': string\n id: string\n 'model-id': string\n prompt: string\n}\n\nexport interface Endpoints {\n textarea: Omit<Endpoint, 'root'>\n upload: Omit<Endpoint, 'root'>\n}\n\nexport type ActionMenuItems =\n | 'Compose'\n | 'Expand'\n | 'Proofread'\n | 'Rephrase'\n | 'Settings'\n | 'Simplify'\n | 'Summarize'\n | 'Tone'\n | 'Translate'\n\nexport type ActionMenuEvents =\n | 'onCompose'\n | 'onExpand'\n | 'onProofread'\n | 'onRephrase'\n | 'onSettings'\n | 'onSimplify'\n | 'onSummarize'\n | 'onTone'\n | 'onTranslate'\n\nexport type UseMenuEvents = {\n [key in ActionMenuEvents]?: (data?: unknown) => void\n}\n\nexport type BaseItemProps<T = any> = {\n children?: React.ReactNode\n disabled?: boolean\n hideIcon?: boolean\n onClick: (data?: unknown) => void\n onMouseEnter?: MouseEventHandler<T> | undefined\n onMouseLeave?: MouseEventHandler<T> | undefined\n style?: CSSProperties | undefined\n isMenu?: boolean\n isActive?: boolean\n}\n\n/**\n * This interface was referenced by `Config`'s JSON-Schema\n * via the `definition` \"plugin-ai-instructions\".\n */\nexport interface PluginAiInstruction {\n id: string\n 'schema-path'?: string | null\n 'field-type'?: ('text' | 'textarea' | 'upload' | 'richText') | null\n 'model-id'?: ('openai-gpt-text' | 'dall-e' | 'tts' | 'openai-gpt-object') | null\n prompt?: string | null\n 'openai-gpt-text-settings'?: {\n model?: ('gpt-4o' | 'gpt-4-turbo' | 'gpt-4o-mini' | 'gpt-3.5-turbo') | null\n }\n 'dalle-e-settings'?: {\n version?: ('dall-e-3' | 'dall-e-2') | null\n size?: ('256x256' | '512x512' | '1024x1024' | '1792x1024' | '1024x1792') | null\n style?: ('vivid' | 'natural') | null\n 'enable-prompt-optimization'?: boolean | null\n }\n 'openai-tts-settings'?: {\n voice?: ('alloy' | 'echo' | 'fable' | 'onyx' | 'nova' | 'shimmer') | null\n model?: ('tts-1' | 'tts-1-hd') | null\n response_format?: ('mp3' | 'opus' | 'aac' | 'flac' | 'wav' | 'pcm') | null\n speed?: number | null\n }\n 'openai-gpt-object-settings'?: {\n model?: ('gpt-4o' | 'gpt-4-turbo' | 'gpt-4o-mini' | 'gpt-4o-2024-08-06') | null\n system?: string | null\n layout?: string | null\n }\n updatedAt: string\n createdAt: string\n}\n"],"names":[],"mappings":"AAsFA;;;CAGC,GACD,WA4BC"}
1
+ {"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { JSONSchema } from 'openai/lib/jsonschema'\nimport type { Endpoint, Field, GroupField } from 'payload'\nimport type { CSSProperties, MouseEventHandler } from 'react'\n\nexport interface PluginConfig {\n collections: {\n [key: string]: boolean\n }\n debugging?: boolean\n disableSponsorMessage?: boolean\n editorConfig?: { nodes: JSONSchema[] }\n fields?: Field[]\n generatePromptOnInit?: boolean\n globals?: string[]\n interfaceName?: string\n}\n\nexport interface GenerationModel {\n fields: string[]\n handler?: (payload: any, options: any) => Promise<any>\n id: string\n name: string\n output: 'audio' | 'file' | 'image' | 'json' | 'text' | 'video'\n settings?: GroupField\n supportsPromptOptimization?: boolean\n}\n\nexport interface GenerationConfig {\n models: GenerationModel[]\n provider: string\n}\n\nexport type GenerateTextarea<T = any> = (args: {\n doc: T\n locale?: string\n options?: any\n}) => Promise<string> | string\n\nexport interface Instructions {\n 'collection-slug': string\n id: string\n 'model-id': string\n prompt: string\n}\n\nexport interface Endpoints {\n textarea: Omit<Endpoint, 'root'>\n upload: Omit<Endpoint, 'root'>\n}\n\nexport type ActionMenuItems =\n | 'Compose'\n | 'Expand'\n | 'Proofread'\n | 'Rephrase'\n | 'Settings'\n | 'Simplify'\n | 'Summarize'\n | 'Tone'\n | 'Translate'\n\nexport type ActionMenuEvents =\n | 'onCompose'\n | 'onExpand'\n | 'onProofread'\n | 'onRephrase'\n | 'onSettings'\n | 'onSimplify'\n | 'onSummarize'\n | 'onTone'\n | 'onTranslate'\n\nexport type UseMenuEvents = {\n [key in ActionMenuEvents]?: (data?: unknown) => void\n}\n\nexport type BaseItemProps<T = any> = {\n children?: React.ReactNode\n disabled?: boolean\n hideIcon?: boolean\n isActive?: boolean\n isMenu?: boolean\n onClick: (data?: unknown) => void\n onMouseEnter?: MouseEventHandler<T> | undefined\n onMouseLeave?: MouseEventHandler<T> | undefined\n style?: CSSProperties | undefined\n title?: string\n}\n"],"names":[],"mappings":"AA4EA,WAWC"}
@@ -0,0 +1,9 @@
1
+ import type { FieldDescriptionServerProps } from 'payload';
2
+ import type { FC } from 'react';
3
+ type ComposeProps = {
4
+ descriptionProps?: FieldDescriptionServerProps;
5
+ instructionId: string;
6
+ };
7
+ export declare const Compose: FC<ComposeProps>;
8
+ export {};
9
+ //# sourceMappingURL=Compose.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Compose.d.ts","sourceRoot":"","sources":["../../../src/ui/Compose/Compose.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,SAAS,CAAA;AAC1D,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,OAAO,CAAA;AA6B/B,KAAK,YAAY,GAAG;IAClB,gBAAgB,CAAC,EAAE,2BAA2B,CAAA;IAC9C,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,eAAO,MAAM,OAAO,EAAE,EAAE,CAAC,YAAY,CAyJpC,CAAA"}
@@ -1,13 +1,13 @@
1
1
  'use client';
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useEditorConfigContext } from '@payloadcms/richtext-lexical/client';
4
- import { Popup, useDocumentDrawer, useField, useFieldProps } from '@payloadcms/ui';
4
+ import { FieldDescription, Popup, useDocumentDrawer, useField } from '@payloadcms/ui';
5
5
  import React, { useCallback, useEffect, useRef, useState } from 'react';
6
6
  import { PLUGIN_INSTRUCTIONS_TABLE } from '../../defaults.js';
7
7
  import { setSafeLexicalState } from '../../utilities/setSafeLexicalState.js';
8
8
  import { PluginIcon } from '../Icons/Icons.js';
9
9
  import { UndoRedoActions } from './UndoRedoActions.js';
10
- import styles from './actions.module.scss';
10
+ import styles from './compose.module.css';
11
11
  import { useMenu } from './hooks/menu/useMenu.js';
12
12
  import { useGenerate } from './hooks/useGenerate.js';
13
13
  function findParentWithClass(element, className) {
@@ -22,12 +22,12 @@ function findParentWithClass(element, className) {
22
22
  // Recursively call the function on the parent element
23
23
  return findParentWithClass(element.parentElement, className);
24
24
  }
25
- export const Actions = ({ descriptionProps = {}, instructionId })=>{
25
+ export const Compose = ({ descriptionProps, instructionId })=>{
26
26
  const [DocumentDrawer, _, { closeDrawer, openDrawer }] = useDocumentDrawer({
27
27
  id: instructionId,
28
28
  collectionSlug: PLUGIN_INSTRUCTIONS_TABLE
29
29
  });
30
- const { type: fieldType, path: pathFromContext, schemaPath } = useFieldProps();
30
+ const { field: { type: fieldType }, path: pathFromContext, schemaPath } = descriptionProps || {};
31
31
  const { editor: lexicalEditor, editorContainerRef } = useEditorConfigContext();
32
32
  // Below snippet is used to show/hide the actions menu on AI enabled fields
33
33
  const [input, setInput] = useState(null);
@@ -70,7 +70,9 @@ export const Actions = ({ descriptionProps = {}, instructionId })=>{
70
70
  actionsRef
71
71
  ]);
72
72
  const [isProcessing, setIsProcessing] = useState(false);
73
- const { generate, isLoading } = useGenerate();
73
+ const { generate, isLoading, stop } = useGenerate({
74
+ instructionId
75
+ });
74
76
  const { ActiveComponent, Menu } = useMenu({
75
77
  onCompose: async ()=>{
76
78
  console.log('Composing...');
@@ -113,14 +115,14 @@ export const Actions = ({ descriptionProps = {}, instructionId })=>{
113
115
  });
114
116
  },
115
117
  onTranslate: async (data)=>{
116
- console.log('Translating...', data);
118
+ console.log('Translating...');
117
119
  await generate({
118
120
  action: 'Translate',
119
121
  params: data
120
122
  });
121
123
  }
122
124
  });
123
- const { setValue, value } = useField({
125
+ const { setValue } = useField({
124
126
  path: pathFromContext
125
127
  });
126
128
  const setIfValueIsLexicalState = useCallback((val)=>{
@@ -129,41 +131,50 @@ export const Actions = ({ descriptionProps = {}, instructionId })=>{
129
131
  }
130
132
  // DO NOT PROVIDE lexicalEditor as a dependency, it freaks out and does not update the editor after first undo/redo
131
133
  }, []);
132
- return /*#__PURE__*/ _jsx(React.Fragment, {
133
- children: /*#__PURE__*/ _jsxs("label", {
134
- className: `${styles.actions}`,
135
- onClick: (e)=>e.preventDefault(),
136
- ref: actionsRef,
137
- children: [
138
- /*#__PURE__*/ _jsx(DocumentDrawer, {
139
- onSave: ()=>{
140
- closeDrawer();
141
- }
142
- }),
143
- /*#__PURE__*/ _jsx(Popup, {
144
- button: /*#__PURE__*/ _jsx(PluginIcon, {
145
- isLoading: isProcessing || isLoading
134
+ return /*#__PURE__*/ _jsxs(React.Fragment, {
135
+ children: [
136
+ /*#__PURE__*/ _jsxs("label", {
137
+ className: `${styles.actions}`,
138
+ onClick: (e)=>e.preventDefault(),
139
+ ref: actionsRef,
140
+ role: "presentation",
141
+ children: [
142
+ /*#__PURE__*/ _jsx(DocumentDrawer, {
143
+ onSave: ()=>{
144
+ closeDrawer();
145
+ }
146
+ }),
147
+ /*#__PURE__*/ _jsx(Popup, {
148
+ button: /*#__PURE__*/ _jsx(PluginIcon, {
149
+ isLoading: isProcessing || isLoading
150
+ }),
151
+ render: ({ close })=>{
152
+ return /*#__PURE__*/ _jsx(Menu, {
153
+ isLoading: isProcessing || isLoading,
154
+ onClose: close
155
+ });
156
+ },
157
+ verticalAlign: "bottom"
158
+ }),
159
+ /*#__PURE__*/ _jsx(ActiveComponent, {
160
+ isLoading: isProcessing || isLoading,
161
+ stop: stop
146
162
  }),
147
- render: ({ close })=>{
148
- return /*#__PURE__*/ _jsx(Menu, {
149
- isLoading: isProcessing || isLoading,
150
- onClose: close
151
- });
152
- },
153
- verticalAlign: "bottom"
154
- }),
155
- /*#__PURE__*/ _jsx(ActiveComponent, {
156
- isLoading: isProcessing || isLoading
157
- }),
158
- /*#__PURE__*/ _jsx(UndoRedoActions, {
159
- onChange: (val)=>{
160
- setValue(val);
161
- setIfValueIsLexicalState(val);
162
- }
163
+ /*#__PURE__*/ _jsx(UndoRedoActions, {
164
+ onChange: (val)=>{
165
+ setValue(val);
166
+ setIfValueIsLexicalState(val);
167
+ }
168
+ })
169
+ ]
170
+ }),
171
+ descriptionProps ? /*#__PURE__*/ _jsx("div", {
172
+ children: /*#__PURE__*/ _jsx(FieldDescription, {
173
+ ...descriptionProps
163
174
  })
164
- ]
165
- })
175
+ }) : null
176
+ ]
166
177
  });
167
178
  };
168
179
 
169
- //# sourceMappingURL=Actions.js.map
180
+ //# sourceMappingURL=Compose.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/ui/Compose/Compose.tsx"],"sourcesContent":["'use client'\n\nimport type { FieldDescriptionServerProps } from 'payload'\nimport type { FC } from 'react'\n\nimport { useEditorConfigContext } from '@payloadcms/richtext-lexical/client'\nimport { FieldDescription, Popup, useDocumentDrawer, useField } from '@payloadcms/ui'\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\n\nimport { PLUGIN_INSTRUCTIONS_TABLE } from '../../defaults.js'\nimport { setSafeLexicalState } from '../../utilities/setSafeLexicalState.js'\nimport { PluginIcon } from '../Icons/Icons.js'\nimport { UndoRedoActions } from './UndoRedoActions.js'\nimport styles from './compose.module.css'\nimport { useMenu } from './hooks/menu/useMenu.js'\nimport { useGenerate } from './hooks/useGenerate.js'\n\nfunction findParentWithClass(element, className) {\n // Base case: if the element is null or we've reached the top of the DOM\n if (!element || element === document.body) {\n return null\n }\n\n // Check if the current element has the class we're looking for\n if (element.classList.contains(className)) {\n return element\n }\n\n // Recursively call the function on the parent element\n return findParentWithClass(element.parentElement, className)\n}\n\ntype ComposeProps = {\n descriptionProps?: FieldDescriptionServerProps\n instructionId: string\n}\n\nexport const Compose: FC<ComposeProps> = ({ descriptionProps, instructionId }) => {\n const [DocumentDrawer, _, { closeDrawer, openDrawer }] = useDocumentDrawer({\n id: instructionId,\n collectionSlug: PLUGIN_INSTRUCTIONS_TABLE,\n })\n\n const {\n field: { type: fieldType },\n path: pathFromContext,\n schemaPath,\n } = descriptionProps || ({} as FieldDescriptionServerProps)\n const { editor: lexicalEditor, editorContainerRef } = useEditorConfigContext()\n\n // Below snippet is used to show/hide the actions menu on AI enabled fields\n const [input, setInput] = useState(null)\n const actionsRef = useRef(null)\n\n // Set input element for current field\n useEffect(() => {\n if (!actionsRef.current) return\n\n const fieldId = `field-${pathFromContext.replace(/\\./g, '__')}`\n const inputElement = document.getElementById(fieldId)\n\n if (!inputElement && fieldType === 'richText') {\n setInput(editorContainerRef.current)\n } else {\n actionsRef.current.setAttribute('for', fieldId)\n setInput(inputElement)\n }\n }, [pathFromContext, schemaPath, actionsRef, editorContainerRef])\n\n // Show or hide actions menu on field\n useEffect(() => {\n if (!input || !actionsRef.current) return\n\n actionsRef.current.classList.add(styles.actions_hidden)\n input.addEventListener('click', (event) => {\n document.querySelectorAll('.ai-plugin-active')?.forEach((element) => {\n const actionElement = element.querySelector(`.${styles.actions}`)\n if (actionElement) {\n actionElement.classList.add(styles.actions_hidden)\n element.classList.remove('ai-plugin-active')\n }\n })\n\n actionsRef.current.classList.remove(styles.actions_hidden)\n const parentWithClass = findParentWithClass(event.target, 'field-type')\n parentWithClass.classList.add('ai-plugin-active')\n })\n }, [input, actionsRef])\n\n const [isProcessing, setIsProcessing] = useState(false)\n const { generate, isLoading, stop } = useGenerate({ instructionId })\n\n const { ActiveComponent, Menu } = useMenu({\n onCompose: async () => {\n console.log('Composing...')\n setIsProcessing(true)\n await generate({\n action: 'Compose',\n }).finally(() => {\n setIsProcessing(false)\n })\n },\n onExpand: async () => {\n console.log('Expanding...')\n await generate({\n action: 'Expand',\n })\n },\n onProofread: async () => {\n console.log('Proofreading...')\n await generate({\n action: 'Proofread',\n })\n },\n onRephrase: async () => {\n console.log('Rephrasing...')\n await generate({\n action: 'Rephrase',\n })\n },\n onSettings: openDrawer,\n onSimplify: async () => {\n console.log('Simplifying...')\n await generate({\n action: 'Simplify',\n })\n },\n onSummarize: async () => {\n console.log('Summarizing...')\n await generate({\n action: 'Summarize',\n })\n },\n onTranslate: async (data) => {\n console.log('Translating...')\n await generate({\n action: 'Translate',\n params: data,\n })\n },\n })\n\n const { setValue } = useField<string>({\n path: pathFromContext,\n })\n\n const setIfValueIsLexicalState = useCallback((val: any) => {\n if (val.root && lexicalEditor) {\n setSafeLexicalState(JSON.stringify(val), lexicalEditor)\n }\n\n // DO NOT PROVIDE lexicalEditor as a dependency, it freaks out and does not update the editor after first undo/redo\n }, [])\n\n return (\n <React.Fragment>\n <label\n className={`${styles.actions}`}\n onClick={(e) => e.preventDefault()}\n ref={actionsRef}\n role=\"presentation\"\n >\n <DocumentDrawer\n onSave={() => {\n closeDrawer()\n }}\n />\n <Popup\n button={<PluginIcon isLoading={isProcessing || isLoading} />}\n render={({ close }) => {\n return <Menu isLoading={isProcessing || isLoading} onClose={close} />\n }}\n verticalAlign=\"bottom\"\n />\n <ActiveComponent isLoading={isProcessing || isLoading} stop={stop} />\n <UndoRedoActions\n onChange={(val) => {\n setValue(val)\n setIfValueIsLexicalState(val)\n }}\n />\n </label>\n {/*Render incoming description field*/}\n {descriptionProps ? (\n <div>\n <FieldDescription {...descriptionProps} />\n </div>\n ) : null}\n </React.Fragment>\n )\n}\n"],"names":["useEditorConfigContext","FieldDescription","Popup","useDocumentDrawer","useField","React","useCallback","useEffect","useRef","useState","PLUGIN_INSTRUCTIONS_TABLE","setSafeLexicalState","PluginIcon","UndoRedoActions","styles","useMenu","useGenerate","findParentWithClass","element","className","document","body","classList","contains","parentElement","Compose","descriptionProps","instructionId","DocumentDrawer","_","closeDrawer","openDrawer","id","collectionSlug","field","type","fieldType","path","pathFromContext","schemaPath","editor","lexicalEditor","editorContainerRef","input","setInput","actionsRef","current","fieldId","replace","inputElement","getElementById","setAttribute","add","actions_hidden","addEventListener","event","querySelectorAll","forEach","actionElement","querySelector","actions","remove","parentWithClass","target","isProcessing","setIsProcessing","generate","isLoading","stop","ActiveComponent","Menu","onCompose","console","log","action","finally","onExpand","onProofread","onRephrase","onSettings","onSimplify","onSummarize","onTranslate","data","params","setValue","setIfValueIsLexicalState","val","root","JSON","stringify","Fragment","label","onClick","e","preventDefault","ref","role","onSave","button","render","close","onClose","verticalAlign","onChange","div"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"UndoRedoActions.d.ts","sourceRoot":"","sources":["../../../src/ui/Actions/UndoRedoActions.tsx"],"names":[],"mappings":"AAGA,eAAO,MAAM,eAAe,iBAAkB;IAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,IAAI,CAAA;CAAE,4CAuCjF,CAAA"}
1
+ {"version":3,"file":"UndoRedoActions.d.ts","sourceRoot":"","sources":["../../../src/ui/Compose/UndoRedoActions.tsx"],"names":[],"mappings":"AAGA,eAAO,MAAM,eAAe,iBAAkB;IAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,IAAI,CAAA;CAAE,4CA0DjF,CAAA"}
@@ -1,6 +1,6 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  import { useHistory } from './hooks/useHistory.js';
3
- import React, { useCallback } from 'react';
3
+ import React, { useCallback, useEffect, useState } from 'react';
4
4
  export const UndoRedoActions = ({ onChange })=>{
5
5
  const { canRedo, canUndo, redo, undo } = useHistory();
6
6
  const redoHistoryValue = useCallback((event)=>{
@@ -21,19 +21,32 @@ export const UndoRedoActions = ({ onChange })=>{
21
21
  }, [
22
22
  undo
23
23
  ]);
24
- if (!canUndo && !canRedo) return null;
24
+ // Delay rendering until the client-side hydration is complete
25
+ const [isMounted, setIsMounted] = useState(false);
26
+ useEffect(()=>{
27
+ setIsMounted(true);
28
+ }, []);
29
+ if (!isMounted || !canUndo && !canRedo) return null;
25
30
  return /*#__PURE__*/ _jsxs(_Fragment, {
26
31
  children: [
27
32
  /*#__PURE__*/ _jsx("button", {
28
33
  onClick: undoHistoryValue,
29
34
  type: "button",
30
35
  disabled: !canUndo,
36
+ className: `btn btn--size-small btn--style-secondary ${!canUndo && 'btn--disabled'}`,
37
+ style: {
38
+ marginBlock: 0
39
+ },
31
40
  children: "Undo"
32
41
  }),
33
42
  /*#__PURE__*/ _jsx("button", {
34
43
  onClick: redoHistoryValue,
35
44
  type: "button",
36
45
  disabled: !canRedo,
46
+ className: `btn btn--size-small btn--style-secondary ${!canRedo && 'btn--disabled'}`,
47
+ style: {
48
+ marginBlock: 0
49
+ },
37
50
  children: "Redo"
38
51
  })
39
52
  ]
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/ui/Compose/UndoRedoActions.tsx"],"sourcesContent":["import { useHistory } from './hooks/useHistory.js'\nimport React, { MouseEventHandler, useCallback, useEffect, useState } from 'react'\n\nexport const UndoRedoActions = ({ onChange }: { onChange: (val: unknown) => void }) => {\n const { canRedo, canUndo, redo, undo } = useHistory()\n\n const redoHistoryValue = useCallback<MouseEventHandler>(\n (event) => {\n event.stopPropagation()\n\n const value = redo()\n if (value) {\n onChange(value)\n }\n },\n [redo],\n )\n\n const undoHistoryValue = useCallback<MouseEventHandler>(\n (event) => {\n event.stopPropagation()\n\n const value = undo()\n if (value) {\n onChange(value)\n }\n },\n [undo],\n )\n\n // Delay rendering until the client-side hydration is complete\n const [isMounted, setIsMounted] = useState(false)\n\n useEffect(() => {\n setIsMounted(true)\n }, [])\n\n if (!isMounted || (!canUndo && !canRedo)) return null\n\n return (\n <>\n <button\n onClick={undoHistoryValue}\n type=\"button\"\n disabled={!canUndo}\n className={`btn btn--size-small btn--style-secondary ${!canUndo && 'btn--disabled'}`}\n style={{ marginBlock: 0 }}\n >\n Undo\n </button>\n <button\n onClick={redoHistoryValue}\n type=\"button\"\n disabled={!canRedo}\n className={`btn btn--size-small btn--style-secondary ${!canRedo && 'btn--disabled'}`}\n style={{ marginBlock: 0 }}\n >\n Redo\n </button>\n </>\n )\n}\n"],"names":["useHistory","React","useCallback","useEffect","useState","UndoRedoActions","onChange","canRedo","canUndo","redo","undo","redoHistoryValue","event","stopPropagation","value","undoHistoryValue","isMounted","setIsMounted","button","onClick","type","disabled","className","style","marginBlock"],"mappings":";AAAA,SAASA,UAAU,QAAQ,wBAAuB;AAClD,OAAOC,SAA4BC,WAAW,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,QAAO;AAElF,OAAO,MAAMC,kBAAkB,CAAC,EAAEC,QAAQ,EAAwC;IAChF,MAAM,EAAEC,OAAO,EAAEC,OAAO,EAAEC,IAAI,EAAEC,IAAI,EAAE,GAAGV;IAEzC,MAAMW,mBAAmBT,YACvB,CAACU;QACCA,MAAMC,eAAe;QAErB,MAAMC,QAAQL;QACd,IAAIK,OAAO;YACTR,SAASQ;QACX;IACF,GACA;QAACL;KAAK;IAGR,MAAMM,mBAAmBb,YACvB,CAACU;QACCA,MAAMC,eAAe;QAErB,MAAMC,QAAQJ;QACd,IAAII,OAAO;YACTR,SAASQ;QACX;IACF,GACA;QAACJ;KAAK;IAGR,8DAA8D;IAC9D,MAAM,CAACM,WAAWC,aAAa,GAAGb,SAAS;IAE3CD,UAAU;QACRc,aAAa;IACf,GAAG,EAAE;IAEL,IAAI,CAACD,aAAc,CAACR,WAAW,CAACD,SAAU,OAAO;IAEjD,qBACE;;0BACE,KAACW;gBACCC,SAASJ;gBACTK,MAAK;gBACLC,UAAU,CAACb;gBACXc,WAAW,CAAC,yCAAyC,EAAE,CAACd,WAAW,iBAAiB;gBACpFe,OAAO;oBAAEC,aAAa;gBAAE;0BACzB;;0BAGD,KAACN;gBACCC,SAASR;gBACTS,MAAK;gBACLC,UAAU,CAACd;gBACXe,WAAW,CAAC,yCAAyC,EAAE,CAACf,WAAW,iBAAiB;gBACpFgB,OAAO;oBAAEC,aAAa;gBAAE;0BACzB;;;;AAKP,EAAC"}
@@ -8,12 +8,12 @@
8
8
  max-height: 100px;
9
9
  opacity: 1;
10
10
  align-items: center;
11
+ }
11
12
 
12
- &_hidden {
13
- max-height: 0;
14
- overflow: hidden;
15
- padding: 0 5px;
16
- margin: 0;
17
- opacity: 0;
18
- }
13
+ .actions_hidden {
14
+ max-height: 0;
15
+ overflow: hidden;
16
+ padding: 0 5px;
17
+ margin: 0;
18
+ opacity: 0;
19
19
  }
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
2
  import type { BaseItemProps } from '../../../../types.js';
3
3
  export declare const Item: React.FC<BaseItemProps>;
4
- export declare const createMenuItem: (IconComponent: any, initialText: any) => React.MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
4
+ export declare const createMenuItem: (IconComponent: any, initialText: any) => React.MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
5
5
  //# sourceMappingURL=Item.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Item.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Actions/hooks/menu/Item.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAe,MAAM,OAAO,CAAA;AAEnC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAKzD,eAAO,MAAM,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAaxC,CAAA;AAED,eAAO,MAAM,cAAc,mIACyC,aAAa,6CAM7E,CAAA"}
1
+ {"version":3,"file":"Item.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Compose/hooks/menu/Item.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAe,MAAM,OAAO,CAAA;AAEnC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAKzD,eAAO,MAAM,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAaxC,CAAA;AAED,eAAO,MAAM,cAAc,mIACyC,aAAa,6CAM7E,CAAA"}
@@ -2,7 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import React, { memo } from 'react';
3
3
  import { ArrowIcon } from '../../../Icons/Icons.js';
4
4
  import styles from './menu.module.scss';
5
- export const Item = /*#__PURE__*/ memo(({ children, disabled, onClick, isActive, ...rest })=>/*#__PURE__*/ _jsx("span", {
5
+ export const Item = /*#__PURE__*/ memo(({ children, disabled, isActive, onClick, ...rest })=>/*#__PURE__*/ _jsx("span", {
6
6
  className: styles.generate_button + ' ' + (isActive ? styles.active : ''),
7
7
  "data-disabled": disabled,
8
8
  onClick: !disabled ? onClick : null,
@@ -11,7 +11,7 @@ export const Item = /*#__PURE__*/ memo(({ children, disabled, onClick, isActive,
11
11
  ...rest,
12
12
  children: children
13
13
  }));
14
- export const createMenuItem = (IconComponent, initialText)=>/*#__PURE__*/ memo(({ children, disabled, hideIcon, onClick, isMenu, ...rest })=>/*#__PURE__*/ _jsxs(Item, {
14
+ export const createMenuItem = (IconComponent, initialText)=>/*#__PURE__*/ memo(({ children, disabled, hideIcon, isMenu, onClick, ...rest })=>/*#__PURE__*/ _jsxs(Item, {
15
15
  disabled: disabled,
16
16
  onClick: onClick,
17
17
  ...rest,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/ui/Actions/hooks/menu/Item.tsx"],"sourcesContent":["import React, { memo } from 'react'\n\nimport type { BaseItemProps } from '../../../../types.js'\n\nimport { ArrowIcon } from '../../../Icons/Icons.js'\nimport styles from './menu.module.scss'\n\nexport const Item: React.FC<BaseItemProps> = memo(\n ({ children, disabled, onClick, isActive, ...rest }) => (\n <span\n className={styles.generate_button + ' ' + (isActive ? styles.active : '')}\n data-disabled={disabled}\n onClick={!disabled ? onClick : null}\n onKeyDown={!disabled ? onClick : null}\n role=\"presentation\"\n {...rest}\n >\n {children}\n </span>\n ),\n)\n\nexport const createMenuItem = (IconComponent, initialText) =>\n memo(({ children, disabled, hideIcon, onClick, isMenu, ...rest }: BaseItemProps) => (\n <Item disabled={disabled} onClick={onClick} {...rest}>\n {hideIcon || <IconComponent size={18} />}\n {children || <span className={styles.text}>{initialText}</span>}\n {isMenu && <ArrowIcon size={18} />}\n </Item>\n ))\n"],"names":["React","memo","ArrowIcon","styles","Item","children","disabled","onClick","isActive","rest","span","className","generate_button","active","data-disabled","onKeyDown","role","createMenuItem","IconComponent","initialText","hideIcon","isMenu","size","text"],"mappings":";AAAA,OAAOA,SAASC,IAAI,QAAQ,QAAO;AAInC,SAASC,SAAS,QAAQ,0BAAyB;AACnD,OAAOC,YAAY,qBAAoB;AAEvC,OAAO,MAAMC,qBAAgCH,KAC3C,CAAC,EAAEI,QAAQ,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,QAAQ,EAAE,GAAGC,MAAM,iBACjD,KAACC;QACCC,WAAWR,OAAOS,eAAe,GAAG,MAAOJ,CAAAA,WAAWL,OAAOU,MAAM,GAAG,EAAC;QACvEC,iBAAeR;QACfC,SAAS,CAACD,WAAWC,UAAU;QAC/BQ,WAAW,CAACT,WAAWC,UAAU;QACjCS,MAAK;QACJ,GAAGP,IAAI;kBAEPJ;QAGN;AAED,OAAO,MAAMY,iBAAiB,CAACC,eAAeC,4BAC5ClB,KAAK,CAAC,EAAEI,QAAQ,EAAEC,QAAQ,EAAEc,QAAQ,EAAEb,OAAO,EAAEc,MAAM,EAAE,GAAGZ,MAAqB,iBAC7E,MAACL;YAAKE,UAAUA;YAAUC,SAASA;YAAU,GAAGE,IAAI;;gBACjDW,0BAAY,KAACF;oBAAcI,MAAM;;gBACjCjB,0BAAY,KAACK;oBAAKC,WAAWR,OAAOoB,IAAI;8BAAGJ;;gBAC3CE,wBAAU,KAACnB;oBAAUoB,MAAM;;;YAE9B"}
1
+ {"version":3,"sources":["../../../../../src/ui/Compose/hooks/menu/Item.tsx"],"sourcesContent":["import React, { memo } from 'react'\n\nimport type { BaseItemProps } from '../../../../types.js'\n\nimport { ArrowIcon } from '../../../Icons/Icons.js'\nimport styles from './menu.module.scss'\n\nexport const Item: React.FC<BaseItemProps> = memo(\n ({ children, disabled, isActive, onClick, ...rest }) => (\n <span\n className={styles.generate_button + ' ' + (isActive ? styles.active : '')}\n data-disabled={disabled}\n onClick={!disabled ? onClick : null}\n onKeyDown={!disabled ? onClick : null}\n role=\"presentation\"\n {...rest}\n >\n {children}\n </span>\n ),\n)\n\nexport const createMenuItem = (IconComponent, initialText) =>\n memo(({ children, disabled, hideIcon, isMenu, onClick, ...rest }: BaseItemProps) => (\n <Item disabled={disabled} onClick={onClick} {...rest}>\n {hideIcon || <IconComponent size={18} />}\n {children || <span className={styles.text}>{initialText}</span>}\n {isMenu && <ArrowIcon size={18} />}\n </Item>\n ))\n"],"names":["React","memo","ArrowIcon","styles","Item","children","disabled","isActive","onClick","rest","span","className","generate_button","active","data-disabled","onKeyDown","role","createMenuItem","IconComponent","initialText","hideIcon","isMenu","size","text"],"mappings":";AAAA,OAAOA,SAASC,IAAI,QAAQ,QAAO;AAInC,SAASC,SAAS,QAAQ,0BAAyB;AACnD,OAAOC,YAAY,qBAAoB;AAEvC,OAAO,MAAMC,qBAAgCH,KAC3C,CAAC,EAAEI,QAAQ,EAAEC,QAAQ,EAAEC,QAAQ,EAAEC,OAAO,EAAE,GAAGC,MAAM,iBACjD,KAACC;QACCC,WAAWR,OAAOS,eAAe,GAAG,MAAOL,CAAAA,WAAWJ,OAAOU,MAAM,GAAG,EAAC;QACvEC,iBAAeR;QACfE,SAAS,CAACF,WAAWE,UAAU;QAC/BO,WAAW,CAACT,WAAWE,UAAU;QACjCQ,MAAK;QACJ,GAAGP,IAAI;kBAEPJ;QAGN;AAED,OAAO,MAAMY,iBAAiB,CAACC,eAAeC,4BAC5ClB,KAAK,CAAC,EAAEI,QAAQ,EAAEC,QAAQ,EAAEc,QAAQ,EAAEC,MAAM,EAAEb,OAAO,EAAE,GAAGC,MAAqB,iBAC7E,MAACL;YAAKE,UAAUA;YAAUE,SAASA;YAAU,GAAGC,IAAI;;gBACjDW,0BAAY,KAACF;oBAAcI,MAAM;;gBACjCjB,0BAAY,KAACK;oBAAKC,WAAWR,OAAOoB,IAAI;8BAAGJ;;gBAC3CE,wBAAU,KAACnB;oBAAUoB,MAAM;;;YAE9B"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TranslateMenu.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Compose/hooks/menu/TranslateMenu.tsx"],"names":[],"mappings":"AAOA,eAAO,MAAM,aAAa;;6CA0EzB,CAAA"}
@@ -1,8 +1,8 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import React, { useState } from 'react';
3
2
  import locales from 'locale-codes';
4
- import { Translate } from './items.js';
3
+ import React, { useState } from 'react';
5
4
  import { Item } from './Item.js';
5
+ import { Translate } from './items.js';
6
6
  import styles from './menu.module.scss';
7
7
  export const TranslateMenu = ({ onClick })=>{
8
8
  const [show, setShow] = useState(false);
@@ -20,12 +20,12 @@ export const TranslateMenu = ({ onClick })=>{
20
20
  },
21
21
  children: [
22
22
  /*#__PURE__*/ _jsx(Translate, {
23
+ isActive: show,
24
+ isMenu: true,
23
25
  onClick: ()=>{
24
26
  setShow(!show);
25
27
  },
26
- onMouseEnter: ()=>setShow(true),
27
- isMenu: true,
28
- isActive: show
28
+ onMouseEnter: ()=>setShow(true)
29
29
  }),
30
30
  /*#__PURE__*/ _jsx("div", {
31
31
  className: styles.hoverMenu,
@@ -36,15 +36,13 @@ export const TranslateMenu = ({ onClick })=>{
36
36
  /*#__PURE__*/ _jsx(Item, {
37
37
  onClick: ()=>{},
38
38
  style: {
39
- position: 'sticky',
40
- top: 0,
39
+ background: 'transparent',
41
40
  padding: '0 0 5px 0',
42
- background: 'transparent'
41
+ position: 'sticky',
42
+ top: 0
43
43
  },
44
44
  children: /*#__PURE__*/ _jsx("input", {
45
45
  className: styles.menuInput,
46
- placeholder: 'Search...',
47
- onFocus: ()=>setInputFocus(true),
48
46
  onBlur: ()=>setInputFocus(false),
49
47
  onChange: (event)=>{
50
48
  const value = event.target.value;
@@ -52,7 +50,9 @@ export const TranslateMenu = ({ onClick })=>{
52
50
  const lowerCaseValue = value.toLowerCase();
53
51
  return l.name.toLowerCase().startsWith(lowerCaseValue) || l.location.toLowerCase().startsWith(lowerCaseValue) || l.tag.toLowerCase().startsWith(lowerCaseValue);
54
52
  }));
55
- }
53
+ },
54
+ onFocus: ()=>setInputFocus(true),
55
+ placeholder: "Search..."
56
56
  })
57
57
  }),
58
58
  languages.map((locale)=>{
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/ui/Compose/hooks/menu/TranslateMenu.tsx"],"sourcesContent":["import locales from 'locale-codes'\nimport React, { useState } from 'react'\n\nimport { Item } from './Item.js'\nimport { Translate } from './items.js'\nimport styles from './menu.module.scss'\n\nexport const TranslateMenu = ({ onClick }) => {\n const [show, setShow] = useState(false)\n\n const filteredLocales = locales.all.filter((a) => {\n return a.tag && a.location\n })\n\n const [languages, setLanguages] = useState(filteredLocales)\n const [inputFocus, setInputFocus] = useState(false)\n\n return (\n <div\n className={styles.menu}\n onMouseLeave={() => {\n if (!inputFocus) {\n setShow(false)\n }\n }}\n >\n <Translate\n isActive={show}\n isMenu\n onClick={() => {\n setShow(!show)\n }}\n onMouseEnter={() => setShow(true)}\n />\n <div className={styles.hoverMenu} data-show={show}>\n <div className={`${styles.menu} ${styles.subMenu}`}>\n <Item\n onClick={() => {}}\n style={{\n background: 'transparent',\n padding: '0 0 5px 0',\n position: 'sticky',\n top: 0,\n }}\n >\n <input\n className={styles.menuInput}\n onBlur={() => setInputFocus(false)}\n onChange={(event) => {\n const value = event.target.value\n setLanguages(\n filteredLocales.filter((l) => {\n const lowerCaseValue = value.toLowerCase()\n return (\n l.name.toLowerCase().startsWith(lowerCaseValue) ||\n l.location.toLowerCase().startsWith(lowerCaseValue) ||\n l.tag.toLowerCase().startsWith(lowerCaseValue)\n )\n }),\n )\n }}\n onFocus={() => setInputFocus(true)}\n placeholder=\"Search...\"\n />\n </Item>\n {languages.map((locale) => {\n return (\n <Item\n key={locale.tag}\n onClick={() => {\n onClick({ locale: locale.tag })\n }}\n >\n <span className={styles.ellipsis}>{`${locale.location} (${locale.tag})`}</span>\n </Item>\n )\n })}\n </div>\n </div>\n </div>\n )\n}\n"],"names":["locales","React","useState","Item","Translate","styles","TranslateMenu","onClick","show","setShow","filteredLocales","all","filter","a","tag","location","languages","setLanguages","inputFocus","setInputFocus","div","className","menu","onMouseLeave","isActive","isMenu","onMouseEnter","hoverMenu","data-show","subMenu","style","background","padding","position","top","input","menuInput","onBlur","onChange","event","value","target","l","lowerCaseValue","toLowerCase","name","startsWith","onFocus","placeholder","map","locale","span","ellipsis"],"mappings":";AAAA,OAAOA,aAAa,eAAc;AAClC,OAAOC,SAASC,QAAQ,QAAQ,QAAO;AAEvC,SAASC,IAAI,QAAQ,YAAW;AAChC,SAASC,SAAS,QAAQ,aAAY;AACtC,OAAOC,YAAY,qBAAoB;AAEvC,OAAO,MAAMC,gBAAgB,CAAC,EAAEC,OAAO,EAAE;IACvC,MAAM,CAACC,MAAMC,QAAQ,GAAGP,SAAS;IAEjC,MAAMQ,kBAAkBV,QAAQW,GAAG,CAACC,MAAM,CAAC,CAACC;QAC1C,OAAOA,EAAEC,GAAG,IAAID,EAAEE,QAAQ;IAC5B;IAEA,MAAM,CAACC,WAAWC,aAAa,GAAGf,SAASQ;IAC3C,MAAM,CAACQ,YAAYC,cAAc,GAAGjB,SAAS;IAE7C,qBACE,MAACkB;QACCC,WAAWhB,OAAOiB,IAAI;QACtBC,cAAc;YACZ,IAAI,CAACL,YAAY;gBACfT,QAAQ;YACV;QACF;;0BAEA,KAACL;gBACCoB,UAAUhB;gBACViB,MAAM;gBACNlB,SAAS;oBACPE,QAAQ,CAACD;gBACX;gBACAkB,cAAc,IAAMjB,QAAQ;;0BAE9B,KAACW;gBAAIC,WAAWhB,OAAOsB,SAAS;gBAAEC,aAAWpB;0BAC3C,cAAA,MAACY;oBAAIC,WAAW,GAAGhB,OAAOiB,IAAI,CAAC,CAAC,EAAEjB,OAAOwB,OAAO,EAAE;;sCAChD,KAAC1B;4BACCI,SAAS,KAAO;4BAChBuB,OAAO;gCACLC,YAAY;gCACZC,SAAS;gCACTC,UAAU;gCACVC,KAAK;4BACP;sCAEA,cAAA,KAACC;gCACCd,WAAWhB,OAAO+B,SAAS;gCAC3BC,QAAQ,IAAMlB,cAAc;gCAC5BmB,UAAU,CAACC;oCACT,MAAMC,QAAQD,MAAME,MAAM,CAACD,KAAK;oCAChCvB,aACEP,gBAAgBE,MAAM,CAAC,CAAC8B;wCACtB,MAAMC,iBAAiBH,MAAMI,WAAW;wCACxC,OACEF,EAAEG,IAAI,CAACD,WAAW,GAAGE,UAAU,CAACH,mBAChCD,EAAE3B,QAAQ,CAAC6B,WAAW,GAAGE,UAAU,CAACH,mBACpCD,EAAE5B,GAAG,CAAC8B,WAAW,GAAGE,UAAU,CAACH;oCAEnC;gCAEJ;gCACAI,SAAS,IAAM5B,cAAc;gCAC7B6B,aAAY;;;wBAGfhC,UAAUiC,GAAG,CAAC,CAACC;4BACd,qBACE,KAAC/C;gCAECI,SAAS;oCACPA,QAAQ;wCAAE2C,QAAQA,OAAOpC,GAAG;oCAAC;gCAC/B;0CAEA,cAAA,KAACqC;oCAAK9B,WAAWhB,OAAO+C,QAAQ;8CAAG,GAAGF,OAAOnC,QAAQ,CAAC,EAAE,EAAEmC,OAAOpC,GAAG,CAAC,CAAC,CAAC;;+BALlEoC,OAAOpC,GAAG;wBAQrB;;;;;;AAKV,EAAC"}
@@ -1,9 +1,9 @@
1
- export declare const Proofread: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
2
- export declare const Rephrase: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
3
- export declare const Translate: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
4
- export declare const Expand: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
5
- export declare const Summarize: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
6
- export declare const Simplify: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
7
- export declare const Compose: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
8
- export declare const Settings: import("react").MemoExoticComponent<({ children, disabled, hideIcon, onClick, isMenu, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
1
+ export declare const Proofread: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
2
+ export declare const Rephrase: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
3
+ export declare const Translate: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
4
+ export declare const Expand: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
5
+ export declare const Summarize: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
6
+ export declare const Simplify: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
7
+ export declare const Compose: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
8
+ export declare const Settings: import("react").MemoExoticComponent<({ children, disabled, hideIcon, isMenu, onClick, ...rest }: import("../../../../types.js").BaseItemProps) => import("react/jsx-runtime").JSX.Element>;
9
9
  //# sourceMappingURL=items.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"items.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Actions/hooks/menu/items.tsx"],"names":[],"mappings":"AAYA,eAAO,MAAM,SAAS,4LAA8C,CAAA;AACpE,eAAO,MAAM,QAAQ,4LAA2C,CAAA;AAChE,eAAO,MAAM,SAAS,4LAA6C,CAAA;AACnE,eAAO,MAAM,MAAM,4LAA0C,CAAA;AAC7D,eAAO,MAAM,SAAS,4LAA6C,CAAA;AACnE,eAAO,MAAM,QAAQ,4LAA0C,CAAA;AAC/D,eAAO,MAAM,OAAO,4LAA4C,CAAA;AAChE,eAAO,MAAM,QAAQ,4LAAuC,CAAA"}
1
+ {"version":3,"file":"items.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Compose/hooks/menu/items.tsx"],"names":[],"mappings":"AAYA,eAAO,MAAM,SAAS,4LAA8C,CAAA;AACpE,eAAO,MAAM,QAAQ,4LAA2C,CAAA;AAChE,eAAO,MAAM,SAAS,4LAA6C,CAAA;AACnE,eAAO,MAAM,MAAM,4LAA0C,CAAA;AAC7D,eAAO,MAAM,SAAS,4LAA6C,CAAA;AACnE,eAAO,MAAM,QAAQ,4LAA0C,CAAA;AAC/D,eAAO,MAAM,OAAO,4LAA4C,CAAA;AAChE,eAAO,MAAM,QAAQ,4LAAuC,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/ui/Actions/hooks/menu/items.tsx"],"sourcesContent":["import {\n DocsAddOnIcon,\n EditNoteIcon,\n SegmentIcon,\n SpellCheckIcon,\n StylusNoteIcon,\n SummarizeIcon,\n TranslateIcon,\n TuneIcon,\n} from '../../../Icons/Icons.js'\nimport { createMenuItem } from './Item.js'\n\nexport const Proofread = createMenuItem(SpellCheckIcon, 'Proofread')\nexport const Rephrase = createMenuItem(EditNoteIcon, 'Rephrase')\nexport const Translate = createMenuItem(TranslateIcon, 'Translate')\nexport const Expand = createMenuItem(DocsAddOnIcon, 'Expand')\nexport const Summarize = createMenuItem(SummarizeIcon, 'Summarize')\nexport const Simplify = createMenuItem(SegmentIcon, 'Simplify')\nexport const Compose = createMenuItem(StylusNoteIcon, 'Compose')\nexport const Settings = createMenuItem(TuneIcon, 'Settings')\n"],"names":["DocsAddOnIcon","EditNoteIcon","SegmentIcon","SpellCheckIcon","StylusNoteIcon","SummarizeIcon","TranslateIcon","TuneIcon","createMenuItem","Proofread","Rephrase","Translate","Expand","Summarize","Simplify","Compose","Settings"],"mappings":"AAAA,SACEA,aAAa,EACbC,YAAY,EACZC,WAAW,EACXC,cAAc,EACdC,cAAc,EACdC,aAAa,EACbC,aAAa,EACbC,QAAQ,QACH,0BAAyB;AAChC,SAASC,cAAc,QAAQ,YAAW;AAE1C,OAAO,MAAMC,YAAYD,eAAeL,gBAAgB,aAAY;AACpE,OAAO,MAAMO,WAAWF,eAAeP,cAAc,YAAW;AAChE,OAAO,MAAMU,YAAYH,eAAeF,eAAe,aAAY;AACnE,OAAO,MAAMM,SAASJ,eAAeR,eAAe,UAAS;AAC7D,OAAO,MAAMa,YAAYL,eAAeH,eAAe,aAAY;AACnE,OAAO,MAAMS,WAAWN,eAAeN,aAAa,YAAW;AAC/D,OAAO,MAAMa,UAAUP,eAAeJ,gBAAgB,WAAU;AAChE,OAAO,MAAMY,WAAWR,eAAeD,UAAU,YAAW"}
1
+ {"version":3,"sources":["../../../../../src/ui/Compose/hooks/menu/items.tsx"],"sourcesContent":["import {\n DocsAddOnIcon,\n EditNoteIcon,\n SegmentIcon,\n SpellCheckIcon,\n StylusNoteIcon,\n SummarizeIcon,\n TranslateIcon,\n TuneIcon,\n} from '../../../Icons/Icons.js'\nimport { createMenuItem } from './Item.js'\n\nexport const Proofread = createMenuItem(SpellCheckIcon, 'Proofread')\nexport const Rephrase = createMenuItem(EditNoteIcon, 'Rephrase')\nexport const Translate = createMenuItem(TranslateIcon, 'Translate')\nexport const Expand = createMenuItem(DocsAddOnIcon, 'Expand')\nexport const Summarize = createMenuItem(SummarizeIcon, 'Summarize')\nexport const Simplify = createMenuItem(SegmentIcon, 'Simplify')\nexport const Compose = createMenuItem(StylusNoteIcon, 'Compose')\nexport const Settings = createMenuItem(TuneIcon, 'Settings')\n"],"names":["DocsAddOnIcon","EditNoteIcon","SegmentIcon","SpellCheckIcon","StylusNoteIcon","SummarizeIcon","TranslateIcon","TuneIcon","createMenuItem","Proofread","Rephrase","Translate","Expand","Summarize","Simplify","Compose","Settings"],"mappings":"AAAA,SACEA,aAAa,EACbC,YAAY,EACZC,WAAW,EACXC,cAAc,EACdC,cAAc,EACdC,aAAa,EACbC,aAAa,EACbC,QAAQ,QACH,0BAAyB;AAChC,SAASC,cAAc,QAAQ,YAAW;AAE1C,OAAO,MAAMC,YAAYD,eAAeL,gBAAgB,aAAY;AACpE,OAAO,MAAMO,WAAWF,eAAeP,cAAc,YAAW;AAChE,OAAO,MAAMU,YAAYH,eAAeF,eAAe,aAAY;AACnE,OAAO,MAAMM,SAASJ,eAAeR,eAAe,UAAS;AAC7D,OAAO,MAAMa,YAAYL,eAAeH,eAAe,aAAY;AACnE,OAAO,MAAMS,WAAWN,eAAeN,aAAa,YAAW;AAC/D,OAAO,MAAMa,UAAUP,eAAeJ,gBAAgB,WAAU;AAChE,OAAO,MAAMY,WAAWR,eAAeD,UAAU,YAAW"}
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import type React from 'react';
2
2
  import type { ActionMenuItems, BaseItemProps } from '../../../../types.js';
3
3
  type MenuItemsMapType = {
4
4
  component: React.FC<BaseItemProps>;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"itemsMap.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Compose/hooks/menu/itemsMap.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAK1E,KAAK,gBAAgB,GAAG;IACtB,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAAC,CAAA;IAClC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,IAAI,EAAE,eAAe,CAAA;CACtB,CAAA;AAED,eAAO,MAAM,YAAY,EAAE,gBAAgB,EAoB1C,CAAA"}
@@ -1,6 +1,5 @@
1
- import React from 'react';
2
- import { Compose, Expand, Proofread, Rephrase, Settings, Simplify, Summarize } from './items.js';
3
1
  import { TranslateMenu } from './TranslateMenu.js';
2
+ import { Compose, Expand, Proofread, Rephrase, Settings, Simplify, Summarize } from './items.js';
4
3
  export const menuItemsMap = [
5
4
  {
6
5
  name: 'Proofread',
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/ui/Compose/hooks/menu/itemsMap.ts"],"sourcesContent":["import type React from 'react'\n\nimport type { ActionMenuItems, BaseItemProps } from '../../../../types.js'\n\nimport { TranslateMenu } from './TranslateMenu.js'\nimport { Compose, Expand, Proofread, Rephrase, Settings, Simplify, Summarize } from './items.js'\n\ntype MenuItemsMapType = {\n component: React.FC<BaseItemProps>\n excludedFor?: string[]\n loadingText?: string\n name: ActionMenuItems\n}\n\nexport const menuItemsMap: MenuItemsMapType[] = [\n { name: 'Proofread', component: Proofread, excludedFor: ['upload'], loadingText: 'Proofreading' },\n { name: 'Rephrase', component: Rephrase, excludedFor: ['upload'], loadingText: 'Rephrasing' },\n {\n name: 'Translate',\n component: TranslateMenu,\n excludedFor: ['upload'],\n loadingText: 'Translating',\n },\n { name: 'Expand', component: Expand, excludedFor: ['upload', 'text'], loadingText: 'Expanding' },\n {\n // Turned off - WIP\n name: 'Summarize',\n component: Summarize,\n excludedFor: ['upload', 'text', 'richText'],\n loadingText: 'Summarizing',\n },\n { name: 'Simplify', component: Simplify, excludedFor: ['upload'], loadingText: 'Simplifying' },\n { name: 'Compose', component: Compose, loadingText: 'Composing' },\n { name: 'Settings', component: Settings },\n]\n"],"names":["TranslateMenu","Compose","Expand","Proofread","Rephrase","Settings","Simplify","Summarize","menuItemsMap","name","component","excludedFor","loadingText"],"mappings":"AAIA,SAASA,aAAa,QAAQ,qBAAoB;AAClD,SAASC,OAAO,EAAEC,MAAM,EAAEC,SAAS,EAAEC,QAAQ,EAAEC,QAAQ,EAAEC,QAAQ,EAAEC,SAAS,QAAQ,aAAY;AAShG,OAAO,MAAMC,eAAmC;IAC9C;QAAEC,MAAM;QAAaC,WAAWP;QAAWQ,aAAa;YAAC;SAAS;QAAEC,aAAa;IAAe;IAChG;QAAEH,MAAM;QAAYC,WAAWN;QAAUO,aAAa;YAAC;SAAS;QAAEC,aAAa;IAAa;IAC5F;QACEH,MAAM;QACNC,WAAWV;QACXW,aAAa;YAAC;SAAS;QACvBC,aAAa;IACf;IACA;QAAEH,MAAM;QAAUC,WAAWR;QAAQS,aAAa;YAAC;YAAU;SAAO;QAAEC,aAAa;IAAY;IAC/F;QACE,mBAAmB;QACnBH,MAAM;QACNC,WAAWH;QACXI,aAAa;YAAC;YAAU;YAAQ;SAAW;QAC3CC,aAAa;IACf;IACA;QAAEH,MAAM;QAAYC,WAAWJ;QAAUK,aAAa;YAAC;SAAS;QAAEC,aAAa;IAAc;IAC7F;QAAEH,MAAM;QAAWC,WAAWT;QAASW,aAAa;IAAY;IAChE;QAAEH,MAAM;QAAYC,WAAWL;IAAS;CACzC,CAAA"}
@@ -1,7 +1,8 @@
1
1
  import type { UseMenuEvents } from '../../../../types.js';
2
2
  export declare const useMenu: (menuEvents: UseMenuEvents) => {
3
- ActiveComponent: ({ isLoading }: {
3
+ ActiveComponent: ({ isLoading, stop }: {
4
4
  isLoading: any;
5
+ stop: any;
5
6
  }) => import("react/jsx-runtime").JSX.Element;
6
7
  Menu: ({ isLoading, onClose }: {
7
8
  isLoading: any;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMenu.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Compose/hooks/menu/useMenu.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAmB,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAoB1E,eAAO,MAAM,OAAO,eAAgB,aAAa;;;;;;;;;CAwFhD,CAAA"}