Friday, 25 December 2015

Sling Models in sightly

Its very easy to fetch values from sling model classes in sightly. Here is the sample example how we can bind the sling and sightly for multicomposite values.



Above is the content screen shot for the multicomposite header menu

Tab will store the properties as label and link. These values are fetched easily using sling model

Sling Model Class:

package com.shoppingcart.models;

import javax.inject.Inject;

import org.apache.sling.api.resource.Resource;
import org.apache.sling.models.annotations.Model;

@Model(adaptables=Resource.class)
public class Header {

@Inject
public Resource multiComp;


}

Sightly Code:

<div class="top-menu" data-sly-use.headerMenu="${'com.shoppingcart.models.Header'}">
<ul data-sly-list=${headerMenu.multiComp.listChildren}>
<li href="${item.link}"> ${item.label}</li>
</ul>

</div>

Sightly WCMUse Class

Having question in mind ??

How can we link our sightly component file with Java Class ?

Here we go ... Follow the steps below

1. Create a sightly component



Above screenshot is the sample headermenu component which will take label and link as multicomposite xtype

2.Create a Java(WCMUsePojo) Class which will fetch the configured values as below

Below class will fetch the values from the data page which are configured.

package com.shoppingcart.util;

import java.util.ArrayList;
import java.util.Iterator;

import javax.jcr.Node;
import javax.jcr.RepositoryException;

import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.adobe.cq.sightly.WCMUsePojo;
import com.day.cq.wcm.api.Page;

import com.shoppingcart.models.Link;

public class HeaderMenu extends WCMUsePojo{

private static final Logger LOGGER = LoggerFactory.getLogger(HeaderMenu.class);
private static final String dataPagePath = "/content/shopping-cart-/headerfooter";
private ArrayList<Link> headerList = new ArrayList<Link>();

@Override
public void activate() throws Exception {
// TODO Auto-generated method stub
ResourceResolver resourceResolver = getResourceResolver();
Page dataPage = resourceResolver.getResource(dataPagePath).adaptTo(Page.class);
LOGGER.debug("Page {}",dataPage.getName());
if(dataPage !=null){
Resource headerMenu = dataPage.getContentResource();
LOGGER.debug("Jcr {}",headerMenu.getName());
if(headerMenu != null && headerMenu.hasChildren()){
Node multiComp = headerMenu.getChild("data-page/headermenu/multiComp").adaptTo(Node.class);
LOGGER.debug("multiComp {}",multiComp.getName());
if(multiComp != null){
buildHeaderLinks(multiComp);
}
}
LOGGER.debug("End");
}
}
public void buildHeaderLinks(Node multiComp) {
// TODO Auto-generated method stub
try {
if(multiComp.hasNodes()){
Iterator<Node> itemNodes = multiComp.getNodes();
while(itemNodes.hasNext()){
Node itemNode = itemNodes.next();
generateBean(itemNode);

}
}
} catch (RepositoryException e) {
// TODO Auto-generated catch block
LOGGER.error("Error while fetching the header links {}",e.getMessage());
}
}

public void generateBean(Node childNode){
String label = checkProperty(childNode,"label");
String link = checkProperty(childNode,"link");
Link itemBean = new Link();
itemBean.setLabel(label);
itemBean.setLink(link);
getHeaderList().add(itemBean);
}

public String checkProperty(Node childNode, String property) {
// TODO Auto-generated method stub
try {
if(childNode.hasProperty(property)){
return childNode.getProperty(property).getString();
}
} catch (RepositoryException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;

}
public ArrayList<Link> getHeaderList() {
return headerList;
}
public void setHeaderList(ArrayList<Link> headerList) {
this.headerList = headerList;
}



}

Bean Class:

package com.shoppingcart.models;

public class Link {

private String label;
private String link;
public String getLabel() {
return label;
}
public void setLabel(String label) {
this.label = label;
}
public String getLink() {
return link;
}
public void setLink(String link) {
this.link = link;
}


}

3.Iterate the above values in headermenu component using sightly coding as below

<div class="top-menu" data-sly-use.headerMenu="${'com.shoppingcart.util.HeaderMenu'}">
    <span class="menu"><img src="/content/dam/shoppingcart/nav.png" alt=""/> </span>
<ul data-sly-list.itemBean="${headerMenu.headerList}">
   <li data-sly-test="${itemBeanList.index == 0}" >
    <a   href="${itemBean.link}" class="active">${itemBean.label}</a>
    </li>
    <li data-sly-test="${itemBeanList.index != 0}" >
    <a   href="${itemBean.link}" >${itemBean.label}</a>
    </li>
</ul>
</div>

Below is the screenshot how you can get the values fetched.




Tuesday, 8 December 2015

Creating AEM Project Structure using lazybones

Facing difficulties in creating AEM project structure using maven and eclipse no worries here is the easy way to create the basic AEM structure using ACS Commons, includes default config options.

Steps to create the project structure :


  1. Naviagate to link https://bintray.com/pledbrook/lazybones-templates/lazybones#files download the zip file for windows operating system.
  2. Extract the zip file and set the environment path variable to \lazybones-0.8.1\bin
  3. open the command then type lazybones command, you will be able to see some of the commands used in lazybones.
  4. once you have installed lazybones for creating the AEM project structure type the command lazybones create aem-multimodule-project <directory name>.
  5. CMD will prompt some of the question as below.
Description
Default
Parameter Name
Maven Group ID
com.myco
groupId
Maven Artifact ID
example-project
artifactId
Maven Version
0.0.1-SNAPSHOT
Version
Project Name
My AEM Project
projectName
Target AEM Version
6.0
aemVersion
Bundle Artifact ID
example-project-bundle
bundleArtifactId
Content Package Artifact ID
example-project-content
contentArtifactId
Folder to create under /apps
My-aem-project

appsFolderName
Folder to use under /content
My-aem-project
contentFolderName
Create a site design?
Yes
createDesign
Design folder name
my-aem-project
designFolderName
Create a main client library?
Yes
createMainClientLib
Create a dependencies client library
Yes
createDependenciesClientLib
Enable code quality checks?
Yes
enableCodeQuality
Set root mapping to /welcome (Classic UI)?
yes in 5.6.1, no in 6.0
reconfigureRootMapping
Set Default Authoring UI to Classic? (6.0 only)
Yes
enableClassicAuthoringAsDefault
Include ACS AEM Commons?
Yes
includeAcsAemCommons
Include ACS AEM Commons as a sub-package?
Yes
includeAcsAemCommonsSubPackage
Enable ACS AEM Commons Error Handler?
Yes
enableErrorHandler
Default Error Page Path
/content/my-aem-project/errors/404
defaultErrorPath
Define Error Page Folder for /content/my-aem-project ?
No
defineErrorPageFolder
Error Page Folder for /content/my-aem-project
Errors
errorFolder
Enable ACS AEM Commons Pages Reference Provider?
yes
enablePagesReferenceProvider
Enable ACS AEM Commons Design Reference Provider?
Yes
enableDesignReferenceProvider
Enable ACS AEM Commons Design Html Library Manager?
Yes
enableDhlm
Enable ACS AEM Commons Versioned Client Libraries?
Yes
enableVersionedClientLibs
Create Environment-Specific Config Folders?
Yes
createRunModeConfigFolders
Environment Names
localdev,dev,qa,stage,prod
envNames
Create Author and Publish Config Folders per Environment?
Yes
createAuthorAndPublishPerEnv
Using Sling Models?
Yes
usingSlingModels
Sling Models Package
''
slingModelsPackage
Purge DAM Workflows?
Yes
purgeDamWorkflows
DAM Workflow Retention Period (days)
7
purgeDamWorkflowRetention

Once this is done you can now see the sample AEM project structure.