Class: GithubMarkdownPreview::HtmlPreview
- Inherits:
-
Object
- Object
- GithubMarkdownPreview::HtmlPreview
- Defined in:
- lib/github-markdown-preview/html_preview.rb
Overview
Creates an high-fidelity html preview of the given markdown file
For a given file /path/to/file.md, generates /path/to/file.md.html
Instance Attribute Summary collapse
-
#preview_file ⇒ Object
readonly
Returns the value of attribute preview_file.
-
#source_file ⇒ Object
readonly
Returns the value of attribute source_file.
Instance Method Summary collapse
-
#delete ⇒ Object
Delete the preview file from disk.
-
#end_watch ⇒ Object
Stop watching source file (only applies to previews using the non-blocking #watch).
-
#initialize(source_file, options = {}) ⇒ HtmlPreview
constructor
A new instance of HtmlPreview.
-
#on_update(&update_callback) ⇒ Object
Register a callback to be fired when the preview is updated.
-
#pipeline_context(options) ⇒ Object
Compute the context to pass to html-pipeline based on the given options.
-
#pipeline_filters(options) ⇒ Object
Compute the filters to use in the html-pipeline based on the given options.
-
#update ⇒ Object
Update the preview file.
-
#watch ⇒ Object
Watch source file for changes, updating preview on change.
-
#watch! ⇒ Object
Watch source file for changes, updating preview on change.
-
#wrap_preview(preview_html) ⇒ Object
Wrap the given html in a full page of github-ish html for rendering and styling.
Constructor Details
#initialize(source_file, options = {}) ⇒ HtmlPreview
Returns a new instance of HtmlPreview.
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/github-markdown-preview/html_preview.rb', line 23 def initialize(source_file, = {}) unless File.exist?(source_file) raise FileNotFoundError.new("Cannot find source file: #{source_file}") end @source_file = Pathname.new(source_file).realpath.to_s = { :delete_on_exit => false, :comment_mode => false, :preview_file => @source_file + '.html' }.merge() @preview_file = [:preview_file] @preview_width = [:comment_mode] ? 712 : 722 @update_callbacks = [] @pipeline_context = pipeline_context() @preview_pipeline = HTML::Pipeline.new pipeline_filters() # generate initial preview update at_exit do if [:delete_on_exit] delete end end end |
Instance Attribute Details
#preview_file ⇒ Object (readonly)
Returns the value of attribute preview_file.
13 14 15 |
# File 'lib/github-markdown-preview/html_preview.rb', line 13 def preview_file @preview_file end |
#source_file ⇒ Object (readonly)
Returns the value of attribute source_file.
13 14 15 |
# File 'lib/github-markdown-preview/html_preview.rb', line 13 def source_file @source_file end |
Instance Method Details
#delete ⇒ Object
Delete the preview file from disk
159 160 161 162 163 |
# File 'lib/github-markdown-preview/html_preview.rb', line 159 def delete if File.exist?(@preview_file) File.delete(@preview_file) end end |
#end_watch ⇒ Object
Stop watching source file (only applies to previews using the non-blocking #watch)
151 152 153 154 155 |
# File 'lib/github-markdown-preview/html_preview.rb', line 151 def end_watch if @listener @listener.stop end end |
#on_update(&update_callback) ⇒ Object
Register a callback to be fired when the preview is updated
Multiple calls to this will register multiple callbacks
112 113 114 |
# File 'lib/github-markdown-preview/html_preview.rb', line 112 def on_update(&update_callback) @update_callbacks << update_callback end |
#pipeline_context(options) ⇒ Object
Compute the context to pass to html-pipeline based on the given options
57 58 59 60 61 62 63 64 |
# File 'lib/github-markdown-preview/html_preview.rb', line 57 def pipeline_context() { :asset_root => "https://a248.e.akamai.net/assets.github.com/images/icons/", :base_url => "https://github.com/", :gfm => [:comment_mode], :disabled_tasks => ![:comment_mode] } end |
#pipeline_filters(options) ⇒ Object
Compute the filters to use in the html-pipeline based on the given options
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 |
# File 'lib/github-markdown-preview/html_preview.rb', line 68 def pipeline_filters() filters = [ HTML::Pipeline::MarkdownFilter, HTML::Pipeline::SanitizationFilter, HTML::Pipeline::ImageMaxWidthFilter, HTML::Pipeline::HttpsFilter, HTML::Pipeline::EmojiFilter, GithubMarkdownPreview::Pipeline::TaskListFilter ] if HtmlPreview::SYNTAX_HIGHLIGHTS filters << HTML::Pipeline::SyntaxHighlightFilter end if [:comment_mode] filters << HTML::Pipeline::MentionFilter else filters << HTML::Pipeline::TableOfContentsFilter end filters end |
#update ⇒ Object
Update the preview file
93 94 95 96 97 98 99 100 101 102 103 104 105 106 |
# File 'lib/github-markdown-preview/html_preview.rb', line 93 def update unless File.exist?(@source_file) raise FileNotFoundError.new("Source file deleted") end markdown_render = @preview_pipeline.call(IO.read(@source_file), @pipeline_context, {})[:output].to_s preview_html = wrap_preview(markdown_render) File.open(@preview_file, 'w') do |f| f.write(preview_html) end @update_callbacks.each { |callback| callback.call } end |
#watch ⇒ Object
Watch source file for changes, updating preview on change
Non-blocking version of #watch!
120 121 122 |
# File 'lib/github-markdown-preview/html_preview.rb', line 120 def watch start_watch end |
#watch! ⇒ Object
Watch source file for changes, updating preview on change
Blocking version of #watch
128 129 130 |
# File 'lib/github-markdown-preview/html_preview.rb', line 128 def watch! start_watch true end |
#wrap_preview(preview_html) ⇒ Object
Wrap the given html in a full page of github-ish html for rendering and styling
167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 |
# File 'lib/github-markdown-preview/html_preview.rb', line 167 def wrap_preview(preview_html) output_file_content =<<CONTENT <head> <meta charset="utf-8"> <style type="text/css"> #{IO.read(Resources.(File.join('css','github.css')))} #{IO.read(Resources.(File.join('css','github2.css')))} html, .markdown-body { overflow: inherit; } .markdown-body h1 { margin-top: 0; } .readme-content { width: #{@preview_width}px; } /* hack in an anchor icon */ .markdown-body h1:hover a.anchor, .markdown-body h2:hover a.anchor, .markdown-body h3:hover a.anchor, .markdown-body h4:hover a.anchor, .markdown-body h5:hover a.anchor, .markdown-body h6:hover a.anchor { padding: 8px 13px; margin: 0px 0px 12px -27px; background: url('') no-repeat left center; } .markdown-body h1:hover a.anchor .octicon-link, .markdown-body h2:hover a.anchor .octicon-link, .markdown-body h3:hover a.anchor .octicon-link, .markdown-body h4:hover a.anchor .octicon-link, .markdown-body h5:hover a.anchor .octicon-link, .markdown-body h6:hover a.anchor .octicon-link { display: none; } </style> </head> <body class="markdown-body" style="padding:10px 40px;"> <div class="readme-content"> #{preview_html} </div> </body> CONTENT output_file_content end |