-
Notifications
You must be signed in to change notification settings - Fork 14
Theming LODEX
LODEX has always allowed theming, but since LODEX 14.0.27, a dynamic system has been added to allow easy theme creation.
To allow this, a themes
folder is available in
the src/app/custom/ directory.
And a `themes' configuration to enable or disable themes is available in
the config.json file.
- Public Panel: Page generated with the dataset and model
- Admin Panel: Page used to add a dataset and model
- Root Panel: Page used to create instances
A theme requires at least one file; this file must be a json file called lodex-theme.json
.
LODEX will not load the theme without this file.
Any other file is optional, and if you want to override the default main theme palette and index file, you must declare it in the theme file.
themes
├── myTheme
│ ├── lodex-theme.json
│ ├── index.ejs
│ ├── theme.js
│ └── theme.css
└── otherTheme
└── ...
The theme file is the declaration of a theme, containing the name, description and other metadata required to load and apply it correctly.
The version
corresponds to the LODEX theme system version, if the theme is a different version,
a message will be shown in the console and an outdated text will be added to the description.
To see all the changes, you can consult the
changelog bellow.
The name
and description
are used to localise and describe the theme in LODEX Admin Panel.
The configuration
are optional but allow you to override the index.ejs
file and the theme palette,
these files must be in the same directory as the theme file.
This object also allows you
to add custom variables into the ejs template to give access to a better customisation in the
Public Panel (e.g.: custom title and summary to reflect the corpus dataset)
{
"version": "4",
"name": {
"fr": "Système",
"en": "System"
},
"description": {
"fr": "Thème système",
"en": "System theme"
},
"configuration": {
// Optional files to replace the default mui theme and the index
"files": {
"index": "index.ejs",
"palette": "systemTheme.js"
},
// Optional Record<string, string> list all default value for custom variables
// to be used in the EJS template
"variables": {}
}
}
This html index is an EJS files, we use ejs to provide templating to allow dynamic modification of the html inner content.
In the EJS template you have access to the following variables:
-
lodex
-
version
(string) access to the current LODEX version -
tenant
(string) access to the current tenant -
istexApi
(url or an empty string if non-pertinent) access to the ISTEX api url if available -
preload
(json as string) access to the preload stats of lodex -
base
-
href
(host with port, or an empty string if non-pertinent) access to the LODEX api host
-
-
-
theme
-
cssVariables
(string containing css) access to all css variables -
base
-
href
(host with port, or an empty string if non-pertinent) access to the lodex front host (pertinent in development environment)
-
-
-
custom
custom is an object use as a key value map containing all variables declared inconfiguration.variables
and in the Admin Panel.
If you want to minify css you need to install clean-css-cli via the following command npm install -g clean-css-cli
.
To minify css files, you can use the following command with your
files cleancss -o ./src/app/custom/themes/theme-name/css-file.min.css ./src/app/custom/themes/theme-name/css-file.css
.
Version under-development
Update the html structure
- Home pages now have
home-page
id. - Version Compoments is now at the end of the div with the
root
id. - NavBar is now at the end of the div with the
root
id. - Updated version compoment to have
version
as id and changed some internal html compoments. - Add a top div for the breadcrumb with
breadcrumb
as id. - Breadcrumb item now handles https url not declared as external.
- Removed version from detail
- Resource now has
resource-page
as id andresource
as class and the redondent div has been removed. - Flatten HTML structure by removing app components (div with
page-page
andbody
class) - Add a div with
content
as id with a container inside that contains the page content. - Version, Breadcrumb and NavBar now have a container to handle left and right padding.
Available since 14.0.55
-
theme.base.href
now target the theme folder -
theme.current.href
as been added and target the current theme folder, this variable target thedefault
folder if the index has not been declared
Available since 14.0.54
-
theme.base.href
now target the current theme folder, this mean is not only pertinent in development environment
Available since 14.0.54
- Update theme file to have a future-proof structure
- Remove
files.theme
and replace it toconfiguration.files
- Add a
configuration.variables
to allow adding custom variables to EJS template - Replace
main
(js color theme fromfiles.theme
) topalette
(js color theme fromconfiguration.files
)
- Remove
- Remove root configuration variables used in EJS template
This version changes only the custom variables system and allows a more user-friendly implementation of this system. The default values are now declared in the theme files with change in the file structure. The values are now editable via the instance configuration in the Admin Panel.
Old theme file
{
"version": "3",
"name": {
"fr": "Système",
"en": "System"
},
"description": {
"fr": "Thème système",
"en": "System theme"
},
"files": {
"theme": {
"main": "systemTheme.js",
"index": "index.ejs"
}
}
}
New theme file
{
"version": "4",
"name": {
"fr": "Système",
"en": "System"
},
"description": {
"fr": "Thème système",
"en": "System theme"
},
"configuration": {
"files": {
"index": "index.ejs",
"palette": "systemTheme.js"
}
}
}
Available since 14.0.52
- Remove
restricted
from the LODEX theme file - Update color palette system
- Admin Panel now uses the file from System Theme (default)
- Public Panel, Admin Panel and Root Panel now use the same css file as
base
src/app/custom/themes/default/css/styles.css
- Default background change from
#fff
to#fafafa
- Paper background change from
#fff
to#fafafa
- Update rendering system to fully use ejs
- The index html need to have the
ejs
extension and not the classichtml
, this is to show the usage of ejs. - Every other change does not have a major impact on the theme creation, but we recommend you to create a new theme with the default as a base.
Warning: This version in un-versioned, this means you need to use the version 2
, the theme system works differently
from the previous version.
Available since 14.0.48
- Default theme is now a proper theme
- Now using
ejs
instead of regex for HTML template
EJS available variable:
-
lodex.version
: LODEX Version -
lodex.base.href
: replace{|__JS_HOST__|}
-
theme.base.href
: replace{|__THEMES_HOST__|}
Example of EJS Call:
<%= theme.base.href %>
Warning: This version in un-versioned, this means you need to use the version 2
, the theme system works differently
from the previous version.
Available since 14.0.45
- Theme folder move from
src/themes
tosrc/app/custom/themes
- Symlink create from
src/app/custom/themes
tosrc/themes
Theme folder: src/app/custom/themes
and src/themes
Available since 14.0.34
- Theme import system updated
Available since 14.0.27
Theme folder: src/themes
-
{|__JS_HOST__|}
: Allow access to application files (relevant in dev mode, this allows access to webpack) -
{|__THEMES_HOST__|}
: Allow access to theme files (always in dev mode, this allows access to the API)