Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/obedm503/showdown-katex
Math typesetting for showdown
https://github.com/obedm503/showdown-katex
asciimath katex latex markdown math showdown
Last synced: 2 months ago
JSON representation
Math typesetting for showdown
- Host: GitHub
- URL: https://github.com/obedm503/showdown-katex
- Owner: obedm503
- License: mit
- Created: 2016-10-09T14:24:42.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-10-19T19:25:22.000Z (over 2 years ago)
- Last Synced: 2024-11-08T05:44:06.687Z (3 months ago)
- Topics: asciimath, katex, latex, markdown, math, showdown
- Language: JavaScript
- Homepage: https://obedm503.github.io/showdown-katex/
- Size: 2.19 MB
- Stars: 36
- Watchers: 4
- Forks: 11
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# showdown-katex
> `npm install showdown-katex`
[Showdown](https://github.com/showdownjs/showdown) extension to render [LaTeX](https://www.latex-project.org/) math and [AsciiMath](http://asciimath.org/) using [KaTeX](https://khan.github.io/KaTeX/);
Special characters do not need escaping
> Works well alongside [bootmark](https://obedm503.github.io/bootmark/)
## Config
You can customize what gets passed to the katex renderer by passing a config object.
These are the defaults:
```js
{
displayMode: true,
throwOnError: false, // allows katex to fail silently
errorColor: '#ff0000',
delimiters: [
{ left: "$$", right: "$$", display: false },
{ left: '~', right: '~', display: false, asciimath: true },
],
}
```Examples:
```html
const converter = new showdown.Converter({
extensions: [
showdownKatex({
// maybe you want katex to throwOnError
throwOnError: true,
// disable displayMode
displayMode: false,
// change errorColor to blue
errorColor: '#1500ff',
}),
],
});
converter.makeHtml('~x=2~');```
Check [katex for more details](https://github.com/Khan/KaTeX#user-content-rendering-options).### Default Delimiters
| Format | Left | Right | Display mode |
| --------- | ---- | ----- | ------------ |
| Latex | `$$` | `$$` | `false` |
| Asciimath | `~` | `~` | `false` |To define custom delimiters simply define a `delimiters` property in the config as an array of objects. Each object MUST have a `left` (`string`) property with the left delimiter, and a `right` (`string`) property with the right delimiter. The oject may also have a `display` (`boolean`) property if the delimiter should use display mode instead of inline mode, and an `asciimath` (`boolean`) id the delimiter is Asciimath instead of Latex.
Custom delimiters won't disable the defaults, so you can use both custom and default delimiters.
```js
const converter = new showdown.Converter({
extensions: [
showdownKatex({
delimiters: [{ left: '( ͡° ͜ʖ ͡°)', right: '( ͡° ͜ʖ ͡°)', asciimath: true }],
}),
],
});
converter.makeHtml(
'some text here, ( ͡° ͜ʖ ͡°) E=mc^2 ( ͡° ͜ʖ ͡°), you can still use ~ E=Mc^2 ~',
);
```## FOUC
If your page suffers from a "Flash Of Unstyled Content," add this to your `` tag:
```html
```
This hides the body and shows it only when the JavaScript has loaded.## Math Example
```asciimath
x = (-b +- sqrt(b^2-4ac)) / (2a)
``````asciimath
x = (-b +- sqrt(b^2-4ac)) / (2a)
``````latex
x=\frac{ -b\pm\sqrt{ b^2-4ac } } {2a}
``````latex
x=\frac{ -b\pm\sqrt{ b^2-4ac } } {2a}
```They will both render the exact same thing. If the examples don't render correctly click [here](https://obedm503.github.io/showdown-katex/).
----