@wordpress/dataviews 10.2.0 → 10.3.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 +25 -0
- package/README.md +108 -1
- package/build/components/dataform/index.js +6 -2
- package/build/components/dataform/index.js.map +3 -3
- package/build/components/dataform-context/index.js +4 -2
- package/build/components/dataform-context/index.js.map +1 -1
- package/build/components/dataviews/index.js +8 -6
- package/build/components/dataviews/index.js.map +1 -1
- package/build/components/dataviews-bulk-actions/index.js +4 -2
- package/build/components/dataviews-bulk-actions/index.js.map +1 -1
- package/build/components/dataviews-context/index.js +3 -1
- package/build/components/dataviews-context/index.js.map +1 -1
- package/build/components/dataviews-filters/add-filter.js +4 -2
- package/build/components/dataviews-filters/add-filter.js.map +1 -1
- package/build/components/dataviews-filters/filter.js +20 -5
- package/build/components/dataviews-filters/filter.js.map +3 -3
- package/build/components/dataviews-filters/filters-toggled.js +3 -1
- package/build/components/dataviews-filters/filters-toggled.js.map +1 -1
- package/build/components/dataviews-filters/filters.js +3 -1
- package/build/components/dataviews-filters/filters.js.map +1 -1
- package/build/components/dataviews-filters/index.js +2 -0
- package/build/components/dataviews-filters/index.js.map +1 -1
- package/build/components/dataviews-filters/input-widget.js +3 -1
- package/build/components/dataviews-filters/input-widget.js.map +1 -1
- package/build/components/dataviews-filters/reset-filters.js +3 -1
- package/build/components/dataviews-filters/reset-filters.js.map +1 -1
- package/build/components/dataviews-filters/search-widget.js +8 -6
- package/build/components/dataviews-filters/search-widget.js.map +2 -2
- package/build/components/dataviews-filters/toggle.js +3 -1
- package/build/components/dataviews-filters/toggle.js.map +1 -1
- package/build/components/dataviews-filters/use-filters.js +2 -0
- package/build/components/dataviews-filters/use-filters.js.map +1 -1
- package/build/components/dataviews-filters/utils.js +4 -2
- package/build/components/dataviews-filters/utils.js.map +1 -1
- package/build/components/dataviews-footer/index.js +4 -2
- package/build/components/dataviews-footer/index.js.map +1 -1
- package/build/components/dataviews-item-actions/index.js +23 -4
- package/build/components/dataviews-item-actions/index.js.map +2 -2
- package/build/components/dataviews-layout/index.js +3 -1
- package/build/components/dataviews-layout/index.js.map +1 -1
- package/build/components/dataviews-pagination/index.js +3 -1
- package/build/components/dataviews-pagination/index.js.map +1 -1
- package/build/components/dataviews-picker/footer.js +4 -2
- package/build/components/dataviews-picker/footer.js.map +1 -1
- package/build/components/dataviews-picker/index.js +8 -6
- package/build/components/dataviews-picker/index.js.map +1 -1
- package/build/components/dataviews-search/index.js +4 -2
- package/build/components/dataviews-search/index.js.map +1 -1
- package/build/components/dataviews-selection-checkbox/index.js +3 -1
- package/build/components/dataviews-selection-checkbox/index.js.map +1 -1
- package/build/components/dataviews-view-config/index.js +17 -400
- package/build/components/dataviews-view-config/index.js.map +3 -3
- package/build/components/dataviews-view-config/infinite-scroll-toggle.js +3 -1
- package/build/components/dataviews-view-config/infinite-scroll-toggle.js.map +1 -1
- package/build/components/dataviews-view-config/properties-section.js +177 -0
- package/build/components/dataviews-view-config/properties-section.js.map +7 -0
- package/build/constants.js +39 -34
- package/build/constants.js.map +2 -2
- package/build/dataform-controls/array.js +4 -2
- package/build/dataform-controls/array.js.map +1 -1
- package/build/dataform-controls/checkbox.js +4 -2
- package/build/dataform-controls/checkbox.js.map +1 -1
- package/build/dataform-controls/color.js +5 -3
- package/build/dataform-controls/color.js.map +1 -1
- package/build/dataform-controls/date.js +8 -6
- package/build/dataform-controls/date.js.map +1 -1
- package/build/dataform-controls/datetime.js +11 -15
- package/build/dataform-controls/datetime.js.map +3 -3
- package/build/dataform-controls/email.js +3 -1
- package/build/dataform-controls/email.js.map +1 -1
- package/build/dataform-controls/index.js +4 -2
- package/build/dataform-controls/index.js.map +1 -1
- package/build/dataform-controls/integer.js +3 -1
- package/build/dataform-controls/integer.js.map +1 -1
- package/build/dataform-controls/number.js +3 -1
- package/build/dataform-controls/number.js.map +1 -1
- package/build/dataform-controls/password.js +3 -1
- package/build/dataform-controls/password.js.map +1 -1
- package/build/dataform-controls/radio.js +4 -2
- package/build/dataform-controls/radio.js.map +1 -1
- package/build/dataform-controls/select.js +4 -2
- package/build/dataform-controls/select.js.map +1 -1
- package/build/dataform-controls/telephone.js +3 -1
- package/build/dataform-controls/telephone.js.map +1 -1
- package/build/dataform-controls/text.js +3 -1
- package/build/dataform-controls/text.js.map +1 -1
- package/build/dataform-controls/textarea.js +4 -2
- package/build/dataform-controls/textarea.js.map +1 -1
- package/build/dataform-controls/toggle-group.js +4 -2
- package/build/dataform-controls/toggle-group.js.map +1 -1
- package/build/dataform-controls/toggle.js +4 -2
- package/build/dataform-controls/toggle.js.map +1 -1
- package/build/dataform-controls/url.js +3 -1
- package/build/dataform-controls/url.js.map +1 -1
- package/build/dataform-controls/utils/get-custom-validity.js +2 -0
- package/build/dataform-controls/utils/get-custom-validity.js.map +1 -1
- package/build/dataform-controls/utils/relative-date-control.js +4 -2
- package/build/dataform-controls/utils/relative-date-control.js.map +1 -1
- package/build/dataform-controls/utils/validated-input.js +4 -2
- package/build/dataform-controls/utils/validated-input.js.map +1 -1
- package/build/dataform-controls/utils/validated-number.js +4 -2
- package/build/dataform-controls/utils/validated-number.js.map +1 -1
- package/build/dataform-layouts/card/index.js +65 -34
- package/build/dataform-layouts/card/index.js.map +3 -3
- package/build/dataform-layouts/data-form-layout.js +8 -14
- package/build/dataform-layouts/data-form-layout.js.map +3 -3
- package/build/dataform-layouts/details/index.js +78 -0
- package/build/dataform-layouts/details/index.js.map +7 -0
- package/build/dataform-layouts/get-summary-fields.js +3 -1
- package/build/dataform-layouts/get-summary-fields.js.map +1 -1
- package/build/dataform-layouts/index.js +9 -2
- package/build/dataform-layouts/index.js.map +3 -3
- package/build/dataform-layouts/{normalize-form-fields.js → normalize-form.js} +44 -22
- package/build/dataform-layouts/normalize-form.js.map +7 -0
- package/build/dataform-layouts/panel/dropdown.js +9 -8
- package/build/dataform-layouts/panel/dropdown.js.map +2 -2
- package/build/dataform-layouts/panel/index.js +10 -14
- package/build/dataform-layouts/panel/index.js.map +2 -2
- package/build/dataform-layouts/panel/modal.js +9 -8
- package/build/dataform-layouts/panel/modal.js.map +2 -2
- package/build/dataform-layouts/panel/summary-button.js +3 -1
- package/build/dataform-layouts/panel/summary-button.js.map +1 -1
- package/build/dataform-layouts/regular/index.js +8 -10
- package/build/dataform-layouts/regular/index.js.map +2 -2
- package/build/dataform-layouts/row/index.js +10 -33
- package/build/dataform-layouts/row/index.js.map +3 -3
- package/build/dataviews-layouts/grid/index.js +4 -2
- package/build/dataviews-layouts/grid/index.js.map +1 -1
- package/build/dataviews-layouts/grid/preview-size-picker.js +4 -2
- package/build/dataviews-layouts/grid/preview-size-picker.js.map +1 -1
- package/build/dataviews-layouts/index.js +12 -1
- package/build/dataviews-layouts/index.js.map +3 -3
- package/build/dataviews-layouts/list/index.js +6 -6
- package/build/dataviews-layouts/list/index.js.map +2 -2
- package/build/dataviews-layouts/picker-grid/index.js +4 -2
- package/build/dataviews-layouts/picker-grid/index.js.map +1 -1
- package/build/dataviews-layouts/picker-table/index.js +422 -0
- package/build/dataviews-layouts/picker-table/index.js.map +7 -0
- package/build/dataviews-layouts/table/column-header-menu.js +6 -4
- package/build/dataviews-layouts/table/column-header-menu.js.map +2 -2
- package/build/dataviews-layouts/table/column-primary.js +4 -7
- package/build/dataviews-layouts/table/column-primary.js.map +2 -2
- package/build/dataviews-layouts/table/density-picker.js +3 -1
- package/build/dataviews-layouts/table/density-picker.js.map +1 -1
- package/build/dataviews-layouts/table/index.js +48 -2
- package/build/dataviews-layouts/table/index.js.map +2 -2
- package/build/dataviews-layouts/table/use-is-horizontal-scroll-end.js +3 -1
- package/build/dataviews-layouts/table/use-is-horizontal-scroll-end.js.map +1 -1
- package/build/dataviews-layouts/utils/get-data-by-group.js +2 -0
- package/build/dataviews-layouts/utils/get-data-by-group.js.map +1 -1
- package/build/dataviews-layouts/utils/grid-items.js +4 -2
- package/build/dataviews-layouts/utils/grid-items.js.map +1 -1
- package/build/dataviews-layouts/utils/item-click-wrapper.js +3 -1
- package/build/dataviews-layouts/utils/item-click-wrapper.js.map +1 -1
- package/build/dataviews-layouts/utils/preview-size-picker.js +4 -2
- package/build/dataviews-layouts/utils/preview-size-picker.js.map +1 -1
- package/build/field-types/array.js +3 -1
- package/build/field-types/array.js.map +1 -1
- package/build/field-types/boolean.js +3 -1
- package/build/field-types/boolean.js.map +1 -1
- package/build/field-types/color.js +3 -1
- package/build/field-types/color.js.map +1 -1
- package/build/field-types/date.js +4 -2
- package/build/field-types/date.js.map +1 -1
- package/build/field-types/datetime.js +17 -2
- package/build/field-types/datetime.js.map +3 -3
- package/build/field-types/email.js +4 -2
- package/build/field-types/email.js.map +1 -1
- package/build/field-types/index.js +3 -1
- package/build/field-types/index.js.map +1 -1
- package/build/field-types/integer.js +3 -1
- package/build/field-types/integer.js.map +1 -1
- package/build/field-types/media.js +2 -0
- package/build/field-types/media.js.map +1 -1
- package/build/field-types/number.js +3 -1
- package/build/field-types/number.js.map +1 -1
- package/build/field-types/password.js +3 -1
- package/build/field-types/password.js.map +1 -1
- package/build/field-types/telephone.js +3 -1
- package/build/field-types/telephone.js.map +1 -1
- package/build/field-types/text.js +3 -1
- package/build/field-types/text.js.map +1 -1
- package/build/field-types/url.js +3 -1
- package/build/field-types/url.js.map +1 -1
- package/build/{dataform-layouts/is-combined-field.js → field-types/utils/parse-date-time.js} +15 -11
- package/build/field-types/utils/parse-date-time.js.map +7 -0
- package/build/field-types/utils/render-from-elements.js +2 -0
- package/build/field-types/utils/render-from-elements.js.map +1 -1
- package/build/hooks/index.js +2 -0
- package/build/hooks/index.js.map +1 -1
- package/build/hooks/use-elements.js +3 -1
- package/build/hooks/use-elements.js.map +1 -1
- package/build/hooks/use-form-validity.js +425 -321
- package/build/hooks/use-form-validity.js.map +3 -3
- package/build/index.js +2 -0
- package/build/index.js.map +1 -1
- package/build/lock-unlock.js +3 -1
- package/build/lock-unlock.js.map +1 -1
- package/build/types/dataform.js +2 -0
- package/build/types/dataform.js.map +2 -2
- package/build/types/dataviews.js +2 -0
- package/build/types/dataviews.js.map +2 -2
- package/build/types/field-api.js +2 -0
- package/build/types/field-api.js.map +1 -1
- package/build/types/index.js +2 -0
- package/build/types/index.js.map +1 -1
- package/build/types/private.js +2 -0
- package/build/types/private.js.map +1 -1
- package/build/utils/filter-sort-and-paginate.js +3 -1
- package/build/utils/filter-sort-and-paginate.js.map +1 -1
- package/build/utils/has-elements.js +2 -0
- package/build/utils/has-elements.js.map +1 -1
- package/build/utils/normalize-fields.js +4 -2
- package/build/utils/normalize-fields.js.map +1 -1
- package/build-module/components/dataform/index.js +5 -2
- package/build-module/components/dataform/index.js.map +2 -2
- package/build-module/components/dataform-context/index.js +3 -2
- package/build-module/components/dataform-context/index.js.map +1 -1
- package/build-module/components/dataviews/index.js +7 -6
- package/build-module/components/dataviews/index.js.map +1 -1
- package/build-module/components/dataviews-bulk-actions/index.js +3 -2
- package/build-module/components/dataviews-bulk-actions/index.js.map +1 -1
- package/build-module/components/dataviews-context/index.js +2 -1
- package/build-module/components/dataviews-context/index.js.map +1 -1
- package/build-module/components/dataviews-filters/add-filter.js +3 -2
- package/build-module/components/dataviews-filters/add-filter.js.map +1 -1
- package/build-module/components/dataviews-filters/filter.js +19 -5
- package/build-module/components/dataviews-filters/filter.js.map +2 -2
- package/build-module/components/dataviews-filters/filters-toggled.js +2 -1
- package/build-module/components/dataviews-filters/filters-toggled.js.map +1 -1
- package/build-module/components/dataviews-filters/filters.js +2 -1
- package/build-module/components/dataviews-filters/filters.js.map +1 -1
- package/build-module/components/dataviews-filters/index.js +1 -0
- package/build-module/components/dataviews-filters/index.js.map +1 -1
- package/build-module/components/dataviews-filters/input-widget.js +2 -1
- package/build-module/components/dataviews-filters/input-widget.js.map +1 -1
- package/build-module/components/dataviews-filters/reset-filters.js +2 -1
- package/build-module/components/dataviews-filters/reset-filters.js.map +1 -1
- package/build-module/components/dataviews-filters/search-widget.js +7 -6
- package/build-module/components/dataviews-filters/search-widget.js.map +2 -2
- package/build-module/components/dataviews-filters/toggle.js +2 -1
- package/build-module/components/dataviews-filters/toggle.js.map +1 -1
- package/build-module/components/dataviews-filters/use-filters.js +1 -0
- package/build-module/components/dataviews-filters/use-filters.js.map +1 -1
- package/build-module/components/dataviews-filters/utils.js +3 -2
- package/build-module/components/dataviews-filters/utils.js.map +1 -1
- package/build-module/components/dataviews-footer/index.js +3 -2
- package/build-module/components/dataviews-footer/index.js.map +1 -1
- package/build-module/components/dataviews-item-actions/index.js +22 -4
- package/build-module/components/dataviews-item-actions/index.js.map +2 -2
- package/build-module/components/dataviews-layout/index.js +2 -1
- package/build-module/components/dataviews-layout/index.js.map +1 -1
- package/build-module/components/dataviews-pagination/index.js +2 -1
- package/build-module/components/dataviews-pagination/index.js.map +1 -1
- package/build-module/components/dataviews-picker/footer.js +3 -2
- package/build-module/components/dataviews-picker/footer.js.map +1 -1
- package/build-module/components/dataviews-picker/index.js +7 -6
- package/build-module/components/dataviews-picker/index.js.map +1 -1
- package/build-module/components/dataviews-search/index.js +3 -2
- package/build-module/components/dataviews-search/index.js.map +1 -1
- package/build-module/components/dataviews-selection-checkbox/index.js +2 -1
- package/build-module/components/dataviews-selection-checkbox/index.js.map +1 -1
- package/build-module/components/dataviews-view-config/index.js +20 -416
- package/build-module/components/dataviews-view-config/index.js.map +2 -2
- package/build-module/components/dataviews-view-config/infinite-scroll-toggle.js +2 -1
- package/build-module/components/dataviews-view-config/infinite-scroll-toggle.js.map +1 -1
- package/build-module/components/dataviews-view-config/properties-section.js +149 -0
- package/build-module/components/dataviews-view-config/properties-section.js.map +7 -0
- package/build-module/constants.js +37 -34
- package/build-module/constants.js.map +2 -2
- package/build-module/dataform-controls/array.js +3 -2
- package/build-module/dataform-controls/array.js.map +1 -1
- package/build-module/dataform-controls/checkbox.js +3 -2
- package/build-module/dataform-controls/checkbox.js.map +1 -1
- package/build-module/dataform-controls/color.js +4 -3
- package/build-module/dataform-controls/color.js.map +1 -1
- package/build-module/dataform-controls/date.js +7 -6
- package/build-module/dataform-controls/date.js.map +1 -1
- package/build-module/dataform-controls/datetime.js +7 -12
- package/build-module/dataform-controls/datetime.js.map +2 -2
- package/build-module/dataform-controls/email.js +2 -1
- package/build-module/dataform-controls/email.js.map +1 -1
- package/build-module/dataform-controls/index.js +3 -2
- package/build-module/dataform-controls/index.js.map +1 -1
- package/build-module/dataform-controls/integer.js +2 -1
- package/build-module/dataform-controls/integer.js.map +1 -1
- package/build-module/dataform-controls/number.js +2 -1
- package/build-module/dataform-controls/number.js.map +1 -1
- package/build-module/dataform-controls/password.js +2 -1
- package/build-module/dataform-controls/password.js.map +1 -1
- package/build-module/dataform-controls/radio.js +3 -2
- package/build-module/dataform-controls/radio.js.map +1 -1
- package/build-module/dataform-controls/select.js +3 -2
- package/build-module/dataform-controls/select.js.map +1 -1
- package/build-module/dataform-controls/telephone.js +2 -1
- package/build-module/dataform-controls/telephone.js.map +1 -1
- package/build-module/dataform-controls/text.js +2 -1
- package/build-module/dataform-controls/text.js.map +1 -1
- package/build-module/dataform-controls/textarea.js +3 -2
- package/build-module/dataform-controls/textarea.js.map +1 -1
- package/build-module/dataform-controls/toggle-group.js +3 -2
- package/build-module/dataform-controls/toggle-group.js.map +1 -1
- package/build-module/dataform-controls/toggle.js +3 -2
- package/build-module/dataform-controls/toggle.js.map +1 -1
- package/build-module/dataform-controls/url.js +2 -1
- package/build-module/dataform-controls/url.js.map +1 -1
- package/build-module/dataform-controls/utils/get-custom-validity.js +1 -0
- package/build-module/dataform-controls/utils/get-custom-validity.js.map +1 -1
- package/build-module/dataform-controls/utils/relative-date-control.js +3 -2
- package/build-module/dataform-controls/utils/relative-date-control.js.map +1 -1
- package/build-module/dataform-controls/utils/validated-input.js +3 -2
- package/build-module/dataform-controls/utils/validated-input.js.map +1 -1
- package/build-module/dataform-controls/utils/validated-number.js +3 -2
- package/build-module/dataform-controls/utils/validated-number.js.map +1 -1
- package/build-module/dataform-layouts/card/index.js +63 -33
- package/build-module/dataform-layouts/card/index.js.map +3 -3
- package/build-module/dataform-layouts/data-form-layout.js +8 -15
- package/build-module/dataform-layouts/data-form-layout.js.map +2 -2
- package/build-module/dataform-layouts/details/index.js +47 -0
- package/build-module/dataform-layouts/details/index.js.map +7 -0
- package/build-module/dataform-layouts/get-summary-fields.js +2 -1
- package/build-module/dataform-layouts/get-summary-fields.js.map +1 -1
- package/build-module/dataform-layouts/index.js +8 -2
- package/build-module/dataform-layouts/index.js.map +2 -2
- package/build-module/dataform-layouts/{normalize-form-fields.js → normalize-form.js} +39 -17
- package/build-module/dataform-layouts/normalize-form.js.map +7 -0
- package/build-module/dataform-layouts/panel/dropdown.js +7 -7
- package/build-module/dataform-layouts/panel/dropdown.js.map +2 -2
- package/build-module/dataform-layouts/panel/index.js +9 -14
- package/build-module/dataform-layouts/panel/index.js.map +2 -2
- package/build-module/dataform-layouts/panel/modal.js +7 -7
- package/build-module/dataform-layouts/panel/modal.js.map +2 -2
- package/build-module/dataform-layouts/panel/summary-button.js +2 -1
- package/build-module/dataform-layouts/panel/summary-button.js.map +1 -1
- package/build-module/dataform-layouts/regular/index.js +6 -9
- package/build-module/dataform-layouts/regular/index.js.map +2 -2
- package/build-module/dataform-layouts/row/index.js +9 -23
- package/build-module/dataform-layouts/row/index.js.map +2 -2
- package/build-module/dataviews-layouts/grid/index.js +3 -2
- package/build-module/dataviews-layouts/grid/index.js.map +1 -1
- package/build-module/dataviews-layouts/grid/preview-size-picker.js +3 -2
- package/build-module/dataviews-layouts/grid/preview-size-picker.js.map +1 -1
- package/build-module/dataviews-layouts/index.js +13 -2
- package/build-module/dataviews-layouts/index.js.map +2 -2
- package/build-module/dataviews-layouts/list/index.js +5 -6
- package/build-module/dataviews-layouts/list/index.js.map +2 -2
- package/build-module/dataviews-layouts/picker-grid/index.js +3 -2
- package/build-module/dataviews-layouts/picker-grid/index.js.map +1 -1
- package/build-module/dataviews-layouts/picker-table/index.js +397 -0
- package/build-module/dataviews-layouts/picker-table/index.js.map +7 -0
- package/build-module/dataviews-layouts/table/column-header-menu.js +5 -4
- package/build-module/dataviews-layouts/table/column-header-menu.js.map +2 -2
- package/build-module/dataviews-layouts/table/column-primary.js +3 -7
- package/build-module/dataviews-layouts/table/column-primary.js.map +2 -2
- package/build-module/dataviews-layouts/table/density-picker.js +2 -1
- package/build-module/dataviews-layouts/table/density-picker.js.map +1 -1
- package/build-module/dataviews-layouts/table/index.js +48 -3
- package/build-module/dataviews-layouts/table/index.js.map +2 -2
- package/build-module/dataviews-layouts/table/use-is-horizontal-scroll-end.js +2 -1
- package/build-module/dataviews-layouts/table/use-is-horizontal-scroll-end.js.map +1 -1
- package/build-module/dataviews-layouts/utils/get-data-by-group.js +1 -0
- package/build-module/dataviews-layouts/utils/get-data-by-group.js.map +1 -1
- package/build-module/dataviews-layouts/utils/grid-items.js +3 -2
- package/build-module/dataviews-layouts/utils/grid-items.js.map +1 -1
- package/build-module/dataviews-layouts/utils/item-click-wrapper.js +2 -1
- package/build-module/dataviews-layouts/utils/item-click-wrapper.js.map +1 -1
- package/build-module/dataviews-layouts/utils/preview-size-picker.js +3 -2
- package/build-module/dataviews-layouts/utils/preview-size-picker.js.map +1 -1
- package/build-module/field-types/array.js +2 -1
- package/build-module/field-types/array.js.map +1 -1
- package/build-module/field-types/boolean.js +2 -1
- package/build-module/field-types/boolean.js.map +1 -1
- package/build-module/field-types/color.js +2 -1
- package/build-module/field-types/color.js.map +1 -1
- package/build-module/field-types/date.js +3 -2
- package/build-module/field-types/date.js.map +1 -1
- package/build-module/field-types/datetime.js +16 -2
- package/build-module/field-types/datetime.js.map +2 -2
- package/build-module/field-types/email.js +3 -2
- package/build-module/field-types/email.js.map +1 -1
- package/build-module/field-types/index.js +2 -1
- package/build-module/field-types/index.js.map +1 -1
- package/build-module/field-types/integer.js +2 -1
- package/build-module/field-types/integer.js.map +1 -1
- package/build-module/field-types/media.js +1 -0
- package/build-module/field-types/media.js.map +1 -1
- package/build-module/field-types/number.js +2 -1
- package/build-module/field-types/number.js.map +1 -1
- package/build-module/field-types/password.js +2 -1
- package/build-module/field-types/password.js.map +1 -1
- package/build-module/field-types/telephone.js +2 -1
- package/build-module/field-types/telephone.js.map +1 -1
- package/build-module/field-types/text.js +2 -1
- package/build-module/field-types/text.js.map +1 -1
- package/build-module/field-types/url.js +2 -1
- package/build-module/field-types/url.js.map +1 -1
- package/build-module/field-types/utils/parse-date-time.js +14 -0
- package/build-module/field-types/utils/parse-date-time.js.map +7 -0
- package/build-module/field-types/utils/render-from-elements.js +1 -0
- package/build-module/field-types/utils/render-from-elements.js.map +1 -1
- package/build-module/hooks/index.js +1 -0
- package/build-module/hooks/index.js.map +1 -1
- package/build-module/hooks/use-elements.js +2 -1
- package/build-module/hooks/use-elements.js.map +1 -1
- package/build-module/hooks/use-form-validity.js +424 -321
- package/build-module/hooks/use-form-validity.js.map +3 -3
- package/build-module/index.js +1 -0
- package/build-module/index.js.map +1 -1
- package/build-module/lock-unlock.js +2 -1
- package/build-module/lock-unlock.js.map +1 -1
- package/build-module/utils/filter-sort-and-paginate.js +2 -1
- package/build-module/utils/filter-sort-and-paginate.js.map +1 -1
- package/build-module/utils/has-elements.js +1 -0
- package/build-module/utils/has-elements.js.map +1 -1
- package/build-module/utils/normalize-fields.js +3 -2
- package/build-module/utils/normalize-fields.js.map +1 -1
- package/build-style/style-rtl.css +35 -40
- package/build-style/style.css +35 -40
- package/build-types/components/dataform/index.d.ts.map +1 -1
- package/build-types/components/dataviews-filters/filter.d.ts.map +1 -1
- package/build-types/components/dataviews-filters/utils.d.ts.map +1 -1
- package/build-types/components/dataviews-item-actions/index.d.ts.map +1 -1
- package/build-types/components/dataviews-view-config/index.d.ts.map +1 -1
- package/build-types/components/dataviews-view-config/properties-section.d.ts +4 -0
- package/build-types/components/dataviews-view-config/properties-section.d.ts.map +1 -0
- package/build-types/constants.d.ts +1 -0
- package/build-types/constants.d.ts.map +1 -1
- package/build-types/dataform-controls/datetime.d.ts.map +1 -1
- package/build-types/dataform-layouts/card/index.d.ts +1 -1
- package/build-types/dataform-layouts/card/index.d.ts.map +1 -1
- package/build-types/dataform-layouts/data-form-layout.d.ts +4 -4
- package/build-types/dataform-layouts/data-form-layout.d.ts.map +1 -1
- package/build-types/dataform-layouts/details/index.d.ts +6 -0
- package/build-types/dataform-layouts/details/index.d.ts.map +1 -0
- package/build-types/dataform-layouts/get-summary-fields.d.ts.map +1 -1
- package/build-types/dataform-layouts/index.d.ts +7 -2
- package/build-types/dataform-layouts/index.d.ts.map +1 -1
- package/build-types/dataform-layouts/normalize-form.d.ts +8 -0
- package/build-types/dataform-layouts/normalize-form.d.ts.map +1 -0
- package/build-types/dataform-layouts/panel/dropdown.d.ts +2 -2
- package/build-types/dataform-layouts/panel/dropdown.d.ts.map +1 -1
- package/build-types/dataform-layouts/panel/index.d.ts.map +1 -1
- package/build-types/dataform-layouts/panel/modal.d.ts +2 -2
- package/build-types/dataform-layouts/panel/modal.d.ts.map +1 -1
- package/build-types/dataform-layouts/regular/index.d.ts.map +1 -1
- package/build-types/dataform-layouts/row/index.d.ts.map +1 -1
- package/build-types/dataviews-layouts/index.d.ts +8 -0
- package/build-types/dataviews-layouts/index.d.ts.map +1 -1
- package/build-types/dataviews-layouts/list/index.d.ts.map +1 -1
- package/build-types/dataviews-layouts/picker-table/index.d.ts +4 -0
- package/build-types/dataviews-layouts/picker-table/index.d.ts.map +1 -0
- package/build-types/dataviews-layouts/table/column-header-menu.d.ts +3 -3
- package/build-types/dataviews-layouts/table/column-header-menu.d.ts.map +1 -1
- package/build-types/dataviews-layouts/table/column-primary.d.ts.map +1 -1
- package/build-types/dataviews-layouts/table/index.d.ts.map +1 -1
- package/build-types/field-types/datetime.d.ts +1 -1
- package/build-types/field-types/datetime.d.ts.map +1 -1
- package/build-types/field-types/utils/parse-date-time.d.ts +2 -0
- package/build-types/field-types/utils/parse-date-time.d.ts.map +1 -0
- package/build-types/hooks/use-form-validity.d.ts.map +1 -1
- package/build-types/stories/dataform.story.d.ts +4 -10
- package/build-types/stories/dataform.story.d.ts.map +1 -1
- package/build-types/stories/dataviews-picker.story.d.ts +33 -0
- package/build-types/stories/dataviews-picker.story.d.ts.map +1 -1
- package/build-types/stories/dataviews.fixtures.d.ts.map +1 -1
- package/build-types/stories/dataviews.story.d.ts +7 -1
- package/build-types/stories/dataviews.story.d.ts.map +1 -1
- package/build-types/test/normalize-form.d.ts +2 -0
- package/build-types/test/normalize-form.d.ts.map +1 -0
- package/build-types/types/dataform.d.ts +23 -9
- package/build-types/types/dataform.d.ts.map +1 -1
- package/build-types/types/dataviews.d.ts +23 -2
- package/build-types/types/dataviews.d.ts.map +1 -1
- package/build-wp/index.js +2101 -1673
- package/package.json +15 -15
- package/src/components/dataform/index.tsx +3 -1
- package/src/components/dataviews-filters/filter.tsx +16 -1
- package/src/components/dataviews-item-actions/index.tsx +37 -14
- package/src/components/dataviews-view-config/index.tsx +8 -504
- package/src/components/dataviews-view-config/properties-section.tsx +201 -0
- package/src/components/dataviews-view-config/style.scss +2 -39
- package/src/constants.ts +1 -0
- package/src/dataform-controls/datetime.tsx +3 -10
- package/src/dataform-layouts/card/index.tsx +45 -21
- package/src/dataform-layouts/data-form-layout.tsx +12 -23
- package/src/dataform-layouts/details/index.tsx +71 -0
- package/src/dataform-layouts/details/style.scss +5 -0
- package/src/dataform-layouts/index.tsx +10 -3
- package/src/dataform-layouts/{normalize-form-fields.ts → normalize-form.ts} +45 -23
- package/src/dataform-layouts/panel/dropdown.tsx +10 -13
- package/src/dataform-layouts/panel/index.tsx +9 -24
- package/src/dataform-layouts/panel/modal.tsx +15 -15
- package/src/dataform-layouts/regular/index.tsx +7 -12
- package/src/dataform-layouts/row/index.tsx +13 -26
- package/src/dataviews-layouts/index.ts +10 -0
- package/src/dataviews-layouts/list/index.tsx +2 -5
- package/src/dataviews-layouts/picker-table/index.tsx +487 -0
- package/src/dataviews-layouts/picker-table/style.scss +45 -0
- package/src/dataviews-layouts/table/column-header-menu.tsx +3 -2
- package/src/dataviews-layouts/table/column-primary.tsx +4 -7
- package/src/dataviews-layouts/table/index.tsx +54 -2
- package/src/dataviews-layouts/table/style.scss +6 -1
- package/src/field-types/datetime.tsx +16 -5
- package/src/field-types/utils/parse-date-time.ts +17 -0
- package/src/hooks/use-form-validity.ts +572 -422
- package/src/stories/dataform.story.tsx +586 -454
- package/src/stories/dataviews-picker.story.tsx +166 -38
- package/src/stories/dataviews.fixtures.tsx +4 -1
- package/src/stories/dataviews.story.tsx +10 -2
- package/src/stories/field-types.story.tsx +7 -7
- package/src/style.scss +2 -0
- package/src/test/normalize-form.ts +568 -0
- package/src/test/use-form-validity.ts +318 -33
- package/src/types/dataform.ts +30 -11
- package/src/types/dataviews.ts +36 -2
- package/tsconfig.tsbuildinfo +1 -1
- package/build/dataform-layouts/is-combined-field.js.map +0 -7
- package/build/dataform-layouts/normalize-form-fields.js.map +0 -7
- package/build-module/dataform-layouts/is-combined-field.js +0 -7
- package/build-module/dataform-layouts/is-combined-field.js.map +0 -7
- package/build-module/dataform-layouts/normalize-form-fields.js.map +0 -7
- package/build-types/dataform-layouts/is-combined-field.d.ts +0 -6
- package/build-types/dataform-layouts/is-combined-field.d.ts.map +0 -1
- package/build-types/dataform-layouts/normalize-form-fields.d.ts +0 -19
- package/build-types/dataform-layouts/normalize-form-fields.d.ts.map +0 -1
- package/build-types/test/normalize-form-fields.d.ts +0 -2
- package/build-types/test/normalize-form-fields.d.ts.map +0 -1
- package/src/dataform-layouts/is-combined-field.ts +0 -10
- package/src/test/normalize-form-fields.ts +0 -324
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import {
|
|
5
|
+
__experimentalItemGroup as ItemGroup,
|
|
6
|
+
__experimentalItem as Item,
|
|
7
|
+
__experimentalVStack as VStack,
|
|
8
|
+
__experimentalHStack as HStack,
|
|
9
|
+
BaseControl,
|
|
10
|
+
Icon,
|
|
11
|
+
} from '@wordpress/components';
|
|
12
|
+
import { __ } from '@wordpress/i18n';
|
|
13
|
+
import { useContext } from '@wordpress/element';
|
|
14
|
+
import { check } from '@wordpress/icons';
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Internal dependencies
|
|
18
|
+
*/
|
|
19
|
+
import type { NormalizedField } from '../../types';
|
|
20
|
+
import DataViewsContext from '../dataviews-context';
|
|
21
|
+
|
|
22
|
+
function FieldItem( {
|
|
23
|
+
field,
|
|
24
|
+
isVisible,
|
|
25
|
+
onToggleVisibility,
|
|
26
|
+
}: {
|
|
27
|
+
field: NormalizedField< any >;
|
|
28
|
+
isVisible: boolean;
|
|
29
|
+
onToggleVisibility?: () => void;
|
|
30
|
+
} ) {
|
|
31
|
+
return (
|
|
32
|
+
<Item onClick={ field.enableHiding ? onToggleVisibility : undefined }>
|
|
33
|
+
<HStack expanded justify="flex-start" alignment="center">
|
|
34
|
+
<div style={ { height: 24, width: 24 } }>
|
|
35
|
+
{ isVisible && <Icon icon={ check } /> }
|
|
36
|
+
</div>
|
|
37
|
+
<span className="dataviews-view-config__label">
|
|
38
|
+
{ field.label }
|
|
39
|
+
</span>
|
|
40
|
+
</HStack>
|
|
41
|
+
</Item>
|
|
42
|
+
);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function isDefined< T >( item: T | undefined ): item is T {
|
|
46
|
+
return !! item;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export function PropertiesSection( {
|
|
50
|
+
showLabel = true,
|
|
51
|
+
}: {
|
|
52
|
+
showLabel?: boolean;
|
|
53
|
+
} ) {
|
|
54
|
+
const { view, fields, onChangeView } = useContext( DataViewsContext );
|
|
55
|
+
|
|
56
|
+
const togglableFields = [
|
|
57
|
+
view?.titleField,
|
|
58
|
+
view?.mediaField,
|
|
59
|
+
view?.descriptionField,
|
|
60
|
+
].filter( Boolean );
|
|
61
|
+
|
|
62
|
+
// Get all regular fields (non-locked) in their original order from fields prop
|
|
63
|
+
const regularFields = fields.filter(
|
|
64
|
+
( f ) =>
|
|
65
|
+
! togglableFields.includes( f.id ) &&
|
|
66
|
+
f.type !== 'media' &&
|
|
67
|
+
f.enableHiding !== false
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
if ( ! regularFields?.length ) {
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
const titleField = fields.find( ( f ) => f.id === view.titleField );
|
|
74
|
+
const previewField = fields.find( ( f ) => f.id === view.mediaField );
|
|
75
|
+
const descriptionField = fields.find(
|
|
76
|
+
( f ) => f.id === view.descriptionField
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
const lockedFields = [
|
|
80
|
+
{
|
|
81
|
+
field: titleField,
|
|
82
|
+
isVisibleFlag: 'showTitle',
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
field: previewField,
|
|
86
|
+
isVisibleFlag: 'showMedia',
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
field: descriptionField,
|
|
90
|
+
isVisibleFlag: 'showDescription',
|
|
91
|
+
},
|
|
92
|
+
].filter( ( { field } ) => isDefined( field ) );
|
|
93
|
+
const visibleFieldIds = view.fields ?? [];
|
|
94
|
+
const visibleRegularFieldsCount = regularFields.filter( ( f ) =>
|
|
95
|
+
visibleFieldIds.includes( f.id )
|
|
96
|
+
).length;
|
|
97
|
+
|
|
98
|
+
let visibleLockedFields = lockedFields.filter(
|
|
99
|
+
( { field, isVisibleFlag } ) =>
|
|
100
|
+
// @ts-expect-error
|
|
101
|
+
isDefined( field ) && ( view[ isVisibleFlag ] ?? true )
|
|
102
|
+
) as Array< {
|
|
103
|
+
field: NormalizedField< any >;
|
|
104
|
+
isVisibleFlag: string;
|
|
105
|
+
} >;
|
|
106
|
+
|
|
107
|
+
// If only one field (locked or regular) is visible, prevent it from being hidden
|
|
108
|
+
const totalVisibleFields =
|
|
109
|
+
visibleLockedFields.length + visibleRegularFieldsCount;
|
|
110
|
+
if ( totalVisibleFields === 1 ) {
|
|
111
|
+
if ( visibleLockedFields.length === 1 ) {
|
|
112
|
+
visibleLockedFields = visibleLockedFields.map( ( locked ) => ( {
|
|
113
|
+
...locked,
|
|
114
|
+
field: { ...locked.field, enableHiding: false },
|
|
115
|
+
} ) );
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
const hiddenLockedFields = lockedFields.filter(
|
|
120
|
+
( { field, isVisibleFlag } ) =>
|
|
121
|
+
// @ts-expect-error
|
|
122
|
+
isDefined( field ) && ! ( view[ isVisibleFlag ] ?? true )
|
|
123
|
+
) as Array< {
|
|
124
|
+
field: NormalizedField< any >;
|
|
125
|
+
isVisibleFlag: string;
|
|
126
|
+
} >;
|
|
127
|
+
|
|
128
|
+
return (
|
|
129
|
+
<VStack className="dataviews-field-control" spacing={ 0 }>
|
|
130
|
+
{ showLabel && (
|
|
131
|
+
<BaseControl.VisualLabel>
|
|
132
|
+
{ __( 'Properties' ) }
|
|
133
|
+
</BaseControl.VisualLabel>
|
|
134
|
+
) }
|
|
135
|
+
<VStack className="dataviews-view-config__properties" spacing={ 0 }>
|
|
136
|
+
<ItemGroup isBordered isSeparated size="medium">
|
|
137
|
+
{ visibleLockedFields.map( ( { field, isVisibleFlag } ) => {
|
|
138
|
+
return (
|
|
139
|
+
<FieldItem
|
|
140
|
+
key={ field.id }
|
|
141
|
+
field={ field }
|
|
142
|
+
isVisible
|
|
143
|
+
onToggleVisibility={ () => {
|
|
144
|
+
onChangeView( {
|
|
145
|
+
...view,
|
|
146
|
+
[ isVisibleFlag ]: false,
|
|
147
|
+
} );
|
|
148
|
+
} }
|
|
149
|
+
/>
|
|
150
|
+
);
|
|
151
|
+
} ) }
|
|
152
|
+
|
|
153
|
+
{ hiddenLockedFields.map( ( { field, isVisibleFlag } ) => {
|
|
154
|
+
return (
|
|
155
|
+
<FieldItem
|
|
156
|
+
key={ field.id }
|
|
157
|
+
field={ field }
|
|
158
|
+
isVisible={ false }
|
|
159
|
+
onToggleVisibility={ () => {
|
|
160
|
+
onChangeView( {
|
|
161
|
+
...view,
|
|
162
|
+
[ isVisibleFlag ]: true,
|
|
163
|
+
} );
|
|
164
|
+
} }
|
|
165
|
+
/>
|
|
166
|
+
);
|
|
167
|
+
} ) }
|
|
168
|
+
|
|
169
|
+
{ regularFields.map( ( field ) => {
|
|
170
|
+
// Check if this is the last visible field to prevent hiding
|
|
171
|
+
const isVisible = visibleFieldIds.includes( field.id );
|
|
172
|
+
const isLastVisible =
|
|
173
|
+
totalVisibleFields === 1 && isVisible;
|
|
174
|
+
const fieldToRender = isLastVisible
|
|
175
|
+
? { ...field, enableHiding: false }
|
|
176
|
+
: field;
|
|
177
|
+
|
|
178
|
+
return (
|
|
179
|
+
<FieldItem
|
|
180
|
+
key={ field.id }
|
|
181
|
+
field={ fieldToRender }
|
|
182
|
+
isVisible={ isVisible }
|
|
183
|
+
onToggleVisibility={ () => {
|
|
184
|
+
onChangeView( {
|
|
185
|
+
...view,
|
|
186
|
+
fields: isVisible
|
|
187
|
+
? visibleFieldIds.filter(
|
|
188
|
+
( fieldId ) =>
|
|
189
|
+
fieldId !== field.id
|
|
190
|
+
)
|
|
191
|
+
: [ ...visibleFieldIds, field.id ],
|
|
192
|
+
} );
|
|
193
|
+
} }
|
|
194
|
+
/>
|
|
195
|
+
);
|
|
196
|
+
} ) }
|
|
197
|
+
</ItemGroup>
|
|
198
|
+
</VStack>
|
|
199
|
+
</VStack>
|
|
200
|
+
);
|
|
201
|
+
}
|
|
@@ -58,44 +58,7 @@
|
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
|
-
.dataviews-field-control__field {
|
|
62
|
-
height: $grid-unit-40;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
.dataviews-field-control__actions {
|
|
66
|
-
position: absolute;
|
|
67
|
-
top: -9999em;
|
|
68
|
-
}
|
|
69
|
-
.dataviews-field-control__actions.dataviews-field-control__actions {
|
|
70
|
-
gap: $grid-unit-05;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
.dataviews-field-control__field:hover,
|
|
74
|
-
.dataviews-field-control__field:focus-within,
|
|
75
|
-
.dataviews-field-control__field.is-interacting {
|
|
76
|
-
.dataviews-field-control__actions {
|
|
77
|
-
position: unset;
|
|
78
|
-
top: unset;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
.dataviews-field-control__icon {
|
|
83
|
-
display: flex;
|
|
84
|
-
width: $icon-size;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
.dataviews-field-control__label-sub-label-container {
|
|
88
|
-
flex-grow: 1;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
.dataviews-field-control__label {
|
|
92
|
-
display: block;
|
|
93
|
-
}
|
|
94
61
|
|
|
95
|
-
.dataviews-
|
|
96
|
-
|
|
97
|
-
margin-bottom: 0;
|
|
98
|
-
font-size: 11px;
|
|
99
|
-
font-style: normal;
|
|
100
|
-
color: $gray-700;
|
|
62
|
+
.dataviews-view-config__label {
|
|
63
|
+
text-wrap: nowrap;
|
|
101
64
|
}
|
package/src/constants.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { format
|
|
4
|
+
import { format } from 'date-fns';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* WordPress dependencies
|
|
@@ -13,7 +13,7 @@ import {
|
|
|
13
13
|
} from '@wordpress/components';
|
|
14
14
|
import { useCallback, useEffect, useRef, useState } from '@wordpress/element';
|
|
15
15
|
import { __ } from '@wordpress/i18n';
|
|
16
|
-
import {
|
|
16
|
+
import { getSettings } from '@wordpress/date';
|
|
17
17
|
|
|
18
18
|
/**
|
|
19
19
|
* Internal dependencies
|
|
@@ -22,18 +22,11 @@ import type { DataFormControlProps } from '../types';
|
|
|
22
22
|
import { OPERATOR_IN_THE_PAST, OPERATOR_OVER } from '../constants';
|
|
23
23
|
import RelativeDateControl from './utils/relative-date-control';
|
|
24
24
|
import getCustomValidity from './utils/get-custom-validity';
|
|
25
|
+
import parseDateTime from '../field-types/utils/parse-date-time';
|
|
25
26
|
import { unlock } from '../lock-unlock';
|
|
26
27
|
|
|
27
28
|
const { DateCalendar, ValidatedInputControl } = unlock( componentsPrivateApis );
|
|
28
29
|
|
|
29
|
-
const parseDateTime = ( dateTimeString?: string ): Date | null => {
|
|
30
|
-
if ( ! dateTimeString ) {
|
|
31
|
-
return null;
|
|
32
|
-
}
|
|
33
|
-
const parsed = getDate( dateTimeString );
|
|
34
|
-
return parsed && isValidDate( parsed ) ? parsed : null;
|
|
35
|
-
};
|
|
36
|
-
|
|
37
30
|
const formatDateTime = ( date?: Date | string ): string => {
|
|
38
31
|
if ( ! date ) {
|
|
39
32
|
return '';
|
|
@@ -16,16 +16,14 @@ import { chevronDown, chevronUp } from '@wordpress/icons';
|
|
|
16
16
|
import { getFormFieldLayout } from '..';
|
|
17
17
|
import DataFormContext from '../../components/dataform-context';
|
|
18
18
|
import type {
|
|
19
|
-
NormalizedCardLayout,
|
|
20
|
-
CardLayout,
|
|
21
19
|
FieldLayoutProps,
|
|
22
|
-
|
|
23
|
-
Layout,
|
|
20
|
+
NormalizedCardLayout,
|
|
24
21
|
NormalizedField,
|
|
22
|
+
NormalizedForm,
|
|
23
|
+
NormalizedLayout,
|
|
25
24
|
} from '../../types';
|
|
26
25
|
import { DataFormLayout } from '../data-form-layout';
|
|
27
|
-
import {
|
|
28
|
-
import { DEFAULT_LAYOUT, normalizeLayout } from '../normalize-form-fields';
|
|
26
|
+
import { DEFAULT_LAYOUT } from '../normalize-form';
|
|
29
27
|
import { getSummaryFields } from '../get-summary-fields';
|
|
30
28
|
|
|
31
29
|
const NonCollapsibleCardHeader = ( {
|
|
@@ -34,7 +32,7 @@ const NonCollapsibleCardHeader = ( {
|
|
|
34
32
|
}: {
|
|
35
33
|
children: React.ReactNode;
|
|
36
34
|
} ) => (
|
|
37
|
-
<OriginalCardHeader { ...props }>
|
|
35
|
+
<OriginalCardHeader isBorderless { ...props }>
|
|
38
36
|
<div
|
|
39
37
|
style={ {
|
|
40
38
|
height: '40px', // This is to match the chevron's __next40pxDefaultSize
|
|
@@ -72,6 +70,7 @@ export function useCardHeader( layout: NormalizedCardLayout ) {
|
|
|
72
70
|
cursor: 'pointer',
|
|
73
71
|
...props.style,
|
|
74
72
|
} }
|
|
73
|
+
isBorderless
|
|
75
74
|
>
|
|
76
75
|
<div
|
|
77
76
|
style={ {
|
|
@@ -162,16 +161,12 @@ export default function FormCardField< Item >( {
|
|
|
162
161
|
validity,
|
|
163
162
|
}: FieldLayoutProps< Item > ) {
|
|
164
163
|
const { fields } = useContext( DataFormContext );
|
|
164
|
+
const layout = field.layout as NormalizedCardLayout;
|
|
165
165
|
|
|
166
|
-
const
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
const form: Form = useMemo(
|
|
172
|
-
(): Form => ( {
|
|
173
|
-
layout: DEFAULT_LAYOUT as Layout,
|
|
174
|
-
fields: isCombinedField( field ) ? field.children : [],
|
|
166
|
+
const form: NormalizedForm = useMemo(
|
|
167
|
+
() => ( {
|
|
168
|
+
layout: DEFAULT_LAYOUT as NormalizedLayout,
|
|
169
|
+
fields: field.children ?? [],
|
|
175
170
|
} ),
|
|
176
171
|
[ field ]
|
|
177
172
|
);
|
|
@@ -184,11 +179,27 @@ export default function FormCardField< Item >( {
|
|
|
184
179
|
isSummaryFieldVisible( summaryField, layout.summary, isOpen )
|
|
185
180
|
);
|
|
186
181
|
|
|
187
|
-
|
|
182
|
+
const sizeCard = {
|
|
183
|
+
blockStart: 'medium' as const,
|
|
184
|
+
blockEnd: 'medium' as const,
|
|
185
|
+
inlineStart: 'medium' as const,
|
|
186
|
+
inlineEnd: 'medium' as const,
|
|
187
|
+
};
|
|
188
|
+
|
|
189
|
+
if ( !! field.children ) {
|
|
188
190
|
const withHeader = !! field.label && layout.withHeader;
|
|
189
191
|
|
|
192
|
+
const sizeCardBody = {
|
|
193
|
+
blockStart: withHeader
|
|
194
|
+
? ( 'none' as const )
|
|
195
|
+
: ( 'medium' as const ),
|
|
196
|
+
blockEnd: 'medium' as const,
|
|
197
|
+
inlineStart: 'medium' as const,
|
|
198
|
+
inlineEnd: 'medium' as const,
|
|
199
|
+
};
|
|
200
|
+
|
|
190
201
|
return (
|
|
191
|
-
<Card className="dataforms-layouts-card__field">
|
|
202
|
+
<Card className="dataforms-layouts-card__field" size={ sizeCard }>
|
|
192
203
|
{ withHeader && (
|
|
193
204
|
<CardHeader className="dataforms-layouts-card__field-header">
|
|
194
205
|
<span className="dataforms-layouts-card__field-header-label">
|
|
@@ -213,7 +224,10 @@ export default function FormCardField< Item >( {
|
|
|
213
224
|
{ ( isOpen || ! withHeader ) && (
|
|
214
225
|
// If it doesn't have a header, keep it open.
|
|
215
226
|
// Otherwise, the card will not be visible.
|
|
216
|
-
<CardBody
|
|
227
|
+
<CardBody
|
|
228
|
+
size={ sizeCardBody }
|
|
229
|
+
className="dataforms-layouts-card__field-control"
|
|
230
|
+
>
|
|
217
231
|
{ field.description && (
|
|
218
232
|
<div className="dataforms-layouts-card__field-description">
|
|
219
233
|
{ field.description }
|
|
@@ -245,8 +259,15 @@ export default function FormCardField< Item >( {
|
|
|
245
259
|
}
|
|
246
260
|
const withHeader = !! fieldDefinition.label && layout.withHeader;
|
|
247
261
|
|
|
262
|
+
const sizeCardBody = {
|
|
263
|
+
blockStart: withHeader ? ( 'none' as const ) : ( 'medium' as const ),
|
|
264
|
+
blockEnd: 'medium' as const,
|
|
265
|
+
inlineStart: 'medium' as const,
|
|
266
|
+
inlineEnd: 'medium' as const,
|
|
267
|
+
};
|
|
268
|
+
|
|
248
269
|
return (
|
|
249
|
-
<Card className="dataforms-layouts-card__field">
|
|
270
|
+
<Card className="dataforms-layouts-card__field" size={ sizeCard }>
|
|
250
271
|
{ withHeader && (
|
|
251
272
|
<CardHeader className="dataforms-layouts-card__field-header">
|
|
252
273
|
<span className="dataforms-layouts-card__field-header-label">
|
|
@@ -268,7 +289,10 @@ export default function FormCardField< Item >( {
|
|
|
268
289
|
{ ( isOpen || ! withHeader ) && (
|
|
269
290
|
// If it doesn't have a header, keep it open.
|
|
270
291
|
// Otherwise, the card will not be visible.
|
|
271
|
-
<CardBody
|
|
292
|
+
<CardBody
|
|
293
|
+
size={ sizeCardBody }
|
|
294
|
+
className="dataforms-layouts-card__field-control"
|
|
295
|
+
>
|
|
272
296
|
<RegularLayout
|
|
273
297
|
data={ data }
|
|
274
298
|
field={ field }
|
|
@@ -2,22 +2,19 @@
|
|
|
2
2
|
* WordPress dependencies
|
|
3
3
|
*/
|
|
4
4
|
import { __experimentalVStack as VStack } from '@wordpress/components';
|
|
5
|
-
import { useContext
|
|
5
|
+
import { useContext } from '@wordpress/element';
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Internal dependencies
|
|
9
9
|
*/
|
|
10
10
|
import type {
|
|
11
11
|
FieldValidity,
|
|
12
|
-
Form,
|
|
13
|
-
FormField,
|
|
14
12
|
FormValidity,
|
|
15
|
-
|
|
13
|
+
NormalizedForm,
|
|
14
|
+
NormalizedFormField,
|
|
16
15
|
} from '../types';
|
|
17
16
|
import { getFormFieldLayout } from './index';
|
|
18
17
|
import DataFormContext from '../components/dataform-context';
|
|
19
|
-
import { isCombinedField } from './is-combined-field';
|
|
20
|
-
import normalizeFormFields, { normalizeLayout } from './normalize-form-fields';
|
|
21
18
|
|
|
22
19
|
const DEFAULT_WRAPPER = ( { children }: { children: React.ReactNode } ) => (
|
|
23
20
|
<VStack className="dataforms-layouts__wrapper" spacing={ 4 }>
|
|
@@ -34,46 +31,38 @@ export function DataFormLayout< Item >( {
|
|
|
34
31
|
as,
|
|
35
32
|
}: {
|
|
36
33
|
data: Item;
|
|
37
|
-
form:
|
|
34
|
+
form: NormalizedForm;
|
|
38
35
|
onChange: ( value: any ) => void;
|
|
39
36
|
validity?: FormValidity;
|
|
40
37
|
children?: (
|
|
41
38
|
FieldLayout: ( props: {
|
|
42
39
|
data: Item;
|
|
43
|
-
field:
|
|
40
|
+
field: NormalizedFormField;
|
|
44
41
|
onChange: ( value: any ) => void;
|
|
45
42
|
hideLabelFromVision?: boolean;
|
|
46
43
|
validity?: FieldValidity;
|
|
47
44
|
} ) => React.JSX.Element | null,
|
|
48
|
-
childField:
|
|
45
|
+
childField: NormalizedFormField,
|
|
49
46
|
childFieldValidity?: FieldValidity
|
|
50
47
|
) => React.JSX.Element;
|
|
51
48
|
as?: React.ComponentType< { children: React.ReactNode } >;
|
|
52
49
|
} ) {
|
|
53
50
|
const { fields: fieldDefinitions } = useContext( DataFormContext );
|
|
54
51
|
|
|
55
|
-
function getFieldDefinition( field:
|
|
56
|
-
const fieldId = typeof field === 'string' ? field : field.id;
|
|
57
|
-
|
|
52
|
+
function getFieldDefinition( field: NormalizedFormField ) {
|
|
58
53
|
return fieldDefinitions.find(
|
|
59
|
-
( fieldDefinition ) => fieldDefinition.id ===
|
|
54
|
+
( fieldDefinition ) => fieldDefinition.id === field.id
|
|
60
55
|
);
|
|
61
56
|
}
|
|
62
57
|
|
|
63
|
-
const normalizedFormFields = useMemo(
|
|
64
|
-
() => normalizeFormFields( form ),
|
|
65
|
-
[ form ]
|
|
66
|
-
);
|
|
67
|
-
|
|
68
|
-
const normalizedFormLayout = normalizeLayout( form.layout );
|
|
69
58
|
const Wrapper =
|
|
70
59
|
as ??
|
|
71
|
-
getFormFieldLayout(
|
|
60
|
+
getFormFieldLayout( form.layout.type )?.wrapper ??
|
|
72
61
|
DEFAULT_WRAPPER;
|
|
73
62
|
|
|
74
63
|
return (
|
|
75
|
-
<Wrapper layout={
|
|
76
|
-
{
|
|
64
|
+
<Wrapper layout={ form.layout }>
|
|
65
|
+
{ form.fields.map( ( formField ) => {
|
|
77
66
|
const FieldLayout = getFormFieldLayout( formField.layout.type )
|
|
78
67
|
?.component;
|
|
79
68
|
|
|
@@ -81,7 +70,7 @@ export function DataFormLayout< Item >( {
|
|
|
81
70
|
return null;
|
|
82
71
|
}
|
|
83
72
|
|
|
84
|
-
const fieldDefinition = !
|
|
73
|
+
const fieldDefinition = ! formField.children
|
|
85
74
|
? getFieldDefinition( formField )
|
|
86
75
|
: undefined;
|
|
87
76
|
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { useContext, useMemo } from '@wordpress/element';
|
|
5
|
+
import { __ } from '@wordpress/i18n';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Internal dependencies
|
|
9
|
+
*/
|
|
10
|
+
import type {
|
|
11
|
+
NormalizedForm,
|
|
12
|
+
NormalizedDetailsLayout,
|
|
13
|
+
FieldLayoutProps,
|
|
14
|
+
} from '../../types';
|
|
15
|
+
import DataFormContext from '../../components/dataform-context';
|
|
16
|
+
import { DataFormLayout } from '../data-form-layout';
|
|
17
|
+
import { DEFAULT_LAYOUT } from '../normalize-form';
|
|
18
|
+
|
|
19
|
+
export default function FormDetailsField< Item >( {
|
|
20
|
+
data,
|
|
21
|
+
field,
|
|
22
|
+
onChange,
|
|
23
|
+
}: FieldLayoutProps< Item > ) {
|
|
24
|
+
const { fields } = useContext( DataFormContext );
|
|
25
|
+
|
|
26
|
+
const form: NormalizedForm = useMemo(
|
|
27
|
+
() => ( {
|
|
28
|
+
layout: DEFAULT_LAYOUT,
|
|
29
|
+
fields: field.children ?? [],
|
|
30
|
+
} ),
|
|
31
|
+
[ field ]
|
|
32
|
+
);
|
|
33
|
+
|
|
34
|
+
if ( ! field.children ) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// Find the summary field definition if specified
|
|
39
|
+
const summaryFieldId =
|
|
40
|
+
( field.layout as NormalizedDetailsLayout ).summary ?? '';
|
|
41
|
+
const summaryField = summaryFieldId
|
|
42
|
+
? fields.find( ( fieldDef ) => fieldDef.id === summaryFieldId )
|
|
43
|
+
: undefined;
|
|
44
|
+
|
|
45
|
+
// Render the summary content
|
|
46
|
+
let summaryContent;
|
|
47
|
+
if ( summaryField && summaryField.render ) {
|
|
48
|
+
// Use the field's render function to display the current value
|
|
49
|
+
summaryContent = (
|
|
50
|
+
<summaryField.render item={ data } field={ summaryField } />
|
|
51
|
+
);
|
|
52
|
+
} else {
|
|
53
|
+
// Fall back to the label
|
|
54
|
+
summaryContent = field.label || __( 'More details' );
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return (
|
|
58
|
+
<details className="dataforms-layouts-details__details">
|
|
59
|
+
<summary className="dataforms-layouts-details__summary">
|
|
60
|
+
{ summaryContent }
|
|
61
|
+
</summary>
|
|
62
|
+
<div className="dataforms-layouts-details__content">
|
|
63
|
+
<DataFormLayout
|
|
64
|
+
data={ data }
|
|
65
|
+
form={ form }
|
|
66
|
+
onChange={ onChange }
|
|
67
|
+
/>
|
|
68
|
+
</div>
|
|
69
|
+
</details>
|
|
70
|
+
);
|
|
71
|
+
}
|
|
@@ -9,11 +9,12 @@ import {
|
|
|
9
9
|
/**
|
|
10
10
|
* Internal dependencies
|
|
11
11
|
*/
|
|
12
|
-
import type {
|
|
12
|
+
import type { NormalizedLayout, NormalizedRowLayout } from '../types';
|
|
13
13
|
import FormRegularField from './regular';
|
|
14
14
|
import FormPanelField from './panel';
|
|
15
15
|
import FormCardField from './card';
|
|
16
16
|
import FormRowField from './row';
|
|
17
|
+
import FormDetailsField from './details';
|
|
17
18
|
|
|
18
19
|
const FORM_FIELD_LAYOUTS = [
|
|
19
20
|
{
|
|
@@ -51,13 +52,15 @@ const FORM_FIELD_LAYOUTS = [
|
|
|
51
52
|
layout,
|
|
52
53
|
}: {
|
|
53
54
|
children: React.ReactNode;
|
|
54
|
-
layout:
|
|
55
|
+
layout: NormalizedLayout;
|
|
55
56
|
} ) => (
|
|
56
57
|
<VStack className="dataforms-layouts__wrapper" spacing={ 4 }>
|
|
57
58
|
<div className="dataforms-layouts-row__field">
|
|
58
59
|
<HStack
|
|
59
60
|
spacing={ 4 }
|
|
60
|
-
alignment={
|
|
61
|
+
alignment={
|
|
62
|
+
( layout as NormalizedRowLayout ).alignment
|
|
63
|
+
}
|
|
61
64
|
>
|
|
62
65
|
{ children }
|
|
63
66
|
</HStack>
|
|
@@ -65,6 +68,10 @@ const FORM_FIELD_LAYOUTS = [
|
|
|
65
68
|
</VStack>
|
|
66
69
|
),
|
|
67
70
|
},
|
|
71
|
+
{
|
|
72
|
+
type: 'details',
|
|
73
|
+
component: FormDetailsField,
|
|
74
|
+
},
|
|
68
75
|
];
|
|
69
76
|
|
|
70
77
|
export function getFormFieldLayout( type: string ) {
|