Part 3: Adding Sections to the VTEX Headless CMS
caution
This tutorial is intended for those who started their FastStore project with the Store Components starter. If you started your project with the Base Store starter, please refer to this tutorial.
Introduction​
In this part of this tutorial, you'll learn how to make your components available at the VTEX Headless CMS by writing the schemas that describe your frontend components.
Declaring Section schemas​
A schema is written in JSON Schema v6, a description language for creating forms, and rendered as a react-jsonschema-form
in the VTEX Headless CMS.
To define a schema, you must first import the Schema
object from @vtex/gatsby-plugin-cms
in the src/@vtex/gatsby-plugin-cms/index.ts
and then declare your components as in the following example:
import { Schema, BuilderConfig } from '@vtex/gatsby-plugin-cms'
const AwesomeComponent: Schema = {
title: 'My local component',
description: 'Change this description on your src/gatsby-plugin-cms-index.js',
type: 'object',
properties: {
prop1: {
title: 'Default value for prop1',
type: 'string',
},
prop2: {
title: 'Default value for prop2',
type: 'string',
},
},
},
Notice that each component will present a unique structure. However, you'll always need to define at least the following values:
Key | Description |
---|---|
title | The name that identifies your component in the CMS interface. |
description | A brief description to help editors understand the behavior of your component. |
type | The data type of your schema. Possible values are string , object , array , number , integer , boolean . |
Now, depending on the type
of your schema, you may need to define particular fields related to your component structure. For example, for a schema of the object
type, you'll need to determine properties
that map key-value pairs. For a schema of the array
type, you'll need to define the items
of that array.
For more information on each property, check the JSON Schema Reference
.
💡 A helpful feature to write your schema is the
react-jsonschema-form
Playground. This Playground allows you to visualize and validate the React form corresponding to your JSON Schema.
Using widgets​
When defining your Schema, you can also use the uiSchema
along with widgets
to specify which UI widget should be used to render a given field of your schema. Common widgets are draftjs-rich-text
, image-uploader
, and block-select
.
Check the following example of the draftjs-rich-text
component being used.
- Code
- CMS
const RichTextComponent: Schema = {
title: 'Text',
type: 'object',
properties: {
content: {
type: 'string',
title: 'Text',
widget: {
'ui:widget': 'draftjs-rich-text', // custom widget to render the component
},
},
},
},
Exporting Sections​
To export our schemas, we must declare them inside the blocks
property of the builderConfig
object.
import { Schema, BuilderConfig } from '@vtex/gatsby-plugin-cms'
export const builderConfig: BuilderConfig = {
blocks: {
// your sections
AwesomeComponent
},
contentTypes: {
// your content types
home: {
name: 'Home Page',
extraBlocks: {},
},
},
messages: {
// your translation keys
},
}
Now, if you start creating a new Home Page in the VTEX Headless CMS app and click on the +
sign, you will see your AwesomeComponent
available.