Styling an entire set of JavaScript components can be quite a challenge. Luckily, Sass, a powerful CSS tool, can simplify it! Our toolset, Wijmo, contains many components, including some very complex ones, like FlexGrid. We decided to fully leverage Sass to make our own work easier, but more importantly, it makes building a theme for all components easy for customers. Let’s walk through the steps below to build a complete Wijmo theme using just a few lines of Sass:
- Start with a JavaScript App
- Add a New Theme
- Reference the New Theme
- Run the App
- Customize the Theme
- Reuse the Theme
You can download this sample app and follow along yourself.
Ready to Try It Out? Download Wijmo Today!
Start with a JavaScript App
First, we will start with a simple JavaScript app that has a few Wijmo components in it (we won’t walk through building this app) and uses Sass for CSS, assuming we already installed Wijmo in our app using:
All Wijmo themes are installed with this command (which includes everything we need to build our theme). The Wijmo Sass and CSS files are all inside this single package: @mescius/wijmo.styles
Here is a breakdown of what is inside the package:
📄wijmo.scss |
Main file that compiles all parts together and applies variables. |
📁 misc |
Contains utilities for themes. It is good to reference _variables.scss in here to understand all available variables in Wijmo themes. |
📁 parts |
You won’t need to use this, but it contains all the CSS rules for our individual components. Feel free to take a look, though! |
📁 themes |
Contains all themes available for Wijmo. It’s good to look through these to find a theme close to what you want or to get an idea of how we build themes. |
Add a New Theme
Now, we want to find a theme that is close to what our theme will look like. You can test different themes from our demo site. Choose themes from the dropdown in the top right to see how components look.
After you decide on a theme you want to start with, find it in the node_modules\@mescius\wijmo.styles\themes directory.
For this tutorial, we will use Cleanlight. Let’s copy and paste that wijmo.theme.cleanlight.scss file into our root directory (you can put it anywhere you keep CSS files). You don’t want to keep your theme in the Wijmo package directory so that it will never get lost or overwritten. It should always exist in your own app (or in your own package if you plan to share it across apps).
Rename the file to give it a name that you like. We will name this one: wijmo.theme.custom.scss.
Our application now has a custom Wijmo theme in it:
The theme file has two parts:
- This first section sets (overrides default) variables
- The second section imports the wijmo.scss file and applies those variables
Since we moved the theme from node_modules into our root directory, we will need to change the path of the @import statement at the end of the theme file.
The new path should look like this:
Referencing the New Theme
Our application has a styles.scss file with basic CSS rules and previously imported a Wijmo theme. Now, we want to import our new theme instead. At the end of this file, let’s import our new theme (in this sample, it's in the same directory as our styles.scss file)
As for the app itself, we just import the compiled CSS files in app.js
Run the App
This app already uses Sass, but let’s make sure it's clear how. First, we need the Sass package in our package.json dependencies:
Next, we modify our scripts to add a “sass-dev” command to compile our scss files into CSS files. We also modify our “start” command to run the “sass-dev” command before running the app.
After those things are set up in our app (assuming we already ran “npm install”), we can run the following:
Now we see our app running using our new theme!
Customizing Our Theme
Now that our new theme is running in our app, it's time to customize it to our liking.
As a convenience, we recommend opening _variables.scss file and copying its contents into the top of the new theme, then commenting them out. These variables already have little comments next to them that describe what they style, and you can also see their default values. Here is an example of the top of our custom theme file with all possible variables commented out:
Note: most Wijmo themes don’t override all variables. You only need to override what you want to change from our default. Usually, it's just a small subset of them.
Okay, now we will customize our new theme. Here is a short list of things we want in this new theme:
- Larger padding (in cells, buttons, etc.) for a more modern look
- Black/dark gray text
- Nice purplish grays for headers
- White background for the main content
- Teal color for highlights
- Remove cell borders in the grid
- Purple tooltip
Here are the contents of our entire theme. It's just a few lines of setting variables to style every JavaScript component in Wijmo!
The results are as shown:
That’s it! You can continue to refine the theme as much or as little as you like.
Reusing Your Theme
We already finished building a theme, but what if you want to share this theme across many apps? Of course, you can copy and paste it, but there is another option.
Optionally, you can manage this theme in a separate project and publish only this theme on npm (or your own private registry). Then, any of your apps can install and import the shared theme via npm. This is the best option for large companies that share a theme across many teams and apps. If you do end up publishing a theme publicly, please let us know. We would love to take a look and even share it if you like.
Ready to Try It Out? Download Wijmo Today!