Sitecore MVC for Front-end developers
Part 5: Navigation
Navigation
Since Navigation is not referenced by Feature modules it can go in the Feature layer of the solution. This module comprises of templates such as _Navigation inherited by all page templates. This is a good way to ensure consistency in the fields used for navigation components.
data:image/s3,"s3://crabby-images/4b729/4b729154f4a44ce38973f1fe22cbe1d811224373" alt="Feature Layer Navigation Templates Feature Layer Navigation Templates"
data:image/s3,"s3://crabby-images/d7454/d7454436f9a0d30166b54aa71cb72ace0636fc90" alt="Project Layer Navigation Templates Project Layer Navigation Templates"
Menu Rendering
Within the placeholders of the header are two instances of the menu component. The menu is in the Navigation module in the Feature layer. This component uses a datasource containing sub-items for each menu link.
These menu items use templates defined in the Project layer. Project layer templates inherit from Feature and/or Foundation templates. They usually do not add any new field definitions. Thus we define almost all fields in the Feature and Foundation layers.
data:image/s3,"s3://crabby-images/601bf/601bfaaccc8504c382e2ecb0a4c80835c6a79bd7" alt="Logo Menu Logo Menu"
data:image/s3,"s3://crabby-images/d0b85/d0b85edeb863833d0d8455a2a0e7315eb7c81d52" alt="Standard Menu Standard Menu"
data:image/s3,"s3://crabby-images/5367c/5367c871741f4dbe9af5e624abf8dd953bf4dd92" alt="Menu Content Structure Menu Content Structure"
You will notice that the first instance of the menu contains the site logo. We use an if/else branch in the view rendering to change the markup depending on the template of the menu item.
@using Sitecore.Data.Items
@using Sitecore.Foundation.FedEx
@model Sitecore.Mvc.Presentation.RenderingModel
<ul class="@(Html.Sitecore().Parameter("Menu") == "1" ? "menu" : "") @(Html.Sitecore().Parameter("Vertical") == "1" ? " vertical" : "")">
@foreach (var menuItem in (IEnumerable <Item>)Model.Item.Children)
{
if (menuItem.Template.Name == "TextItem")
{
<li class="menu-text">@Html.Sitecore().Field("Text", menuItem)</li>
}
else if (menuItem.Template.Name == "LinkItem")
{
<li>@Html.Sitecore().Field("Link", menuItem)</li>
}
else if (menuItem.Template.Name == "ImageItem")
{
<li class="menu-text"><a href="@Html.Sitecore().GetLinkFieldUrl(menuItem, "Link")">@Html.Sitecore().Field("Image", menuItem, new {w=160})</a></li>
}
}
</ul>
Breadcrumb Rendering
On the product pages of the site are breadcrumb renderings which show where you are in the site.
data:image/s3,"s3://crabby-images/ccbd3/ccbd324569a4b83fbf8da345cec051038d8f66c9" alt="Breadcrumb Menu Breadcrumb Menu"
data:image/s3,"s3://crabby-images/b5a18/b5a1824f1cb25d4a85bf68e4eb86d43c500b242c" alt="Content Tree Navigation Template Content Tree Navigation Template"
Unlike the Menu component, the Breadcrumb has no datasource. It renders content starting with the current item in the content tree. It uses the NavigationTitle field from the _Navigation template. Every page template (Project layer) inherits this template.
You can do this without any extension methods, but I added a few methods to make the rendering code cleaner.
@using Sitecore.Data.Items
@using Sitecore.Foundation.FedEx
@model Sitecore.Mvc.Presentation.RenderingModel
<div class="row columns">
<nav aria-label="You are here:" role="navigation">
<ul class="breadcrumbs">
@foreach (var item in Html.Sitecore().GetBreadcrumbItems())
{
<li><a href="@Html.Sitecore().GetItemUrl(item)">@Html.Sitecore().Field("NavigationTitle", item)</a></li>
}
<li class="disabled">@Html.Sitecore().Field("NavigationTitle", Model.PageItem)</li>
</ul>
</nav>
</div>
What's Next?
Thanks for reading and stay-tuned for the next article in the series where I talk about the header structure and components.
- Introduction
- The Layout
- MetaData
- Header
- Navigation (this page)
- Section Header
- Content
- Product Details
- Product/Article List
- Sidebar Widget
- Footer