Skip to content

Create your own component

Eufemia Forms contains helper fields and tools so you can declaratively create interactive form components that flawlessly integrates between existing data and your custom form components.

By using the building blocks for field components, you save development time, and at the same time ensure that local, custom components work similarly, and fit into the setup with the standardized field components.

import {
DataContext,
Field,
FieldBlock,
Iterate,
Value,
ValueBlock,
Visibility,
useDataValue,
} from '@dnb/eufemia/extensions/forms'

More details

Here is an example of a custom component. Notice how the props received by your field component are passed through the useDataValue hook. This hook does not change the API of the props, so the props returned by the hook share the same typescript type with which it was called. However, it adds a few additional properties to simplify the standardization of field behavior. This in the form of the handler functions handleFocus, handleChange and handleBlur. Even if field components externally have these callback functions named with "on" (eg "onChange"), these will remain untouched, while the "handle" variants add handling that saves you a lot of extra work.

The example explained

In the example above, you see how you can create your own user input functionality in a standardized context using FieldBlock. This allows you to display labels, error messages and other surrounding elements in a consistent manner with the ready-made fields found in Eufemia Forms.

When you call these three functions as used above from your own implementation of the user experience for the field component, a lot will happen in the background. All available validation functions will be called at the right time, changes in value will be synchronized with any surrounding DataContext, co-operation between several fields that should display error messages collectively instead of individually, and not least it ensures that error messages are not displayed on unnecessary times such as while the user is making changes to the field.

Remember that everything that happens by using useDataValue and the rest of the available helper functionality, you can override the behavior individually to make the component work exactly as you want.

Your own validation

If – for example; you need to carry out your own custom validation and cannot use the built-in validation with a JSON Schema or by sending in a derivative validator (as is done in the example above), you can write your own logic for it, and send the result in as props to FieldBlock in the form of error. All direct props override standard handling, so you have full control over your component.

Customized even further

If you need something that looks even more different than the usual fields, you can drop FieldBlock and display surrounding elements in other ways – but still get all the help of a data flow logic, such as useDataValue offers.

Here follows an example that retrieves data from a surrounding DataContext, and creates a composite field based on other components from Eufemia:

My custom label

Layout

When building your custom form components, preferably use the Layout component.

Width definitions

These are the official sizes you can use when creating your own form fields.

:root {
--forms-field-width--small: 5rem;
--forms-field-width--medium: 11rem;
--forms-field-width--large: 21rem;
}

You can also use a FieldBlock and provide a width prop with a value of either small, medium or large and use it as a sized wrapper.

Components

FieldBlock

FieldBlock is a reusable wrapper for building Field-components. It shows surrounding elements through properties from FieldProps like label and error, and ensure that spacing between different fields work as required when put into surrounding components like Flex.Container or Card. It can also be used to group multiple inner FieldBlock component, composing error messages together as one component.

ValueBlock

ValueBlock is a reusable wrapper component that can be used to easily create custom Value-components that will display in the same way as other Value-components.


Hooks

useDataValue

The useDataValue hook standardize handling of the value flow for a single consumer component representing one data point. It holds error state, hides it while the field is in focus, connects to surrounding DataContext (if present) and other things that all field or value components needs to do. By implementing custom field or value components and passing the received props through useDataValue, all these features work the same way as other field or value components, and you only need to implement the specific unique features of that component.