Kendo UI Builder ships with many components, but you may want to create your own custom ones. Read on to learn how to do this in Angular and AngularJS.
In Kendo UI Builder, a component is a widget that you can place on a blank view. Kendo UI Builder already ships with many components out of the box, making it a very rich development environment (for example, charts, calendars, etc.). However, there may come a time when you will want to create custom components for reuse across your Angular or AngularJS projects and applications, or even across your entire organization.
As we did for learning the basics of custom views, we will explore the simplest component possible in the form of a “Hello World” custom component.
To follow along, download the custom-hello-world-comp project zip from github or clone this repository
Copy the folder “custom-hello-world-comp” to the folder “template/components” in your target application and restart Kendo UI Builder. Click “Add View,” select a Blank view and you should now see the custom component like in this screenshot (scroll to the bottom of the component panel or search for custom):
When building a custom component, there are three main items to construct:
Here is a screenshot illustrating where some of these items appear in the designer:
Open the file custom-hello-world-comp.json.
This file contains a set of fields. The key fields to define are:
The id property is required and it helps ensure multiple instances of the component can exist on the same page.
Kendo UI Builder will ensure that no two components on the same view have the same id. Here is what you would get if you had duplicated ids:
When we get to the run-time part, we will see how the unique id is also used to define, in the model, properties specific to each instance.
They are located in the sub-directory “design-time.” In this folder we have:
.ejs files are template files. They are executed by Kendo UI Builder to replace the template tags with their actual value. See http://ejs.co/ for more information.
When you program a custom component, you simply provide a representation of the widget that comes close to the run-time view. However you do not have to implement user interactions as Kendo UI Builder does not pass mouse or keyboard events to the design-time view.
The design goal is to let you focus your time and energy on the rendering of the run-time component.
The content of the run-time files will depend on which target framework is used. In Kendo UI Builder version 2.x, we support the AngularJS framework. As of the newly released version 3, we now support both AngularJS and Angular 5 frameworks.
Note: You can download a trial of the latest Kendo UI Builder right here.
The files are in sub-directory “angularjs”:
Options.json.ejs: This is where we define which component properties will get added to the model in the controller of the blank view the component is attached to.
The properties are added to the $components array, indexed by the component unique id. Now we see the importance of the id property in the component definition file. For example, for two instances of a hello world component in the same blank view my controller.js contains:
this
.$components[
'customhelloworldcomp1'
] = {
"greeting"
:
"Hi1"
};
this
.$components[
'customhelloworldcomp2'
] = {
"greeting"
:
"Hi2"
};
directive.html.ejs: This file contains the HTML that will be rendered at runtime. The items defined in options.json.ejs are available from the component model.
In this EJS template we use the id property to access the specific instance model and from there we access the greeting property. For example:
<
span
>
{{vm.$components.<%-id%>.greeting}} World
</
span
>
A property travels from the definition file to the options.json file, then to the blank view controller and finally to the runtime component.
The files are in sub-directory “angular”:
config.json.ejs: This is where we define which view properties will get added to the components elements of the $config variable.
The properties are added to the components array, indexed by the component unique id. Here again, we see the importance of the id property in the component definition file. For example, for two instances of a hello world component in the same blank view my base.components.ts file contains:
public $config: any = {
components: {
customhelloworldcomp0: {
"greeting"
:
"Salutations 1"
},
customhelloworldcomp1: {
"greeting"
:
"Salutations 2"
}
}
};
You will find this file in your generated code under the view sub-folder. For example, my view is called hw-comp under module custom-components. This is where the file is located: app\src\app\modules\custom-components\hw-comp\hw-comp.view.base.component.ts
template.html.ejs: This file contains the HTML that will be rendered at runtime. The items defined in config.json.ejs are available from the component model.
In this EJS template we use the id property to access the specific instance model and from there we access the greeting property. For example:
<
span
>
{{$config.components.<%-id%>.greeting}} World
</
span
>
As you can see, creating a custom component has similarity with a custom view. We must take into account that multiple instances of the component can exist in the same view. This is the main reason for having an id property in the definition file.
Also, a component can interact with other components using the model property. For example, a metric component showing the temperature of the room selected in a combo-box component on the same page. In the next blog post, we will look how to create such components. Stay tuned. 😊
If you jumped into this series in the middle and want to start from the beginning, you can find the previous blog posts here:
Thierry Ciot is a Software Architect on the Corticon Business Rule Management System. Ciot has gained broad experience in the development of products ranging from development tools to production monitoring systems. He is now focusing on bringing Business Rule Management to Javascript and in particular to the serverless world where Corticon will shine. He holds two patents in the memory management space.
Subscribe to get all the news, info and tutorials you need to build better business apps and sites