Skip to content

Commit

Permalink
FEATURE: Add KaTeX rendering support (#15)
Browse files Browse the repository at this point in the history
* FEATURE: Add KaTeX in-browser rendering support.

* Remove ttf fonts from KaTeX

* Update KaTeX to v0.10.1, fix paths to fonts.

Font loading was fixed by rebuilding KaTeX
and specifiying absolute paths to fonts in CSS:
Steps to build KaTeX:

1. `git clone https://github.com/KaTeX/KaTeX.git && cd KaTeX`
    `git submodule update --init --recursive`

2. Change paths to fonts:
    `sed -ri 's/@font-folder.+$/@font-folder:
"\/plugins\/discourse-math\/katex\/fonts";/'
submodules/katex-fonts/fonts.less`

3. Disable TTF fonts:
   `export USE_TTF=false`
    Alternatively, we could modify `.browserslistrc` to match what
Discourse supports

3. Build KaTeX
   `yarn && yarn builld`

4. Copy `katex.min.js` and `katex.min.css` from `dist/` to
`discourse-math/public/katex/`

5. Update fonts, copy woff and woff2 files from
`submodules/katex-fonts/fonts`

* Minor copy edit to settings

Mark MathKJax only settings

* Add Mhchem extension for KaTeX.

It is already automatically loaded for MathJaX.
  • Loading branch information
danielhollas authored and SamSaffron committed Mar 4, 2019
1 parent 41341b5 commit dce1a1b
Show file tree
Hide file tree
Showing 48 changed files with 77 additions and 6 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
## Discourse Math plugin

Adds MathJax support to your Discourse instance.
Adds LaTeX support to your Discourse instance.

https://meta.discourse.org/t/discourse-math-plugin/65770
60 changes: 60 additions & 0 deletions assets/javascripts/initializers/discourse-math-katex.js.es6
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
import { withPluginApi } from "discourse/lib/plugin-api";
import loadScript from "discourse/lib/load-script";

function ensureKaTeX() {
return loadScript("/plugins/discourse-math/katex/katex.min.js").then(() => {
return loadScript("/plugins/discourse-math/katex/katex.min.css", { css: true }).then(() => {
return loadScript("/plugins/discourse-math/katex/mhchem.min.js")
})
})
}

function decorate(elem, isPreview) {
const $elem = $(elem);
const displayMode = elem.tagName === 'DIV';

if ($elem.data("applied-katex")) {
return;
}
$elem.data("applied-katex", true);

if ($elem.hasClass("math")) {
const text = $elem.text();
$elem.text('');
window.katex.render(text, elem, { displayMode });
}
}

function katex($elem) {
if (!$elem || !$elem.find) {
return;
}

const mathElems = $elem.find(".math");

if (mathElems.length > 0) {
const isPreview = $elem.hasClass("d-editor-preview");

ensureKaTeX().then(() => {
mathElems.each((idx, elem) => decorate(elem, isPreview));
});
}
}

function initializeMath(api) {
api.decorateCooked(function(elem) {
katex(elem);
});
}

export default {
name: "apply-math-katex",
initialize(container) {
const siteSettings = container.lookup("site-settings:main");
if (siteSettings.discourse_math_enabled && siteSettings.discourse_math_provider === 'katex') {
withPluginApi("0.5", function(api) {
initializeMath(api);
});
}
}
};
Original file line number Diff line number Diff line change
Expand Up @@ -108,15 +108,15 @@ function initializeMath(api, discourse_math_opts) {
}

export default {
name: "apply-math",
name: "apply-math-mathjax",
initialize(container) {
const siteSettings = container.lookup("site-settings:main");
let discourse_math_opts = {
zoom_on_hover: siteSettings.discourse_math_zoom_on_hover,
enable_accessibility: siteSettings.discourse_math_enable_accessibility,
enable_asciimath: siteSettings.discourse_math_enable_asciimath
};
if (siteSettings.discourse_math_enabled) {
if (siteSettings.discourse_math_enabled && siteSettings.discourse_math_provider == 'mathjax') {
withPluginApi("0.5", function(api) {
initializeMath(api, discourse_math_opts);
});
Expand Down
7 changes: 4 additions & 3 deletions config/locales/server.en.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
en:
site_settings:
discourse_math_enabled: 'Enable Discourse Math plugin (will add special processing to $ and $$ blocks)'
discourse_math_zoom_on_hover: 'Zoom 200% on hover'
discourse_math_enable_accessibility: 'Enable accessibility features'
discourse_math_enable_asciimath: 'Enable asciimath (will add special processing to % delimited input)'
discourse_math_provider: 'Default math rendering provider'
discourse_math_zoom_on_hover: 'Zoom 200% on hover (MathJax only)'
discourse_math_enable_accessibility: 'Enable accessibility features (MathJax only)'
discourse_math_enable_asciimath: 'Enable asciimath (will add special processing to % delimited input) (MathJax only)'
7 changes: 7 additions & 0 deletions config/settings.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,13 @@ plugins:
discourse_math_enabled:
default: false
client: true
discourse_math_provider:
default: 'mathjax'
client: true
type: enum
choices:
- mathjax
- katex
discourse_math_zoom_on_hover:
default: false
client: true
Expand Down
Binary file added public/katex/fonts/KaTeX_AMS-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_AMS-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Caligraphic-Bold.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Caligraphic-Bold.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Caligraphic-Regular.woff
Binary file not shown.
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Fraktur-Bold.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Fraktur-Bold.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Fraktur-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Fraktur-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-Bold.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-Bold.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-BoldItalic.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-BoldItalic.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-Italic.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-Italic.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Main-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Math-BoldItalic.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Math-BoldItalic.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Math-Italic.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Math-Italic.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_SansSerif-Bold.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_SansSerif-Bold.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_SansSerif-Italic.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_SansSerif-Italic.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_SansSerif-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_SansSerif-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Script-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Script-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size1-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size1-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size2-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size2-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size3-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size3-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size4-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Size4-Regular.woff2
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Typewriter-Regular.woff
Binary file not shown.
Binary file added public/katex/fonts/KaTeX_Typewriter-Regular.woff2
Binary file not shown.
1 change: 1 addition & 0 deletions public/katex/katex.min.css

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions public/katex/katex.min.js

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions public/katex/mhchem.min.js

Large diffs are not rendered by default.

0 comments on commit dce1a1b

Please sign in to comment.