Project

prez

0.0
No commit activity in last 3 years
No release in over 3 years
Gem to aid in the creation of single file HTML presentations.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.7
~> 10.0

Runtime

~> 2.4
~> 3.4
~> 0.19
~> 2.7
 Project Readme

Prez

Simple single file HTML presentations.

Installation

Simply install this gem:

$ gem install prez

Usage

If you want to create a new presentation:

$ prez new MyPresentation

Modify the resulting template file, and build the final file:

$ prez build MyPresentation

Copy the file where-ever you want and then run it by opening it in your browser!

Alternatively, launch the presentation directly in your browser without creating the HTML file:

$ prez start MyPresentation

Syntax

Build a new slide

<% slide do %>
  <p>
    Contents of your slide!
  </p>
<% end %>

Provide notes for your slide

<% slide do %>
  <p>
    Contents of your slide!
  </p>

  <% notes do %>
    These notes show up just for you while presenting this slide.
  <% end %>
<% end %>

Add extra slide elements

<% slide do %>
  <p>
    Contents of your slide!
  </p>

  <% element do %>
    <p>
      A second slide element.
    </p>
  <% end %>

  <% element do %>
    <p>
      A third slide element.
    </p>
  <% end %>
<% end %>

Slide elements are pieces of a bigger slide that show up when you advance to the next slide, but before actually moving to the next slide. The slide will not continue until all elements are shown.

By default, slide elements are represented as divs. You can change the tag that is used by providing it in the tag option, or just embed the element directly and use the prez-element class.

<% slide do %>
  <ul>
    <li>
      First element
    </li>

    <% element tag: :li do %>
      Second element
    <% end %>

    <li class="prez-element">
      Third element
    </li>
  </ul>
<% end %>

Note that all elements are always hidden when a slide first appears. Any content you want displayed should not be contained in an element.

Slide horizontal alignment

By default, slides are center aligned. To left or right align, you may provide it as an option to the slide method:

<% slide align: :right do %>
  ...
<% end %>

<% slide align: :left do %>
  ...
<% end %>

Presentation timing

<% duration 300 %>

You can indicate how much time your presentation should take using the duration helper. It accepts either the number of seconds for the total presentation, or a string representation of the form hours:minutes:seconds. For example, "2:30:00" would represent 2 hours and 30 minutes.

Before you start your presentation, you can adjust the amount for the current run. During your presentation, the time will be displayed in the upper left corner. If you are running low on time, the remaining time will turn red and flash. Once you are over, the time will stay solid red and start to count up.

Slide timing

Each slide will have a time limit based on the total duration provided in the upper right corner. It is simply the total time remaining divided by the remaining slides, ignoring slides that have specific timing specified.

Specific timing can be provided to a slide via the duration option in the slide method. It accepts the amount of seconds as a number.

<% slide duration: 15 do %>
  ...
<% end %>

Like the total duration, the slide duration will begin to flash red when it is running out, and it will stay solid red and count up when you are over.

Include custom JS or CSS

<html>
  <head>
    <%= javascript "myCustomScript" %>
    <%= stylesheet "myCustomStyle" %>

CoffeeScript and Sass are supported. If the file is first found in the current directory, searching will stop. The next path will be the javascripts or stylsheets directory from within the current directory depending on which asset you are including. If all those fail, the file will be searched within the prez gem itself. An error will be thrown if the asset cannot be found.

You can specify the full file name directly, or let the helper find it for you. For JavaScript, the extensions searched will be (in this order): .js.coffee, .coffee and .js. For stylesheets, the extensions will be: .css.scss, .scss and .css.

These assets will be minified before inserting them in the resulting HTML file.

Include images

<% slide do %>
  <p>
    <%= image "myImage" %>
    <%= image "otherImage.png", width: "50%" %>
    <%= image "yetAnotherImage.gif", height: "50%" %>
  </p>
<% end %>

Like JS and CSS assets, the images will be searched from the current directory, then the images directory from within the current directory. Also, the extension is optional and can be one of: .gif, .jpeg, .jpg, .png, .svg, .tif or .tiff.

A width and height option are allowed, which will add the respective attribute to the resulting img tag.

Contributing

  1. Fork it ( https://github.com/mikestone/prez/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request