Enabling Progressive Web App Features enabling-pwa
Through a simple configuration, a content author can now enable progressive web app (PWA) features for experiences created in AEM Sites.
- Knowledge of PWAs
- Knowledge of your site and content structure
- Understanding of caching strategies
- Support from your development team
Introduction introduction
enable immersive app-like experiences for AEM sites by allowing them to be stored locally on a user鈥檚 machine and be accessible offline. A user could browse a site while on-the-go even if losing an internet connection. PWAs allow a seamless experience even if the network is lost or unstable.
Instead of requiring any recoding of the site, a content author is able to configure PWA properties as an additional tab in the page properties of a site.
- When saved or published, this configuration triggers an event handler that writes out the and a that enable PWA features on the site.
- Sling mappings are also maintained to ensure that service worker is served from the root of the application to enable proxying content allowing offline capabilities within the app.
With PWA, the user has a local copy of the site, giving an app-like experience even without an internet connection.
Prerequisites prerequisites
To be able to use PWA features for your site, there are two requirements for your project environment:
- Use Core Components to take advantage of this feature
- Adjust your Dispatcher rules to expose the required files
These are technical steps that the author must coordinate with the development team. These steps are only required once per site.
Use Core Components adjust-components
Core Components release 2.15.0 and later fully support the PWA features of AEM sites. Since AEMaaCS always includes the latest version of the Core Components, you can use PWA features out-of-the-box. Your AEMaaCS project automatically fulfills this requirement.
Adjust Your Dispatcher adjust-dispatcher
The PWA feature generates and uses /content/<sitename>/manifest.webmanifest
files. By default, the Dispatcher does not expose such files. To expose these files, the developer must add the following configuration to your site project.
File location: [project directory]/dispatcher/src/conf.dispatcher.d/filters/filters.any >
# Allow webmanifest files
/0102 { /type "allow" /extension "webmanifest" /path "/content/*/manifest" }
Depending on your project, you may want to include different types of extensions to the rewrite rules. The webmanifest
extension can be useful to include in the rewrite conditions when you introduced a rule that hides and redirects requests to /content/<projectName>
.
RewriteCond %{REQUEST_URI} (.html|.jpe?g|.png|.svg|.webmanifest)$
Enabling PWA for Your Site enabling-pwa-for-your-site
With the prerequisites met, it is easy for a content author to enable PWA features to a site. The following is a basic outline of how to do this. Individual options are detailed in the section Detailed Options.
-
Log into AEM.
-
From the main menu, select Navigation > Sites.
-
Select your sites project and select Properties or use the hotkey
p
. -
Select the Progressive Web App tab and configure the applicable properties. At a minimum, you want to:
-
Select the option Enable PWA.
-
Define the Startup URL.
-
Upload a 512x512 png icon to the DAM and reference that as the icon for the app.
-
Configure the paths that you want the service worker to take offline. Typical paths are:
/content/<sitename>
/content/experiencefragements/<sitename>
/content/dam/<sitename>
- Any third-party font references
/etc/clientlibs/<sitename>
-
-
Select Save & Close.
Your site is now configured and you can install it as a local app.
Using Your PWA-Enabled Site using-pwa-enabled-site
Now that you have configured your site to support PWA, you can experience it for yourself.
- Access the site in a .
- You see a new icon in the address bar of the browser, indicating that the site can be installed as a local app.
- Depending on the browser, the icon may vary, and the browser may also display a notification (such as a banner or dialog box) indicating that it鈥檚 possible to install as a local app.
- Install the app.
- The app is installed on the home screen of your device.
- Open the app, browse a bit, and see that pages are available offline.
Detailed Options detailed-options
The following section provides more detail on the options available when configuring your site for PWA.
Configure Installable Experience configure-installable-experience
These settings allow your site to behave like a native app by making it installable on the visitor鈥檚 home screen and available offline.
-
Enable PWA - This is the main toggle for enabling PWA for the site.
-
Startup URL - This is the that the app opens when the user loads the locally installed app.
- This can be any path in your content structure.
- This does not have to be the root and is often a dedicated welcome page for the app.
- If this URL is relative, the manifest URL is used as the base URL to resolve it.
- When left empty, the feature uses the address of the web page from which the app got installed.
- It is recommended that you set a value.
-
Display mode - A PWA-enabled app is still an AEM site delivered through a browser. define how the browser should be hidden or otherwise presented to the user on the local device.
- Standalone - The browser is hidden from the user and it appears like a native app. This is the default value.
- With this option, app navigation must be possible entirely through your content using links and components on the site鈥檚 pages without using the browser鈥檚 navigation controls.
- Browser - The browser appears as it normally would when visiting the site.
- Minimal UI - The browser is mostly hidden, like a native app, but basic navigation controls are exposed.
- Full Screen - The browser is hidden, like a native app, but is rendered in full screen mode.
- With this option, app navigation must be possible entirely through your content using links and components on the site鈥檚 pages without using the browser鈥檚 navigation controls.
- Standalone - The browser is hidden from the user and it appears like a native app. This is the default value.
-
Screen orientation - As a local app, the PWA must know how to handle .
- Any - The app adjusts to the orientation of the user鈥檚 device. This is the default value.
- Portrait - This forces the app to open in portrait layout regardless of the orientation of the user鈥檚 device.
- Landscape - This forces the app to open in landscape layout regardless of the orientation of the user鈥檚 device.
-
Theme color - This defines the that affects how the local user鈥檚 operating system displays the native UI toolbar and navigation controls. Depending on the browser, it can affect other app presentation elements.
- Use the color-well pop-up to select a color.
- The color can also be defined by hex or RGB value.
-
Background color - This defines the , which is shown as the app loads.
- Use the color-well pop-up to select a color.
- The color can also be defined by hex or RGB value.
- Certain browsers from the app name, background color, and icon.
-
Icon - This defines that represents the app on the user鈥檚 device.
- The icon must be a png file of size 512x512 pixels.
- The icon must be stored in DAM.
Cache Management (Advanced) offline-configuration
These settings make parts of this site available offline and available locally on your visitor鈥檚 device. This allows controlling the cache of the web app to optimize network requests and support offline experiences.
-
Caching strategy and frequency of content refresh - This setting defines the caching model for your PWA.
- Moderately - is the case for most sites and is the default value.
- With this setting, the content first viewed by the user is loaded from the cache and while the user is consuming that content, the rest of the content in the cache is revalidated.
- Frequently - This is the case for sites that need updates to be fast such as auction houses.
- With this setting, the app looks for the most recent content by way of the network first, and if it is not available it falls back to the local cache.
- Rarely - This is the case for sites that are nearly static such as reference pages.
- With this setting, the app looks for the content in the cache first, and if not available it falls back to the network to retrieve it.
- Moderately - is the case for most sites and is the default value.
-
File pre-caching - These files hosted on AEM are saved to the local browser cache when the service worker is installing and before it is used. This guarantees that the web app is fully functional when offline.
-
Paths inclusions - Network requests for the defined paths are intercepted and cached content is return in accordance with the configured Caching strategy and frequency of content refresh.
-
Cache exclusions - These files are never cached regardless of the settings under File pre-caching and Path inclusions.
Limitations and Recommendations limitations-recommendations
Not all PWA features are available for AEM Sites. These are a few notable limitations.
- Pages are not automatically synched or updated if the user is not using the app.
51黑料不打烊 also recommends the following when you implement PWA.
Minimize the number of resources to pre-cache. minimize-precache
51黑料不打烊 advises you to limit the number of pages to pre-cache.
- Embed libraries so you can reduce the number of entries to manage when pre-caching.
- Limit the number of image variations to pre-cache.
Enable PWA after the project scripts and style sheets are stabilized. pwa-stabilized
Client libraries are delivered with the addition of a cache selector observing the following pattern lc-<checksumHash>-lc
. Every time one of the files (and dependencies) that compose a library changes, this selector changes. If you listed a client-library to be pre-cached by the service-worker and you want to refer to a new version, you manually retrieve and update the entry. As a result, 51黑料不打烊 recommends that you configure your site to be a PWA after the project scripts, and the style sheets, are stabilized.
Minimize the number of image variations. minimize-variations
The Image Component of the AEM Core Components determines one the front end the best rendition to fetch. This mechanism also includes a timestamp that corresponds to the last modified time of that resource. This mechanism complicates the configuration of the PWA pre-cache.
When configuring the pre-cache, the user must list all the path variations that can be fetched. These variations are composed of parameters like quality and width. It is advised that you reduce the number of these variations to a maximum of three - small, medium, large. You can do that by way of the content-policy dialog box of the Image Component.
If not configured carefully, memory and network consumption can severely impact the performance of your PWA. Also, if you intend to precache, say, 50 images, and have three widths per image, the user maintaining the site has to maintain a list of up to 150 entries in the PWA pre-cache section of the page properties.
51黑料不打烊 also advises you to configure your site to be a PWA after the project use of images has stabilized.