@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
|
@@ -58,8 +58,10 @@ describe( 'useFormValidity', () => {
|
|
|
58
58
|
expect( validity ).toEqual( undefined );
|
|
59
59
|
expect( isValid ).toBe( true );
|
|
60
60
|
} );
|
|
61
|
+
} );
|
|
61
62
|
|
|
62
|
-
|
|
63
|
+
describe( 'form fields', () => {
|
|
64
|
+
it( 'defined as strings are checked for validity', () => {
|
|
63
65
|
const item = { id: 1, order: undefined };
|
|
64
66
|
const fields: Field< {} >[] = [
|
|
65
67
|
{
|
|
@@ -71,7 +73,7 @@ describe( 'useFormValidity', () => {
|
|
|
71
73
|
},
|
|
72
74
|
];
|
|
73
75
|
const form = {
|
|
74
|
-
fields: [
|
|
76
|
+
fields: [ 'order' ],
|
|
75
77
|
};
|
|
76
78
|
const {
|
|
77
79
|
result: {
|
|
@@ -79,18 +81,14 @@ describe( 'useFormValidity', () => {
|
|
|
79
81
|
},
|
|
80
82
|
} = renderHook( () => useFormValidity( item, fields, form ) );
|
|
81
83
|
expect( validity ).toEqual( {
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
order: {
|
|
85
|
-
required: { type: 'invalid' },
|
|
86
|
-
},
|
|
87
|
-
},
|
|
84
|
+
order: {
|
|
85
|
+
required: { type: 'invalid' },
|
|
88
86
|
},
|
|
89
87
|
} );
|
|
90
88
|
expect( isValid ).toBe( false );
|
|
91
89
|
} );
|
|
92
90
|
|
|
93
|
-
it( '
|
|
91
|
+
it( 'defined as objects are checked for validity', () => {
|
|
94
92
|
const item = { id: 1, order: undefined };
|
|
95
93
|
const fields: Field< {} >[] = [
|
|
96
94
|
{
|
|
@@ -116,38 +114,78 @@ describe( 'useFormValidity', () => {
|
|
|
116
114
|
} );
|
|
117
115
|
expect( isValid ).toBe( false );
|
|
118
116
|
} );
|
|
119
|
-
} );
|
|
120
|
-
|
|
121
|
-
describe( 'isValid.required', () => {
|
|
122
|
-
const REQUIRED_MESSAGE = {
|
|
123
|
-
required: { type: 'invalid' },
|
|
124
|
-
};
|
|
125
117
|
|
|
126
|
-
it( '
|
|
127
|
-
|
|
128
|
-
|
|
118
|
+
it( 'with children are checked for validity', async () => {
|
|
119
|
+
type TestValidity = {
|
|
120
|
+
id: number;
|
|
121
|
+
field1?: number;
|
|
122
|
+
field2?: number;
|
|
123
|
+
field3?: number;
|
|
124
|
+
field4?: number;
|
|
125
|
+
};
|
|
126
|
+
const item: TestValidity = {
|
|
127
|
+
id: 1,
|
|
128
|
+
field1: 2,
|
|
129
|
+
field2: 3,
|
|
130
|
+
field3: undefined,
|
|
131
|
+
field4: undefined,
|
|
132
|
+
};
|
|
133
|
+
const fields: Field< TestValidity >[] = [
|
|
129
134
|
{
|
|
130
|
-
id: '
|
|
131
|
-
type: '
|
|
135
|
+
id: 'field1',
|
|
136
|
+
type: 'integer',
|
|
137
|
+
elements: [ { value: 1, label: 'One' } ],
|
|
132
138
|
isValid: {
|
|
133
|
-
|
|
134
|
-
await new Promise( ( resolve ) =>
|
|
135
|
-
setTimeout( resolve, 5 )
|
|
136
|
-
).then( () => null ),
|
|
139
|
+
elements: true,
|
|
137
140
|
},
|
|
138
141
|
},
|
|
139
142
|
{
|
|
140
|
-
id: '
|
|
141
|
-
type: '
|
|
143
|
+
id: 'field2',
|
|
144
|
+
type: 'integer',
|
|
145
|
+
getElements: async () =>
|
|
146
|
+
await new Promise( ( resolve ) => {
|
|
147
|
+
setTimeout( resolve, 5 );
|
|
148
|
+
} ).then( () => [ { value: 2, label: 'Two' } ] ),
|
|
149
|
+
isValid: {
|
|
150
|
+
elements: true,
|
|
151
|
+
},
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
id: 'field3',
|
|
155
|
+
type: 'integer',
|
|
156
|
+
isValid: {
|
|
157
|
+
required: true,
|
|
158
|
+
},
|
|
159
|
+
},
|
|
160
|
+
{
|
|
161
|
+
id: 'field4',
|
|
162
|
+
type: 'integer',
|
|
142
163
|
isValid: {
|
|
143
164
|
custom: async () =>
|
|
144
165
|
await new Promise( ( resolve ) =>
|
|
145
166
|
setTimeout( resolve, 5 )
|
|
146
|
-
).then( () =>
|
|
167
|
+
).then( () => 'Field is invalid.' ),
|
|
147
168
|
},
|
|
148
169
|
},
|
|
149
170
|
];
|
|
150
|
-
const form = {
|
|
171
|
+
const form = {
|
|
172
|
+
fields: [
|
|
173
|
+
'field1',
|
|
174
|
+
{
|
|
175
|
+
id: 'combined1',
|
|
176
|
+
children: [
|
|
177
|
+
'field2',
|
|
178
|
+
{
|
|
179
|
+
id: 'combined2',
|
|
180
|
+
children: [
|
|
181
|
+
'field3',
|
|
182
|
+
{ id: 'combined3', children: [ 'field4' ] },
|
|
183
|
+
],
|
|
184
|
+
},
|
|
185
|
+
],
|
|
186
|
+
},
|
|
187
|
+
],
|
|
188
|
+
};
|
|
151
189
|
const { result } = renderHook( () =>
|
|
152
190
|
useFormValidity( item, fields, form )
|
|
153
191
|
);
|
|
@@ -155,17 +193,52 @@ describe( 'useFormValidity', () => {
|
|
|
155
193
|
await waitFor( () => {
|
|
156
194
|
expect( result.current ).toEqual( {
|
|
157
195
|
validity: {
|
|
158
|
-
|
|
159
|
-
|
|
196
|
+
combined1: {
|
|
197
|
+
children: {
|
|
198
|
+
combined2: {
|
|
199
|
+
children: {
|
|
200
|
+
combined3: {
|
|
201
|
+
children: {
|
|
202
|
+
field4: {
|
|
203
|
+
custom: {
|
|
204
|
+
type: 'invalid',
|
|
205
|
+
message:
|
|
206
|
+
'Field is invalid.',
|
|
207
|
+
},
|
|
208
|
+
},
|
|
209
|
+
},
|
|
210
|
+
},
|
|
211
|
+
field3: {
|
|
212
|
+
required: { type: 'invalid' },
|
|
213
|
+
},
|
|
214
|
+
},
|
|
215
|
+
},
|
|
216
|
+
field2: {
|
|
217
|
+
elements: {
|
|
218
|
+
type: 'invalid',
|
|
219
|
+
message:
|
|
220
|
+
'Value must be one of the elements.',
|
|
221
|
+
},
|
|
222
|
+
},
|
|
223
|
+
},
|
|
160
224
|
},
|
|
161
|
-
|
|
162
|
-
|
|
225
|
+
field1: {
|
|
226
|
+
elements: {
|
|
227
|
+
type: 'invalid',
|
|
228
|
+
message: 'Value must be one of the elements.',
|
|
229
|
+
},
|
|
163
230
|
},
|
|
164
231
|
},
|
|
165
|
-
isValid:
|
|
232
|
+
isValid: false,
|
|
166
233
|
} );
|
|
167
234
|
} );
|
|
168
235
|
} );
|
|
236
|
+
} );
|
|
237
|
+
|
|
238
|
+
describe( 'isValid.required', () => {
|
|
239
|
+
const REQUIRED_MESSAGE = {
|
|
240
|
+
required: { type: 'invalid' },
|
|
241
|
+
};
|
|
169
242
|
|
|
170
243
|
it( 'array is invalid when required but empty', () => {
|
|
171
244
|
const item = { id: 1, tags: [] };
|
|
@@ -542,5 +615,217 @@ describe( 'useFormValidity', () => {
|
|
|
542
615
|
} );
|
|
543
616
|
expect( isValid ).toBe( false );
|
|
544
617
|
} );
|
|
618
|
+
|
|
619
|
+
describe( 'async', () => {
|
|
620
|
+
it( 'is valid when validity object only contains type:valid messages', async () => {
|
|
621
|
+
const item = {
|
|
622
|
+
id: 1,
|
|
623
|
+
title: 'Valid Title',
|
|
624
|
+
status: 'published',
|
|
625
|
+
};
|
|
626
|
+
const fields: Field< {} >[] = [
|
|
627
|
+
{
|
|
628
|
+
id: 'title',
|
|
629
|
+
type: 'text',
|
|
630
|
+
isValid: {
|
|
631
|
+
custom: async () =>
|
|
632
|
+
await new Promise( ( resolve ) =>
|
|
633
|
+
setTimeout( resolve, 5 )
|
|
634
|
+
).then( () => null ),
|
|
635
|
+
},
|
|
636
|
+
},
|
|
637
|
+
{
|
|
638
|
+
id: 'status',
|
|
639
|
+
type: 'text',
|
|
640
|
+
isValid: {
|
|
641
|
+
custom: async () =>
|
|
642
|
+
await new Promise( ( resolve ) =>
|
|
643
|
+
setTimeout( resolve, 5 )
|
|
644
|
+
).then( () => null ),
|
|
645
|
+
},
|
|
646
|
+
},
|
|
647
|
+
];
|
|
648
|
+
const form = { fields: [ 'title', 'status' ] };
|
|
649
|
+
const { result } = renderHook( () =>
|
|
650
|
+
useFormValidity( item, fields, form )
|
|
651
|
+
);
|
|
652
|
+
|
|
653
|
+
await waitFor( () => {
|
|
654
|
+
expect( result.current ).toEqual( {
|
|
655
|
+
validity: {
|
|
656
|
+
title: {
|
|
657
|
+
custom: { type: 'valid', message: 'Valid' },
|
|
658
|
+
},
|
|
659
|
+
status: {
|
|
660
|
+
custom: { type: 'valid', message: 'Valid' },
|
|
661
|
+
},
|
|
662
|
+
},
|
|
663
|
+
isValid: true,
|
|
664
|
+
} );
|
|
665
|
+
} );
|
|
666
|
+
} );
|
|
667
|
+
|
|
668
|
+
it( 'is invalid and message is "Validating…" when promise is in flight', async () => {
|
|
669
|
+
const item = {
|
|
670
|
+
id: 1,
|
|
671
|
+
title: 'Invalid Title',
|
|
672
|
+
status: 'published',
|
|
673
|
+
};
|
|
674
|
+
const fields: Field< {} >[] = [
|
|
675
|
+
{
|
|
676
|
+
id: 'title',
|
|
677
|
+
type: 'text',
|
|
678
|
+
isValid: {
|
|
679
|
+
// This promise is never resolved.
|
|
680
|
+
// Serves to test in flight behavior of validation.
|
|
681
|
+
custom: async () => await new Promise( () => {} ),
|
|
682
|
+
},
|
|
683
|
+
},
|
|
684
|
+
];
|
|
685
|
+
const form = { fields: [ 'title' ] };
|
|
686
|
+
const { result } = renderHook( () =>
|
|
687
|
+
useFormValidity( item, fields, form )
|
|
688
|
+
);
|
|
689
|
+
|
|
690
|
+
await waitFor( () => {
|
|
691
|
+
expect( result.current ).toEqual( {
|
|
692
|
+
validity: {
|
|
693
|
+
title: {
|
|
694
|
+
custom: {
|
|
695
|
+
type: 'validating',
|
|
696
|
+
message: 'Validating…',
|
|
697
|
+
},
|
|
698
|
+
},
|
|
699
|
+
},
|
|
700
|
+
isValid: false,
|
|
701
|
+
} );
|
|
702
|
+
} );
|
|
703
|
+
} );
|
|
704
|
+
|
|
705
|
+
it( 'is invalid when validity object contains at least one type:invalid message', async () => {
|
|
706
|
+
const item = {
|
|
707
|
+
id: 1,
|
|
708
|
+
title: 'Invalid Title',
|
|
709
|
+
status: 'published',
|
|
710
|
+
};
|
|
711
|
+
const fields: Field< {} >[] = [
|
|
712
|
+
{
|
|
713
|
+
id: 'title',
|
|
714
|
+
type: 'text',
|
|
715
|
+
isValid: {
|
|
716
|
+
custom: async () =>
|
|
717
|
+
await new Promise( ( resolve ) =>
|
|
718
|
+
setTimeout( resolve, 5 )
|
|
719
|
+
).then( () => 'Title is invalid.' ),
|
|
720
|
+
},
|
|
721
|
+
},
|
|
722
|
+
];
|
|
723
|
+
const form = { fields: [ 'title' ] };
|
|
724
|
+
const { result } = renderHook( () =>
|
|
725
|
+
useFormValidity( item, fields, form )
|
|
726
|
+
);
|
|
727
|
+
|
|
728
|
+
await waitFor( () => {
|
|
729
|
+
expect( result.current ).toEqual( {
|
|
730
|
+
validity: {
|
|
731
|
+
title: {
|
|
732
|
+
custom: {
|
|
733
|
+
type: 'invalid',
|
|
734
|
+
message: 'Title is invalid.',
|
|
735
|
+
},
|
|
736
|
+
},
|
|
737
|
+
},
|
|
738
|
+
isValid: false,
|
|
739
|
+
} );
|
|
740
|
+
} );
|
|
741
|
+
} );
|
|
742
|
+
|
|
743
|
+
it( 'is invalid when custom returns anything other than null or a string', async () => {
|
|
744
|
+
const item = {
|
|
745
|
+
id: 1,
|
|
746
|
+
title: 'Invalid Title',
|
|
747
|
+
status: 'published',
|
|
748
|
+
};
|
|
749
|
+
const fields: Field< {} >[] = [
|
|
750
|
+
{
|
|
751
|
+
id: 'title',
|
|
752
|
+
type: 'text',
|
|
753
|
+
isValid: {
|
|
754
|
+
// @ts-ignore returns wrong type for testing purposes
|
|
755
|
+
custom: async () =>
|
|
756
|
+
await new Promise( ( resolve ) =>
|
|
757
|
+
setTimeout( resolve, 5 )
|
|
758
|
+
).then( () => 3 ),
|
|
759
|
+
},
|
|
760
|
+
},
|
|
761
|
+
];
|
|
762
|
+
const form = { fields: [ 'title' ] };
|
|
763
|
+
const { result } = renderHook( () =>
|
|
764
|
+
useFormValidity( item, fields, form )
|
|
765
|
+
);
|
|
766
|
+
|
|
767
|
+
await waitFor( () => {
|
|
768
|
+
expect( result.current ).toEqual( {
|
|
769
|
+
validity: {
|
|
770
|
+
title: {
|
|
771
|
+
custom: {
|
|
772
|
+
type: 'invalid',
|
|
773
|
+
message:
|
|
774
|
+
'Validation could not be processed.',
|
|
775
|
+
},
|
|
776
|
+
},
|
|
777
|
+
},
|
|
778
|
+
isValid: false,
|
|
779
|
+
} );
|
|
780
|
+
} );
|
|
781
|
+
} );
|
|
782
|
+
|
|
783
|
+
it( 'is invalid when promise was rejected', async () => {
|
|
784
|
+
const item = {
|
|
785
|
+
id: 1,
|
|
786
|
+
title: 'Invalid Title',
|
|
787
|
+
status: 'published',
|
|
788
|
+
};
|
|
789
|
+
const fields: Field< {} >[] = [
|
|
790
|
+
{
|
|
791
|
+
id: 'title',
|
|
792
|
+
type: 'text',
|
|
793
|
+
isValid: {
|
|
794
|
+
custom: async () =>
|
|
795
|
+
await new Promise( ( resolve, reject ) =>
|
|
796
|
+
setTimeout(
|
|
797
|
+
() =>
|
|
798
|
+
reject(
|
|
799
|
+
new Error(
|
|
800
|
+
'Validation did not complete successfully.'
|
|
801
|
+
)
|
|
802
|
+
),
|
|
803
|
+
5
|
|
804
|
+
)
|
|
805
|
+
),
|
|
806
|
+
},
|
|
807
|
+
},
|
|
808
|
+
];
|
|
809
|
+
const form = { fields: [ 'title' ] };
|
|
810
|
+
const { result } = renderHook( () =>
|
|
811
|
+
useFormValidity( item, fields, form )
|
|
812
|
+
);
|
|
813
|
+
|
|
814
|
+
await waitFor( () => {
|
|
815
|
+
expect( result.current ).toEqual( {
|
|
816
|
+
validity: {
|
|
817
|
+
title: {
|
|
818
|
+
custom: {
|
|
819
|
+
type: 'invalid',
|
|
820
|
+
message:
|
|
821
|
+
'Validation did not complete successfully.',
|
|
822
|
+
},
|
|
823
|
+
},
|
|
824
|
+
},
|
|
825
|
+
isValid: false,
|
|
826
|
+
} );
|
|
827
|
+
} );
|
|
828
|
+
} );
|
|
829
|
+
} );
|
|
545
830
|
} );
|
|
546
831
|
} );
|
package/src/types/dataform.ts
CHANGED
|
@@ -6,7 +6,7 @@ import type { Field, FieldValidity } from './field-api';
|
|
|
6
6
|
/**
|
|
7
7
|
* DataForm layouts.
|
|
8
8
|
*/
|
|
9
|
-
export type LayoutType = 'regular' | 'panel' | 'card' | 'row';
|
|
9
|
+
export type LayoutType = 'regular' | 'panel' | 'card' | 'row' | 'details';
|
|
10
10
|
export type LabelPosition = 'top' | 'side' | 'none';
|
|
11
11
|
|
|
12
12
|
export type PanelSummaryField = string | string[];
|
|
@@ -97,32 +97,47 @@ export type NormalizedRowLayout = {
|
|
|
97
97
|
styles: Record< string, { flex?: React.CSSProperties[ 'flex' ] } >;
|
|
98
98
|
};
|
|
99
99
|
|
|
100
|
-
export type
|
|
100
|
+
export type DetailsLayout = {
|
|
101
|
+
type: 'details';
|
|
102
|
+
summary?: string;
|
|
103
|
+
};
|
|
104
|
+
export type NormalizedDetailsLayout = {
|
|
105
|
+
type: 'details';
|
|
106
|
+
summary: string;
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
export type Layout =
|
|
110
|
+
| RegularLayout
|
|
111
|
+
| PanelLayout
|
|
112
|
+
| CardLayout
|
|
113
|
+
| RowLayout
|
|
114
|
+
| DetailsLayout;
|
|
101
115
|
export type NormalizedLayout =
|
|
102
116
|
| NormalizedRegularLayout
|
|
103
117
|
| NormalizedPanelLayout
|
|
104
118
|
| NormalizedCardLayout
|
|
105
|
-
| NormalizedRowLayout
|
|
119
|
+
| NormalizedRowLayout
|
|
120
|
+
| NormalizedDetailsLayout;
|
|
106
121
|
|
|
107
122
|
export type NormalizedSummaryField =
|
|
108
123
|
| NormalizedPanelSummaryField
|
|
109
124
|
| NormalizedCardSummaryField;
|
|
110
125
|
|
|
111
|
-
export type
|
|
126
|
+
export type FormField = {
|
|
112
127
|
id: string;
|
|
128
|
+
label?: string;
|
|
129
|
+
description?: string;
|
|
113
130
|
layout?: Layout;
|
|
131
|
+
children?: Array< FormField | string >;
|
|
114
132
|
};
|
|
115
|
-
|
|
116
|
-
export type CombinedFormField = {
|
|
133
|
+
export type NormalizedFormField = {
|
|
117
134
|
id: string;
|
|
135
|
+
layout: NormalizedLayout;
|
|
118
136
|
label?: string;
|
|
119
137
|
description?: string;
|
|
120
|
-
|
|
121
|
-
children: Array< FormField | string >;
|
|
138
|
+
children?: NormalizedFormField[];
|
|
122
139
|
};
|
|
123
140
|
|
|
124
|
-
export type FormField = SimpleFormField | CombinedFormField;
|
|
125
|
-
|
|
126
141
|
/**
|
|
127
142
|
* The form configuration.
|
|
128
143
|
*/
|
|
@@ -130,6 +145,10 @@ export type Form = {
|
|
|
130
145
|
layout?: Layout;
|
|
131
146
|
fields?: Array< FormField | string >;
|
|
132
147
|
};
|
|
148
|
+
export type NormalizedForm = {
|
|
149
|
+
layout: NormalizedLayout;
|
|
150
|
+
fields: NormalizedFormField[];
|
|
151
|
+
};
|
|
133
152
|
|
|
134
153
|
export interface DataFormProps< Item > {
|
|
135
154
|
data: Item;
|
|
@@ -143,7 +162,7 @@ export type FormValidity = Record< string, FieldValidity > | undefined;
|
|
|
143
162
|
|
|
144
163
|
export interface FieldLayoutProps< Item > {
|
|
145
164
|
data: Item;
|
|
146
|
-
field:
|
|
165
|
+
field: NormalizedFormField;
|
|
147
166
|
onChange: ( value: any ) => void;
|
|
148
167
|
hideLabelFromVision?: boolean;
|
|
149
168
|
validity?: FieldValidity;
|
package/src/types/dataviews.ts
CHANGED
|
@@ -269,7 +269,33 @@ export interface ViewPickerGrid extends ViewBase {
|
|
|
269
269
|
};
|
|
270
270
|
}
|
|
271
271
|
|
|
272
|
-
export
|
|
272
|
+
export interface ViewPickerTable extends ViewBase {
|
|
273
|
+
type: 'pickerTable';
|
|
274
|
+
|
|
275
|
+
layout?: {
|
|
276
|
+
/**
|
|
277
|
+
* The styles for the columns.
|
|
278
|
+
*/
|
|
279
|
+
styles?: Record< string, ColumnStyle >;
|
|
280
|
+
|
|
281
|
+
/**
|
|
282
|
+
* The density of the view.
|
|
283
|
+
*/
|
|
284
|
+
density?: Density;
|
|
285
|
+
|
|
286
|
+
/**
|
|
287
|
+
* Whether the view allows column moving.
|
|
288
|
+
*/
|
|
289
|
+
enableMoving?: boolean;
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
export type View =
|
|
294
|
+
| ViewList
|
|
295
|
+
| ViewGrid
|
|
296
|
+
| ViewTable
|
|
297
|
+
| ViewPickerGrid
|
|
298
|
+
| ViewPickerTable;
|
|
273
299
|
|
|
274
300
|
interface ActionBase< Item > {
|
|
275
301
|
/**
|
|
@@ -428,16 +454,24 @@ export interface ViewPickerGridProps< Item >
|
|
|
428
454
|
view: ViewPickerGrid;
|
|
429
455
|
}
|
|
430
456
|
|
|
457
|
+
export interface ViewPickerTableProps< Item >
|
|
458
|
+
extends Omit< ViewPickerBaseProps< Item >, 'view' > {
|
|
459
|
+
view: ViewPickerTable;
|
|
460
|
+
}
|
|
461
|
+
|
|
431
462
|
export type ViewProps< Item > =
|
|
432
463
|
| ViewTableProps< Item >
|
|
433
464
|
| ViewGridProps< Item >
|
|
434
465
|
| ViewListProps< Item >;
|
|
435
466
|
|
|
436
|
-
export type ViewPickerProps< Item > =
|
|
467
|
+
export type ViewPickerProps< Item > =
|
|
468
|
+
| ViewPickerGridProps< Item >
|
|
469
|
+
| ViewPickerTableProps< Item >;
|
|
437
470
|
|
|
438
471
|
export interface SupportedLayouts {
|
|
439
472
|
list?: Omit< ViewList, 'type' >;
|
|
440
473
|
grid?: Omit< ViewGrid, 'type' >;
|
|
441
474
|
table?: Omit< ViewTable, 'type' >;
|
|
442
475
|
pickerGrid?: Omit< ViewPickerGrid, 'type' >;
|
|
476
|
+
pickerTable?: Omit< ViewPickerTable, 'type' >;
|
|
443
477
|
}
|