Customization Guide ๐ ๏ธ
Runtime Theming ๐จ
How to Use
To use this feature, simply set the FRONTEND_CSS_URL environment variable to the URL of your custom CSS file. For example:
FRONTEND_CSS_URL=http://anything/custom-style.css
Once you've set this variable, Docs will load your custom CSS file and apply the styles to our frontend application.
Benefits
This feature provides several benefits, including:
- Easy customization ๐: With this feature, you can easily customize the look and feel of our application without requiring any code changes.
- Flexibility ๐: You can use any CSS styles you like to create a custom theme that meets your needs.
- Runtime theming โฑ๏ธ: This feature allows you to change the theme of our application at runtime, without requiring a restart or recompilation.
Example Use Case
Let's say you want to change the background color of our application to a custom color. You can create a custom CSS file with the following contents:
body { background-color: #3498db; }
Then, set the FRONTEND_CSS_URL environment variable to the URL of your custom CSS file. Once you've done this, our application will load your custom CSS file and apply the styles, changing the background color to the custom color you specified.
Runtime JavaScript Injection ๐
How to Use
To use this feature, simply set the FRONTEND_JS_URL environment variable to the URL of your custom JavaScript file. For example:
FRONTEND_JS_URL=http://anything/custom-script.js
Once you've set this variable, Docs will load your custom JavaScript file and execute it in the browser, allowing you to modify the application's behavior at runtime.
Benefits
This feature provides several benefits, including:
- Dynamic customization ๐: With this feature, you can dynamically modify the behavior and appearance of our application without requiring any code changes.
- Flexibility ๐: You can add custom functionality, modify existing features, or integrate third-party services.
- Runtime injection โฑ๏ธ: This feature allows you to inject JavaScript into the application at runtime, without requiring a restart or recompilation.
Example Use Case
Let's say you want to add a custom menu to the application header. You can create a custom JavaScript file with the following contents:
(function() { 'use strict'; function initCustomMenu() { // Wait for the page to be fully loaded const header = document.querySelector('header'); if (!header) return false; // Create and inject your custom menu const customMenu = document.createElement('div'); customMenu.innerHTML = '<button>Custom Menu</button>'; header.appendChild(customMenu); console.log('Custom menu added successfully'); return true; } // Initialize when DOM is ready if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', initCustomMenu); } else { initCustomMenu(); } })();
Then, set the FRONTEND_JS_URL environment variable to the URL of your custom JavaScript file. Once you've done this, our application will load your custom JavaScript file and execute it, adding your custom menu to the header.
Your Docs icon ๐
You can add your own Docs icon in the header from the theme customization file.
Settings ๐ง
THEME_CUSTOMIZATION_FILE_PATH=<path>
Example of JSON
You can activate it with the header.icon configuration: https://github.com/suitenumerique/docs/blob/main/src/helm/env.d/dev/configuration/theme/demo.json
This configuration is optional. If not set, the default icon will be used.
Footer Configuration ๐
The footer is configurable from the theme customization file.
Settings ๐ง
THEME_CUSTOMIZATION_FILE_PATH=<path>
Example of JSON
The json must follow some rules: https://github.com/suitenumerique/docs/blob/main/src/helm/env.d/dev/configuration/theme/demo.json
footer.default is the fallback if the language is not supported.
Below is a visual example of a configured footer โฌ๏ธ:
Custom Translations ๐
The translations can be partially overridden from the theme customization file.
Settings ๐ง
THEME_CUSTOMIZATION_FILE_PATH=<path>
Example of JSON
The json must follow some rules: https://github.com/suitenumerique/docs/blob/main/src/helm/env.d/dev/configuration/theme/demo.json
Waffle Configuration ๐ง
The Waffle (La Gaufre) is a widget that displays a grid of services.
Settings ๐ง
THEME_CUSTOMIZATION_FILE_PATH=<path>
Configuration
The Waffle can be configured in the theme customization file with the waffle key.
Available Properties
See: LaGaufreV2Props
Complete Example
From the theme customization file: https://github.com/suitenumerique/docs/blob/main/src/helm/env.d/dev/configuration/theme/demo.json
Behavior
- If
data.servicesis provided, the Waffle will display those services statically - If no data is provided, services can be fetched dynamically from an API endpoint thanks to the
apiUrlproperty

