@pie-lib/math-toolbar 1.11.31-next.134 → 1.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.
- package/CHANGELOG.md +16 -0
- package/NEXT.CHANGELOG.json +1 -0
- package/lib/__tests__/editor-and-pad.test.js +37 -0
- package/lib/__tests__/index.test.js +41 -0
- package/lib/__tests__/math-preview.test.js +42 -0
- package/lib/done-button.js +1 -1
- package/lib/editor-and-pad.js +27 -105
- package/lib/index.js +17 -6
- package/lib/math-preview.js +104 -89
- package/lib/utils.js +21 -0
- package/package.json +4 -4
- package/src/__tests__/__snapshots__/editor-and-pad.test.js.snap +31 -0
- package/src/__tests__/__snapshots__/index.test.js.snap +30 -0
- package/src/__tests__/__snapshots__/math-preview.test.js.snap +23 -0
- package/src/__tests__/editor-and-pad.test.js +25 -0
- package/src/__tests__/index.test.js +28 -0
- package/src/__tests__/math-preview.test.js +31 -0
- package/src/editor-and-pad.jsx +22 -121
- package/src/index.jsx +13 -2
- package/src/math-preview.jsx +56 -82
- package/src/utils.js +11 -0
- package/lib/done-button.js.map +0 -1
- package/lib/editor-and-pad.js.map +0 -1
- package/lib/index.js.map +0 -1
- package/lib/math-preview.js.map +0 -1
package/lib/math-preview.js
CHANGED
|
@@ -7,45 +7,111 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports["default"] = exports.RawMathPreview = void 0;
|
|
9
9
|
|
|
10
|
-
var
|
|
10
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
11
|
+
|
|
12
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
13
|
+
|
|
14
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
15
|
+
|
|
16
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
17
|
+
|
|
18
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
19
|
+
|
|
20
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
21
|
|
|
12
22
|
var _react = _interopRequireDefault(require("react"));
|
|
13
23
|
|
|
14
24
|
var _classnames = _interopRequireDefault(require("classnames"));
|
|
15
25
|
|
|
16
|
-
var _get = _interopRequireDefault(require("lodash/get"));
|
|
17
|
-
|
|
18
26
|
var _debug = _interopRequireDefault(require("debug"));
|
|
19
27
|
|
|
20
|
-
var _styles = require("@material-ui/styles");
|
|
28
|
+
var _styles = require("@material-ui/core/styles");
|
|
21
29
|
|
|
22
30
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
23
31
|
|
|
24
32
|
var _mathInput = require("@pie-lib/math-input");
|
|
25
33
|
|
|
34
|
+
var _utils = require("./utils");
|
|
35
|
+
|
|
36
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
37
|
+
|
|
38
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
39
|
+
|
|
40
|
+
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); }; }
|
|
41
|
+
|
|
42
|
+
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; } }
|
|
43
|
+
|
|
44
|
+
var _mq$CommonMqStyles = _mathInput.mq.CommonMqStyles,
|
|
45
|
+
commonMqFontStyles = _mq$CommonMqStyles.commonMqFontStyles,
|
|
46
|
+
longdivStyles = _mq$CommonMqStyles.longdivStyles,
|
|
47
|
+
supsubStyles = _mq$CommonMqStyles.supsubStyles;
|
|
26
48
|
var log = (0, _debug["default"])('@pie-lib:math-toolbar:math-preview');
|
|
27
|
-
|
|
49
|
+
|
|
50
|
+
var RawMathPreview = /*#__PURE__*/function (_React$Component) {
|
|
51
|
+
(0, _inherits2["default"])(RawMathPreview, _React$Component);
|
|
52
|
+
|
|
53
|
+
var _super = _createSuper(RawMathPreview);
|
|
54
|
+
|
|
55
|
+
function RawMathPreview() {
|
|
56
|
+
(0, _classCallCheck2["default"])(this, RawMathPreview);
|
|
57
|
+
return _super.apply(this, arguments);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
(0, _createClass2["default"])(RawMathPreview, [{
|
|
61
|
+
key: "componentDidMount",
|
|
62
|
+
value: function componentDidMount() {
|
|
63
|
+
(0, _utils.markFractionBaseSuperscripts)();
|
|
64
|
+
}
|
|
65
|
+
}, {
|
|
66
|
+
key: "componentDidUpdate",
|
|
67
|
+
value: function componentDidUpdate(prevProps) {
|
|
68
|
+
// Re-run only if LaTeX changed
|
|
69
|
+
if (this.props.node.data.get('latex') !== prevProps.node.data.get('latex')) {
|
|
70
|
+
(0, _utils.markFractionBaseSuperscripts)();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}, {
|
|
74
|
+
key: "render",
|
|
75
|
+
value: function render() {
|
|
76
|
+
log('[render] data: ', this.props.node.data);
|
|
77
|
+
var latex = this.props.node.data.get('latex');
|
|
78
|
+
var _this$props = this.props,
|
|
79
|
+
classes = _this$props.classes,
|
|
80
|
+
isSelected = _this$props.isSelected,
|
|
81
|
+
onFocus = _this$props.onFocus,
|
|
82
|
+
onBlur = _this$props.onBlur;
|
|
83
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
84
|
+
className: (0, _classnames["default"])(classes.root, isSelected && classes.selected)
|
|
85
|
+
}, ' ', /*#__PURE__*/_react["default"].createElement("span", {
|
|
86
|
+
className: classes.insideOverlay
|
|
87
|
+
}), /*#__PURE__*/_react["default"].createElement(_mathInput.mq.Static, {
|
|
88
|
+
latex: latex,
|
|
89
|
+
onFocus: onFocus,
|
|
90
|
+
onBlur: onBlur
|
|
91
|
+
}));
|
|
92
|
+
}
|
|
93
|
+
}]);
|
|
94
|
+
return RawMathPreview;
|
|
95
|
+
}(_react["default"].Component);
|
|
96
|
+
|
|
97
|
+
exports.RawMathPreview = RawMathPreview;
|
|
98
|
+
(0, _defineProperty2["default"])(RawMathPreview, "propTypes", {
|
|
99
|
+
latex: _propTypes["default"].string,
|
|
100
|
+
node: _propTypes["default"].object,
|
|
101
|
+
classes: _propTypes["default"].object,
|
|
102
|
+
isSelected: _propTypes["default"].bool,
|
|
103
|
+
onFocus: _propTypes["default"].func,
|
|
104
|
+
onBlur: _propTypes["default"].func
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
var mp = function mp(theme) {
|
|
28
108
|
return {
|
|
29
|
-
root: {
|
|
109
|
+
root: _objectSpread(_objectSpread(_objectSpread({
|
|
30
110
|
display: 'inline-flex',
|
|
31
111
|
alignItems: 'center',
|
|
32
112
|
position: 'relative',
|
|
33
|
-
'& *':
|
|
34
|
-
|
|
35
|
-
'-webkit-font-smoothing': 'antialiased !important'
|
|
36
|
-
},
|
|
37
|
-
'& > .mq-math-mode > span > var': {
|
|
38
|
-
fontFamily: 'MJXZERO, MJXTEX-I !important'
|
|
39
|
-
},
|
|
40
|
-
'& > .mq-math-mode span var': {
|
|
41
|
-
fontFamily: 'MJXZERO, MJXTEX-I !important'
|
|
42
|
-
},
|
|
43
|
-
'& > .mq-math-mode .mq-nonSymbola': {
|
|
44
|
-
fontFamily: 'MJXZERO, MJXTEX-I !important'
|
|
45
|
-
},
|
|
46
|
-
'& > .mq-math-mode > span > var.mq-operator-name': {
|
|
47
|
-
fontFamily: 'MJXZERO, MJXTEX !important'
|
|
48
|
-
},
|
|
113
|
+
'& *': commonMqFontStyles
|
|
114
|
+
}, supsubStyles), longdivStyles), {}, {
|
|
49
115
|
'& > .mq-math-mode': {
|
|
50
116
|
border: 'solid 1px lightgrey'
|
|
51
117
|
},
|
|
@@ -75,23 +141,6 @@ var useStyles = (0, _styles.makeStyles)(function (theme) {
|
|
|
75
141
|
paddingBottom: '0 !important',
|
|
76
142
|
marginBottom: '-2px'
|
|
77
143
|
},
|
|
78
|
-
'& > .mq-math-mode sup.mq-nthroot': {
|
|
79
|
-
fontSize: '70.7% !important',
|
|
80
|
-
verticalAlign: '0.5em !important',
|
|
81
|
-
paddingRight: '0.15em'
|
|
82
|
-
},
|
|
83
|
-
'& > .mq-longdiv-inner': {
|
|
84
|
-
marginTop: '-1px',
|
|
85
|
-
marginLeft: '5px !important;',
|
|
86
|
-
'& > .mq-empty': {
|
|
87
|
-
padding: '0 !important',
|
|
88
|
-
marginLeft: '0px !important',
|
|
89
|
-
marginTop: '2px'
|
|
90
|
-
}
|
|
91
|
-
},
|
|
92
|
-
'& > .mq-math-mode .mq-longdiv': {
|
|
93
|
-
display: 'inline-flex !important'
|
|
94
|
-
},
|
|
95
144
|
'& > .mq-math-mode .mq-longdiv .mq-longdiv-inner .mq-empty': {
|
|
96
145
|
paddingTop: '6px !important',
|
|
97
146
|
paddingLeft: '4px !important'
|
|
@@ -99,9 +148,6 @@ var useStyles = (0, _styles.makeStyles)(function (theme) {
|
|
|
99
148
|
'& > .mq-math-mode .mq-longdiv .mq-longdiv-inner': {
|
|
100
149
|
marginLeft: '0 !important'
|
|
101
150
|
},
|
|
102
|
-
'& > .mq-math-mode .mq-supsub': {
|
|
103
|
-
fontSize: '70.7% !important'
|
|
104
|
-
},
|
|
105
151
|
'& > .mq-math-mode .mq-overarrow': {
|
|
106
152
|
fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important'
|
|
107
153
|
},
|
|
@@ -115,15 +161,6 @@ var useStyles = (0, _styles.makeStyles)(function (theme) {
|
|
|
115
161
|
marginTop: '-2px !important',
|
|
116
162
|
paddingTop: '5px !important'
|
|
117
163
|
},
|
|
118
|
-
'& > .mq-supsub ': {
|
|
119
|
-
fontSize: '70.7%'
|
|
120
|
-
},
|
|
121
|
-
'& > .mq-math-mode .mq-supsub.mq-sup-only': {
|
|
122
|
-
verticalAlign: '-0.1em !important',
|
|
123
|
-
'& .mq-sup': {
|
|
124
|
-
marginBottom: '0px !important'
|
|
125
|
-
}
|
|
126
|
-
},
|
|
127
164
|
'& .mq-overarrow-inner': {
|
|
128
165
|
paddingTop: '0 !important',
|
|
129
166
|
border: 'none !important'
|
|
@@ -142,9 +179,16 @@ var useStyles = (0, _styles.makeStyles)(function (theme) {
|
|
|
142
179
|
top: '-0.4em',
|
|
143
180
|
left: '-1px'
|
|
144
181
|
},
|
|
182
|
+
// NOTE: This workaround adds `!important` to enforce the correct positioning and styling
|
|
183
|
+
// of `.mq-overarrow.mq-arrow-both` elements in MathQuill. This ensures consistent display
|
|
184
|
+
// regardless of the order in which MathQuill is initialized on our websites.
|
|
185
|
+
//
|
|
186
|
+
// In the future, investigate why MathQuill scripts and styles are being initialized
|
|
187
|
+
// more than once and address the root cause to prevent potential conflicts and ensure
|
|
188
|
+
// optimal performance.
|
|
145
189
|
'&:after': {
|
|
146
190
|
top: '0px !important',
|
|
147
|
-
position: 'absolute',
|
|
191
|
+
position: 'absolute !important',
|
|
148
192
|
right: '-2px'
|
|
149
193
|
},
|
|
150
194
|
'&.mq-empty:after': {
|
|
@@ -169,10 +213,13 @@ var useStyles = (0, _styles.makeStyles)(function (theme) {
|
|
|
169
213
|
},
|
|
170
214
|
'& .mq-parallelogram': {
|
|
171
215
|
lineHeight: 0.85
|
|
216
|
+
},
|
|
217
|
+
'& span[data-prime="true"]': {
|
|
218
|
+
fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important'
|
|
172
219
|
}
|
|
173
|
-
},
|
|
220
|
+
}),
|
|
174
221
|
selected: {
|
|
175
|
-
border: "solid 1px ".concat(
|
|
222
|
+
border: "solid 1px ".concat(theme.palette.primary.main),
|
|
176
223
|
'& > .mq-math-mode': {
|
|
177
224
|
border: 'solid 0px lightgrey'
|
|
178
225
|
}
|
|
@@ -185,41 +232,9 @@ var useStyles = (0, _styles.makeStyles)(function (theme) {
|
|
|
185
232
|
top: 0
|
|
186
233
|
}
|
|
187
234
|
};
|
|
188
|
-
}
|
|
235
|
+
};
|
|
189
236
|
|
|
190
|
-
var
|
|
191
|
-
log('[render] data: ', props.node.data);
|
|
192
|
-
var latex = props.node.data.latex;
|
|
193
|
-
var isSelected = props.isSelected,
|
|
194
|
-
onFocus = props.onFocus,
|
|
195
|
-
onBlur = props.onBlur,
|
|
196
|
-
attributes = props.attributes,
|
|
197
|
-
children = props.children;
|
|
198
|
-
var classes = useStyles(props);
|
|
199
|
-
return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
|
|
200
|
-
className: (0, _classnames["default"])(classes.root, isSelected && classes.selected)
|
|
201
|
-
}, attributes, {
|
|
202
|
-
contentEditable: false,
|
|
203
|
-
ref: ref
|
|
204
|
-
}), children, " ", /*#__PURE__*/_react["default"].createElement("span", {
|
|
205
|
-
className: classes.insideOverlay
|
|
206
|
-
}), /*#__PURE__*/_react["default"].createElement(_mathInput.mq.Static, {
|
|
207
|
-
latex: latex,
|
|
208
|
-
onFocus: onFocus,
|
|
209
|
-
onBlur: onBlur
|
|
210
|
-
}));
|
|
211
|
-
});
|
|
237
|
+
var _default = (0, _styles.withStyles)(mp)(RawMathPreview);
|
|
212
238
|
|
|
213
|
-
exports.RawMathPreview = RawMathPreview;
|
|
214
|
-
RawMathPreview.propTypes = {
|
|
215
|
-
element: _propTypes["default"].object,
|
|
216
|
-
latex: _propTypes["default"].string,
|
|
217
|
-
node: _propTypes["default"].object,
|
|
218
|
-
classes: _propTypes["default"].object,
|
|
219
|
-
isSelected: _propTypes["default"].bool,
|
|
220
|
-
onFocus: _propTypes["default"].func,
|
|
221
|
-
onBlur: _propTypes["default"].func
|
|
222
|
-
};
|
|
223
|
-
var _default = RawMathPreview;
|
|
224
239
|
exports["default"] = _default;
|
|
225
|
-
//# sourceMappingURL=math-preview.js.map
|
|
240
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/math-preview.jsx"],"names":["mq","CommonMqStyles","commonMqFontStyles","longdivStyles","supsubStyles","log","RawMathPreview","prevProps","props","node","data","get","latex","classes","isSelected","onFocus","onBlur","root","selected","insideOverlay","React","Component","PropTypes","string","object","bool","func","mp","theme","display","alignItems","position","border","outline","boxShadow","borderRadius","paddingTop","verticalAlign","top","left","marginTop","padding","paddingBottom","marginBottom","paddingLeft","marginLeft","fontFamily","borderTop","minWidth","lineHeight","right","palette","primary","main","bottom"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAEA,yBAA4DA,cAAGC,cAA/D;AAAA,IAAQC,kBAAR,sBAAQA,kBAAR;AAAA,IAA4BC,aAA5B,sBAA4BA,aAA5B;AAAA,IAA2CC,YAA3C,sBAA2CA,YAA3C;AAEA,IAAMC,GAAG,GAAG,uBAAM,oCAAN,CAAZ;;IAEaC,c;;;;;;;;;;;;WAUX,6BAAoB;AAClB;AACD;;;WAED,4BAAmBC,SAAnB,EAA8B;AAC5B;AACA,UAAI,KAAKC,KAAL,CAAWC,IAAX,CAAgBC,IAAhB,CAAqBC,GAArB,CAAyB,OAAzB,MAAsCJ,SAAS,CAACE,IAAV,CAAeC,IAAf,CAAoBC,GAApB,CAAwB,OAAxB,CAA1C,EAA4E;AAC1E;AACD;AACF;;;WAED,kBAAS;AACPN,MAAAA,GAAG,CAAC,iBAAD,EAAoB,KAAKG,KAAL,CAAWC,IAAX,CAAgBC,IAApC,CAAH;AACA,UAAME,KAAK,GAAG,KAAKJ,KAAL,CAAWC,IAAX,CAAgBC,IAAhB,CAAqBC,GAArB,CAAyB,OAAzB,CAAd;AACA,wBAAiD,KAAKH,KAAtD;AAAA,UAAQK,OAAR,eAAQA,OAAR;AAAA,UAAiBC,UAAjB,eAAiBA,UAAjB;AAAA,UAA6BC,OAA7B,eAA6BA,OAA7B;AAAA,UAAsCC,MAAtC,eAAsCA,MAAtC;AACA,0BACE;AAAK,QAAA,SAAS,EAAE,4BAAWH,OAAO,CAACI,IAAnB,EAAyBH,UAAU,IAAID,OAAO,CAACK,QAA/C;AAAhB,SACG,GADH,eAEE;AAAM,QAAA,SAAS,EAAEL,OAAO,CAACM;AAAzB,QAFF,eAGE,gCAAC,aAAD,CAAI,MAAJ;AAAW,QAAA,KAAK,EAAEP,KAAlB;AAAyB,QAAA,OAAO,EAAEG,OAAlC;AAA2C,QAAA,MAAM,EAAEC;AAAnD,QAHF,CADF;AAOD;;;EAhCiCI,kBAAMC,S;;;iCAA7Bf,c,eACQ;AACjBM,EAAAA,KAAK,EAAEU,sBAAUC,MADA;AAEjBd,EAAAA,IAAI,EAAEa,sBAAUE,MAFC;AAGjBX,EAAAA,OAAO,EAAES,sBAAUE,MAHF;AAIjBV,EAAAA,UAAU,EAAEQ,sBAAUG,IAJL;AAKjBV,EAAAA,OAAO,EAAEO,sBAAUI,IALF;AAMjBV,EAAAA,MAAM,EAAEM,sBAAUI;AAND,C;;AAkCrB,IAAMC,EAAE,GAAG,SAALA,EAAK,CAACC,KAAD;AAAA,SAAY;AACrBX,IAAAA,IAAI;AACFY,MAAAA,OAAO,EAAE,aADP;AAEFC,MAAAA,UAAU,EAAE,QAFV;AAGFC,MAAAA,QAAQ,EAAE,UAHR;AAIF,aAAO7B;AAJL,OAKCE,YALD,GAMCD,aAND;AAOF,2BAAqB;AACnB6B,QAAAA,MAAM,EAAE;AADW,OAPnB;AAUF,yBAAmB;AACjBC,QAAAA,OAAO,EAAE,MADQ;AAEjBC,QAAAA,SAAS,EAAE,MAFM;AAGjBF,QAAAA,MAAM,EAAE,iBAHS;AAIjBG,QAAAA,YAAY,EAAE;AAJG,OAVjB;AAgBF,0CAAoC;AAClCC,QAAAA,UAAU,EAAE;AADsB,OAhBlC;AAmBF,wCAAkC;AAChCA,QAAAA,UAAU,EAAE;AADoB,OAnBhC;AAsBF,2CAAqC;AACnCC,QAAAA,aAAa,EAAE,qBADoB;AAEnCC,QAAAA,GAAG,EAAE,gBAF8B;AAGnCC,QAAAA,IAAI,EAAE;AAH6B,OAtBnC;AA2BF,2CAAqC;AACnCC,QAAAA,SAAS,EAAE,iBADwB;AAEnCC,QAAAA,OAAO,EAAE;AAF0B,OA3BnC;AA+BF,iEAA2D;AACzDA,QAAAA,OAAO,EAAE,oBADgD;AAEzDC,QAAAA,aAAa,EAAE,cAF0C;AAGzDC,QAAAA,YAAY,EAAE;AAH2C,OA/BzD;AAoCF,mEAA6D;AAC3DP,QAAAA,UAAU,EAAE,gBAD+C;AAE3DQ,QAAAA,WAAW,EAAE;AAF8C,OApC3D;AAwCF,yDAAmD;AACjDC,QAAAA,UAAU,EAAE;AADqC,OAxCjD;AA2CF,yCAAmC;AACjCC,QAAAA,UAAU,EAAE;AADqB,OA3CjC;AA8CF,qCAA+B;AAC7BT,QAAAA,aAAa,EAAE,gBADc;AAE7BI,QAAAA,OAAO,EAAE;AAFoB,OA9C7B;AAmDF,yCAAmC;AACjCM,QAAAA,SAAS,EAAE,cADsB;AAEjCF,QAAAA,UAAU,EAAE,QAFqB;AAGjCL,QAAAA,SAAS,EAAE,iBAHsB;AAIjCJ,QAAAA,UAAU,EAAE;AAJqB,OAnDjC;AA0DF,+BAAyB;AACvBA,QAAAA,UAAU,EAAE,cADW;AAEvBJ,QAAAA,MAAM,EAAE;AAFe,OA1DvB;AA8DF,yCAAmC;AACjCQ,QAAAA,SAAS,EAAE;AADsB,OA9DjC;AAiEF,uCAAiC;AAC/BF,QAAAA,GAAG,EAAE,OAD0B;AAE/BE,QAAAA,SAAS,EAAE,KAFoB;AAG/BQ,QAAAA,QAAQ,EAAE,QAHqB;AAI/B,eAAO;AACLC,UAAAA,UAAU,EAAE;AADP,SAJwB;AAO/B,oBAAY;AACVX,UAAAA,GAAG,EAAE,QADK;AAEVC,UAAAA,IAAI,EAAE;AAFI,SAPmB;AAW/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAW;AACTD,UAAAA,GAAG,EAAE,gBADI;AAETP,UAAAA,QAAQ,EAAE,qBAFD;AAGTmB,UAAAA,KAAK,EAAE;AAHE,SAlBoB;AAuB/B,4BAAoB;AAClBZ,UAAAA,GAAG,EAAE;AADa;AAvBW,OAjE/B;AA4FF,wCAAkC;AAChC,oBAAY;AACVA,UAAAA,GAAG,EAAE,QADK;AAEVY,UAAAA,KAAK,EAAE;AAFG;AADoB,OA5FhC;AAkGF,qCAA+B;AAC7BrB,QAAAA,OAAO,EAAE;AADoB,OAlG7B;AAqGF,oCAA8B;AAC5BA,QAAAA,OAAO,EAAE;AADmB,OArG5B;AAwGF,6BAAuB;AACrBkB,QAAAA,SAAS,EAAE,sBADU;AAErBX,QAAAA,UAAU,EAAE;AAFS,OAxGrB;AA4GF,6BAAuB;AACrBa,QAAAA,UAAU,EAAE;AADS,OA5GrB;AA+GF,mCAA6B;AAC3BH,QAAAA,UAAU,EAAE;AADe;AA/G3B,MADiB;AAoHrB5B,IAAAA,QAAQ,EAAE;AACRc,MAAAA,MAAM,sBAAeJ,KAAK,CAACuB,OAAN,CAAcC,OAAd,CAAsBC,IAArC,CADE;AAER,2BAAqB;AACnBrB,QAAAA,MAAM,EAAE;AADW;AAFb,KApHW;AA0HrBb,IAAAA,aAAa,EAAE;AACbY,MAAAA,QAAQ,EAAE,UADG;AAEbuB,MAAAA,MAAM,EAAE,CAFK;AAGbf,MAAAA,IAAI,EAAE,CAHO;AAIbW,MAAAA,KAAK,EAAE,CAJM;AAKbZ,MAAAA,GAAG,EAAE;AALQ;AA1HM,GAAZ;AAAA,CAAX;;eAmIe,wBAAWX,EAAX,EAAerB,cAAf,C","sourcesContent":["import React from 'react';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { withStyles } from '@material-ui/core/styles';\nimport PropTypes from 'prop-types';\nimport { mq } from '@pie-lib/math-input';\nimport { markFractionBaseSuperscripts } from './utils';\n\nconst { commonMqFontStyles, longdivStyles, supsubStyles } = mq.CommonMqStyles;\n\nconst log = debug('@pie-lib:math-toolbar:math-preview');\n\nexport class RawMathPreview extends React.Component {\n  static propTypes = {\n    latex: PropTypes.string,\n    node: PropTypes.object,\n    classes: PropTypes.object,\n    isSelected: PropTypes.bool,\n    onFocus: PropTypes.func,\n    onBlur: PropTypes.func,\n  };\n\n  componentDidMount() {\n    markFractionBaseSuperscripts();\n  }\n\n  componentDidUpdate(prevProps) {\n    // Re-run only if LaTeX changed\n    if (this.props.node.data.get('latex') !== prevProps.node.data.get('latex')) {\n      markFractionBaseSuperscripts();\n    }\n  }\n\n  render() {\n    log('[render] data: ', this.props.node.data);\n    const latex = this.props.node.data.get('latex');\n    const { classes, isSelected, onFocus, onBlur } = this.props;\n    return (\n      <div className={classNames(classes.root, isSelected && classes.selected)}>\n        {' '}\n        <span className={classes.insideOverlay} />\n        <mq.Static latex={latex} onFocus={onFocus} onBlur={onBlur} />\n      </div>\n    );\n  }\n}\n\nconst mp = (theme) => ({\n  root: {\n    display: 'inline-flex',\n    alignItems: 'center',\n    position: 'relative',\n    '& *': commonMqFontStyles,\n    ...supsubStyles,\n    ...longdivStyles,\n    '& > .mq-math-mode': {\n      border: 'solid 1px lightgrey',\n    },\n    '& > .mq-focused': {\n      outline: 'none',\n      boxShadow: 'none',\n      border: 'solid 1px black',\n      borderRadius: '0px',\n    },\n    '& > .mq-math-mode .mq-root-block': {\n      paddingTop: '7px !important',\n    },\n    '& > .mq-math-mode .mq-overarc ': {\n      paddingTop: '0.45em !important',\n    },\n    '& > .mq-math-mode .mq-sqrt-prefix': {\n      verticalAlign: 'baseline !important',\n      top: '1px !important',\n      left: '-0.1em !important',\n    },\n    '& > .mq-math-mode .mq-denominator': {\n      marginTop: '-5px !important',\n      padding: '0.5em 0.1em 0.1em !important',\n    },\n    '& > .mq-math-mode .mq-numerator, .mq-math-mode .mq-over': {\n      padding: '0 0.1em !important',\n      paddingBottom: '0 !important',\n      marginBottom: '-2px',\n    },\n    '& > .mq-math-mode .mq-longdiv .mq-longdiv-inner .mq-empty': {\n      paddingTop: '6px !important',\n      paddingLeft: '4px !important',\n    },\n    '& > .mq-math-mode .mq-longdiv .mq-longdiv-inner': {\n      marginLeft: '0 !important',\n    },\n    '& > .mq-math-mode .mq-overarrow': {\n      fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',\n    },\n    '& > .mq-math-mode .mq-paren': {\n      verticalAlign: 'top !important',\n      padding: '1px 0.1em !important',\n    },\n\n    '& > .mq-math-mode .mq-sqrt-stem': {\n      borderTop: '0.07em solid',\n      marginLeft: '-1.5px',\n      marginTop: '-2px !important',\n      paddingTop: '5px !important',\n    },\n\n    '& .mq-overarrow-inner': {\n      paddingTop: '0 !important',\n      border: 'none !important',\n    },\n    '& .mq-editable-field .mq-cursor': {\n      marginTop: '-15px !important',\n    },\n    '& .mq-overarrow.mq-arrow-both': {\n      top: '7.5px',\n      marginTop: '0px',\n      minWidth: '1.23em',\n      '& *': {\n        lineHeight: '1 !important',\n      },\n      '&:before': {\n        top: '-0.4em',\n        left: '-1px',\n      },\n      // NOTE: This workaround adds `!important` to enforce the correct positioning and styling\n      // of `.mq-overarrow.mq-arrow-both` elements in MathQuill. This ensures consistent display\n      // regardless of the order in which MathQuill is initialized on our websites.\n      //\n      // In the future, investigate why MathQuill scripts and styles are being initialized\n      // more than once and address the root cause to prevent potential conflicts and ensure\n      // optimal performance.\n      '&:after': {\n        top: '0px !important',\n        position: 'absolute !important',\n        right: '-2px',\n      },\n      '&.mq-empty:after': {\n        top: '-0.45em',\n      },\n    },\n    '& .mq-overarrow.mq-arrow-right': {\n      '&:before': {\n        top: '-0.4em',\n        right: '-1px',\n      },\n    },\n    '& .mq-overarrow-inner-right': {\n      display: 'none !important',\n    },\n    '& .mq-overarrow-inner-left': {\n      display: 'none !important',\n    },\n    '& .mq-longdiv-inner': {\n      borderTop: '1px solid !important',\n      paddingTop: '1.5px !important',\n    },\n    '& .mq-parallelogram': {\n      lineHeight: 0.85,\n    },\n    '& span[data-prime=\"true\"]': {\n      fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',\n    },\n  },\n  selected: {\n    border: `solid 1px ${theme.palette.primary.main}`,\n    '& > .mq-math-mode': {\n      border: 'solid 0px lightgrey',\n    },\n  },\n  insideOverlay: {\n    position: 'absolute',\n    bottom: 0,\n    left: 0,\n    right: 0,\n    top: 0,\n  },\n});\n\nexport default withStyles(mp)(RawMathPreview);\n"]}
|
package/lib/utils.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.markFractionBaseSuperscripts = void 0;
|
|
7
|
+
|
|
8
|
+
var markFractionBaseSuperscripts = function markFractionBaseSuperscripts() {
|
|
9
|
+
document.querySelectorAll('.mq-supsub.mq-sup-only').forEach(function (supsub) {
|
|
10
|
+
var prev = supsub.previousElementSibling;
|
|
11
|
+
|
|
12
|
+
if (prev && prev.classList.contains('mq-non-leaf') && prev.querySelector('.mq-fraction')) {
|
|
13
|
+
supsub.classList.add('mq-after-fraction-group');
|
|
14
|
+
} else {
|
|
15
|
+
supsub.classList.remove('mq-after-fraction-group');
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
exports.markFractionBaseSuperscripts = markFractionBaseSuperscripts;
|
|
21
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6WyJtYXJrRnJhY3Rpb25CYXNlU3VwZXJzY3JpcHRzIiwiZG9jdW1lbnQiLCJxdWVyeVNlbGVjdG9yQWxsIiwiZm9yRWFjaCIsInN1cHN1YiIsInByZXYiLCJwcmV2aW91c0VsZW1lbnRTaWJsaW5nIiwiY2xhc3NMaXN0IiwiY29udGFpbnMiLCJxdWVyeVNlbGVjdG9yIiwiYWRkIiwicmVtb3ZlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQU8sSUFBTUEsNEJBQTRCLEdBQUcsU0FBL0JBLDRCQUErQixHQUFNO0FBQ2hEQyxFQUFBQSxRQUFRLENBQUNDLGdCQUFULENBQTBCLHdCQUExQixFQUFvREMsT0FBcEQsQ0FBNEQsVUFBQ0MsTUFBRCxFQUFZO0FBQ3RFLFFBQU1DLElBQUksR0FBR0QsTUFBTSxDQUFDRSxzQkFBcEI7O0FBRUEsUUFBSUQsSUFBSSxJQUFJQSxJQUFJLENBQUNFLFNBQUwsQ0FBZUMsUUFBZixDQUF3QixhQUF4QixDQUFSLElBQWtESCxJQUFJLENBQUNJLGFBQUwsQ0FBbUIsY0FBbkIsQ0FBdEQsRUFBMEY7QUFDeEZMLE1BQUFBLE1BQU0sQ0FBQ0csU0FBUCxDQUFpQkcsR0FBakIsQ0FBcUIseUJBQXJCO0FBQ0QsS0FGRCxNQUVPO0FBQ0xOLE1BQUFBLE1BQU0sQ0FBQ0csU0FBUCxDQUFpQkksTUFBakIsQ0FBd0IseUJBQXhCO0FBQ0Q7QUFDRixHQVJEO0FBU0QsQ0FWTSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBtYXJrRnJhY3Rpb25CYXNlU3VwZXJzY3JpcHRzID0gKCkgPT4ge1xuICBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKCcubXEtc3Vwc3ViLm1xLXN1cC1vbmx5JykuZm9yRWFjaCgoc3Vwc3ViKSA9PiB7XG4gICAgY29uc3QgcHJldiA9IHN1cHN1Yi5wcmV2aW91c0VsZW1lbnRTaWJsaW5nO1xuXG4gICAgaWYgKHByZXYgJiYgcHJldi5jbGFzc0xpc3QuY29udGFpbnMoJ21xLW5vbi1sZWFmJykgJiYgcHJldi5xdWVyeVNlbGVjdG9yKCcubXEtZnJhY3Rpb24nKSkge1xuICAgICAgc3Vwc3ViLmNsYXNzTGlzdC5hZGQoJ21xLWFmdGVyLWZyYWN0aW9uLWdyb3VwJyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHN1cHN1Yi5jbGFzc0xpc3QucmVtb3ZlKCdtcS1hZnRlci1mcmFjdGlvbi1ncm91cCcpO1xuICAgIH1cbiAgfSk7XG59O1xuIl19
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"publishConfig": {
|
|
4
4
|
"access": "public"
|
|
5
5
|
},
|
|
6
|
-
"version": "1.
|
|
6
|
+
"version": "1.13.0-beta.0",
|
|
7
7
|
"description": "Math toolbar for editing math equations",
|
|
8
8
|
"keywords": [
|
|
9
9
|
"math",
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
"dependencies": {
|
|
20
20
|
"@material-ui/core": "^3.8.3",
|
|
21
21
|
"@material-ui/icons": "^3.0.2",
|
|
22
|
-
"@pie-lib/math-input": "^6.
|
|
22
|
+
"@pie-lib/math-input": "^6.13.0-beta.0",
|
|
23
23
|
"classnames": "^2.2.6",
|
|
24
24
|
"debug": "^4.1.1",
|
|
25
25
|
"keycode": "^2.2.0",
|
|
@@ -30,8 +30,8 @@
|
|
|
30
30
|
"react-dom": "^16.9.0"
|
|
31
31
|
},
|
|
32
32
|
"devDependencies": {
|
|
33
|
-
"@pie-lib/test-utils": "^0.
|
|
33
|
+
"@pie-lib/test-utils": "^0.4.0-beta.0"
|
|
34
34
|
},
|
|
35
35
|
"scripts": {},
|
|
36
|
-
"gitHead": "
|
|
36
|
+
"gitHead": "3818c24530f62b5bb9be7a2c6aa5428f13a17e0a"
|
|
37
37
|
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
+
|
|
3
|
+
exports[`snapshot renders 1`] = `
|
|
4
|
+
<div
|
|
5
|
+
className=""
|
|
6
|
+
>
|
|
7
|
+
<div
|
|
8
|
+
className=""
|
|
9
|
+
>
|
|
10
|
+
<div
|
|
11
|
+
className=""
|
|
12
|
+
>
|
|
13
|
+
<WithStyles(Input)
|
|
14
|
+
className=""
|
|
15
|
+
innerRef={[Function]}
|
|
16
|
+
onBlur={[Function]}
|
|
17
|
+
onChange={[Function]}
|
|
18
|
+
onFocus={[Function]}
|
|
19
|
+
/>
|
|
20
|
+
</div>
|
|
21
|
+
</div>
|
|
22
|
+
<hr />
|
|
23
|
+
<HorizontalKeypad
|
|
24
|
+
additionalKeys={Array []}
|
|
25
|
+
className=""
|
|
26
|
+
mode="scientific"
|
|
27
|
+
noDecimal={false}
|
|
28
|
+
onClick={[Function]}
|
|
29
|
+
/>
|
|
30
|
+
</div>
|
|
31
|
+
`;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
+
|
|
3
|
+
exports[`snapshot renders with DONE button if hideDoneButton is not defined 1`] = `
|
|
4
|
+
<div
|
|
5
|
+
className=""
|
|
6
|
+
>
|
|
7
|
+
<div />
|
|
8
|
+
<WithStyles(EditorAndPad)
|
|
9
|
+
classNames={Object {}}
|
|
10
|
+
controlledKeypad={true}
|
|
11
|
+
showKeypad={true}
|
|
12
|
+
/>
|
|
13
|
+
<WithStyles(RawDoneButton)
|
|
14
|
+
hideBackground={false}
|
|
15
|
+
/>
|
|
16
|
+
</div>
|
|
17
|
+
`;
|
|
18
|
+
|
|
19
|
+
exports[`snapshot renders without DONE button if hideDoneButton value is true 1`] = `
|
|
20
|
+
<div
|
|
21
|
+
className=""
|
|
22
|
+
>
|
|
23
|
+
<div />
|
|
24
|
+
<WithStyles(EditorAndPad)
|
|
25
|
+
classNames={Object {}}
|
|
26
|
+
controlledKeypad={true}
|
|
27
|
+
showKeypad={true}
|
|
28
|
+
/>
|
|
29
|
+
</div>
|
|
30
|
+
`;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
+
|
|
3
|
+
exports[`snapshot renders 1`] = `
|
|
4
|
+
<RawMathPreview
|
|
5
|
+
classes={
|
|
6
|
+
Object {
|
|
7
|
+
"insideOverlay": "RawMathPreview-insideOverlay-3",
|
|
8
|
+
"root": "RawMathPreview-root-1",
|
|
9
|
+
"selected": "RawMathPreview-selected-2",
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
isSelected={false}
|
|
13
|
+
node={
|
|
14
|
+
Object {
|
|
15
|
+
"data": Object {
|
|
16
|
+
"get": [MockFunction],
|
|
17
|
+
},
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
onBlur={[MockFunction]}
|
|
21
|
+
onFocus={[MockFunction]}
|
|
22
|
+
/>
|
|
23
|
+
`;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { EditorAndPad } from '../editor-and-pad';
|
|
2
|
+
import { shallow } from 'enzyme';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
|
|
5
|
+
describe('snapshot', () => {
|
|
6
|
+
let wrapper;
|
|
7
|
+
let onBlur = jest.fn();
|
|
8
|
+
|
|
9
|
+
beforeAll(() => {
|
|
10
|
+
wrapper = (extras) => {
|
|
11
|
+
const defaults = {
|
|
12
|
+
classes: {},
|
|
13
|
+
classNames: {},
|
|
14
|
+
onBlur,
|
|
15
|
+
};
|
|
16
|
+
const props = { ...defaults, ...extras };
|
|
17
|
+
|
|
18
|
+
return shallow(<EditorAndPad {...props} />);
|
|
19
|
+
};
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it('renders', () => {
|
|
23
|
+
expect(wrapper()).toMatchSnapshot();
|
|
24
|
+
});
|
|
25
|
+
});
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { RawPureToolbar } from '../index';
|
|
2
|
+
import { shallow } from 'enzyme';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
|
|
5
|
+
describe('snapshot', () => {
|
|
6
|
+
let wrapper;
|
|
7
|
+
|
|
8
|
+
beforeAll(() => {
|
|
9
|
+
wrapper = (extras) => {
|
|
10
|
+
const defaults = {
|
|
11
|
+
classes: {},
|
|
12
|
+
controlledKeypad: true,
|
|
13
|
+
showKeypad: true,
|
|
14
|
+
};
|
|
15
|
+
const props = { ...defaults, ...extras };
|
|
16
|
+
|
|
17
|
+
return shallow(<RawPureToolbar {...props} />);
|
|
18
|
+
};
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
it('renders with DONE button if hideDoneButton is not defined', () => {
|
|
22
|
+
expect(wrapper()).toMatchSnapshot();
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('renders without DONE button if hideDoneButton value is true', () => {
|
|
26
|
+
expect(wrapper({ hideDoneButton: true })).toMatchSnapshot();
|
|
27
|
+
});
|
|
28
|
+
});
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { shallow } from 'enzyme';
|
|
3
|
+
|
|
4
|
+
import MathPreview from '../math-preview';
|
|
5
|
+
|
|
6
|
+
describe('snapshot', () => {
|
|
7
|
+
let wrapper;
|
|
8
|
+
|
|
9
|
+
beforeAll(() => {
|
|
10
|
+
wrapper = (extras) => {
|
|
11
|
+
const defaults = {
|
|
12
|
+
node: {
|
|
13
|
+
data: {
|
|
14
|
+
get: jest.fn().mockReturnValue('sqrt(5)'),
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
classes: {},
|
|
18
|
+
isSelected: false,
|
|
19
|
+
onFocus: jest.fn(),
|
|
20
|
+
onBlur: jest.fn(),
|
|
21
|
+
};
|
|
22
|
+
const props = { ...defaults, ...extras };
|
|
23
|
+
|
|
24
|
+
return shallow(<MathPreview {...props} />);
|
|
25
|
+
};
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
it('renders', () => {
|
|
29
|
+
expect(wrapper()).toMatchSnapshot();
|
|
30
|
+
});
|
|
31
|
+
});
|