Skip to content

Latest commit

 

History

History
140 lines (99 loc) · 4.38 KB

README.md

File metadata and controls

140 lines (99 loc) · 4.38 KB

ThemeOverride

A reveal.js 3.x / 4.x plugin to easily change themes of reveal.js and its syntax highlightning.

Installation

Copy this repository into the plugin folder of your reveal.js presentation, ie plugin/themeoverride.

Add the plugin to the initialization of your presentation, as below.

reveal 4.x

<script src="plugin/themeoverride/themeoverride.js"></script>
// .. 
Reveal.initialize({
	// ...
	plugins: [
		// ..
		ThemeOverride,
	]
});

reveal 3.x

Reveal.initialize({
	// ...
	dependencies: [
		// ...
		{ src: 'plugin/themeoverride/themeoverride.js', async: true },
	]
});

For reveal 3.x only you may need to edit your HTML file to be able to override themes.

  • The <link> element of the reveal.js theme needs an id attribute of theme.
  • The <link> element of the syntax highlighting theme needs an id attribute of highlight-theme.
<head>
	...
	<link rel="stylesheet" href="css/theme/black.css" id="theme">
	<link rel="stylesheet" href="lib/css/zenburn.css" id="highlight-theme">
	...
</head>

The value for this id is not configurable. It must be theme and highlight-theme respectivly otherwise the plugin will not find the stylesheets in your presentation file.

Remark

Please remember that no other syntax highlightning themes besides zenburn.css are shipped with the standard reveal.js package. You may want to install further highlight.js themes from https://highlightjs.org/ into the same directory as the shipped themes.

Usage

After installation theme settings are allowed in different places. The theme applied to your presentation is the first found from the following list:

  1. URI parameter
  2. Configuration options
  3. <link> element

Configuration

You can configure some aspects of the plugin by adding the following options to your reveal configuration. Note that all configuration values are optional and will default to the settings from your link elements.

Configuration options are useful if you have further plugins installed like AltMode to toggle between different themes during your live presentation.

Reveal.initialize({
	// ...

	// Overrides the theme set in <link> element by the
	// given value.
	// If your presentation was copied from the reveal.js demo.html,
	// everything just works.
	// Otherwise you need to set id="theme" on reveal.js theme
	// <link> element.
	theme: 'serif',

	// Overrides the syntax highlightning theme set in <link> element
	// by the given value.
	// For reveal 4.x, if your presentation was copied from the reveal.js
	// demo.html, everything just works.
	// For reveal 3.x this only works if you set id="highlight-theme"
	// on the <link> element.
	highlightTheme: 'monokai',
});

URI parameter

URI parameter come in handy if you just want to try out new themes without editing your presentation file.

http://example.com/demo.html?theme=serif&highlightTheme=monokai

Theme values

Values for themes may contain one of the following:

  • a style name (eg. serif). The plugin will append .css to the name and tries to access the file from the theme directory of reveal.js or the syntax highlightning theme directory relative to your reveal.js installation.

  • a stylesheet filename (eg. serif.css). The plugin will try to access the file from the theme directory of reveal.js or or the syntax highlightning theme directory relative to your reveal.js installation.

  • a relative path with filename (eg. dist/theme/serif.css). The plugin will try to access the file relative to your reveal.js installation.

API

CSS

To apply style overrides depending on the displayed themes, the plugin will add data attributes with the names of the active themes as values to the <body> element like:

...
<body data-theme="serif" data-highlight-theme="monokai">
...

Javascript

The plugin API is accessible from the global ThemeOverride object.

// Change a config value at runtime
ThemeOverride.configure({
	// Takes the same options as for configuration
	theme: 'serif.css',
	highlightTheme: 'monokai',
});

License

MIT licensed.

Copyright (C) 2020 Sören Weber