This is the last tutorial of the Full-stack XM Cloud Development Guide.
So we've covered 2 parts: How to Set Up Docker for XM Cloud Dev and Full-Stack Local XM Cloud Dev Environment Tutorial.
This Full-stack XM Cloud Development Guide is written by Yaochang Liu, a Sitecore Content Hub Administrator Certification winner and experienced developer from Qedge. Yaochang, we really appreciate your effort!
So, let's get started.
Component Development Process
๐Basic Process
1. Create a Datasource Template
/sitecore/templates/Project/Components/Demo/Demo1Component
data:image/s3,"s3://crabby-images/db730/db730e8a10476befc77f596308ec35c6f5c9bfd3" alt="Full-stack XM Cloud Development Guide"
2. Create a Parameters Template
Create a Parameters Template and build Standard Values
/sitecore/templates/Project/Components/Demo/Rendering Parameters/Demo1 Parameters
data:image/s3,"s3://crabby-images/ab645/ab645450acac81664c5075d49e50974ba4216f11" alt="Create a Parameters Template"
3. Create a JSON rendering
/sitecore/layout/Renderings/Project/Play/Demo Component/Demo1
Edit the following fields:
- Parameters Template: Select the Parameters Template created in step 2.
- Datasource Template: Select the Datasource Template created in step 1.
data:image/s3,"s3://crabby-images/50abb/50abbc0f8c47d2c8bc2f7c17d3933a899615b656" alt="Create a JSON rendering"
4. Create Available Rendering
Add the JSON Rendering created in Step 3 to the corresponding Available Rendering
/sitecore/content/Play/Play/Presentation/Available Renderings/Demo Component
data:image/s3,"s3://crabby-images/ea0ee/ea0eef26acd05cb0a2f56a1966c93f89cc0ebad0" alt="Create Available Rendering"
5. Create Variants
/sitecore/content/Play/Play/Presentation/Headless Variants/Demo1
6. Create Variant Definition
/sitecore/content/Play/Play/Presentation/Headless Variants/Demo1/Default
data:image/s3,"s3://crabby-images/e6e39/e6e39830e69ffd40236022587d620a71d37ee328" alt="Create Variant Definition"
7. FE coding
The file name should be consistent with the Component Name in step 3 of the JSON rendering and should not contain any spaces.
data:image/s3,"s3://crabby-images/1e1b0/1e1b09210086a7ed4496a68ff68da70fe0ce42e4" alt="FE coding"
data:image/s3,"s3://crabby-images/342e2/342e2407fbdaa9ed734ad8357d97afefca9f2757" alt="FE coding - tsx"
import React from 'react';
import {
Image as JssImage,
Text,
ImageField,
TextField,
} from '@sitecore-jss/sitecore-jss-nextjs';
interface Fields {
Image: ImageField;
Title: TextField;
}
type Demo1Props = {
params: { [key: string]: string };
fields: Fields;
};
const Demo1DefaultComponent = (props: Demo1Props): JSX.Element => (
<div className={`component promo ${props.params.styles}`}>
<div className="component-content">
<span className="is-empty-hint">Demo1</span>
</div>
</div>
);
export const Default = (props: Demo1Props): JSX.Element => {
const id = props.params.RenderingIdentifier;
if (props.fields) {
return (
<div className={`component promo ${props.params.styles}`} id={id ? id : undefined}>
<div className="component-content">
<div className="field-promoicon">
<JssImage field={props.fields.Image} />
</div>
<div className="promo-text">
<div>
<div className="field-promotext">
<Text field={props.fields.Title} />
</div>
</div>
</div>
</div>
</div>
);
}
return <Demo1DefaultComponent {...props} />;
};
Note: Ensure that the export const Default is consistent with the name "Default" in step 6 of the Variant Definition.
โ๏ธAdvanced Techniques
Nest Components within Components (static placeholder) and/or using multi-variant.
1. Create a Placeholder
/sitecore/layout/Placeholder Settings/Project/Play/Demo1
data:image/s3,"s3://crabby-images/37c79/37c79836cc711cfc5cb9bf019e317e2e1b5eba8f" alt="Create a Placeholder"
2. Update Rendering
Modify the Layout Service Placeholders in the JSON Rendering.
Select the Placeholder added in the previous step.
data:image/s3,"s3://crabby-images/c479f/c479ff890e92e79024167c67e832dfda18399a33" alt="Update Rendering"
3. Set placeholder restrictions
Add placeholder to the appropriate path
/sitecore/content/Play/Play/Presentation/Placeholder Settings/Demo1/Demo1
data:image/s3,"s3://crabby-images/e6b41/e6b41b1736647027c755c87ff2195638f3064ebb" alt="Set placeholder restrictions"
4. Add a Variant Definition
/sitecore/content/Play/Play/Presentation/Headless Variants/Demo1/WithSub
data:image/s3,"s3://crabby-images/dcf1e/dcf1e9a536a9f036cb5515fe7bf27105b8e458e2" alt="Add a Variant Definition"
5. FE coding
import React from 'react';
import {
Image as JssImage,
Text,
ImageField,
TextField,
Placeholder,
} from '@sitecore-jss/sitecore-jss-nextjs';
import { ComponentProps } from 'lib/component-props';
interface Fields {
Image: ImageField;
Title: TextField;
}
type Demo1Props =
ComponentProps & {
fields: Fields;
};
const Demo1DefaultComponent = (props: Demo1Props): JSX.Element => (
<div className={`component promo ${props.params.styles}`}>
<div className="component-content">
<span className="is-empty-hint">Demo1</span>
</div>
</div>
);
export const Default = (props: Demo1Props): JSX.Element => {
const id = props.params.RenderingIdentifier;
if (props.fields) {
return (
<div className={`component promo ${props.params.styles}`} id={id ? id : undefined}>
<div className="component-content">
<div className="field-promoicon">
<JssImage field={props.fields.Image} />
</div>
<div className="promo-text">
<div>
<div className="field-promotext">
<Text field={props.fields.Title} />
</div>
</div>
</div>
</div>
</div>
);
}
return <Demo1DefaultComponent {...props} />;
};
export const WithSub = (props: Demo1Props): JSX.Element => {
const id = props.params.RenderingIdentifier;
if (props.fields) {
return (
<div className={`component promo ${props.params.styles}`} id={id ? id : undefined}>
<div className="component-content">
<div className="field-promoicon">
<JssImage field={props.fields.Image} />
</div>
<div className="promo-text">
<div>
<div className="field-promotext">
<Text field={props.fields.Title} />
<h1>VVV</h1>
<div className="row">
//The following is for nesting components
<Placeholder name="demo1" rendering={props.rendering} />
</div>
</div>
</div>
</div>
</div>
</div>
);
}
return <Demo1DefaultComponent {...props} />;
};
๐ Styles
1. Add Styles
Add the JSON Rendering to the Allowed Renderings of the corresponding Style
/sitecore/content/Play/Play/Presentation/Styles/Demo1/Demo1 large
data:image/s3,"s3://crabby-images/8029b/8029b58b0e0d71d1fe91dd0bd180d7ad6f8015d5" alt="Add Styles"
2. FE coding
Add scss
data:image/s3,"s3://crabby-images/229b2/229b24202876ab70c5b86c72fdd16698260c07ee" alt="Add scss"
@import "@sass/abstracts/vars";
@import "@sass/abstracts/mixins";
.large-css {
max-width: 960px;
padding: 0;
border-top-width: 3px;
border-style: solid;
overflow: visible;
background-color: red;
}
3. Preview in Pages
data:image/s3,"s3://crabby-images/73ac1/73ac12a2226a4e81066078da06a22564e84a422c" alt="Preview in Pages"