Simon J Ovens
Feb 18, 2017
(0 votes)

How to get the current page's category from a block and use Find to search for all pages that match the category.

In my application I created a block that showed all related pages based on the parent pages category. 
To achieve this I created a new category field called Location, the idea behind this field is to only select one location per page hence the call below to get the First() location. You could use .In() if you required to match against multiple.
In the block controllers ActionResult() method I get the parent page object by using the ServiceLocator.Current.GetInstance<IPageRouteHelper>() .  
In the search query you can see that I first Filter() on the Location category field and call Match() to get the pages that match the parent page's Location.
I then use Filter() and Match() to exclude the parent page from the results based on the ContentGUID.  

Note: The code below has no exception handling for blog readability so this would need to be added in a real world application.

    public class RelatedHomesBlockController : BlockController<RelatedHomesBlock>
        private readonly IPageRouteHelper _pageRouteHelper;
        public IClient FindServiceClient { get; private set; }

        public RelatedHomesBlockController(IClient client)
            FindServiceClient = client;
            _pageRouteHelper = ServiceLocator.Current.GetInstance<IPageRouteHelper>();

        public override ActionResult Index(RelatedHomesBlock currentBlock)
            var currentPage = (_pageRouteHelper.Page as AccommodationPage);
            var currentPageCategory = currentPage.Location.First();
            var contentResult = FindServiceClient.Search<AccommodationPage>()
                                .Filter(h => h.Location.Match(currentPageCategory))
                                .Filter(h => !h.ContentGuid.Match(currentPage.ContentGuid))
            var model = new RelatedHomesBlockModel
                Heading = currentBlock.Heading,
                ContentResult = contentResult

            return PartialView(model);
Feb 18, 2017


Please login to comment.
Latest blogs
Zombie Properties want to Eat Your Brains

It’s a story as old as time. You work hard to build a great site. You have all the right properties – with descriptive names – that the content...

Joe Mayberry | Mar 29, 2023 | Syndicated blog

Optimizely finally releases new and improved list properties!

For years, the Generic PropertyList has been widely used, despite it being unsupported. Today a better option is released!

Tomas Hensrud Gulla | Mar 28, 2023 | Syndicated blog

Official List property support

Introduction Until now users were able to store list properties in three ways: Store simple types (int, string, DateTime, double) as native...

Bartosz Sekula | Mar 28, 2023

New dashboard implemented in CMS UI 12.18.0

As part of the CMS UI 12.18.0 release , a new dashboard has been added as a ‘one stop shop’ to enable editors to access all of their content items,...

Matthew Slim | Mar 28, 2023