Adding Sitecore integration (v6.0)
This is not the latest version
For documentation on the latest version of the Sitecore connector, see Adding Sitecore integration.
This section describes how to modernize the default Sitecore site. When you are done you will have the Sitecore site running with the following configuration:
- Content managed in Sitecore
- Layout & renderings ported to React components
- CSS ported to front-end
- Front-end managed by Next.js
- Presentation details managed in Uniform Canvas
Prerequisites
- Uniform account (free tier or greater)
- Node.js installed on your machine (version 14 or greater)
- Sitecore instance (8.2, 9.0.2 or greater)
- Sitecore admin user login (e.g. sitecore\admin)
- Uniform connector is installed on your Sitecore instance. If it is not already installed you should install it now.
- Uniform API token from Sitecore instance.
- Npm access token (contact Uniform Product Support if you need one).
info
Communication between the Uniform app and Sitecore is done
entirely client-side using cross-domain requests. This means
the Sitecore instance must be accessible using https://.
This also means the Sitecore instance can be a local instance.
Configure Sitecore Services Client
Configure Sitecore Services Client for Sitecore 8.2
Uniform uses the Sitecore Services Client (SSC) to read content from Sitecore, so SSC must be enabled and configured.
- If SSC is not enabled, you must enable it. The following is an
example of a config file that enables SSC:<configuration>
 <sitecore>
 <settings>
 <setting name="Sitecore.Services.AllowAnonymousUser" value="true" />
 <setting name="Sitecore.Services.AllowItemServiceAnonymousUser" value="true" />
 <setting name="Sitecore.Services.SecurityPolicy" value="Sitecore.Services.Infrastructure.Web.Http.Security.ServicesOnPolicy, Sitecore.Services.Infrastructure" />
 </settings>
 </sitecore>
 </configuration>
- In Website folder, open Web.config and config CORS header<system.webServer>
 <httpProtocol>
 <customHeaders>
 <remove name="X-Powered-By" />
 <add name="Access-Control-Allow-Origin" value="https://uniform.app" />
 </customHeaders>
 </httpProtocol>
 </system.webServer>
- Grant sitecore\servicesAPIuser with access to site items,/sitecore/system/Languages,/sitecore/templatesand/sitecore/system/Uniform
tip
We also recommend that the user sitecore\servicesAPI have
permissions configured that explicitly deny access to the
remaining parts of the content tree. This is the account SSC uses by default
for calls.
Configure Sitecore Services Client for Sitecore 9.0.2 or greater
Uniform uses the Sitecore Services Client (SSC) to read content from Sitecore, so SSC must be enabled and configured.
- If SSC is not enabled, you must enable it. The following is an
example of a config file that enables SSC:<configuration>
 <sitecore>
 <settings>
 <setting name="Sitecore.Services.AllowAnonymousUser" value="true" />
 <setting name="Sitecore.Services.AllowItemServiceAnonymousUser" value="true" />
 <setting name="Sitecore.Services.SecurityPolicy" value="Sitecore.Services.Infrastructure.Web.Http.Security.ServicesOnPolicy, Sitecore.Services.Infrastructure" />
 </settings>
 </sitecore>
 </configuration>
- In Sitecore, open Content Editor.
- Navigate to sitecore > system > Settings > Services > API Keys
- Add the following item:- Template: API Key
- Name: Uniform API Key
 
- Template: 
- Set the following field values:- CORS Origins: https://uniform.app
- Allowed Controllers: Sitecore.Services.Infrastructure.*
- Impersonation User: Name of a Sitecore user with access
to site items, /sitecore/system/Languages,/sitecore/templatesand/sitecore/system/Uniform(for example,sitecore\admin)
 
- CORS Origins: 
- Save the item.
- Publish the item.
- Note the item ID. This is your Sitecore API key. You will need this value later.
tip
We also recommend that the user sitecore\servicesAPI have
permissions configured that explicitly deny access to the
remaining parts of content tree. This is the account SSC uses by default
for calls when an API key is not specified.
Create Uniform project
A Uniform project is where all of the settings related to your web app are configured. You must create a new project for your web app.
- Log into https://uniform.app.
- Click (+) to create a new project.
- Enter the following values and click Continue.- Project name: My Site Project
- Setup option: Empty project
 
- Project name: 
Create Uniform API key
A Uniform API key is needed for both Sitecore and the web app to communicate with Canvas. You must create a new key for your web app
- In Uniform, click the logo in the top-left to return to the home page.
- Navigate to Settings > API Keys.
- Click (+).
- Enter the following values:- Name: My Site key
- Project dropdown: My Site Project
 
- Name: 
- Select the following permissions in the section Uniform Canvas:- Component Library > Manage
- Compositions > Read Draft
- Compositions > Read Published
 
- Click Create API Key.
- Note the value for Key because this is the only time it will be displayed. This is your Uniform API key.
- Note the value for the project My Site Project. This is your Uniform project ID.
- Click Close.
Configure Sitecore site
Canvas will read content from your Sitecore site, but some configuration is needed. This configuration comes in the form of something called site configuration. The Uniform connector on your Sitecore instance uses the site configuration to determine which Uniform functionality to enable. You must create a site configuration for your web app.
tip
Site configuration can be created using Sitecore config files or Sitecore items. These instructions use Sitecore items. The config file approach is recommended for production environments, but using Sitecore items may be easier for some users during development and testing.
- In Content Editor, navigate to sitecore > system > Uniform > SiteConfigurations.
- Add the following item:- Template: Site Configuration
- Name: MySite
 
- Template: 
- Add an item using the template Configure Site.
- Select the child item Configuration.
- Set the following field values:- Inherits: website
 
- Inherits: 
- Save the item.
- Publish the site.
info
Before the Canvas-specific settings can be configured, some other steps must be completed. You will return to the site configuration later.
Add Sitecore integration to Uniform project
In order for Canvas to be able to read content from Sitecore, you must add and configure an integration in your Uniform project.
- In Uniform, click the logo in the top-left to return to the home page.
- Navigate to the project My Site Project.
- Navigate to Settings > Integrations.
- Click Sitecore.
- Click Add Sitecore to this project.
- In the Sitecore configuration screen, enter the following values:- URL of your Sitecore instance: The URL to the root of the Sitecore instance. This must start with https://.
- Sitecore API key: Your Sitecore API key or any GUID if you use Sitecore 8.2
- Site configuration name: MySite
 
- URL of your Sitecore instance: The URL to the root of the Sitecore instance. This must start with 
- Click Save.
- A message will appear to indicate that values were stored. If you see an error message, consider the following troubleshooting steps:- Verify that SSC is configured correctly using /sitecore/admin/showconfig.aspxon your Sitecore instance.
- Verify that the user account defined in Sitecore API key has read access rights to the item /sitecore/system/Uniform/Site Configurations/MySite.
- Check your browser's dev console for client-side error messages.
- Consult with Sitecore SSC documentation.
- Contact Sitecore support regarding SSC connectivity issues.
 
- Verify that SSC is configured correctly using 
Replicate Sitecore layout in Canvas
You need to model the home page from the Sitecore site in Canvas. This involves porting the layout, renderings and presentation details from Sitecore into Canvas.
To get to the presentation:
- In Content Editor, navigate to sitecore > Content > Home.
- In the ribbon, click PRESENTATION.
- In the toolbar, click Details.
- In the Layout Details screen, in the section for the default device, click Sample Layout.
- In the Device Editor screen, click the tab Controls.
If you look at the presentation details assigned to the home item, you will see three controls. These controls represent a fairly complex sort of layout with nested placeholders. This makes this item a good example to use.

- The layout has a rendering Sample Sublayout assigned to the placeholder main.
- The rendering Sample Sublayout has a placeholder centercolumn with a rendering Sample Inner Sublayout assigned to it.
- The rendering Sample Inner Sublayout has a placeholder content with a rendering Sample Rendering assigned to it.
- The rendering Sample Rendering either does not have any placeholders or it has placeholders but no renderings have been assigned to any of them yet.
This is the structure you will replicate in Canvas.
Component: Sample Layout
You must define a Canvas component that represents the Sample Layout from Sitecore.
- In Uniform, click the logo in the top-left to return to the home page.
- Navigate to the project My Site Project.
- Navigate to Canvas > Component Library.
- Click (+)
- In the Add Component Type screen, enter the following values:- Component Name: Sample Layout
- Composition Component: ticked
 
- Component Name: 
- Navigate to Slots
- Click (+)
- In the Add Slot screen, enter the following values:- Slot Name: main
 
- Slot Name: 
- Click OK.
- Click Save and close.
important
By default, when you add a new slot, Uniform generates a Public ID value based on the Slot Name. The Public ID value must match the name of the placeholder exactly.
For example, if you set the Slot Name to My Placeholder, Uniform
will generate the value myPlaceholder. If the name of the placeholder
is my-placeholder, you must manually change the Public ID value to
my-placeholder.
Component: Sample Sublayout
You must define a Canvas component that represents the Sample Sublayout from Sitecore.
- Create another component using the following settings:- Component Name: Sample Sublayout
- Slot Name: centercolumn
 
- Component Name: 
- On the dropdown on the button Save and Close, click Save.
- Click Allow in a slot.
- Select the component Sample Layout.
- Select the slot main.
- Click Allow in Sample Layout's main slot.
- Click Save and close.
Component: Sample Inner Sublayout
You must define a Canvas component that represents the Sample Inner Sublayout from Sitecore.
- Create another component using the following settings:- Component Name: Sample Inner Sublayout
- Slot Name: content
 
- Component Name: 
- On the dropdown on the button Save and Close, click Save.
- Click Allow in a slot.
- Select the component Sample Sublayout.
- Select the slot centercolumn.
- Click Allow in Sample Sublayout's centercolumn slot.
- Click Save and close.
Component: Sample Rendering
You must define a Canvas component that represents the Sample Rendering from Sitecore.
- Create another component using the following settings:- Component Name: Sample Rendering
 
- Component Name: 
- On the dropdown on the button Save and Close, click Save.
- Click Allow in a slot.
- Select the component Sample Inner Sublayout.
- Select the slot content.
- Click Allow in Sample Inner Sublayout's content slot.
- Click Save and close.
Composition: Home Page
You must define a Canvas composition that represents the presentation details from the Home item in Sitecore.
- In the left menu, click Compositions.
- Click (+)
- Enter the following values:- Select a composition type: Sample Layout
- Name: Home Page
 
- Select a composition type: 
- Click Create.
- Under Sample Layout, click (+)
- Click Sample Sublayout.
- Under Sample Sublayout, click (+)
- Click Sample Inner Sublayout.
- Under Sample Inner Sublayout, click (+)
- Click Sample Rendering.
- Click Save and publish.
- In your browsers URL bar, notice the structure of the URL.
The last part of the URL, after /edit/is a GUID. This is your Uniform composition ID. Normally you do not need to note this value, but for this exercise you will need it in a later step.
Create the front-end
In the previous section you used Canvas to describe how to arrange the components that make up a web page. The next step is to implement that actual components that will be used to deliver the digital experience to a visitor. This will be done using the front-end framework Next.js.
In this example you only have a single page, so you don't need to worry about routing.
Create web app
Since you are migrating your site to a new front-end, you must create the web app where you will define that front-end.
- Open a command-line interface (CLI).
- Enter the following commands:npx create-next-app mysite
 cd mysite
- Add a file .envand define the variables in the table below.
| Name | Value | 
|---|---|
| UNIFORM_API_TOKEN | Your Uniform API token | 
| UNIFORM_PROJECT_ID | Your Uniform Project ID | 
| UNIFORM_API_URL | Your Sitecore URL (must use https://) | 
| UNIFORM_API_SITENAME | MySite | 
| UNIFORM_API_KEY | Your Uniform API key | 
| SITECORE_API_KEY | Your Sitecore API key or any GUID if you use Sitecore 8.2 | 
- If your Sitecore instance uses self-signed SSL certificate, define the extra variable:- Name: NODE_TLS_REJECT_UNAUTHORIZED
- Value: 0
 
- Name: 
important
The .env file uses simple file format:
# comment
VARIABLE1_NAME=VARIABLE1_VALUE
VARIABLE2_NAME=VARIABLE2_VALUE
Add npm packages
In order to add Uniform functionality to your web app, you must add a number of npm packages. Some of these packages are publically available and some require an npm access token.
- Set the following environment variable:- Name: NPM_TOKEN
- Value: Your Uniform npm access token
 
- Name: 
- Add a file .npmrc://registry.npmjs.org/:_authToken=${NPM_TOKEN}
- Enter the following commands:npm install dotenv @uniformdev/canvas @uniformdev/canvas-react @uniformdev/canvas-sitecore @uniformdev/cli
 npm install @uniformdev/next-server @uniformdev/common-server @uniformdev/common-client @uniformdev/canvas-sitecore
Add Uniform config
You must configure Next.js to load Uniform settings when it runs.
- Open the file next.config.js.
- Change the contents to the following:const { uniformNextConfig } = require('@uniformdev/next-server');
 module.exports = uniformNextConfig();
Create components
You need to create the React components that are used to implement the front-end. This involves porting code from Sitecore to React. The following files on your Sitecore server represent the presentation logic that you will port to React:
| Component | File | 
|---|---|
| Sample Layout | C:\inetpub\wwwroot\layouts\sample layout.aspx | 
| Sample Sublayout | C:\inetpub\wwwroot\layouts\sample sublayout.ascx | 
| Sample Inner Sublayout | C:\inetpub\wwwroot\layouts\sample inner sublayout.ascx | 
| Sample Rendering | C:\inetpub\wwwroot\xsl\sample rendering.xslt | 
Component: Sample Layout
In this component, the webcontrol sc:placeholder is replaced with a React component Slot.
Create a file components/SampleLayout.jsx:
import Head from 'next/head';
import { Slot } from '@uniformdev/canvas-react';
export function SampleLayout() {
  return (
    <>
      <Head>
        <title>Welcome to Sitecore</title>
      </Head>
      <div id="MainPanel">
        <Slot name="main"></Slot>
      </div>
    </>
  );
}
tip
The Sitecore layout also includes a link to the CSS file /default.css,
which is located on the Sitecore server at C:\inetpub\wwwroot\default.css.
In order for these styles to be applied to your page, the contents
of this css file can be added to the React file styles/global.css.
This file includes a style that sets an image. You must change
the URL to be fully qualified by adding the hostname for your
Sitecore server. For example, https://yoursitecore/-/media/Default Website/cover.ashx.
Component: Sample Sublayout
Create a file components/SampleSublayout.jsx:
import { Slot } from '@uniformdev/canvas-react';
export function SampleSublayout() {
  return (
    <div id="CenterColumn">
      <Slot name="centercolumn"></Slot>
    </div>
  );
}
Component: Sample Inner Sublayout
Create a file components/SampleInnerSublayout.jsx:
import { Slot } from '@uniformdev/canvas-react';
export function SampleInnerSublayout() {
  return (
    <div id="InnerCenter">
      <div id="Header">
        <img src="https://yoursitecore/-/media/Default Website/sc_logo.ashx" alt="Sitecore" id="scLogo" />
      </div>
      <div id="Content">
        <div id="LeftContent">
          <Slot name="content"></Slot>
        </div>
      </div>
      <div id="Footer">
        <hr className="divider" />© {new Date().getFullYear()} Sitecore
      </div>
    </div>
  );
}
important
Replace https://yoursitecore with your actual Sitecore URL.
Next.js will use this URL during the build process.
Component: Sample Rendering
This component displays fields from the Sitecore data source item. If the data source item is not selected, it uses a context item (a page item) instead. Uniform makes the item available as a prop that is passed to the component. In the next section you will wire this up.
Create a file components/SampleRendering.jsx:
export function SampleRendering({ model }) {
  return (
    <div>
      <h1 className="contentTitle">{model.Title}</h1>
      {/* rich text field needs to be rendered via dangerouslySetInnerHTML */}
      <div className="contentDescription" dangerouslySetInnerHTML={{ __html: model.Text }}></div>
    </div>
  );
}
important
The model field name was chosen by a convention that will
be explained in next chapters.
Map component name to implementation
Each component defined in Canvas has a public ID. When your web app reads composition definitions from Canvas, the components that are assigned to the composition are identified using this value.
You must provide instructions to your web app on how to map the public ID to the front-end implementation of that component. In your web app, React components provide that implementation.
Create a file lib/resolveRenderer.jsx:
import { SampleLayout } from '../components/SampleLayout';
import { SampleSublayout } from '../components/SampleSublayout';
import { SampleInnerSublayout } from '../components/SampleInnerSublayout';
import { SampleRendering } from '../components/SampleRendering';
export const resolveRenderer = (component) => {
  // notice this is Public ID, not Component Name - and it is case-sensitive
  if (component.type === 'sampleLayout') {
    return SampleLayout;
  }
  if (component.type === 'sampleSublayout') {
    return SampleSublayout;
  }
  if (component.type === 'sampleInnerSublayout') {
    return SampleInnerSublayout;
  }
  if (component.type === 'sampleRendering') {
    return SampleRendering;
  }
  throw new Error(`Component is not registered: ${component.type}`);
};
Configure page
As its name suggests, the Home Page composition represents the home page for the web app. The Next.js page component must use the React component that represents the composition component.
Replace the contents of the file pages/index.jsx with the following:
import { Composition } from '@uniformdev/canvas-react';
import { resolveRenderer } from '../lib/resolveRenderer';
export default function Home({ composition }) {
  return (
    <Composition data={composition} resolveRenderer={resolveRenderer}>
      {() => resolveRenderer(composition)}
    </Composition>
  );
}
export { getStaticProps } from '../lib/getStaticProps';
info
This code exports the function getStaticProps from a file that
does not exist. This file - and function - will be defined in a
later step.
Define the enhancer
Enhancers are an essential part of how Canvas aggregated data from multiple content sources. An enhancer is used to make content from the Sitecore integration that you configured in your Uniform project available to your web app.
You must inject Sitecore item fields into the composition so that
the component Sample Rendering can display them on the page.
Create a file lib/enhanceComposition.jsx:
import { EnhancerBuilder, enhance } from "@uniformdev/canvas";
import { createItemEnhancer } from '@uniformdev/canvas-sitecore';
export async function enhanceComposition({ composition, config, pageId, pageData, context, isPreview }) {
  const itemEnhancer = createItemEnhancer({
    pageId,
    pageItem: pageData,
    config,
    isPreview,
  });
  const enhancers = new EnhancerBuilder()
    .component('sampleRendering', b => b.data('model', itemEnhancer))
  await enhance({ composition, enhancers, context });
}
important
This enhancer adds props.model property that is used in components/SampleRendering.jsx file
and it will hold all Sitecore fields of the datasource item, or a page item if a datasource
item is not selected. The model term was used instead of item because of a uniform nature
of the frontend components: they can be reused by different systems that don't have
Sitecore's data item concept.
Define getStaticProps
Next.js uses the function getStaticProps during the build
process to save data needed to build the page at runtime.
This function implements the following logic:
- Reads Uniform configuration injected via next.config.js.
- Uses CanvasClientto get composition by its ID.
- Uses getPageInfoto retrieve page data from Sitecore using SSC and Uniform APIs.
- Uses enhanceCompositionto enhance the composition.
Create a file lib/getStaticProps.jsx:
// private @uniformdev npm packages
import { throwException } from '@uniformdev/common';
import { parseUniformServerConfig } from '@uniformdev/common-server';
import { noopLogger } from '@uniformdev/common-client';
import { getPageInfo } from '@uniformdev/canvas-sitecore';
// public @uniformdev npm package
import { CanvasClient, CANVAS_PUBLISHED_STATE } from '@uniformdev/canvas';
// read configuration and prepare
const config = parseUniformServerConfig(process.env, noopLogger, true);
import { enhanceComposition } from './enhanceComposition';
export async function getStaticProps(context) {
  const slug = '/';
  // create the canvas client
  const client = new CanvasClient({
    apiKey: config.env.UNIFORM_API_KEY ?? throwException('The UNIFORM_API_KEY environment variable is missing'),
    projectId: config.env.UNIFORM_PROJECT_ID ?? throwException('The UNIFORM_PROJECT_ID environment variable is missing'),
    apiHost: 'https://uniform.app',
  });
  const { composition } = await client.getCompositionById({
    //
    // for simplicity of this tutorial, hard-code the composition id
    //
    compositionId: 'YOUR_UNIFORM_COMPOSITION_ID'',
    state: CANVAS_PUBLISHED_STATE
  });
  const isPreview = false;
  let { pageId, pageData, } = await getPageInfo({ slug, config, isPreview });
  await enhanceComposition({ composition, pageId, pageData, isPreview });
  // set `composition` as a prop to the route
  return {
    props: {
      composition,
    },
  };
}
important
Replace YOUR_UNIFORM_COMPOSITION_ID' with your Uniform composition
ID. The extra single-quote character was added to cause build-time
error to make sure you don't miss it. The hard-coded value will be
removed in next chapters of this tutorial.
Start the web app
When you run the web app, you should see the page from the default Sitecore site, but Sitecore isn't handling page rendering. Sitecore is only acting as a headless CMS.
- On the CLI, enter the following command:npm run dev
- Open your browser to http://localhost:3000.
Model Builders
Canvas Sitecore integration allows to define a model builder for component. It can be helpful when item fields is not enough and we need to prepare data from backend side.
How to use model builders
Implement Uniform.ModelBuilders.IComponentModelBuilder, Uniform.Platform.Canvas.ModelBuilder interface
public interface IComponentModelBuilder
{
  [CanBeNull]
  object BuildModel(
    [NotNull] Item pageItem,
    [NotNull] Item datasourceItem,
    [NotNull] IReadOnlyDictionary<string, string> parameters
  );
}
pageItem - current page item
datasourceItem - current datasource item (can be the same as a page item)
parameters - key-value parameters defined for component on Canvas composition
<result> - json-serializable object
Register model builder via Sitecore config
<configuration xmlns:set="http://www.sitecore.net/xmlconfig/set/">
    <sitecore>
        <uniform>
            <siteConfigurations>
                <siteConfiguration name="MySite">
                    <canvas>
                        <canvasModelBuilderService ref="uniform/services/canvasModelBuilderService">
                            <modelBuilders hint="raw:RegisterModelBuilder">
                                <builder componentId="<CANVAS_COMPONENT_ID>" type="Namespace.ModelBuilderType, Assembly" />
                            </modelBuilders>
                        </canvasModelBuilderService>
                    </canvas>
                </siteConfiguration>
            </siteConfigurations>
        </uniform>
    </sitecore>
</configuration>
Update enhancers to use model instead of Sitecore item for particular component.
@uniformdev/canvas-sitecore package contains a few helpers to work with model builders.
- getModelfunction- const model = await getModel({
 id: itemId,
 pageId,
 component,
 config,
 isPreview,
 });
- create an enhancer from - createItemEnhancerfunction with- useModelBuilderoption- const modelEnhancer = createItemEnhancer({
 pageId,
 pageItem: pageData,
 config,
 isPreview,
 useModelBuilder: true,
 });
Model builder example: Sample rendering
Implement Sample Rendering model and model builder
using System.Collections.Generic;
using Sitecore.Data.Items;
using Uniform.ModelBuilders;
namespace MySite.ModelBuilders
{
    public class SampleRenderingModel
    {
        public string Title { get; set; }
        public string Text { get; set; }
    }
    public class SampleRenderingModelBuilder : IComponentModelBuilder
    {
        public object BuildModel(Item pageItem, Item datasourceItem, IReadOnlyDictionary<string, string> parameters)
        {
            return new SampleRenderingModel()
            {
                Title = datasourceItem["Title"],
                // Rich Text fields needs to be rendered
                Text = ModelBuilderHelper.RenderField(datasourceItem, "Text")
            };
        }
    }
}
Register Sample Rendering model builder
Create App_Config\Include\zzz_MySite\MySite.Uniform.Canvas.config config with the following content
<configuration xmlns:set="http://www.sitecore.net/xmlconfig/set/">
    <sitecore>
        <uniform>
            <siteConfigurations>
                <siteConfiguration name="MySite">
                    <canvas>
                        <canvasModelBuilderService ref="uniform/services/canvasModelBuilderService">
                            <modelBuilders hint="raw:RegisterModelBuilder">
                                <sampleRendering componentId="sampleRendering" type="MySite.ModelBuilders.SampleRenderingModelBuilder, MySite" />
                            </modelBuilders>
                        </canvasModelBuilderService>
                    </canvas>
                </siteConfiguration>
            </siteConfigurations>
        </uniform>
    </sitecore>
</configuration>
Update enhanceComposition function
import { EnhancerBuilder, enhance } from "@uniformdev/canvas";
import { createItemEnhancer } from '@uniformdev/canvas-sitecore';
export async function enhanceComposition({ composition, pageId, pageData, config, context, isPreview }) {
  const modelEnhancer = createItemEnhancer({
    pageId,
    pageItem: pageData,
    config,
    isPreview,
    useModelBuilder: true
  });
  const enhancers = new EnhancerBuilder()
    .component('sampleRendering', b => b.data('item', modelEnhancer))
  await enhance({ composition, enhancers, context });
}