How to Build Webparts and Widgets in Kentico
data:image/s3,"s3://crabby-images/346dd/346ddc86676dcc81a5245d8f7b82ad2c3ba6da54" alt=""
Introduction
The Kentico CMS product supports Webparts and Widgets. The main difference between a Webpart and a Widget in Kentico is that a webpart is associated with a template while a widget is associated with a specific page. These are essentially “components” that are a bundle of content and functionality. The process of creating a web part, widget, and page is detailed in the post through an example of the "Expert Callout" widget.
A template is usually constructed with a collection of these components, as shown in the screenshot below:
data:image/s3,"s3://crabby-images/6cce2/6cce234cfb63bfd32bcaa9bb37deb2defc2e66c5" alt=""
The major difference between a Kentico Webpart and a Kentico Widget is that a webpart is associated with a template while a widget is associated with a specific page (that builds on that template). In this sense, when you make a change to a webpart in a template, it will be reflected on ALL pages that use that template. In contrast, widget properties and data are stored at a page-level. Any changes that you make to a widget will affect ONLY that specific page.
The Client Use Case
The www.epiqglobal.com website has multiple solution pages. Each page has a specific expert assigned to it. For example, the eDiscovery solution has a specific expert:
data:image/s3,"s3://crabby-images/71b4b/71b4b8950ea546147e327513176e0d644fb74f83" alt=""
while the Regulatory & Compliance solution has a different expert.
data:image/s3,"s3://crabby-images/e0048/e0048c6efee13ff2c54f8f0d7bd845ca21e11299" alt=""
This functionality can be achieved by designing a custom webpart and associating it with the template. It would eventually look like this:
data:image/s3,"s3://crabby-images/26860/26860ad6689d4c74a86821dfc6546034ad02681b" alt=""
We need a webpart that would give the content manager an ability to assign an expert to a specific page based on this template. After the content manager assigns an expert, the webpart will automatically pull up the expert details : image, name and title.
This functionality is not available in any of the default webparts. So we have to develop a custom webpart to achieve the functionality.
Creating a new webpart
Developing new webparts consists of three main steps:
- Create the webpart code files
- Register the webpart in Kentico
- Parametrize the webpart in Kentico, so that it can accept different parameters
We create two user controls: ExpertCallout_USA.ascx and ExpertCallout_USA.ascx.cs. Both these inherit from an appropriate base class:
data:image/s3,"s3://crabby-images/25b2f/25b2f2494a41296d5e4eb22685496b8c023de28f" alt=""
data:image/s3,"s3://crabby-images/e25d6/e25d6cbe1a7c5d7a637354e2a926d9d1659064b7" alt=""
We then register this webpart as “Expert Callout” in the Kentico Webpart Admin section as shown below:
data:image/s3,"s3://crabby-images/d64ee/d64eef9329fe791522272b3eaae2f15fe9f9367f" alt=""
Webpart “properties” essentially allow you to parametrize and assign different values to a webpart. Based on these parameters that are assigned, the webpart would render differently. For example, you need to assign the relevant expert name to this webpart. So you create a property called “Expert” and assign this to the webpart. (screenshot below)
data:image/s3,"s3://crabby-images/1a6cc/1a6ccd5d909124a3edd85ec270f9a0e1556ef460" alt=""
The image below shows how you can go about creating properties and assigning them to the webpart.
data:image/s3,"s3://crabby-images/0e658/0e658f80e7a9a0e35edf32dfd2cfbfc59261f968" alt=""
Create a Widget based on the Webpart
As shown below, you can create a Widget based on a Webpart. In this example, the Webpart is “Expert Callout”
data:image/s3,"s3://crabby-images/358a9/358a9b2dacbf79467f6a10e250ffe5e716987a18" alt=""
After you create the widgets, you can assign parameters to it, similar to how we described this process for a Webpart.
data:image/s3,"s3://crabby-images/e7b4b/e7b4b7ac7c6856eaa216abf2eec011bdad1c509c" alt=""
Finally, you can add the Widget to the template.
data:image/s3,"s3://crabby-images/e67b7/e67b70be85d02c90ae5b2394c62144b46a5f0a41" alt=""
At this point, the content administrator will be able to create a page based on the template, and select the specific values for the Expert widget area.
The Final Content Manager Experience
In this section, we illustrate the actual experience of a content manager creating a page and assigning an expert to this page.
Step 1: Select a Services page from the Pages dashboard. You can see the Expert callout widget attached to the page. Now click on configure webpart.
data:image/s3,"s3://crabby-images/b8105/b81055b0932a87661f88e6cc9194dca9a0f785b4" alt=""
Select the desired expert in the widget properties, as shown below. Click on Save and Close. You are done!
data:image/s3,"s3://crabby-images/fcb8d/fcb8d726c227bcc17d6bed2a93737a77068e41ab" alt=""
Now, the website user will see this page with the selected expert, as shown below.
data:image/s3,"s3://crabby-images/373c0/373c02caefb01660d9c412cafbe3eba63868bb34" alt=""
if we need to change the design of expert card then we need to create country specific design. You can checkout our article about creating country specific kentico design here