Creating Components is our regular job in AEM. But if some properties can make the component better, so why we are not using them.
So today in this blog, we will talk about some of the very interesting properties of a component and how can we use them.
cq:icon:  If you see the icon of a component, by default it refers to the first two letters of a component Title as an abbreviation.
| Fig - Default icons contains first two letter of component title | 
- Abbreviation: You can change the abbreviation by adding the property abbreviation in the cq:Component Node and can change the number of characters shown as component icons. But it's advisable to use only two characters for better visualization.
- Coral UI Icon : There are a lot of coral UI Icons available that can be used for the component icons.
Add cq:icon property in a component node and its value is from coral UI icon.
| Fig - Added cq:icon property in component dialog | 
| Fig - Coral UI icon added in a component | 
- PNG Images: You can configure a PNG Image as a component icon by adding image as cq:icon.png node of nt:file type under cq:component node.
PNG Images should have a transparent background and background set of #707070 color and size of 20px by 20px.However to accommodate retina displays 40px by 40px might be more preferable.
- SVG Images: You can configure SVG Images as component icon by adding image as cq:icon.svg of nt:file under cq:component node same as PNG Images.
helpPath: I ignored this property a lot, but the benefits of this property is like boon to an author.
We used to provide authoring guide to authors so that they can go to that and author the website.They just open the doc find the component which they want to author and continue their work.
| Fig - Help icon in the component dialog | 
helpPath property links the help icon to a particular page.We can create an authoring guide page in AEM only and add that page path as a value of helpPath poperty.You can add also external path and if author starts authoring, he/she can just click on the icon and see the documentation.It is quite a useful property.
 - For out-of-the box components this often references a page in the documentation.
- If no helpPath is specified, the default URL (documentation overview page) is shown.
| Add caption | 
Decoration Tag: When a component is getting rendered on a page, an HTML element can be wrapped that component.
The reasons can be:
- The component can only be edited if it is wrapped with an HTML element.
- The wrapping element is used to apply HTML classes that provides Layout and Styling Information.
- cq:noDecoration{Boolean}: If we add this property as true in the component node, all the default wrapper HTML elements won’t get displayed. But this property won’t let the component editable as wrapping elements are mandatory to open a dialog in the edit mode.
- cq:htmlTag : If you want to change the default class of wrapper element, put some styling over the component, you can create cq:htmlTag node under the component with the following properties:
- cq:tagName:This property can be used to add a custom HTML tag in the wrapper of the component in place of default div element.
- class: This property is used to add a custom class in the default wrapper.
- Other property names will be added as HTML attributes with the same String value as provided.
Decoration Tags with HTL and JSP:
Decoration Tag behaves differently in both HTL and JSP.
HTL: In general, the wrapper behavior in HTL can be summarized as follows:
- No wrapper DIV is rendered by default (when just doing data-sly-resource="foo").
- All wcm-modes (disabled, preview, edit on both author and publish) render identically.
The behavior of the wrapper can also be fully controlled.
- The HTL script has full control over the resulting behavior of the wrapper tag.
- Component properties (like cq:noDecoration and cq:tagName) can also define the wrapper tag.
 Use Cases for Decoration Tag
Let’s understand the different use cases for the decoration Tag.
 +--content/page1
     +--parent(sling:resourceType=/apps/components/parent) [Parent Component]
        +--child(sling:resourceType=/apps/components/child)[Child Component]
 +--/apps/components   
+--parent
+--parent
         +--parent.html
     +--child
         +--child.html
          +--cq:htmlTag/
            +--@cq:tagName =”article”
            +--@class =”article-child”
1.Include a component for Code Reuse :
If you are including a child component in parent component just for the code reusability purpose and child component doesn’t have any dialog to author, cq:noDecoration can be true because no need to have any wrapper elements.
| 
parent.html: <sly data-sly-resource="${'child' @ resourceType='/apps/aem-training/components/content/child'}"></sly> 
child.html: This is Child Page. 
Resulting output on /content/page1.html: 
This is Child Page. | 
 2.Include an Editable Component: When the need of including the child component in the parent component in the editable format, so we need to have the wrapping elements for the child component to make it enable for working.
Since the included component is in this case an independent component, it needs a wrapper element for the editor to work, and to define its layout and style to apply. To trigger this behavior, we need to add cq:htmlTag node in the child component.
3.Custom Behavior: There can be any number of complex cases, which can be achieved easily by the possibility of HTL to provide explicitly:
- decorationTagName='ELEMENT_NAME' To define the element name of the wrapper.
- cssClassName='CLASS_NAME' To define the CSS class names to set on it.
| 
parent.html:  <sly data-sly-resource="${'child' @ resourceType='/apps/aem-training/components/content/child',decorationTagName=article, cssClassName='child'}"></sly> 
child.html: Hello World! 
Resulting output /content/page1.html: 
<article class="child">Hello World!</article> | 
 JSP: When including a component using cq:include or sling:include, the default behavior in AEM is to use a DIV to wrap the element. However, this wrapping can be customized in two ways:
- Explicitly tell AEM not to wrap the component using cq:noDecoration.
Demonstration video on decoration tag in a component:
Note: Special recommendation of watching the Youtube video for decoration tag.
 
If you have any query or suggestion then kindly comment or mail us at sgaem.blog02@gmail.com
Hope it will help you guys !!
Thanks and Happy Learning.

Great post!
ReplyDeleteExcellent, thanks
ReplyDeleteThis blogspot is more practical rather than theory. Keep it up and keep helping. Thanks.
ReplyDeleteGreat Post!!!!
ReplyDeletebut I have one doubt regarding preview mode where wrapper div is being removed in preview mode if I define tag and class with cq:htmlTag Node. I found this is a default behaviour, How can I avoid/overwrite this because I wan't to display same HTML in edit and preview. AEM version - 6.3
http://aemtricks.blogspot.be/2016/01/aem-removing-wrapper-element-of.html
Is it possible to have custom HTML tags such as 'my-comp', 'cmp-container', 'customTag', etc... on cq:tagName property?
ReplyDeleteI am using AEM 6.5 and having these custom tags doesn't render the wrapper at all!
Only the default HTML5 tags are accepted such as div, span, article, ul, etc...