12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- """
- Latex Plugin For Pelican
- ========================
- This plugin allows you to write mathematical equations in your articles using Latex.
- It uses the MathJax Latex JavaScript library to render latex that is embedded in
- between `$..$` for inline math and `$$..$$` for displayed math. It also allows for
- writing equations in by using `\begin{equation}`...`\end{equation}`.
- """
- from pelican import signals
- latexScript = """
- <script src="http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML" type= "text/javascript">
- MathJax.Hub.Config({
- config: ["MMLorHTML.js"],
- jax: ["input/TeX","input/MathML","output/HTML-CSS","output/NativeMML"],
- TeX: { extensions: ["AMSmath.js","AMSsymbols.js","noErrors.js","noUndefined.js"], equationNumbers: { autoNumber: "AMS" } },
- extensions: ["tex2jax.js","mml2jax.js","MathMenu.js","MathZoom.js"],
- tex2jax: {
- inlineMath: [ [\'$\',\'$\'] ],
- displayMath: [ [\'$$\',\'$$\'] ],
- processEscapes: true },
- "HTML-CSS": {
- styles: { ".MathJax .mo, .MathJax .mi": {color: "black ! important"}}
- }
- });
- </script>
- """
- def addLatex(gen, metadata):
- """
- The registered handler for the latex plugin. It will add
- the latex script to the article metadata
- """
- if 'LATEX' in gen.settings.keys() and gen.settings['LATEX'] == 'article':
- if 'latex' in metadata.keys():
- metadata['latex'] = latexScript
- else:
- metadata['latex'] = latexScript
- def register():
- """
- Plugin registration
- """
- signals.article_generate_context.connect(addLatex)
- signals.pages_generate_context.connect(addLatex)
|