mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2025-01-25 23:30:01 +00:00
96d4a3ecf7
Due to historical reasons, the code is in subfolder "1". With SVN removal, we place the code back and remove the annoying "1" folder.
26 lines
1.7 KiB
Markdown
26 lines
1.7 KiB
Markdown
## Dependencies
|
|
|
|
Themes are written using Sass to keep things modular and reduce the need for repeated selectors across files. Make sure that you have the reveal.js development environment including the Grunt dependencies installed before proceding: https://github.com/hakimel/reveal.js#full-setup
|
|
|
|
You also need to install Ruby and then Sass (with `gem install sass`).
|
|
|
|
## Creating a Theme
|
|
|
|
To create your own theme, start by duplicating any ```.scss``` file in [/css/theme/source](https://github.com/hakimel/reveal.js/blob/master/css/theme/source) and adding it to the compilation list in the [Gruntfile](https://github.com/hakimel/reveal.js/blob/master/Gruntfile.js).
|
|
|
|
Each theme file does four things in the following order:
|
|
|
|
1. **Include [/css/theme/template/mixins.scss](https://github.com/hakimel/reveal.js/blob/master/css/theme/template/mixins.scss)**
|
|
Shared utility functions.
|
|
|
|
2. **Include [/css/theme/template/settings.scss](https://github.com/hakimel/reveal.js/blob/master/css/theme/template/settings.scss)**
|
|
Declares a set of custom variables that the template file (step 4) expects. Can be overridden in step 3.
|
|
|
|
3. **Override**
|
|
This is where you override the default theme. Either by specifying variables (see [settings.scss](https://github.com/hakimel/reveal.js/blob/master/css/theme/template/settings.scss) for reference) or by adding full selectors with hardcoded styles.
|
|
|
|
4. **Include [/css/theme/template/theme.scss](https://github.com/hakimel/reveal.js/blob/master/css/theme/template/theme.scss)**
|
|
The template theme file which will generate final CSS output based on the currently defined variables.
|
|
|
|
When you are done, run `grunt css-themes` to compile the Sass file to CSS and you are ready to use your new theme.
|