Skip to content

Formula plugin

v0.7.2+

This plugin is only supported in rich text mode, so it needs to be used after registering the RichText plugin

This plugin is used to support inserting formulas into nodes.

注意:公式是通过KaTeX库实现的,KaTeX提供了一些配置,插件默认的一个配置是:

Note: The formula is implemented through the KaTeX library, and 'KaTeX' provides some configurations. The default configuration for the plugin is:

js
{
    output: 'mathml'
}

This formula may not render successfully on a few browsers. If you need to be compatible with these browsers, you can consider changing the configuration to 'HTML'. For detailed documentation, please refer to Options. Using this configuration may require the introduction of a 'KaTeX' style file, which you can test on your own.

v0.9.3+will internally determine whether the current Chrome kernel version of the browser is lower than 100, If so, it will automatically convert 'output' from 'mathml' to 'html', At this point, the style file for 'KaTeX' needs to be imported, but it is not imported within the library, so you need to manually import it in the project. If you introduced 'simple-mind-map' through the 'npm' method, you can introduce it as follows:

js
import 'simple-mind-map/node_modules/katex/dist/katex.min.css'

If you are using packaged files such as '.umd.js' or '.esm.js', you can import them through online CDN services, such as https://unpkg.com/browse/katex@0.16.9/dist/, Of course, it is best to upload the 'css' file of the 'katex' and the corresponding font files in the 'fonts' directory to your own server.

Version v0.10.3+ will default to importing the style files of 'KaTeX'. So you don't need to manually introduce it anymore. When the rendering mode of the Katex library is html, it depends on some font files, which are not included in the plugin. You need to use the katexFontPath instantiation option to set the path of the font files.

Problem

1.On some browsers, the formula source code is displayed

This is because some browsers do not support the 'mathml' output mode of the 'KaTex' library. You can change the output mode to 'html' by using the 'getKatexOutputType' instantiation option.

2.Sometimes formulas and text may display line breaks

This is usually because formula rendering uses the 'html' mode, which depends on the font file. Therefore, when rendering the mind map before the font file is loaded, the calculated formula content size may not match the actual formula size after loading the font file, resulting in a row change. We can find a way to make the font file load before rendering the mind map.

3.SVG files exported on one browser have inconsistent styles when opened on another browser

Because the calculation of node size depends on the proxy style of the browser, the default style of different browsers is not consistent, so the calculated node size is also inconsistent.

4.The smm or json file exported on one browser cannot be rendered properly when imported on another browser

Because some browsers may render in 'mathml' mode, while others may render in 'html' mode, those that support 'mathml' mode usually support 'html', while the opposite is not possible.

5.Abnormal formula for exporting images when rendering in html mode

This is caused by not loading the font, and there is currently no solution.

Register

js
import MindMap from 'simple-mind-map'
import Formula from 'simple-mind-map/src/plugins/Formula.js'

MindMap.usePlugin(Formula)

After registration and instantiation of MindMap, the instance can be obtained through mindMap.formula.

Usage

After registering the plugin, you can use the command 'INSERT_FORMULA' to insert the specified formula for the node:

js
mindMap.execCommand('INSERT_FORMULA', 'a^2')

The above command will insert the 'a^2' formula into the currently active node.

If you want to assign a formula to a node or nodes, you can pass the second parameter:

js
mindMap.execCommand('INSERT_FORMULA', 'a^2', [Node])

Pass in the specified node instance through the second parameter.

Methods

getKatexConfig()

Get the current configuration passed to Katex.

MIT License.