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.
21 22 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 |
# File 'lib/github-markdown-preview/html_preview.rb', line 21 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.
11 12 13 |
# File 'lib/github-markdown-preview/html_preview.rb', line 11 def preview_file @preview_file end |
#source_file ⇒ Object (readonly)
Returns the value of attribute source_file.
11 12 13 |
# File 'lib/github-markdown-preview/html_preview.rb', line 11 def source_file @source_file end |
Instance Method Details
#delete ⇒ Object
Delete the preview file from disk
157 158 159 160 161 |
# File 'lib/github-markdown-preview/html_preview.rb', line 157 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)
149 150 151 152 153 |
# File 'lib/github-markdown-preview/html_preview.rb', line 149 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
110 111 112 |
# File 'lib/github-markdown-preview/html_preview.rb', line 110 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
55 56 57 58 59 60 61 62 |
# File 'lib/github-markdown-preview/html_preview.rb', line 55 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
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/github-markdown-preview/html_preview.rb', line 66 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
91 92 93 94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/github-markdown-preview/html_preview.rb', line 91 def update unless File.exists?(@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!
118 119 120 |
# File 'lib/github-markdown-preview/html_preview.rb', line 118 def watch start_watch end |
#watch! ⇒ Object
Watch source file for changes, updating preview on change
Blocking version of #watch
126 127 128 |
# File 'lib/github-markdown-preview/html_preview.rb', line 126 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
165 166 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 |
# File 'lib/github-markdown-preview/html_preview.rb', line 165 def wrap_preview(preview_html) output_file_content ="<head>\n <meta charset=\"utf-8\">\n <style type=\"text/css\">\n \#{IO.read(Resources.expand_path(File.join('css','github.css')))}\n \#{IO.read(Resources.expand_path(File.join('css','github2.css')))}\n\n html, .markdown-body {\n overflow: inherit;\n }\n .markdown-body h1 {\n margin-top: 0;\n }\n .readme-content {\n width: \#{@preview_width}px;\n }\n\n /* hack in an anchor icon */\n .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 {\n padding: 8px 13px;\n margin: 0px 0px 12px -27px;\n background: url('')\n no-repeat\n left center;\n }\n .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 {\n display: none;\n }\n </style>\n</head>\n<body class=\"markdown-body\" style=\"padding:10px 40px;\">\n <div class=\"readme-content\">\n \#{preview_html}\n </div>\n</body>\n" output_file_content end |