Getting Started with SPFx Form Customizer

Form customizers are SharePoint Framework components that allow you to override the form experience in a list or library level by associating the component to the used content type. Form customizer components can be used in SharePoint Online, and you build them using modern JavaScript tools and libraries.

Create lists structure

Create the list structure as described below. You can follow the steps below or download the PnP Template Customers List PnP Template to create the following structure.

  1. Create a Project list for lookup
  2. Create a content type called Customer
  3. Crate a Customers list and associated above Customer content type
  • Create Projects list
    Create a Projects list with the following fields. I have not used any content type with the Projects list, but you can set it up however you want. The project list used for a lookup column Projects in the Customers list

    Name Type Settings
    Title Single Line of text
    Status Choices In Progress, Completed, On Hold
    Members Person or Group
    StartDate DateTime

Populate the project list with some sample data. So that the projects will be available to select when we create a new item in the Customers list

  • Create Customer Content Type
    Create a Customer content type with the following fields

    Name Type Settings
    Title Single Line of text
    Email Single Line of text
    Address Multiple lines of text
    Projects Lookup Lookup to Projects list
    Interests Choices Decorating, Diving, Livestreaming, Drawing, Kung fu,
  • Create Customers List
    Create a Customers list and associate the Customer content type created in the above step.

At this point, you have will Customers list ready to test SPFx Form Customizer.

Create a Form Customizer extension project

  1. Create a new extension by running the Yeoman SharePoint Generator.

    yo @microsoft/sharepoint

  2. When prompted, enter the following values (select the default option for all prompts omitted below):

  • What is your solution name?: cc-formcustomizer-customers
  • Which type of client-side component to create?: Extension
  • Which type of client-side extension to create? Form Customizer
  • What is your Form Customizer name? Customers
  • Which template would you like to use?: react

At this point, Yeoman installs the required dependencies and scaffolds the solution files along with the HelloWorld extension. This might take a few minutes.

Debug Form customizer extension

  1. Open the serve.json file located under config folder and update the pageUrl and RootFolder
    pageUrl
    Site URL of the Customers list
    RootFolder
    Relative path of the Customers list
    After the changes, your serve.json should look like the following code:
{
"$schema": "https://developer.microsoft.com/json-schemas/core-build/serve.schema.json",
"port": 4321,
"https": true,
"serveConfigurations": {
"default": {
"pageUrl": "https://ejazhussain.sharepoint.com/sites/dev/_layouts/15/SPListForm.aspx",
"formCustomizer": {
"componentId": "61d237b3-a18d-4a84-a9e3-31085547d19a",
"PageType": 8,
"RootFolder": "/sites/dev/Lists/Customers",
"properties": {
"sampleText": "Value"
}
}
},
"Customers_NewForm": {
"pageUrl": "https://ejazhussain.sharepoint.com/sites/dev/_layouts/15/SPListForm.aspx",
"formCustomizer": {
"componentId": "61d237b3-a18d-4a84-a9e3-31085547d19a",
"PageType": 8,
"RootFolder": "/sites/dev/Lists/Customers",
"properties": {
"sampleText": "Value"
}
}
},
"Customers_EditForm": {
"pageUrl": "https://ejazhussain.sharepoint.com/sites/dev/_layouts/15/SPListForm.aspx",
"formCustomizer": {
"componentId": "61d237b3-a18d-4a84-a9e3-31085547d19a",
"PageType": 6,
"RootFolder": "/sites/dev/Lists/Customers",
"ID": 1,
"properties": {
"sampleText": "Value"
}
}
},
"Customers_ViewForm": {
"pageUrl": "https://ejazhussain.sharepoint.com/sites/dev/_layouts/15/SPListForm.aspx",
"formCustomizer": {
"componentId": "61d237b3-a18d-4a84-a9e3-31085547d19a",
"PageType": 4,
"RootFolder": "/sites/dev/Lists/Customers",
"ID": 217,
"properties": {
"sampleText": "Value"
}
}
}
}
}
  1. You can see multiple configurations that can be used to debug new, edit and view forms with specific query parameter differences. You can define the used configuration in your gulp serve command, for example as
    console gulp serve --config=Customers_EditForm
    This will start your default browser and load the page defined in serve.json file.
  2. Accept the loading of debug manifests by selecting Load debug scripts when prompted.
  3. This is an initial rendering of SPFx form customizer. You will have the entire canvas below highlighted in red to create custom list forms. You can build a custom list form experience for the following display modes
    • New Form
    • Edit Form
    • View Form

Form Customizer Initial Rendering

Custom List Forms Experience

I have created the following custom list forms experience to overcome some limitations we had with the OOTB list experience. For examples

  • Lookup Column
    Selecting items from the extensive lookup list
  • Conditionally show fields
    Showing or hiding fields based on form logic

Tip

You can find the complete source code from GitHub.

  1. View List Form
    Form Customizer New List Form
  2. Edit List Form
    Form Customizer Edit List Form
  3. New List Form
    Form Customizer New List Form

Deploy Form Customizer Extension

A few steps are related to the component associated with the content type. The steps for deployment are as follows:

  1. Deploy the solution to SharePoint App Catalog

  2. Install a solution to the site collection where you want to use the extension if you are not using the tenant scoped deployment

  3. Associate the custom component to the content type using the specific properties in the ContentType object. There are two options

    • Associate component to content type using REST or CSOM APIs.
    • You can provision the used list and content type from your solution if you are using site scoped deployment option
  4. Here is a CSOM code to assoicate component to content type. You will be updating the following three properties of the content type. You can get the componentId from serve.json file

    • NewFormClientSideComponentId
    • EditFormClientSideComponentId
    • DisplayFormClientSideComponentId
try
{

var list = clientContext.Web.Lists.GetByTitle("Customers");
clientContext.Load(list, l => l.Title, l => l.ContentTypes.Include(c => c.NewFormClientSideComponentId, c => c.EditFormClientSideComponentId, c => c.DisplayFormClientSideComponentId));
await clientContext.ExecuteQueryAsync();

if (list != null)
{

var contentTypeCollection = list.ContentTypes.ToList().AsQueryable();
var customerCT = contentTypeCollection.Where(c => c.Name == contentTypeName).FirstOrDefault();
if (customerCT != null)
{
customerCT.NewFormClientSideComponentId = componentId;
customerCT.EditFormClientSideComponentId = componentId;
customerCT.DisplayFormClientSideComponentId = componentId;

customerCT.Update(false);
await clientContext.ExecuteQueryAsync();

Console.ForegroundColor = ConsoleColor.Green;
Console.WriteLine(contentTypeName + " content type form component ID's updated");
}
}
}
catch (Exception ex)
{
throw new Exception(ex.Message, ex);
}
Author: Ejaz Hussain
Link: https://office365clinic.com/2022/07/10/getting-started-with-spfx-form-customizer/
Copyright Notice: All articles in this blog are licensed under CC BY-NC-SA 4.0 unless stating additionally.