Options
All
  • Public
  • Public/Protected
  • All
Menu

Extends MathEditorRenderable and uses KaTeX as renderer. Listen DOM mouse and keyboard events for expression manipulation. Includes default semantic validator.

Hierarchy

Index

Constructors

constructor

  • new MathEditor(element: HTMLElement, renderer: DomRenderer): MathEditor
  • Parameters

    • element: HTMLElement
    • renderer: DomRenderer

    Returns MathEditor

Properties

heuristics

heuristics: Heuristic[]

API Accessors

userInputLocked

  • get userInputLocked(): boolean
  • Returns whether user input locked or not.

    category

    API

    Returns boolean

API Methods

addOnNotify

addOnUpdate

  • addOnUpdate(cb: (updateInfo: NotifyUpdateObject[], confirmation: ConfirmRequiredOperation) => void): void
  • Add listener to listen for all the editor updates.

    Parameters

    • cb: (updateInfo: NotifyUpdateObject[], confirmation: ConfirmRequiredOperation) => void

      The listener will receive two parameters: updateInfo - what exactly were updated and confirmation - what was not yet updated, but the user was asked to confirm the operation instead

    Returns void

applyAdvice

  • applyAdvice(advice: IAdvice): this

applyHeuristics

  • applyHeuristics(): boolean
  • Applies all the previously installed heuristics.

    Returns boolean

    true if the heuristics have changed the current expression, false if not.

blur

  • blur(): void
  • Blurs the editor.

    Returns void

copy

  • copy(): string
  • Copies selected expression to the clipboard.

    Returns string

    • copied expression

cut

  • cut(): string
  • Cuts selected expression to the clipboard.

    Returns string

    • cut expression

defineEditableCell

  • defineEditableCell(editableCells: { avoidParenthesesWrap?: boolean; borderVisible?: boolean; nodeId: number }[]): MathEditorAPI
  • Makes editor readonly and creates editable cells inside.

    Parameters

    • editableCells: { avoidParenthesesWrap?: boolean; borderVisible?: boolean; nodeId: number }[]

      nodeId - node id for editable cell borderVisible - whether the border of editable cell visible or not avoidParenthesesWrap - whether the wrap editable cell with parens or not

    Returns MathEditorAPI

delete

  • Deletes node near the current cursor position or replaces the selection. This method allows programmatically emulate pressing delete/backspace button. It requires cursor or non-empty selection inside the editor. Otherwise, it does nothing.

    Parameters

    • direction: HorizontalDirection

      left for backspace button and right for delete button

    • Optional force: boolean

      whether node or ask user for confirmation

    Returns this

destroy

  • destroy(): void
  • Destroys the editor.

    Returns void

disableMouseInteraction

  • disableMouseInteraction(): void
  • Disables mouse interaction for the editor.

    Returns void

disableUndoRedo

  • disableUndoRedo(): void
  • Disables undo/redo for the editor.

    Returns void

dropSelection

  • dropSelection(placeCursorAtSelectionEnd: boolean): void
  • Drops the current selection.

    Parameters

    • placeCursorAtSelectionEnd: boolean

      whether put the cursor to the end of selection after dropping

    Returns void

enableMouseInteraction

  • enableMouseInteraction(): void
  • Enables mouse interaction for the editor.

    Returns void

enableUndoRedo

  • enableUndoRedo(): void
  • Enables undo/redo for the editor.

    Returns void

focus

  • focus(): void
  • Focuses the editor.

    Returns void

getAdvices

  • getAdvices(): IAdvice[]
  • Returns advices for the current cursor position. Advice is a suggestion to end user what can be inserted into the current cursor position. For example, if user enters 'in' then we can suggest him 'Indefinite integral'.

    Returns IAdvice[]

getCharacterSpeech

  • getCharacterSpeech(): string

getCursor

getDOMElement

  • getDOMElement(nodeId: number): Element[]
  • Returns list of {@link Element} for a given node id.

    Parameters

    • nodeId: number

    Returns Element[]

getLatex

  • getLatex(): string

getNearestNode

  • getNearestNode(point: Point): { nodeId: number; side: CursorSide }
  • Returns nearest node for a given point.

    Parameters

    • point: Point

    Returns { nodeId: number; side: CursorSide }

getSelectionTree

getSemantic

getSemanticSpeech

  • getSemanticSpeech(): string
  • Returns description of the current expression as human readable math text.

    Returns string

getSemanticText

  • getSemanticText(): string

getSymbolsAtCursor

  • getSymbolsAtCursor(includeHidden?: boolean): number[]
  • Returns symbols located near the cursor.

    gradarius

    Parameters

    • Optional includeHidden: boolean

      include hidden symbols (such as implicit multiplication) or not

    Returns number[]

getTree

  • Parameters

    • Optional settings: MathTreeSettings

      allow to post process semantic tree to omit information (eg selection, cursor, etc)

    Returns MathStructure

    current expression as semantic tree

hasSelection

  • hasSelection(): boolean

insertSymbol

  • insertSymbol(s: string): boolean
  • Inserts character to the right of the current cursor position or replaces the selection. This method allows programmatically emulate user input. It requires cursor or non-empty selection or empty expression inside the editor. Otherwise, it does nothing.

    Parameters

    • s: string

      character to insert

    Returns boolean

    true if the character was successfully inserted

insertTree

  • insertTree(tree: MathStructure, overrideContext?: boolean): boolean
  • Inserts tree to the right of the current cursor position or replaces the selection. This method allows programmatically to insert one semantic tree into another. It requires cursor or non-empty selection or empty expression inside the editor. Otherwise, it does nothing.

    Parameters

    • tree: MathStructure

      semantic tree to insert

    • Default value overrideContext: boolean = true

      if true then overrides semantic context of the insertable tree to match current one (default) if false then throws an exception on context conflicts

    Returns boolean

    true if the tree was successfully inserted

lockUserInput

  • lockUserInput(): void
  • Locks user input.

    Returns void

moveSelectionHorizontalBoundary

moveSelectionVerticalBoundary

navigate

  • Programmatically moves cursor to the given direction. It requires cursor inside the editor. Otherwise, it does nothing.

    Parameters

    Returns boolean

paste

  • paste(latex: string): boolean
  • Pastes expression from the clipboard to the right of the current cursor position or replaces the selection. It requires cursor or non-empty selection or empty expression inside the editor. Otherwise, it does nothing.

    Parameters

    • latex: string

    Returns boolean

    true if the expression was successfully pasted

placeCursor

  • placeCursor(nodeId: number, side: CursorSide): boolean
  • Places cursor at the left or at the right of the given symbol

    Parameters

    • nodeId: number

      identifier of the given symbol (can be found in model classes)

    • side: CursorSide

      where to place the cursor - at the right of the symbol or at the left

    Returns boolean

redo

removeCursor

  • removeCursor(): boolean
  • Removes cursor from the editor

    Returns boolean

    true if the cursor was actually in the editor

removeOnNotify

removeOnUpdate

  • removeOnUpdate(cb: (updateInfo: NotifyUpdateObject[], confirmation: ConfirmRequiredOperation) => void): void

requestValidation

  • requestValidation(): void
  • Validates current expression in the editor and highlights invalid nodes.

    Returns void

select

  • Programmatically increases selection in a given direction. It requires cursor or non-empty selection inside the editor.

    Parameters

    • direction: NavDirection

      direction to increase the selection

    Returns MathEditorAPI

selectByNodeIds

  • Programmatically creates selection between given nodes using the provided horizontal and vertical direction.

    gradarius

    Parameters

    • startNodeId: number

      start node id

    • endNodeId: number

      end node id

    • horizontalDirection: HorizontalDirection

      horizontal direction

    • verticalDirection: VerticalDirection

      vertical direction

    • Default value includeStartNode: boolean = true

      whether include start node to selection or not (default true)

    Returns MathEditorAPI

selectInRectangle

  • selectInRectangle(startPoint: Point, endPoint: Point): boolean
  • Selects expression in the editor inside a given rectangle.

    Parameters

    • startPoint: Point
    • endPoint: Point

    Returns boolean

setReadOnly

  • setReadOnly(): void
  • Enables readonly mode for the editor.

    Returns void

setReadWrite

  • setReadWrite(): void
  • Disables readonly mode for the editor.

    Returns void

setTree

  • Updates current expression with the given semantic tree

    Parameters

    Returns MathStructure

    updated math tree (original one can be changed by hints)

undo

unlockUserInput

  • unlockUserInput(): void
  • Unlocks user input.

    Returns void

Internal Methods

cleanDecorations

  • cleanDecorations(): void

cleanEditorWithoutNotify

  • cleanEditorWithoutNotify(): void

decorateNodes

  • decorateNodes(nodeIds: number[], decorator: (element: HTMLElement) => void, preDelete?: () => void, withRender?: boolean, omitRedraw?: boolean): () => void
  • Decorates math nodes inside the editor. For that, it creates an overlay element you can style. The decoration is dropped if the tree changed because it becomes disconnected with new tree nodes.

    Parameters

    • nodeIds: number[]

      node ids to decorate

    • decorator: (element: HTMLElement) => void

      function to decorate the overlay element

        • (element: HTMLElement): void
        • Parameters

          • element: HTMLElement

          Returns void

    • Optional preDelete: () => void

      hook that executes when the decoration is removed on math tree update

        • (): void
        • Returns void

    • Default value withRender: boolean = true

      indicates if the decoration requires rendering after creation

    • Optional omitRedraw: boolean

      indicates if the decoration requires redrawing

    Returns () => void

    handler to remove the decoration

      • (): void
      • Returns void

getCurrentState

  • getCurrentState(): string

getCurrentStateWithHistory

  • getCurrentStateWithHistory(): string

getCursorBoundingRect

  • getCursorBoundingRect(): ClientRect

getExpressionInternalRepresentation

  • getExpressionInternalRepresentation(): string

getSelectionBoundingRect

  • getSelectionBoundingRect(): ClientRect[]

navigateVertically

renderDecorationsOnly

  • renderDecorationsOnly(): void

setCurrentState

  • setCurrentState(state: string): void
  • Sets internal editor state using provided JSON.

    Parameters

    • state: string

      internal editor state

    Returns void

setCurrentStateWithHistory

  • setCurrentStateWithHistory(state: string): void

setExpressionInternalRepresentation

  • setExpressionInternalRepresentation(mathExpression: string): number[]
  • Sets internal expression representation. Returns an array of node ids, ordered left to right according to initial order in the math expression.

    Parameters

    • mathExpression: string

      internal expression representation

    Returns number[]

Legend

  • Module
  • Object literal
  • Variable
  • Function
  • Function with type parameter
  • Index signature
  • Type alias
  • Type alias with type parameter
  • Enumeration
  • Enumeration member
  • Property
  • Method
  • Interface
  • Interface with type parameter
  • Constructor
  • Property
  • Method
  • Index signature
  • Class
  • Class with type parameter
  • Constructor
  • Property
  • Method
  • Accessor
  • Index signature
  • Inherited constructor
  • Inherited property
  • Inherited method
  • Inherited accessor
  • Protected property
  • Protected method
  • Protected accessor
  • Private property
  • Private method
  • Private accessor
  • Static property
  • Static method

Generated using TypeDoc