@ai-stack/payloadcms 3.0.0-beta.95.2 → 3.2.1-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 (186) hide show
  1. package/LICENSE.md +2 -2
  2. package/README.md +19 -17
  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/generateRichText.js +2 -2
  15. package/dist/ai/models/openai/generateRichText.js.map +1 -1
  16. package/dist/ai/models/openai/generateVoice.d.ts +1 -1
  17. package/dist/ai/models/openai/index.d.ts.map +1 -1
  18. package/dist/ai/models/openai/index.js +9 -35
  19. package/dist/ai/models/openai/index.js.map +1 -1
  20. package/dist/ai/prompts.d.ts +1 -1
  21. package/dist/ai/prompts.d.ts.map +1 -1
  22. package/dist/ai/prompts.js +6 -3
  23. package/dist/ai/prompts.js.map +1 -1
  24. package/dist/ai/schemas/lexicalJsonSchema.d.ts +2 -0
  25. package/dist/ai/schemas/lexicalJsonSchema.d.ts.map +1 -0
  26. package/dist/ai/schemas/lexicalJsonSchema.js +317 -0
  27. package/dist/ai/schemas/lexicalJsonSchema.js.map +1 -0
  28. package/dist/ai/utils/generateFileNameByPrompt.js.map +1 -1
  29. package/dist/ai/utils/systemGenerate.d.ts +5 -0
  30. package/dist/ai/utils/systemGenerate.d.ts.map +1 -0
  31. package/dist/ai/utils/{generateSeedPrompt.js → systemGenerate.js} +2 -2
  32. package/dist/ai/utils/systemGenerate.js.map +1 -0
  33. package/dist/collections/Instructions.d.ts +1 -1
  34. package/dist/collections/Instructions.d.ts.map +1 -1
  35. package/dist/collections/Instructions.js +177 -85
  36. package/dist/collections/Instructions.js.map +1 -1
  37. package/dist/defaults.d.ts +1 -1
  38. package/dist/defaults.d.ts.map +1 -1
  39. package/dist/defaults.js +1 -1
  40. package/dist/defaults.js.map +1 -1
  41. package/dist/endpoints/fetchFields.d.ts +3 -0
  42. package/dist/endpoints/fetchFields.d.ts.map +1 -0
  43. package/dist/endpoints/fetchFields.js +21 -0
  44. package/dist/endpoints/fetchFields.js.map +1 -0
  45. package/dist/endpoints/index.d.ts.map +1 -1
  46. package/dist/endpoints/index.js +12 -18
  47. package/dist/endpoints/index.js.map +1 -1
  48. package/dist/exports/fields.d.ts +2 -1
  49. package/dist/exports/fields.d.ts.map +1 -1
  50. package/dist/exports/fields.js +2 -1
  51. package/dist/exports/fields.js.map +1 -1
  52. package/dist/fields/ComposeField/ComposeField.d.ts +3 -0
  53. package/dist/fields/ComposeField/ComposeField.d.ts.map +1 -0
  54. package/dist/fields/ComposeField/ComposeField.js +24 -0
  55. package/dist/fields/ComposeField/ComposeField.js.map +1 -0
  56. package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts +2 -0
  57. package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts.map +1 -0
  58. package/dist/fields/LexicalEditor/ComposeFeatureComponent.js +28 -0
  59. package/dist/fields/LexicalEditor/ComposeFeatureComponent.js.map +1 -0
  60. package/dist/fields/LexicalEditor/feature.client.d.ts +4 -1
  61. package/dist/fields/LexicalEditor/feature.client.d.ts.map +1 -1
  62. package/dist/fields/LexicalEditor/feature.client.js +15 -7
  63. package/dist/fields/LexicalEditor/feature.client.js.map +1 -1
  64. package/dist/fields/PromptEditorField/PromptEditorField.d.ts +2 -2
  65. package/dist/fields/PromptEditorField/PromptEditorField.d.ts.map +1 -1
  66. package/dist/fields/PromptEditorField/PromptEditorField.js +4 -8
  67. package/dist/fields/PromptEditorField/PromptEditorField.js.map +1 -1
  68. package/dist/fields/SelectField/SelectField.d.ts +3 -2
  69. package/dist/fields/SelectField/SelectField.d.ts.map +1 -1
  70. package/dist/fields/SelectField/SelectField.js +2 -3
  71. package/dist/fields/SelectField/SelectField.js.map +1 -1
  72. package/dist/index.d.ts +1 -6
  73. package/dist/index.d.ts.map +1 -1
  74. package/dist/index.js +1 -6
  75. package/dist/index.js.map +1 -1
  76. package/dist/init.d.ts +2 -1
  77. package/dist/init.d.ts.map +1 -1
  78. package/dist/init.js +22 -21
  79. package/dist/init.js.map +1 -1
  80. package/dist/libraries/autocomplete/AutocompleteTextArea.js +9 -7
  81. package/dist/libraries/autocomplete/AutocompleteTextArea.js.map +1 -1
  82. package/dist/libraries/handlebars/asyncHandlebars.js +1 -1
  83. package/dist/libraries/handlebars/asyncHandlebars.js.map +1 -1
  84. package/dist/libraries/handlebars/helpers.js.map +1 -1
  85. package/dist/plugin.d.ts.map +1 -1
  86. package/dist/plugin.js +30 -41
  87. package/dist/plugin.js.map +1 -1
  88. package/dist/providers/FieldProvider/FieldProvider.d.ts +15 -0
  89. package/dist/providers/FieldProvider/FieldProvider.d.ts.map +1 -0
  90. package/dist/providers/FieldProvider/FieldProvider.js +33 -0
  91. package/dist/providers/FieldProvider/FieldProvider.js.map +1 -0
  92. package/dist/providers/FieldProvider/useFieldProps.d.ts +6 -0
  93. package/dist/providers/FieldProvider/useFieldProps.d.ts.map +1 -0
  94. package/dist/providers/FieldProvider/useFieldProps.js +12 -0
  95. package/dist/providers/FieldProvider/useFieldProps.js.map +1 -0
  96. package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts +5 -1
  97. package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts.map +1 -1
  98. package/dist/providers/InstructionsProvider/InstructionsProvider.js +12 -7
  99. package/dist/providers/InstructionsProvider/InstructionsProvider.js.map +1 -1
  100. package/dist/providers/InstructionsProvider/useInstructions.d.ts +2 -2
  101. package/dist/providers/InstructionsProvider/useInstructions.d.ts.map +1 -1
  102. package/dist/providers/InstructionsProvider/useInstructions.js +17 -4
  103. package/dist/providers/InstructionsProvider/useInstructions.js.map +1 -1
  104. package/dist/types.d.ts +9 -41
  105. package/dist/types.d.ts.map +1 -1
  106. package/dist/types.js +1 -4
  107. package/dist/types.js.map +1 -1
  108. package/dist/ui/Compose/Compose.d.ts +9 -0
  109. package/dist/ui/Compose/Compose.d.ts.map +1 -0
  110. package/dist/ui/{Actions/Actions.js → Compose/Compose.js} +49 -39
  111. package/dist/ui/Compose/Compose.js.map +1 -0
  112. package/dist/ui/{Actions → Compose}/UndoRedoActions.d.ts.map +1 -1
  113. package/dist/ui/{Actions → Compose}/UndoRedoActions.js +15 -2
  114. package/dist/ui/Compose/UndoRedoActions.js.map +1 -0
  115. package/dist/ui/{Actions → Compose}/hooks/menu/Item.d.ts +1 -1
  116. package/dist/ui/{Actions → Compose}/hooks/menu/Item.d.ts.map +1 -1
  117. package/dist/ui/{Actions → Compose}/hooks/menu/Item.js +2 -2
  118. package/dist/ui/{Actions → Compose}/hooks/menu/Item.js.map +1 -1
  119. package/dist/ui/Compose/hooks/menu/TranslateMenu.d.ts.map +1 -0
  120. package/dist/ui/{Actions → Compose}/hooks/menu/TranslateMenu.js +11 -11
  121. package/dist/ui/Compose/hooks/menu/TranslateMenu.js.map +1 -0
  122. package/dist/ui/{Actions → Compose}/hooks/menu/items.d.ts +8 -8
  123. package/dist/ui/{Actions → Compose}/hooks/menu/items.d.ts.map +1 -1
  124. package/dist/ui/{Actions → Compose}/hooks/menu/items.js.map +1 -1
  125. package/dist/ui/{Actions → Compose}/hooks/menu/itemsMap.d.ts +1 -1
  126. package/dist/ui/Compose/hooks/menu/itemsMap.d.ts.map +1 -0
  127. package/dist/ui/{Actions → Compose}/hooks/menu/itemsMap.js +1 -2
  128. package/dist/ui/Compose/hooks/menu/itemsMap.js.map +1 -0
  129. package/dist/ui/Compose/hooks/menu/useMenu.d.ts.map +1 -0
  130. package/dist/ui/{Actions → Compose}/hooks/menu/useMenu.js +2 -1
  131. package/dist/ui/Compose/hooks/menu/useMenu.js.map +1 -0
  132. package/dist/ui/{Actions → Compose}/hooks/useGenerate.d.ts +3 -1
  133. package/dist/ui/Compose/hooks/useGenerate.d.ts.map +1 -0
  134. package/dist/ui/{Actions → Compose}/hooks/useGenerate.js +19 -24
  135. package/dist/ui/Compose/hooks/useGenerate.js.map +1 -0
  136. package/dist/ui/Compose/hooks/useHistory.d.ts.map +1 -0
  137. package/dist/ui/{Actions → Compose}/hooks/useHistory.js +6 -3
  138. package/dist/ui/Compose/hooks/useHistory.js.map +1 -0
  139. package/dist/utilities/setSafeLexicalState.d.ts +2 -2
  140. package/dist/utilities/setSafeLexicalState.d.ts.map +1 -1
  141. package/dist/utilities/setSafeLexicalState.js +5 -12
  142. package/dist/utilities/setSafeLexicalState.js.map +1 -1
  143. package/dist/utilities/updateFieldsConfig.d.ts.map +1 -1
  144. package/dist/utilities/updateFieldsConfig.js +18 -6
  145. package/dist/utilities/updateFieldsConfig.js.map +1 -1
  146. package/package.json +33 -60
  147. package/dist/ai/schemas/lexical.schema.d.ts +0 -31
  148. package/dist/ai/schemas/lexical.schema.d.ts.map +0 -1
  149. package/dist/ai/schemas/lexical.schema.js +0 -102
  150. package/dist/ai/schemas/lexical.schema.js.map +0 -1
  151. package/dist/ai/utils/generateSeedPrompt.d.ts +0 -5
  152. package/dist/ai/utils/generateSeedPrompt.d.ts.map +0 -1
  153. package/dist/ai/utils/generateSeedPrompt.js.map +0 -1
  154. package/dist/fields/DescriptionField/DescriptionField.d.ts +0 -4
  155. package/dist/fields/DescriptionField/DescriptionField.d.ts.map +0 -1
  156. package/dist/fields/DescriptionField/DescriptionField.js +0 -18
  157. package/dist/fields/DescriptionField/DescriptionField.js.map +0 -1
  158. package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts +0 -2
  159. package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts.map +0 -1
  160. package/dist/fields/LexicalEditor/ActionsFeatureComponent.js +0 -15
  161. package/dist/fields/LexicalEditor/ActionsFeatureComponent.js.map +0 -1
  162. package/dist/ui/Actions/Actions.d.ts +0 -5
  163. package/dist/ui/Actions/Actions.d.ts.map +0 -1
  164. package/dist/ui/Actions/Actions.js.map +0 -1
  165. package/dist/ui/Actions/UndoRedoActions.js.map +0 -1
  166. package/dist/ui/Actions/hooks/menu/TranslateMenu.d.ts.map +0 -1
  167. package/dist/ui/Actions/hooks/menu/TranslateMenu.js.map +0 -1
  168. package/dist/ui/Actions/hooks/menu/itemsMap.d.ts.map +0 -1
  169. package/dist/ui/Actions/hooks/menu/itemsMap.js.map +0 -1
  170. package/dist/ui/Actions/hooks/menu/useMenu.d.ts.map +0 -1
  171. package/dist/ui/Actions/hooks/menu/useMenu.js.map +0 -1
  172. package/dist/ui/Actions/hooks/useGenerate.d.ts.map +0 -1
  173. package/dist/ui/Actions/hooks/useGenerate.js.map +0 -1
  174. package/dist/ui/Actions/hooks/useHistory.d.ts.map +0 -1
  175. package/dist/ui/Actions/hooks/useHistory.js.map +0 -1
  176. package/dist/utilities/jsonToZod.d.ts +0 -3
  177. package/dist/utilities/jsonToZod.d.ts.map +0 -1
  178. package/dist/utilities/jsonToZod.js +0 -33
  179. package/dist/utilities/jsonToZod.js.map +0 -1
  180. /package/dist/ui/{Actions → Compose}/UndoRedoActions.d.ts +0 -0
  181. /package/dist/ui/{Actions/actions.module.scss → Compose/compose.module.scss} +0 -0
  182. /package/dist/ui/{Actions → Compose}/hooks/menu/TranslateMenu.d.ts +0 -0
  183. /package/dist/ui/{Actions → Compose}/hooks/menu/items.js +0 -0
  184. /package/dist/ui/{Actions → Compose}/hooks/menu/menu.module.scss +0 -0
  185. /package/dist/ui/{Actions → Compose}/hooks/menu/useMenu.d.ts +0 -0
  186. /package/dist/ui/{Actions → Compose}/hooks/useHistory.d.ts +0 -0
@@ -1 +1 @@
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,CAAC,EAAEH,eAAe,CAAC,EAAEE,GAAG,CAAC;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
+ {"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 +1 @@
1
- {"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAKrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAW9C,QAAA,MAAM,eAAe,iBACJ,YAAY,sBACV,MAAM,KAAG,MAsGzB,CAAA;AAEH,OAAO,EAAE,eAAe,EAAE,CAAA"}
1
+ {"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAIrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAiB9C,QAAA,MAAM,eAAe,iBACJ,YAAY,sBACV,MAAM,KAAG,MAuFzB,CAAA;AAEH,OAAO,EAAE,eAAe,EAAE,CAAA"}
package/dist/plugin.js CHANGED
@@ -1,22 +1,31 @@
1
1
  import { deepMerge } from 'payload/shared';
2
- import { zodToJsonSchema } from 'zod-to-json-schema';
3
- import { lexicalSchema } from './ai/schemas/lexical.schema.js';
4
- import { Instructions } from './collections/Instructions.js';
5
- import { PLUGIN_INSTRUCTIONS_MAP_GLOBAL, PLUGIN_NAME } from './defaults.js';
2
+ import { lexicalJsonSchema } from './ai/schemas/lexicalJsonSchema.js';
3
+ import { instructionsCollection } from './collections/Instructions.js';
4
+ import { PLUGIN_NAME } from './defaults.js';
5
+ import { fetchFields } from './endpoints/fetchFields.js';
6
6
  import { endpoints } from './endpoints/index.js';
7
7
  import { init } from './init.js';
8
8
  import { translations } from './translations/index.js';
9
9
  import { isPluginActivated } from './utilities/isPluginActivated.js';
10
10
  import { updateFieldsConfig } from './utilities/updateFieldsConfig.js';
11
+ const defaultPluginConfig = {
12
+ collections: {},
13
+ generatePromptOnInit: true
14
+ };
11
15
  const payloadAiPlugin = (pluginConfig)=>(incomingConfig)=>{
16
+ pluginConfig = {
17
+ ...defaultPluginConfig,
18
+ ...pluginConfig
19
+ };
12
20
  const isActivated = isPluginActivated();
13
21
  let updatedConfig = {
14
22
  ...incomingConfig
15
23
  };
16
24
  let collectionsFieldPathMap = {};
17
25
  if (isActivated) {
26
+ const Instructions = instructionsCollection();
18
27
  // Inject editor schema to config, so that it can be accessed when /textarea endpoint will hit
19
- const zodLexicalSchema = lexicalSchema(pluginConfig.editorConfig?.nodes);
28
+ const lexicalSchema = lexicalJsonSchema(pluginConfig.editorConfig?.nodes);
20
29
  if (pluginConfig.debugging) {
21
30
  Instructions.admin.hidden = false;
22
31
  }
@@ -25,16 +34,7 @@ const payloadAiPlugin = (pluginConfig)=>(incomingConfig)=>{
25
34
  [PLUGIN_NAME]: {
26
35
  editorConfig: {
27
36
  // Used in admin client for useObject hook
28
- schema: zodToJsonSchema(zodLexicalSchema)
29
- }
30
- }
31
- };
32
- Instructions.custom = {
33
- ...Instructions.custom || {},
34
- [PLUGIN_NAME]: {
35
- editorConfig: {
36
- // Used in textarea endpoint for llm
37
- schema: zodLexicalSchema
37
+ schema: lexicalSchema
38
38
  }
39
39
  }
40
40
  };
@@ -43,14 +43,20 @@ const payloadAiPlugin = (pluginConfig)=>(incomingConfig)=>{
43
43
  Instructions
44
44
  ];
45
45
  const { collections: collectionSlugs = [] } = pluginConfig;
46
- incomingConfig.admin.components.providers = [
47
- ...incomingConfig.admin.components.providers ?? [],
46
+ const { components: { providers = [] } = {} } = incomingConfig.admin || {};
47
+ const updatedProviders = [
48
+ ...providers ?? [],
48
49
  {
49
- clientProps: {},
50
- path: '@ai-stack/payloadcms/client#InstructionsProvider',
51
- serverProps: {}
50
+ path: '@ai-stack/payloadcms/client#InstructionsProvider'
52
51
  }
53
52
  ];
53
+ incomingConfig.admin = {
54
+ ...incomingConfig.admin || {},
55
+ components: {
56
+ ...incomingConfig.admin?.components ?? {},
57
+ providers: updatedProviders
58
+ }
59
+ };
54
60
  updatedConfig = {
55
61
  ...incomingConfig,
56
62
  collections: collections.map((collection)=>{
@@ -67,28 +73,11 @@ const payloadAiPlugin = (pluginConfig)=>(incomingConfig)=>{
67
73
  endpoints: [
68
74
  ...incomingConfig.endpoints ?? [],
69
75
  endpoints.textarea,
70
- endpoints.upload
71
- ],
72
- globals: [
73
- ...incomingConfig.globals || [],
74
- {
75
- slug: PLUGIN_INSTRUCTIONS_MAP_GLOBAL,
76
- access: {
77
- read: ()=>true
78
- },
79
- admin: {
80
- hidden: !pluginConfig.debugging
81
- },
82
- fields: [
83
- {
84
- name: 'map',
85
- type: 'json'
86
- }
87
- ]
88
- }
76
+ endpoints.upload,
77
+ fetchFields
89
78
  ],
90
79
  i18n: {
91
- ...incomingConfig.i18n,
80
+ ...incomingConfig.i18n || {},
92
81
  translations: {
93
82
  ...deepMerge(translations, incomingConfig.i18n?.translations)
94
83
  }
@@ -101,7 +90,7 @@ const payloadAiPlugin = (pluginConfig)=>(incomingConfig)=>{
101
90
  payload.logger.warn(`— AI Plugin: Not activated. Please verify your environment keys.`);
102
91
  return;
103
92
  }
104
- await init(payload, collectionsFieldPathMap).catch((error)=>{
93
+ await init(payload, collectionsFieldPathMap, pluginConfig).catch((error)=>{
105
94
  console.error(error);
106
95
  payload.logger.error(`— AI Plugin: Initialization Error: ${error}`);
107
96
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/plugin.ts"],"sourcesContent":["import type { Config } from 'payload'\n\nimport { deepMerge } from 'payload/shared'\nimport { zodToJsonSchema } from 'zod-to-json-schema'\n\nimport type { PluginConfig } from './types.js'\n\nimport { lexicalSchema } from './ai/schemas/lexical.schema.js'\nimport { Instructions } from './collections/Instructions.js'\nimport { PLUGIN_INSTRUCTIONS_MAP_GLOBAL, PLUGIN_NAME } from './defaults.js'\nimport { endpoints } from './endpoints/index.js'\nimport { init } from './init.js'\nimport { translations } from './translations/index.js'\nimport { isPluginActivated } from './utilities/isPluginActivated.js'\nimport { updateFieldsConfig } from './utilities/updateFieldsConfig.js'\n\nconst payloadAiPlugin =\n (pluginConfig: PluginConfig) =>\n (incomingConfig: Config): Config => {\n const isActivated = isPluginActivated()\n let updatedConfig: Config = { ...incomingConfig }\n let collectionsFieldPathMap = {}\n\n if (isActivated) {\n // Inject editor schema to config, so that it can be accessed when /textarea endpoint will hit\n const zodLexicalSchema = lexicalSchema(pluginConfig.editorConfig?.nodes)\n\n if (pluginConfig.debugging) {\n Instructions.admin.hidden = false\n }\n\n Instructions.admin.custom = {\n ...(Instructions.admin.custom || {}),\n [PLUGIN_NAME]: {\n editorConfig: {\n // Used in admin client for useObject hook\n schema: zodToJsonSchema(zodLexicalSchema),\n },\n },\n }\n\n Instructions.custom = {\n ...(Instructions.custom || {}),\n [PLUGIN_NAME]: {\n editorConfig: {\n // Used in textarea endpoint for llm\n schema: zodLexicalSchema,\n },\n },\n }\n\n const collections = [...(incomingConfig.collections ?? []), Instructions]\n const { collections: collectionSlugs = [] } = pluginConfig\n\n incomingConfig.admin.components.providers = [\n ...(incomingConfig.admin.components.providers ?? []),\n {\n clientProps: {},\n path: '@ai-stack/payloadcms/client#InstructionsProvider',\n serverProps: {},\n },\n ]\n\n updatedConfig = {\n ...incomingConfig,\n collections: collections.map((collection) => {\n if (collectionSlugs[collection.slug]) {\n const { schemaPathMap, updatedCollectionConfig } = updateFieldsConfig(collection)\n collectionsFieldPathMap = {\n ...collectionsFieldPathMap,\n ...schemaPathMap,\n }\n return updatedCollectionConfig\n }\n\n return collection\n }),\n endpoints: [...(incomingConfig.endpoints ?? []), endpoints.textarea, endpoints.upload],\n globals: [\n ...(incomingConfig.globals || []),\n {\n slug: PLUGIN_INSTRUCTIONS_MAP_GLOBAL,\n access: {\n read: () => true,\n },\n admin: {\n hidden: !pluginConfig.debugging,\n },\n fields: [\n {\n name: 'map',\n type: 'json',\n },\n ],\n },\n ],\n i18n: {\n ...incomingConfig.i18n,\n translations: {\n ...deepMerge(translations, incomingConfig.i18n?.translations),\n },\n },\n }\n }\n\n updatedConfig.onInit = async (payload) => {\n if (incomingConfig.onInit) await incomingConfig.onInit(payload)\n\n if (!isActivated) {\n payload.logger.warn(`— AI Plugin: Not activated. Please verify your environment keys.`)\n return\n }\n\n await init(payload, collectionsFieldPathMap).catch((error) => {\n console.error(error)\n payload.logger.error(`— AI Plugin: Initialization Error: ${error}`)\n })\n }\n\n return updatedConfig\n }\n\nexport { payloadAiPlugin }\n"],"names":["deepMerge","zodToJsonSchema","lexicalSchema","Instructions","PLUGIN_INSTRUCTIONS_MAP_GLOBAL","PLUGIN_NAME","endpoints","init","translations","isPluginActivated","updateFieldsConfig","payloadAiPlugin","pluginConfig","incomingConfig","isActivated","updatedConfig","collectionsFieldPathMap","zodLexicalSchema","editorConfig","nodes","debugging","admin","hidden","custom","schema","collections","collectionSlugs","components","providers","clientProps","path","serverProps","map","collection","slug","schemaPathMap","updatedCollectionConfig","textarea","upload","globals","access","read","fields","name","type","i18n","onInit","payload","logger","warn","catch","error","console"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/plugin.ts"],"sourcesContent":["import type { Config } from 'payload'\n\nimport { deepMerge } from 'payload/shared'\n\nimport type { PluginConfig } from './types.js'\n\nimport { lexicalJsonSchema } from './ai/schemas/lexicalJsonSchema.js'\nimport { instructionsCollection } from './collections/Instructions.js'\nimport { PLUGIN_NAME } from './defaults.js'\nimport { fetchFields } from './endpoints/fetchFields.js'\nimport { endpoints } from './endpoints/index.js'\nimport { init } from './init.js'\nimport { translations } from './translations/index.js'\nimport { isPluginActivated } from './utilities/isPluginActivated.js'\nimport { updateFieldsConfig } from './utilities/updateFieldsConfig.js'\n\nconst defaultPluginConfig: PluginConfig = {\n collections: {},\n generatePromptOnInit: true,\n}\n\nconst payloadAiPlugin =\n (pluginConfig: PluginConfig) =>\n (incomingConfig: Config): Config => {\n pluginConfig = { ...defaultPluginConfig, ...pluginConfig }\n const isActivated = isPluginActivated()\n let updatedConfig: Config = { ...incomingConfig }\n let collectionsFieldPathMap = {}\n if (isActivated) {\n const Instructions = instructionsCollection()\n // Inject editor schema to config, so that it can be accessed when /textarea endpoint will hit\n const lexicalSchema = lexicalJsonSchema(pluginConfig.editorConfig?.nodes)\n\n if (pluginConfig.debugging) {\n Instructions.admin.hidden = false\n }\n\n Instructions.admin.custom = {\n ...(Instructions.admin.custom || {}),\n [PLUGIN_NAME]: {\n editorConfig: {\n // Used in admin client for useObject hook\n schema: lexicalSchema,\n },\n },\n }\n\n const collections = [...(incomingConfig.collections ?? []), Instructions]\n const { collections: collectionSlugs = [] } = pluginConfig\n\n const { components: { providers = [] } = {} } = incomingConfig.admin || {}\n const updatedProviders = [\n ...(providers ?? []),\n {\n path: '@ai-stack/payloadcms/client#InstructionsProvider',\n },\n ]\n\n incomingConfig.admin = {\n ...(incomingConfig.admin || {}),\n components: {\n ...(incomingConfig.admin?.components ?? {}),\n providers: updatedProviders,\n },\n }\n\n updatedConfig = {\n ...incomingConfig,\n collections: collections.map((collection) => {\n if (collectionSlugs[collection.slug]) {\n const { schemaPathMap, updatedCollectionConfig } = updateFieldsConfig(collection)\n collectionsFieldPathMap = {\n ...collectionsFieldPathMap,\n ...schemaPathMap,\n }\n return updatedCollectionConfig\n }\n\n return collection\n }),\n endpoints: [\n ...(incomingConfig.endpoints ?? []),\n endpoints.textarea,\n endpoints.upload,\n fetchFields,\n ],\n i18n: {\n ...(incomingConfig.i18n || {}),\n translations: {\n ...deepMerge(translations, incomingConfig.i18n?.translations),\n },\n },\n }\n }\n\n updatedConfig.onInit = async (payload) => {\n if (incomingConfig.onInit) await incomingConfig.onInit(payload)\n\n if (!isActivated) {\n payload.logger.warn(`— AI Plugin: Not activated. Please verify your environment keys.`)\n return\n }\n\n await init(payload, collectionsFieldPathMap, pluginConfig).catch((error) => {\n console.error(error)\n payload.logger.error(`— AI Plugin: Initialization Error: ${error}`)\n })\n }\n\n return updatedConfig\n }\n\nexport { payloadAiPlugin }\n"],"names":["deepMerge","lexicalJsonSchema","instructionsCollection","PLUGIN_NAME","fetchFields","endpoints","init","translations","isPluginActivated","updateFieldsConfig","defaultPluginConfig","collections","generatePromptOnInit","payloadAiPlugin","pluginConfig","incomingConfig","isActivated","updatedConfig","collectionsFieldPathMap","Instructions","lexicalSchema","editorConfig","nodes","debugging","admin","hidden","custom","schema","collectionSlugs","components","providers","updatedProviders","path","map","collection","slug","schemaPathMap","updatedCollectionConfig","textarea","upload","i18n","onInit","payload","logger","warn","catch","error","console"],"mappings":"AAEA,SAASA,SAAS,QAAQ,iBAAgB;AAI1C,SAASC,iBAAiB,QAAQ,oCAAmC;AACrE,SAASC,sBAAsB,QAAQ,gCAA+B;AACtE,SAASC,WAAW,QAAQ,gBAAe;AAC3C,SAASC,WAAW,QAAQ,6BAA4B;AACxD,SAASC,SAAS,QAAQ,uBAAsB;AAChD,SAASC,IAAI,QAAQ,YAAW;AAChC,SAASC,YAAY,QAAQ,0BAAyB;AACtD,SAASC,iBAAiB,QAAQ,mCAAkC;AACpE,SAASC,kBAAkB,QAAQ,oCAAmC;AAEtE,MAAMC,sBAAoC;IACxCC,aAAa,CAAC;IACdC,sBAAsB;AACxB;AAEA,MAAMC,kBACJ,CAACC,eACD,CAACC;QACCD,eAAe;YAAE,GAAGJ,mBAAmB;YAAE,GAAGI,YAAY;QAAC;QACzD,MAAME,cAAcR;QACpB,IAAIS,gBAAwB;YAAE,GAAGF,cAAc;QAAC;QAChD,IAAIG,0BAA0B,CAAC;QAC/B,IAAIF,aAAa;YACf,MAAMG,eAAejB;YACrB,8FAA8F;YAC9F,MAAMkB,gBAAgBnB,kBAAkBa,aAAaO,YAAY,EAAEC;YAEnE,IAAIR,aAAaS,SAAS,EAAE;gBAC1BJ,aAAaK,KAAK,CAACC,MAAM,GAAG;YAC9B;YAEAN,aAAaK,KAAK,CAACE,MAAM,GAAG;gBAC1B,GAAIP,aAAaK,KAAK,CAACE,MAAM,IAAI,CAAC,CAAC;gBACnC,CAACvB,YAAY,EAAE;oBACbkB,cAAc;wBACZ,0CAA0C;wBAC1CM,QAAQP;oBACV;gBACF;YACF;YAEA,MAAMT,cAAc;mBAAKI,eAAeJ,WAAW,IAAI,EAAE;gBAAGQ;aAAa;YACzE,MAAM,EAAER,aAAaiB,kBAAkB,EAAE,EAAE,GAAGd;YAE9C,MAAM,EAAEe,YAAY,EAAEC,YAAY,EAAE,EAAE,GAAG,CAAC,CAAC,EAAE,GAAGf,eAAeS,KAAK,IAAI,CAAC;YACzE,MAAMO,mBAAmB;mBACnBD,aAAa,EAAE;gBACnB;oBACEE,MAAM;gBACR;aACD;YAEDjB,eAAeS,KAAK,GAAG;gBACrB,GAAIT,eAAeS,KAAK,IAAI,CAAC,CAAC;gBAC9BK,YAAY;oBACV,GAAId,eAAeS,KAAK,EAAEK,cAAc,CAAC,CAAC;oBAC1CC,WAAWC;gBACb;YACF;YAEAd,gBAAgB;gBACd,GAAGF,cAAc;gBACjBJ,aAAaA,YAAYsB,GAAG,CAAC,CAACC;oBAC5B,IAAIN,eAAe,CAACM,WAAWC,IAAI,CAAC,EAAE;wBACpC,MAAM,EAAEC,aAAa,EAAEC,uBAAuB,EAAE,GAAG5B,mBAAmByB;wBACtEhB,0BAA0B;4BACxB,GAAGA,uBAAuB;4BAC1B,GAAGkB,aAAa;wBAClB;wBACA,OAAOC;oBACT;oBAEA,OAAOH;gBACT;gBACA7B,WAAW;uBACLU,eAAeV,SAAS,IAAI,EAAE;oBAClCA,UAAUiC,QAAQ;oBAClBjC,UAAUkC,MAAM;oBAChBnC;iBACD;gBACDoC,MAAM;oBACJ,GAAIzB,eAAeyB,IAAI,IAAI,CAAC,CAAC;oBAC7BjC,cAAc;wBACZ,GAAGP,UAAUO,cAAcQ,eAAeyB,IAAI,EAAEjC,aAAa;oBAC/D;gBACF;YACF;QACF;QAEAU,cAAcwB,MAAM,GAAG,OAAOC;YAC5B,IAAI3B,eAAe0B,MAAM,EAAE,MAAM1B,eAAe0B,MAAM,CAACC;YAEvD,IAAI,CAAC1B,aAAa;gBAChB0B,QAAQC,MAAM,CAACC,IAAI,CAAC,CAAC,gEAAgE,CAAC;gBACtF;YACF;YAEA,MAAMtC,KAAKoC,SAASxB,yBAAyBJ,cAAc+B,KAAK,CAAC,CAACC;gBAChEC,QAAQD,KAAK,CAACA;gBACdJ,QAAQC,MAAM,CAACG,KAAK,CAAC,CAAC,mCAAmC,EAAEA,OAAO;YACpE;QACF;QAEA,OAAO7B;IACT;AAEF,SAASJ,eAAe,GAAE"}
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ export declare const FieldContext: React.Context<{
3
+ path?: string;
4
+ schemaPath?: string;
5
+ type?: string;
6
+ }>;
7
+ export declare const FieldProvider: ({ children, context, }: {
8
+ children: React.ReactNode;
9
+ context: {
10
+ path: string;
11
+ schemaPath: unknown;
12
+ type: unknown;
13
+ };
14
+ }) => import("react/jsx-runtime").JSX.Element;
15
+ //# sourceMappingURL=FieldProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FieldProvider.d.ts","sourceRoot":"","sources":["../../../src/providers/FieldProvider/FieldProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmC,MAAM,OAAO,CAAA;AAYvD,eAAO,MAAM,YAAY;WAThB,MAAM;iBACA,MAAM;WACZ,MAAM;EAO0C,CAAA;AAEzD,eAAO,MAAM,aAAa,2BAGvB;IACD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,OAAO,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,OAAO,CAAA;KAAE,CAAA;CAC9D,4CAwBA,CAAA"}
@@ -0,0 +1,33 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React, { createContext, useEffect } from 'react';
3
+ const initialContext = {
4
+ type: undefined,
5
+ path: '',
6
+ schemaPath: ''
7
+ };
8
+ export const FieldContext = /*#__PURE__*/ createContext(initialContext);
9
+ export const FieldProvider = ({ children, context })=>{
10
+ const [type, setType] = React.useState();
11
+ const [path, setPath] = React.useState();
12
+ const [schemaPath, setSchemaPath] = React.useState();
13
+ useEffect(()=>{
14
+ if (schemaPath !== context.schemaPath) {
15
+ setType(context.type);
16
+ setPath(context.path);
17
+ setSchemaPath(context.schemaPath);
18
+ }
19
+ }, [
20
+ schemaPath,
21
+ context
22
+ ]);
23
+ return /*#__PURE__*/ _jsx(FieldContext.Provider, {
24
+ value: {
25
+ type,
26
+ path,
27
+ schemaPath
28
+ },
29
+ children: children
30
+ });
31
+ };
32
+
33
+ //# sourceMappingURL=FieldProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/providers/FieldProvider/FieldProvider.tsx"],"sourcesContent":["import React, { createContext, useEffect } from 'react'\n\nconst initialContext: {\n path?: string\n schemaPath?: string\n type?: string\n} = {\n type: undefined,\n path: '',\n schemaPath: '',\n}\n\nexport const FieldContext = createContext(initialContext)\n\nexport const FieldProvider = ({\n children,\n context,\n}: {\n children: React.ReactNode\n context: { path: string; schemaPath: unknown; type: unknown }\n}) => {\n const [type, setType] = React.useState<string>()\n const [path, setPath] = React.useState<string>()\n const [schemaPath, setSchemaPath] = React.useState<string>()\n\n useEffect(() => {\n if (schemaPath !== context.schemaPath) {\n setType(context.type as string)\n setPath(context.path)\n setSchemaPath(context.schemaPath as string)\n }\n }, [schemaPath, context])\n\n return (\n <FieldContext.Provider\n value={{\n type,\n path,\n schemaPath,\n }}\n >\n {children}\n </FieldContext.Provider>\n )\n}\n"],"names":["React","createContext","useEffect","initialContext","type","undefined","path","schemaPath","FieldContext","FieldProvider","children","context","setType","useState","setPath","setSchemaPath","Provider","value"],"mappings":";AAAA,OAAOA,SAASC,aAAa,EAAEC,SAAS,QAAQ,QAAO;AAEvD,MAAMC,iBAIF;IACFC,MAAMC;IACNC,MAAM;IACNC,YAAY;AACd;AAEA,OAAO,MAAMC,6BAAeP,cAAcE,gBAAe;AAEzD,OAAO,MAAMM,gBAAgB,CAAC,EAC5BC,QAAQ,EACRC,OAAO,EAIR;IACC,MAAM,CAACP,MAAMQ,QAAQ,GAAGZ,MAAMa,QAAQ;IACtC,MAAM,CAACP,MAAMQ,QAAQ,GAAGd,MAAMa,QAAQ;IACtC,MAAM,CAACN,YAAYQ,cAAc,GAAGf,MAAMa,QAAQ;IAElDX,UAAU;QACR,IAAIK,eAAeI,QAAQJ,UAAU,EAAE;YACrCK,QAAQD,QAAQP,IAAI;YACpBU,QAAQH,QAAQL,IAAI;YACpBS,cAAcJ,QAAQJ,UAAU;QAClC;IACF,GAAG;QAACA;QAAYI;KAAQ;IAExB,qBACE,KAACH,aAAaQ,QAAQ;QACpBC,OAAO;YACLb;YACAE;YACAC;QACF;kBAECG;;AAGP,EAAC"}
@@ -0,0 +1,6 @@
1
+ export declare const useFieldProps: () => {
2
+ type: string;
3
+ path: string;
4
+ schemaPath: string;
5
+ };
6
+ //# sourceMappingURL=useFieldProps.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFieldProps.d.ts","sourceRoot":"","sources":["../../../src/providers/FieldProvider/useFieldProps.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,aAAa;;;;CAQzB,CAAA"}
@@ -0,0 +1,12 @@
1
+ import { useContext } from 'react';
2
+ import { FieldContext } from './FieldProvider.js';
3
+ export const useFieldProps = ()=>{
4
+ const { type, path, schemaPath } = useContext(FieldContext);
5
+ return {
6
+ type,
7
+ path,
8
+ schemaPath
9
+ };
10
+ };
11
+
12
+ //# sourceMappingURL=useFieldProps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/providers/FieldProvider/useFieldProps.ts"],"sourcesContent":["import { useContext } from 'react'\n\nimport { FieldContext } from './FieldProvider.js'\n\nexport const useFieldProps = () => {\n const { type, path, schemaPath } = useContext(FieldContext)\n\n return {\n type,\n path,\n schemaPath,\n }\n}\n"],"names":["useContext","FieldContext","useFieldProps","type","path","schemaPath"],"mappings":"AAAA,SAASA,UAAU,QAAQ,QAAO;AAElC,SAASC,YAAY,QAAQ,qBAAoB;AAEjD,OAAO,MAAMC,gBAAgB;IAC3B,MAAM,EAAEC,IAAI,EAAEC,IAAI,EAAEC,UAAU,EAAE,GAAGL,WAAWC;IAE9C,OAAO;QACLE;QACAC;QACAC;IACF;AACF,EAAC"}
@@ -1,6 +1,10 @@
1
+ import type { Field } from 'payload';
1
2
  import React from 'react';
2
3
  export declare const InstructionsContext: React.Context<{
3
- instructions: any;
4
+ field?: Field;
5
+ instructions: Record<string, any>;
6
+ path?: string;
7
+ schemaPath?: unknown;
4
8
  }>;
5
9
  export declare const InstructionsProvider: React.FC;
6
10
  //# sourceMappingURL=InstructionsProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"InstructionsProvider.d.ts","sourceRoot":"","sources":["../../../src/providers/InstructionsProvider/InstructionsProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA6C,MAAM,OAAO,CAAA;AAQjE,eAAO,MAAM,mBAAmB;;EAAgC,CAAA;AAEhE,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAqBxC,CAAA"}
1
+ {"version":3,"file":"InstructionsProvider.d.ts","sourceRoot":"","sources":["../../../src/providers/InstructionsProvider/InstructionsProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAA;AAGpC,OAAO,KAA6C,MAAM,OAAO,CAAA;AAgBjE,eAAO,MAAM,mBAAmB;YAXtB,KAAK;kBACC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;WAC1B,MAAM;iBACA,OAAO;EAQ0C,CAAA;AAEhE,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EA0BxC,CAAA"}
@@ -1,20 +1,25 @@
1
1
  'use client';
2
2
  import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { useConfig } from '@payloadcms/ui';
3
4
  import React, { createContext, useEffect, useState } from 'react';
4
- import { PLUGIN_INSTRUCTIONS_MAP_GLOBAL } from '../../defaults.js';
5
+ import { PLUGIN_FETCH_FIELDS_ENDPOINT } from '../../defaults.js';
5
6
  const initialContext = {
6
- instructions: undefined
7
+ field: undefined,
8
+ instructions: undefined,
9
+ path: '',
10
+ schemaPath: ''
7
11
  };
8
12
  export const InstructionsContext = /*#__PURE__*/ createContext(initialContext);
9
13
  export const InstructionsProvider = ({ children })=>{
10
14
  const [instructions, setInstructionsState] = useState({});
15
+ const { config } = useConfig();
16
+ const { routes: { api }, serverURL } = config;
11
17
  // This is here because each field have separate instructions and
12
- // their ID is needed to edit them for Drawer, so instead of fetching it
13
- // one by one its map is saved in globals during build
18
+ // their ID is needed to edit them for Drawer
14
19
  useEffect(()=>{
15
- fetch(`/api/globals/${PLUGIN_INSTRUCTIONS_MAP_GLOBAL}`).then((res)=>{
16
- res.json().then((data)=>{
17
- setInstructionsState(data.map);
20
+ fetch(`${serverURL}${api}${PLUGIN_FETCH_FIELDS_ENDPOINT}`).then(async (res)=>{
21
+ await res.json().then((data)=>{
22
+ setInstructionsState(data);
18
23
  });
19
24
  }).catch((err)=>{
20
25
  console.error('InstructionsProvider:', err);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/providers/InstructionsProvider/InstructionsProvider.tsx"],"sourcesContent":["'use client'\n\nimport React, { createContext, useEffect, useState } from 'react'\n\nimport { PLUGIN_INSTRUCTIONS_MAP_GLOBAL } from '../../defaults.js'\n\nconst initialContext = {\n instructions: undefined,\n}\n\nexport const InstructionsContext = createContext(initialContext)\n\nexport const InstructionsProvider: React.FC = ({ children }: { children: React.ReactNode }) => {\n const [instructions, setInstructionsState] = useState({})\n\n // This is here because each field have separate instructions and\n // their ID is needed to edit them for Drawer, so instead of fetching it\n // one by one its map is saved in globals during build\n useEffect(() => {\n fetch(`/api/globals/${PLUGIN_INSTRUCTIONS_MAP_GLOBAL}`)\n .then((res) => {\n res.json().then((data) => {\n setInstructionsState(data.map)\n })\n })\n .catch((err) => {\n console.error('InstructionsProvider:', err)\n })\n }, [])\n\n return (\n <InstructionsContext.Provider value={{ instructions }}>{children}</InstructionsContext.Provider>\n )\n}\n"],"names":["React","createContext","useEffect","useState","PLUGIN_INSTRUCTIONS_MAP_GLOBAL","initialContext","instructions","undefined","InstructionsContext","InstructionsProvider","children","setInstructionsState","fetch","then","res","json","data","map","catch","err","console","error","Provider","value"],"mappings":"AAAA;;AAEA,OAAOA,SAASC,aAAa,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,QAAO;AAEjE,SAASC,8BAA8B,QAAQ,oBAAmB;AAElE,MAAMC,iBAAiB;IACrBC,cAAcC;AAChB;AAEA,OAAO,MAAMC,oCAAsBP,cAAcI,gBAAe;AAEhE,OAAO,MAAMI,uBAAiC,CAAC,EAAEC,QAAQ,EAAiC;IACxF,MAAM,CAACJ,cAAcK,qBAAqB,GAAGR,SAAS,CAAC;IAEvD,iEAAiE;IACjE,wEAAwE;IACxE,sDAAsD;IACtDD,UAAU;QACRU,MAAM,CAAC,aAAa,EAAER,+BAA+B,CAAC,EACnDS,IAAI,CAAC,CAACC;YACLA,IAAIC,IAAI,GAAGF,IAAI,CAAC,CAACG;gBACfL,qBAAqBK,KAAKC,GAAG;YAC/B;QACF,GACCC,KAAK,CAAC,CAACC;YACNC,QAAQC,KAAK,CAAC,yBAAyBF;QACzC;IACJ,GAAG,EAAE;IAEL,qBACE,KAACX,oBAAoBc,QAAQ;QAACC,OAAO;YAAEjB;QAAa;kBAAII;;AAE5D,EAAC"}
1
+ {"version":3,"sources":["../../../src/providers/InstructionsProvider/InstructionsProvider.tsx"],"sourcesContent":["'use client'\n\nimport type { Field } from 'payload'\n\nimport { useConfig } from '@payloadcms/ui'\nimport React, { createContext, useEffect, useState } from 'react'\n\nimport { PLUGIN_FETCH_FIELDS_ENDPOINT } from '../../defaults.js'\n\nconst initialContext: {\n field?: Field\n instructions: Record<string, any>\n path?: string\n schemaPath?: unknown\n} = {\n field: undefined,\n instructions: undefined,\n path: '',\n schemaPath: '',\n}\n\nexport const InstructionsContext = createContext(initialContext)\n\nexport const InstructionsProvider: React.FC = ({ children }: { children: React.ReactNode }) => {\n const [instructions, setInstructionsState] = useState({})\n\n const { config } = useConfig()\n const {\n routes: { api },\n serverURL,\n } = config\n\n // This is here because each field have separate instructions and\n // their ID is needed to edit them for Drawer\n useEffect(() => {\n fetch(`${serverURL}${api}${PLUGIN_FETCH_FIELDS_ENDPOINT}`)\n .then(async (res) => {\n await res.json().then((data) => {\n setInstructionsState(data)\n })\n })\n .catch((err) => {\n console.error('InstructionsProvider:', err)\n })\n }, [])\n\n return (\n <InstructionsContext.Provider value={{ instructions }}>{children}</InstructionsContext.Provider>\n )\n}\n"],"names":["useConfig","React","createContext","useEffect","useState","PLUGIN_FETCH_FIELDS_ENDPOINT","initialContext","field","undefined","instructions","path","schemaPath","InstructionsContext","InstructionsProvider","children","setInstructionsState","config","routes","api","serverURL","fetch","then","res","json","data","catch","err","console","error","Provider","value"],"mappings":"AAAA;;AAIA,SAASA,SAAS,QAAQ,iBAAgB;AAC1C,OAAOC,SAASC,aAAa,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,QAAO;AAEjE,SAASC,4BAA4B,QAAQ,oBAAmB;AAEhE,MAAMC,iBAKF;IACFC,OAAOC;IACPC,cAAcD;IACdE,MAAM;IACNC,YAAY;AACd;AAEA,OAAO,MAAMC,oCAAsBV,cAAcI,gBAAe;AAEhE,OAAO,MAAMO,uBAAiC,CAAC,EAAEC,QAAQ,EAAiC;IACxF,MAAM,CAACL,cAAcM,qBAAqB,GAAGX,SAAS,CAAC;IAEvD,MAAM,EAAEY,MAAM,EAAE,GAAGhB;IACnB,MAAM,EACJiB,QAAQ,EAAEC,GAAG,EAAE,EACfC,SAAS,EACV,GAAGH;IAEJ,iEAAiE;IACjE,6CAA6C;IAC7Cb,UAAU;QACRiB,MAAM,GAAGD,YAAYD,MAAMb,8BAA8B,EACtDgB,IAAI,CAAC,OAAOC;YACX,MAAMA,IAAIC,IAAI,GAAGF,IAAI,CAAC,CAACG;gBACrBT,qBAAqBS;YACvB;QACF,GACCC,KAAK,CAAC,CAACC;YACNC,QAAQC,KAAK,CAAC,yBAAyBF;QACzC;IACJ,GAAG,EAAE;IAEL,qBACE,KAACd,oBAAoBiB,QAAQ;QAACC,OAAO;YAAErB;QAAa;kBAAIK;;AAE5D,EAAC"}
@@ -1,4 +1,4 @@
1
- export declare const useInstructions: ({ path }: {
2
- path: any;
1
+ export declare const useInstructions: (update?: {
2
+ schemaPath?: unknown;
3
3
  }) => any;
4
4
  //# sourceMappingURL=useInstructions.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useInstructions.d.ts","sourceRoot":"","sources":["../../../src/providers/InstructionsProvider/useInstructions.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,eAAe;;SAkC3B,CAAA"}
1
+ {"version":3,"file":"useInstructions.d.ts","sourceRoot":"","sources":["../../../src/providers/InstructionsProvider/useInstructions.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,eAAe,YAClB;IACN,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB,QAgDF,CAAA"}
@@ -1,7 +1,7 @@
1
- import { useContext } from 'react';
2
- import { InstructionsContext } from './InstructionsProvider.js';
1
+ import { useContext, useEffect, useState } from 'react';
3
2
  import { handlebarsHelpers, handlebarsHelpersMap } from '../../libraries/handlebars/helpersMap.js';
4
- export const useInstructions = ({ path })=>{
3
+ import { InstructionsContext } from './InstructionsProvider.js';
4
+ export const useInstructions = (update = {})=>{
5
5
  const context = useContext(InstructionsContext);
6
6
  //Fields are used for autocompletion in PromptTextareaField
7
7
  const fields = Object.keys(context.instructions || {}).map((key)=>{
@@ -12,6 +12,10 @@ export const useInstructions = ({ path })=>{
12
12
  ].reduce((acc, f)=>{
13
13
  const fieldKey = Object.keys(context.instructions).find((k)=>k.endsWith(f));
14
14
  const fieldInfo = context.instructions[fieldKey];
15
+ // Currently, Upload fields are excluded from suggestions
16
+ if (fieldInfo.fieldType === 'upload') {
17
+ return acc;
18
+ }
15
19
  const helpers = handlebarsHelpers.filter((h)=>handlebarsHelpersMap[h]?.field === fieldInfo.fieldType);
16
20
  if (helpers.length) {
17
21
  for (const helper of helpers){
@@ -22,9 +26,18 @@ export const useInstructions = ({ path })=>{
22
26
  acc.push(f);
23
27
  return acc;
24
28
  }, []);
29
+ const [schemaPath, setSchemaPath] = useState(update.schemaPath);
30
+ useEffect(()=>{
31
+ if (update.schemaPath !== schemaPath) {
32
+ setSchemaPath(update.schemaPath);
33
+ }
34
+ }, [
35
+ schemaPath,
36
+ update
37
+ ]);
25
38
  return {
26
39
  ...context,
27
- ...context.instructions[path] || {},
40
+ ...context.instructions[schemaPath] || {},
28
41
  fields,
29
42
  map: context.instructions,
30
43
  promptEditorSuggestions
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/providers/InstructionsProvider/useInstructions.ts"],"sourcesContent":["import { useContext } from 'react'\n\nimport { InstructionsContext } from './InstructionsProvider.js'\nimport { handlebarsHelpers, handlebarsHelpersMap } from '../../libraries/handlebars/helpersMap.js'\n\nexport const useInstructions = ({ path }) => {\n const context = useContext(InstructionsContext)\n\n //Fields are used for autocompletion in PromptTextareaField\n const fields = Object.keys(context.instructions || {}).map((key) => {\n return key.split('.').slice(1).join('.')\n })\n\n const promptEditorSuggestions = [...fields].reduce((acc, f) => {\n const fieldKey = Object.keys(context.instructions).find((k) => k.endsWith(f))\n const fieldInfo = context.instructions[fieldKey]\n\n const helpers = handlebarsHelpers.filter(\n (h) => handlebarsHelpersMap[h]?.field === fieldInfo.fieldType,\n )\n\n if (helpers.length) {\n for (const helper of helpers) {\n acc.push(helper + ` ${f}`)\n }\n return acc\n }\n\n acc.push(f)\n return acc\n }, [])\n\n return {\n ...context,\n ...(context.instructions[path] || {}),\n fields,\n map: context.instructions,\n promptEditorSuggestions,\n }\n}\n"],"names":["useContext","InstructionsContext","handlebarsHelpers","handlebarsHelpersMap","useInstructions","path","context","fields","Object","keys","instructions","map","key","split","slice","join","promptEditorSuggestions","reduce","acc","f","fieldKey","find","k","endsWith","fieldInfo","helpers","filter","h","field","fieldType","length","helper","push"],"mappings":"AAAA,SAASA,UAAU,QAAQ,QAAO;AAElC,SAASC,mBAAmB,QAAQ,4BAA2B;AAC/D,SAASC,iBAAiB,EAAEC,oBAAoB,QAAQ,2CAA0C;AAElG,OAAO,MAAMC,kBAAkB,CAAC,EAAEC,IAAI,EAAE;IACtC,MAAMC,UAAUN,WAAWC;IAE3B,2DAA2D;IAC3D,MAAMM,SAASC,OAAOC,IAAI,CAACH,QAAQI,YAAY,IAAI,CAAC,GAAGC,GAAG,CAAC,CAACC;QAC1D,OAAOA,IAAIC,KAAK,CAAC,KAAKC,KAAK,CAAC,GAAGC,IAAI,CAAC;IACtC;IAEA,MAAMC,0BAA0B;WAAIT;KAAO,CAACU,MAAM,CAAC,CAACC,KAAKC;QACvD,MAAMC,WAAWZ,OAAOC,IAAI,CAACH,QAAQI,YAAY,EAAEW,IAAI,CAAC,CAACC,IAAMA,EAAEC,QAAQ,CAACJ;QAC1E,MAAMK,YAAYlB,QAAQI,YAAY,CAACU,SAAS;QAEhD,MAAMK,UAAUvB,kBAAkBwB,MAAM,CACtC,CAACC,IAAMxB,oBAAoB,CAACwB,EAAE,EAAEC,UAAUJ,UAAUK,SAAS;QAG/D,IAAIJ,QAAQK,MAAM,EAAE;YAClB,KAAK,MAAMC,UAAUN,QAAS;gBAC5BP,IAAIc,IAAI,CAACD,SAAS,CAAC,CAAC,EAAEZ,EAAE,CAAC;YAC3B;YACA,OAAOD;QACT;QAEAA,IAAIc,IAAI,CAACb;QACT,OAAOD;IACT,GAAG,EAAE;IAEL,OAAO;QACL,GAAGZ,OAAO;QACV,GAAIA,QAAQI,YAAY,CAACL,KAAK,IAAI,CAAC,CAAC;QACpCE;QACAI,KAAKL,QAAQI,YAAY;QACzBM;IACF;AACF,EAAC"}
1
+ {"version":3,"sources":["../../../src/providers/InstructionsProvider/useInstructions.ts"],"sourcesContent":["import { useContext, useEffect, useState } from 'react'\n\nimport { handlebarsHelpers, handlebarsHelpersMap } from '../../libraries/handlebars/helpersMap.js'\nimport { InstructionsContext } from './InstructionsProvider.js'\n\nexport const useInstructions = (\n update: {\n schemaPath?: unknown\n } = {},\n) => {\n const context = useContext(InstructionsContext)\n\n //Fields are used for autocompletion in PromptTextareaField\n const fields = Object.keys(context.instructions || {}).map((key) => {\n return key.split('.').slice(1).join('.')\n })\n\n const promptEditorSuggestions = [...fields].reduce((acc, f) => {\n const fieldKey = Object.keys(context.instructions).find((k) => k.endsWith(f))\n const fieldInfo = context.instructions[fieldKey]\n\n // Currently, Upload fields are excluded from suggestions\n if (fieldInfo.fieldType === 'upload') {\n return acc\n }\n\n const helpers = handlebarsHelpers.filter(\n (h) => handlebarsHelpersMap[h]?.field === fieldInfo.fieldType,\n )\n\n if (helpers.length) {\n for (const helper of helpers) {\n acc.push(helper + ` ${f}`)\n }\n return acc\n }\n\n acc.push(f)\n return acc\n }, [])\n\n const [schemaPath, setSchemaPath] = useState(update.schemaPath as string)\n\n useEffect(() => {\n if(update.schemaPath !== schemaPath) {\n setSchemaPath(update.schemaPath as string)\n }\n }, [schemaPath, update])\n\n return {\n ...context,\n ...(context.instructions[schemaPath] || {}),\n fields,\n map: context.instructions,\n promptEditorSuggestions,\n }\n}\n"],"names":["useContext","useEffect","useState","handlebarsHelpers","handlebarsHelpersMap","InstructionsContext","useInstructions","update","context","fields","Object","keys","instructions","map","key","split","slice","join","promptEditorSuggestions","reduce","acc","f","fieldKey","find","k","endsWith","fieldInfo","fieldType","helpers","filter","h","field","length","helper","push","schemaPath","setSchemaPath"],"mappings":"AAAA,SAASA,UAAU,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,QAAO;AAEvD,SAASC,iBAAiB,EAAEC,oBAAoB,QAAQ,2CAA0C;AAClG,SAASC,mBAAmB,QAAQ,4BAA2B;AAE/D,OAAO,MAAMC,kBAAkB,CAC7BC,SAEI,CAAC,CAAC;IAEN,MAAMC,UAAUR,WAAWK;IAE3B,2DAA2D;IAC3D,MAAMI,SAASC,OAAOC,IAAI,CAACH,QAAQI,YAAY,IAAI,CAAC,GAAGC,GAAG,CAAC,CAACC;QAC1D,OAAOA,IAAIC,KAAK,CAAC,KAAKC,KAAK,CAAC,GAAGC,IAAI,CAAC;IACtC;IAEA,MAAMC,0BAA0B;WAAIT;KAAO,CAACU,MAAM,CAAC,CAACC,KAAKC;QACvD,MAAMC,WAAWZ,OAAOC,IAAI,CAACH,QAAQI,YAAY,EAAEW,IAAI,CAAC,CAACC,IAAMA,EAAEC,QAAQ,CAACJ;QAC1E,MAAMK,YAAYlB,QAAQI,YAAY,CAACU,SAAS;QAEhD,yDAAyD;QACzD,IAAII,UAAUC,SAAS,KAAK,UAAU;YACpC,OAAOP;QACT;QAEA,MAAMQ,UAAUzB,kBAAkB0B,MAAM,CACtC,CAACC,IAAM1B,oBAAoB,CAAC0B,EAAE,EAAEC,UAAUL,UAAUC,SAAS;QAG/D,IAAIC,QAAQI,MAAM,EAAE;YAClB,KAAK,MAAMC,UAAUL,QAAS;gBAC5BR,IAAIc,IAAI,CAACD,SAAS,CAAC,CAAC,EAAEZ,GAAG;YAC3B;YACA,OAAOD;QACT;QAEAA,IAAIc,IAAI,CAACb;QACT,OAAOD;IACT,GAAG,EAAE;IAEL,MAAM,CAACe,YAAYC,cAAc,GAAGlC,SAASK,OAAO4B,UAAU;IAE9DlC,UAAU;QACR,IAAGM,OAAO4B,UAAU,KAAKA,YAAY;YACnCC,cAAc7B,OAAO4B,UAAU;QACjC;IACF,GAAG;QAACA;QAAY5B;KAAO;IAEvB,OAAO;QACL,GAAGC,OAAO;QACV,GAAIA,QAAQI,YAAY,CAACuB,WAAW,IAAI,CAAC,CAAC;QAC1C1B;QACAI,KAAKL,QAAQI,YAAY;QACzBM;IACF;AACF,EAAC"}
package/dist/types.d.ts CHANGED
@@ -1,17 +1,18 @@
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
+ editorConfig?: {
10
+ nodes: JSONSchema[];
11
+ };
8
12
  fields?: Field[];
13
+ generatePromptOnInit?: boolean;
9
14
  globals?: string[];
10
15
  interfaceName?: string;
11
- editorConfig?: {
12
- nodes: (typeof LexicalBaseNode)[];
13
- };
14
- debugging?: boolean;
15
16
  }
16
17
  export interface GenerationModel {
17
18
  fields: string[];
@@ -50,44 +51,11 @@ export type BaseItemProps<T = any> = {
50
51
  children?: React.ReactNode;
51
52
  disabled?: boolean;
52
53
  hideIcon?: boolean;
54
+ isActive?: boolean;
55
+ isMenu?: boolean;
53
56
  onClick: (data?: unknown) => void;
54
57
  onMouseEnter?: MouseEventHandler<T> | undefined;
55
58
  onMouseLeave?: MouseEventHandler<T> | undefined;
56
59
  style?: CSSProperties | undefined;
57
- isMenu?: boolean;
58
- isActive?: boolean;
59
60
  };
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
61
  //# 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\n\nexport interface PluginConfig {\n collections: {\n [key: string]: boolean\n }\n debugging?: 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}\n"],"names":[],"mappings":"AA4EA,WAUC"}
@@ -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"}