Themes & Styles
Survey Creator supports appearance customization using UI themes that adjust the colors and sizes of the tool's UI elements. This help topic describes how to apply a predefined theme, create a custom theme, and give users the ability to modify a theme and persist these modifications.
Add Predefined Themes to Survey Creator
Survey Creator is shipped with four predefined themes:
- Light
- Dark
- Contrast
- Survey Creator 2020
data:image/s3,"s3://crabby-images/6c8d1/6c8d1d15677462127ecc55d057ce046ee34d787d" alt="Survey Creator UI themes"
By default, users can customize only the Light theme. To make other predefined themes available for customization, import or reference the following module/script:
// In modular applications:
import "survey-creator-core/themes";
<!-- In classic script applications -->
<head>
<!-- ... -->
<script src="https://unpkg.com/survey-creator-core/themes/index.min.js"></script>
<!-- ... -->
</head>
Run your application, open Survey Creator settings using the gear button in the bottom right, and ensure that the predefined themes are added to the Theme name dropdown.
data:image/s3,"s3://crabby-images/55f8a/55f8a28975b52f43310de97dc33944bcfa426385" alt="Survey Creator: Predefined themes in a drop-down list"
If you want to add only specific predefined themes, use the following imports or links. In this case, you need to register the themes using the static registerCreatorTheme(theme)
method:
Modular applications
import { SC2020, DefaultDark, DefaultContrast } from "survey-creator-core/themes";
import { registerCreatorTheme } from "survey-creator-core";
registerCreatorTheme(SC2020);
registerCreatorTheme(DefaultDark);
registerCreatorTheme(DefaultContrast);
Classic script applications
<head>
<!-- ... -->
<script src="https://unpkg.com/survey-creator-core/themes/sc2020.min.js"></script>
<script src="https://unpkg.com/survey-creator-core/themes/default-dark.min.js"></script>
<script src="https://unpkg.com/survey-creator-core/themes/default-contrast.min.js"></script>
<!-- ... -->
</head>
<body>
<script>
SurveyCreatorCore.registerCreatorTheme(SurveyCreatorTheme.SC2020);
SurveyCreatorCore.registerCreatorTheme(SurveyCreatorTheme.DefaultDark);
SurveyCreatorCore.registerCreatorTheme(SurveyCreatorTheme.DefaultContrast);
</script>
</body>
Apply a Predefined Theme in Code
The Light theme is applied with the survey-creator-core.css
style sheet. All other themes are defined as JSON objects that contain a unique theme identifier and a nested object with CSS variables that override the corresponding variables in the Light theme. To apply the Dark, Contrast, or Survey Creator 2020 theme, import or reference it and pass the theme JSON object to the applyCreatorTheme(theme)
method on a SurveyCreatorModel
instance:
Modular applications
// Option 1: Import an individual theme
import { SC2020 } from "survey-creator-core/themes";
// import { DefaultDark } from "survey-creator-core/themes";
// import { DefaultContrast } from "survey-creator-core/themes";
const creatorOptions = { /* ... */ };
const creator = new SurveyCreatorModel(creatorOptions);
creator.applyCreatorTheme(SC2020);
// Option 2: Import all themes
import "survey-creator-core/themes";
const creatorOptions = { /* ... */ };
const creator = new SurveyCreatorModel(creatorOptions);
creator.applyCreatorTheme(SurveyCreatorTheme.SC2020);
// creator.applyCreatorTheme(SurveyCreatorTheme.DefaultDark);
// creator.applyCreatorTheme(SurveyCreatorTheme.DefaultContrast);
Classic script applications
<head>
<!-- ... -->
<!-- Option 1: Reference an individual theme -->
<script src="https://unpkg.com/survey-creator-core/themes/sc2020.min.js"></script>
<!-- <script src="https://unpkg.com/survey-creator-core/themes/default-dark.min.js"></script> -->
<!-- <script src="https://unpkg.com/survey-creator-core/themes/default-contrast.min.js"></script> -->
<!-- ... -->
</head>
<body>
<script>
const creatorOptions = { /* ... */ };
const creator = new SurveyCreatorModel(creatorOptions);
creator.applyCreatorTheme(SurveyCreatorTheme.SC2020);
// creator.applyCreatorTheme(SurveyCreatorTheme.DefaultDark);
// creator.applyCreatorTheme(SurveyCreatorTheme.DefaultContrast);
</script>
</body>
<head>
<!-- ... -->
<!-- Option 2: Reference all themes -->
<script src="https://unpkg.com/survey-creator-core/themes/index.min.js"></script>
<!-- ... -->
</head>
<body>
<script>
const creatorOptions = { /* ... */ };
const creator = new SurveyCreatorModel(creatorOptions);
creator.applyCreatorTheme(SurveyCreatorTheme.SC2020);
// creator.applyCreatorTheme(SurveyCreatorTheme.DefaultDark);
// creator.applyCreatorTheme(SurveyCreatorTheme.DefaultContrast);
</script>
</body>
Save and Restore User-Made Customizations
You can save theme customizations made by a user in the browser's localStorage
and restore them next time the user opens Survey Creator. To access the theme JSON object, use the SurveyCreatorModel
's creatorTheme
property. Convert this object to string and save the result to the localStorage
.
const localStorageKey = "userSurveyCreatorTheme";
// Save a custom theme
const saveTheme = () => {
const themeStr = JSON.stringify(creator.creatorTheme);
localStorage.setItem(localStorageKey, themeStr);
};
// Restore a custom theme
const savedTheme = localStorage.getItem(localStorageKey);
if (savedTheme) {
creator.applyCreatorTheme(JSON.parse(savedTheme));
}
A custom theme can be saved automatically when a user changes it. To implement this functionality, handle the onCreatorThemePropertyChanged
event as follows:
creator.onCreatorThemePropertyChanged.add(() => {
const themeStr = JSON.stringify(creator.creatorTheme);
localStorage.setItem(localStorageKey, themeStr);
});
As an alternative, users can save a custom theme by clicking a custom toolbar button. To implement this functionality, refer to the following demo:
Create a Custom Theme
If none of the predefined themes meet your requirements, you can create a custom theme and apply it to Survey Creator or make it available to users for further customization. To learn more, refer to the following demo: