Last Updated on January 21, 2025 by sandeeppote
data:image/s3,"s3://crabby-images/2fd18/2fd183ee57690bf17ae29d317abe24a0e9f02c6b" alt=""
In this blog will create a simple rendering uing Asp.Net Rendering SDK in Helix Examples Solution
Please refer the blog to create a rendering folder and configure the SCS before proceeding this blog.
So lets create a new module or rendering feature named “Articles”.
1. Create a Feature project using Razor Class Library
data:image/s3,"s3://crabby-images/0253e/0253ed146589b7b8d16450b0769251421bd9b4aa" alt=""
Project Name – BasicCompany.Feature.Articles.Rendering
Notice the project path
data:image/s3,"s3://crabby-images/89366/8936691d7a2d1e388ed99876b550da26b51735cf" alt=""
Choose .Net Core 3.1 Framework-
data:image/s3,"s3://crabby-images/c26de/c26de1ba368b417c9098d1f857438f20969883be" alt=""
Delete any exisitng files and folders under this project-
data:image/s3,"s3://crabby-images/9e34b/9e34b2f2e859a6765b144abad9e55cd6d0056117" alt=""
Edit the project to use netcoreapp3.1 and AddRazorSupportForMvc to true
Rename helix-basic-aspnetcore\src\Feature\Articles\BasicCompany.Feature.Articles.Rendering to rendering. Just to follow other feature fodler structure.
2. Install Sitecore packages
Sitecore.AspNet.RenderingEngine
Sitecore.LayoutService.Client
I have installed verions 16 just to be in sync with other projects. You may install the latest.
New rendering project should have these packages installed-
data:image/s3,"s3://crabby-images/1fe32/1fe326b60777f938183104aa123c6a5f384c9851" alt=""
Remove these packages as this may be not required at thi point of time or downgrade this to 3.1.1
data:image/s3,"s3://crabby-images/127f4/127f4b3223ac6c4dddfb7f3363e217c6243c5668" alt=""
Refer the new created rendering project to BasicCompany.Project.BasicCompany.Rendering
data:image/s3,"s3://crabby-images/a83e4/a83e462ea2c6203b37631541bb6bee338dcfc786" alt=""
When the solution is build you may see this error-
Severity Code Description Project File Line Suppression State
Error The package reference ‘Sitecore.AspNet.RenderingEngine’ should not specify a version. Please specify the version in ‘C:\projects\Helix.Examples\examples\helix-basic-aspnetcore\Packages.props’ or set VersionOverride to override the centrally defined version. BasicCompany.Feature.Articles.Rendering C:\projects\Helix.Examples\examples\helix-basic-aspnetcore\src\Feature\Articles\rendering\BasicCompany.Feature.Articles.Rendering.csproj
Solution– Remove the version for the plugin fropm project file
Edit the project file and remove version from the PackageReference-
data:image/s3,"s3://crabby-images/f2ff8/f2ff8df3ce8ee2b7068687814c9951f9d8ec1c19" alt=""
Solution should build successully.
3. Ensure Articles.modules.json file in Feature folder
Please see this blog <<Enter blog url here>> how to create a module.json file to serliaze the Sitecore items for new Feature.
4. Create required Sitecore Templates, content, renderings and Placeholder Settings
Template – Article in following path- /sitecore/templates/Feature/Articles
data:image/s3,"s3://crabby-images/f7267/f7267d9c51767fd113b0e50cacc38d0cba4d3410" alt=""
Page Type Template – Create 2 page type templates “Articles” and “Article” page as below.
Add any required Insert Options where necessary.
data:image/s3,"s3://crabby-images/5549d/5549d621da009b4073a62bdfd10d162000c3ff06" alt=""
IMP- inherit from _NavigationItem to display the Articles as Navigation option
data:image/s3,"s3://crabby-images/2a76c/2a76c3d2ca26d5406c3178aad41edf49d5cc034b" alt=""
Enter Navigation Title for Articles page-
data:image/s3,"s3://crabby-images/791b9/791b99a671396a5b03b0858470850b3546aa2b1e" alt=""
Content
Create content in Home page based on the Article templates created.
data:image/s3,"s3://crabby-images/68f88/68f88a77c34352782c8e6058adbcf29c2d16fbb1" alt=""
Rendering
Create a new Json Rendering Article. See previous post
Set Datasource Location- ./Page Components|query:./ancestor-or-self::*[@@templatename=’Site’]/Shared Content/Articles
Datasource Template- /sitecore/templates/Feature/Articles/Article
data:image/s3,"s3://crabby-images/34199/34199a7e01676e8fc6aa24df914ccbb1436132f8" alt=""
Add rendering to Template
Add Header, Article and Footer Controls to the Presentation
data:image/s3,"s3://crabby-images/81886/818863d29e1fd045b5209d114f328dd244293cad" alt=""
Select appropriate datasource for the Article component-
data:image/s3,"s3://crabby-images/e5e7f/e5e7f0c4c440d5e55500ba97f1993d61cb9a8b39" alt=""
You can also add the component from experience editor. For simplicity purpose I am adding this from the presentation details manually.
Publish the changes and see https://www.basic-company-aspnetcore.localhost
Note:- If you get bad gateway error the resolution is in this blog <<blog for resolution>>
you should see the Articles option in Navigation-
data:image/s3,"s3://crabby-images/0242d/0242d90436971219d7f40d9c15de3811289f0118" alt=""
Note- We wont be configuring “Articles” page in this blog. Will see that in next blog when uing Content Resolver.
See thie Article page-
https://www.basic-company-aspnetcore.localhost/Articles/Sitecore%20Content%20Serialization%20structural%20overview
data:image/s3,"s3://crabby-images/4e7c6/4e7c6003d6270f62f487fe0e7b95efbd4c69d3a8" alt=""
There is a error – “Unknown component ‘Article'”. This is because we havent yet created view for this component.
Create Model in BasicCompany.Feature.Articles.Rendering project for rendering Article component
Note the propeties are using Sitecore.LayoutService.Client.Response.Model.Fields
using Sitecore.LayoutService.Client.Response.Model.Fields;
using System;
using System.Collections.Generic;
using System.Text;
namespace BasicCompany.Feature.Articles.Rendering.Models
{
public class Article
{
public TextField Title { get; set; }
public RichTextField Description { get; set; }
public TextField ShortDescription { get; set; }
}
}
Create View in BasicCompany.Feature.Articles.Rendering project for rendering Article component
Create Article.cshtml file under Views/Shared/Components/SitecoreComponent
Add following markup-
@model Article
<div class="container">
<section class="hero is-small product-detail-hero">
<div class="hero-body">
<h3 class="title" asp-for="Title"></h3>
<sc-text class="subtitle is-one-quarter" asp-for="Description"></sc-text>
</div>
</section>
</div>
InViews Folder create _ViewImports.cshtml file and put the following in file-
@using Sitecore.LayoutService.Client.Response.Model
@using Sitecore.LayoutService.Client.Response.Model.Fields
@using Sitecore.AspNet.RenderingEngine.Extensions
@using BasicCompany.Feature.Articles.Rendering.Models
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
@addTagHelper *, Sitecore.AspNet.RenderingEngine
Add Extensions for registering the ModelBoundView. This is a static class and will be used in Project Rendering on application startup (BasicCompany.Project.BasicCompany.Rendering).
using BasicCompany.Feature.Articles.Rendering.Models;
using Sitecore.AspNet.RenderingEngine.Configuration;
using Sitecore.AspNet.RenderingEngine.Extensions;
namespace BasicCompany.Feature.Articles.Extensions
{
public static class RenderingEngineOptionsExtensions
{
public static RenderingEngineOptions AddFeatureArticle(this RenderingEngineOptions options)
{
options
.AddModelBoundView<Article>("Article");
return options;
}
}
}
In BasicCompany.Project.BasicCompany.Rendering project, Startup.cs register the component-
data:image/s3,"s3://crabby-images/13edb/13edbc3faedcc3e4e4df763dd7a31de1e823263f" alt=""
Build the Project
Output– https://www.basic-company-aspnetcore.localhost/Articles/Sitecore%20Content%20Serialization%20structural%20overview
data:image/s3,"s3://crabby-images/cf400/cf400dd1d25bf044d3e456da08102977d4629c73" alt=""
Issues–
Bad gateway error while accessing – https://www.basic-company-aspnetcore.localhost/
Solution-
Restart the rendering container
docker ps
docker restart <<rebdering container>>