CSS Injection
DANGER
🚨 CSS Injection is a deprecated feature and will be removed in the next major release planned on Q1 of 2024.
WARNING
🚨 If you are using CSS Injection for theming purpose, consider review design tokens based theming.
All our components use default Semrush styles (default theme prefixed with --intergalactic
in tokens). However, if your product uses a different color palette or you need to style the components differently, you may want to change the default Semrush styles. This page contains instructions on how to do that using the React Semcore plugin for Babel.
Step one
Install the component you want to restyle and our React Semcore plugin. They're needed to properly transpile the code. To install the plugin, use the following command:
npm i @semcore/babel-plugin-react-semcore
WARNING
⚠️ Attention. Don't process our files with Babel plugins in your code. This may lead to unpredictable results 🤕
Step two
Create a directory for components with injected CSS taking into account the following restrictions. They're needed because CSS injection are very much tied to naming and file structure.
- The directory with the CSS injection must contain directories with component names without the
@semcore
prefix. - Directories with component names should contain only
.shadow.css
files. - The names of
.shadow.css
files must match the names of the corresponding components' stylesheets.
In the following example, a directory contains three components:
components < --CSS injection root directory | ──button | └--button.shadow.css | ──product - head | └--product - head.shadow.css└── link└--link.shadow.css
Step three
Add a new rule to your webpack-config
:
{
test: /\.js$/,
include: /\/node_modules\/@semcore\//,
enforce: 'pre',
use: [{
loader: 'babel-loader',
options: {
plugins: [
['@semcore/babel-plugin-react-semcore', {
theme: path.resolve(process.cwd(), 'directory-with-injection')
}],
],
},
}, ],
}
TIP
You can also use the name of the package with CSS injections, for example { theme: "my-css injection-npm-package" }
.
After that, all the styles created in your CSS injection style directory will be applied to the corresponding components.
👯 Congratulations, you've changed the styles of the components!
Versioning
TIP
Versioning is optional, but recommended for your own comfort.
You can design a CSS injection for different component versions. To do this, create a versions.json
file and specify the versions and paths to the .css
files.
An example of file structure:
components < --CSS injection root directory | ──button└--button_v2.shadow.css└--button_v3.shadow.css└--versions.json
An example of the versions.json
file :
{
"2": {
"button.shadow.css": "button_v2.shadow.css"
},
"3": {
"button.shadow.css": "button_v3.shadow.css"
}
}
TIP
Versions follow the SemVer format, you can also specify *
.
Note
To develop CSS injections locally, you need hot module replacement. It won't work out of the box because CSS injections are applied during the build process and watchers can't see the changes. To fix that:
- Add
@semcore/shadow-loader
to the webpack configuration. - Add loaders for
.css
files
Example rules for webpack:
{
test: /\.js$/,
include: /\/node_modules\/@semcore\//,
use: {
loader: '@semcore/shadow-loader',
},
}, {
test: /\.css$/,
include: /\/node_modules\/\.cache\//,
use: ['style-loader', 'css-loader'],
}