Is your hybrid app ready for AEM Mobile? is-your-hybrid-app-ready-for-aem-mobile

AEM 6.4 has reached the end of extended support and this documentation is no longer updated. For further details, see our technical support periods. Find the supported versions here.
Adobe recommends using the SPA Editor for projects that require single page application framework-based client-side rendering (e.g. React). Learn more.

So you’ve imported your Hybrid PhoneGap or Cordova app into AEM, now what? Likely you will want to add authorable content to your app. To accomplish this task you will need a general understanding of the structure of an AEM app. An app in AEM is commonly divided into two parts. The ‘shell’ and ‘content’. The ‘shell’ comprises of the static parts of your app; such as the PhoneGap configuration files, the app framework, and the navigation controls. The contents of the archive that you imported are stored as part of the shell. In the context of this document, the shell is all the non-AEM authored content of your Hybrid PhoneGap app built by the app developer.

Content refers to the components, templates and authored pages that are authored in AEM built by the AEM Developer. Content is categorized as either developer content or as authored content. Components, designs and page templates are considered to be dev-content since they are built by a developer. author-content are pages that have been built using the components and templates. These are typically done by a designer or a marketer.

Adding authored AEM pages to your Hybrid app requires coordination between the app developer and the AEM developer. Anywhere in the app where you want to add authored content, the app developer needs to organise these pages in a structure that can be overlayed in AEM. The app developer must be able to provide the AEM developer with the paths to where the AEM authored content to be added and then provide a placeholder page in the Hybrid app that will be replaced after the AEM developer has authored the page content.

To make the explanation easier to follow we will be using the AEM Marketing Cloud: AEM Mobile Hybrid Reference to explain the concepts. The Hybrid Reference app consists of a weclome page with a side menu.


In this example we are going to author the welcome page of the application. Taking a look at the source We see that the app developer has defined a welcome page and provided a template for the page which is rendered by the app. This is where the app developer and AEM developer need to coordinate. The path to the welcome page template in the Hybrid Reference App is defined as ‘‘content/mobileapps/hybrid-reference-app/en/welcome.template.html’’. This path is extremely important because the AEM developer will author their welcome page in the AEM repository using the same path.


It is important the hybrid app and the AEM authored content use the same path because we rely on the ability to overlay content using Content Sync to add new pages to the Hybrid app. When the Hybrid App is imported into AEM as part of the import process Content Sync configurations are setup.


When you ‘Download Source’ from the app dashboard these ContentSync scripts are run to assemble an archive of your Hybrid App.


ContentSync first pulls in ‘shell’ of the app which is where all the app developed content of the Hybrid app is stored and then it pulls in the ‘content’ of the app. Now if there are pages in the ‘shell’ that have the same path as in ‘content’ the pages under ‘shell’ will be (replaced) by the pages under ‘content’. In other words in the Hybrid Reference App sample if we create a page in AEM that has the same path as ‘‘content/mobileapps/hybrid-reference-app/en/welcome.template.html’’ when ContentSync runs it will overlay the page that was part of the Hybrid Reference app with whatever is in AEM at that location. The overlay is taken care by ContentSync so for someone who’s using the app the updates to app with AEM authored content will look seamless and will not require a rebuild of the app. As a result when you run the app the welcome page will appear as follows: