data:image/s3,"s3://crabby-images/40de7/40de7f5c4a5c1698729788056ef111da919ffa92" alt="Sitecore EXM"
We will need two Json Rendering components, one for list items and one for container to have the list. For example: MessageListItem, MessageListCard.
data:image/s3,"s3://crabby-images/33a4f/33a4f35483384e04235fe1e06dca7db4a3f309b6" alt=""
NextJS code will looks like as follows for the list item (we have a custom theme)
import { styled } from '@mui/material/styles';
import {
RichText,
RichTextField,
ImageField,
Image,
withDatasourceCheck,
} from '@sitecore-jss/sitecore-jss-nextjs';
import { xxxTheme } from '@xxxx/yyy.theme';
import { xxxText } from '@xxx/yyy.components';
import { ComponentProps } from 'lib/component-props';
interface Fields {
LeadingIconField: ImageField;
MessagesListItemTextField: RichTextField;
TrailingIconField: ImageField;
}
type MessagesListItemParams = ComponentProps & {
fields: Fields;
params: { [key: string]: string };
};
const StyledMessagesListItem = styled('li', { name: 'MessagesListItem' })(
({
theme: {
xxx: { spacing },
},
}: {
theme: xxxTheme;
}) => ({
display: 'flex',
gap: spacing(100),
marginBottom: spacing(200),
'&:last-of-type': {
marginBottom: 0
}
})
);
const MessagesListItem = ({ fields }: MessagesListItemParams): JSX.Element => {
return (
<StyledMessagesListItem>
<Image field={fields.LeadingIconField} />
<xxxText size="bodyLg" component="div" disableSpacing>
<RichText field={fields.MessagesListItemTextField} />
</xxxText>
</StyledMessagesListItem>
);
};
export default withDatasourceCheck()<MessagesListItemParams>(MessagesListItem);
NextJS code for the MessageListCard will looks like
import { styled } from '@mui/material/styles';
import {
ComponentParams,
ComponentRendering,
LinkField,
Placeholder,
} from '@sitecore-jss/sitecore-jss-nextjs';
import { xxxTheme } from '@xxxx/yyy.theme';
interface Fields {
LinkField: LinkField;
}
export interface MessagesListCardProps {
rendering: ComponentRendering;
params: ComponentParams;
fields: Fields;
}
const StyledMessagesListCard = styled('ul', { name: 'MessagesListCard' })(
({
theme: {
xxx: { palette, spacing },
},
}: {
theme: xxxTheme;
}) => ({
backgroundColor: palette.neutral.background.medium,
padding: spacing(600),
width: '100%',
})
);
export const MessagesListCard = (props: MessagesListCardProps): JSX.Element => {
return (
<StyledMessagesListCard>
<Placeholder name='message-list-title' rendering={props.rendering} />
<Placeholder name='message-list-item' rendering={props.rendering} />
</StyledMessagesListCard>
);
};
export default MessagesListCard;
For the list item we will need Datasource template
data:image/s3,"s3://crabby-images/ef649/ef649d0d829c9a6215e65ee4c5706339565b94e5" alt=""
We will also need a parent / container Datasource template to hold the list
data:image/s3,"s3://crabby-images/c218e/c218e475786b6bb44563ba1202b5c4cb7ac462d8" alt=""
We need to create a couple of placeholders:
data:image/s3,"s3://crabby-images/b3a90/b3a90daf05969a7db2e438a04ece36b79a905d56" alt=""
And allow placeholders inside the component “MessageListCard”
data:image/s3,"s3://crabby-images/e0bbe/e0bbe6c3630344f89fcd041c73b34481e12268ad" alt=""
Finally, when we drop the component on a page and set the Datasource it will looks like
data:image/s3,"s3://crabby-images/9fd35/9fd3513e076664c98cbf987f49aa3cd2aef312eb" alt=""