@pie-lib/math-input 6.11.5-next.0 → 6.12.0-beta.2
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.
- package/CHANGELOG.md +64 -181
- package/NEXT.CHANGELOG.json +1 -0
- package/package.json +5 -2
- package/src/__tests__/__snapshots__/math-input-test.jsx.snap +152 -0
- package/src/__tests__/math-input-test.jsx +85 -0
- package/src/horizontal-keypad.jsx +14 -1
- package/src/index.jsx +1 -10
- package/src/keypad/__tests__/__snapshots__/index.test.jsx.snap +193 -0
- package/src/keypad/__tests__/index.test.jsx +24 -0
- package/src/keypad/__tests__/keys-layout.test.js +15 -0
- package/src/keypad/index.jsx +99 -15
- package/src/keys/__tests__/utils.test.js +57 -0
- package/src/keys/geometry.js +6 -2
- package/src/keys/grades.js +11 -0
- package/src/keys/log.js +1 -1
- package/src/mq/__tests__/__snapshots__/input.test.jsx.snap +9 -0
- package/src/mq/__tests__/input.test.jsx +92 -0
- package/src/mq/__tests__/static.test.jsx +57 -0
- package/src/mq/common-mq-styles.js +105 -0
- package/src/mq/index.js +2 -1
- package/src/mq/input.jsx +22 -9
- package/src/mq/static.jsx +142 -13
- package/src/updateSpans.js +15 -0
- package/README.md +0 -27
- package/lib/horizontal-keypad.js +0 -118
- package/lib/horizontal-keypad.js.map +0 -1
- package/lib/index.js +0 -80
- package/lib/index.js.map +0 -1
- package/lib/keypad/index.js +0 -441
- package/lib/keypad/index.js.map +0 -1
- package/lib/keypad/keys-layout.js +0 -34
- package/lib/keypad/keys-layout.js.map +0 -1
- package/lib/keys/basic-operators.js +0 -41
- package/lib/keys/basic-operators.js.map +0 -1
- package/lib/keys/chars.js +0 -17
- package/lib/keys/chars.js.map +0 -1
- package/lib/keys/comparison.js +0 -49
- package/lib/keys/comparison.js.map +0 -1
- package/lib/keys/constants.js +0 -43
- package/lib/keys/constants.js.map +0 -1
- package/lib/keys/digits.js +0 -53
- package/lib/keys/digits.js.map +0 -1
- package/lib/keys/edit.js +0 -17
- package/lib/keys/edit.js.map +0 -1
- package/lib/keys/exponent.js +0 -36
- package/lib/keys/exponent.js.map +0 -1
- package/lib/keys/fractions.js +0 -34
- package/lib/keys/fractions.js.map +0 -1
- package/lib/keys/geometry.js +0 -167
- package/lib/keys/geometry.js.map +0 -1
- package/lib/keys/grades.js +0 -283
- package/lib/keys/grades.js.map +0 -1
- package/lib/keys/index.js +0 -54
- package/lib/keys/index.js.map +0 -1
- package/lib/keys/log.js +0 -32
- package/lib/keys/log.js.map +0 -1
- package/lib/keys/logic.js +0 -23
- package/lib/keys/logic.js.map +0 -1
- package/lib/keys/matrices.js +0 -23
- package/lib/keys/matrices.js.map +0 -1
- package/lib/keys/misc.js +0 -74
- package/lib/keys/misc.js.map +0 -1
- package/lib/keys/navigation.js +0 -25
- package/lib/keys/navigation.js.map +0 -1
- package/lib/keys/operators.js +0 -18
- package/lib/keys/operators.js.map +0 -1
- package/lib/keys/statistics.js +0 -47
- package/lib/keys/statistics.js.map +0 -1
- package/lib/keys/sub-sup.js +0 -23
- package/lib/keys/sub-sup.js.map +0 -1
- package/lib/keys/trigonometry.js +0 -53
- package/lib/keys/trigonometry.js.map +0 -1
- package/lib/keys/utils.js +0 -120
- package/lib/keys/utils.js.map +0 -1
- package/lib/keys/vars.js +0 -29
- package/lib/keys/vars.js.map +0 -1
- package/lib/math-input.js +0 -192
- package/lib/math-input.js.map +0 -1
- package/lib/mq/custom-elements.js +0 -23
- package/lib/mq/custom-elements.js.map +0 -1
- package/lib/mq/index.js +0 -24
- package/lib/mq/index.js.map +0 -1
- package/lib/mq/input.js +0 -245
- package/lib/mq/input.js.map +0 -1
- package/lib/mq/static.js +0 -233
- 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
|
package/lib/mq/input.js.map
DELETED
|
@@ -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
|
package/lib/mq/static.js.map
DELETED
|
@@ -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":"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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 '../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"}
|