commercetools Frontend comes with an out-of-the-box Amplience extension to integrate Amplience in your commercetools Frontend project.
With the extension you can deliver content from Amplience, such as images, videos, and other media assets, to your commercetools Frontend website.
For demonstration purposes, in this document you will learn how to render on your commercetools Frontend website one or multiple blog posts that you created on Amplience.
- An Amplience account
- An Amplience Content Hub to store your content and media assets. To create a Content Hub, log in to your Amplience account and request Amplience support to create it.
content-amplience extension is not available in your commercetools Frontend project at this path packages/PROJECT_NAME/backend, before proceeding with the following configurations, you must:- Copy the content-amplienceextension from the scaffold repository to your project.
- Register the extension in your project.
Get started
To start using the Amplience extension, follow these steps:
- 
Add the following project configuration field to the project schema from the Studio.{ "name": "Amplience Extension", "fields": [ { "label": "Amplience Hub Name", "field": "EXTENSION_AMPLIENCE_HUB_NAME", "type": "encrypted", "translatable": false, "required": true } ] }
- 
Set the value for the Amplience Hub Name configuration field from the Studio.The value must match the name of the Amplience Content Hub you created as a prerequisite. 
Deliver content with the Amplience extension
To deliver any type of media content with the Amplience extension you must follow these steps:
- 
Create content on Amplience (create the content type schema, content type, and content items).
- 
Add the Frontend components to a dedicated page version in the Studio.
In this document, we present an example of how to render one or multiple blog posts.
Create content on Amplience
To use the Amplience extension, you need to create on Amplience the content that you want to deliver on your website. In this example, we create three blog content items.
To create the blog content items, follow these steps:
- 
Create a content type schema using the following schema for the blog content.{ "$schema": "http://json-schema.org/draft-07/schema#", "$id": "https://schema-cofe.com/blog", "title": "Blog", "description": "Blog", "allOf": [ { "$ref": "http://bigcontent.io/cms/schema/v1/core#/definitions/content" } ] "type": "object", "properties": { "title": { "title": "Title", "description": "The blog's title", "allOf": [ { "$ref": "http://bigcontent.io/cms/schema/v1/localization#/definitions/localized-string" } ] }, "banner": { "title": "Banner", "allOf": [ { "$ref": "http://bigcontent.io/cms/schema/v1/core#/definitions/image-link" } ] }, "summary": { "title": "Summary", "description": "Short summary on what the blog is about.", "type": "string", "format": "markdown" } }, "propertyOrder": [] }
- 
Use the Blog content type schema you created to register a content type.
- 
Create three blog content items by selecting the Blog content type you created and adding content of your choice such as text, images, videos, or other media assets. In this example, we call the content items Blog 1, Blog 2, and Blog 3. You have now created three blog content items on Amplience.
Upload data source schemas
- amplience/contentto fetch a single content item from Amplience.
- amplience/content-listto fetch multiple content items from Amplience with filters and configurations.
{
  "name": "Amplience Content",
  "customDataSourceType": "amplience/content",
  "category": "Content",
  "icon": "source",
  "schema": [
    {
      "name": "Content Selection",
      "fields": [
        {
          "label": "Content ID",
          "field": "contentId",
          "type": "text",
          "translatable": false
        }
      ]
    }
  ]
}
{
  "name": "Amplience Content List",
  "customDataSourceType": "amplience/content-list",
  "category": "Content",
  "icon": "bookmark",
  "schema": [
    {
      "name": "Configuration",
      "fields": [
        {
          "label": "Content Type",
          "field": "contentType",
          "type": "text",
          "translatable": false
        },
        {
          "label": "Limit",
          "field": "limit",
          "type": "number",
          "default": 12
        }
      ]
    },
    {
      "name": "Advanced",
      "fields": [
        {
          "label": "Filters",
          "field": "filters",
          "type": "text",
          "translatable": false
        },
        {
          "type": "description",
          "text": "In the format of white space separated key-value pairs. For example, sorting1=val1 sorting2=val2"
        },
        {
          "label": "Sorting",
          "field": "sort",
          "type": "text",
          "translatable": false
        },
        {
          "type": "description",
          "text": "In the format of white space separated key-value pairs. For example, filter1=val1 filter2=val2"
        },
        {
          "label": "Resolve hierarchy tree",
          "field": "resolveHierarchyTree",
          "type": "boolean",
          "default": false
        }
      ]
    }
  ]
}
Create Frontend components
- amplience/contentto fetch a single content item from Amplience.
- amplience/content-listto fetch multiple content items from Amplience with filters and configurations.
To create the components, follow these steps:
- 
Create the Frontend component schemas by uploading the following schemas to the Studio.{ "tasticType": "commercetools/ui/content/blog", "name": "commercetools UI Amplience Blog", "icon": "bookmark", "category": "Content", "schema": [ { "name": "Content", "fields": [ { "label": "Amplience Content", "field": "data", "type": "dataSource", "dataSourceType": "amplience/content", "required": true } ] } ] }{ "tasticType": "commercetools/ui/content/blog-list", "name": "commercetools UI Amplience Blog List", "icon": "bookmark", "category": "Content", "schema": [ { "name": "Content", "fields": [ { "label": "Amplience Content", "field": "data", "type": "dataSource", "dataSourceType": "amplience/content-list", "required": true } ] } ] }
- 
In your commercetools Frontend project undercomponents/commercetools-ui/content/blog, add the followingindex.tsxfile for theBlogReact component.const Blog = ({ title, summary, banner }) => { return ( <div className="w-[280px]"> <h4 className="py-4 pr-8 text-lg font-bold dark:text-white"> {title} </h4> <div className="relative h-[160px] w-[280px]"> <Image src={banner} objectFit="cover" layout="fill" className="rounded-sm" /> </div> <p className="box-border pt-4 pr-4 dark:text-white">{summary}</p> </div> ); };
- 
In your commercetools Frontend project, add theindex.tsxfiles for theamplience-blogandamplience-blog-listFrontend components.- 
Add the followingindex.tsxfile undertastics/content/amplience-blog.import React from 'react'; import Blog, { Props } from 'components/commercetools-ui/content/blog'; const BlogTastic = ({ data }) => { const blog = data?.data?.dataSource as Props; if (!blog) return <></>; }; export default BlogTastic;
- 
Add the followingindex.tsxfile undertastics/content/amplience-blog-list.import React from 'react'; import Blog, { Props } from 'components/commercetools-ui/content/blog'; const BlogListTastic = ({ data }) => { const blogs = (data?.data?.dataSource ?? []) as Props[]; return ( <div className="flex flex-wrap items-center gap-4"> {blogs.map((blog) => ( <Blog key={blog._meta.deliveryId} {...blog} /> ))} </div> ); }; export default BlogListTastic;
 
- 
- 
Reference theindex.tsxfiles for theamplience-blogandamplience-blog-listFrontend components in theindex.tsxfile underfrontastic/tastics.export const tastics = { ... 'commercetools/ui/checkout': Checkout, 'commercetools/ui/thank-you': ThankYou, 'commercetools/ui/cart': Cart, 'commercetools/ui/footer': Footer, 'commercetools/ui/header': Header, 'commercetools/ui/content/amplience-blog': BlogTastic, 'commercetools/ui/content/amplience-blog-list': BlogListTastic, 'commercetools/ui/content/tile': Tile, 'commercetools/ui/content/spacer': Spacer, 'commercetools/ui/content/showcase': Showcase, ... default: NotFound, };
Add data sources and configure data source filters
To add the data sources to the page folder and configure the data source filters, follow these steps:
- 
If necessary, create a page folder. Otherwise, from the Studio home page or from the left menu, go to Site builder.
- 
In the page folder list, hold the pointer over the page folder where you want to render the content and click the Settings icon: the Page folder settings dialog opens.
- 
In the Data source section, click + Add data source filter: the list of the available data sources opens. From the list, you can select the Amplience Content and Amplience Content List data sources. When you select a data source, the data source filter editor opens.
- 
Configure the data source filters as follows and save: - For the Amplience Content data source: in the Content ID field, enter the Content ID of the Amplience content item that you want to render. In this example, we enter the Content ID of the Blog 1 content item that we created.
- For the Amplience Content List data source:
- In Configuration > Content Type field, enter the unique URL of your Amplience content type schema. In this example, we enter the URL of the Blog content type schema that we created.
- In Configuration > Limit, set the maximum number of content items that you want to retrieve.
 
 
Add Frontend components to the page version
To add the Frontend components to the page version, follow these steps:
- 
If necessary, create a page version. Otherwise, from the Studio home page or from the left menu, go to Site builder.
- 
Use the page folder list and the status sections to navigate to the page version where you want to add the Frontend component. Then, hold the pointer over the page version and click the Edit icon: the page builder opens.
- 
Edit the layout of the page version as you wish. In this example, we add a 1/1 layout element to the MAIN layout section.
- 
Use the Components pane to find the Frontend component to add. Then, drag it to the layout element. In this example, we drag both the Amplience Blog and the Amplience Blog List Frontend components to the 1/1 layout element.
- 
Select the Frontend component. Then, in Component settings > Content select the data source to associate to the Frontend component. In this example, we select Amplience Content for the Amplience Blog Frontend component and Amplience Content List for the Amplience Blog List Frontend component.  
- 
Preview and save your changes. Your Amplience content is now rendered on your commercetools Frontend website.