@webiny/app-headless-cms-common 6.0.0-beta.0 → 6.0.0-rc.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/Fields/ErrorBoundary.d.ts +24 -0
- package/Fields/ErrorBoundary.js +40 -0
- package/Fields/ErrorBoundary.js.map +1 -0
- package/Fields/FieldElement.d.ts +64 -0
- package/Fields/FieldElement.js +77 -0
- package/Fields/FieldElement.js.map +1 -0
- package/Fields/FieldElementError.d.ts +7 -0
- package/Fields/FieldElementError.js +25 -0
- package/Fields/FieldElementError.js.map +1 -0
- package/Fields/Fields.d.ts +11 -0
- package/Fields/Fields.js +43 -0
- package/Fields/Fields.js.map +1 -0
- package/Fields/Label.d.ts +6 -0
- package/Fields/Label.js +10 -0
- package/Fields/Label.js.map +1 -0
- package/Fields/index.d.ts +3 -0
- package/Fields/index.js +5 -0
- package/Fields/index.js.map +1 -0
- package/Fields/useBind.d.ts +9 -0
- package/Fields/useBind.js +113 -0
- package/Fields/useBind.js.map +1 -0
- package/Fields/useRenderPlugins.d.ts +1 -0
- package/Fields/useRenderPlugins.js +7 -0
- package/Fields/useRenderPlugins.js.map +1 -0
- package/ModelFieldProvider/ModelFieldContext.d.ts +38 -0
- package/ModelFieldProvider/ModelFieldContext.js +26 -0
- package/ModelFieldProvider/ModelFieldContext.js.map +1 -0
- package/ModelFieldProvider/index.d.ts +2 -0
- package/ModelFieldProvider/index.js +4 -0
- package/ModelFieldProvider/index.js.map +1 -0
- package/ModelFieldProvider/useModelField.d.ts +15 -0
- package/ModelFieldProvider/useModelField.js +29 -0
- package/ModelFieldProvider/useModelField.js.map +1 -0
- package/ModelProvider/ModelContext.d.ts +9 -0
- package/ModelProvider/ModelContext.js +12 -0
- package/ModelProvider/ModelContext.js.map +1 -0
- package/ModelProvider/index.d.ts +2 -0
- package/ModelProvider/index.js +4 -0
- package/ModelProvider/index.js.map +1 -0
- package/ModelProvider/useModel.d.ts +9 -0
- package/ModelProvider/useModel.js +16 -0
- package/ModelProvider/useModel.js.map +1 -0
- package/README.md +6 -13
- package/constants.d.ts +1 -0
- package/constants.js +3 -0
- package/constants.js.map +1 -0
- package/createFieldsList.d.ts +6 -2
- package/createFieldsList.js +31 -32
- package/createFieldsList.js.map +1 -1
- package/createValidationContainer.d.ts +18 -0
- package/createValidationContainer.js +23 -0
- package/createValidationContainer.js.map +1 -0
- package/createValidators.d.ts +3 -0
- package/createValidators.js +52 -0
- package/createValidators.js.map +1 -0
- package/entries.graphql.d.ts +54 -2
- package/entries.graphql.js +338 -55
- package/entries.graphql.js.map +1 -1
- package/exports/admin/cms.d.ts +1 -0
- package/exports/admin/cms.js +3 -0
- package/exports/admin/cms.js.map +1 -0
- package/getModelTitleFieldId.d.ts +1 -1
- package/getModelTitleFieldId.js +1 -7
- package/getModelTitleFieldId.js.map +1 -1
- package/index.d.ts +10 -4
- package/index.js +10 -49
- package/index.js.map +1 -1
- package/package.json +20 -25
- package/prepareFormData.d.ts +1 -1
- package/prepareFormData.js +23 -42
- package/prepareFormData.js.map +1 -1
- package/types/index.d.ts +53 -43
- package/types/index.js +1 -38
- package/types/index.js.map +1 -1
- package/types/model.d.ts +23 -17
- package/types/model.js +1 -5
- package/types/model.js.map +1 -1
- package/types/shared.js +1 -5
- package/types/validation.d.ts +3 -3
- package/types/validation.js +1 -5
- package/types/validation.js.map +1 -1
package/types/model.d.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import { Validator } from "@webiny/validation/types";
|
|
2
|
-
import { CmsModelFieldValidator } from "
|
|
3
|
-
import { CmsDynamicZoneTemplate, CmsEditorFieldPredefinedValues, CmsModelFieldRendererPlugin } from "
|
|
4
|
-
import { CmsIdentity } from "
|
|
1
|
+
import type { Validator } from "@webiny/validation/types.js";
|
|
2
|
+
import type { CmsModelFieldValidator } from "../types/validation.js";
|
|
3
|
+
import type { CmsDynamicZoneTemplate, CmsEditorFieldPredefinedValues, CmsModelFieldRendererPlugin } from "../types/index.js";
|
|
4
|
+
import type { CmsIdentity } from "../types/shared.js";
|
|
5
|
+
import type React from "react";
|
|
5
6
|
/**
|
|
6
7
|
* @deprecated Use `CmsModelField` instead.
|
|
7
8
|
*/
|
|
8
|
-
export
|
|
9
|
+
export type CmsEditorField<T = unknown> = CmsModelField<T>;
|
|
9
10
|
export interface CmsModelFieldSettings<T = unknown> {
|
|
10
11
|
defaultValue?: string | boolean | number | null | undefined;
|
|
11
12
|
defaultSetValue?: string;
|
|
@@ -17,17 +18,19 @@ export interface CmsModelFieldSettings<T = unknown> {
|
|
|
17
18
|
imagesOnly?: boolean;
|
|
18
19
|
[key: string]: any;
|
|
19
20
|
}
|
|
20
|
-
export
|
|
21
|
+
export type CmsModelField<T = unknown> = T & {
|
|
21
22
|
id: string;
|
|
22
23
|
type: string;
|
|
23
24
|
fieldId: CmsEditorFieldId;
|
|
24
25
|
storageId?: string;
|
|
25
26
|
label: string;
|
|
26
|
-
|
|
27
|
-
|
|
27
|
+
help?: string | React.ReactNode;
|
|
28
|
+
description?: string | React.ReactNode;
|
|
29
|
+
note?: string | React.ReactNode;
|
|
30
|
+
placeholder?: string;
|
|
28
31
|
validation?: (CmsModelFieldValidator | Validator)[];
|
|
29
32
|
listValidation?: CmsModelFieldValidator[];
|
|
30
|
-
|
|
33
|
+
list?: boolean;
|
|
31
34
|
predefinedValues?: CmsEditorFieldPredefinedValues;
|
|
32
35
|
settings?: CmsModelFieldSettings<T>;
|
|
33
36
|
renderer: {
|
|
@@ -41,13 +44,13 @@ export declare type CmsModelField<T = unknown> = T & {
|
|
|
41
44
|
| CmsModelFieldRendererPlugin["renderer"]["render"];
|
|
42
45
|
tags?: string[];
|
|
43
46
|
};
|
|
44
|
-
export
|
|
45
|
-
export
|
|
47
|
+
export type CmsEditorFieldId = string;
|
|
48
|
+
export type CmsEditorFieldsLayout = CmsEditorFieldId[][];
|
|
46
49
|
/**
|
|
47
50
|
* @category GraphQL
|
|
48
51
|
* @category Model
|
|
49
52
|
*/
|
|
50
|
-
export
|
|
53
|
+
export type CmsEditorContentModel = CmsModel;
|
|
51
54
|
/**
|
|
52
55
|
* @category GraphQL
|
|
53
56
|
* @category Group
|
|
@@ -67,12 +70,11 @@ export interface CmsGroup {
|
|
|
67
70
|
}
|
|
68
71
|
export interface CmsModel {
|
|
69
72
|
id: string;
|
|
70
|
-
group:
|
|
73
|
+
group: string;
|
|
71
74
|
description?: string;
|
|
72
75
|
version: number;
|
|
73
76
|
layout?: CmsEditorFieldsLayout;
|
|
74
77
|
fields: CmsModelField[];
|
|
75
|
-
lockedFields: CmsModelField[];
|
|
76
78
|
icon: string;
|
|
77
79
|
name: string;
|
|
78
80
|
modelId: string;
|
|
@@ -81,9 +83,6 @@ export interface CmsModel {
|
|
|
81
83
|
titleFieldId: string | null;
|
|
82
84
|
descriptionFieldId: string | null;
|
|
83
85
|
imageFieldId: string | null;
|
|
84
|
-
settings: {
|
|
85
|
-
[key: string]: any;
|
|
86
|
-
};
|
|
87
86
|
status: string;
|
|
88
87
|
savedOn: string;
|
|
89
88
|
meta: any;
|
|
@@ -93,4 +92,11 @@ export interface CmsModel {
|
|
|
93
92
|
* If model is a plugin one (it cannot be changed/deleted)
|
|
94
93
|
*/
|
|
95
94
|
plugin?: boolean;
|
|
95
|
+
/**
|
|
96
|
+
* Is model currently being deleted?
|
|
97
|
+
*/
|
|
98
|
+
isBeingDeleted?: boolean;
|
|
99
|
+
settings: {
|
|
100
|
+
[key: string]: any;
|
|
101
|
+
};
|
|
96
102
|
}
|
package/types/model.js
CHANGED
package/types/model.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["model.ts"],"sourcesContent":["import { Validator } from \"@webiny/validation/types\";\nimport { CmsModelFieldValidator } from \"~/types/validation\";\nimport {\n CmsDynamicZoneTemplate,\n CmsEditorFieldPredefinedValues,\n CmsModelFieldRendererPlugin\n} from \"~/types/index\";\nimport { CmsIdentity } from \"~/types/shared\";\n\n/**\n * @deprecated Use `CmsModelField` instead.\n */\nexport type CmsEditorField<T = unknown> = CmsModelField<T>;\n\nexport interface CmsModelFieldSettings<T = unknown> {\n defaultValue?: string | boolean | number | null | undefined;\n defaultSetValue?: string;\n type?: string;\n fields?: CmsModelField<T>[];\n layout?: string[][];\n models?: Pick<CmsModel, \"modelId\">[];\n templates?: CmsDynamicZoneTemplate[];\n imagesOnly?: boolean;\n [key: string]: any;\n}\n\nexport type CmsModelField<T = unknown> = T & {\n id: string;\n type: string;\n fieldId: CmsEditorFieldId;\n storageId?: string;\n label: string;\n
|
|
1
|
+
{"version":3,"names":[],"sources":["model.ts"],"sourcesContent":["import type { Validator } from \"@webiny/validation/types.js\";\nimport type { CmsModelFieldValidator } from \"~/types/validation.js\";\nimport type {\n CmsDynamicZoneTemplate,\n CmsEditorFieldPredefinedValues,\n CmsModelFieldRendererPlugin\n} from \"~/types/index.js\";\nimport type { CmsIdentity } from \"~/types/shared.js\";\nimport type React from \"react\";\n\n/**\n * @deprecated Use `CmsModelField` instead.\n */\nexport type CmsEditorField<T = unknown> = CmsModelField<T>;\n\nexport interface CmsModelFieldSettings<T = unknown> {\n defaultValue?: string | boolean | number | null | undefined;\n defaultSetValue?: string;\n type?: string;\n fields?: CmsModelField<T>[];\n layout?: string[][];\n models?: Pick<CmsModel, \"modelId\">[];\n templates?: CmsDynamicZoneTemplate[];\n imagesOnly?: boolean;\n [key: string]: any;\n}\n\nexport type CmsModelField<T = unknown> = T & {\n id: string;\n type: string;\n fieldId: CmsEditorFieldId;\n storageId?: string;\n label: string;\n help?: string | React.ReactNode;\n description?: string | React.ReactNode;\n note?: string | React.ReactNode;\n placeholder?: string;\n validation?: (CmsModelFieldValidator | Validator)[];\n listValidation?: CmsModelFieldValidator[];\n list?: boolean;\n predefinedValues?: CmsEditorFieldPredefinedValues;\n settings?: CmsModelFieldSettings<T>;\n renderer:\n | {\n name: string;\n settings?: Record<string, any>;\n }\n /**\n * Use this only for programmatic assignment of renderers.\n * Since functions cannot be serialized, this can only work via code.\n */\n | CmsModelFieldRendererPlugin[\"renderer\"][\"render\"];\n tags?: string[];\n};\n\nexport type CmsEditorFieldId = string;\nexport type CmsEditorFieldsLayout = CmsEditorFieldId[][];\n\n/**\n * @category GraphQL\n * @category Model\n */\nexport type CmsEditorContentModel = CmsModel;\n\n/**\n * @category GraphQL\n * @category Group\n */\nexport interface CmsGroup {\n id: string;\n name: string;\n slug: string;\n icon: string;\n description?: string;\n contentModels: CmsModel[];\n createdBy: CmsIdentity;\n /**\n * Tells if this group is a plugin one (cannot be changed/deleted)\n */\n plugin?: boolean;\n}\n\nexport interface CmsModel {\n id: string;\n group: string;\n description?: string;\n version: number;\n layout?: CmsEditorFieldsLayout;\n fields: CmsModelField[];\n icon: string;\n name: string;\n modelId: string;\n singularApiName: string;\n pluralApiName: string;\n titleFieldId: string | null;\n descriptionFieldId: string | null;\n imageFieldId: string | null;\n status: string;\n savedOn: string;\n meta: any;\n createdBy: CmsIdentity;\n tags: string[];\n /**\n * If model is a plugin one (it cannot be changed/deleted)\n */\n plugin?: boolean;\n /**\n * Is model currently being deleted?\n */\n isBeingDeleted?: boolean;\n settings: {\n [key: string]: any;\n };\n}\n"],"mappings":"","ignoreList":[]}
|
package/types/shared.js
CHANGED
package/types/validation.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import { Plugin } from "@webiny/plugins/types";
|
|
3
|
-
import { CmsModelField } from "
|
|
1
|
+
import type * as React from "react";
|
|
2
|
+
import type { Plugin } from "@webiny/plugins/types.js";
|
|
3
|
+
import type { CmsModelField } from "../types/index.js";
|
|
4
4
|
export interface CmsModelFieldValidatorConfigAdapter {
|
|
5
5
|
isRequired(): boolean;
|
|
6
6
|
getName(): string;
|
package/types/validation.js
CHANGED
package/types/validation.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["validation.ts"],"sourcesContent":["import * as React from \"react\";\nimport { Plugin } from \"@webiny/plugins/types\";\nimport { CmsModelField } from \"~/types\";\n\nexport interface CmsModelFieldValidatorConfigAdapter {\n isRequired(): boolean;\n getName(): string;\n getLabel(): string;\n getDescription(): string;\n getDefaultMessage(): string;\n getDefaultSettings(): Record<string, any> | undefined;\n getVariables(): CmsModelFieldValidatorVariable[];\n getVariableDescription(variableName: string): string | undefined;\n}\n\nexport interface CmsModelFieldValidatorVariable {\n name: string;\n description: string;\n}\n\n/**\n * This interface is used in the validator configuration UI (Field dialog).\n */\nexport interface CmsModelFieldValidatorConfig {\n name: string;\n required?: boolean;\n label?: string;\n description?: string;\n defaultMessage?: string;\n defaultSettings?: Record<string, any>;\n variables?: CmsModelFieldValidatorVariable[];\n}\n\n/**\n * This interface allows you to control the title, description, and validators located in the specific\n * validators group, like `validators` or `listValidators` within the Field dialog.\n */\nexport interface CmsModelFieldValidatorsGroup {\n validators: (string | CmsModelFieldValidatorConfig)[];\n title?: string;\n description?: string;\n}\n\n/**\n * This interface allows you to generate validators based on the field configuration.\n */\nexport interface CmsModelFieldValidatorsFactory {\n (field: CmsModelField): string[] | CmsModelFieldValidatorsGroup;\n}\n\nexport interface CmsModelFieldValidator {\n name: string;\n message?: string;\n settings?: any;\n}\n\nexport interface CmsModelFieldValidatorPlugin<T = any> extends Plugin {\n type: \"cms-model-field-validator\";\n validator: {\n name: string;\n label: string;\n description: string;\n defaultMessage: string;\n variables?: CmsModelFieldValidatorVariable[];\n defaultSettings?: Record<string, any>;\n getVariableValues?: (context: {\n validator: CmsModelFieldValidator;\n }) => Record<string, string>;\n renderSettings?: (config: CmsModelFieldValidatorConfigAdapter) => React.ReactElement;\n renderCustomUi?: () => React.ReactElement;\n validate: (\n value: T,\n context: {\n validator: CmsModelFieldValidator;\n field: CmsModelField;\n }\n ) => Promise<any>;\n };\n}\n\nexport interface CmsModelFieldRegexValidatorExpressionPlugin extends Plugin {\n type: \"cms-model-field-regex-validator-expression\";\n pattern: {\n name: string;\n message: string;\n label: string;\n regex: string;\n flags: string;\n };\n}\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["validation.ts"],"sourcesContent":["import type * as React from \"react\";\nimport type { Plugin } from \"@webiny/plugins/types.js\";\nimport type { CmsModelField } from \"~/types/index.js\";\n\nexport interface CmsModelFieldValidatorConfigAdapter {\n isRequired(): boolean;\n getName(): string;\n getLabel(): string;\n getDescription(): string;\n getDefaultMessage(): string;\n getDefaultSettings(): Record<string, any> | undefined;\n getVariables(): CmsModelFieldValidatorVariable[];\n getVariableDescription(variableName: string): string | undefined;\n}\n\nexport interface CmsModelFieldValidatorVariable {\n name: string;\n description: string;\n}\n\n/**\n * This interface is used in the validator configuration UI (Field dialog).\n */\nexport interface CmsModelFieldValidatorConfig {\n name: string;\n required?: boolean;\n label?: string;\n description?: string;\n defaultMessage?: string;\n defaultSettings?: Record<string, any>;\n variables?: CmsModelFieldValidatorVariable[];\n}\n\n/**\n * This interface allows you to control the title, description, and validators located in the specific\n * validators group, like `validators` or `listValidators` within the Field dialog.\n */\nexport interface CmsModelFieldValidatorsGroup {\n validators: (string | CmsModelFieldValidatorConfig)[];\n title?: string;\n description?: string;\n}\n\n/**\n * This interface allows you to generate validators based on the field configuration.\n */\nexport interface CmsModelFieldValidatorsFactory {\n (field: CmsModelField): string[] | CmsModelFieldValidatorsGroup;\n}\n\nexport interface CmsModelFieldValidator {\n name: string;\n message?: string;\n settings?: any;\n}\n\nexport interface CmsModelFieldValidatorPlugin<T = any> extends Plugin {\n type: \"cms-model-field-validator\";\n validator: {\n name: string;\n label: string;\n description: string;\n defaultMessage: string;\n variables?: CmsModelFieldValidatorVariable[];\n defaultSettings?: Record<string, any>;\n getVariableValues?: (context: {\n validator: CmsModelFieldValidator;\n }) => Record<string, string>;\n renderSettings?: (config: CmsModelFieldValidatorConfigAdapter) => React.ReactElement;\n renderCustomUi?: () => React.ReactElement;\n validate: (\n value: T,\n context: {\n validator: CmsModelFieldValidator;\n field: CmsModelField;\n }\n ) => Promise<any>;\n };\n}\n\nexport interface CmsModelFieldRegexValidatorExpressionPlugin extends Plugin {\n type: \"cms-model-field-regex-validator-expression\";\n pattern: {\n name: string;\n message: string;\n label: string;\n regex: string;\n flags: string;\n };\n}\n"],"mappings":"","ignoreList":[]}
|