docs/docs/customization.md at main ยท feuzavalol/docs

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 โฌ‡๏ธ:

Footer Configuration Example


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.

Waffle Configuration Example

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.services is 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 apiUrl property