Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fiqus/prexent
🎥 Fast, live and beautiful presentations from Markdown powered by Phoenix LiveView
https://github.com/fiqus/prexent
elixir-lang markdown phoenix-framework phoenix-liveview presentation-slides
Last synced: 3 months ago
JSON representation
🎥 Fast, live and beautiful presentations from Markdown powered by Phoenix LiveView
- Host: GitHub
- URL: https://github.com/fiqus/prexent
- Owner: fiqus
- License: mit
- Created: 2019-09-19T22:48:16.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-04T22:01:33.000Z (about 2 years ago)
- Last Synced: 2024-10-18T09:06:42.815Z (3 months ago)
- Topics: elixir-lang, markdown, phoenix-framework, phoenix-liveview, presentation-slides
- Language: Elixir
- Homepage:
- Size: 12.2 MB
- Stars: 85
- Watchers: 7
- Forks: 7
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-speaker - prexent - Create fast, live and beautiful presentations from Markdown powered by Phoenix LiveView with the ability to run and edit live code (for languages you have the interpreter for). (Presentation Editors)
README
# Prexent
[![Hex pm](http://img.shields.io/hexpm/v/prexent.svg?style=flat)](https://hex.pm/packages/prexent)> ### Markdown |> HTML |> code |> run |> edit
> Create fast, live and beautiful presentations from Markdown powered by Phoenix LiveView.This is the Spawnfest 2019 project by [Fiqus](https://github.com/fiqus) team.
A HTML presentations generator from markdown files with the ability to *run* and *edit* live elixir code (and other languages you have the interpreter for).
Once you create a prexent, the dependency will be installed on top of Phoenix and LiveView, gaining all its powerfull features.Install the mix archive, create presentations quicky on the fly, edit markdown, include your code and prexent!
This tool is meant to be adopted by the Elixir community as a main presentation utility.
## Pre-requisites
* `Elixir` 1.7 or later
* `Erlang/OTP` 21 or later## Create a presentation
Install the mix archive installer from Hex:$ mix archive.install hex prexent_new 0.2.1
Or create it from an unreleased version:
$ cd installer
$ mix do archive.build, archive.installThe installer is installed globally for your elixir version and with this you will be able to create multiple presentations quickly.
Create a new presentation in any directory:
$ mix prexent.new nice_talk
The installer will prompt you to confirm installing all the dependecies, `prexent` will be installed!
$ cd nice_talk
$ mix deps.getThis mix task will create the project structure and a `slides.md` with demo Markdown, feel free to edit it!
Then, run prexent:
$ mix prexent
If you change the file name you can optionally pass that to the task:
$ mix prexent source_file.md
Access to `http://localhost:4000` for the slideshow view or `http://localhost:4000/presenter` for the presenter view.
## Prexent commands
Customize your presentations, add prexent commands wherever you want in your markdown file:
#### Live code
!code code/my_function.exsFor other languages than elixir you have to specify the language (2nd param) and the interpreter (3rd param), i.e:
!code code/code.py python python3
#### Header, footer, css..
!header Fiqus
!footer SliderAdd your(s) custom css:
!custom_css custom.css
For custom syntax highlighting, you can see [demos](https://highlightjs.org/static/demo/) of the available schemas.
You can download any of them [here](https://github.com/highlightjs/highlight.js/tree/master/src/styles) and include them in your markdown file.#### Background image
Global background!global_background /background.jpg
Background for a specific slide
!slide_background /background.jpg
#### Include other markdown files
!include partial.md#### Comment
The comment is only shown in the presenter view.!comment tip for this slide!
## Examples
The Prexent source code ships with some prexent project presentations examples under `/examples`.
Try them yourself!$ cd examples/photos
$ mix deps.get
$ mix prexentEnjoy!