UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

38 lines (37 loc) 1.09 kB
"use client"; import React, { useCallback, useContext, useReducer } from 'react'; import DataContext from "../DataContext/Context.js"; import Log from "./Log.js"; import useEventListener from "../DataContext/Provider/useEventListener.js"; function Errors({ label }) { const [, forceUpdate] = useReducer(() => ({}), {}); const { fieldErrorRef, errorsRef } = useContext(DataContext); const fieldErrors = Object.keys(fieldErrorRef?.current || {}).reduce((acc, key) => { acc[key] = fieldErrorRef?.current[key]?.message; return acc; }, {}); const formErrors = Object.keys(errorsRef?.current || {}).reduce((acc, key) => { acc[key || '/'] = errorsRef?.current[key]?.message; return acc; }, {}); const handleSetFieldError = useCallback(() => { forceUpdate(); }, []); useEventListener('onSetFieldError', handleSetFieldError); const data = { fieldErrors, formErrors }; return React.createElement(Log, { data: data, label: label }); } Errors._supportsSpacingProps = true; export default Errors; //# sourceMappingURL=Errors.js.map