@pie-lib/math-input 6.11.4 → 6.13.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/lib/__tests__/math-input-test.js +109 -0
  4. package/lib/horizontal-keypad.js +10 -4
  5. package/lib/index.js +11 -15
  6. package/lib/keypad/__tests__/index.test.js +41 -0
  7. package/lib/keypad/__tests__/keys-layout.test.js +15 -0
  8. package/lib/keypad/index.js +96 -25
  9. package/lib/keypad/keys-layout.js +1 -1
  10. package/lib/keys/__tests__/utils.test.js +60 -0
  11. package/lib/keys/basic-operators.js +1 -1
  12. package/lib/keys/chars.js +1 -1
  13. package/lib/keys/comparison.js +1 -1
  14. package/lib/keys/constants.js +1 -1
  15. package/lib/keys/digits.js +1 -1
  16. package/lib/keys/edit.js +1 -1
  17. package/lib/keys/exponent.js +1 -1
  18. package/lib/keys/fractions.js +1 -1
  19. package/lib/keys/geometry.js +5 -3
  20. package/lib/keys/grades.js +13 -1
  21. package/lib/keys/index.js +1 -1
  22. package/lib/keys/log.js +2 -2
  23. package/lib/keys/logic.js +1 -1
  24. package/lib/keys/matrices.js +1 -1
  25. package/lib/keys/misc.js +1 -1
  26. package/lib/keys/navigation.js +1 -1
  27. package/lib/keys/operators.js +1 -1
  28. package/lib/keys/statistics.js +1 -1
  29. package/lib/keys/sub-sup.js +1 -1
  30. package/lib/keys/trigonometry.js +1 -1
  31. package/lib/keys/utils.js +1 -1
  32. package/lib/keys/vars.js +1 -1
  33. package/lib/math-input.js +1 -1
  34. package/lib/mq/__tests__/input.test.js +119 -0
  35. package/lib/mq/__tests__/static.test.js +74 -0
  36. package/lib/mq/common-mq-styles.js +110 -0
  37. package/lib/mq/custom-elements.js +1 -1
  38. package/lib/mq/index.js +9 -1
  39. package/lib/mq/input.js +13 -11
  40. package/lib/mq/static.js +199 -76
  41. package/lib/updateSpans.js +23 -0
  42. package/package.json +2 -2
  43. package/src/__tests__/__snapshots__/math-input-test.jsx.snap +152 -0
  44. package/src/__tests__/math-input-test.jsx +85 -0
  45. package/src/horizontal-keypad.jsx +14 -1
  46. package/src/index.jsx +1 -10
  47. package/src/keypad/__tests__/__snapshots__/index.test.jsx.snap +193 -0
  48. package/src/keypad/__tests__/index.test.jsx +24 -0
  49. package/src/keypad/__tests__/keys-layout.test.js +15 -0
  50. package/src/keypad/index.jsx +99 -15
  51. package/src/keys/__tests__/utils.test.js +57 -0
  52. package/src/keys/geometry.js +6 -2
  53. package/src/keys/grades.js +11 -0
  54. package/src/keys/log.js +1 -1
  55. package/src/mq/__tests__/__snapshots__/input.test.jsx.snap +9 -0
  56. package/src/mq/__tests__/input.test.jsx +92 -0
  57. package/src/mq/__tests__/static.test.jsx +57 -0
  58. package/src/mq/common-mq-styles.js +105 -0
  59. package/src/mq/index.js +2 -1
  60. package/src/mq/input.jsx +22 -9
  61. package/src/mq/static.jsx +142 -13
  62. package/src/updateSpans.js +15 -0
  63. package/README.md +0 -27
  64. package/lib/horizontal-keypad.js.map +0 -1
  65. package/lib/index.js.map +0 -1
  66. package/lib/keypad/index.js.map +0 -1
  67. package/lib/keypad/keys-layout.js.map +0 -1
  68. package/lib/keys/basic-operators.js.map +0 -1
  69. package/lib/keys/chars.js.map +0 -1
  70. package/lib/keys/comparison.js.map +0 -1
  71. package/lib/keys/constants.js.map +0 -1
  72. package/lib/keys/digits.js.map +0 -1
  73. package/lib/keys/edit.js.map +0 -1
  74. package/lib/keys/exponent.js.map +0 -1
  75. package/lib/keys/fractions.js.map +0 -1
  76. package/lib/keys/geometry.js.map +0 -1
  77. package/lib/keys/grades.js.map +0 -1
  78. package/lib/keys/index.js.map +0 -1
  79. package/lib/keys/log.js.map +0 -1
  80. package/lib/keys/logic.js.map +0 -1
  81. package/lib/keys/matrices.js.map +0 -1
  82. package/lib/keys/misc.js.map +0 -1
  83. package/lib/keys/navigation.js.map +0 -1
  84. package/lib/keys/operators.js.map +0 -1
  85. package/lib/keys/statistics.js.map +0 -1
  86. package/lib/keys/sub-sup.js.map +0 -1
  87. package/lib/keys/trigonometry.js.map +0 -1
  88. package/lib/keys/utils.js.map +0 -1
  89. package/lib/keys/vars.js.map +0 -1
  90. package/lib/math-input.js.map +0 -1
  91. package/lib/mq/custom-elements.js.map +0 -1
  92. package/lib/mq/index.js.map +0 -1
  93. package/lib/mq/input.js.map +0 -1
  94. package/lib/mq/static.js.map +0 -1
package/lib/mq/static.js CHANGED
@@ -29,7 +29,7 @@ var _debug = _interopRequireDefault(require("debug"));
29
29
 
30
30
  var _mathquill = _interopRequireDefault(require("@pie-framework/mathquill"));
31
31
 
32
- var _index = require("../index");
32
+ var _updateSpans = require("../updateSpans");
33
33
 
34
34
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
35
35
 
@@ -49,6 +49,18 @@ function stripSpaces() {
49
49
  var string = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
50
50
  return string.replace(WHITESPACE_REGEX, '');
51
51
  }
52
+
53
+ function countBraces(latex) {
54
+ var count = 0;
55
+
56
+ for (var i = 0; i < (latex || '').length; i++) {
57
+ if (latex[i] === '{') {
58
+ count++;
59
+ }
60
+ }
61
+
62
+ return count;
63
+ }
52
64
  /**
53
65
  * Wrapper for MathQuill MQ.MathField.
54
66
  */
@@ -59,73 +71,78 @@ var Static = /*#__PURE__*/function (_React$Component) {
59
71
 
60
72
  var _super = _createSuper(Static);
61
73
 
62
- function Static() {
74
+ function Static(props) {
63
75
  var _this;
64
76
 
65
77
  (0, _classCallCheck2["default"])(this, Static);
78
+ _this = _super.call(this, props);
79
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "createLiveRegion", function () {
80
+ _this.liveRegion = document.createElement('div');
81
+ _this.liveRegion.style.position = 'absolute';
82
+ _this.liveRegion.style.width = '1px';
83
+ _this.liveRegion.style.height = '1px';
84
+ _this.liveRegion.style.marginTop = '-1px';
85
+ _this.liveRegion.style.clip = 'rect(1px, 1px, 1px, 1px)';
86
+ _this.liveRegion.style.overflow = 'hidden';
66
87
 
67
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
68
- args[_key] = arguments[_key];
69
- }
88
+ _this.liveRegion.setAttribute('aria-live', 'polite');
70
89
 
71
- _this = _super.call.apply(_super, [this].concat(args));
72
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onFocus", function (e) {
73
- try {
74
- var rootBlock = e.target.parentElement.nextSibling;
75
- var id = parseInt(rootBlock.getAttribute('mathquill-block-id'), 10);
76
-
77
- if (!id) {
78
- rootBlock = rootBlock.parentElement;
79
- id = parseInt(rootBlock.getAttribute('mathquill-block-id'), 10);
80
- }
90
+ _this.liveRegion.setAttribute('aria-atomic', 'true');
81
91
 
82
- var innerField = _this.mathField.innerFields.find(function (f) {
83
- return f.id === id;
84
- });
85
-
86
- if (innerField) {
87
- var name = _this.props.getFieldName(innerField, _this.mathField.innerFields);
92
+ document.body.appendChild(_this.liveRegion);
93
+ });
94
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "addEventListeners", function () {
95
+ var input = _this.inputRef.current;
88
96
 
89
- if (_this.props.setInput) {
90
- _this.props.setInput(innerField);
91
- }
97
+ if (input) {
98
+ input.addEventListener('keydown', _this.handleKeyDown);
99
+ input.addEventListener('click', _this.handleMathKeyboardClick);
100
+ }
101
+ });
102
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "removeEventListeners", function () {
103
+ var input = _this.inputRef.current;
92
104
 
93
- _this.props.onSubFieldFocus(name, innerField);
94
- }
95
- } catch (err) {
96
- // eslint-disable-next-line no-console
97
- console.error('error finding root block', err.message);
105
+ if (input) {
106
+ input.removeEventListener('keydown', _this.handleKeyDown);
107
+ input.removeEventListener('click', _this.handleMathKeyboardClick);
98
108
  }
99
109
  });
100
- return _this;
101
- }
110
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "removeLiveRegion", function () {
111
+ if (_this.liveRegion) {
112
+ document.body.removeChild(_this.liveRegion);
113
+ _this.liveRegion = null;
114
+ }
115
+ });
116
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleKeyDown", function (event) {
117
+ if ((event === null || event === void 0 ? void 0 : event.key) === 'Backspace' || (event === null || event === void 0 ? void 0 : event.key) === 'Delete') {
118
+ _this.setState({
119
+ isDeleteKeyPressed: true
120
+ });
121
+ }
102
122
 
103
- (0, _createClass2["default"])(Static, [{
104
- key: "componentDidMount",
105
- value: function componentDidMount() {
106
- this.update();
107
- (0, _index.updateSpans)();
108
- }
109
- }, {
110
- key: "componentDidUpdate",
111
- value: function componentDidUpdate() {
112
- this.update();
113
- (0, _index.updateSpans)();
114
- }
115
- }, {
116
- key: "onInputEdit",
117
- value: function onInputEdit(field) {
118
- if (!this.mathField) {
123
+ _this.setState({
124
+ inputSource: 'keyboard'
125
+ });
126
+ });
127
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleMathKeyboardClick", function () {
128
+ _this.setState({
129
+ inputSource: 'mathKeyboard'
130
+ });
131
+ });
132
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onInputEdit", function (field) {
133
+ if (!_this.mathField) {
119
134
  return;
120
135
  }
121
136
 
122
- var name = this.props.getFieldName(field, this.mathField.innerFields);
137
+ var name = _this.props.getFieldName(field, _this.mathField.innerFields);
138
+
139
+ if (_this.props.onSubFieldChange) {
140
+ var _this$inputRef;
123
141
 
124
- if (this.props.onSubFieldChange) {
125
142
  // eslint-disable-next-line no-useless-escape
126
143
  var regexMatch = field.latex().match(/[0-9]\\ \\frac\{[^\{]*\}\{ \}/);
127
144
 
128
- if (this.input && regexMatch && regexMatch !== null && regexMatch !== void 0 && regexMatch.length) {
145
+ if ((_this$inputRef = _this.inputRef) !== null && _this$inputRef !== void 0 && _this$inputRef.current && regexMatch && regexMatch !== null && regexMatch !== void 0 && regexMatch.length) {
129
146
  try {
130
147
  field.__controller.cursor.insLeftOf(field.__controller.cursor.parent[-1].parent);
131
148
 
@@ -137,45 +154,155 @@ var Static = /*#__PURE__*/function (_React$Component) {
137
154
  console.error(e.toString());
138
155
  }
139
156
  } else {
140
- this.props.onSubFieldChange(name, field.latex());
157
+ _this.props.onSubFieldChange(name, field.latex());
141
158
  }
142
159
  }
143
- }
144
- }, {
145
- key: "update",
146
- value: function update() {
160
+
161
+ _this.announceLatexConversion(field.latex());
162
+ });
163
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "announceLatexConversion", function (newLatex) {
164
+ if (!_this.state) {
165
+ console.error('State is not initialized');
166
+ return;
167
+ }
168
+
169
+ var _this$state = _this.state,
170
+ previousLatex = _this$state.previousLatex,
171
+ inputSource = _this$state.inputSource,
172
+ isDeleteKeyPressed = _this$state.isDeleteKeyPressed;
173
+ var announcement = 'Converted to math symbol';
174
+
175
+ if (inputSource === 'keyboard' && !isDeleteKeyPressed) {
176
+ var newBraces = countBraces(newLatex);
177
+ var oldBraces = countBraces(previousLatex);
178
+
179
+ if (newBraces > oldBraces) {
180
+ _this.announceMessage(announcement);
181
+ } else {
182
+ try {
183
+ _this.mathField.parseLatex(previousLatex);
184
+
185
+ _this.mathField.parseLatex(newLatex);
186
+
187
+ if (newLatex == previousLatex) {
188
+ _this.announceMessage(announcement);
189
+ }
190
+ } catch (e) {
191
+ console.warn('Error parsing latex:', e.message);
192
+ console.warn(e);
193
+ }
194
+ }
195
+ }
196
+
197
+ _this.setState({
198
+ previousLatex: newLatex,
199
+ isDeleteKeyPressed: false
200
+ });
201
+ });
202
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "announceMessage", function (message) {
203
+ _this.setState({
204
+ previousLatex: ''
205
+ });
206
+
207
+ if (_this.liveRegion) {
208
+ _this.liveRegion.textContent = message; // Clear the message after it is announced
209
+
210
+ setTimeout(function () {
211
+ _this.liveRegion.textContent = '';
212
+ }, 500);
213
+ }
214
+ });
215
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "update", function () {
147
216
  if (!MQ) {
148
217
  throw new Error('MQ is not defined - but component has mounted?');
149
- } // this.input.innerHTML = this.props.latex;
218
+ }
150
219
 
220
+ if (!_this.mathField) {
221
+ var _this$inputRef2;
151
222
 
152
- if (!this.mathField) {
153
- this.mathField = MQ.StaticMath(this.input, {
223
+ _this.mathField = MQ.StaticMath((_this$inputRef2 = _this.inputRef) === null || _this$inputRef2 === void 0 ? void 0 : _this$inputRef2.current, {
154
224
  handlers: {
155
- edit: this.onInputEdit.bind(this)
225
+ edit: _this.onInputEdit.bind((0, _assertThisInitialized2["default"])(_this))
156
226
  }
157
227
  });
158
228
  }
159
229
 
160
230
  try {
161
- this.mathField.parseLatex(this.props.latex);
162
- this.mathField.latex(this.props.latex);
231
+ _this.mathField.parseLatex(_this.props.latex);
232
+
233
+ _this.mathField.latex(_this.props.latex);
163
234
  } catch (e) {
164
235
  // default latex if received has errors
165
- this.mathField.latex('\\MathQuillMathField[r1]{}');
236
+ _this.mathField.latex('\\MathQuillMathField[r1]{}');
166
237
  }
238
+ });
239
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "blur", function () {
240
+ log('blur mathfield');
241
+
242
+ _this.mathField.blur();
243
+ });
244
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "focus", function () {
245
+ log('focus mathfield...');
246
+
247
+ _this.mathField.focus();
248
+ });
249
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onFocus", function (e) {
250
+ try {
251
+ var rootBlock = e.target.parentElement.nextSibling;
252
+ var id = parseInt(rootBlock.getAttribute('mathquill-block-id'), 10);
253
+
254
+ if (!id) {
255
+ rootBlock = rootBlock.parentElement;
256
+ id = parseInt(rootBlock.getAttribute('mathquill-block-id'), 10);
257
+ }
258
+
259
+ var innerField = _this.mathField.innerFields.find(function (f) {
260
+ return f.id === id;
261
+ });
262
+
263
+ if (innerField) {
264
+ var name = _this.props.getFieldName(innerField, _this.mathField.innerFields);
265
+
266
+ if (_this.props.setInput) {
267
+ _this.props.setInput(innerField);
268
+ }
269
+
270
+ _this.props.onSubFieldFocus(name, innerField);
271
+ }
272
+ } catch (err) {
273
+ // eslint-disable-next-line no-console
274
+ console.error('error finding root block', err.message);
275
+ }
276
+ });
277
+ _this.state = {
278
+ announcement: '',
279
+ previousLatex: '',
280
+ inputSource: null,
281
+ isDeleteKeyPressed: false
282
+ };
283
+ _this.inputRef = /*#__PURE__*/_react["default"].createRef();
284
+ return _this;
285
+ }
286
+
287
+ (0, _createClass2["default"])(Static, [{
288
+ key: "componentDidMount",
289
+ value: function componentDidMount() {
290
+ this.update();
291
+ (0, _updateSpans.updateSpans)();
292
+ this.createLiveRegion();
293
+ this.addEventListeners();
167
294
  }
168
295
  }, {
169
- key: "blur",
170
- value: function blur() {
171
- log('blur mathfield');
172
- this.mathField.blur();
296
+ key: "componentDidUpdate",
297
+ value: function componentDidUpdate() {
298
+ this.update();
299
+ (0, _updateSpans.updateSpans)();
173
300
  }
174
301
  }, {
175
- key: "focus",
176
- value: function focus() {
177
- log('focus mathfield...');
178
- this.mathField.focus();
302
+ key: "componentWillUnmount",
303
+ value: function componentWillUnmount() {
304
+ this.removeLiveRegion();
305
+ this.removeEventListeners();
179
306
  }
180
307
  }, {
181
308
  key: "shouldComponentUpdate",
@@ -198,8 +325,6 @@ var Static = /*#__PURE__*/function (_React$Component) {
198
325
  }, {
199
326
  key: "render",
200
327
  value: function render() {
201
- var _this2 = this;
202
-
203
328
  var _this$props = this.props,
204
329
  onBlur = _this$props.onBlur,
205
330
  className = _this$props.className;
@@ -207,9 +332,7 @@ var Static = /*#__PURE__*/function (_React$Component) {
207
332
  className: className,
208
333
  onFocus: this.onFocus,
209
334
  onBlur: onBlur,
210
- ref: function ref(r) {
211
- return _this2.input = r;
212
- }
335
+ ref: this.inputRef
213
336
  });
214
337
  }
215
338
  }]);
@@ -230,4 +353,4 @@ exports["default"] = Static;
230
353
  (0, _defineProperty2["default"])(Static, "defaultProps", {
231
354
  getFieldName: function getFieldName() {}
232
355
  });
233
- //# sourceMappingURL=static.js.map
356
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/mq/static.jsx"],"names":["MQ","window","MathQuill","getInterface","log","REGEX","WHITESPACE_REGEX","stripSpaces","string","replace","countBraces","latex","count","i","length","Static","props","liveRegion","document","createElement","style","position","width","height","marginTop","clip","overflow","setAttribute","body","appendChild","input","inputRef","current","addEventListener","handleKeyDown","handleMathKeyboardClick","removeEventListener","removeChild","event","key","setState","isDeleteKeyPressed","inputSource","field","mathField","name","getFieldName","innerFields","onSubFieldChange","regexMatch","match","__controller","cursor","insLeftOf","parent","el","dispatchEvent","KeyboardEvent","keyCode","e","console","error","toString","announceLatexConversion","newLatex","state","previousLatex","announcement","newBraces","oldBraces","announceMessage","parseLatex","warn","message","textContent","setTimeout","Error","StaticMath","handlers","edit","onInputEdit","bind","blur","focus","rootBlock","target","parentElement","nextSibling","id","parseInt","getAttribute","innerField","find","f","setInput","onSubFieldFocus","err","React","createRef","update","createLiveRegion","addEventListeners","removeLiveRegion","removeEventListeners","nextProps","parsedLatex","stripped","newFieldCount","out","trim","Object","keys","onBlur","className","onFocus","Component","PropTypes","isRequired","func"],"mappings":"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","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport debug from 'debug';\nimport MathQuill from '@pie-framework/mathquill';\nimport { updateSpans } from '../updateSpans';\n\nlet MQ;\nif (typeof window !== 'undefined') {\n  MQ = MathQuill.getInterface(2);\n}\n\nconst log = debug('pie-lib:math-input:mq:static');\nconst REGEX = /\\\\MathQuillMathField\\[r\\d*\\]\\{(.*?)\\}/g;\nconst WHITESPACE_REGEX = / /g;\n\nfunction stripSpaces(string = '') {\n  return string.replace(WHITESPACE_REGEX, '');\n}\n\nfunction countBraces(latex) {\n  let count = 0;\n\n  for (let i = 0; i < (latex || '').length; i++) {\n    if (latex[i] === '{') {\n      count++;\n    }\n  }\n\n  return count;\n}\n\n/**\n * Wrapper for MathQuill MQ.MathField.\n */\nexport default class Static extends React.Component {\n  static propTypes = {\n    latex: PropTypes.string.isRequired,\n    onFocus: PropTypes.func,\n    onBlur: PropTypes.func,\n    className: PropTypes.string,\n    getFieldName: PropTypes.func,\n    onSubFieldChange: PropTypes.func,\n    onSubFieldFocus: PropTypes.func,\n    setInput: PropTypes.func,\n  };\n\n  static defaultProps = {\n    getFieldName: () => {},\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      announcement: '',\n      previousLatex: '',\n      inputSource: null,\n      isDeleteKeyPressed: false,\n    };\n\n    this.inputRef = React.createRef();\n  }\n\n  componentDidMount() {\n    this.update();\n    updateSpans();\n\n    this.createLiveRegion();\n    this.addEventListeners();\n  }\n\n  componentDidUpdate() {\n    this.update();\n    updateSpans();\n  }\n\n  componentWillUnmount() {\n    this.removeLiveRegion();\n    this.removeEventListeners();\n  }\n\n  createLiveRegion = () => {\n    this.liveRegion = document.createElement('div');\n    this.liveRegion.style.position = 'absolute';\n    this.liveRegion.style.width = '1px';\n    this.liveRegion.style.height = '1px';\n    this.liveRegion.style.marginTop = '-1px';\n    this.liveRegion.style.clip = 'rect(1px, 1px, 1px, 1px)';\n    this.liveRegion.style.overflow = 'hidden';\n    this.liveRegion.setAttribute('aria-live', 'polite');\n    this.liveRegion.setAttribute('aria-atomic', 'true');\n\n    document.body.appendChild(this.liveRegion);\n  };\n\n  addEventListeners = () => {\n    const input = this.inputRef.current;\n\n    if (input) {\n      input.addEventListener('keydown', this.handleKeyDown);\n      input.addEventListener('click', this.handleMathKeyboardClick);\n    }\n  };\n\n  removeEventListeners = () => {\n    const input = this.inputRef.current;\n\n    if (input) {\n      input.removeEventListener('keydown', this.handleKeyDown);\n      input.removeEventListener('click', this.handleMathKeyboardClick);\n    }\n  };\n\n  removeLiveRegion = () => {\n    if (this.liveRegion) {\n      document.body.removeChild(this.liveRegion);\n      this.liveRegion = null;\n    }\n  };\n\n  handleKeyDown = (event) => {\n    if (event?.key === 'Backspace' || event?.key === 'Delete') {\n      this.setState({ isDeleteKeyPressed: true });\n    }\n    this.setState({ inputSource: 'keyboard' });\n  };\n\n  handleMathKeyboardClick = () => {\n    this.setState({ inputSource: 'mathKeyboard' });\n  };\n\n  onInputEdit = (field) => {\n    if (!this.mathField) {\n      return;\n    }\n    const name = this.props.getFieldName(field, this.mathField.innerFields);\n\n    if (this.props.onSubFieldChange) {\n      // eslint-disable-next-line no-useless-escape\n      const regexMatch = field.latex().match(/[0-9]\\\\ \\\\frac\\{[^\\{]*\\}\\{ \\}/);\n\n      if (this.inputRef?.current && regexMatch && regexMatch?.length) {\n        try {\n          field.__controller.cursor.insLeftOf(field.__controller.cursor.parent[-1].parent);\n          field.el().dispatchEvent(new KeyboardEvent('keydown', { keyCode: 8 }));\n        } catch (e) {\n          // eslint-disable-next-line no-console\n          console.error(e.toString());\n        }\n      } else {\n        this.props.onSubFieldChange(name, field.latex());\n      }\n    }\n\n    this.announceLatexConversion(field.latex());\n  };\n\n  announceLatexConversion = (newLatex) => {\n    if (!this.state) {\n      console.error('State is not initialized');\n      return;\n    }\n\n    const { previousLatex, inputSource, isDeleteKeyPressed } = this.state;\n    const announcement = 'Converted to math symbol';\n\n    if (inputSource === 'keyboard' && !isDeleteKeyPressed) {\n      const newBraces = countBraces(newLatex);\n      const oldBraces = countBraces(previousLatex);\n\n      if (newBraces > oldBraces) {\n        this.announceMessage(announcement);\n      } else {\n        try {\n          this.mathField.parseLatex(previousLatex);\n          this.mathField.parseLatex(newLatex);\n\n          if (newLatex == previousLatex) {\n            this.announceMessage(announcement);\n          }\n        } catch (e) {\n          console.warn('Error parsing latex:', e.message);\n          console.warn(e);\n        }\n      }\n    }\n\n    this.setState({ previousLatex: newLatex, isDeleteKeyPressed: false });\n  };\n\n  announceMessage = (message) => {\n    this.setState({ previousLatex: '' });\n\n    if (this.liveRegion) {\n      this.liveRegion.textContent = message;\n\n      // Clear the message after it is announced\n      setTimeout(() => {\n        this.liveRegion.textContent = '';\n      }, 500);\n    }\n  };\n\n  update = () => {\n    if (!MQ) {\n      throw new Error('MQ is not defined - but component has mounted?');\n    }\n    if (!this.mathField) {\n      this.mathField = MQ.StaticMath(this.inputRef?.current, {\n        handlers: {\n          edit: this.onInputEdit.bind(this),\n        },\n      });\n    }\n\n    try {\n      this.mathField.parseLatex(this.props.latex);\n      this.mathField.latex(this.props.latex);\n    } catch (e) {\n      // default latex if received has errors\n      this.mathField.latex('\\\\MathQuillMathField[r1]{}');\n    }\n  };\n\n  blur = () => {\n    log('blur mathfield');\n    this.mathField.blur();\n  };\n\n  focus = () => {\n    log('focus mathfield...');\n    this.mathField.focus();\n  };\n\n  shouldComponentUpdate(nextProps) {\n    try {\n      const parsedLatex = this.mathField.parseLatex(nextProps.latex);\n      const stripped = stripSpaces(parsedLatex);\n      const newFieldCount = (nextProps.latex.match(REGEX) || []).length;\n\n      const out =\n        stripped !== stripSpaces(this.mathField.latex().trim()) ||\n        newFieldCount !== Object.keys(this.mathField.innerFields).length / 2;\n\n      log('[shouldComponentUpdate] ', out);\n      return out;\n    } catch (e) {\n      // eslint-disable-next-line no-console\n      console.warn('Error parsing latex:', e.message, 'skip update');\n      // eslint-disable-next-line no-console\n      console.warn(e);\n      return false;\n    }\n  }\n\n  onFocus = (e) => {\n    try {\n      let rootBlock = e.target.parentElement.nextSibling;\n      let id = parseInt(rootBlock.getAttribute('mathquill-block-id'), 10);\n\n      if (!id) {\n        rootBlock = rootBlock.parentElement;\n        id = parseInt(rootBlock.getAttribute('mathquill-block-id'), 10);\n      }\n\n      const innerField = this.mathField.innerFields.find((f) => f.id === id);\n\n      if (innerField) {\n        const name = this.props.getFieldName(innerField, this.mathField.innerFields);\n        if (this.props.setInput) {\n          this.props.setInput(innerField);\n        }\n        this.props.onSubFieldFocus(name, innerField);\n      }\n    } catch (err) {\n      // eslint-disable-next-line no-console\n      console.error('error finding root block', err.message);\n    }\n  };\n\n  render() {\n    const { onBlur, className } = this.props;\n\n    return <span className={className} onFocus={this.onFocus} onBlur={onBlur} ref={this.inputRef} />;\n  }\n}\n"]}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.updateSpans = void 0;
7
+
8
+ // increase the font of parallel notation
9
+ var updateSpans = function updateSpans() {
10
+ var spans = Array.from(document.querySelectorAll('span[mathquill-command-id]'));
11
+ (spans || []).forEach(function (span) {
12
+ if (span && span.innerText === '∥' && span.className !== 'mq-editable-field') {
13
+ span.style.fontSize = '32px';
14
+ }
15
+
16
+ if ((span.innerText === '′' || span.innerText === '′′') && !span.hasAttribute('data-prime')) {
17
+ span.setAttribute('data-prime', 'true');
18
+ }
19
+ });
20
+ };
21
+
22
+ exports.updateSpans = updateSpans;
23
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91cGRhdGVTcGFucy5qcyJdLCJuYW1lcyI6WyJ1cGRhdGVTcGFucyIsInNwYW5zIiwiQXJyYXkiLCJmcm9tIiwiZG9jdW1lbnQiLCJxdWVyeVNlbGVjdG9yQWxsIiwiZm9yRWFjaCIsInNwYW4iLCJpbm5lclRleHQiLCJjbGFzc05hbWUiLCJzdHlsZSIsImZvbnRTaXplIiwiaGFzQXR0cmlidXRlIiwic2V0QXR0cmlidXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7QUFDQSxJQUFNQSxXQUFXLEdBQUcsU0FBZEEsV0FBYyxHQUFNO0FBQ3hCLE1BQU1DLEtBQUssR0FBR0MsS0FBSyxDQUFDQyxJQUFOLENBQVdDLFFBQVEsQ0FBQ0MsZ0JBQVQsQ0FBMEIsNEJBQTFCLENBQVgsQ0FBZDtBQUNBLEdBQUNKLEtBQUssSUFBSSxFQUFWLEVBQWNLLE9BQWQsQ0FBc0IsVUFBQ0MsSUFBRCxFQUFVO0FBQzlCLFFBQUlBLElBQUksSUFBSUEsSUFBSSxDQUFDQyxTQUFMLEtBQW1CLEdBQTNCLElBQWtDRCxJQUFJLENBQUNFLFNBQUwsS0FBbUIsbUJBQXpELEVBQThFO0FBQzVFRixNQUFBQSxJQUFJLENBQUNHLEtBQUwsQ0FBV0MsUUFBWCxHQUFzQixNQUF0QjtBQUNEOztBQUVELFFBQUksQ0FBQ0osSUFBSSxDQUFDQyxTQUFMLEtBQW1CLEdBQW5CLElBQTBCRCxJQUFJLENBQUNDLFNBQUwsS0FBbUIsSUFBOUMsS0FBdUQsQ0FBQ0QsSUFBSSxDQUFDSyxZQUFMLENBQWtCLFlBQWxCLENBQTVELEVBQTZGO0FBQzNGTCxNQUFBQSxJQUFJLENBQUNNLFlBQUwsQ0FBa0IsWUFBbEIsRUFBZ0MsTUFBaEM7QUFDRDtBQUNGLEdBUkQ7QUFTRCxDQVhEIiwic291cmNlc0NvbnRlbnQiOlsiLy8gaW5jcmVhc2UgdGhlIGZvbnQgb2YgcGFyYWxsZWwgbm90YXRpb25cbmNvbnN0IHVwZGF0ZVNwYW5zID0gKCkgPT4ge1xuICBjb25zdCBzcGFucyA9IEFycmF5LmZyb20oZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnc3BhblttYXRocXVpbGwtY29tbWFuZC1pZF0nKSk7XG4gIChzcGFucyB8fCBbXSkuZm9yRWFjaCgoc3BhbikgPT4ge1xuICAgIGlmIChzcGFuICYmIHNwYW4uaW5uZXJUZXh0ID09PSAn4oilJyAmJiBzcGFuLmNsYXNzTmFtZSAhPT0gJ21xLWVkaXRhYmxlLWZpZWxkJykge1xuICAgICAgc3Bhbi5zdHlsZS5mb250U2l6ZSA9ICczMnB4JztcbiAgICB9XG5cbiAgICBpZiAoKHNwYW4uaW5uZXJUZXh0ID09PSAn4oCyJyB8fCBzcGFuLmlubmVyVGV4dCA9PT0gJ+KAsuKAsicpICYmICFzcGFuLmhhc0F0dHJpYnV0ZSgnZGF0YS1wcmltZScpKSB7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZGF0YS1wcmltZScsICd0cnVlJyk7XG4gICAgfVxuICB9KTtcbn07XG5cbmV4cG9ydCB7IHVwZGF0ZVNwYW5zIH07XG4iXX0=
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "publishConfig": {
4
4
  "access": "public"
5
5
  },
6
- "version": "6.11.4",
6
+ "version": "6.13.0-beta.0",
7
7
  "main": "lib/index.js",
8
8
  "module": "src/index.jsx",
9
9
  "dependencies": {
@@ -22,5 +22,5 @@
22
22
  "react-dom": "^16.9.0"
23
23
  },
24
24
  "scripts": {},
25
- "gitHead": "55b71039999a60aae146343bbf30df306e2603c4"
25
+ "gitHead": "3818c24530f62b5bb9be7a2c6aa5428f13a17e0a"
26
26
  }
@@ -0,0 +1,152 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`MathInput snapshot renders 1`] = `
4
+ <div
5
+ className="className"
6
+ >
7
+ <WithStyles(Input)
8
+ innerRef={[Function]}
9
+ onBlur={[Function]}
10
+ onChange={[Function]}
11
+ onFocus={[Function]}
12
+ />
13
+ <div>
14
+ <WithStyles(KeyPad)
15
+ additionalKeys={Array []}
16
+ baseSet={
17
+ Array [
18
+ Array [
19
+ Object {
20
+ "category": "digit",
21
+ "label": "7",
22
+ "name": "seven",
23
+ "write": "7",
24
+ },
25
+ Object {
26
+ "category": "digit",
27
+ "label": "8",
28
+ "name": "eight",
29
+ "write": "8",
30
+ },
31
+ Object {
32
+ "category": "digit",
33
+ "label": "9",
34
+ "name": "nine",
35
+ "write": "9",
36
+ },
37
+ Object {
38
+ "category": "operators",
39
+ "command": "\\\\divide",
40
+ "label": "÷",
41
+ "name": "divide",
42
+ "otherNotation": "\\\\div",
43
+ },
44
+ ],
45
+ Array [
46
+ Object {
47
+ "category": "digit",
48
+ "label": "4",
49
+ "name": "four",
50
+ "write": "4",
51
+ },
52
+ Object {
53
+ "category": "digit",
54
+ "label": "5",
55
+ "name": "five",
56
+ "write": "5",
57
+ },
58
+ Object {
59
+ "category": "digit",
60
+ "label": "6",
61
+ "name": "six",
62
+ "write": "6",
63
+ },
64
+ Object {
65
+ "category": "operators",
66
+ "command": "\\\\times",
67
+ "label": "×",
68
+ "name": "multiply",
69
+ },
70
+ ],
71
+ Array [
72
+ Object {
73
+ "category": "digit",
74
+ "label": "1",
75
+ "name": "one",
76
+ "write": "1",
77
+ },
78
+ Object {
79
+ "category": "digit",
80
+ "label": "2",
81
+ "name": "two",
82
+ "write": "2",
83
+ },
84
+ Object {
85
+ "category": "digit",
86
+ "label": "3",
87
+ "name": "three",
88
+ "write": "3",
89
+ },
90
+ Object {
91
+ "category": "operators",
92
+ "label": "−",
93
+ "write": "−",
94
+ },
95
+ ],
96
+ Array [
97
+ Object {
98
+ "category": "digit",
99
+ "label": "0",
100
+ "name": "zero",
101
+ "write": "0",
102
+ },
103
+ Object {
104
+ "category": "digit",
105
+ "label": ".",
106
+ "name": "decimal-point",
107
+ "write": ".",
108
+ },
109
+ Object {
110
+ "category": "digit",
111
+ "label": ",",
112
+ "name": "comma",
113
+ "write": ",",
114
+ },
115
+ Object {
116
+ "category": "operators",
117
+ "label": "+",
118
+ "write": "+",
119
+ },
120
+ ],
121
+ Array [
122
+ Object {
123
+ "ariaLabel": "Move cursor left",
124
+ "category": "navigation",
125
+ "keystroke": "Left",
126
+ "label": "◀",
127
+ },
128
+ Object {
129
+ "ariaLabel": "Move cursor right",
130
+ "category": "navigation",
131
+ "keystroke": "Right",
132
+ "label": "▶",
133
+ },
134
+ Object {
135
+ "ariaLabel": "Delete",
136
+ "category": "edit",
137
+ "keystroke": "Backspace",
138
+ "label": "⌫",
139
+ },
140
+ Object {
141
+ "category": "operators",
142
+ "label": "=",
143
+ "write": "=",
144
+ },
145
+ ],
146
+ ]
147
+ }
148
+ onPress={[Function]}
149
+ />
150
+ </div>
151
+ </div>
152
+ `;