The code base of Mathjs is writting in JavaScript. The TypeScript definitions are maintained separately.
The over all structure is:
- The library exports the core function
create
which creates a MathJS instance and returnsMathJsInstance
. - Mathjs has a special function
chain
, which allows you to use the functions in a chained way, likechain(2).add(3).done()
. The functionchain
returns an interfaceMathJsChain
, which contains all mathjs functions and constants as a method. Unlike the static functions, these methods are defined with the chain instancethis
as first argument. - The library exports collections with factory functions of all functions and their dependencies. To create an instance of the function
add
, one can docreate(addDependencies)
for example. To import all functions, one can docreate(all)
. - The library also returns a static instance, which can directly be used like
import { add } from 'mathjs'
.
Maintaining the TypeScript types is done manually. When adding a function, one has to create the following TypeScript definitions:
- Add a normal definition inside
interface MathJsInstance {...}
- Add a chained definition inside
interface MathJsChain {...}
- Add a static definition inside
export const {...} : MathJsInstance
- Add a dependencies definition inside
export const {...} : Record<string, FactoryFunctionMap>
For exampe for the function add
, we can have the following definitions:
// instance
export interface MathJsInstance extends MathJsFactory {
//...
add<T extends MathType>(x: T, y: T): T
//...
}
// chain
export interface MathJsChain<TValue> {
//...
add<T extends MathType>(this: MathJsChain<T>, y: T): MathJsChain<T>
//...
}
// static
export const {
// ...
add,
// ...
} : MathJsInstance
// dependencies
export const {
// ...
addDependencies,
// ...
} : Record<string, FactoryFunctionMap>