@wordpress/dataviews 4.0.0 → 4.2.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/CHANGELOG.md +33 -5
- package/README.md +31 -23
- package/build/components/dataform/index.js +10 -61
- package/build/components/dataform/index.js.map +1 -1
- package/build/components/dataviews/index.js +23 -14
- package/build/components/dataviews/index.js.map +1 -1
- package/build/components/dataviews-bulk-actions/index.js +3 -0
- package/build/components/dataviews-bulk-actions/index.js.map +1 -1
- package/build/components/dataviews-filters/add-filter.js +34 -17
- package/build/components/dataviews-filters/add-filter.js.map +1 -1
- package/build/components/dataviews-filters/index.js +109 -43
- package/build/components/dataviews-filters/index.js.map +1 -1
- package/build/components/dataviews-filters/search-widget.js +2 -5
- package/build/components/dataviews-filters/search-widget.js.map +1 -1
- package/build/components/dataviews-layout/index.js +2 -2
- package/build/components/dataviews-layout/index.js.map +1 -1
- package/build/components/dataviews-pagination/index.js +23 -15
- package/build/components/dataviews-pagination/index.js.map +1 -1
- package/build/components/dataviews-search/index.js +8 -5
- package/build/components/dataviews-search/index.js.map +1 -1
- package/build/components/dataviews-view-config/index.js +240 -188
- package/build/components/dataviews-view-config/index.js.map +1 -1
- package/build/constants.js +6 -1
- package/build/constants.js.map +1 -1
- package/build/dataform-controls/datetime.js +49 -0
- package/build/dataform-controls/datetime.js.map +1 -0
- package/build/dataform-controls/index.js +50 -0
- package/build/dataform-controls/index.js.map +1 -0
- package/build/dataform-controls/integer.js +45 -0
- package/build/dataform-controls/integer.js.map +1 -0
- package/build/dataform-controls/radio.js +45 -0
- package/build/dataform-controls/radio.js.map +1 -0
- package/build/dataform-controls/select.js +58 -0
- package/build/dataform-controls/select.js.map +1 -0
- package/build/dataform-controls/text.js +45 -0
- package/build/dataform-controls/text.js.map +1 -0
- package/build/dataforms-layouts/index.js +24 -0
- package/build/dataforms-layouts/index.js.map +1 -0
- package/build/dataforms-layouts/panel/index.js +132 -0
- package/build/dataforms-layouts/panel/index.js.map +1 -0
- package/build/dataforms-layouts/regular/index.js +42 -0
- package/build/dataforms-layouts/regular/index.js.map +1 -0
- package/build/dataviews-layouts/grid/density-picker.js +114 -0
- package/build/dataviews-layouts/grid/density-picker.js.map +1 -0
- package/build/{layouts → dataviews-layouts}/grid/index.js +9 -9
- package/build/dataviews-layouts/grid/index.js.map +1 -0
- package/build/dataviews-layouts/index.js.map +1 -0
- package/build/{layouts → dataviews-layouts}/list/index.js +6 -2
- package/build/dataviews-layouts/list/index.js.map +1 -0
- package/build/{layouts → dataviews-layouts}/table/column-header-menu.js +3 -6
- package/build/dataviews-layouts/table/column-header-menu.js.map +1 -0
- package/build/dataviews-layouts/table/index.js.map +1 -0
- package/build/field-types/datetime.js +30 -0
- package/build/field-types/datetime.js.map +1 -0
- package/build/field-types/index.js +50 -0
- package/build/field-types/index.js.map +1 -0
- package/build/field-types/integer.js +35 -0
- package/build/field-types/integer.js.map +1 -0
- package/build/field-types/text.js +28 -0
- package/build/field-types/text.js.map +1 -0
- package/build/filter-and-sort-data-view.js +2 -11
- package/build/filter-and-sort-data-view.js.map +1 -1
- package/build/index.js +9 -2
- package/build/index.js.map +1 -1
- package/build/normalize-fields.js +34 -1
- package/build/normalize-fields.js.map +1 -1
- package/build/types.js.map +1 -1
- package/build/validation.js +22 -0
- package/build/validation.js.map +1 -0
- package/build-module/components/dataform/index.js +10 -61
- package/build-module/components/dataform/index.js.map +1 -1
- package/build-module/components/dataviews/index.js +21 -14
- package/build-module/components/dataviews/index.js.map +1 -1
- package/build-module/components/dataviews-bulk-actions/index.js +3 -0
- package/build-module/components/dataviews-bulk-actions/index.js.map +1 -1
- package/build-module/components/dataviews-filters/add-filter.js +33 -17
- package/build-module/components/dataviews-filters/add-filter.js.map +1 -1
- package/build-module/components/dataviews-filters/index.js +108 -45
- package/build-module/components/dataviews-filters/index.js.map +1 -1
- package/build-module/components/dataviews-filters/search-widget.js +2 -5
- package/build-module/components/dataviews-filters/search-widget.js.map +1 -1
- package/build-module/components/dataviews-layout/index.js +1 -1
- package/build-module/components/dataviews-layout/index.js.map +1 -1
- package/build-module/components/dataviews-pagination/index.js +23 -15
- package/build-module/components/dataviews-pagination/index.js.map +1 -1
- package/build-module/components/dataviews-search/index.js +8 -5
- package/build-module/components/dataviews-search/index.js.map +1 -1
- package/build-module/components/dataviews-view-config/index.js +243 -191
- package/build-module/components/dataviews-view-config/index.js.map +1 -1
- package/build-module/constants.js +5 -0
- package/build-module/constants.js.map +1 -1
- package/build-module/dataform-controls/datetime.js +43 -0
- package/build-module/dataform-controls/datetime.js.map +1 -0
- package/build-module/dataform-controls/index.js +42 -0
- package/build-module/dataform-controls/index.js.map +1 -0
- package/build-module/dataform-controls/integer.js +38 -0
- package/build-module/dataform-controls/integer.js.map +1 -0
- package/build-module/dataform-controls/radio.js +38 -0
- package/build-module/dataform-controls/radio.js.map +1 -0
- package/build-module/dataform-controls/select.js +51 -0
- package/build-module/dataform-controls/select.js.map +1 -0
- package/build-module/dataform-controls/text.js +38 -0
- package/build-module/dataform-controls/text.js.map +1 -0
- package/build-module/dataforms-layouts/index.js +16 -0
- package/build-module/dataforms-layouts/index.js.map +1 -0
- package/build-module/dataforms-layouts/panel/index.js +127 -0
- package/build-module/dataforms-layouts/panel/index.js.map +1 -0
- package/build-module/dataforms-layouts/regular/index.js +35 -0
- package/build-module/dataforms-layouts/regular/index.js.map +1 -0
- package/build-module/dataviews-layouts/grid/density-picker.js +107 -0
- package/build-module/dataviews-layouts/grid/density-picker.js.map +1 -0
- package/build-module/{layouts → dataviews-layouts}/grid/index.js +9 -9
- package/build-module/dataviews-layouts/grid/index.js.map +1 -0
- package/build-module/dataviews-layouts/index.js.map +1 -0
- package/build-module/{layouts → dataviews-layouts}/list/index.js +5 -2
- package/build-module/dataviews-layouts/list/index.js.map +1 -0
- package/build-module/{layouts → dataviews-layouts}/table/column-header-menu.js +3 -6
- package/build-module/dataviews-layouts/table/column-header-menu.js.map +1 -0
- package/build-module/dataviews-layouts/table/index.js.map +1 -0
- package/build-module/field-types/datetime.js +24 -0
- package/build-module/field-types/datetime.js.map +1 -0
- package/build-module/field-types/index.js +44 -0
- package/build-module/field-types/index.js.map +1 -0
- package/build-module/field-types/integer.js +29 -0
- package/build-module/field-types/integer.js.map +1 -0
- package/build-module/field-types/text.js +22 -0
- package/build-module/field-types/text.js.map +1 -0
- package/build-module/filter-and-sort-data-view.js +2 -11
- package/build-module/filter-and-sort-data-view.js.map +1 -1
- package/build-module/index.js +2 -1
- package/build-module/index.js.map +1 -1
- package/build-module/normalize-fields.js +33 -1
- package/build-module/normalize-fields.js.map +1 -1
- package/build-module/types.js.map +1 -1
- package/build-module/validation.js +15 -0
- package/build-module/validation.js.map +1 -0
- package/build-style/style-rtl.css +186 -20
- package/build-style/style.css +186 -20
- package/build-types/components/dataform/index.d.ts +2 -13
- package/build-types/components/dataform/index.d.ts.map +1 -1
- package/build-types/components/dataform/stories/index.story.d.ts +12 -1
- package/build-types/components/dataform/stories/index.story.d.ts.map +1 -1
- package/build-types/components/dataviews/index.d.ts.map +1 -1
- package/build-types/components/dataviews/stories/fixtures.d.ts +25 -0
- package/build-types/components/dataviews/stories/fixtures.d.ts.map +1 -1
- package/build-types/components/dataviews/stories/index.story.d.ts +9 -0
- package/build-types/components/dataviews/stories/index.story.d.ts.map +1 -1
- package/build-types/components/dataviews-bulk-actions/index.d.ts.map +1 -1
- package/build-types/components/dataviews-filters/add-filter.d.ts +3 -0
- package/build-types/components/dataviews-filters/add-filter.d.ts.map +1 -1
- package/build-types/components/dataviews-filters/index.d.ts +11 -1
- package/build-types/components/dataviews-filters/index.d.ts.map +1 -1
- package/build-types/components/dataviews-filters/search-widget.d.ts.map +1 -1
- package/build-types/components/dataviews-pagination/index.d.ts.map +1 -1
- package/build-types/components/dataviews-search/index.d.ts.map +1 -1
- package/build-types/components/dataviews-view-config/index.d.ts +4 -3
- package/build-types/components/dataviews-view-config/index.d.ts.map +1 -1
- package/build-types/constants.d.ts +4 -0
- package/build-types/constants.d.ts.map +1 -1
- package/build-types/dataform-controls/datetime.d.ts +6 -0
- package/build-types/dataform-controls/datetime.d.ts.map +1 -0
- package/build-types/dataform-controls/index.d.ts +11 -0
- package/build-types/dataform-controls/index.d.ts.map +1 -0
- package/build-types/dataform-controls/integer.d.ts +6 -0
- package/build-types/dataform-controls/integer.d.ts.map +1 -0
- package/build-types/dataform-controls/radio.d.ts +6 -0
- package/build-types/dataform-controls/radio.d.ts.map +1 -0
- package/build-types/dataform-controls/select.d.ts +6 -0
- package/build-types/dataform-controls/select.d.ts.map +1 -0
- package/build-types/dataform-controls/text.d.ts +6 -0
- package/build-types/dataform-controls/text.d.ts.map +1 -0
- package/build-types/dataforms-layouts/index.d.ts +9 -0
- package/build-types/dataforms-layouts/index.d.ts.map +1 -0
- package/build-types/dataforms-layouts/panel/index.d.ts +3 -0
- package/build-types/dataforms-layouts/panel/index.d.ts.map +1 -0
- package/build-types/dataforms-layouts/regular/index.d.ts +3 -0
- package/build-types/dataforms-layouts/regular/index.d.ts.map +1 -0
- package/build-types/dataviews-layouts/grid/density-picker.d.ts.map +1 -0
- package/build-types/dataviews-layouts/grid/index.d.ts.map +1 -0
- package/build-types/dataviews-layouts/index.d.ts.map +1 -0
- package/build-types/dataviews-layouts/list/index.d.ts.map +1 -0
- package/build-types/dataviews-layouts/table/column-header-menu.d.ts.map +1 -0
- package/build-types/dataviews-layouts/table/index.d.ts.map +1 -0
- package/build-types/field-types/datetime.d.ts +13 -0
- package/build-types/field-types/datetime.d.ts.map +1 -0
- package/build-types/field-types/index.d.ts +20 -0
- package/build-types/field-types/index.d.ts.map +1 -0
- package/build-types/field-types/integer.d.ts +13 -0
- package/build-types/field-types/integer.d.ts.map +1 -0
- package/build-types/field-types/text.d.ts +13 -0
- package/build-types/field-types/text.d.ts.map +1 -0
- package/build-types/filter-and-sort-data-view.d.ts.map +1 -1
- package/build-types/index.d.ts +2 -1
- package/build-types/index.d.ts.map +1 -1
- package/build-types/normalize-fields.d.ts +0 -3
- package/build-types/normalize-fields.d.ts.map +1 -1
- package/build-types/types.d.ts +73 -18
- package/build-types/types.d.ts.map +1 -1
- package/build-types/validation.d.ts +3 -0
- package/build-types/validation.d.ts.map +1 -0
- package/package.json +12 -11
- package/src/components/dataform/index.tsx +8 -97
- package/src/components/dataform/stories/index.story.tsx +82 -4
- package/src/components/dataviews/index.tsx +26 -14
- package/src/components/dataviews/stories/fixtures.js +30 -1
- package/src/components/dataviews/stories/index.story.js +7 -1
- package/src/components/dataviews/style.scss +5 -14
- package/src/components/dataviews-bulk-actions/index.tsx +5 -0
- package/src/components/dataviews-bulk-actions-toolbar/style.scss +1 -1
- package/src/components/dataviews-filters/add-filter.tsx +37 -21
- package/src/components/dataviews-filters/index.tsx +152 -61
- package/src/components/dataviews-filters/search-widget.tsx +1 -8
- package/src/components/dataviews-filters/style.scss +31 -1
- package/src/components/dataviews-layout/index.tsx +1 -1
- package/src/components/dataviews-pagination/index.tsx +35 -16
- package/src/components/dataviews-pagination/style.scss +9 -4
- package/src/components/dataviews-search/index.tsx +8 -5
- package/src/components/dataviews-view-config/index.tsx +300 -257
- package/src/components/dataviews-view-config/style.scss +44 -0
- package/src/constants.ts +5 -0
- package/src/dataform-controls/datetime.tsx +43 -0
- package/src/dataform-controls/index.tsx +61 -0
- package/src/dataform-controls/integer.tsx +38 -0
- package/src/dataform-controls/radio.tsx +42 -0
- package/src/dataform-controls/select.tsx +52 -0
- package/src/dataform-controls/style.scss +4 -0
- package/src/dataform-controls/text.tsx +40 -0
- package/src/dataforms-layouts/index.tsx +20 -0
- package/src/dataforms-layouts/panel/index.tsx +168 -0
- package/src/dataforms-layouts/panel/style.scss +59 -0
- package/src/dataforms-layouts/regular/index.tsx +45 -0
- package/src/dataviews-layouts/grid/density-picker.tsx +102 -0
- package/src/{layouts → dataviews-layouts}/grid/index.tsx +9 -9
- package/src/{layouts → dataviews-layouts}/grid/style.scss +29 -4
- package/src/{layouts → dataviews-layouts}/list/index.tsx +6 -2
- package/src/{layouts → dataviews-layouts}/list/style.scss +4 -1
- package/src/{layouts → dataviews-layouts}/table/column-header-menu.tsx +4 -6
- package/src/field-types/datetime.tsx +28 -0
- package/src/field-types/index.tsx +50 -0
- package/src/field-types/integer.tsx +34 -0
- package/src/field-types/text.tsx +27 -0
- package/src/filter-and-sort-data-view.ts +1 -15
- package/src/index.ts +2 -1
- package/src/normalize-fields.ts +43 -4
- package/src/style.scss +7 -3
- package/src/test/filter-and-sort-data-view.js +74 -3
- package/src/test/validation.ts +131 -0
- package/src/types.ts +92 -23
- package/src/validation.ts +18 -0
- package/tsconfig.json +2 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/build/layouts/grid/density-picker.js +0 -143
- package/build/layouts/grid/density-picker.js.map +0 -1
- package/build/layouts/grid/index.js.map +0 -1
- package/build/layouts/index.js.map +0 -1
- package/build/layouts/list/index.js.map +0 -1
- package/build/layouts/table/column-header-menu.js.map +0 -1
- package/build/layouts/table/index.js.map +0 -1
- package/build-module/layouts/grid/density-picker.js +0 -138
- package/build-module/layouts/grid/density-picker.js.map +0 -1
- package/build-module/layouts/grid/index.js.map +0 -1
- package/build-module/layouts/index.js.map +0 -1
- package/build-module/layouts/list/index.js.map +0 -1
- package/build-module/layouts/table/column-header-menu.js.map +0 -1
- package/build-module/layouts/table/index.js.map +0 -1
- package/build-types/layouts/grid/density-picker.d.ts.map +0 -1
- package/build-types/layouts/grid/index.d.ts.map +0 -1
- package/build-types/layouts/index.d.ts.map +0 -1
- package/build-types/layouts/list/index.d.ts.map +0 -1
- package/build-types/layouts/table/column-header-menu.d.ts.map +0 -1
- package/build-types/layouts/table/index.d.ts.map +0 -1
- package/src/layouts/grid/density-picker.tsx +0 -136
- /package/build/{layouts → dataviews-layouts}/index.js +0 -0
- /package/build/{layouts → dataviews-layouts}/table/index.js +0 -0
- /package/build-module/{layouts → dataviews-layouts}/index.js +0 -0
- /package/build-module/{layouts → dataviews-layouts}/table/index.js +0 -0
- /package/build-types/{layouts → dataviews-layouts}/grid/density-picker.d.ts +0 -0
- /package/build-types/{layouts → dataviews-layouts}/grid/index.d.ts +0 -0
- /package/build-types/{layouts → dataviews-layouts}/index.d.ts +0 -0
- /package/build-types/{layouts → dataviews-layouts}/list/index.d.ts +0 -0
- /package/build-types/{layouts → dataviews-layouts}/table/column-header-menu.d.ts +0 -0
- /package/build-types/{layouts → dataviews-layouts}/table/index.d.ts +0 -0
- /package/src/{layouts → dataviews-layouts}/index.ts +0 -0
- /package/src/{layouts → dataviews-layouts}/table/index.tsx +0 -0
- /package/src/{layouts → dataviews-layouts}/table/style.scss +0 -0
package/src/types.ts
CHANGED
|
@@ -42,9 +42,31 @@ export type Operator =
|
|
|
42
42
|
| 'isAll'
|
|
43
43
|
| 'isNotAll';
|
|
44
44
|
|
|
45
|
-
export type
|
|
45
|
+
export type FieldType = 'text' | 'integer' | 'datetime';
|
|
46
46
|
|
|
47
|
-
export type
|
|
47
|
+
export type ValidationContext = {
|
|
48
|
+
elements?: Option[];
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* An abstract interface for Field based on the field type.
|
|
53
|
+
*/
|
|
54
|
+
export type FieldTypeDefinition< Item > = {
|
|
55
|
+
/**
|
|
56
|
+
* Callback used to sort the field.
|
|
57
|
+
*/
|
|
58
|
+
sort: ( a: Item, b: Item, direction: SortDirection ) => number;
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Callback used to validate the field.
|
|
62
|
+
*/
|
|
63
|
+
isValid: ( item: Item, context?: ValidationContext ) => boolean;
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Callback used to render an edit control for the field or control name.
|
|
67
|
+
*/
|
|
68
|
+
Edit: ComponentType< DataFormControlProps< Item > > | string;
|
|
69
|
+
};
|
|
48
70
|
|
|
49
71
|
/**
|
|
50
72
|
* A dataview field for a specific property of a data type.
|
|
@@ -65,6 +87,17 @@ export type Field< Item > = {
|
|
|
65
87
|
*/
|
|
66
88
|
label?: string;
|
|
67
89
|
|
|
90
|
+
/**
|
|
91
|
+
* The header of the field. Defaults to the label.
|
|
92
|
+
* It allows the usage of a React Element to render the field labels.
|
|
93
|
+
*/
|
|
94
|
+
header?: string | ReactElement;
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* A description of the field.
|
|
98
|
+
*/
|
|
99
|
+
description?: string;
|
|
100
|
+
|
|
68
101
|
/**
|
|
69
102
|
* Placeholder for the field.
|
|
70
103
|
*/
|
|
@@ -75,6 +108,21 @@ export type Field< Item > = {
|
|
|
75
108
|
*/
|
|
76
109
|
render?: ComponentType< { item: Item } >;
|
|
77
110
|
|
|
111
|
+
/**
|
|
112
|
+
* Callback used to render an edit control for the field.
|
|
113
|
+
*/
|
|
114
|
+
Edit?: ComponentType< DataFormControlProps< Item > > | string;
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Callback used to sort the field.
|
|
118
|
+
*/
|
|
119
|
+
sort?: ( a: Item, b: Item, direction: SortDirection ) => number;
|
|
120
|
+
|
|
121
|
+
/**
|
|
122
|
+
* Callback used to validate the field.
|
|
123
|
+
*/
|
|
124
|
+
isValid?: ( item: Item, context?: ValidationContext ) => boolean;
|
|
125
|
+
|
|
78
126
|
/**
|
|
79
127
|
* Whether the field is sortable.
|
|
80
128
|
*/
|
|
@@ -99,26 +147,22 @@ export type Field< Item > = {
|
|
|
99
147
|
* Filter config for the field.
|
|
100
148
|
*/
|
|
101
149
|
filterBy?: FilterByConfig | undefined;
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
}
|
|
110
|
-
: {
|
|
111
|
-
/**
|
|
112
|
-
* Callback used to retrieve the value of the field from the item.
|
|
113
|
-
* Defaults to `item[ field.id ]`.
|
|
114
|
-
*/
|
|
115
|
-
getValue: ( args: { item: Item } ) => any;
|
|
116
|
-
} );
|
|
150
|
+
|
|
151
|
+
/**
|
|
152
|
+
* Callback used to retrieve the value of the field from the item.
|
|
153
|
+
* Defaults to `item[ field.id ]`.
|
|
154
|
+
*/
|
|
155
|
+
getValue?: ( args: { item: Item } ) => any;
|
|
156
|
+
};
|
|
117
157
|
|
|
118
158
|
export type NormalizedField< Item > = Field< Item > & {
|
|
119
159
|
label: string;
|
|
160
|
+
header: string | ReactElement;
|
|
120
161
|
getValue: ( args: { item: Item } ) => any;
|
|
121
162
|
render: ComponentType< { item: Item } >;
|
|
163
|
+
Edit: ComponentType< DataFormControlProps< Item > >;
|
|
164
|
+
sort: ( a: Item, b: Item, direction: SortDirection ) => number;
|
|
165
|
+
isValid: ( item: Item, context?: ValidationContext ) => boolean;
|
|
122
166
|
};
|
|
123
167
|
|
|
124
168
|
/**
|
|
@@ -132,7 +176,15 @@ export type Data< Item > = Item[];
|
|
|
132
176
|
* The form configuration.
|
|
133
177
|
*/
|
|
134
178
|
export type Form = {
|
|
135
|
-
|
|
179
|
+
type?: 'regular' | 'panel';
|
|
180
|
+
fields?: string[];
|
|
181
|
+
};
|
|
182
|
+
|
|
183
|
+
export type DataFormControlProps< Item > = {
|
|
184
|
+
data: Item;
|
|
185
|
+
field: NormalizedField< Item >;
|
|
186
|
+
onChange: ( value: Record< string, any > ) => void;
|
|
187
|
+
hideLabelFromVision?: boolean;
|
|
136
188
|
};
|
|
137
189
|
|
|
138
190
|
/**
|
|
@@ -244,6 +296,8 @@ export interface CombinedField {
|
|
|
244
296
|
|
|
245
297
|
label: string;
|
|
246
298
|
|
|
299
|
+
header?: string | ReactElement;
|
|
300
|
+
|
|
247
301
|
/**
|
|
248
302
|
* The fields to use as columns.
|
|
249
303
|
*/
|
|
@@ -381,6 +435,18 @@ interface ActionBase< Item > {
|
|
|
381
435
|
* Whether the action can be used as a bulk action.
|
|
382
436
|
*/
|
|
383
437
|
supportsBulk?: boolean;
|
|
438
|
+
|
|
439
|
+
/**
|
|
440
|
+
* The context in which the action is visible.
|
|
441
|
+
* This is only a "meta" information for now.
|
|
442
|
+
*/
|
|
443
|
+
context?: 'list' | 'single';
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
export interface RenderModalProps< Item > {
|
|
447
|
+
items: Item[];
|
|
448
|
+
closeModal?: () => void;
|
|
449
|
+
onActionPerformed?: ( items: Item[] ) => void;
|
|
384
450
|
}
|
|
385
451
|
|
|
386
452
|
export interface ActionModal< Item > extends ActionBase< Item > {
|
|
@@ -391,11 +457,7 @@ export interface ActionModal< Item > extends ActionBase< Item > {
|
|
|
391
457
|
items,
|
|
392
458
|
closeModal,
|
|
393
459
|
onActionPerformed,
|
|
394
|
-
}:
|
|
395
|
-
items: Item[];
|
|
396
|
-
closeModal?: () => void;
|
|
397
|
-
onActionPerformed?: ( items: Item[] ) => void;
|
|
398
|
-
} ) => ReactElement;
|
|
460
|
+
}: RenderModalProps< Item > ) => ReactElement;
|
|
399
461
|
|
|
400
462
|
/**
|
|
401
463
|
* Whether to hide the modal header.
|
|
@@ -459,3 +521,10 @@ export interface SupportedLayouts {
|
|
|
459
521
|
grid?: Omit< ViewGrid, 'type' >;
|
|
460
522
|
table?: Omit< ViewTable, 'type' >;
|
|
461
523
|
}
|
|
524
|
+
|
|
525
|
+
export interface DataFormProps< Item > {
|
|
526
|
+
data: Item;
|
|
527
|
+
fields: Field< Item >[];
|
|
528
|
+
form: Form;
|
|
529
|
+
onChange: ( value: Record< string, any > ) => void;
|
|
530
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Internal dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { normalizeFields } from './normalize-fields';
|
|
5
|
+
import type { Field, Form } from './types';
|
|
6
|
+
|
|
7
|
+
export function isItemValid< Item >(
|
|
8
|
+
item: Item,
|
|
9
|
+
fields: Field< Item >[],
|
|
10
|
+
form: Form
|
|
11
|
+
): boolean {
|
|
12
|
+
const _fields = normalizeFields(
|
|
13
|
+
fields.filter( ( { id } ) => !! form.fields?.includes( id ) )
|
|
14
|
+
);
|
|
15
|
+
return _fields.every( ( field ) => {
|
|
16
|
+
return field.isValid( item, { elements: field.elements } );
|
|
17
|
+
} );
|
|
18
|
+
}
|