Form Fields

Creating custom form field is just a matter of adding a couple of plugins.

If you are not already familiar with how plugins work, we recommend you take a look at the Plugins Crash Course.

First we need to register a plugin with the type form-editor-field-type, which will actually add the field to the form builder.

Let's examine the following example:

// We first import a couple of components that will make the form field creation easier.
import { Cell, Grid } from "@webiny/ui/Grid";
import { I18NInput } from "@webiny/app-i18n/admin/components";
import { Input } from "@webiny/ui/Input";
import { FbBuilderFieldPlugin } from "@webiny/app-form-builder/types";
import { ReactComponent as SecretIcon } from "my-webiny-app/icons/lock.svg";
// The following shows a complete plugin definition for a new "Secrets" form field.
// All of the relevant options are contained in the "field" property.
const secretTextFormField: FbBuilderFieldPlugin = {
type: "form-editor-field-type",
name: "form-editor-field-type-secret-text",
field: {
name: "text-secret",
type: "text",
validators: ["required", "minLength", "maxLength", "pattern"],
label: "Secrets",
description: "A field that hides user's input.",
icon: <SecretIcon />,
createField() {
return {
type: this.type,
validation: [],
settings: {
defaultValue: ""
renderSettings({ form: { Bind } }) {
return (
<Cell span={12}>
<Bind name={"placeholderText"}>
label={"Placeholder text"}
description={"Placeholder text (optional)"}
<Cell span={12}>
<Bind name={"settings.defaultValue"}>
label={"Default value"}
description={"Default value (optional)"}
<Cell span={12}>
<Bind name={"settings.aCustomSetting"}>
label={"A custom setting"}
description={"This can be another custom setting needed for the input."}

With the above plugin properly registered, we should already see our new form field in the form builder! Just try dragging the "Custom" field from the fields menu, and you should see it in the dialog that follows:

Form field registered successfully

Once you click on the icon, we'll be able to see the form that consists of two tabs. And if we take a look at the form in the initial "General" tab, we'll see that at the top we have "Label", "Field ID", and "Help Text" fields (which are present for every field by default), and on the bottom we have three fields we added via the renderSettings function in our plugin.

Form field settings

Last updated on by Pavel Denisjuk