This plugin adds a progress bar to the top of your Codedoc documents. The progress bar extends itself to show the reading progress of the current document.
Using the Codedoc CLI, run the following command inside your project's folder:
$ codedoc install codedoc-readingprogress-plugin
To use the plugin, first edit your config.ts
file like below. Make sure you import the plugin at the top of the file, and then add it to the plugins
section in the configuration
function.
import { configuration } from '@codedoc/core';
import { readingProgressPlugin } from 'codedoc-readingprogress-plugin' // --> import the plugin
import { theme } from './theme';
export const config = /*#__PURE__*/configuration({
theme,
// other properties removed for brevity
plugins: [
readingProgressPlugin() // --> make sure you add this section
]
});
The appearance of the progress bar can be changed by passing a ReadingProgressOptions
object to the readingProgressPlugin()
function.
You can change the height and the colors of the progress bar for Codedoc's light and dark mode. If you supply two colors, the progress bar will be rendered with a nice gradient effect.
// imports removed for brevity
export const config = /*#__PURE__*/configuration({
theme,
// other properties removed for brevity
plugins: [
readingProgressPlugin({
height: 5,
lightMode: {
primaryColor: '#FDD819',
secondaryColor: '#E80505'
},
darkMode: {
primaryColor: '#FFF720',
secondaryColor: '#3CD500'
}
})
]
});
None of these options are mandatory, but if you add lightMode
or darkMode
, then you must supply at least the primaryColor
. If you supply the secondaryColor
, the progress bar will be gradient, otherwise the secondary color will be the same as the primary color.
Below is a reference of the supported options:
Option | Type | Required | Description | Default Value |
---|---|---|---|---|
height | number | No | The height of the progress bar (in pixels). | 3 |
lightMode | object | No | ||
lightMode.primaryColor | string | Yes | The primary color of the bar when in light mode. | #1eb2a6 |
lightMode.secondaryColor | string | No | The secondary color of the bar when in light mode. | = primaryColor |
darkMode | object | No | ||
darkMode.primaryColor | string | Yes | The primary color of the bar when in dark mode. | #1eb2a6 |
darkMode.secondaryColor | string | No | The secondary color of the bar when in dark mode. | = primaryColor |
This is a list of websites where you can find and create nice color gradients:
There's nothing else to be done. You just add the plugin and the progress bar will show up on every page! 😃
If you'd like to contribute to this plugin, here are some ideas for improvements:
-
The bar is just a
div
and the current animation is done by changing itswidth
property. I read that this is a CPU intensive task that causes the browser to do a lot of repaints. I wonder if it's possible to do it with CSS transforms (likescaleX
) instead. -
Right now the bar is shown for every document, but it's not really necessary on small documents that don't cause a lot of scrolling. There could be an option to set a minimum size and the bar would be hidden in smaller documents.
-
Codedoc has a nice and smooth transition effect when switching between light and dark modes, but unfortunately CSS gradients do not support it! Fortunately, this article by Keith Grant suggests a nice trick to do it. Maybe we could change the implementation to use it.
This plugin was based on this Pen implementation by Envato Tuts+.