Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Snyk] Upgrade mathlive from 0.69.10 to 0.101.0 #120

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

a-gt
Copy link
Owner

@a-gt a-gt commented Oct 31, 2024

snyk-top-banner

Snyk has created this PR to upgrade mathlive from 0.69.10 to 0.101.0.

ℹ️ Keep your dependencies up-to-date. This makes it easier to fix existing vulnerabilities and to more quickly identify and fix newly disclosed vulnerabilities when they affect your project.


  • The recommended version is 90 versions ahead of your current version.

  • The recommended version was released on 3 months ago.

Release notes
Package name: mathlive
  • 0.101.0 - 2024-07-17
  • 0.100.0 - 2024-06-12

    0.100.0 2024-06-12

    Bug Fixes

    • #2396 Pressing the arrow keys in the virtual keyboard would not move the
      selection in the mathfield and display a runtime error in the console.

    • #2395 Added a dispatchEvent command which can be attached to a
      custom keycap.

    • #2392 Pressing the backspace key after typing several digits would
      delete all the digits.

      Its first argument is the name of the dispatched event, and the second
      argument is an object with the detail property, which is the data
      associated with the event.

        { 
          label: "✨",
          command: "displatchEvent('customEvent', {detail: 'some data'})"
        }

      To handle the event, add an event listener to the mathfield element:

      mf.addEventListener('customEvent', (ev) => {
        console.log(ev.detail);
      });

    0.99.0 2024-06-10

    Breaking Changes

    • The mf.offsetFromPoint() method has been renamed mf.getOffsetFromPoint()

    • The mf.scriptDepth() and mf.hitboxFromOffset() methodds have been
      replaced with mf.getElementInfo().

      The getElementInfo() method provides more information including any id
      that may have been applied with \htmlId{}.

      It is useful from within a click handler to get more information about the
      element that was clicked, e.g.

        mf.getElementInfo(mf.getOffsetFromPoint(ev.clientX, ev.clientY))

      The info returned is an object with the following properties:

      export type ElementInfo = {
      /* The depth in the expression tree. 0 for top-level elements */
      depth?: number;

      /** The bounding box of the element */
      bounds?: DOMRect;

      /** id associated with this element or its ancestor, set with \htmlId or
      \cssId
      */
      id?: string;

      /** HTML attributes associated with element or its ancestores, set with
      * \htmlData
      */
      data?: Record<string, string | undefined>;

      /** The mode (math, text or LaTeX) */
      mode?: ParseMode;

      /** A LaTeX representation of the element */
      latex?: string;

      /** The style (color, weight, variant, etc...) of this element. */
      style?: Style;
      };

    Bold

    The way bold is handled in LaTeX is particularly confusing, reflecting
    limitations of the text rendering technology of the time.

    Various attempts have been made over the years to improve the rendering of
    bold, but this has resulted in inconsistent behavior. Furthermore, various
    implementations of LaTeX and LaTeX-like systems have implemented bold in
    different ways.

    This release introduces a more consistent and intuitive handling of bold,
    although it may result in different rendering of some formulas compared to
    some implementations of LaTeX.

    The original bold command in LaTeX is \mathbf. This command renders its
    argument using a bold variant of the current font. However, only letters and
    numbers can be rendered by this command. It does not affect symbols, operators,
    or greek characters.

    For example, \mathbf{a+b} will render as 𝐚+𝐛, with the a and b in bold,
    but the + in normal weight. Characters rendered by \mathbf are rendered
    upright, even if they would have been rendered as italic otherwise.

    The \boldsymbol command is an alternative to \mathbf that affects more
    characters, including Greek letters and symbols. It does not affect
    the style of the characters, so they remain italic if they were italic before.
    However, the inter-character spacing and italic correction may not be rendered correctly.

    The \bm command from the bm package is a more modern alternative that
    affects even more characters. It also preserves the style of the characters,
    so they remain italic if they were italic before. The inter-character spacing
    and italic correction are handled correctly.

    The \bm command is recommended over \boldsymbol and \mathbf. However,
    it is not part of the standard LaTeX distribution, so it may not always be available.

    When serializing to LaTeX, MathLive will now use \mathbf when possible, and
    fall back to \bm when not. This should result in more consistent rendering
    of bold text.

    When parsing, MathLive will interpret both \mathbf, \boldsymbol and \bm as
    bold.

    The bold style is now consistently inherited by sub-expressions.

    Similarly, when applying a bold style using mf.applyStyle({weight: "bold"}),
    the bold attribute is applied to the entire selection, not just the letters
    and numbers.

    Mode Switching

    • #2375 The switch-mode command has two optionals arguments, a prefix
      and suffix. The prefix is inserted before the mode switch, and the suffix
      after. The command was behaving incorrectly. It now behaves as expected.
    • It is now possible to roundtrip between math and text mode. For example,
      selecting a fraction \frac{a}{b} and pressing alt+shift+T will convert the
      selection to (a)/(b). Pressing alt+shift+T again will convert it back to
      \frac{a}{b}.
    • When in LaTeX mode, changing the selection would sometimes unexpectedly exit
      LaTeX mode, for example after the Select All command. This has been fixed.

    New Features

    • \href

      The \href{url}{content} command, a MathJax extension that allows a link
      to be associated with some content, is now supported.

      Clicking on the content will open the link. By default, the link is opened
      in a new window, and only links with a HTTP, HTTPS or FILE protocol are
      allowed. This can be controlled by the new MathfieldElement.openUrl
      property. This property is a function with a single argument, the URL to
      be opened, that is called when the content of the \href command is clicked on.

    • Tooltip appearance

      Added CSS variables to control the appearance of the toolip displayed with
      \mathtip and \texttip:

      • --tooltip-border
      • --tooltip-color
      • --tooltip-background-color
      • --tooltip-box-shadow
      • --tooltip-border-radius.
    • The maxMatrixCols property has been added that specifies the maximum number
      of columns that a matrix may have. The default value is 10, which follows the
      default value from the amsmath package. The property applies to all of
      the matrix environments (matrix, pmatrix, bmatrix, etc.). This property is
      also accessible via the max-matrix-cols attribute.

    • The virtual keyboard now supports variants for shifted-keys. This includes
      support for Swedish specific characters such as å, ä, and ö and their
      uppercase variants.

    • Accept "true" and "false" as values for on/off attributes in the
      <math-field> element, for example <math-field smart-fence="true">.

    • Added a target property (a MathfieldElement) to the onMenuSelect
      arguments.

    • #2337 Added an option MathfieldElement.restoreFocusWhenDocumentFocused
      to control whether a mathfield that was previously focused regains focus
      when the tab or window regains focus. This is true by default and matches
      the previous behavior, and the behavior of the <textarea> element.

    • An alternate syntax for selectors with arguments. Selectors are used for
      example to associate actions with a keycap, such as switchKeyboardLayer.
      The previous syntax was command: ["switchKeyboardLayer", "alt-layer"],
      the new syntax is command: 'switchKeyboardLayer("alt-layer")'. This is more
      concise and easier to read.

    Issues Resolved

    • #2387 When using a macro, the spacing around the macro was incorrect in
      some cases.
    • #2370 The order of the keydown and input event is now consistent
      with the <textarea> element.
    • #2369 After typing a shortcut, using the backspace key could result
      in unexpected behavior. Now, pressing the backspace key after a shortcut
      has been typed will undo the conversion of the shortcut.
    • #2380 In some cases, when using the menu, some spurious focus/blur events
      would be dispatched.
    • #2384 When using repeating decimals after a comma (i.e. 123{,}4(1)),
      do not use a \left...\right command in order to get the proper spacing.
    • #2349 The positioning of subscripts for extensible symbols, such as \int
      was incorrect.
    • #2326 The Cut and Copy commands in the context menu are now working
      correctly in Safari.
    • #2309 When using styled text (e.g. \textit{}), the content could
      sometimes be serialized with an unnecessary \text{} command, i.e.
      \text{\textit{...}}.
    • #2376 When smart-fence was off, the { and } keys would not insert
      braces.
    • #2273 Using one of the Chinese locales would result in a runtime error.
    • #2355 When pressing the down arrow key in \sqrt[#?]{1} from the #?
      position, a runtime exception would occur.
    • #2298 When using screen readers, pressing the spacebar would not always
      correctly focus the mathfield.
    • #2297 In some cases, when using touch input, the previously selected item
      in a context menu would appear to be selected.
    • #2289 When changing the value of the mathfield, the selection is now
      preserved. In addition, when using a controlled component with React an
      unnecessary update is avoided.
    • #2282 Don't display selection when the mathfield is not focused
    • #2280 Handle better very deeply nested expressions
    • #2261 When a style was applied to an empty range, the style was ignored.
    • #2208 When setting a variant style (i.e. blackboard, fraktur, etc...) the
      style is no longer adopted by subsequent characters.
    • #2104, #2260 When replacing the selection by typing, the new content would not
      always be correctly styled. The content now inherits the style of the
      selection, or the style of the insertion point if the selection is collapsed.
    • Better handle the case where the mathlive library gets loaded before the DOM
      is constructed.
    • On Safari, the Insert Matrix submenu was displayed incorrectly.
    • When the mathfield is an iframe, the before-virtual-keyboard-toggle and
      virtual-keyboard-toggle events are now dispatched on the
      window.mathVirtualKeyboard object of the iframe. This can be used to detect
      a request (and prevent) for the virtual keyboard to be displayed.
    • If the unknown in an expression was a complex identifier, such as \mathcal{C}
      it would not be displayed correctly in the "Solve for" menu.
    • The \mathrlap command was incorrectly rendering like \mathllap.

    0.98.6 2024-01-27

    New Features

    • Added StaticRenderOptions.TeX.className to specify that an element with the
      specified class name should be rendered as a LaTeX formula.
    • #2273 Added a --keycap-width CSS variable to specify the width of a
      keycap in a virtual-keyboard. By default, if the CSS variable is not
      specified, the width of the keycap is calculated based on the width of the
      parent container. However, this requires browser that support the cq CSS
      unit. If the browser does not support the cq CSS unit, this CSS variable can
      be used to specify the width of the keycap. (See #2028, #2133)
    • #2255 Support for gather* environment
    • #2242 A virtual keyboard keycap can now include a tooltip for its shifted
      variant.

    Issues Resolved

    • When using some APIs such as renderToMarkup() or renderToMathML() in a
      server-side environment, a runtime error would occur.
    • When tabbing in a mathfield with multiple prompts, tab out of the mathfield
      when the last or first prompt is reached.
    • **#2243##, **#2245** Unicode characters such as ² or are now
      interpreted as their LaTeX equivalent only when in math mode.
    • #2237 The command \iff now renders correctly
    • #2246 Changing the mf.value property would not always update the value
      of the mathfield.
    • #2244 Worked around an issue in Safari on iOS where doing a double-tap on
      the virtual keyboard would result in the mathfield losing focus and the
      virtualy keyboard closing.
    • #2252 At some viewport sizes, the integral sign in the symbols virtual
      keyboard would be clipped.
    • #2235 Improved serialization to ASCIIMath.
    • Avoid conflicts with some class names when rendering static math.
    • When using renderMathToElement() or renderMathInDocument(), coalesce
      adjacent text nodes.
    • Correctly parse the \cfrac optional alignment argument
    • The commands \bf, \bfseries, \mdseries, \upshape, \itshape,
      \slshape, \scshape, \rmfamily, \sffamily, \ttfamily are now
      interpreted correctly.
    • The command \operatorname is now spoken correctly
    • #2152 On Safari, fill-in-the-blank prompts containing a fraction were
      rendered incorrectly.

    0.98.5 2023-12-27

    Issues Resolved

    • When a font size command is inside a \left...\right command, apply the font
      size to the content of the command. As a result
      \frac34 + \left( \scriptstyle \frac12 \right) will now render as expected.

    • #2214 When using Linux or Windows with a German keyboard layout, typing
      the ^ key will now switch to superscript.

    • #2214 When typing Unicode characters such as ² or , correctly
      interpret them as their LaTeX equivalent. This also affects parsing of the
      value property.

    • #2000, #2063 A mathfield with multiple lines now generate correct
      LaTeX using the \displaylines command.

    • When a superscript or subscript is attached to a function, correctly position
      a following \left...\right command closer to the function.

    • When typing a superscript after f, g or some other function, correctly
      interpret the superscript as an exponent, not as a function argument.

    • #787, #1869 The f, g and h symbols are no longer hardcoded as
      symbols representing functions.

      Whether a symbol is considered a function affects the layout of a formula,
      specifically the amount of space between the symbol and a subsequent delimiter
      such as a parenthesis.

      Now whether a symbol should be treated as a function is determined by the
      MathfieldElement.isFunction hook.

      By the default, this hook uses the MathfieldElement.computeEngine to
      determine if the domain of a symbol is a function.

      This can be customized by setting the isFunction property of the mathfield
      or by declaring a symbol as a function using the declare() method of the
      compute engine. For example:

      MathfieldElement.computeEngine.declare("f", "Functions");

      In addition, a new isImplicitFunction hook has been added which can be used
      to indicate which symbols or commands are expected to be followed by an
      implicit argument. For example, the \sin function can be followed by an
      implicit argument without parentheses, as in \sin \frac{\pi}{2}. This
      affects the editing behavior when typing a / after the function. If an
      implicit function, the / will be interpreted as an argument to the function,
      otherwise it will be interpreted as a fraction with the function as the
      numerator.

    • The "phi" keycap in the virtual keyboard was incorrectly displaying the
      \varphi symbol. It now displays the \phi symbol.

    • #2227 Updating the content of the mathfield with mf.innerText will now
      correctly update the value of the mathfield.

    • #2225 For consistency with <textarea>, when setting the value change the
      selection to be at the end of the mathfield.

    0.98.3 2023-12-07

    Improvements

    • Improved contrast calculation for the checkmarks over color swatches, now
      using APCA.

    • In some situations, the virtual keyboard would not be displayed when the
      mathfield was focused and the mathVirtualKeyboardPolicy was set to "auto".

    0.98.2 2023-12-06

    Improvements

    • In some rare cases, the menu was not positioned correctly or would not display
      at all.

    • When dynamically changing the layout of the mathfield, for example when using
      a font-size attribute based on viewport units, correctly redraw the selection

    • Selection while dragging would stop after a few milliseconds

    • The "contains highlight" indicator is no longer displayed when the mathfield
      is not focused or when the indicator is outside of a prompt.

    • #2194 Ignore long press events when the pointer is a mouse.

    Issues Resolved

    • #2195 If the mathfield had a variable width the selection would not be
      displayed correctly.

    • #2190 Under some circumstances, commands selected from the menu could be
      executed twice.

    0.98.1 2023-12-05

    New Features

    • Added mf.showMenu() method to programmatically show the context menu.

    Issues Resolved

    • Correctly position the menu when the document has been scrolled.

    • When serializing, do not generate a \text command around a \texttt
      command.

    Improvements

    • Keyboard navigate submenus with a grid layout

    0.98.0 2023-12-03

    Breaking Changes

    • The mf.setPromptContent() method has been renamed to mf.setPromptValue()
      for consistency with the mf.getPromptValue() method.

    • The mf.stripPromptContent() method has been removed. Its functionality can
      be achieved with:

    const prompts = mf.getPrompts();
    const values = prompts.map(id => mf.getPromptValue(id));
    prompts.forEach(id => mf.setPromptValue(id, ""));

    Improvements

    • A new mf.getPromptRange() method returns the selection range of a prompt.
      This can be used for example to focus a mathfield and select a specific
      prompt:
    mf.focus();
    mf.selection = mf.getPromptRange(id);
    • The Color, Background Color and Variant menus correctly toggle the colors and
      variant, and reflect their state with a checkmark or mixedmark.

    • Setting the mf.menuItems property before the mathfield is inserted in the
      DOM will now correctly update the menu items.

    • Correctly display tooltips in the menu when invoked via the menu icon.

    • Localized menu items in the context menu.

    New Features

    • #348 Added a placeholder attribute, similar to the placeholder
      attribute of a <textarea> element. This specifies a short hint as a LaTeX
      string that describes the expected value of the mathfield. When the mathfield
      is empty, the placeholder text is displayed. The placeholder text can be
      styled with the math-field::part(placeholder) CSS selector.

    • #2162 Added a "latex-without-placeholders" format to the getValue()
      method. This format is similar to the "latex" format, but does not include
      the placeholders (for "fill-in-the-blanks").

    Issues Resolved

    • #2169 Changing the selection programatically will now correctly update the
      mathfield.

    • #2189 If the decimal separator is set to ,, the virtual keyboard will
      now correctly display the decimal separator as a comma.

    • #2139 On some keyboard layouts, ALT+/ would insert a
      \/ command, which is not standard. Now, the simple / is inserted.

    0.97.4 2023-11-29

    Issues Resolved

    • When a global .row class was defined, it would be applied to the virtual
      keyboard rows, resulting in incorrect layout.

    Improvements

    • Added mf.queryStyle() method to query the style of a selection or the
      current style if no selection.

    0.97.3 2023-11-28

    Improvements

    • The mode-change event is now dispatched more consistently when the mode
      changes.

    • When the mathfield loses focus, if some of the content is in LaTeX mode, it
      remains in LaTeX mode. Previously, it would switch to math mode when losing
      focus.

    • Changing the user-select CSS property before inserting the mathfield in the
      DOM would not always be respected.

    • Use the DOM Popover API when available, which should ensure menus are
      displayed on top of other elements more consistently.

    • Added support for accented characters in the virtual keyboard (press and hold
      a vowel on an alphabetic keyboard to get accented variants), including a
      modified AZERTY layout (SHIFT+digits to get common accented
      characters).

    • Improved rendering of the menu for CJK and LTR languages.

    Issues Resolved

    • If there were multiple mathfield elements on the page, only the last one would
      display tooltips.

    • #2184 Pressing the TAB key when in a prompt (fill-in-the-blank)
      would not move to the next prompt

    • #2183 The MathML serialization of factorial was incorrect.

    • #2181 The MathML serialization of limits was incorrect.

    0.97.2 2023-11-21

    Issues Resolved

    • Keybindings for German Linux keyboard layout were not working correctly.

    0.97.1 2023-11-20

    Issues Resolved

    • #2180 Allow the context menu to get turned off by setting
      mf.menuItems = []

    • Fixed a layout issue with the positioning of the context menu in some cases.

    • Improved dark mode appearance of context menu

    0.97.0 2023-11-20

    New Features

    • Context Menu Right-clicking on a mathfield or clicking the menu icon next
      to the virtual keyboard icon will bring up a context menu.

      The keyboard shortcut ALT+SPACE will also bring up the
      context menu. This keyboard shortcut previously toggled the virtual keyboard.
      This keyboard shortcut to toggle the virtual keyboard is now
      ALT+SHIFT+SPACE.

      The menu includes commands to:

      • insert and edit matrixes
      • evaluate, simplify and solve equations
      • change the variant of a symbol (blackboard, fraktur, etc...)
      • change the style (italic, bold, etc...) of the selection
      • change the color and background color
      • insert text
      • copy LaTeX, MathML or MathASCII to the clipboard
      • toggle the virtual keyboard

      The content of the menu may change in future versions, and feedback is
      welcome.

      The menu can be customized by setting the mf.menuItems property of the
      mathfield. The value of this property is an array of menu items. See
      the documentation for details.

    Improvements

    • The tooltip above the virtual keyboard toggle (and the menu glyph) now only
      appears after a delay.

    Issues Resolved

    • The expression \pmod5 is now correctly parsed as \pmod{5}. Macros that
      used an argument that was not a literal group were not parsed correctly.

    0.96.2 2023-11-16

    Issues Resolved

    • The vertical alignment of formulas containing some fractions was incorrect in
      some cases.
    • #2168 Changing the MathfieldELement.locale or MathfieldElement.strings
      would not affect existing mathfields.
    • Incorrectly accessing static properties (for example using mf.locale instead
      of MathfieldElement.locale) will now throw an error.
    • #2160 The keycap tooltips were not displayed.
    • #2144 When smartFence was on, an inline shortcut that conflicted with a
      delimiter was ignored.

    Improvements

    • #2141: Added St Mary's Road symbols for theoretical computer science,
      including \mapsfrom.
    • #2158 Support the German keyboard layout on Linux.
    • #2102 The mathfield element now respects the user-select CSS property.
      If it is set to none, the mathfield will not be selectable.

    0.96.1 2023-11-15

    Improvements

    • Simplified the syntax to modify registers. Use
      mf.registers.arraystretch = 1.5 instead of mf.registers = {...mf.registers,
      arraystretch: 1.5}`
    • Allow changing registers using \renewcommand, for example
      \renewcommand{\arraystretch}{1.5}
    • Added keycap shortcuts [up] and [down] to move the selection up or down in
      a matrix.
    • Display the environment popover when the selection is inside a matrix, even
      when the virtual keyboard is not visible.

    Issues Resolved

    • #2159 Runtime error in sandboxed mode when in an iframe from different
      origin
    • #2175 Addressed some rendering issues with Safar where a fraction inside a
      \left...\right was vertically offset.
    • #2176 Using the [hide-keyboard] virtual keycap would cause a runtime
      error.
    • #2161 When the virtual keyboard is hidden, a geometrychange event is
      dispatched.

    0.96.0 2023-11-14

    Breaking Changes

    • The function serializeMathJsonToLatex() has been renamed to
      convertMathJsonToLatex() for consistency.

    Issues Resolved

    • A closing parenthesis following a function application would be ignored, i.e.
      (f(x)) would be parsed as (f(x).
    • #2116 Pressing the "/" key after an expression ending with a superscript
      would not recognize the left argument as a numerator.
    • #2124 In text mode, some characters were incorrectly interpreted as a math
      command, for example ( was interpreted as \lparen`. This could cause some
      interoperability issues.
    • #2110 If using the keyboard to enter several macros mapping to an
      \operatorname command, some of the commands could fail to render. For
      example, typing "1mm + 2mm" in a mathfield would result in "1 + 2mm" to be
      displayed.
    • When inserting an mchem atom, preserve the verbatimLatex associated with the
      atom, so that the value property of the atom is correctly serialized.
    • When invoking the moveToMathfieldEnd command, the selection was not changed
      if it was not collapsed and already at the end of the mathfield. Similarly for
      moveToMathfieldStart.

    Improvements

    • Added support for additional commands from the mathtools, actuarialangle,
      colonequals, statmath and amsopn packages
    • Added support for longdiv enclosure (\mathenclose{longdiv}{...})
    • The decimal separator key (.) in the virtual keyboard was displayed as a
      blank key.
    • #2109 In the virtual keyboard, some placeholders could be hard to see when
      a keycap was in a pressed state.
    • #2105 The keycap shift + in the numeric keyboard was inserting a sum
      with limits contrary to what the keycap label indicated.
    • In the alphabetic virtual keyboard, the , key now produces a semicolon when
      shifted and has a variant panel with additional punctuation.
    • Improved virtual keyboard for integrals with more explicit template
    • When removing the limit of an integral or a sum, do not delete the operator
      itself.
    • #2122 On the Virtual Keyboard, the multiplication key now produces \cdot
      instead of \times. Use shift to produce \times.
    • Improved serialization to ASCIIMath and MathML (#2130 and others)
    • #2121 For ASCIIMath and MathML serialization, including phantom closing
      delimiter in the output.
    • Pressing the Action keycap on the virtual keyboa...

Snyk has created this PR to upgrade mathlive from 0.69.10 to 0.101.0.

See this package in npm:
mathlive

See this project in Snyk:
https://app.snyk.io/org/apexiodacoder/project/2f88544a-9970-43c7-a8ff-7ddd0e750a2b?utm_source=github&utm_medium=referral&page=upgrade-pr
Copy link

vercel bot commented Oct 31, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
graph ✅ Ready (Inspect) Visit Preview 💬 Add feedback Oct 31, 2024 6:31am

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants