mirror of
https://github.com/thegeeklab/hugo-geekblog.git
synced 2024-11-22 05:00:39 +00:00
feat: add KaTeX support (#211)
This commit is contained in:
parent
4707387ffa
commit
591ee8d6df
@ -23,6 +23,8 @@ toc
|
|||||||
ToC
|
ToC
|
||||||
relref
|
relref
|
||||||
href
|
href
|
||||||
|
KaTeX
|
||||||
|
katex
|
||||||
Emojify
|
Emojify
|
||||||
Netlify
|
Netlify
|
||||||
Makefile
|
Makefile
|
||||||
|
@ -266,3 +266,41 @@ investiture. Ornateness bland it ex enc, est yeti am bongo detract re. Pro ad
|
|||||||
prompts feud gait, quid exercise emeritus bis e. In pro quints consequent.
|
prompts feud gait, quid exercise emeritus bis e. In pro quints consequent.
|
||||||
{{< /tab >}}
|
{{< /tab >}}
|
||||||
{{< /tabs >}}
|
{{< /tabs >}}
|
||||||
|
|
||||||
|
## KaTeX
|
||||||
|
|
||||||
|
[KaTeX](https://katex.org/) shortcode let you render math typesetting in markdown document.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
{{< columns >}}
|
||||||
|
|
||||||
|
```latex
|
||||||
|
{{</* katex [display] [class="text-center"] */>}}
|
||||||
|
f(x) = \int_{-\infty}^\infty\hat f(\xi)\,e^{2 \pi i \xi x}\,d\xi
|
||||||
|
{{</* /katex */>}}
|
||||||
|
```
|
||||||
|
|
||||||
|
<--->
|
||||||
|
|
||||||
|
<!-- spellchecker-disable -->
|
||||||
|
<!-- prettier-ignore -->
|
||||||
|
{{< katex display >}}
|
||||||
|
f(x) = \int_{-\infty}^\infty\hat f(\xi)\,e^{2 \pi i \xi x}\,d\xi
|
||||||
|
{{< /katex >}}
|
||||||
|
|
||||||
|
<!-- spellchecker-enable -->
|
||||||
|
|
||||||
|
{{< /columns >}}
|
||||||
|
|
||||||
|
KaTeX can also be used inline, for example {{< katex >}}\pi(x){{< /katex >}} or used with the `display` parameter:
|
||||||
|
|
||||||
|
<!-- spellchecker-disable -->
|
||||||
|
<!-- prettier-ignore -->
|
||||||
|
{{< katex display >}}
|
||||||
|
f(x) = \int_{-\infty}^\infty\hat f(\xi)\,e^{2 \pi i \xi x}\,d\xi
|
||||||
|
{{< /katex >}}
|
||||||
|
|
||||||
|
<!-- spellchecker-enable -->
|
||||||
|
|
||||||
|
Text continues here.
|
||||||
|
15
layouts/shortcodes/katex.html
Normal file
15
layouts/shortcodes/katex.html
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
{{ if not (.Page.Scratch.Get "katex") }}
|
||||||
|
<!-- Include katex only first time -->
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
href="{{ index (index .Site.Data.assets "katex.css") "src" | relURL }}"
|
||||||
|
/>
|
||||||
|
<script defer src="{{ index (index .Site.Data.assets "katex.js") "src" | relURL }}"></script>
|
||||||
|
{{ .Page.Scratch.Set "katex" true }}
|
||||||
|
{{ end }}
|
||||||
|
|
||||||
|
<span class="gblog-katex">
|
||||||
|
{{ cond (in .Params "display") "\\[" "\\(" -}}
|
||||||
|
{{- trim .Inner "\n" -}}
|
||||||
|
{{- cond (in .Params "display") "\\]" "\\)" }}
|
||||||
|
</span>
|
@ -31,6 +31,7 @@
|
|||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"clipboard": "2.0.10",
|
"clipboard": "2.0.10",
|
||||||
|
"katex": "0.15.2",
|
||||||
"mermaid": "8.14.0",
|
"mermaid": "8.14.0",
|
||||||
"store2": "2.13.1"
|
"store2": "2.13.1"
|
||||||
},
|
},
|
||||||
@ -42,6 +43,7 @@
|
|||||||
"eslint": "8.9.0",
|
"eslint": "8.9.0",
|
||||||
"eslint-config-prettier": "8.4.0",
|
"eslint-config-prettier": "8.4.0",
|
||||||
"eslint-plugin-prettier": "4.0.0",
|
"eslint-plugin-prettier": "4.0.0",
|
||||||
|
"favicons": "6.2.2",
|
||||||
"favicons-webpack-plugin": "5.0.2",
|
"favicons-webpack-plugin": "5.0.2",
|
||||||
"npm-run-all": "4.1.5",
|
"npm-run-all": "4.1.5",
|
||||||
"postcss-loader": "6.2.1",
|
"postcss-loader": "6.2.1",
|
||||||
|
9
src/js/katex.js
Normal file
9
src/js/katex.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import "katex/dist/katex.css"
|
||||||
|
|
||||||
|
document.addEventListener("DOMContentLoaded", function () {
|
||||||
|
import("katex/dist/contrib/auto-render")
|
||||||
|
.then(({ default: renderMathInElement }) => {
|
||||||
|
renderMathInElement(document.body)
|
||||||
|
})
|
||||||
|
.catch((error) => console.error(error))
|
||||||
|
})
|
@ -17,7 +17,10 @@ var config = {
|
|||||||
path.resolve("src", "sass", "print.scss")
|
path.resolve("src", "sass", "print.scss")
|
||||||
],
|
],
|
||||||
main: path.resolve("src", "js", "app.js"),
|
main: path.resolve("src", "js", "app.js"),
|
||||||
mermaid: path.resolve("src", "js", "mermaid.js")
|
mermaid: path.resolve("src", "js", "mermaid.js"),
|
||||||
|
katex: [path.resolve("src", "js", "katex.js")].concat(
|
||||||
|
glob.sync(path.join(nodeModulesPath, "katex", "dist", "fonts", "*.{woff,woff2}"))
|
||||||
|
)
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
filename: "js/[name]-[contenthash:8].bundle.min.js",
|
filename: "js/[name]-[contenthash:8].bundle.min.js",
|
||||||
|
Loading…
Reference in New Issue
Block a user