First lets understand what is a component in Adobe CQ5 or AEM:
Components are reusable, modular units used to achieve specific functionality that can be present on webpage. The main advantage of having a component is it is modular and isolated individual uanits that can be reused across the application. Below are the general properties of a component.
data:image/s3,"s3://crabby-images/05a14/05a149d5e82e827d770622f6b2fb1bcd2dfded42" alt=""
Now the next question that arises in our mind by looking at above component is what does allowedPaths property do or what do we mean by sling:superResourceType.Let’s see
allowedParents: It specifies path of a component that is allowed to be a parent of this component.
allowedChildren: It specifies path of a component that is allowed to be a child of this component.
componentGroup: It specifies group under which the component can be selected in the Sidekick.
sling:resourceSuperType: It is used to achieve inheritance in cq. When set, it inherits the specified component to this component.
There are two approaches for creating a custom component in adobe cq:-
By copying component from libs folder and then renaming it.
By creating a new component and then point it to libs-> foundation component.
Note: I will suggest to use second approach as chances of manual copy pasting error are less, but for experienced developers i suggest first approach as it save lots of time while creating component. Lets see both Approaches:
Steps to create custom component in CQ5:-
Components are reusable, modular units used to achieve specific functionality that can be present on webpage. The main advantage of having a component is it is modular and isolated individual uanits that can be reused across the application. Below are the general properties of a component.
data:image/s3,"s3://crabby-images/05a14/05a149d5e82e827d770622f6b2fb1bcd2dfded42" alt=""
Now the next question that arises in our mind by looking at above component is what does allowedPaths property do or what do we mean by sling:superResourceType.Let’s see
allowedParents: It specifies path of a component that is allowed to be a parent of this component.
allowedChildren: It specifies path of a component that is allowed to be a child of this component.
componentGroup: It specifies group under which the component can be selected in the Sidekick.
sling:resourceSuperType: It is used to achieve inheritance in cq. When set, it inherits the specified component to this component.
There are two approaches for creating a custom component in adobe cq:-
By copying component from libs folder and then renaming it.
By creating a new component and then point it to libs-> foundation component.
Note: I will suggest to use second approach as chances of manual copy pasting error are less, but for experienced developers i suggest first approach as it save lots of time while creating component. Lets see both Approaches:
Steps to create custom component in CQ5:-
Approach 1:
Open CRXDE Lite , create a component folder in apps/<myProject> copy an existing component to it, such as the Text component, and rename it( Like customText in below example). For example, to customize the Text component copy:
Text component from /libs/foundation/components/text to /apps/myProject/components/textdata:image/s3,"s3://crabby-images/d6ffe/d6ffe062f3b95b5d047107773a341f28504032f3" alt=""
Change the jcr:title of new component (Like Custom Text Component in above example), so that we can easily distinguish it.
In CQ WCM , open a page in your web site in authoring mode you can see new component is available in the sidekick under the component group that you have specified.
Open CRXDE Lite , create a component folder in apps/<myProject> copy an existing component to it, such as the Text component, and rename it( Like customText in below example). For example, to customize the Text component copy:
Text component from /libs/foundation/components/text to /apps/myProject/components/text
data:image/s3,"s3://crabby-images/d6ffe/d6ffe062f3b95b5d047107773a341f28504032f3" alt=""
Change the jcr:title of new component (Like Custom Text Component in above example), so that we can easily distinguish it.
In CQ WCM , open a page in your web site in authoring mode you can see new component is available in the sidekick under the component group that you have specified.
Approach 2:
Here we will create a custom component with custom dialog, which will have three fields in its dialog.
Open CRXDE Lite , create a component folder in apps/<myProject>.
Right click on components folder Select Create –> Create Components.data:image/s3,"s3://crabby-images/f4b48/f4b485baab619b30ff038df4e0a2dec7674a194d" alt=""
Enter below details in the Create Component dialog :
Label : customLinkComponent
Title : Custom Link
Description : Custom Link Component, used by my Sample Website
Super Type : foundation/components/page
Group: Geometrixx Gov
data:image/s3,"s3://crabby-images/c39a9/c39a952ed1f9ccbd1bd899a0dc6fd5fdb8a1365c" alt=""
Click Next till last screen and click OK on last Screen. These screen contains optional
properties which we have already seen above.
data:image/s3,"s3://crabby-images/a2f6c/a2f6c1ab1879271d0fd0f79194b179aa1f5cd3bf" alt=""
data:image/s3,"s3://crabby-images/d970f/d970fc78771a20b3602fa7dc4b893fbab19c6809" alt=""
data:image/s3,"s3://crabby-images/38b67/38b6734a9cc5a3c17e5efe57a1eff855f7119174" alt=""
Click on Save All on top left of crxde to save the changes.
Use of Advanced Component Setting during creation of component in AEM:-
Is Container: Enable to make you component as a container like parsys. Where content author can drag and drop other components.
No Decoration: When we hover on our component in authoring enviroment a green border comes, if we dont want the green border selection we can enable No decoration
Cell Name: A unique div id that will be assigned to your component div.
Dialog Path: Path of existing dialog that you want to reuse.
Now Lets create a Custom Dialog for the Custom Link Component
Right Click on customLinkComponent that we have created Select Create –>
Here we will create a custom component with custom dialog, which will have three fields in its dialog.
Open CRXDE Lite , create a component folder in apps/<myProject>.
Right click on components folder Select Create –> Create Components.
data:image/s3,"s3://crabby-images/f4b48/f4b485baab619b30ff038df4e0a2dec7674a194d" alt=""
Enter below details in the Create Component dialog :
Label : customLinkComponent
Title : Custom Link
Description : Custom Link Component, used by my Sample Website
Super Type : foundation/components/page
Group: Geometrixx Gov
data:image/s3,"s3://crabby-images/c39a9/c39a952ed1f9ccbd1bd899a0dc6fd5fdb8a1365c" alt=""
Click Next till last screen and click OK on last Screen. These screen contains optional
properties which we have already seen above.
data:image/s3,"s3://crabby-images/a2f6c/a2f6c1ab1879271d0fd0f79194b179aa1f5cd3bf" alt=""
data:image/s3,"s3://crabby-images/d970f/d970fc78771a20b3602fa7dc4b893fbab19c6809" alt=""
data:image/s3,"s3://crabby-images/38b67/38b6734a9cc5a3c17e5efe57a1eff855f7119174" alt=""
Click on Save All on top left of crxde to save the changes.
Use of Advanced Component Setting during creation of component in AEM:-
Is Container: Enable to make you component as a container like parsys. Where content author can drag and drop other components.
No Decoration: When we hover on our component in authoring enviroment a green border comes, if we dont want the green border selection we can enable No decoration
Cell Name: A unique div id that will be assigned to your component div.
Dialog Path: Path of existing dialog that you want to reuse.
Now Lets create a Custom Dialog for the Custom Link Component
Right Click on customLinkComponent that we have created Select Create –>
Create Dialog.
Enter below details in the Create Dialog :
Label: dialog
Title: Custom Link Dialog
data:image/s3,"s3://crabby-images/70a7c/70a7ca67449deb8e3b02911282eec8a1c371509a" alt=""
Click OK and save all changes. You can see that your dialog structure has created.
data:image/s3,"s3://crabby-images/a8305/a8305327b3548498c32a96d46e20d9bf0d72d546" alt=""
Provide a suitable name to tab1 value(For Ex: I have provided Custom Link Tab) and save changes.data:image/s3,"s3://crabby-images/1e794/1e7942bff8fac3210d90341e88fd911888fa858c" alt=""
Right Click on tab1 or Custom Link Tab and create a node by Selecting Create –> Create Node of type cq:WidgetCollection.
Enter below details in the Create Node:
Name: Items
Type: cq:WidgetCollection
Note:- name of cq:WidgetCollection should be Items.
data:image/s3,"s3://crabby-images/88975/88975c93cf96f43b32988215cf8c0188c4de19ea" alt=""
Create new node inside the componentItems node which we have just created and enter below details. Save the changes. your dialog structure would look like below figure.
Name: displaytext
Type: cq:Widgetdata:image/s3,"s3://crabby-images/4c352/4c352bb800d75fcd9035f58d04363351a3167c87" alt=""
Add following properties manually (fieldDescription, fieldLabel, name, xtype) for the customDisplayText node to configure it as a text field. see below figure for reference.
data:image/s3,"s3://crabby-images/1e3ae/1e3ae6d5afe540f2849e037df7c8a4bdd06f9964" alt=""
Similarly create two more nodes on the same level of customDisplayText with properties shown below:
Name: link
Type: cq:Widget
data:image/s3,"s3://crabby-images/13d19/13d1991e153ba4a2c5ef3a2ddfaf6c9f35003f78" alt=""
Name: newWindow
Type: cq:Widget
data:image/s3,"s3://crabby-images/5ebc4/5ebc4d315fe9028f8959ee55f6de0301f313547c" alt=""
Save the changes and your final folder structure should look like:
data:image/s3,"s3://crabby-images/dcfd8/dcfd8bcf11c4c18ea713708c38deaf7dab975f24" alt=""
Enter below details in the Create Dialog :
Label: dialog
Title: Custom Link Dialog
data:image/s3,"s3://crabby-images/70a7c/70a7ca67449deb8e3b02911282eec8a1c371509a" alt=""
Click OK and save all changes. You can see that your dialog structure has created.
data:image/s3,"s3://crabby-images/a8305/a8305327b3548498c32a96d46e20d9bf0d72d546" alt=""
Provide a suitable name to tab1 value(For Ex: I have provided Custom Link Tab) and save changes.
data:image/s3,"s3://crabby-images/1e794/1e7942bff8fac3210d90341e88fd911888fa858c" alt=""
Right Click on tab1 or Custom Link Tab and create a node by Selecting Create –> Create Node of type cq:WidgetCollection.
Enter below details in the Create Node:
Name: Items
Type: cq:WidgetCollection
Note:- name of cq:WidgetCollection should be Items.
data:image/s3,"s3://crabby-images/88975/88975c93cf96f43b32988215cf8c0188c4de19ea" alt=""
Create new node inside the componentItems node which we have just created and enter below details. Save the changes. your dialog structure would look like below figure.
Name: displaytext
Type: cq:Widget
data:image/s3,"s3://crabby-images/4c352/4c352bb800d75fcd9035f58d04363351a3167c87" alt=""
Add following properties manually (fieldDescription, fieldLabel, name, xtype) for the customDisplayText node to configure it as a text field. see below figure for reference.
data:image/s3,"s3://crabby-images/1e3ae/1e3ae6d5afe540f2849e037df7c8a4bdd06f9964" alt=""
Similarly create two more nodes on the same level of customDisplayText with properties shown below:
Name: link
Type: cq:Widget
data:image/s3,"s3://crabby-images/13d19/13d1991e153ba4a2c5ef3a2ddfaf6c9f35003f78" alt=""
Name: newWindow
Type: cq:Widget
data:image/s3,"s3://crabby-images/5ebc4/5ebc4d315fe9028f8959ee55f6de0301f313547c" alt=""
Save the changes and your final folder structure should look like:
data:image/s3,"s3://crabby-images/dcfd8/dcfd8bcf11c4c18ea713708c38deaf7dab975f24" alt=""
Open customLinkComponents.jsp and replace the existing code with below code.
<%@page language="Java"%>
<%@include file="/libs/foundation/global.jsp"%>
<cq:include script="/libs/wcm/core/components/init/init.jsp"/>
<%@page session="false" %>
<% // TODO add you code here %>
<html>
<head>
<title>Link Components</title>
</head>
<body>
<a href="#" >Click Here</a>
</body>
</html>
Integrate Custom Component with the Page
Create a Page or use existing page and make sure you have sidekick in it which contains
your custom link component.
data:image/s3,"s3://crabby-images/9522b/9522ba27f5037add5b68c9c776580e60ba4460eb" alt=""
<%@page language="Java"%>
<%@include file="/libs/foundation/global.jsp"%>
<cq:include script="/libs/wcm/core/components/init/init.jsp"/>
<%@page session="false" %>
<% // TODO add you code here %>
<html>
<head>
<title>Link Components</title>
</head>
<body>
<a href="#" >Click Here</a>
</body>
</html>
Integrate Custom Component with the Page
Create a Page or use existing page and make sure you have sidekick in it which contains
your custom link component.
data:image/s3,"s3://crabby-images/9522b/9522ba27f5037add5b68c9c776580e60ba4460eb" alt=""
Drag the custom link component to page and double click on the link to view the dialog.
No comments:
Post a Comment
If you have any doubts or questions, please let us know.