Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/byteclubfr/prez
Generate Reveal.js slideshows from a set of markdowns
https://github.com/byteclubfr/prez
reveal-js
Last synced: 28 days ago
JSON representation
Generate Reveal.js slideshows from a set of markdowns
- Host: GitHub
- URL: https://github.com/byteclubfr/prez
- Owner: byteclubfr
- Created: 2015-01-23T01:20:55.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2021-05-04T07:31:57.000Z (over 3 years ago)
- Last Synced: 2024-11-06T05:16:12.435Z (about 1 month ago)
- Topics: reveal-js
- Language: JavaScript
- Size: 390 KB
- Stars: 227
- Watchers: 13
- Forks: 42
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![npm version](https://badge.fury.io/js/prez.svg)](http://badge.fury.io/js/prez)
[![Dependency Status](https://david-dm.org/byteclubfr/prez.png)](https://david-dm.org/byteclubfr/prez)## prez
Opinionated [Reveal slideshow](http://lab.hakim.se/reveal-js) generator with nice PDF output and ability to treat [notes](https://github.com/hakimel/reveal.js#speaker-notes) as first-class content.
### Install
```sh
npm install -g prez
```### Feel the magic
Check that you have **node 6** installed:
```sh
node --version
6.x.x
```In your terminal, go to an empty directory and run:
```sh
prez --init
```A sample workspace has been generated for you. Then run:
```sh
prez --serve --print --watch
```* edit your slides from `slides` folder (html or [markdown](https://www.npmjs.com/package/marked))
* if you need some assets, you can work in `images`, `css`, `js`, `media` folders and use `includes.txt`
* your slideshow is automatically built into `build` folder
* your slideshow is hosted and your browser is opened to localhost:9000
* any change you make will rebuild and refresh your browser
* oh, and a printer-friendly `slides.pdf` is automatically generated on any change too### Slides structure and format
* Slides and chapters (vertical stacks) are sorted by name.
* If a slide or a chapter name starts with a dot `.` (hidden), it will be skipped. (or use `--keep-hidden`)
* You can number your slides to ensure order by adding a "*number*-" prefix, it will be automagically stripped out.
* Each slide will have an id generated from filename (removing accents and spaces).
* If you use `--sub-covers` the title is the stripped name, accents and case remain untouched.#### Sample structure
```
images/
js/
css/
slides/
01-intro.md
02-Chapter 1/
01-hello-world.md
02-bonjour-monde.md
03-conclusion.md
```#### Sample slide
```md
# Slide's titleContent of your slide
note:
Your notes go here.
Complex (multiline, code samples, etc.) notes are really supported only with --such-notes.
```#### Customize slide attributes
You can set per-slide properties like general style, [background](https://github.com/hakimel/reveal.js/#slide-backgrounds) or [transition](https://github.com/hakimel/reveal.js/#slide-transitions) by adding special lines at **the head of your slides**:
* `$class:some class$` add class
* `$id:id$` replace automatic id, if you set it to "none", it will remove any id on the slide
* Any other property will be added as a data-attribute, here are some examples supported by Reveal:
* `$background:/path/to/image.jpg$`
* `$background-video:/path/to/video.webm$`
* `$background-iframe:http://mysite.com$`
* `$transition:zoom$`
* `$transition-speed:fast$`### Step by step
#### Initialize sample workspace
```sh
mkdir sandbox
cd sandboxprez --init
```This will create a full workspace with `js`, `images`, etc… where you'll put your custom content. In reality the only required folder is `slides`.
#### Build
```sh
prez
```This will create a `build` folder with your slideshow.
#### Show
```sh
prez --serve
```This will run a server on port 9000 and open your local browser to your slideshow.
```sh
prez --print --print-theme=simple
```This will generate "slides.pdf" from your slideshow.
### Such notes!
Option `--such-notes` modifies the print layout and the notes popup so that notes have more space.
![](such-notes.png)
### Usage
`prez [ []] [options]`
* `source` is the slideshow workspace (where you'll have your slides and assets), default = `./`
* `destination` is the target directory, default = `./build/`#### Available options:
* `-v`, `--version`: show version and exit
* `-s `, `--slides-dir=`: customize name of the folder containing slides (default = `slides`)Assets & slides
* `--init`: populate your new presentation with dummy initial data (see the content of `data/init`)
* `--skip-reveal`: do not copy reveal.js slides into target directory (useful if you want faster build over existing build)
* `--skip-index`: do not generate `index.html` in target (will remain untouched if already existing)
* `--skip-user`: do not include user assets
* `--keep-hidden`: render slides or chapters starting with a dot `.`
* `--sub-covers`: auto generate cover slides with the dir name as a h1 for each chapter (vertical stack of slides)Custom parser
* `--parser`: parser used to convert slides from Markdown to HTML, available values are:
* *marked* (default, depending on [`marked`](https://www.npmjs.com/package/marked) and `highlight.js`, automatically embedded)
* *marky-markdown* (requires installation of [`marky-markdown`](https://github.com/npm/marky-markdown) and note that [`highlight`](https://www.npmjs.com/package/highlights)'s themes are not embedded so you'll have to include the CSS file yourself yet)
* *markdown-it* (requires installation of [`markdown-it`](https://github.com/markdown-it/markdown-it))
* *remarkable* (requires installation of [`remarkable`](https://github.com/jonschlinkert/remarkable))
* Path to custom module, relative to current working directory. This module's default export must be a function taking a string (original content) and return a string (converted content). You can use a custom module when you need to call an external command, or our defaults do not match your preferences. You can browser `lib/parsers` to look for our implementations.Meta
* `--title=`: specify the title of your presentation (default = `package.json name` if found or `Prez`)
* `--author=`: specify the author of your presentation (default = `package.json author` if found)
* `--description=`: specify the description of your presentation (default = `package.json description` if found)Theme
* `--theme=`: choose [reveal theme](https://github.com/hakimel/reveal.js/tree/master/css/theme) (default = `solarized`)
* `--highlight-theme=`: choose [highlight.js theme](https://github.com/isagalaev/highlight.js/tree/master/src/styles) (default = `zenburn`)
* `--no-dynamic-theme`: disable ability to change theme from query string
* `--print-notes`: enable special print layout with first-class notes
* `--such-notes`: focus on notes, which will enable a special print layout with notes as first-class content, and more space for them in the notes popupLive server
* `-w`, `--watch`: automatically rebuild (lazy) on changes
* `--serve[=]`: serve slideshow (you can specify port here or use `--port`)
* `-p `, `--port=`: modify http server port (default 9000), you can use value `auto` to use a random available port
* `--no-live-reload`: disable live-reload when serving slideshow
* `--no-open-browser`: do not open local browser automatically when serving slideshow* `--print[=]`: print slideshow as pdf (requires `--serve` and phantomjs must be installed)
* `--print-theme=`: theme to be used for pdf output (default = no override)
* `--phantomjs=`: path to phantomjs (default = `phantomjs`)Misc
* `--no-update-notifier`: disable version checking
* `--stats`: display visual stats about your slides and chapters![](stats.jpg)
#### Configuration file
You can store your default preferences in a configuration file. Take a look at [CONFIG.md](CONFIG.md) for details and see examples on the [Wiki](https://github.com/byteclubfr/prez/wiki/prezrc-example).
### TODO
* Lazier reprint in watch mode
* FIX issue with notes too tall in printed pdf