Set up a project
Purple Experience Builder

Deploy Resources to Multiple Brands

9min

This article explains how to use the Purple Experience Builder to provide dynamic resources to multiple brands working in the Purple Experience. If you have multiple brands in your portfolio and want to use the same logic and templates, but vary logos, colours, etc., you can define one of your Purple Apps as a parent that will provide new features to its children. To make this approach work, you will define protected files for the apps to prevent overwriting files needed for the different look and feel of the child apps.

Deployment only affects the 'Preview' dynamic resources of the main and target apps, and you still need to manually copy the dynamic resources to 'Release' once you are satisfied that the 'Preview' looks good.

Any (scss)-pipeline must be executed on the Builder to be applied



Preconditions

Create or edit an existing builder.config.json inside the /default folder in the Experience Builder. Here is a basic example as well as a minimal and one with pipelines.

/default/builder.config.json
Minimal
With Pipelines


Legend to the above code

  • mainAppId: The main app for this deployment.

All non-brand-specific changes should be done to this app only!

  • targetApps: The target apps to which the main app is deployed (excluding global and app-specific protected files)
  • protectedFiles: Files to exclude from copying for all apps


Deployment Process (Preview)

When the preconditions are met, there will be a new menu entry at the top right Hamburger Menu in Experience Builder, called Deploy to Target Apps

Deploy to target apps


Clicking on Deploy to Target Apps opens a dialog

  • It shows a list of all Target Apps (they are links to the app)
  • It also shows the current state of the deployment
'Deploy to Target Apps' dialog
'Deploy to Target Apps' dialog


You have the option to change the configuration file inside the dialog directly

Deployment status configuration file
Deployment status configuration file


When you start a deployment, the dialog shows the status of the current deployment on the current app as well as on any target apps (while the target app is not finished being deployed).

Deployment status file
Deployment status file


Deployment process (Purple App Release Version)

We currently don't support a deployment process for to the Release Versions of your Purple Apps.

You have to manually download the dynamic resources from the preview app and upload it to the release app.

This can be done inside the Purple Manager > Select your App > 3 Dot Menu > Dynamic. Alternatively: Each App also has a quick link to the correct Purple Manager Page (seen below).

quick link to Purple Manager Page
quick link to Purple Manager Page


FAQ

Q: I can't see the Deploy to Target Apps Menu entry. A: The builder.config.json is either misconfigured or doesn't exist. Please make sure that it does follow the JSON guidelines and does not have any trailing commas.

Q: When I open an App I see the Deployment Status Dialog and can't close it. A: This happens when a deployment is triggered from the Main App, while the deployment process is in progress. Your app will be available (the dialog does disappear by itself) as soon as your app is deployed.

Q: The Deployment Dialog didn't update for a while, what should I do? A: This can happen when the Experience Builder gets redeployed by a Developer due to a current bug. While being redeployed, the Deployment Data stored on the server can not be cleared. The Data does clear itself after 60 seconds which then will allow you to edit Apps again, but you have to refresh the page.

Q: I get the following message when I hover the Deploy to Target Apps entry: "This is a target app for a deployment, to make changes to the deployment config open the main app or change the mainAppId" A: This happens when you are inside of a target app and this message functions mainly as a quick link to the main app. If you are inside of the main app and get the message, then change the mainAppId inside the builder.config.json

Q: I get the following message when I hover the Deploy to Target Apps entry: "In your deployment config is the property mainAppId missing, add it to enable this menu entry" A: This message comes when the mainAppId inside the builder.config.json is missing, the property is used when the JSON is populated to the target apps to differentiate if this is the main app or a target app.

Q: I get the following message when I hover the Deploy to Target Apps entry: "In your deployment config are no target apps configured, add one to enable this menu entry" A: This message comes when the targetApps inside the builder.config.json is missing or empty. This basically means you have no apps to deploy to so no reason to enable the menu entry.