Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/concludio/react-mathlive
A react wrapper-component for mathlive.js
https://github.com/concludio/react-mathlive
latex math mathlive react react-component react-wrapper
Last synced: 4 months ago
JSON representation
A react wrapper-component for mathlive.js
- Host: GitHub
- URL: https://github.com/concludio/react-mathlive
- Owner: concludio
- License: mit
- Created: 2019-02-01T16:09:59.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-05T16:18:53.000Z (about 2 years ago)
- Last Synced: 2024-10-05T17:21:38.028Z (4 months ago)
- Topics: latex, math, mathlive, react, react-component, react-wrapper
- Language: TypeScript
- Size: 2.12 MB
- Stars: 24
- Watchers: 5
- Forks: 16
- Open Issues: 40
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# react-mathlive
[![Build Status](https://semaphoreci.com/api/v1/concludio/react-mathlive/branches/master/shields_badge.svg)](https://semaphoreci.com/concludio/react-mathlive)
[![Coverage Status](https://coveralls.io/repos/github/concludio/react-mathlive/badge.svg?branch=master)](https://coveralls.io/github/concludio/react-mathlive?branch=master)A react component using [mathlive.js](https://mathlive.io)'s mathfield (interactive math editor).
## How to install
You can install *react-mathlive* like any other Javascript or Typescript library via npm:
```
npm i react-mathlive
```For Typescript users: As *react-mathlive* is written in Typescript, it comes with its own typings.
## How to use
This text assumes you know [how to build simple react components](https://reactjs.org/tutorial/tutorial.html).
You can use the `MathfieldComponent` in your web application as follows:
```JS
import { MathfieldComponent } from "react-mathlive";
```You can then either use it as a controlled or uncontrolled component.
### Uncontrolled component
In this mode the mathfield is initialized with the `initialLatex`. Whenever the user performs changes the `onChange`-handler is called.
This example is part of an assumed react component class.
```JSX
render() {
return ;
}onMathChange(mathText) {
console.log(mathText);
}
```In an uncontrolled `MathfieldComponent` the only way to programmatically change the mathfields contents are by accessing the `mathfield` directly and calling the modifying methods in there (see [Interacting with the native library](#Interacting-with-the-native-library)).
### Controlled component
In this mode the mathfield gets its contents updated whenever the `latex`-property changes.
This example makes use of reacts functional components.
```JSX
export function MyComponent() {
const [latex, setLatex] = React.useState("f(x)=\\log _10 x");
return ;
}
```There is also an [example Typescript react application](/examples/example1/) using this library.
### Interacting with the native library
The `MathfieldComponent` also allows retrieving the native [`Mathfield` object](https://cortexjs.io/docs/mathlive/#(%22mathfield%22%3Amodule).(Mathfield%3Ainterface)) from the Mathlive library via the `mathfieldRef` parameter:
```JavaScript
render() {
return (this.internalMathfield = mf)}
/>;
}
```The object stored in `internalMathfield` can be used to read and modify the underlying mathfield directly.
Via the optional `mathfieldConfig` parameter it is possible to provide the native `Mathfield` with a [`MathfieldConfig`](https://cortexjs.io/docs/mathlive/#(%22config%22%3Amodule).(MathfieldConfig%3Atype)) on its creation:
```JSX
render() {
return ;
}
```## Contribute
This is an open source library and issues and pull requests are very welcome.
See [Contributing](CONTRIBUTING.md).