@pie-lib/math-input 6.11.4 → 6.12.1-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 (86) hide show
  1. package/CHANGELOG.md +54 -187
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/package.json +6 -2
  4. package/src/__tests__/__snapshots__/math-input-test.jsx.snap +152 -0
  5. package/src/__tests__/math-input-test.jsx +85 -0
  6. package/src/horizontal-keypad.jsx +14 -1
  7. package/src/index.jsx +1 -10
  8. package/src/keypad/__tests__/__snapshots__/index.test.jsx.snap +193 -0
  9. package/src/keypad/__tests__/index.test.jsx +24 -0
  10. package/src/keypad/__tests__/keys-layout.test.js +15 -0
  11. package/src/keypad/index.jsx +99 -15
  12. package/src/keys/__tests__/utils.test.js +57 -0
  13. package/src/keys/geometry.js +6 -2
  14. package/src/keys/grades.js +11 -0
  15. package/src/keys/log.js +1 -1
  16. package/src/mq/__tests__/__snapshots__/input.test.jsx.snap +9 -0
  17. package/src/mq/__tests__/input.test.jsx +92 -0
  18. package/src/mq/__tests__/static.test.jsx +57 -0
  19. package/src/mq/common-mq-styles.js +105 -0
  20. package/src/mq/index.js +2 -1
  21. package/src/mq/input.jsx +22 -9
  22. package/src/mq/static.jsx +142 -13
  23. package/src/updateSpans.js +15 -0
  24. package/README.md +0 -27
  25. package/lib/horizontal-keypad.js +0 -118
  26. package/lib/horizontal-keypad.js.map +0 -1
  27. package/lib/index.js +0 -80
  28. package/lib/index.js.map +0 -1
  29. package/lib/keypad/index.js +0 -441
  30. package/lib/keypad/index.js.map +0 -1
  31. package/lib/keypad/keys-layout.js +0 -34
  32. package/lib/keypad/keys-layout.js.map +0 -1
  33. package/lib/keys/basic-operators.js +0 -41
  34. package/lib/keys/basic-operators.js.map +0 -1
  35. package/lib/keys/chars.js +0 -17
  36. package/lib/keys/chars.js.map +0 -1
  37. package/lib/keys/comparison.js +0 -49
  38. package/lib/keys/comparison.js.map +0 -1
  39. package/lib/keys/constants.js +0 -43
  40. package/lib/keys/constants.js.map +0 -1
  41. package/lib/keys/digits.js +0 -53
  42. package/lib/keys/digits.js.map +0 -1
  43. package/lib/keys/edit.js +0 -17
  44. package/lib/keys/edit.js.map +0 -1
  45. package/lib/keys/exponent.js +0 -36
  46. package/lib/keys/exponent.js.map +0 -1
  47. package/lib/keys/fractions.js +0 -34
  48. package/lib/keys/fractions.js.map +0 -1
  49. package/lib/keys/geometry.js +0 -167
  50. package/lib/keys/geometry.js.map +0 -1
  51. package/lib/keys/grades.js +0 -283
  52. package/lib/keys/grades.js.map +0 -1
  53. package/lib/keys/index.js +0 -54
  54. package/lib/keys/index.js.map +0 -1
  55. package/lib/keys/log.js +0 -32
  56. package/lib/keys/log.js.map +0 -1
  57. package/lib/keys/logic.js +0 -23
  58. package/lib/keys/logic.js.map +0 -1
  59. package/lib/keys/matrices.js +0 -23
  60. package/lib/keys/matrices.js.map +0 -1
  61. package/lib/keys/misc.js +0 -74
  62. package/lib/keys/misc.js.map +0 -1
  63. package/lib/keys/navigation.js +0 -25
  64. package/lib/keys/navigation.js.map +0 -1
  65. package/lib/keys/operators.js +0 -18
  66. package/lib/keys/operators.js.map +0 -1
  67. package/lib/keys/statistics.js +0 -47
  68. package/lib/keys/statistics.js.map +0 -1
  69. package/lib/keys/sub-sup.js +0 -23
  70. package/lib/keys/sub-sup.js.map +0 -1
  71. package/lib/keys/trigonometry.js +0 -53
  72. package/lib/keys/trigonometry.js.map +0 -1
  73. package/lib/keys/utils.js +0 -120
  74. package/lib/keys/utils.js.map +0 -1
  75. package/lib/keys/vars.js +0 -29
  76. package/lib/keys/vars.js.map +0 -1
  77. package/lib/math-input.js +0 -192
  78. package/lib/math-input.js.map +0 -1
  79. package/lib/mq/custom-elements.js +0 -23
  80. package/lib/mq/custom-elements.js.map +0 -1
  81. package/lib/mq/index.js +0 -24
  82. package/lib/mq/index.js.map +0 -1
  83. package/lib/mq/input.js +0 -245
  84. package/lib/mq/input.js.map +0 -1
  85. package/lib/mq/static.js +0 -233
  86. package/lib/mq/static.js.map +0 -1
package/lib/mq/input.js DELETED
@@ -1,245 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = exports.Input = void 0;
9
-
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
22
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
23
-
24
- var _react = _interopRequireDefault(require("react"));
25
-
26
- var _propTypes = _interopRequireDefault(require("prop-types"));
27
-
28
- var _styles = require("@material-ui/core/styles");
29
-
30
- var _debug = _interopRequireDefault(require("debug"));
31
-
32
- var _classnames = _interopRequireDefault(require("classnames"));
33
-
34
- var _customElements = require("./custom-elements");
35
-
36
- var _mathquill = _interopRequireDefault(require("@pie-framework/mathquill"));
37
-
38
- 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); }; }
39
-
40
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
41
-
42
- var MQ;
43
-
44
- if (typeof window !== 'undefined') {
45
- MQ = _mathquill["default"].getInterface(2);
46
-
47
- if (MQ && MQ.registerEmbed) {
48
- (0, _customElements.registerLineBreak)(MQ);
49
- }
50
- }
51
-
52
- var log = (0, _debug["default"])('math-input:mq:input');
53
- /**
54
- * Wrapper for MathQuill MQ.MathField.
55
- */
56
-
57
- var Input = /*#__PURE__*/function (_React$Component) {
58
- (0, _inherits2["default"])(Input, _React$Component);
59
-
60
- var _super = _createSuper(Input);
61
-
62
- function Input() {
63
- var _this;
64
-
65
- (0, _classCallCheck2["default"])(this, Input);
66
-
67
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
68
- args[_key] = arguments[_key];
69
- }
70
-
71
- _this = _super.call.apply(_super, [this].concat(args));
72
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onInputEdit", function () {
73
- log('[onInputEdit] ...');
74
- var onChange = _this.props.onChange;
75
-
76
- if (!_this.mathField) {
77
- return;
78
- }
79
-
80
- if (onChange) {
81
- onChange(_this.mathField.latex());
82
- }
83
- });
84
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "refresh", function () {
85
- _this.blur();
86
-
87
- _this.focus();
88
- });
89
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onKeyPress", function (event) {
90
- var keys = Object.keys(_this.mathField.__controller.options);
91
-
92
- if (keys.indexOf('ignoreNextMousedown') < 0) {
93
- // It seems like the controller has the above handler as an option
94
- // when all the right events are set and everything works fine
95
- // this seems to work in all cases
96
- _this.refresh();
97
- }
98
-
99
- if (event.charCode === 13) {
100
- // if enter's pressed, we're going for a custom embedded element that'll
101
- // have a block display (empty div) - for a hacked line break using ccs
102
- // all because mathquill doesn't support a line break
103
- _this.write('\\embed{newLine}[]');
104
-
105
- _this.onInputEdit();
106
- }
107
- });
108
- return _this;
109
- }
110
-
111
- (0, _createClass2["default"])(Input, [{
112
- key: "componentDidMount",
113
- value: function componentDidMount() {
114
- if (!MQ) {
115
- throw new Error('MQ is not defined - but component has mounted?');
116
- }
117
-
118
- this.mathField = MQ.MathField(this.input, {
119
- handlers: {
120
- edit: this.onInputEdit.bind(this)
121
- }
122
- });
123
- this.updateLatex();
124
- }
125
- }, {
126
- key: "componentDidUpdate",
127
- value: function componentDidUpdate() {
128
- this.updateLatex();
129
- }
130
- }, {
131
- key: "updateLatex",
132
- value: function updateLatex() {
133
- if (!this.mathField) {
134
- return;
135
- }
136
-
137
- var latex = this.props.latex;
138
-
139
- if (latex) {
140
- this.mathField.latex(latex);
141
- }
142
- }
143
- }, {
144
- key: "clear",
145
- value: function clear() {
146
- this.mathField.latex('');
147
- return '';
148
- }
149
- }, {
150
- key: "blur",
151
- value: function blur() {
152
- log('blur mathfield');
153
- this.mathField.blur();
154
- }
155
- }, {
156
- key: "focus",
157
- value: function focus() {
158
- log('focus mathfield...');
159
- this.mathField.focus();
160
- }
161
- }, {
162
- key: "command",
163
- value: function command(v) {
164
- var _this2 = this;
165
-
166
- log('command: ', v);
167
-
168
- if (Array.isArray(v)) {
169
- v.forEach(function (vv) {
170
- _this2.mathField.cmd(vv);
171
- });
172
- } else {
173
- this.mathField.cmd(v);
174
- }
175
-
176
- this.mathField.focus();
177
- return this.mathField.latex();
178
- }
179
- }, {
180
- key: "keystroke",
181
- value: function keystroke(v) {
182
- this.mathField.keystroke(v);
183
- this.mathField.focus();
184
- return this.mathField.latex();
185
- }
186
- }, {
187
- key: "write",
188
- value: function write(v) {
189
- log('write: ', v);
190
- this.mathField.write(v);
191
- this.mathField.focus();
192
- return this.mathField.latex();
193
- }
194
- }, {
195
- key: "shouldComponentUpdate",
196
- value: function shouldComponentUpdate(nextProps) {
197
- log('next: ', nextProps.latex);
198
- log('current: ', this.mathField.latex());
199
- return nextProps.latex !== this.mathField.latex();
200
- }
201
- }, {
202
- key: "render",
203
- value: function render() {
204
- var _this3 = this;
205
-
206
- var _this$props = this.props,
207
- onClick = _this$props.onClick,
208
- onFocus = _this$props.onFocus,
209
- onBlur = _this$props.onBlur,
210
- classes = _this$props.classes,
211
- className = _this$props.className;
212
- return /*#__PURE__*/_react["default"].createElement("span", {
213
- className: (0, _classnames["default"])(classes.input, className),
214
- onKeyPress: this.onKeyPress,
215
- onClick: onClick,
216
- onFocus: onFocus,
217
- onBlur: onBlur,
218
- ref: function ref(r) {
219
- return _this3.input = r;
220
- }
221
- });
222
- }
223
- }]);
224
- return Input;
225
- }(_react["default"].Component);
226
-
227
- exports.Input = Input;
228
- (0, _defineProperty2["default"])(Input, "propTypes", {
229
- className: _propTypes["default"].string,
230
- classes: _propTypes["default"].object.isRequired,
231
- onClick: _propTypes["default"].func,
232
- onChange: _propTypes["default"].func,
233
- latex: _propTypes["default"].string,
234
- onFocus: _propTypes["default"].func,
235
- onBlur: _propTypes["default"].func
236
- });
237
-
238
- var styles = function styles() {
239
- return {};
240
- };
241
-
242
- var _default = (0, _styles.withStyles)(styles)(Input);
243
-
244
- exports["default"] = _default;
245
- //# sourceMappingURL=input.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/mq/input.jsx"],"names":["MQ","window","MathQuill","getInterface","registerEmbed","log","Input","onChange","props","mathField","latex","blur","focus","event","keys","Object","__controller","options","indexOf","refresh","charCode","write","onInputEdit","Error","MathField","input","handlers","edit","bind","updateLatex","v","Array","isArray","forEach","vv","cmd","keystroke","nextProps","onClick","onFocus","onBlur","classes","className","onKeyPress","r","React","Component","PropTypes","string","object","isRequired","func","styles"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport debug from 'debug';\nimport classNames from 'classnames';\nimport { registerLineBreak } from './custom-elements';\nimport MathQuill from '@pie-framework/mathquill';\n\nlet MQ;\nif (typeof window !== 'undefined') {\n MQ = MathQuill.getInterface(2);\n\n if (MQ && MQ.registerEmbed) {\n registerLineBreak(MQ);\n }\n}\n\nconst log = debug('math-input:mq:input');\n\n/**\n * Wrapper for MathQuill MQ.MathField.\n */\nexport class Input extends React.Component {\n static propTypes = {\n className: PropTypes.string,\n classes: PropTypes.object.isRequired,\n onClick: PropTypes.func,\n onChange: PropTypes.func,\n latex: PropTypes.string,\n onFocus: PropTypes.func,\n onBlur: PropTypes.func,\n };\n\n componentDidMount() {\n if (!MQ) {\n throw new Error('MQ is not defined - but component has mounted?');\n }\n\n this.mathField = MQ.MathField(this.input, {\n handlers: {\n edit: this.onInputEdit.bind(this),\n },\n });\n\n this.updateLatex();\n }\n\n componentDidUpdate() {\n this.updateLatex();\n }\n\n updateLatex() {\n if (!this.mathField) {\n return;\n }\n const { latex } = this.props;\n if (latex) {\n this.mathField.latex(latex);\n }\n }\n\n clear() {\n this.mathField.latex('');\n return '';\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 command(v) {\n log('command: ', v);\n if (Array.isArray(v)) {\n v.forEach((vv) => {\n this.mathField.cmd(vv);\n });\n } else {\n this.mathField.cmd(v);\n }\n this.mathField.focus();\n return this.mathField.latex();\n }\n\n keystroke(v) {\n this.mathField.keystroke(v);\n this.mathField.focus();\n return this.mathField.latex();\n }\n\n write(v) {\n log('write: ', v);\n this.mathField.write(v);\n this.mathField.focus();\n return this.mathField.latex();\n }\n\n onInputEdit = () => {\n log('[onInputEdit] ...');\n const { onChange } = this.props;\n if (!this.mathField) {\n return;\n }\n\n if (onChange) {\n onChange(this.mathField.latex());\n }\n };\n\n refresh = () => {\n this.blur();\n this.focus();\n };\n\n onKeyPress = (event) => {\n const keys = Object.keys(this.mathField.__controller.options);\n\n if (keys.indexOf('ignoreNextMousedown') < 0) {\n // It seems like the controller has the above handler as an option\n // when all the right events are set and everything works fine\n // this seems to work in all cases\n this.refresh();\n }\n\n if (event.charCode === 13) {\n // if enter's pressed, we're going for a custom embedded element that'll\n // have a block display (empty div) - for a hacked line break using ccs\n // all because mathquill doesn't support a line break\n this.write('\\\\embed{newLine}[]');\n this.onInputEdit();\n }\n };\n\n shouldComponentUpdate(nextProps) {\n log('next: ', nextProps.latex);\n log('current: ', this.mathField.latex());\n return nextProps.latex !== this.mathField.latex();\n }\n\n render() {\n const { onClick, onFocus, onBlur, classes, className } = this.props;\n\n return (\n <span\n className={classNames(classes.input, className)}\n onKeyPress={this.onKeyPress}\n onClick={onClick}\n onFocus={onFocus}\n onBlur={onBlur}\n ref={(r) => (this.input = r)}\n />\n );\n }\n}\n\nconst styles = () => ({});\n\nexport default withStyles(styles)(Input);\n"],"file":"input.js"}
package/lib/mq/static.js DELETED
@@ -1,233 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
-
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
22
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
23
-
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
- var _react = _interopRequireDefault(require("react"));
27
-
28
- var _debug = _interopRequireDefault(require("debug"));
29
-
30
- var _mathquill = _interopRequireDefault(require("@pie-framework/mathquill"));
31
-
32
- var _index = require("../index");
33
-
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
-
36
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
37
-
38
- var MQ;
39
-
40
- if (typeof window !== 'undefined') {
41
- MQ = _mathquill["default"].getInterface(2);
42
- }
43
-
44
- var log = (0, _debug["default"])('pie-lib:math-input:mq:static');
45
- var REGEX = /\\MathQuillMathField\[r\d*\]\{(.*?)\}/g;
46
- var WHITESPACE_REGEX = / /g;
47
-
48
- function stripSpaces() {
49
- var string = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
50
- return string.replace(WHITESPACE_REGEX, '');
51
- }
52
- /**
53
- * Wrapper for MathQuill MQ.MathField.
54
- */
55
-
56
-
57
- var Static = /*#__PURE__*/function (_React$Component) {
58
- (0, _inherits2["default"])(Static, _React$Component);
59
-
60
- var _super = _createSuper(Static);
61
-
62
- function Static() {
63
- var _this;
64
-
65
- (0, _classCallCheck2["default"])(this, Static);
66
-
67
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
68
- args[_key] = arguments[_key];
69
- }
70
-
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
- }
81
-
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);
88
-
89
- if (_this.props.setInput) {
90
- _this.props.setInput(innerField);
91
- }
92
-
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);
98
- }
99
- });
100
- return _this;
101
- }
102
-
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) {
119
- return;
120
- }
121
-
122
- var name = this.props.getFieldName(field, this.mathField.innerFields);
123
-
124
- if (this.props.onSubFieldChange) {
125
- // eslint-disable-next-line no-useless-escape
126
- var regexMatch = field.latex().match(/[0-9]\\ \\frac\{[^\{]*\}\{ \}/);
127
-
128
- if (this.input && regexMatch && regexMatch !== null && regexMatch !== void 0 && regexMatch.length) {
129
- try {
130
- field.__controller.cursor.insLeftOf(field.__controller.cursor.parent[-1].parent);
131
-
132
- field.el().dispatchEvent(new KeyboardEvent('keydown', {
133
- keyCode: 8
134
- }));
135
- } catch (e) {
136
- // eslint-disable-next-line no-console
137
- console.error(e.toString());
138
- }
139
- } else {
140
- this.props.onSubFieldChange(name, field.latex());
141
- }
142
- }
143
- }
144
- }, {
145
- key: "update",
146
- value: function update() {
147
- if (!MQ) {
148
- throw new Error('MQ is not defined - but component has mounted?');
149
- } // this.input.innerHTML = this.props.latex;
150
-
151
-
152
- if (!this.mathField) {
153
- this.mathField = MQ.StaticMath(this.input, {
154
- handlers: {
155
- edit: this.onInputEdit.bind(this)
156
- }
157
- });
158
- }
159
-
160
- try {
161
- this.mathField.parseLatex(this.props.latex);
162
- this.mathField.latex(this.props.latex);
163
- } catch (e) {
164
- // default latex if received has errors
165
- this.mathField.latex('\\MathQuillMathField[r1]{}');
166
- }
167
- }
168
- }, {
169
- key: "blur",
170
- value: function blur() {
171
- log('blur mathfield');
172
- this.mathField.blur();
173
- }
174
- }, {
175
- key: "focus",
176
- value: function focus() {
177
- log('focus mathfield...');
178
- this.mathField.focus();
179
- }
180
- }, {
181
- key: "shouldComponentUpdate",
182
- value: function shouldComponentUpdate(nextProps) {
183
- try {
184
- var parsedLatex = this.mathField.parseLatex(nextProps.latex);
185
- var stripped = stripSpaces(parsedLatex);
186
- var newFieldCount = (nextProps.latex.match(REGEX) || []).length;
187
- var out = stripped !== stripSpaces(this.mathField.latex().trim()) || newFieldCount !== Object.keys(this.mathField.innerFields).length / 2;
188
- log('[shouldComponentUpdate] ', out);
189
- return out;
190
- } catch (e) {
191
- // eslint-disable-next-line no-console
192
- console.warn('Error parsing latex:', e.message, 'skip update'); // eslint-disable-next-line no-console
193
-
194
- console.warn(e);
195
- return false;
196
- }
197
- }
198
- }, {
199
- key: "render",
200
- value: function render() {
201
- var _this2 = this;
202
-
203
- var _this$props = this.props,
204
- onBlur = _this$props.onBlur,
205
- className = _this$props.className;
206
- return /*#__PURE__*/_react["default"].createElement("span", {
207
- className: className,
208
- onFocus: this.onFocus,
209
- onBlur: onBlur,
210
- ref: function ref(r) {
211
- return _this2.input = r;
212
- }
213
- });
214
- }
215
- }]);
216
- return Static;
217
- }(_react["default"].Component);
218
-
219
- exports["default"] = Static;
220
- (0, _defineProperty2["default"])(Static, "propTypes", {
221
- latex: _propTypes["default"].string.isRequired,
222
- onFocus: _propTypes["default"].func,
223
- onBlur: _propTypes["default"].func,
224
- className: _propTypes["default"].string,
225
- getFieldName: _propTypes["default"].func,
226
- onSubFieldChange: _propTypes["default"].func,
227
- onSubFieldFocus: _propTypes["default"].func,
228
- setInput: _propTypes["default"].func
229
- });
230
- (0, _defineProperty2["default"])(Static, "defaultProps", {
231
- getFieldName: function getFieldName() {}
232
- });
233
- //# sourceMappingURL=static.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/mq/static.jsx"],"names":["MQ","window","MathQuill","getInterface","log","REGEX","WHITESPACE_REGEX","stripSpaces","string","replace","Static","e","rootBlock","target","parentElement","nextSibling","id","parseInt","getAttribute","innerField","mathField","innerFields","find","f","name","props","getFieldName","setInput","onSubFieldFocus","err","console","error","message","update","field","onSubFieldChange","regexMatch","latex","match","input","length","__controller","cursor","insLeftOf","parent","el","dispatchEvent","KeyboardEvent","keyCode","toString","Error","StaticMath","handlers","edit","onInputEdit","bind","parseLatex","blur","focus","nextProps","parsedLatex","stripped","newFieldCount","out","trim","Object","keys","warn","onBlur","className","onFocus","r","React","Component","PropTypes","isRequired","func"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;AAEA,IAAIA,EAAJ;;AACA,IAAI,OAAOC,MAAP,KAAkB,WAAtB,EAAmC;AACjCD,EAAAA,EAAE,GAAGE,sBAAUC,YAAV,CAAuB,CAAvB,CAAL;AACD;;AAED,IAAMC,GAAG,GAAG,uBAAM,8BAAN,CAAZ;AACA,IAAMC,KAAK,GAAG,wCAAd;AACA,IAAMC,gBAAgB,GAAG,IAAzB;;AAEA,SAASC,WAAT,GAAkC;AAAA,MAAbC,MAAa,uEAAJ,EAAI;AAChC,SAAOA,MAAM,CAACC,OAAP,CAAeH,gBAAf,EAAiC,EAAjC,CAAP;AACD;AAED;AACA;AACA;;;IACqBI,M;;;;;;;;;;;;;;;gGAuGT,UAACC,CAAD,EAAO;AACf,UAAI;AACF,YAAIC,SAAS,GAAGD,CAAC,CAACE,MAAF,CAASC,aAAT,CAAuBC,WAAvC;AACA,YAAIC,EAAE,GAAGC,QAAQ,CAACL,SAAS,CAACM,YAAV,CAAuB,oBAAvB,CAAD,EAA+C,EAA/C,CAAjB;;AAEA,YAAI,CAACF,EAAL,EAAS;AACPJ,UAAAA,SAAS,GAAGA,SAAS,CAACE,aAAtB;AACAE,UAAAA,EAAE,GAAGC,QAAQ,CAACL,SAAS,CAACM,YAAV,CAAuB,oBAAvB,CAAD,EAA+C,EAA/C,CAAb;AACD;;AAED,YAAMC,UAAU,GAAG,MAAKC,SAAL,CAAeC,WAAf,CAA2BC,IAA3B,CAAgC,UAACC,CAAD;AAAA,iBAAOA,CAAC,CAACP,EAAF,KAASA,EAAhB;AAAA,SAAhC,CAAnB;;AAEA,YAAIG,UAAJ,EAAgB;AACd,cAAMK,IAAI,GAAG,MAAKC,KAAL,CAAWC,YAAX,CAAwBP,UAAxB,EAAoC,MAAKC,SAAL,CAAeC,WAAnD,CAAb;;AACA,cAAI,MAAKI,KAAL,CAAWE,QAAf,EAAyB;AACvB,kBAAKF,KAAL,CAAWE,QAAX,CAAoBR,UAApB;AACD;;AACD,gBAAKM,KAAL,CAAWG,eAAX,CAA2BJ,IAA3B,EAAiCL,UAAjC;AACD;AACF,OAlBD,CAkBE,OAAOU,GAAP,EAAY;AACZ;AACAC,QAAAA,OAAO,CAACC,KAAR,CAAc,0BAAd,EAA0CF,GAAG,CAACG,OAA9C;AACD;AACF,K;;;;;;WA9GD,6BAAoB;AAClB,WAAKC,MAAL;AACA;AACD;;;WAED,8BAAqB;AACnB,WAAKA,MAAL;AACA;AACD;;;WAED,qBAAYC,KAAZ,EAAmB;AACjB,UAAI,CAAC,KAAKd,SAAV,EAAqB;AACnB;AACD;;AACD,UAAMI,IAAI,GAAG,KAAKC,KAAL,CAAWC,YAAX,CAAwBQ,KAAxB,EAA+B,KAAKd,SAAL,CAAeC,WAA9C,CAAb;;AAEA,UAAI,KAAKI,KAAL,CAAWU,gBAAf,EAAiC;AAC/B;AACA,YAAMC,UAAU,GAAGF,KAAK,CAACG,KAAN,GAAcC,KAAd,CAAoB,+BAApB,CAAnB;;AAEA,YAAI,KAAKC,KAAL,IAAcH,UAAd,IAA4BA,UAA5B,aAA4BA,UAA5B,eAA4BA,UAAU,CAAEI,MAA5C,EAAoD;AAClD,cAAI;AACFN,YAAAA,KAAK,CAACO,YAAN,CAAmBC,MAAnB,CAA0BC,SAA1B,CAAoCT,KAAK,CAACO,YAAN,CAAmBC,MAAnB,CAA0BE,MAA1B,CAAiC,CAAC,CAAlC,EAAqCA,MAAzE;;AACAV,YAAAA,KAAK,CAACW,EAAN,GAAWC,aAAX,CAAyB,IAAIC,aAAJ,CAAkB,SAAlB,EAA6B;AAAEC,cAAAA,OAAO,EAAE;AAAX,aAA7B,CAAzB;AACD,WAHD,CAGE,OAAOrC,CAAP,EAAU;AACV;AACAmB,YAAAA,OAAO,CAACC,KAAR,CAAcpB,CAAC,CAACsC,QAAF,EAAd;AACD;AACF,SARD,MAQO;AACL,eAAKxB,KAAL,CAAWU,gBAAX,CAA4BX,IAA5B,EAAkCU,KAAK,CAACG,KAAN,EAAlC;AACD;AACF;AACF;;;WAED,kBAAS;AACP,UAAI,CAACrC,EAAL,EAAS;AACP,cAAM,IAAIkD,KAAJ,CAAU,gDAAV,CAAN;AACD,OAHM,CAIP;;;AACA,UAAI,CAAC,KAAK9B,SAAV,EAAqB;AACnB,aAAKA,SAAL,GAAiBpB,EAAE,CAACmD,UAAH,CAAc,KAAKZ,KAAnB,EAA0B;AACzCa,UAAAA,QAAQ,EAAE;AACRC,YAAAA,IAAI,EAAE,KAAKC,WAAL,CAAiBC,IAAjB,CAAsB,IAAtB;AADE;AAD+B,SAA1B,CAAjB;AAKD;;AAED,UAAI;AACF,aAAKnC,SAAL,CAAeoC,UAAf,CAA0B,KAAK/B,KAAL,CAAWY,KAArC;AACA,aAAKjB,SAAL,CAAeiB,KAAf,CAAqB,KAAKZ,KAAL,CAAWY,KAAhC;AACD,OAHD,CAGE,OAAO1B,CAAP,EAAU;AACV;AACA,aAAKS,SAAL,CAAeiB,KAAf,CAAqB,4BAArB;AACD;AACF;;;WAED,gBAAO;AACLjC,MAAAA,GAAG,CAAC,gBAAD,CAAH;AACA,WAAKgB,SAAL,CAAeqC,IAAf;AACD;;;WAED,iBAAQ;AACNrD,MAAAA,GAAG,CAAC,oBAAD,CAAH;AACA,WAAKgB,SAAL,CAAesC,KAAf;AACD;;;WAED,+BAAsBC,SAAtB,EAAiC;AAC/B,UAAI;AACF,YAAMC,WAAW,GAAG,KAAKxC,SAAL,CAAeoC,UAAf,CAA0BG,SAAS,CAACtB,KAApC,CAApB;AACA,YAAMwB,QAAQ,GAAGtD,WAAW,CAACqD,WAAD,CAA5B;AACA,YAAME,aAAa,GAAG,CAACH,SAAS,CAACtB,KAAV,CAAgBC,KAAhB,CAAsBjC,KAAtB,KAAgC,EAAjC,EAAqCmC,MAA3D;AAEA,YAAMuB,GAAG,GACPF,QAAQ,KAAKtD,WAAW,CAAC,KAAKa,SAAL,CAAeiB,KAAf,GAAuB2B,IAAvB,EAAD,CAAxB,IACAF,aAAa,KAAKG,MAAM,CAACC,IAAP,CAAY,KAAK9C,SAAL,CAAeC,WAA3B,EAAwCmB,MAAxC,GAAiD,CAFrE;AAIApC,QAAAA,GAAG,CAAC,0BAAD,EAA6B2D,GAA7B,CAAH;AACA,eAAOA,GAAP;AACD,OAXD,CAWE,OAAOpD,CAAP,EAAU;AACV;AACAmB,QAAAA,OAAO,CAACqC,IAAR,CAAa,sBAAb,EAAqCxD,CAAC,CAACqB,OAAvC,EAAgD,aAAhD,EAFU,CAGV;;AACAF,QAAAA,OAAO,CAACqC,IAAR,CAAaxD,CAAb;AACA,eAAO,KAAP;AACD;AACF;;;WA2BD,kBAAS;AAAA;;AACP,wBAA8B,KAAKc,KAAnC;AAAA,UAAQ2C,MAAR,eAAQA,MAAR;AAAA,UAAgBC,SAAhB,eAAgBA,SAAhB;AAEA,0BAAO;AAAM,QAAA,SAAS,EAAEA,SAAjB;AAA4B,QAAA,OAAO,EAAE,KAAKC,OAA1C;AAAmD,QAAA,MAAM,EAAEF,MAA3D;AAAmE,QAAA,GAAG,EAAE,aAACG,CAAD;AAAA,iBAAQ,MAAI,CAAChC,KAAL,GAAagC,CAArB;AAAA;AAAxE,QAAP;AACD;;;EApIiCC,kBAAMC,S;;;iCAArB/D,M,eACA;AACjB2B,EAAAA,KAAK,EAAEqC,sBAAUlE,MAAV,CAAiBmE,UADP;AAEjBL,EAAAA,OAAO,EAAEI,sBAAUE,IAFF;AAGjBR,EAAAA,MAAM,EAAEM,sBAAUE,IAHD;AAIjBP,EAAAA,SAAS,EAAEK,sBAAUlE,MAJJ;AAKjBkB,EAAAA,YAAY,EAAEgD,sBAAUE,IALP;AAMjBzC,EAAAA,gBAAgB,EAAEuC,sBAAUE,IANX;AAOjBhD,EAAAA,eAAe,EAAE8C,sBAAUE,IAPV;AAQjBjD,EAAAA,QAAQ,EAAE+C,sBAAUE;AARH,C;iCADAlE,M,kBAYG;AACpBgB,EAAAA,YAAY,EAAE,wBAAM,CAAE;AADF,C","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport debug from 'debug';\nimport MathQuill from '@pie-framework/mathquill';\nimport { updateSpans } from '../index';\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\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 componentDidMount() {\n this.update();\n updateSpans();\n }\n\n componentDidUpdate() {\n this.update();\n updateSpans();\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.input && 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\n update() {\n if (!MQ) {\n throw new Error('MQ is not defined - but component has mounted?');\n }\n // this.input.innerHTML = this.props.latex;\n if (!this.mathField) {\n this.mathField = MQ.StaticMath(this.input, {\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={(r) => (this.input = r)} />;\n }\n}\n"],"file":"static.js"}