🖥️ Preview
Shows HTML preview of the current note, including Mermaid diagrams and MathJax equations. Requires NP v3.9.2.
🖥️ Preview Plugin
This plugin provides the /preview note and /start live preview commands that renders the current note to HTML including:
- standard Markdown conversion (including referenced images)
- Mermaid diagrams (e.g. flowcharts, gantt charts, sequence diagrams ...)
- MathJax fragments or lines (for mathematical equations and notation)
- all open task and checklist types (according to user's Markdown settings) render as open tasks (using basic GFM rendering)
- some non-standard Markdown conversion (e.g. strikethrough, footnotes, tasklists and tables)
- it renders frontmatter slightly differently
It adds a 'Print (opens in system browser)' button to the preview window (on macOS). Clicking this opens the note in your default browser, where you can then select to print it. (There are limitations in the API that prevent me from making this a single button press, sorry.)
This example NotePlan note includes examples of these different capabilities.
Limitations
This is designed to be a temporary solution while we wait for similar functionality to get baked into the NotePlan app itself. To that end, I don't intend to be making many improvements to this. In particular I'm aware that:
- it does not render embedded images
- there are bugs in the rendering of frontmatter arising from one of the third-party libraries this uses.
Automatic updating
Use the /start live preview command to open the Preview window, and enable near-live update for this note. Under the hood this works by adding a trigger on the note so that the window will automatically refresh when you edit the note. This is the line it adds to the note's frontmatter block:
triggers: onEditorWillSave => np.Preview.updatePreview
It deliberately updates the Preview window without giving it focus, so that you can continue editing.
Mermaid charts
The markdown-ish definition of these charts is done in one or more fenced code blocks:
``` mermaid
... chart definition
lines ...
``` .
(Please ignore the closing period; it's just there to make this render in HTML.)
You might want to read these Mermaid Tutorials.
Theming Mermaid
The plugin automatically sets the Mermaid chart to use their 'default' or 'dark' theme according to the type of the current NotePlan theme. But you can override the theme for individual diagrams by including the following directive at the start of a Mermaid definition:
%%{init: {'theme':'forest'}}%%
MathJax rendering
This provides a way to include complex mathematical expressions either inline or in separate paragraphs, as this example shows:
When \\(a \ne 0\\), there are two solutions to \\(ax^2 + bx + c = 0\\), and they are:
$$x = {-b \pm \sqrt{b^2-4ac} \over 2a}.$$
Thanks
To the people who've spend the time to create and maintain Mermaid, MathJax and the showdown library.
Support
If you find an issue with this plugin, or would like to suggest new features for it, please raise a Bug or Feature 'Issue'.
If you would like to support my late-night work extending NotePlan through writing these plugins, you can through
Thanks!
Changes
Please see the CHANGELOG.