@ai-stack/payloadcms 3.0.0-beta.104.2 → 3.0.0-beta.65.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -16
- package/dist/ai/{schemas → editor}/lexical.schema.d.ts +2 -2
- package/dist/ai/editor/lexical.schema.d.ts.map +1 -0
- package/dist/ai/editor/lexical.schema.js.map +1 -0
- package/dist/ai/models/anthropic/generateRichText.js.map +1 -1
- package/dist/ai/models/anthropic/index.d.ts.map +1 -1
- package/dist/ai/models/anthropic/index.js +4 -43
- package/dist/ai/models/anthropic/index.js.map +1 -1
- package/dist/ai/models/elevenLabs/index.d.ts.map +1 -1
- package/dist/ai/models/elevenLabs/index.js +11 -1
- package/dist/ai/models/elevenLabs/index.js.map +1 -1
- package/dist/ai/models/index.d.ts.map +1 -1
- package/dist/ai/models/index.js +3 -3
- package/dist/ai/models/index.js.map +1 -1
- package/dist/ai/models/openai/generateRichText.js.map +1 -1
- package/dist/ai/models/openai/index.js +3 -3
- package/dist/ai/models/openai/index.js.map +1 -1
- package/dist/ai/models/style.d.ts +2 -0
- package/dist/ai/models/style.d.ts.map +1 -0
- package/dist/ai/models/style.js +31 -0
- package/dist/ai/models/style.js.map +1 -0
- package/dist/ai/prompts.d.ts +6 -7
- package/dist/ai/prompts.d.ts.map +1 -1
- package/dist/ai/prompts.js +16 -24
- package/dist/ai/prompts.js.map +1 -1
- package/dist/ai/utils/generateFileNameByPrompt.js.map +1 -1
- package/dist/ai/utils/generateSeedPrompt.d.ts.map +1 -1
- package/dist/ai/utils/generateSeedPrompt.js +5 -14
- package/dist/ai/utils/generateSeedPrompt.js.map +1 -1
- package/dist/collections/Instructions.d.ts.map +1 -1
- package/dist/collections/Instructions.js +13 -10
- package/dist/collections/Instructions.js.map +1 -1
- package/dist/defaults.d.ts +2 -3
- package/dist/defaults.d.ts.map +1 -1
- package/dist/defaults.js +2 -3
- package/dist/defaults.js.map +1 -1
- package/dist/endpoints/index.d.ts +1 -1
- package/dist/endpoints/index.d.ts.map +1 -1
- package/dist/endpoints/index.js +51 -17
- package/dist/endpoints/index.js.map +1 -1
- package/dist/exports/fields.d.ts +1 -3
- package/dist/exports/fields.d.ts.map +1 -1
- package/dist/exports/fields.js +0 -3
- package/dist/exports/fields.js.map +1 -1
- package/dist/fields/DescriptionField/DescriptionField.d.ts +3 -0
- package/dist/fields/DescriptionField/DescriptionField.d.ts.map +1 -0
- package/dist/fields/DescriptionField/DescriptionField.js +15 -0
- package/dist/fields/DescriptionField/DescriptionField.js.map +1 -0
- package/dist/fields/DescriptionField/DescriptionFieldComponent.d.ts +4 -0
- package/dist/fields/DescriptionField/DescriptionFieldComponent.d.ts.map +1 -0
- package/dist/fields/{ComposeField/ComposeField.js → DescriptionField/DescriptionFieldComponent.js} +5 -5
- package/dist/fields/DescriptionField/DescriptionFieldComponent.js.map +1 -0
- package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts +2 -0
- package/dist/fields/LexicalEditor/ActionsFeatureComponent.d.ts.map +1 -0
- package/dist/fields/LexicalEditor/{ComposeFeatureComponent.js → ActionsFeatureComponent.js} +5 -5
- package/dist/fields/LexicalEditor/ActionsFeatureComponent.js.map +1 -0
- package/dist/fields/LexicalEditor/feature.client.d.ts +4 -1
- package/dist/fields/LexicalEditor/feature.client.d.ts.map +1 -1
- package/dist/fields/LexicalEditor/feature.client.js +2 -2
- package/dist/fields/LexicalEditor/feature.client.js.map +1 -1
- package/dist/fields/LexicalEditor/feature.server.d.ts +7 -1
- package/dist/fields/LexicalEditor/feature.server.d.ts.map +1 -1
- package/dist/fields/LexicalEditor/feature.server.js +11 -4
- package/dist/fields/LexicalEditor/feature.server.js.map +1 -1
- package/dist/fields/PromptEditorField/PromptEditorField.d.ts +2 -2
- package/dist/fields/PromptEditorField/PromptEditorField.d.ts.map +1 -1
- package/dist/fields/PromptEditorField/PromptEditorField.js +51 -32
- package/dist/fields/PromptEditorField/PromptEditorField.js.map +1 -1
- package/dist/fields/SelectField/SelectField.d.ts +2 -9
- package/dist/fields/SelectField/SelectField.d.ts.map +1 -1
- package/dist/fields/SelectField/SelectField.js +23 -26
- package/dist/fields/SelectField/SelectField.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts +1 -2
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +19 -35
- package/dist/init.js.map +1 -1
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +73 -104
- package/dist/plugin.js.map +1 -1
- package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts +3 -1
- package/dist/providers/InstructionsProvider/InstructionsProvider.d.ts.map +1 -1
- package/dist/providers/InstructionsProvider/InstructionsProvider.js.map +1 -1
- package/dist/providers/InstructionsProvider/hook.d.ts +9 -0
- package/dist/providers/InstructionsProvider/hook.d.ts.map +1 -0
- package/dist/providers/InstructionsProvider/hook.js +17 -0
- package/dist/providers/InstructionsProvider/hook.js.map +1 -0
- package/dist/providers/InstructionsProvider/index.d.ts +5 -0
- package/dist/providers/InstructionsProvider/index.d.ts.map +1 -0
- package/dist/providers/InstructionsProvider/index.js +10 -0
- package/dist/providers/InstructionsProvider/index.js.map +1 -0
- package/dist/types.d.ts +1 -2
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/ui/Actions/Actions.d.ts +5 -0
- package/dist/ui/Actions/Actions.d.ts.map +1 -0
- package/dist/ui/{Compose/Compose.js → Actions/Actions.js} +18 -17
- package/dist/ui/Actions/Actions.js.map +1 -0
- package/dist/ui/{Compose → Actions}/UndoRedoActions.d.ts.map +1 -1
- package/dist/ui/{Compose → Actions}/UndoRedoActions.js +2 -15
- package/dist/ui/Actions/UndoRedoActions.js.map +1 -0
- package/dist/ui/Actions/hooks/highlight.module.scss +3 -0
- package/dist/ui/{Compose → Actions}/hooks/menu/Item.d.ts.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/Item.js.map +1 -1
- package/dist/ui/Actions/hooks/menu/TranslateMenu.d.ts.map +1 -0
- package/dist/ui/{Compose → Actions}/hooks/menu/TranslateMenu.js.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/items.d.ts.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/items.js.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.d.ts.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.js.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.d.ts.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.js.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/useGenerate.d.ts.map +1 -1
- package/dist/ui/{Compose → Actions}/hooks/useGenerate.js +12 -10
- package/dist/ui/Actions/hooks/useGenerate.js.map +1 -0
- package/dist/ui/Actions/hooks/useHistory.d.ts.map +1 -0
- package/dist/ui/{Compose → Actions}/hooks/useHistory.js +1 -3
- package/dist/ui/Actions/hooks/useHistory.js.map +1 -0
- package/dist/ui/Floatype/Floatype.d.ts +21 -0
- package/dist/ui/Floatype/Floatype.d.ts.map +1 -0
- package/dist/ui/Floatype/Floatype.js +245 -0
- package/dist/ui/Floatype/Floatype.js.map +1 -0
- package/dist/ui/Floatype/floatype.module.css +25 -0
- package/dist/utilities/getFieldBySchemaPath.d.ts +2 -2
- package/dist/utilities/getFieldBySchemaPath.d.ts.map +1 -1
- package/dist/utilities/getFieldBySchemaPath.js.map +1 -1
- package/dist/utilities/updateFieldsConfig.d.ts.map +1 -1
- package/dist/utilities/updateFieldsConfig.js +8 -14
- package/dist/utilities/updateFieldsConfig.js.map +1 -1
- package/package.json +50 -72
- package/dist/ai/schemas/lexical.schema.d.ts.map +0 -1
- package/dist/ai/schemas/lexical.schema.js.map +0 -1
- package/dist/exports/client.d.ts +0 -3
- package/dist/exports/client.d.ts.map +0 -1
- package/dist/exports/client.js +0 -4
- package/dist/exports/client.js.map +0 -1
- package/dist/fields/ComposeField/ComposeField.d.ts +0 -4
- package/dist/fields/ComposeField/ComposeField.d.ts.map +0 -1
- package/dist/fields/ComposeField/ComposeField.js.map +0 -1
- package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts +0 -2
- package/dist/fields/LexicalEditor/ComposeFeatureComponent.d.ts.map +0 -1
- package/dist/fields/LexicalEditor/ComposeFeatureComponent.js.map +0 -1
- package/dist/libraries/autocomplete/AutocompleteTextArea.d.ts +0 -8
- package/dist/libraries/autocomplete/AutocompleteTextArea.d.ts.map +0 -1
- package/dist/libraries/autocomplete/AutocompleteTextArea.js +0 -437
- package/dist/libraries/autocomplete/AutocompleteTextArea.js.map +0 -1
- package/dist/libraries/autocomplete/AutocompleteTextArea.module.scss +0 -35
- package/dist/libraries/handlebars/asyncHandlebars.d.ts +0 -2
- package/dist/libraries/handlebars/asyncHandlebars.d.ts.map +0 -1
- package/dist/libraries/handlebars/asyncHandlebars.js +0 -5
- package/dist/libraries/handlebars/asyncHandlebars.js.map +0 -1
- package/dist/libraries/handlebars/helpers.d.ts +0 -2
- package/dist/libraries/handlebars/helpers.d.ts.map +0 -1
- package/dist/libraries/handlebars/helpers.js +0 -22
- package/dist/libraries/handlebars/helpers.js.map +0 -1
- package/dist/libraries/handlebars/helpersMap.d.ts +0 -12
- package/dist/libraries/handlebars/helpersMap.d.ts.map +0 -1
- package/dist/libraries/handlebars/helpersMap.js +0 -13
- package/dist/libraries/handlebars/helpersMap.js.map +0 -1
- package/dist/libraries/handlebars/replacePlaceholders.d.ts +0 -2
- package/dist/libraries/handlebars/replacePlaceholders.d.ts.map +0 -1
- package/dist/libraries/handlebars/replacePlaceholders.js +0 -8
- package/dist/libraries/handlebars/replacePlaceholders.js.map +0 -1
- package/dist/providers/InstructionsProvider/useInstructions.d.ts +0 -4
- package/dist/providers/InstructionsProvider/useInstructions.d.ts.map +0 -1
- package/dist/providers/InstructionsProvider/useInstructions.js +0 -38
- package/dist/providers/InstructionsProvider/useInstructions.js.map +0 -1
- package/dist/ui/Compose/Compose.d.ts +0 -9
- package/dist/ui/Compose/Compose.d.ts.map +0 -1
- package/dist/ui/Compose/Compose.js.map +0 -1
- package/dist/ui/Compose/UndoRedoActions.js.map +0 -1
- package/dist/ui/Compose/hooks/menu/TranslateMenu.d.ts.map +0 -1
- package/dist/ui/Compose/hooks/useGenerate.js.map +0 -1
- package/dist/ui/Compose/hooks/useHistory.d.ts.map +0 -1
- package/dist/ui/Compose/hooks/useHistory.js.map +0 -1
- package/dist/utilities/getFieldInfo.d.ts +0 -3
- package/dist/utilities/getFieldInfo.d.ts.map +0 -1
- package/dist/utilities/getFieldInfo.js +0 -14
- package/dist/utilities/getFieldInfo.js.map +0 -1
- package/dist/utilities/isPluginActivated.d.ts +0 -2
- package/dist/utilities/isPluginActivated.d.ts.map +0 -1
- package/dist/utilities/isPluginActivated.js +0 -5
- package/dist/utilities/isPluginActivated.js.map +0 -1
- /package/dist/ai/{schemas → editor}/lexical.schema.js +0 -0
- /package/dist/ui/{Compose → Actions}/UndoRedoActions.d.ts +0 -0
- /package/dist/ui/{Compose/compose.module.scss → Actions/actions.module.scss} +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/Item.d.ts +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/Item.js +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/TranslateMenu.d.ts +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/TranslateMenu.js +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/items.d.ts +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/items.js +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.d.ts +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/itemsMap.js +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/menu.module.scss +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.d.ts +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/menu/useMenu.js +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/useGenerate.d.ts +0 -0
- /package/dist/ui/{Compose → Actions}/hooks/useHistory.d.ts +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feature.client.d.ts","sourceRoot":"","sources":["../../../src/fields/LexicalEditor/feature.client.tsx"],"names":[],"mappings":"AAMA,eAAO,MAAM,0BAA0B,
|
|
1
|
+
{"version":3,"file":"feature.client.d.ts","sourceRoot":"","sources":["../../../src/fields/LexicalEditor/feature.client.tsx"],"names":[],"mappings":"AAMA,eAAO,MAAM,0BAA0B;;;EAOrC,CAAA"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { createClientFeature } from '@payloadcms/richtext-lexical/client';
|
|
3
|
-
import {
|
|
3
|
+
import { ActionsFeatureComponent } from './ActionsFeatureComponent.js';
|
|
4
4
|
export const LexicalEditorFeatureClient = createClientFeature({
|
|
5
5
|
plugins: [
|
|
6
6
|
{
|
|
7
|
-
Component:
|
|
7
|
+
Component: ActionsFeatureComponent,
|
|
8
8
|
position: 'belowContainer'
|
|
9
9
|
}
|
|
10
10
|
]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/fields/LexicalEditor/feature.client.tsx"],"sourcesContent":["'use client'\n\nimport { createClientFeature } from '@payloadcms/richtext-lexical/client'\n\nimport {
|
|
1
|
+
{"version":3,"sources":["../../../src/fields/LexicalEditor/feature.client.tsx"],"sourcesContent":["'use client'\n\nimport { createClientFeature } from '@payloadcms/richtext-lexical/client'\n\nimport { ActionsFeatureComponent } from './ActionsFeatureComponent.js'\n\nexport const LexicalEditorFeatureClient = createClientFeature({\n plugins: [\n {\n Component: ActionsFeatureComponent,\n position: 'belowContainer',\n },\n ],\n})\n"],"names":["createClientFeature","ActionsFeatureComponent","LexicalEditorFeatureClient","plugins","Component","position"],"mappings":"AAAA;AAEA,SAASA,mBAAmB,QAAQ,sCAAqC;AAEzE,SAASC,uBAAuB,QAAQ,+BAA8B;AAEtE,OAAO,MAAMC,6BAA6BF,oBAAoB;IAC5DG,SAAS;QACP;YACEC,WAAWH;YACXI,UAAU;QACZ;KACD;AACH,GAAE"}
|
|
@@ -1,2 +1,8 @@
|
|
|
1
|
-
export declare const PayloadAiPluginLexicalEditorFeature: import("@payloadcms/richtext-lexical").FeatureProviderProviderServer<undefined,
|
|
1
|
+
export declare const PayloadAiPluginLexicalEditorFeature: import("@payloadcms/richtext-lexical").FeatureProviderProviderServer<undefined, {
|
|
2
|
+
applyToFocusedEditor: any;
|
|
3
|
+
disableIfParentHasFixedToolbar: any;
|
|
4
|
+
}, {
|
|
5
|
+
applyToFocusedEditor: any;
|
|
6
|
+
disableIfParentHasFixedToolbar: any;
|
|
7
|
+
}>;
|
|
2
8
|
//# sourceMappingURL=feature.server.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feature.server.d.ts","sourceRoot":"","sources":["../../../src/fields/LexicalEditor/feature.server.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"feature.server.d.ts","sourceRoot":"","sources":["../../../src/fields/LexicalEditor/feature.server.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,mCAAmC;;;;;;EAiB9C,CAAA"}
|
|
@@ -1,10 +1,17 @@
|
|
|
1
1
|
import { createServerFeature } from '@payloadcms/richtext-lexical';
|
|
2
2
|
import { PLUGIN_LEXICAL_EDITOR_FEATURE } from '../../defaults.js';
|
|
3
|
-
import {
|
|
4
|
-
const isActivated = isPluginActivated();
|
|
3
|
+
import { LexicalEditorFeatureClient } from './feature.client.js';
|
|
5
4
|
export const PayloadAiPluginLexicalEditorFeature = createServerFeature({
|
|
6
|
-
feature: {
|
|
7
|
-
|
|
5
|
+
feature: ({ props })=>{
|
|
6
|
+
const sanitizedProps = {
|
|
7
|
+
applyToFocusedEditor: props?.applyToFocusedEditor === undefined ? false : props.applyToFocusedEditor,
|
|
8
|
+
disableIfParentHasFixedToolbar: props?.disableIfParentHasFixedToolbar === undefined ? false : props.disableIfParentHasFixedToolbar
|
|
9
|
+
};
|
|
10
|
+
return {
|
|
11
|
+
ClientFeature: LexicalEditorFeatureClient,
|
|
12
|
+
clientFeatureProps: sanitizedProps,
|
|
13
|
+
sanitizedServerFeatureProps: sanitizedProps
|
|
14
|
+
};
|
|
8
15
|
},
|
|
9
16
|
key: PLUGIN_LEXICAL_EDITOR_FEATURE
|
|
10
17
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/fields/LexicalEditor/feature.server.ts"],"sourcesContent":["import { createServerFeature } from '@payloadcms/richtext-lexical'\n\nimport { PLUGIN_LEXICAL_EDITOR_FEATURE } from '../../defaults.js'\nimport {
|
|
1
|
+
{"version":3,"sources":["../../../src/fields/LexicalEditor/feature.server.ts"],"sourcesContent":["import { createServerFeature } from '@payloadcms/richtext-lexical'\n\nimport { PLUGIN_LEXICAL_EDITOR_FEATURE } from '../../defaults.js'\nimport { LexicalEditorFeatureClient } from './feature.client.js'\n\nexport const PayloadAiPluginLexicalEditorFeature = createServerFeature({\n feature: ({ props }: Record<any, any>) => {\n const sanitizedProps = {\n applyToFocusedEditor:\n props?.applyToFocusedEditor === undefined ? false : props.applyToFocusedEditor,\n disableIfParentHasFixedToolbar:\n props?.disableIfParentHasFixedToolbar === undefined\n ? false\n : props.disableIfParentHasFixedToolbar,\n }\n return {\n ClientFeature: LexicalEditorFeatureClient,\n clientFeatureProps: sanitizedProps,\n sanitizedServerFeatureProps: sanitizedProps,\n }\n },\n key: PLUGIN_LEXICAL_EDITOR_FEATURE,\n})\n"],"names":["createServerFeature","PLUGIN_LEXICAL_EDITOR_FEATURE","LexicalEditorFeatureClient","PayloadAiPluginLexicalEditorFeature","feature","props","sanitizedProps","applyToFocusedEditor","undefined","disableIfParentHasFixedToolbar","ClientFeature","clientFeatureProps","sanitizedServerFeatureProps","key"],"mappings":"AAAA,SAASA,mBAAmB,QAAQ,+BAA8B;AAElE,SAASC,6BAA6B,QAAQ,oBAAmB;AACjE,SAASC,0BAA0B,QAAQ,sBAAqB;AAEhE,OAAO,MAAMC,sCAAsCH,oBAAoB;IACrEI,SAAS,CAAC,EAAEC,KAAK,EAAoB;QACnC,MAAMC,iBAAiB;YACrBC,sBACEF,OAAOE,yBAAyBC,YAAY,QAAQH,MAAME,oBAAoB;YAChFE,gCACEJ,OAAOI,mCAAmCD,YACtC,QACAH,MAAMI,8BAA8B;QAC5C;QACA,OAAO;YACLC,eAAeR;YACfS,oBAAoBL;YACpBM,6BAA6BN;QAC/B;IACF;IACAO,KAAKZ;AACP,GAAE"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
+
import type { TextareaFieldProps } from '@payloadcms/ui';
|
|
1
2
|
import React from 'react';
|
|
2
|
-
|
|
3
|
-
export declare const PromptEditorField: React.FC<TextareaFieldClientProps>;
|
|
3
|
+
export declare const PromptEditorField: React.FC<TextareaFieldProps>;
|
|
4
4
|
//# sourceMappingURL=PromptEditorField.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PromptEditorField.d.ts","sourceRoot":"","sources":["../../../src/fields/PromptEditorField/PromptEditorField.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PromptEditorField.d.ts","sourceRoot":"","sources":["../../../src/fields/PromptEditorField/PromptEditorField.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAGxD,OAAO,KAAyC,MAAM,OAAO,CAAA;AAM7D,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAgE1D,CAAA"}
|
|
@@ -1,40 +1,59 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
import { jsx as _jsx
|
|
3
|
-
import {
|
|
4
|
-
import React from 'react';
|
|
5
|
-
import { useInstructions } from '../../providers/InstructionsProvider/
|
|
6
|
-
import {
|
|
7
|
-
//
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { TextareaField as InputField, useField, useFieldProps, useForm } from '@payloadcms/ui';
|
|
4
|
+
import React, { useCallback, useEffect, useRef } from 'react';
|
|
5
|
+
import { useInstructions } from '../../providers/InstructionsProvider/hook.js';
|
|
6
|
+
import { Floatype } from '../../ui/Floatype/Floatype.js';
|
|
7
|
+
//TODO: Display the handlebarjs tips in description
|
|
8
8
|
export const PromptEditorField = (props)=>{
|
|
9
|
-
const {
|
|
9
|
+
const { name, path: pathFromProps, ...restProps } = props;
|
|
10
10
|
const { path: pathFromContext } = useFieldProps();
|
|
11
|
-
const
|
|
12
|
-
|
|
11
|
+
const elementRef = useRef(null);
|
|
12
|
+
const { fields } = useInstructions({
|
|
13
|
+
path: pathFromProps
|
|
13
14
|
});
|
|
14
|
-
const {
|
|
15
|
-
path: pathFromContext
|
|
15
|
+
const { path, setValue } = useField({
|
|
16
|
+
path: pathFromContext || pathFromProps || name
|
|
16
17
|
});
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
18
|
+
const { formRef, initializing } = useForm();
|
|
19
|
+
useEffect(()=>{
|
|
20
|
+
if (!formRef.current || elementRef.current) return;
|
|
21
|
+
const fieldId = `#field-${path.replace(/\./g, '__')}`;
|
|
22
|
+
elementRef.current = formRef.current.querySelector(fieldId);
|
|
23
|
+
}, [
|
|
24
|
+
formRef,
|
|
25
|
+
path
|
|
26
|
+
]);
|
|
27
|
+
const handleQuery = useCallback((val)=>{
|
|
28
|
+
if (val === '{{ ') return fields;
|
|
29
|
+
return fields.filter((field)=>field.toLowerCase().includes(val.toLowerCase()));
|
|
30
|
+
}, [
|
|
31
|
+
fields
|
|
32
|
+
]);
|
|
33
|
+
const handleSelect = useCallback((value, query)=>{
|
|
34
|
+
if (query === '{{ ') return `${value} }}`;
|
|
35
|
+
return fields.includes(value) ? value : undefined;
|
|
36
|
+
}, [
|
|
37
|
+
fields
|
|
38
|
+
]);
|
|
39
|
+
const handleUpdate = useCallback((value)=>{
|
|
40
|
+
if (value) setValue(value);
|
|
41
|
+
}, [
|
|
42
|
+
setValue
|
|
43
|
+
]);
|
|
44
|
+
const CustomDescription = !initializing ? /*#__PURE__*/ _jsx(Floatype, {
|
|
45
|
+
options: {
|
|
46
|
+
onQuery: handleQuery,
|
|
47
|
+
onSelect: handleSelect,
|
|
48
|
+
onUpdate: handleUpdate
|
|
49
|
+
},
|
|
50
|
+
ref: elementRef
|
|
51
|
+
}) : null;
|
|
52
|
+
return /*#__PURE__*/ _jsx(InputField, {
|
|
53
|
+
...restProps,
|
|
54
|
+
CustomDescription: CustomDescription,
|
|
55
|
+
name: name,
|
|
56
|
+
path: pathFromProps
|
|
38
57
|
});
|
|
39
58
|
};
|
|
40
59
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/fields/PromptEditorField/PromptEditorField.tsx"],"sourcesContent":["'use client'\n\nimport {
|
|
1
|
+
{"version":3,"sources":["../../../src/fields/PromptEditorField/PromptEditorField.tsx"],"sourcesContent":["'use client'\n\nimport type { TextareaFieldProps } from '@payloadcms/ui'\n\nimport { TextareaField as InputField, useField, useFieldProps, useForm } from '@payloadcms/ui'\nimport React, { useCallback, useEffect, useRef } from 'react'\n\nimport { useInstructions } from '../../providers/InstructionsProvider/hook.js'\nimport { Floatype } from '../../ui/Floatype/Floatype.js'\n\n//TODO: Display the handlebarjs tips in description\nexport const PromptEditorField: React.FC<TextareaFieldProps> = (props) => {\n const { name, path: pathFromProps, ...restProps } = props\n const { path: pathFromContext } = useFieldProps()\n\n const elementRef = useRef<HTMLTextAreaElement>(null)\n const { fields } = useInstructions({\n path: pathFromProps,\n })\n\n const { path, setValue } = useField<string>({\n path: pathFromContext || pathFromProps || name,\n })\n\n const { formRef, initializing } = useForm()\n\n useEffect(() => {\n if (!formRef.current || elementRef.current) return\n\n const fieldId = `#field-${path.replace(/\\./g, '__')}`\n elementRef.current = formRef.current.querySelector(fieldId)\n }, [formRef, path])\n\n const handleQuery = useCallback(\n (val: string) => {\n if (val === '{{ ') return fields\n return fields.filter((field) => field.toLowerCase().includes(val.toLowerCase()))\n },\n [fields],\n )\n\n const handleSelect = useCallback(\n (value: string, query: string) => {\n if (query === '{{ ') return `${value} }}`\n return fields.includes(value) ? value : undefined\n },\n [fields],\n )\n\n const handleUpdate = useCallback(\n (value: string) => {\n if (value) setValue(value)\n },\n [setValue],\n )\n\n const CustomDescription = !initializing ? (\n <Floatype\n options={{\n onQuery: handleQuery,\n onSelect: handleSelect,\n onUpdate: handleUpdate,\n }}\n ref={elementRef}\n />\n ) : null\n\n return (\n <InputField\n {...restProps}\n CustomDescription={CustomDescription}\n name={name}\n path={pathFromProps}\n />\n )\n}\n"],"names":["TextareaField","InputField","useField","useFieldProps","useForm","React","useCallback","useEffect","useRef","useInstructions","Floatype","PromptEditorField","props","name","path","pathFromProps","restProps","pathFromContext","elementRef","fields","setValue","formRef","initializing","current","fieldId","replace","querySelector","handleQuery","val","filter","field","toLowerCase","includes","handleSelect","value","query","undefined","handleUpdate","CustomDescription","options","onQuery","onSelect","onUpdate","ref"],"mappings":"AAAA;;AAIA,SAASA,iBAAiBC,UAAU,EAAEC,QAAQ,EAAEC,aAAa,EAAEC,OAAO,QAAQ,iBAAgB;AAC9F,OAAOC,SAASC,WAAW,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAO;AAE7D,SAASC,eAAe,QAAQ,+CAA8C;AAC9E,SAASC,QAAQ,QAAQ,gCAA+B;AAExD,mDAAmD;AACnD,OAAO,MAAMC,oBAAkD,CAACC;IAC9D,MAAM,EAAEC,IAAI,EAAEC,MAAMC,aAAa,EAAE,GAAGC,WAAW,GAAGJ;IACpD,MAAM,EAAEE,MAAMG,eAAe,EAAE,GAAGd;IAElC,MAAMe,aAAaV,OAA4B;IAC/C,MAAM,EAAEW,MAAM,EAAE,GAAGV,gBAAgB;QACjCK,MAAMC;IACR;IAEA,MAAM,EAAED,IAAI,EAAEM,QAAQ,EAAE,GAAGlB,SAAiB;QAC1CY,MAAMG,mBAAmBF,iBAAiBF;IAC5C;IAEA,MAAM,EAAEQ,OAAO,EAAEC,YAAY,EAAE,GAAGlB;IAElCG,UAAU;QACR,IAAI,CAACc,QAAQE,OAAO,IAAIL,WAAWK,OAAO,EAAE;QAE5C,MAAMC,UAAU,CAAC,OAAO,EAAEV,KAAKW,OAAO,CAAC,OAAO,MAAM,CAAC;QACrDP,WAAWK,OAAO,GAAGF,QAAQE,OAAO,CAACG,aAAa,CAACF;IACrD,GAAG;QAACH;QAASP;KAAK;IAElB,MAAMa,cAAcrB,YAClB,CAACsB;QACC,IAAIA,QAAQ,OAAO,OAAOT;QAC1B,OAAOA,OAAOU,MAAM,CAAC,CAACC,QAAUA,MAAMC,WAAW,GAAGC,QAAQ,CAACJ,IAAIG,WAAW;IAC9E,GACA;QAACZ;KAAO;IAGV,MAAMc,eAAe3B,YACnB,CAAC4B,OAAeC;QACd,IAAIA,UAAU,OAAO,OAAO,CAAC,EAAED,MAAM,GAAG,CAAC;QACzC,OAAOf,OAAOa,QAAQ,CAACE,SAASA,QAAQE;IAC1C,GACA;QAACjB;KAAO;IAGV,MAAMkB,eAAe/B,YACnB,CAAC4B;QACC,IAAIA,OAAOd,SAASc;IACtB,GACA;QAACd;KAAS;IAGZ,MAAMkB,oBAAoB,CAAChB,6BACzB,KAACZ;QACC6B,SAAS;YACPC,SAASb;YACTc,UAAUR;YACVS,UAAUL;QACZ;QACAM,KAAKzB;SAEL;IAEJ,qBACE,KAACjB;QACE,GAAGe,SAAS;QACbsB,mBAAmBA;QACnBzB,MAAMA;QACNC,MAAMC;;AAGZ,EAAC"}
|
|
@@ -1,10 +1,3 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
export declare const SelectField: (props:
|
|
3
|
-
filterByField: string;
|
|
4
|
-
options: {
|
|
5
|
-
fields: string[];
|
|
6
|
-
label: string;
|
|
7
|
-
value: string;
|
|
8
|
-
}[];
|
|
9
|
-
} & SelectFieldClientProps) => import("react/jsx-runtime").JSX.Element;
|
|
1
|
+
import type { SelectFieldProps } from '@payloadcms/ui';
|
|
2
|
+
export declare const SelectField: (props: SelectFieldProps) => import("react/jsx-runtime").JSX.Element;
|
|
10
3
|
//# sourceMappingURL=SelectField.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectField.d.ts","sourceRoot":"","sources":["../../../src/fields/SelectField/SelectField.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"SelectField.d.ts","sourceRoot":"","sources":["../../../src/fields/SelectField/SelectField.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AAMtD,eAAO,MAAM,WAAW,UAAW,gBAAgB,4CA6BlD,CAAA"}
|
|
@@ -1,40 +1,37 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
-
import {
|
|
3
|
+
import { SelectField as Select, useField, useFieldProps } from '@payloadcms/ui';
|
|
4
4
|
import React, { useEffect, useState } from 'react';
|
|
5
|
-
// Use to filter model options in settings based on field types
|
|
6
5
|
export const SelectField = (props)=>{
|
|
7
|
-
const
|
|
8
|
-
const { path } =
|
|
9
|
-
const {
|
|
6
|
+
const fieldProps = useFieldProps();
|
|
7
|
+
const { custom: selectOptions, path } = fieldProps;
|
|
8
|
+
const { options: optionsFromProps = [] } = props;
|
|
9
|
+
const { filterByField, options } = selectOptions;
|
|
10
|
+
const { value } = useField({
|
|
10
11
|
path: filterByField
|
|
11
12
|
});
|
|
12
13
|
const [filterOptions, setFilterOptions] = useState([]);
|
|
14
|
+
//TODO: Remove this mess, find alternative
|
|
13
15
|
useEffect(()=>{
|
|
14
|
-
if (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
16
|
+
if (Array.isArray(options)) {
|
|
17
|
+
const opts = options.filter((option)=>{
|
|
18
|
+
if (!value || !option.fields) return true;
|
|
19
|
+
if (Array.isArray(option.fields)) {
|
|
20
|
+
return option.fields.includes(value);
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
setFilterOptions(opts);
|
|
24
|
+
} else {
|
|
25
|
+
setFilterOptions(optionsFromProps);
|
|
26
|
+
}
|
|
22
27
|
}, [
|
|
23
|
-
|
|
28
|
+
value,
|
|
29
|
+
optionsFromProps,
|
|
24
30
|
options
|
|
25
31
|
]);
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
return /*#__PURE__*/ _jsx(SelectInput, {
|
|
30
|
-
label: field.label,
|
|
31
|
-
name: path,
|
|
32
|
-
onChange: (e)=>{
|
|
33
|
-
setValue(e.value);
|
|
34
|
-
},
|
|
35
|
-
options: filterOptions,
|
|
36
|
-
path: path,
|
|
37
|
-
value: selectValue
|
|
32
|
+
return /*#__PURE__*/ _jsx(Select, {
|
|
33
|
+
...props,
|
|
34
|
+
options: filterOptions
|
|
38
35
|
});
|
|
39
36
|
};
|
|
40
37
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/fields/SelectField/SelectField.tsx"],"sourcesContent":["'use client'\n\nimport type {
|
|
1
|
+
{"version":3,"sources":["../../../src/fields/SelectField/SelectField.tsx"],"sourcesContent":["'use client'\n\nimport type { SelectFieldProps } from '@payloadcms/ui'\nimport type { Option } from 'payload'\n\nimport { SelectField as Select, useField, useFieldProps } from '@payloadcms/ui'\nimport React, { useEffect, useState } from 'react'\n\nexport const SelectField = (props: SelectFieldProps) => {\n const fieldProps = useFieldProps()\n\n const { custom: selectOptions, path } = fieldProps\n const { options: optionsFromProps = [] } = props\n const { filterByField, options } = selectOptions\n\n const { value } = useField({\n path: filterByField,\n })\n const [filterOptions, setFilterOptions] = useState<Option[]>([])\n\n //TODO: Remove this mess, find alternative\n useEffect(() => {\n if (Array.isArray(options)) {\n const opts = options.filter((option) => {\n if (!value || !option.fields) return true\n\n if (Array.isArray(option.fields)) {\n return option.fields.includes(value)\n }\n })\n setFilterOptions(opts)\n } else {\n setFilterOptions(optionsFromProps)\n }\n }, [value, optionsFromProps, options])\n\n return <Select {...props} options={filterOptions} />\n}\n"],"names":["SelectField","Select","useField","useFieldProps","React","useEffect","useState","props","fieldProps","custom","selectOptions","path","options","optionsFromProps","filterByField","value","filterOptions","setFilterOptions","Array","isArray","opts","filter","option","fields","includes"],"mappings":"AAAA;;AAKA,SAASA,eAAeC,MAAM,EAAEC,QAAQ,EAAEC,aAAa,QAAQ,iBAAgB;AAC/E,OAAOC,SAASC,SAAS,EAAEC,QAAQ,QAAQ,QAAO;AAElD,OAAO,MAAMN,cAAc,CAACO;IAC1B,MAAMC,aAAaL;IAEnB,MAAM,EAAEM,QAAQC,aAAa,EAAEC,IAAI,EAAE,GAAGH;IACxC,MAAM,EAAEI,SAASC,mBAAmB,EAAE,EAAE,GAAGN;IAC3C,MAAM,EAAEO,aAAa,EAAEF,OAAO,EAAE,GAAGF;IAEnC,MAAM,EAAEK,KAAK,EAAE,GAAGb,SAAS;QACzBS,MAAMG;IACR;IACA,MAAM,CAACE,eAAeC,iBAAiB,GAAGX,SAAmB,EAAE;IAE/D,0CAA0C;IAC1CD,UAAU;QACR,IAAIa,MAAMC,OAAO,CAACP,UAAU;YAC1B,MAAMQ,OAAOR,QAAQS,MAAM,CAAC,CAACC;gBAC3B,IAAI,CAACP,SAAS,CAACO,OAAOC,MAAM,EAAE,OAAO;gBAErC,IAAIL,MAAMC,OAAO,CAACG,OAAOC,MAAM,GAAG;oBAChC,OAAOD,OAAOC,MAAM,CAACC,QAAQ,CAACT;gBAChC;YACF;YACAE,iBAAiBG;QACnB,OAAO;YACLH,iBAAiBJ;QACnB;IACF,GAAG;QAACE;QAAOF;QAAkBD;KAAQ;IAErC,qBAAO,KAACX;QAAQ,GAAGM,KAAK;QAAEK,SAASI;;AACrC,EAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* COMMERCIAL-LICENSE.md. Unauthorized commercial use or resale of modified versions
|
|
5
5
|
* without appropriate licensing is prohibited.
|
|
6
6
|
*/
|
|
7
|
-
export { payloadAiPlugin } from './plugin.js';
|
|
8
7
|
export { PayloadAiPluginLexicalEditorFeature } from './fields/LexicalEditor/feature.server.js';
|
|
9
|
-
export {
|
|
8
|
+
export { payloadAiPlugin } from './plugin.js';
|
|
9
|
+
export { LexicalBaseNode } from './ai/editor/lexical.schema.js';
|
|
10
10
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,mCAAmC,EAAE,MAAM,0CAA0C,CAAA;AAC9F,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA"}
|
package/dist/index.js
CHANGED
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
* redistribution, or embedding in proprietary systems, please refer to the
|
|
4
4
|
* COMMERCIAL-LICENSE.md. Unauthorized commercial use or resale of modified versions
|
|
5
5
|
* without appropriate licensing is prohibited.
|
|
6
|
-
*/ export {
|
|
7
|
-
export {
|
|
8
|
-
export { LexicalBaseNode } from './ai/
|
|
6
|
+
*/ export { PayloadAiPluginLexicalEditorFeature } from './fields/LexicalEditor/feature.server.js';
|
|
7
|
+
export { payloadAiPlugin } from './plugin.js';
|
|
8
|
+
export { LexicalBaseNode } from './ai/editor/lexical.schema.js';
|
|
9
9
|
|
|
10
10
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["/**\n * @license This software is licensed under the MIT License. For commercial use,\n * redistribution, or embedding in proprietary systems, please refer to the\n * COMMERCIAL-LICENSE.md. Unauthorized commercial use or resale of modified versions\n * without appropriate licensing is prohibited.\n */\n\nexport {
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["/**\n * @license This software is licensed under the MIT License. For commercial use,\n * redistribution, or embedding in proprietary systems, please refer to the\n * COMMERCIAL-LICENSE.md. Unauthorized commercial use or resale of modified versions\n * without appropriate licensing is prohibited.\n */\n\nexport { PayloadAiPluginLexicalEditorFeature } from './fields/LexicalEditor/feature.server.js'\nexport { payloadAiPlugin } from './plugin.js'\nexport { LexicalBaseNode } from './ai/editor/lexical.schema.js'\n"],"names":["PayloadAiPluginLexicalEditorFeature","payloadAiPlugin","LexicalBaseNode"],"mappings":"AAAA;;;;;CAKC,GAED,SAASA,mCAAmC,QAAQ,2CAA0C;AAC9F,SAASC,eAAe,QAAQ,cAAa;AAC7C,SAASC,eAAe,QAAQ,gCAA+B"}
|
package/dist/init.d.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
1
|
import type { Payload } from 'payload';
|
|
2
|
-
|
|
3
|
-
export declare const init: (payload: Payload, fieldSchemaPaths: any, pluginConfig: PluginConfig) => Promise<void>;
|
|
2
|
+
export declare const init: (payload: Payload, fieldSchemaPaths: any) => Promise<void>;
|
|
4
3
|
//# sourceMappingURL=init.d.ts.map
|
package/dist/init.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAOtC,eAAO,MAAM,IAAI,YAAmB,OAAO,yCAqE1C,CAAA"}
|
package/dist/init.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
+
import { PLUGIN_INSTRUCTIONS_MAP_GLOBAL, PLUGIN_INSTRUCTIONS_TABLE } from './defaults.js';
|
|
1
2
|
import { GenerationModels } from './ai/models/index.js';
|
|
2
|
-
import { seedPrompts } from './ai/prompts.js';
|
|
3
3
|
import { generateSeedPrompt } from './ai/utils/generateSeedPrompt.js';
|
|
4
|
-
import {
|
|
5
|
-
export const init = async (payload, fieldSchemaPaths
|
|
4
|
+
import { seedPrompts } from './ai/prompts.js';
|
|
5
|
+
export const init = async (payload, fieldSchemaPaths)=>{
|
|
6
6
|
payload.logger.info(`— AI Plugin: Initializing...`);
|
|
7
7
|
const paths = Object.keys(fieldSchemaPaths);
|
|
8
|
+
// TODO: Add default options according to field type in INSTRUCTIONS table
|
|
8
9
|
const fieldInstructionsMap = {};
|
|
9
10
|
for(let i = 0; i < paths.length; i++){
|
|
10
11
|
const path = paths[i];
|
|
11
12
|
const { type: fieldType, label: fieldLabel } = fieldSchemaPaths[path];
|
|
12
|
-
//TODO: if global is broken the plugin doesn't know and does not run reindexing
|
|
13
13
|
const entry = await payload.find({
|
|
14
14
|
collection: PLUGIN_INSTRUCTIONS_TABLE,
|
|
15
15
|
where: {
|
|
@@ -22,46 +22,32 @@ export const init = async (payload, fieldSchemaPaths, pluginConfig)=>{
|
|
|
22
22
|
}
|
|
23
23
|
});
|
|
24
24
|
if (!entry?.docs?.length) {
|
|
25
|
-
const {
|
|
26
|
-
fieldLabel,
|
|
27
|
-
fieldSchemaPaths,
|
|
25
|
+
const { system, prompt } = seedPrompts({
|
|
28
26
|
fieldType,
|
|
29
|
-
|
|
27
|
+
fieldLabel,
|
|
28
|
+
path,
|
|
29
|
+
fieldSchemaPaths
|
|
30
30
|
});
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
});
|
|
37
|
-
payload.logger.info(`\nPrompt generated for "${fieldLabel}" field:\nprompt: ${generatedPrompt}\n\n`);
|
|
38
|
-
}
|
|
31
|
+
const generatedPrompt = await generateSeedPrompt({
|
|
32
|
+
system,
|
|
33
|
+
prompt
|
|
34
|
+
});
|
|
35
|
+
payload.logger.info(`\nPrompt generated for "${fieldLabel}" field:\nprompt: ${generatedPrompt}\n\n`);
|
|
39
36
|
const instructions = await payload.create({
|
|
40
37
|
collection: PLUGIN_INSTRUCTIONS_TABLE,
|
|
41
38
|
data: {
|
|
42
39
|
'field-type': fieldType,
|
|
40
|
+
'schema-path': path,
|
|
43
41
|
'model-id': GenerationModels.find((a)=>{
|
|
44
42
|
return a.fields.includes(fieldType);
|
|
45
|
-
})
|
|
46
|
-
prompt: generatedPrompt
|
|
47
|
-
'schema-path': path
|
|
43
|
+
}).id,
|
|
44
|
+
prompt: generatedPrompt
|
|
48
45
|
}
|
|
49
|
-
}).then((a)=>a).catch((a)=>{
|
|
50
|
-
console.log('err-', a);
|
|
51
46
|
});
|
|
52
|
-
|
|
53
|
-
if (instructions?.id) {
|
|
54
|
-
fieldInstructionsMap[path] = {
|
|
55
|
-
id: instructions.id,
|
|
56
|
-
fieldType
|
|
57
|
-
};
|
|
58
|
-
}
|
|
47
|
+
fieldInstructionsMap[path] = instructions.id;
|
|
59
48
|
} else {
|
|
60
49
|
const [instructions] = entry.docs;
|
|
61
|
-
fieldInstructionsMap[path] =
|
|
62
|
-
id: instructions.id,
|
|
63
|
-
fieldType
|
|
64
|
-
};
|
|
50
|
+
fieldInstructionsMap[path] = instructions.id;
|
|
65
51
|
}
|
|
66
52
|
}
|
|
67
53
|
payload.logger.info(`— AI Plugin: Enabled fieldMap: ${JSON.stringify(fieldInstructionsMap, null, 2)}`);
|
|
@@ -73,9 +59,7 @@ export const init = async (payload, fieldSchemaPaths, pluginConfig)=>{
|
|
|
73
59
|
depth: 2
|
|
74
60
|
});
|
|
75
61
|
payload.logger.info(`— AI Plugin: Initialized!`);
|
|
76
|
-
|
|
77
|
-
payload.logger.info('\n\n-AI Plugin: Example prompts are added to get you started, Now go break some code 🚀🚀🚀\n\n');
|
|
78
|
-
}
|
|
62
|
+
payload.logger.info('\n\n-AI Plugin: Example prompts are added to get you started, Now go break some code 🚀🚀🚀\n\n');
|
|
79
63
|
};
|
|
80
64
|
|
|
81
65
|
//# sourceMappingURL=init.js.map
|
package/dist/init.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/init.ts"],"sourcesContent":["import type { Payload } from 'payload'\n\nimport {
|
|
1
|
+
{"version":3,"sources":["../src/init.ts"],"sourcesContent":["import type { Payload } from 'payload'\n\nimport { PLUGIN_INSTRUCTIONS_MAP_GLOBAL, PLUGIN_INSTRUCTIONS_TABLE } from './defaults.js'\nimport { GenerationModels } from './ai/models/index.js'\nimport { generateSeedPrompt } from './ai/utils/generateSeedPrompt.js'\nimport { seedPrompts } from './ai/prompts.js'\n\nexport const init = async (payload: Payload, fieldSchemaPaths) => {\n payload.logger.info(`— AI Plugin: Initializing...`)\n\n const paths = Object.keys(fieldSchemaPaths)\n\n // TODO: Add default options according to field type in INSTRUCTIONS table\n const fieldInstructionsMap = {}\n for (let i = 0; i < paths.length; i++) {\n const path = paths[i]\n const { type: fieldType, label: fieldLabel } = fieldSchemaPaths[path]\n const entry = await payload.find({\n collection: PLUGIN_INSTRUCTIONS_TABLE,\n where: {\n 'field-type': {\n equals: fieldType,\n },\n 'schema-path': {\n equals: path,\n },\n },\n })\n\n if (!entry?.docs?.length) {\n const { system, prompt } = seedPrompts({\n fieldType,\n fieldLabel,\n path,\n fieldSchemaPaths,\n })\n const generatedPrompt = await generateSeedPrompt({\n system,\n prompt,\n })\n payload.logger.info(\n `\\nPrompt generated for \"${fieldLabel}\" field:\\nprompt: ${generatedPrompt}\\n\\n`,\n )\n const instructions = await payload.create({\n collection: PLUGIN_INSTRUCTIONS_TABLE,\n data: {\n 'field-type': fieldType,\n 'schema-path': path,\n 'model-id': GenerationModels.find((a) => {\n return a.fields.includes(fieldType)\n }).id,\n prompt: generatedPrompt,\n },\n })\n fieldInstructionsMap[path] = instructions.id\n } else {\n const [instructions] = entry.docs\n fieldInstructionsMap[path] = instructions.id\n }\n }\n\n payload.logger.info(\n `— AI Plugin: Enabled fieldMap: ${JSON.stringify(fieldInstructionsMap, null, 2)}`,\n )\n await payload.updateGlobal({\n slug: PLUGIN_INSTRUCTIONS_MAP_GLOBAL, // required\n data: {\n map: fieldInstructionsMap,\n },\n depth: 2,\n })\n\n payload.logger.info(`— AI Plugin: Initialized!`)\n payload.logger.info(\n '\\n\\n-AI Plugin: Example prompts are added to get you started, Now go break some code 🚀🚀🚀\\n\\n',\n )\n}\n"],"names":["PLUGIN_INSTRUCTIONS_MAP_GLOBAL","PLUGIN_INSTRUCTIONS_TABLE","GenerationModels","generateSeedPrompt","seedPrompts","init","payload","fieldSchemaPaths","logger","info","paths","Object","keys","fieldInstructionsMap","i","length","path","type","fieldType","label","fieldLabel","entry","find","collection","where","equals","docs","system","prompt","generatedPrompt","instructions","create","data","a","fields","includes","id","JSON","stringify","updateGlobal","slug","map","depth"],"mappings":"AAEA,SAASA,8BAA8B,EAAEC,yBAAyB,QAAQ,gBAAe;AACzF,SAASC,gBAAgB,QAAQ,uBAAsB;AACvD,SAASC,kBAAkB,QAAQ,mCAAkC;AACrE,SAASC,WAAW,QAAQ,kBAAiB;AAE7C,OAAO,MAAMC,OAAO,OAAOC,SAAkBC;IAC3CD,QAAQE,MAAM,CAACC,IAAI,CAAC,CAAC,4BAA4B,CAAC;IAElD,MAAMC,QAAQC,OAAOC,IAAI,CAACL;IAE1B,0EAA0E;IAC1E,MAAMM,uBAAuB,CAAC;IAC9B,IAAK,IAAIC,IAAI,GAAGA,IAAIJ,MAAMK,MAAM,EAAED,IAAK;QACrC,MAAME,OAAON,KAAK,CAACI,EAAE;QACrB,MAAM,EAAEG,MAAMC,SAAS,EAAEC,OAAOC,UAAU,EAAE,GAAGb,gBAAgB,CAACS,KAAK;QACrE,MAAMK,QAAQ,MAAMf,QAAQgB,IAAI,CAAC;YAC/BC,YAAYtB;YACZuB,OAAO;gBACL,cAAc;oBACZC,QAAQP;gBACV;gBACA,eAAe;oBACbO,QAAQT;gBACV;YACF;QACF;QAEA,IAAI,CAACK,OAAOK,MAAMX,QAAQ;YACxB,MAAM,EAAEY,MAAM,EAAEC,MAAM,EAAE,GAAGxB,YAAY;gBACrCc;gBACAE;gBACAJ;gBACAT;YACF;YACA,MAAMsB,kBAAkB,MAAM1B,mBAAmB;gBAC/CwB;gBACAC;YACF;YACAtB,QAAQE,MAAM,CAACC,IAAI,CACjB,CAAC,wBAAwB,EAAEW,WAAW,kBAAkB,EAAES,gBAAgB,IAAI,CAAC;YAEjF,MAAMC,eAAe,MAAMxB,QAAQyB,MAAM,CAAC;gBACxCR,YAAYtB;gBACZ+B,MAAM;oBACJ,cAAcd;oBACd,eAAeF;oBACf,YAAYd,iBAAiBoB,IAAI,CAAC,CAACW;wBACjC,OAAOA,EAAEC,MAAM,CAACC,QAAQ,CAACjB;oBAC3B,GAAGkB,EAAE;oBACLR,QAAQC;gBACV;YACF;YACAhB,oBAAoB,CAACG,KAAK,GAAGc,aAAaM,EAAE;QAC9C,OAAO;YACL,MAAM,CAACN,aAAa,GAAGT,MAAMK,IAAI;YACjCb,oBAAoB,CAACG,KAAK,GAAGc,aAAaM,EAAE;QAC9C;IACF;IAEA9B,QAAQE,MAAM,CAACC,IAAI,CACjB,CAAC,+BAA+B,EAAE4B,KAAKC,SAAS,CAACzB,sBAAsB,MAAM,GAAG,CAAC;IAEnF,MAAMP,QAAQiC,YAAY,CAAC;QACzBC,MAAMxC;QACNgC,MAAM;YACJS,KAAK5B;QACP;QACA6B,OAAO;IACT;IAEApC,QAAQE,MAAM,CAACC,IAAI,CAAC,CAAC,yBAAyB,CAAC;IAC/CH,QAAQE,MAAM,CAACC,IAAI,CACjB;AAEJ,EAAC"}
|
package/dist/plugin.d.ts.map
CHANGED
|
@@ -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;
|
|
1
|
+
{"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAGrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAa9C,QAAA,MAAM,eAAe,iBACJ,YAAY,sBACV,MAAM,KAAG,MAwFzB,CAAA;AAEH,OAAO,EAAE,eAAe,EAAE,CAAA"}
|