mdpress-0.0.15/0000755000175000017500000000000012250154716012633 5ustar boutilboutilmdpress-0.0.15/examples/0000755000175000017500000000000012250154716014451 5ustar boutilboutilmdpress-0.0.15/examples/helloworld.md0000644000175000017500000000006712250154716017151 0ustar boutilboutil# Hello ## World! --- = data-x='1000' # Hi, mdpress! mdpress-0.0.15/examples/code.md0000644000175000017500000000014112250154716015701 0ustar boutilboutil# Here's some code! def fib x return x if x < 2 fib(x - 1) + fib(x - 2) end mdpress-0.0.15/examples/demo.md0000644000175000017500000000055412250154716015723 0ustar boutilboutil--- author: Aditya Bhargava title: All about chicken --- # Just because ## my middle name is **Pancake**, > doesn't mean you can put syrup on me before I'm ready to come out of the oven. mdpress++ --- = data-x='1000' # Let's Make Lists! 1. Chicken 2. *Emphasized Chicken* 3. [Chicken Link](http://github.com/egonschiele/mdpress) - unordered `chicken = 1` mdpress-0.0.15/bin/0000755000175000017500000000000012250154716013403 5ustar boutilboutilmdpress-0.0.15/bin/mdpress0000755000175000017500000001075612250154716015017 0ustar boutilboutil#!/usr/bin/env ruby require 'rubygems' require 'redcarpet' require 'fileutils' require 'impress_renderer' require 'trollop' require 'tempfile' require 'launchy' require 'yaml' THEMES_DIRNAME = './themes/' def log(x) puts "\033[94m" + x + "\033[0m" if OPTS[:verbose] end def base_dir File.dirname(__FILE__) + "/../lib/" end def list_available_stylesheets log "Available stylesheets:" log "mdpress stylesheets" Dir.glob(base_dir + "impress_css/*.css").each do |file| puts File.basename(file, ".css") end log "Local stylesheets" Dir.glob(THEMES_DIRNAME + "*.css").each do |file| puts File.basename(file, ".css") end end def readfile file if file =~ /^http/ require 'httparty' response = HTTParty.get(file) if response return response.body else raise "couldn't download url: #{file}" end else return File.read(file) end end def extract_metadata text if md = text.match(/\A(---\s*\n.*?\n?)^(---\s*$\n?)/m) [md.post_match, YAML.load(md[1])] else [text, {}] end end def render opts text, metadata = extract_metadata(readfile(FILENAME)) # ugly hack to get attributes for impress.js # TODO make this pretty lines = text.split("\n") lines.drop_while { |l| l =~ /^\s*$/ } attrs = [""] new_lines = [] lines.each_with_index do |line, i| if line =~ /^=(.*)$/ && (i == 0 || lines[i-1] =~ /^(-\s*){3,}$/) line =~ /^=(.*)$/ attrs[attrs.size-1] = $~.to_a[1] next elsif line =~ /^(-\s*){3,}$/ attrs << "" end new_lines << line end text = new_lines.join("\n") # now use those attributes and render the file include Redcarpet ImpressRenderer.init_with_attrs attrs, opts ImpressRenderer.author= metadata['author'] if metadata['author'] ImpressRenderer.title= metadata['title'] if metadata['title'] if File.exist?(STYLESHEET_HEAD) ImpressRenderer.head= File.read(STYLESHEET_HEAD) end m = Markdown.new(ImpressRenderer, :autolink => true, :fenced_code_blocks => true, :tables => true) log "rendering presentation" f = File.open(DIRNAME + "/index.html", "w+") f.write(m.render(text)) f.close end OPTS = Trollop::options do banner <<-EOS Usage: mdpress [filename] [options] where [options] are: EOS opt :automatic, "Keeps running and automatically updates the presentation to reflect changes to markdown file." opt :stylesheet, "Specify what stylesheet to use.", :default => "default" opt :list, "List all available stylesheets." opt :run, "Run presentation (automatically compiles to a tmp directory and opens in a browser window)" opt :latex, "Provide Latex support" opt :verbose, "Be verbose." end if OPTS[:list] list_available_stylesheets exit end Trollop::die("no file specified") if ARGV.empty? # show help screen if OPTS[:run] file = ARGV[0] tmp = Tempfile.new("mdpress") tmp.write(readfile(file)) tmp.flush FILENAME = tmp.path DIRNAME = FILENAME + "_dir" else FILENAME = ARGV[0] DIRNAME = File.basename(FILENAME, File.extname(FILENAME)) end if File.exist?(THEMES_DIRNAME + "#{OPTS[:stylesheet]}.css") STYLESHEET = THEMES_DIRNAME + "#{OPTS[:stylesheet]}.css" STYLESHEET_HEAD = THEMES_DIRNAME + "#{OPTS[:stylesheet]}.html" else STYLESHEET = base_dir + "impress_css/#{OPTS[:stylesheet]}.css" STYLESHEET_HEAD = base_dir + "impress_css/#{OPTS[:stylesheet]}.html" end unless File.exist?(STYLESHEET) puts OPTS[:stylesheet] + " is not a valid stylesheet. See available stylesheets with `mdpress -l`." exit end if File.exist?(DIRNAME) unless File.directory?(DIRNAME) puts "please delete the file: #{DIRNAME} before continuing." exit end else log "making directory" Dir.mkdir(DIRNAME) end render OPTS log "copying files" FileUtils.cp_r(base_dir + "js", DIRNAME) FileUtils.cp_r(base_dir + "css", DIRNAME) FileUtils.cp(STYLESHEET, DIRNAME + "/css/style.css") def auto while true sleep 2 if FileUtils.uptodate?(FILENAME, [DIRNAME + "/index.html"]) log "updating from #{FILENAME}" render OPTS end # Takes care of updating stylesheets for local styles. if FileUtils.uptodate?(STYLESHEET, [DIRNAME + "/css/style.css"]) log "updating stylesheet #{STYLESHEET}" FileUtils.cp(STYLESHEET, DIRNAME + "/css/style.css") end end end if OPTS[:automatic] if ARGV[0] =~ /^http/ puts "Can't run in auto mode for remote files." else log "waiting for updates..." auto end elsif OPTS[:run] log "opening in browser." Launchy.open(DIRNAME + "/index.html", :application => :browser) else log "done." end mdpress-0.0.15/README.md0000644000175000017500000001372412250154716014121 0ustar boutilboutil# mdpress This is a tool that converts markdown files to presentations using impress. # Example [This presentation](http://egonschiele.github.com/mdpress/default) was created from [this markdown file](https://raw.github.com/egonSchiele/mdpress/master/examples/demo.md). [This presentation](http://egonschiele.github.com/mdpress/impress) was created from the same markdown file and a different stylesheet using `mdpress -s [stylesheet name]`. ## Advantages - dead simple, works with any markdown file - comes with a beautiful default stylesheet + more styles (more styles TBD) ... no need to write your own - ...but you can write your own easily if you want! - comes with [prettify](http://code.google.com/p/google-code-prettify/) integrated, does code highlighting out of the box - has an auto-update mode; update your markdown file and mdpress will update your presentation automatically - quick install as a ruby gem - presentations are tiny and easy to distribute - presentations are easy to read as a plain text file ## Install gem install mdpress ## Usage mdpress [filename.md] mdpress [http://www.yourdomain.com/path/to/filename.md] This creates a directory named `filename`. Start the presentation by opening up `index.html`. ## Quickstart (writing your first presentation!) # Chicken Chicken Chicken ## By Chicken --- # Chicken - Chicken - Chicken Chicken Save that as `test.md` and then use `mdpress test.md` to convert it to a presentation. `mdpress` uses [Redcarpet](https://github.com/tanoku/redcarpet), so it can parse whatever markdown you throw at it. We use the horizonal rule, `---`, to indicate the start of a new slide. ### Getting Fancy: adding transformations So far the slide transitions haven't been that exciting. Let's spice them up. Below the `---`, type: = data-x="1000" And re-compile with `mdpress test.md` (you might have to delete your old presentation directory first). Aha! Not bad! We specify transformations with `= [list of transformations]` as the first line of whatever slide we want to apply the transformation to. We could have written = data-x="1000" data-scale="2" To make it scale as well as swipe. ## Possible Attributes - `data-x`, `data-y`, `data-z`: positioning - `data-rotate-x`, `data-rotate-y`, 'data-rotate-z`, `data-rotate`: rotation (`data-rotate` and `data-rotate-z` are exactly the same) - `data-scale`: scale - `id`: used as the slide link. For example, if you use `id=intro`, you can link to that slide using `index.html#/intro`. See [impress.js](https://github.com/bartaz/impress.js/blob/master/index.html) for a broader description of these. Adding this syntax to Markdown feels like kind of a hack, but it's concise. I'm open to suggestions for something better. ## Auto-update Earlier, our workflow involved having to delete the old presentation and recompile every time we made an edit. The better choice is to use the automatic mode: mdpress -a [filename.md] Now, `mdpress` will keep running and check for updates to your markdown file. It will automatically recompile the presentation for you, so you can seamlessly edit your markdown and view your changes instantly. ## Stylesheets `mdpress` comes with a default stylesheet, plus a few more. See the full list of available stylesheets with mdpress -l Or specify a stylesheet to use with mdpress -s [stylesheet] If you make your own stylesheets, send me a pull request and I'll add them to the list! See below. You can also create your own local theme: 1. Use the 'lib/impress_css/' files as a model to work from. 2. Create a folder called 'themes' in the directory where your markdown file is. Inside it put the [yourtheme].css and [yourtheme].html files 3. Call mdpress -s [yourtheme] and mdpress will look for the two theme files in themes/ matching that name. ## Running a presentation Someone emailed you a `mdpress` presentation. Now you want to **just run it**? Sure: mdpress -r [filename.md] That will automatically compile the presentation and open it in a browser window. ## Latex Support mdpress now has Latex support through [MathJax](http://www.mathjax.org/). To build your presentation with latex support, use the `--latex` flag. Put your latex code between a pair of `$$`'s, like this: # Latex! $$e^{\imath\pi} = -1$$ **Note**: you might run into conflicts between markdown and latex. For example, `_` means emphasize in markdown. So if you want subscripts, escape `_`: $a_x$ # wrong, x will be italic $a\_x$ # right, x will be a subscript ## Metadata Metadata can be set via YAML-Frontmatter. Have a look at the examples for further information. For example, if you want to set a title, put this at the top of the markdown file: --- title: All about chicken --- ## Contributing To contribute a new stylesheet, follow these steps: 1. Fork this repo. 2. Place your new stylesheet in `lib/impress_css/[your stylesheet name].css` 3. Send me a pull request! ## Contributors - Mte90 ## License (MIT) Copyright (C) 2012 by Aditya Bhargava Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. mdpress-0.0.15/LICENSE0000644000175000017500000000204312250154716013637 0ustar boutilboutilCopyright (c) 2012 Aditya Bhargava Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. mdpress-0.0.15/lib/0000755000175000017500000000000012250154716013401 5ustar boutilboutilmdpress-0.0.15/lib/impress_renderer.rb0000644000175000017500000000457212250154716017306 0ustar boutilboutilrequire 'redcarpet' class ImpressRenderer < Redcarpet::Render::HTML @@attrs = [] @@current = 0 @@author, @@head, @@title = nil def self.init_with_attrs _attrs, _opts @@attrs = _attrs @@current = 0 @@opts = _opts end def self.author= author @@author = "" end def self.head= head @@head = head end def self.title= title @@title = "#{title}" end def hrule # this is how we later inject attributes into pages. what an awful hack. @@current += 1 %{
} end def block_code code, lang "
#{code}
" end def codespan code "#{code}" end def mathjax if @@opts[:latex] %{ } end end def doc_header %{ #{@@title} #{@@author} #{self.mathjax} #{@@head}

Your browser doesn't support the features required by impress.js, so you are presented with a simplified version of this presentation.

For the best experience please use the latest Chrome, Safari or Firefox browser.

} end def doc_footer %{
} end end mdpress-0.0.15/lib/css/0000755000175000017500000000000012250154716014171 5ustar boutilboutilmdpress-0.0.15/lib/css/reset.css0000644000175000017500000000130012250154716016017 0ustar boutilboutilhtml, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; } code { font-size: 36px; line-height: 40px; font-family: "Courier New", monospace; } mdpress-0.0.15/lib/css/favicon.png0000644000175000017500000000246412250154716016332 0ustar boutilboutilPNG  IHDR szzsRGBIDATXõ]hUg>#ݔnۥ$ۅ1PiX -E(HXA jQ  j+ y(>4D4&!m=>8&$ 3ssUeCU, UeϞ=1Oٶ={/_cTq\;h-3 |]U1PӨU 8N?ܟLƘq$ U{&fEaͮU%HLGȻ"sA&&&Z@oo/oZ'Je.شisH$H1USSS1=L={0jy&Jদ&Ǚ\3LFx>l*'NhFX ڲeKSH:e~\ORa"2Ҳ$؞ Ŧ]}ƏnU%,:\s]7oYjxeΝ; ATJrMƶyÏ $m+Z6۶*\b1mmm`\.3>>ځϒɤ Jb`k26J%aF)yfӧ 1D" m--A$"CCC*Ǐ_TU:;;ۀl% a8D"]":00 u]R )k 6nܸ%RmᓓU\pȑ,\MjY֝e{vލF\=4dн{v |Z,iL9˲&D$A<|t4<@.3@W>Lexڷ{fB$";X?<~*XexС.^ @6ƣƘ^E|~N_CUXnbdd~vuu\m۶w}KOU0Zd2@~ƍa 8`|rDrݻw7V*s\qŚo۶fRT*166p-ퟹU… _+AFlذaWR۶5cavvUMY悕QoWj^فXi !ivUUXCcݩ, ,4H-ͩ1333eIVSƘ5+cBr +^ R(~tҰ1˪ͦ^6NIENDB`mdpress-0.0.15/lib/css/apple-touch-icon.png0000644000175000017500000000755412250154716020061 0ustar boutilboutilPNG  IHDRJJU&sRGB&IDATx[kLe߹v,KAX )6hk6hК(D16|) X6hk1mZik,"p[re3~x?; Od9<<;}:;;[ldE%EeaHnq"$Iy޽dFm#ĨXr\V DDD(=HfP@l#!M "55ECnJԐǍ{uaB, Zv!3D@BNJJb/7+@¯%dDR),EQbuhRB`GFjV1{==VX@`'w5j^6]>O0/ z?wyENb2 $0}騨PEDDJ۷ʢ8& xa%futtܾ}tVWW4ET* ^1M$ ^A&%%% (ܨܒAQA>O'&&r^W*(FDDt\UUU]]jx<|ܮ0h4啔t: fGZmeeO?mZ>|888hZ=@tHRxMVFFF~6 puvA`0ƪݾ3dPuN3~AFKJJ333SSSq'I ~uGŎPW'H.]422rCt(`{a VF&&& {jNaR1Aυ @q*H O<.U(bEQ(Ӟh;T;3cFޞ\ZZ2Lyyy8 H=xNS* X5 E+=ܜX,Vt9s hc=776<< 2[ll,Xfgb'fj fZ=z366rbfWClݻw}FGG;;;***JKK <A(me"Ir{{{vvvrrwccOIaD&O$vƾŠ d4*`q-s rfggGFF=z477'pqqqR A$CTR)piڼܜ쨨(\Î ?=d3ӹ200;==xmX׿ 镕?sbb$I`6x D2??wݺuKr'&&hJ'\~ȑ#'Nt RK/G=S A'0;;;ADdJɓ'ϟ?w?4,tH$ >,з{@ D-ollvG} ~8fC Æn޼bf2 yn4?.<`)cWUU!RZZ*9laۃ|n7?$s&)''@sbIT( =rtpzii)lIDbb+g5. Y2  B(m8A03De]aI$a%=| Iebpw:b/Da^3fkuuUe'v<=ܱz vwwxÌDm\ zKKK|4J}z]6@gZGQ&ca~|ŌkkkBTTTՁ@ >m0B$...++8%%E&1J$o_j D %.dO8͟=|[s֨XE Fԋ3eEGN_Y].!"^o2}LkdIENDB`mdpress-0.0.15/lib/impress_css/0000755000175000017500000000000012250154716015733 5ustar boutilboutilmdpress-0.0.15/lib/impress_css/deckjs.css0000644000175000017500000007673312250154716017730 0ustar boutilboutil/* the style used in impress.js's intro presentation */ /* http://meyerweb.com/eric/tools/css/reset/ v2.0 | 20110126 License: none (public domain) */ html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; } /* HTML5 display-role reset for older browsers */ article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; } body { line-height: 1; } ol{ margin: 0px 0 20px 70px; } ul { margin: 0px 0 20px 50px; } blockquote, q { border-left: 10px solid #BBB; padding-left: 10px; } blockquote p { line-height: 60px; } blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; } table { border-collapse: collapse; border-spacing: 0; } /* show "unsupported" message conditionally */ .fallback-message { font-family: sans-serif; line-height: 1.3; width: 780px; padding: 10px 10px 0; margin: 20px auto; border: 1px solid #E4C652; border-radius: 10px; background: #EEDC94; } .fallback-message p { margin-bottom: 10px; } .impress-supported .fallback-message { display: none; } /* styles start here */ body { font-family: 'Helvetica Neue', Helvetica, sans-serif; min-height: 740px; -webkit-font-smoothing: antialiased; } .step { -webkit-transition: opacity 1s; -moz-transition: opacity 1s; -ms-transition: opacity 1s; -o-transition: opacity 1s; transition: opacity 1s; } .step:not(.active) { opacity: 0.0; } .step { width: 1400px; min-height: 800px; padding: 100px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; font-size: 36px; line-height: 48px; } h1 { font-weight: 900; font-size: 80px; margin: 10px 0 20px 0; text-align: center; font-family: 'Ultra', serif; text-shadow: 3px 3px 3px rgba(0, 0, 0, 0.2); } h2 { font-weight: 900; font-size: 48px; font-family: 'Ultra', serif; text-shadow: 3px 3px 3px rgba(0, 0, 0, 0.2); margin: 10px 0 20px 0; } p { font-weight: 400; color: #555; } a { text-decoration: none; border-bottom: 1px solid #ddd; } li { margin: 3px 0; } /* code highlighting */ code { background: #F2F2F2; font-family: monospace, serif; word-wrap: break-word; font-size: 30px; line-height: 36px; } body { background-image:url() mdpress-0.0.15/lib/impress_css/impress.css0000644000175000017500000001017312250154716020131 0ustar boutilboutil/* the style used in impress.js's intro presentation */ /* http://meyerweb.com/eric/tools/css/reset/ v2.0 | 20110126 License: none (public domain) */ html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; } /* HTML5 display-role reset for older browsers */ article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; } body { line-height: 1; } ol{ margin: 20px 0 20px 70px; } ul { margin: 20px 0 20px 50px; } blockquote, q { border-left: 10px solid #BBB; padding-left: 10px; } blockquote p { line-height: 60px; } blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; } table { border-collapse: collapse; border-spacing: 0; } body { font-family: 'PT Sans', sans-serif; min-height: 740px; background: rgb(215, 215, 215); background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 500, from(rgb(240, 240, 240)), to(rgb(190, 190, 190))); background: -webkit-radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); background: -moz-radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); background: -o-radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); background: radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); -webkit-font-smoothing: antialiased; } b, strong { font-weight: bold } i, em { font-style: italic} a { color: inherit; text-decoration: none; padding: 0 7px; -moz-border-radius: 10px; border-radius: 10px; background: #C9E7EA; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; } a:hover { background: #86D6EA; text-shadow: -1px -1px 2px rgba(100,100,100,0.5); } /* enable clicking on elements 'hiding' behind body in 3D */ body { pointer-events: none; } #impress { pointer-events: auto; } /* COMMON STEP STYLES */ .step { width: 900px; padding: 40px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; font-family: 'PT Serif', georgia, serif; font-size: 48px; } /* fade out inactive slides */ .step { -webkit-transition: opacity 1s; -moz-transition: opacity 1s; -ms-transition: opacity 1s; -o-transition: opacity 1s; transition: opacity 1s; } .step:not(.active) { opacity: 0.3; } /* STEP SPECIFIC STYLES */ h1 { font-size: 120px; line-height: 120px; margin: 0 0 20px 0; width: 100%; } .step { display: block; width: 900px; height: 700px; padding: 40px 60px; border-radius: 10px; background-color: white; box-shadow: 0 2px 6px rgba(0, 0, 0, .1); border: 1px solid rgba(0, 0, 0, .3); font-family: 'Open Sans', Arial, sans-serif; color: rgb(102, 102, 102); text-shadow: 0 2px 2px rgba(0, 0, 0, .1); font-size: 30px; line-height: 36px; letter-spacing: -1px; } p { font-size: 48px; line-height: 72px; } li { font-size: 48px; line-height: 60px; } h2 { font-size: 72px; padding: 20px 0; line-height: 72px; color: #0DADD6; } code.prettyprint{ background-color: #888; } code.inline { padding: 5px 10px; margin: -5px 0 0 0; } .fallback-message { font-family: sans-serif; line-height: 1.3; width: 780px; padding: 10px 10px 0; margin: 20px auto; border: 1px solid #E4C652; border-radius: 10px; background: #EEDC94; } .fallback-message p { margin-bottom: 10px; } .impress-supported .fallback-message { display: none; }mdpress-0.0.15/lib/impress_css/deckjs.html0000644000175000017500000000013412250154716020062 0ustar boutilboutil mdpress-0.0.15/lib/impress_css/default.css0000644000175000017500000000730412250154716020075 0ustar boutilboutilhtml { overflow: hidden; } body { font-family: 'Open Sans', sans-serif; line-height: 40px; font-size: 32px; } body { min-height: 740px; background: -moz-radial-gradient(50% 50%, farthest-side, #fff, #efefef); background: -webkit-gradient(radial, 50% 50%, 250, 50% 50%, 750, from(#fff), to(#efefef)); background: -ms-radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); background: -o-radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); background: radial-gradient(rgb(240, 240, 240), rgb(190, 190, 190)); pointer-events: none; /* Fix Body Click */ } .step { width: 1060px; padding: 40px 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; -webkit-transition: opacity 1s; -moz-transition: opacity 1s; -ms-transition: opacity 1s; -o-transition: opacity 1s; transition: opacity 1s; } .impress-enabled .step { margin: 0; opacity: 0.3; -webkit-transition: opacity 1s; -moz-transition: opacity 1s; -ms-transition: opacity 1s; -o-transition: opacity 1s; transition: opacity 1s; } .step:not(.active) { opacity: 0.0; } .impress-enabled .step.active { opacity: 1 } strong { font-weight: 800; font-weight: bold } em { font-style: italic; } h1, h2 { font-weight: normal; } h1 { font-size: 120px; margin: 20px 0; line-height: 130px; } h2 { font-size: 48px; font-weight: 300; letter-spacing: .1em; text-transform: uppercase; line-height: 72px; margin: 10px 0; } .light { font-weight: 300; letter-spacing: .1em; } blockquote { text-align: justify; font-weight: 300; font-style: italic; line-height: 1.4; margin: 20px 0; padding: 10px 0; border-top: 1px solid #aaa; border-bottom: 1px solid #aaa; width: 1060px; } table { width:100%; } .present a { pointer-events: auto; /* Enable Click on link */ } code { font-size: 30px; line-height: 36px; } a { pointer-events: none; /* Fix Body Click */ color: inherit; text-decoration: none; text-shadow: -1px -1px 2px rgba(100,100,100,0.9); -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; font-weight:bold; } a:hover { color: #333; text-shadow: -1px -1px 2px rgba(100,100,100,0.5); } p { font-weight: 400; line-height: 60px; } ol { margin: 20px 0 20px 70px; } ul { margin: 20px 0 20px 50px; } li { line-height: 50px; list-style: disc; } td,th { vertical-align: top; line-height: 44px; } .fallback-message { font-family: sans-serif; line-height: 1.3; width: 780px; padding: 10px 10px 0; margin: 20px auto; border: 1px solid #E4C652; border-radius: 10px; background: #EEDC94; } .fallback-message p { margin-bottom: 10px; } .impress-supported .fallback-message { display: none; } span,strong { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; display: inline-block; } .present .positioning { -webkit-transform: translateY(-10px); -moz-transform: translateY(-10px); -ms-transform: translateY(-10px); -o-transform: translateY(-10px); transform: translateY(-10px); } .present .rotating { -webkit-transform: rotate(-10deg); -moz-transform: rotate(-10deg); -ms-transform: rotate(-10deg); -o-transform: rotate(-10deg); transform: rotate(-10deg); -webkit-transition-delay: 0.25s; -moz-transition-delay: 0.25s; -ms-transition-delay: 0.25s; -o-transition-delay: 0.25s; transition-delay: 0.25s; } .present .scaling { -webkit-transform: scale(0.7); -moz-transform: scale(0.7); -ms-transform: scale(0.7); -o-transform: scale(0.7); transform: scale(0.7); -webkit-transition-delay: 0.5s; -moz-transition-delay: 0.5s; -ms-transition-delay: 0.5s; -o-transition-delay: 0.5s; transition-delay: 0.5s; } mdpress-0.0.15/lib/impress_css/impress.html0000644000175000017500000000030612250154716020302 0ustar boutilboutil mdpress-0.0.15/lib/impress_css/obtvse.css0000644000175000017500000000536312250154716017756 0ustar boutilboutil/* the style used in impress.js's intro presentation */ /* http://meyerweb.com/eric/tools/css/reset/ v2.0 | 20110126 License: none (public domain) */ html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; } /* HTML5 display-role reset for older browsers */ article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; } body { line-height: 1; } ol{ margin: 0px 0 20px 70px; } ul { margin: 0px 0 20px 50px; } blockquote, q { border-left: 10px solid #BBB; padding-left: 10px; } blockquote p { line-height: 60px; } blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; } table { border-collapse: collapse; border-spacing: 0; } /* show "unsupported" message conditionally */ .fallback-message { font-family: sans-serif; line-height: 1.3; width: 780px; padding: 10px 10px 0; margin: 20px auto; border: 1px solid #E4C652; border-radius: 10px; background: #EEDC94; } .fallback-message p { margin-bottom: 10px; } .impress-supported .fallback-message { display: none; } /* styles start here */ body { font-family: 'Lato', sans-serif; min-height: 740px; background: white; -webkit-font-smoothing: antialiased; } .step { -webkit-transition: opacity 1s; -moz-transition: opacity 1s; -ms-transition: opacity 1s; -o-transition: opacity 1s; transition: opacity 1s; } .step:not(.active) { opacity: 0.0; } .step { width: 1400px; min-height: 800px; padding: 100px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; font-size: 36px; line-height: 48px; } h1 { font-weight: 900; font-size: 80px; margin: 10px 0 20px 0; text-align: center; } h2 { font-weight: 900; font-size: 48px; margin: 10px 0 20px 0; } p { font-weight: 400; color: #555; } a { text-decoration: none; border-bottom: 1px solid #ddd; } li { margin: 3px 0; } /* code highlighting */ code { background: #F2F2F2; font-family: monospace, serif; word-wrap: break-word; font-size: 30px; line-height: 36px; } mdpress-0.0.15/lib/impress_css/obtvse.html0000644000175000017500000000013112250154716020116 0ustar boutilboutil mdpress-0.0.15/lib/impress_css/default.html0000644000175000017500000000021712250154716020245 0ustar boutilboutil mdpress-0.0.15/metadata.yml0000644000175000017500000001004712250154716015140 0ustar boutilboutil--- !ruby/object:Gem::Specification name: mdpress version: !ruby/object:Gem::Version hash: 1 prerelease: segments: - 0 - 0 - 15 version: 0.0.15 platform: ruby authors: - Aditya Bhargava autorequire: bindir: bin cert_chain: [] date: 2012-10-29 00:00:00 Z dependencies: - !ruby/object:Gem::Dependency name: redcarpet prerelease: false requirement: &id001 !ruby/object:Gem::Requirement none: false requirements: - - ">=" - !ruby/object:Gem::Version hash: 3 segments: - 0 version: "0" type: :runtime version_requirements: *id001 - !ruby/object:Gem::Dependency name: trollop prerelease: false requirement: &id002 !ruby/object:Gem::Requirement none: false requirements: - - ">=" - !ruby/object:Gem::Version hash: 3 segments: - 0 version: "0" type: :runtime version_requirements: *id002 - !ruby/object:Gem::Dependency name: launchy prerelease: false requirement: &id003 !ruby/object:Gem::Requirement none: false requirements: - - ">=" - !ruby/object:Gem::Version hash: 3 segments: - 0 version: "0" type: :runtime version_requirements: *id003 - !ruby/object:Gem::Dependency name: httparty prerelease: false requirement: &id004 !ruby/object:Gem::Requirement none: false requirements: - - ">=" - !ruby/object:Gem::Version hash: 3 segments: - 0 version: "0" type: :runtime version_requirements: *id004 description: Build impress.js presentations from markdown files. email: bluemangroupie@gmail.com executables: - mdpress extensions: [] extra_rdoc_files: [] files: - README.md - LICENSE - lib/css/apple-touch-icon.png - lib/css/favicon.png - lib/css/highlight.css - lib/css/highlight_styles/arta.css - lib/css/highlight_styles/ascetic.css - lib/css/highlight_styles/brown_paper.css - lib/css/highlight_styles/brown_papersq.png - lib/css/highlight_styles/dark.css - lib/css/highlight_styles/default.css - lib/css/highlight_styles/far.css - lib/css/highlight_styles/github.css - lib/css/highlight_styles/googlecode.css - lib/css/highlight_styles/idea.css - lib/css/highlight_styles/ir_black.css - lib/css/highlight_styles/magula.css - lib/css/highlight_styles/monokai.css - lib/css/highlight_styles/pojoaque.css - lib/css/highlight_styles/pojoaque.jpg - lib/css/highlight_styles/rainbow.css - lib/css/highlight_styles/school_book.css - lib/css/highlight_styles/school_book.png - lib/css/highlight_styles/solarized_dark.css - lib/css/highlight_styles/solarized_light.css - lib/css/highlight_styles/sunburst.css - lib/css/highlight_styles/tomorrow-night-blue.css - lib/css/highlight_styles/tomorrow-night-bright.css - lib/css/highlight_styles/tomorrow-night-eighties.css - lib/css/highlight_styles/tomorrow-night.css - lib/css/highlight_styles/tomorrow.css - lib/css/highlight_styles/vs.css - lib/css/highlight_styles/xcode.css - lib/css/highlight_styles/zenburn.css - lib/css/reset.css - lib/impress_css/deckjs.css - lib/impress_css/deckjs.html - lib/impress_css/default.css - lib/impress_css/default.html - lib/impress_css/impress.css - lib/impress_css/impress.html - lib/impress_css/obtvse.css - lib/impress_css/obtvse.html - lib/impress_renderer.rb - lib/js/highlight.pack.js - lib/js/impress.js - bin/mdpress - examples/code.md - examples/demo.md - examples/helloworld.md homepage: https://github.com/egonSchiele/mdpress licenses: [] post_install_message: rdoc_options: [] require_paths: - lib required_ruby_version: !ruby/object:Gem::Requirement none: false requirements: - - ">=" - !ruby/object:Gem::Version hash: 3 segments: - 0 version: "0" required_rubygems_version: !ruby/object:Gem::Requirement none: false requirements: - - ">=" - !ruby/object:Gem::Version hash: 3 segments: - 0 version: "0" requirements: [] rubyforge_project: rubygems_version: 1.8.25 signing_key: specification_version: 3 summary: Build impress.js presentations from markdown files. test_files: []