Theme Overview
Align Critical Moments UI to your brand and app's style
Last updated
Align Critical Moments UI to your brand and app's style
Last updated
Themes control the style, colors and font of the Critical Moments UI. By specifying themes, you can align our UI to match the rest of your app, and fit in seamlessly.
Themes are defined in your config file.
A top level themes
object contains a defaultThemeName
string and a namedThemes
map/object, with subitems.
defaultThemeName [optional] defines a default theme. If can be one of the namedThemes
names, or one of the built in theme names:
namedThemes [optional] define custom themes which can be referenced by name from invividual actions, used as a fallback theme, or set as the defaultThemeName. See Custom Theme Config for details on how to create your own theme.
The Critical Moments Demo App can be used to experiment with themes.
Here's an example theme config specifying one custom theme, and setting it as the default via defaultThemeName
:
A theme is specified through a set of variables:
backgroundColor
string
"#ffffff"
The color used for the background of views. Should be a string of the hex color prefixed with #
.
Defaults to the system standard color (respecting dark mode).
primaryColor
string
"#ff0000"
The primary brand color. This is used for buttons, icons, links and more. Should be legible if used on top of backgroundColor. If you aren't setting a manual backgroundColor, check it is legible on the system's light and dark mode background.
If nil, will use system standard behaviour. On iOS will inherit tint from at runtime from the app wide AccentColor (defaults to "system blue").
primaryTextColor
string
"#000000"
The color used for primary content labels.
Defaults to the system standard color (respecting dark mode).
secondaryTextColor
string
"#111111"
The color used for secondary content labels.
Defaults to the system standard color (respecting dark mode).
bannerBackgroundColor
string
"#ffffff"
The background color of banner messages. Should be a string of the hex color prefixed with #
.
Defaults to a yellow color suitable for banners.
bannerForegroundColor
string
"#ffffff"
The foreground color of banner messages. Should be a string of the hex color prefixed with #
.
Defaults to a black.
fontScale
float
1.1
Scales the font size for all CM UI controls. Defaults to 1.0. Useful if your app's style uses font sizes consistently smaller or larger than the system default sizes.
Defaults to 1.0
fontName
string
"AvenirNext-Regular"
The default font to use. If nil, this theme will use the system font.
Check out https://iosfontlist.com for options, or use your own app-installed font.
boldFontName
string
"AvenirNext-Bold"
The default font to use for bold text. If nil, this theme will use the system font.
Check out https://iosfontlist.com for options, or use your own app-installed font.
scaleFontForUserPreference
bool
true
If true, will scale the font size based on the user settings in "Settings" app or control center. Defaults to true. Ideally leave this enabled for accessibility.
darkModeTheme
json object
If specified, a theme to use if the user has enabled "dark mode" for UI in settings. This object has the same structure as the root theme object.
If not set, we will use the root theme for both light and dark mode.
fallback
string
"oldTheme"
A theme name to fallback if this build does not support this theme.
For future use, if the theme spec grows and you continue to use the same config file for older builds using prior SDK version.