Type and handwrite mathematical notation with MathType.
Easily include quality math equations in your documents and digital content.
The following example shows how to integrate MathType into an editable HTML element. The integration consists of two steps: loading a JavaScript file and initializing the plugin into the editable HTML element.
To integrate MathType, please follow the steps below. Please, note you may adjust the example parameters of the example below depending on your integration.
-
Create a new HTML file with two HTML elements, one for the editable area and another for the toolbar:
<html> <body> <div id="toolbar"></div> <div id="htmlEditor" contenteditable="true">Try me!</div> </body> </html>
-
Install the npm module:
npm install @wiris/mathtype-generic
-
Load the module into your project by adding the following code at the head of the document:
<head> <script src="node_modules/@wiris/mathtype-generic/wirisplugin-generic.js"></script> </head>
-
[OPTIONAL] Create a variable to Store MathType Configurable Properties, as for example:
let mathTypeParameters: { editorParameters: { language: 'es' }, },
For more information on the configurable properties, check the official documentation page.
-
Add one of the following code just before closing the body tag:
<script> var genericIntegrationProperties = {}; genericIntegrationProperties.target = document.getElementById("htmlEditor"); genericIntegrationProperties.toolbar = document.getElementById("toolbar"); // optionally, add MathType Properties // genericIntegrationProperties.integrationParameters = mathTypeParameters; // GenericIntegration instance. var genericIntegrationInstance = new WirisPlugin.GenericIntegration(genericIntegrationProperties); genericIntegrationInstance.init(); genericIntegrationInstance.listeners.fire("onTargetReady", {}); WirisPlugin.currentInstance = this.wiris_generic; </script>
or
<script> const htmlEditorDiv = document.getElementById("htmlEditor"); const toolbarDiv = document.getElementById("toolbar"); // Initialyze the editor. // optionally, add MathType Properties window.wrs_int_init(htmlEditorDiv, toolbarDiv /*, mathTypeParameters*/); WirisPlugin.currentInstance = genericIntegrationInstance; </script>
This is the main step of the integration. It does the following:
- Appends two buttons to the toolbar
div
, one for the math editor and another for the chemistry editor. - Initializes the integration into the editable HTML element, assigning listeners to some events of the HTML element. This allows, for instance, to open a formula just by double-clicking it. You may change target and toolbar parameters depending on the structure of your HTML editor.
- The target property must contain the editable HTML element. This is a mandatory parameter.
- The toolbar property must contain the HTML element representing the toolbar. This parameter is optional.
- Appends two buttons to the toolbar
After following these steps, you should have something like this:
<html>
<head>
<script src="node_modules/@wiris/mathtype-generic/wirisplugin-generic.js"></script>
</head>
<body>
<div id="toolbar"></div>
<div id="htmlEditor" contenteditable="true">Try me!</div>
<script>
var genericIntegrationProperties = {};
genericIntegrationProperties.target = document.getElementById("htmlEditor");
genericIntegrationProperties.toolbar = document.getElementById("toolbar");
// GenericIntegration instance.
var genericIntegrationInstance = new WirisPlugin.GenericIntegration(genericIntegrationProperties);
genericIntegrationInstance.init();
genericIntegrationInstance.listeners.fire("onTargetReady", {});
WirisPlugin.currentInstance = genericIntegrationInstance;
</script>
</body>
</html>
Notice the example assumes this directory structure:
└───index.html
└───node_modules
└───@wiris/mathtype-generic
- The editor's caret is lost when inserting a new formula on Safari with ChemType #486
By default, MathType stores equations and the formulas as MathML. However while editing, MathType converts all MathML into img
tags rendered inside the editable HTML element.
Before setting the content of the editable HTML element, you must first convert all MathML into images by using the Parser
class:
htmlData = WirisPlugin.Parser.initParse(htmlData);
For instance, the following call:
WirisPlugin.Parser.initParse("<span>hello!</span> <math><mo>x</mo></math> goodbye");
Returns the following:
<span>hello!</span>
<img
style="max-width: none; vertical-align: -4px;"
class="Wirisformula"
src="data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Awrs%3D%22http%3A%2F%2Fwww.wiris.com%2Fxml%2Fcvs-extension%22%20height%3D%2219%22%20width%3D%2213%22%20wrs%3Abaseline%3D%2215%22%3E%3C!--MathML%3A%20%3Cmath%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F1998%2FMath%2FMathML%22%3E%3Cmo%3Ex%3C%2Fmo%3E%3C%2Fmath%3E--%3E%3Cdefs%3E%3Cstyle%20type%3D%22text%2Fcss%22%2F%3E%3C%2Fdefs%3E%3Ctext%20font-family%3D%22Arial%22%20font-size%3D%2216%22%20text-anchor%3D%22middle%22%20x%3D%226.5%22%20y%3D%2215%22%3Ex%3C%2Ftext%3E%3C%2Fsvg%3E"
data-mathml="«math»«mo»x«/mo»«/math»"
alt="x"
role="math"
width="13"
height="19"
align="middle"
/>
goodbye
You can test this by adding the following JavaScript code at the end of script
in our previous example:
var htmlEditor = document.getElementById("htmlEditor");
var data = "Initial data: <math><msqrt><mo>x</mo></msqrt></math>";
htmlEditor.innerHTML = WirisPlugin.Parser.initParse(data);
After retrieving the content of the editable HTML element, you must convert all images into MathML:
htmlData = WirisPlugin.Parser.endParse(htmlData);
For instance, the following call:
WirisPlugin.Parser.endParse(
'<span>hello!</span> <img style="max-width: none; vertical-align: -4px;" class="Wirisformula" src="data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Awrs%3D%22http%3A%2F%2Fwww.wiris.com%2Fxml%2Fcvs-extension%22%20height%3D%2219%22%20width%3D%2213%22%20wrs%3Abaseline%3D%2215%22%3E%3C!--MathML%3A%20%3Cmath%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F1998%2FMath%2FMathML%22%3E%3Cmo%3Ex%3C%2Fmo%3E%3C%2Fmath%3E--%3E%3Cdefs%3E%3Cstyle%20type%3D%22text%2Fcss%22%2F%3E%3C%2Fdefs%3E%3Ctext%20font-family%3D%22Arial%22%20font-size%3D%2216%22%20text-anchor%3D%22middle%22%20x%3D%226.5%22%20y%3D%2215%22%3Ex%3C%2Ftext%3E%3C%2Fsvg%3E" data-mathml="«math»«mo»x«/mo»«/math»" alt="x" role="math" width="13" height="19" align="middle"/> goodbye',
);
Returns the following:
<span>hello!</span> <math><mo>x</mo></math> goodbye
This npm module uses remotely hosted services to render MathML data. However, we recommend you install these services on your backend. This will allow you, among other things, to configure the service and to locally store the images generated by MathType.
The services are available for Java and PHP. If you use any of these technologies, please download the plugin for your backend technology from here.
To install the Java services, please, follow the steps below:
-
Download and extract MathType for generic HTML editor - Java.
-
Deploy pluginwiris_engine.war in your Java application server (e.g., Tomcat or JBoss).
-
Set the following value for the
configurationService
property:genericIntegrationProperties.configurationService = "/pluginwiris_engine/app/configurationjs";
The previous example would end up like this:
<script> var genericIntegrationProperties = {}; genericIntegrationProperties.target = document.getElementById('htmlEditor'); genericIntegrationProperties.toolbar = document.getElementById('toolbar'); // We just added this line: genericIntegrationProperties.configurationService = '/pluginwiris_engine/app/configurationjs'; // GenericIntegration instance. var genericIntegrationInstance = new WirisPlugin.GenericIntegration(genericIntegrationProperties); genericIntegrationInstance.init(); genericIntegrationInstance.listeners.fire('onTargetReady', {}); WirisPlugin.currentInstance = genericIntegrationInstance; </script>
To install the PHP services, please, follow the steps below:
-
Download and extract MathType for generic HTML editor - PHP.
-
Copy the
generic_wiris/integration
directory into your project. -
Set the following value for the
configurationService
property:genericIntegrationProperties.configurationService = "integration/configurationjs.php";
The previous example would end up like this:
<script> var genericIntegrationProperties = {}; genericIntegrationProperties.target = document.getElementById('htmlEditor'); genericIntegrationProperties.toolbar = document.getElementById('toolbar'); // We just added this line: genericIntegrationProperties.configurationService = 'integration/configurationjs.php'; // GenericIntegration instance. var genericIntegrationInstance = new WirisPlugin.GenericIntegration(genericIntegrationProperties); genericIntegrationInstance.init(); genericIntegrationInstance.listeners.fire('onTargetReady', {}); WirisPlugin.currentInstance = genericIntegrationInstance; </script>
In order to display mathematical formulas on the target page, i.e. the page where content produced by the HTML editor will be visible, the target page needs to include the MathType script. For example for the default setting this would be:
<script src="https://www.wiris.net/demo/plugins/app/WIRISplugins.js?viewer=image"></script>
To find out more information about MathType, please go to the following documentation:
The MathType Privacy Policy covers the data processing operations for the MathType users. It is an addendum of the company’s general Privacy Policy and the general Privacy Policy still applies to MathType users.