@pie-lib/math-input 6.31.0-mui-update.0 → 6.31.1-beta-1

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 (80) hide show
  1. package/CHANGELOG.md +18 -6
  2. package/lib/__tests__/math-input-test.js +109 -0
  3. package/lib/horizontal-keypad.js +45 -17
  4. package/lib/index.js +26 -4
  5. package/lib/keypad/__tests__/index.test.js +41 -0
  6. package/lib/keypad/__tests__/keys-layout.test.js +15 -0
  7. package/lib/keypad/index.js +316 -237
  8. package/lib/keypad/keys-layout.js +13 -3
  9. package/lib/keys/__tests__/utils.test.js +60 -0
  10. package/lib/keys/basic-operators.js +14 -6
  11. package/lib/keys/chars.js +11 -6
  12. package/lib/keys/comparison.js +17 -7
  13. package/lib/keys/constants.js +11 -5
  14. package/lib/keys/digits.js +8 -2
  15. package/lib/keys/edit.js +5 -2
  16. package/lib/keys/exponent.js +11 -5
  17. package/lib/keys/fractions.js +9 -4
  18. package/lib/keys/geometry.js +55 -26
  19. package/lib/keys/grades.js +47 -11
  20. package/lib/keys/index.js +33 -14
  21. package/lib/keys/log.js +9 -4
  22. package/lib/keys/logic.js +7 -3
  23. package/lib/keys/matrices.js +7 -3
  24. package/lib/keys/misc.js +23 -11
  25. package/lib/keys/navigation.js +8 -3
  26. package/lib/keys/operators.js +5 -2
  27. package/lib/keys/statistics.js +13 -6
  28. package/lib/keys/sub-sup.js +7 -3
  29. package/lib/keys/trigonometry.js +15 -7
  30. package/lib/keys/utils.js +41 -8
  31. package/lib/keys/vars.js +9 -4
  32. package/lib/math-input.js +104 -53
  33. package/lib/mq/__tests__/input.test.js +119 -0
  34. package/lib/mq/__tests__/static.test.js +74 -0
  35. package/lib/mq/common-mq-styles.js +19 -8
  36. package/lib/mq/custom-elements.js +5 -2
  37. package/lib/mq/index.js +5 -1
  38. package/lib/mq/input.js +76 -23
  39. package/lib/mq/static.js +93 -32
  40. package/lib/updateSpans.js +6 -2
  41. package/package.json +7 -9
  42. package/src/keypad/index.jsx +153 -154
  43. package/src/math-input.jsx +44 -35
  44. package/src/mq/input.jsx +9 -9
  45. package/LICENSE.md +0 -5
  46. package/NEXT.CHANGELOG.json +0 -1
  47. package/lib/horizontal-keypad.js.map +0 -1
  48. package/lib/index.js.map +0 -1
  49. package/lib/keypad/index.js.map +0 -1
  50. package/lib/keypad/keys-layout.js.map +0 -1
  51. package/lib/keys/basic-operators.js.map +0 -1
  52. package/lib/keys/chars.js.map +0 -1
  53. package/lib/keys/comparison.js.map +0 -1
  54. package/lib/keys/constants.js.map +0 -1
  55. package/lib/keys/digits.js.map +0 -1
  56. package/lib/keys/edit.js.map +0 -1
  57. package/lib/keys/exponent.js.map +0 -1
  58. package/lib/keys/fractions.js.map +0 -1
  59. package/lib/keys/geometry.js.map +0 -1
  60. package/lib/keys/grades.js.map +0 -1
  61. package/lib/keys/index.js.map +0 -1
  62. package/lib/keys/log.js.map +0 -1
  63. package/lib/keys/logic.js.map +0 -1
  64. package/lib/keys/matrices.js.map +0 -1
  65. package/lib/keys/misc.js.map +0 -1
  66. package/lib/keys/navigation.js.map +0 -1
  67. package/lib/keys/operators.js.map +0 -1
  68. package/lib/keys/statistics.js.map +0 -1
  69. package/lib/keys/sub-sup.js.map +0 -1
  70. package/lib/keys/trigonometry.js.map +0 -1
  71. package/lib/keys/utils.js.map +0 -1
  72. package/lib/keys/vars.js.map +0 -1
  73. package/lib/math-input.js.map +0 -1
  74. package/lib/mq/common-mq-styles.js.map +0 -1
  75. package/lib/mq/custom-elements.js.map +0 -1
  76. package/lib/mq/index.js.map +0 -1
  77. package/lib/mq/input.js.map +0 -1
  78. package/lib/mq/static.js.map +0 -1
  79. package/lib/shared/constants.js +0 -13
  80. package/lib/updateSpans.js.map +0 -1
@@ -1,162 +1,191 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  var _typeof = require("@babel/runtime/helpers/typeof");
6
+
5
7
  Object.defineProperty(exports, "__esModule", {
6
8
  value: true
7
9
  });
8
10
  exports["default"] = exports.KeyPad = void 0;
11
+
9
12
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
+
10
14
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
+
11
16
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
17
+
12
18
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
19
+
20
+ var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
21
+
22
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
23
+
13
24
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
25
+
14
26
  var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
15
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
27
+
16
28
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
29
+
17
30
  var _react = _interopRequireDefault(require("react"));
31
+
18
32
  var _propTypes = _interopRequireDefault(require("prop-types"));
19
- var _Button = _interopRequireDefault(require("@mui/material/Button"));
20
- var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
21
- var _styles = require("@mui/material/styles");
33
+
34
+ var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
35
+
36
+ var _IconButton = _interopRequireDefault(require("@material-ui/core/IconButton"));
37
+
38
+ var _styles = require("@material-ui/core/styles");
39
+
22
40
  var _classnames = _interopRequireDefault(require("classnames"));
41
+
42
+ var _colorManipulator = require("@material-ui/core/styles/colorManipulator");
43
+
44
+ var _green = _interopRequireDefault(require("@material-ui/core/colors/green"));
45
+
23
46
  var _debug = _interopRequireDefault(require("debug"));
47
+
24
48
  var _lodash = _interopRequireDefault(require("lodash"));
49
+
25
50
  var _mathquill = _interopRequireDefault(require("@pie-framework/mathquill"));
51
+
26
52
  var mq = _interopRequireWildcard(require("../mq"));
53
+
27
54
  var _keys = require("../keys");
28
- var _constants = _interopRequireDefault(require("./../shared/constants"));
55
+
29
56
  var _commonMqStyles = require("../mq/common-mq-styles");
57
+
30
58
  var _keysLayout = require("./keys-layout");
31
- var _colors = require("@mui/material/colors");
32
- function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
33
- function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
34
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
35
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
36
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
59
+
60
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
61
+
62
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
63
+
64
+ 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; }
65
+
66
+ 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; }
67
+
68
+ 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); }; }
69
+
70
+ 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; } }
71
+
37
72
  var log = (0, _debug["default"])('pie-lib:math-inline:keypad');
38
- var StyledLatexButton = (0, _styles.styled)(_Button["default"])(function (_ref) {
39
- var theme = _ref.theme;
73
+ var LatexButton = (0, _styles.withStyles)(function (theme) {
40
74
  return {
41
- textTransform: 'none',
42
- padding: 0,
43
- margin: 0,
44
- fontSize: '110% !important'
45
- };
46
- });
47
- var LatexButtonContent = (0, _styles.styled)(mq.Static)(function (_ref2) {
48
- var theme = _ref2.theme,
49
- latex = _ref2.latex;
50
- var baseStyles = {
51
- pointerEvents: 'none',
52
- textTransform: 'none !important',
53
- '& .mq-scaled.mq-sqrt-prefix': {
54
- transform: 'scale(1, 0.9) !important'
55
- },
56
- '& .mq-sup-only .mq-sup': {
57
- marginBottom: '0.9px !important'
75
+ root: {
76
+ textTransform: 'none',
77
+ padding: 0,
78
+ margin: 0,
79
+ fontSize: '110% !important'
58
80
  },
59
- '& .mq-empty': {
60
- backgroundColor: "".concat((0, _styles.alpha)(theme.palette.secondary.main, 0.4), " !important")
61
- },
62
- '& .mq-overline .mq-overline-inner': {
63
- borderTop: '2px solid black'
64
- },
65
- '& .mq-non-leaf.mq-overline': {
66
- borderTop: 'none !important'
67
- },
68
- '& .mq-overarrow': {
69
- width: '30px',
70
- marginTop: '0 !important',
71
- borderTop: '2px solid black',
72
- fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',
73
- '&.mq-arrow-both': {
74
- top: '0px !important',
75
- '& *': {
76
- lineHeight: '1 !important',
77
- borderTop: 'none !important'
81
+ latexButton: {
82
+ pointerEvents: 'none',
83
+ textTransform: 'none !important',
84
+ '& .mq-scaled.mq-sqrt-prefix': {
85
+ transform: 'scale(1, 0.9) !important'
86
+ },
87
+ '& .mq-sup-only .mq-sup': {
88
+ marginBottom: '0.9px !important'
89
+ },
90
+ '& .mq-empty': {
91
+ backgroundColor: "".concat((0, _colorManipulator.fade)(theme.palette.secondary.main, 0.4), " !important")
92
+ },
93
+ '& .mq-overline .mq-overline-inner': {
94
+ borderTop: '2px solid black'
95
+ },
96
+ '& .mq-non-leaf.mq-overline': {
97
+ borderTop: 'none !important' // fixing PD-4873 - in OT, it has border-top 1px and adds extra line
98
+
99
+ },
100
+ '& .mq-overarrow': {
101
+ width: '30px',
102
+ marginTop: '0 !important',
103
+ borderTop: '2px solid black',
104
+ fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',
105
+ '&.mq-arrow-both': {
106
+ top: '0px !important',
107
+ '& *': {
108
+ lineHeight: '1 !important',
109
+ borderTop: 'none !important' // fixing PD-4873 - in OT, it has border-top 1px and adds extra line,
110
+
111
+ },
112
+ '&:before': {
113
+ fontSize: '80%',
114
+ left: 'calc(-13%) !important',
115
+ top: '-0.31em !important'
116
+ },
117
+ '&:after': {
118
+ fontSize: '80% !important',
119
+ right: 'calc(-13%) !important',
120
+ top: '-1.5em'
121
+ },
122
+ '&.mq-empty:before': {
123
+ fontSize: '80%',
124
+ left: 'calc(-13%)',
125
+ top: '-0.26em'
126
+ },
127
+ '&.mq-empty:after': {
128
+ fontSize: '80%',
129
+ right: 'calc(-13%)',
130
+ top: '-0.26em'
131
+ },
132
+ '&.mq-empty': {
133
+ minHeight: '1.4em'
134
+ }
78
135
  },
79
- '&:before': {
136
+ '&.mq-arrow-right:before': {
80
137
  fontSize: '80%',
81
- left: 'calc(-13%) !important',
82
- top: '-0.31em !important'
83
- },
84
- '&:after': {
85
- fontSize: '80% !important',
86
138
  right: 'calc(-13%) !important',
87
- top: '-1.5em'
139
+ top: '-0.26em !important'
88
140
  },
89
- '&.mq-empty:before': {
90
- fontSize: '80%',
91
- left: 'calc(-13%)',
92
- top: '-0.26em'
93
- },
94
- '&.mq-empty:after': {
95
- fontSize: '80%',
96
- right: 'calc(-13%)',
97
- top: '-0.26em'
141
+ '& .mq-overarrow-inner': {
142
+ border: 'none !important'
98
143
  },
99
- '&.mq-empty': {
100
- minHeight: '1.4em'
144
+ '& .mq-overarrow-inner .mq-overarrow-inner-right': {
145
+ display: 'none !important'
101
146
  }
102
147
  },
103
- '&.mq-arrow-right:before': {
104
- fontSize: '80%',
105
- right: 'calc(-13%) !important',
106
- top: '-0.26em !important'
148
+ '& .mq-root-block': {
149
+ padding: '5px !important'
107
150
  },
108
- '& .mq-overarrow-inner': {
109
- border: 'none !important'
151
+ '& .mq-overarrow.mq-arrow-both.mq-empty:after': {
152
+ right: '-6px',
153
+ fontSize: '80% !important',
154
+ top: '-3px'
110
155
  },
111
- '& .mq-overarrow-inner .mq-overarrow-inner-right': {
112
- display: 'none !important'
113
- }
114
- },
115
- '& .mq-root-block': {
116
- padding: '5px !important'
117
- },
118
- '& .mq-overarrow.mq-arrow-both.mq-empty:after': {
119
- right: '-6px',
120
- fontSize: '80% !important',
121
- top: '-3px'
122
- },
123
- '& .mq-overarrow.mq-arrow-right.mq-empty:before': {
124
- right: '-5px',
125
- fontSize: '80% !important',
126
- top: '-3px'
127
- },
128
- '& .mq-overarrow.mq-arrow-both.mq-empty:before': {
129
- left: '-6px',
130
- fontSize: '80% !important',
131
- top: '-3px'
132
- },
133
- '& .mq-longdiv-inner': {
134
- borderTop: '1px solid !important',
135
- paddingTop: '1.5px !important'
136
- },
137
- '& .mq-parallelogram': {
138
- lineHeight: 0.85
139
- },
140
- '& .mq-overarc': {
141
- borderTop: '2px solid black !important',
142
- '& .mq-overline': {
143
- borderTop: 'none !important'
156
+ '& .mq-overarrow.mq-arrow-right.mq-empty:before': {
157
+ right: '-5px',
158
+ fontSize: '80% !important',
159
+ top: '-3px'
144
160
  },
145
- '& .mq-overline-inner': {
146
- borderTop: 'none !important',
147
- paddingTop: '0 !important'
148
- }
149
- }
150
- };
161
+ '& .mq-overarrow.mq-arrow-both.mq-empty:before': {
162
+ left: '-6px',
163
+ fontSize: '80% !important',
164
+ top: '-3px'
165
+ },
166
+ '& .mq-longdiv-inner': {
167
+ borderTop: '1px solid !important',
168
+ paddingTop: '1.5px !important'
169
+ },
170
+ '& .mq-parallelogram': {
171
+ lineHeight: 0.85
172
+ },
173
+ '& .mq-overarc': {
174
+ borderTop: '2px solid black !important',
175
+ '& .mq-overline': {
176
+ borderTop: 'none !important' // fixing PD-4873 - in OT, it has border-top 1px and adds extra line
151
177
 
152
- // Add specific styles based on latex content
153
- if (latex === '\\parallel') {
154
- return _objectSpread(_objectSpread({}, baseStyles), {}, {
178
+ },
179
+ '& .mq-overline-inner': {
180
+ borderTop: 'none !important',
181
+ paddingTop: '0 !important'
182
+ }
183
+ }
184
+ },
185
+ parallelButton: {
155
186
  fontStyle: 'italic !important'
156
- });
157
- }
158
- if (latex === '\\overleftrightarrow{\\overline{}}') {
159
- return _objectSpread(_objectSpread({}, baseStyles), {}, {
187
+ },
188
+ leftRightArrowButton: {
160
189
  '& .mq-overarrow.mq-arrow-both': {
161
190
  '& .mq-overline-inner': {
162
191
  borderTop: 'none !important',
@@ -167,13 +196,22 @@ var LatexButtonContent = (0, _styles.styled)(mq.Static)(function (_ref2) {
167
196
  top: '0px !important'
168
197
  }
169
198
  }
170
- });
199
+ }
200
+ };
201
+ })(function (props) {
202
+ var buttonClass;
203
+
204
+ if (props.latex === '\\parallel') {
205
+ buttonClass = (0, _classnames["default"])(props.classes.latexButton, props.mqClassName, props.classes.parallelButton);
206
+ } else if (props.latex === '\\overleftrightarrow{\\overline{}}') {
207
+ buttonClass = (0, _classnames["default"])(props.classes.latexButton, props.mqClassName, props.classes.leftRightArrowButton);
208
+ } else {
209
+ buttonClass = (0, _classnames["default"])(props.classes.latexButton, props.mqClassName);
171
210
  }
172
- return baseStyles;
173
- });
174
- var LatexButton = function LatexButton(props) {
211
+
175
212
  try {
176
213
  var MQ = _mathquill["default"].getInterface(2);
214
+
177
215
  var span = document.createElement('span');
178
216
  span.innerHTML = '';
179
217
  var mathField = MQ.StaticMath(span);
@@ -183,14 +221,17 @@ var LatexButton = function LatexButton(props) {
183
221
  // received latex has errors - do not create button
184
222
  return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null);
185
223
  }
186
- return /*#__PURE__*/_react["default"].createElement(StyledLatexButton, {
187
- className: props.className,
224
+
225
+ return /*#__PURE__*/_react["default"].createElement(_Button["default"], {
226
+ className: (0, _classnames["default"])(props.classes.root, props.className),
188
227
  onClick: props.onClick,
189
228
  "aria-label": props.ariaLabel
190
- }, /*#__PURE__*/_react["default"].createElement(LatexButtonContent, {
229
+ }, /*#__PURE__*/_react["default"].createElement(mq.Static, {
230
+ className: buttonClass,
191
231
  latex: props.latex
192
232
  }));
193
- };
233
+ });
234
+
194
235
  var createCustomLayout = function createCustomLayout(layoutObj) {
195
236
  if (layoutObj) {
196
237
  return {
@@ -199,130 +240,72 @@ var createCustomLayout = function createCustomLayout(layoutObj) {
199
240
  gridAutoFlow: 'initial'
200
241
  };
201
242
  }
243
+
202
244
  return {};
203
245
  };
204
- var KeyPadContainer = (0, _styles.styled)('div')(function (_ref3) {
205
- var theme = _ref3.theme;
206
- return _objectSpread(_objectSpread({}, _commonMqStyles.commonMqKeyboardStyles), {}, {
207
- width: '100%',
208
- display: 'grid',
209
- gridTemplateRows: 'repeat(5, minmax(40px, 60px))',
210
- gridRowGap: '0px',
211
- gridColumnGap: '0px',
212
- gridAutoFlow: 'column',
213
- '&.character': {
214
- textTransform: 'initial !important',
215
- gridTemplateRows: 'repeat(5, minmax(40px, 50px)) !important'
216
- },
217
- '&.language': {
218
- gridTemplateRows: 'repeat(4, minmax(40px, 50px)) !important',
219
- '& *': {
220
- fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important'
221
- }
222
- }
223
- });
224
- });
225
- var StyledButton = (0, _styles.styled)(_Button["default"])(function (_ref4) {
226
- var theme = _ref4.theme,
227
- category = _ref4.category,
228
- isDelete = _ref4.isDelete,
229
- isComma = _ref4.isComma,
230
- isDot = _ref4.isDot;
231
- return _objectSpread({
232
- minWidth: 'auto',
233
- fontSize: isComma || isDot ? '200% !important' : '140% !important',
234
- lineHeight: isComma || isDot ? '100%' : 'normal',
235
- backgroundColor: category === 'operators' ? (0, _styles.lighten)(theme.palette.secondary.light, 0.5) : category === 'comparison' ? (0, _styles.lighten)(_colors.green[500], 0.5) : (0, _styles.lighten)(theme.palette.primary.light, 0.5),
236
- '&:hover': {
237
- backgroundColor: category === 'operators' ? (0, _styles.lighten)(theme.palette.secondary.light, 0.7) : category === 'comparison' ? (0, _styles.lighten)(_colors.green[500], 0.7) : (0, _styles.lighten)(theme.palette.primary.light, 0.7)
238
- },
239
- borderRadius: 0
240
- }, isDelete && {
241
- '& > span': {
242
- fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important'
243
- }
244
- });
245
- });
246
- var StyledLatexButtonWrapper = (0, _styles.styled)(_Button["default"])(function (_ref5) {
247
- var theme = _ref5.theme,
248
- category = _ref5.category;
249
- return {
250
- minWidth: 'auto',
251
- borderRadius: 0,
252
- backgroundColor: category === 'operators' ? (0, _styles.lighten)(theme.palette.secondary.light, 0.5) : category === 'comparison' ? (0, _styles.lighten)(_colors.green[500], 0.5) : (0, _styles.lighten)(theme.palette.primary.light, 0.5),
253
- '&:hover': {
254
- backgroundColor: category === 'operators' ? (0, _styles.lighten)(theme.palette.secondary.light, 0.7) : category === 'comparison' ? (0, _styles.lighten)(_colors.green[500], 0.7) : (0, _styles.lighten)(theme.palette.primary.light, 0.7)
255
- }
256
- };
257
- });
258
- var StyledIconButton = (0, _styles.styled)(_IconButton["default"])(function (_ref6) {
259
- var theme = _ref6.theme,
260
- category = _ref6.category;
261
- return {
262
- minWidth: 'auto',
263
- backgroundColor: category === 'operators' ? (0, _styles.lighten)(theme.palette.secondary.light, 0.5) : category === 'comparison' ? (0, _styles.lighten)(_colors.green[500], 0.5) : (0, _styles.lighten)(theme.palette.primary.light, 0.5),
264
- '&:hover': {
265
- backgroundColor: category === 'operators' ? (0, _styles.lighten)(theme.palette.secondary.light, 0.7) : category === 'comparison' ? (0, _styles.lighten)(_colors.green[500], 0.7) : (0, _styles.lighten)(theme.palette.primary.light, 0.7)
266
- },
267
- borderRadius: 0,
268
- '& .icon': {
269
- height: '30px'
270
- }
271
- };
272
- });
273
- var KeyPad = exports.KeyPad = /*#__PURE__*/function (_React$Component) {
246
+
247
+ var KeyPad = /*#__PURE__*/function (_React$Component) {
248
+ (0, _inherits2["default"])(KeyPad, _React$Component);
249
+
250
+ var _super = _createSuper(KeyPad);
251
+
274
252
  function KeyPad(props) {
275
253
  var _this;
254
+
276
255
  (0, _classCallCheck2["default"])(this, KeyPad);
277
- _this = _callSuper(this, KeyPad, [props]);
278
- (0, _defineProperty2["default"])(_this, "handleKeypadInteraction", function () {
256
+ _this = _super.call(this, props);
257
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleKeypadInteraction", function () {
279
258
  // Check if the setKeypadInteraction prop is available, which is used for both
280
259
  // the language keypad and the special characters keypad
281
260
  if (_this.props.setKeypadInteraction) {
282
261
  _this.props.setKeypadInteraction(true);
283
262
  }
284
263
  });
285
- (0, _defineProperty2["default"])(_this, "buttonClick", function (key) {
264
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "buttonClick", function (key) {
286
265
  log('[buttonClick]', key);
287
266
  var onPress = _this.props.onPress;
288
267
  onPress(key);
289
268
  });
290
- (0, _defineProperty2["default"])(_this, "flowKeys", function (base, extras) {
269
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "flowKeys", function (base, extras) {
291
270
  var transposed = [].concat((0, _toConsumableArray2["default"])((0, _keysLayout.sortKeys)(base)), (0, _toConsumableArray2["default"])((0, _keysLayout.sortKeys)(extras)));
292
271
  return _lodash["default"].flatten(transposed);
293
272
  });
294
- (0, _defineProperty2["default"])(_this, "keyIsNotAllowed", function (key) {
273
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "keyIsNotAllowed", function (key) {
295
274
  var noDecimal = _this.props.noDecimal;
275
+
296
276
  if ((key.write === '.' && key.label === '.' || key.write === ',' && key.label === ',') && noDecimal) {
297
277
  return true;
298
278
  }
279
+
299
280
  return false;
300
281
  });
301
282
  _this.keypadRef = /*#__PURE__*/_react["default"].createRef();
302
283
  return _this;
303
284
  }
304
- (0, _inherits2["default"])(KeyPad, _React$Component);
305
- return (0, _createClass2["default"])(KeyPad, [{
285
+
286
+ (0, _createClass2["default"])(KeyPad, [{
306
287
  key: "componentDidMount",
307
288
  value: function componentDidMount() {
308
289
  var _this$keypadRef;
290
+
309
291
  var keyPadElement = (_this$keypadRef = this.keypadRef) === null || _this$keypadRef === void 0 ? void 0 : _this$keypadRef.current;
310
- var mainContainer = keyPadElement === null || keyPadElement === void 0 ? void 0 : keyPadElement.closest(".".concat(_constants["default"].MAIN_CONTAINER_CLASS));
311
- var currentToolbar = keyPadElement === null || keyPadElement === void 0 ? void 0 : keyPadElement.closest('.pie-toolbar');
292
+ var mainContainer = keyPadElement === null || keyPadElement === void 0 ? void 0 : keyPadElement.closest('.main-container');
293
+ var currentToolbar = keyPadElement === null || keyPadElement === void 0 ? void 0 : keyPadElement.closest('.pie-toolbar'); // need only for math keyboard so we need also controlledKeypadMode
312
294
 
313
- // need only for math keyboard so we need also controlledKeypadMode
314
295
  if (this.props.controlledKeypadMode && mainContainer && currentToolbar) {
315
296
  var mainContainerPosition = mainContainer.getBoundingClientRect();
316
297
  var currentToolbarPosition = currentToolbar.getBoundingClientRect();
317
298
  var difference = mainContainerPosition.top + mainContainerPosition.height - (currentToolbarPosition.top + currentToolbarPosition.height);
299
+
318
300
  if (difference < 0) {
319
- var totalHeight = mainContainerPosition.height + mainContainerPosition.top - difference;
320
- // increase the height of the main container if keyboard needs it
301
+ var totalHeight = mainContainerPosition.height + mainContainerPosition.top - difference; // increase the height of the main container if keyboard needs it
302
+
321
303
  if (mainContainer) {
322
304
  mainContainer.style.height = "".concat(totalHeight, "px");
323
305
  }
324
306
  }
325
307
  }
308
+
326
309
  if (keyPadElement) {
327
310
  keyPadElement.addEventListener('touchstart', this.handleKeypadInteraction, true);
328
311
  keyPadElement.addEventListener('mousedown', this.handleKeypadInteraction, true);
@@ -332,14 +315,17 @@ var KeyPad = exports.KeyPad = /*#__PURE__*/function (_React$Component) {
332
315
  key: "componentWillUnmount",
333
316
  value: function componentWillUnmount() {
334
317
  var _this$keypadRef2;
335
- var keyPadElement = (_this$keypadRef2 = this.keypadRef) === null || _this$keypadRef2 === void 0 ? void 0 : _this$keypadRef2.current;
336
- // need only for math keyboard
318
+
319
+ var keyPadElement = (_this$keypadRef2 = this.keypadRef) === null || _this$keypadRef2 === void 0 ? void 0 : _this$keypadRef2.current; // need only for math keyboard
320
+
337
321
  if (this.props.controlledKeypadMode && keyPadElement) {
338
- var mainContainer = keyPadElement.closest(".".concat(_constants["default"].MAIN_CONTAINER_CLASS));
322
+ var mainContainer = keyPadElement.closest('.main-container');
323
+
339
324
  if (mainContainer) {
340
325
  mainContainer.style.height = 'unset';
341
326
  }
342
327
  }
328
+
343
329
  if (keyPadElement) {
344
330
  keyPadElement.removeEventListener('touchstart', this.handleKeypadInteraction, true);
345
331
  keyPadElement.removeEventListener('mousedown', this.handleKeypadInteraction, true);
@@ -349,69 +335,82 @@ var KeyPad = exports.KeyPad = /*#__PURE__*/function (_React$Component) {
349
335
  key: "render",
350
336
  value: function render() {
351
337
  var _this2 = this;
338
+
352
339
  var _this$props = this.props,
353
- className = _this$props.className,
354
- baseSet = _this$props.baseSet,
355
- additionalKeys = _this$props.additionalKeys,
356
- layoutForKeyPad = _this$props.layoutForKeyPad,
357
- onFocus = _this$props.onFocus,
358
- mode = _this$props.mode;
340
+ classes = _this$props.classes,
341
+ className = _this$props.className,
342
+ baseSet = _this$props.baseSet,
343
+ additionalKeys = _this$props.additionalKeys,
344
+ layoutForKeyPad = _this$props.layoutForKeyPad,
345
+ onFocus = _this$props.onFocus,
346
+ mode = _this$props.mode;
359
347
  var noBaseSet = ['non-negative-integers', 'integers', 'decimals', 'fractions', 'item-authoring', 'language'];
360
348
  var keysWithoutBaseSet = noBaseSet.includes(mode);
361
- var allKeys = keysWithoutBaseSet ? this.flowKeys([], additionalKeys || []) : this.flowKeys(baseSet, additionalKeys || []);
349
+ var allKeys = keysWithoutBaseSet ? this.flowKeys([], additionalKeys || []) : this.flowKeys(baseSet, additionalKeys || []); //, ...sortKeys(additionalKeys)];
350
+
362
351
  var shift = allKeys.length % 5 ? 1 : 0;
352
+
363
353
  var style = _objectSpread({
364
354
  gridTemplateColumns: "repeat(".concat(Math.floor(allKeys.length / 5) + shift, ", minmax(min-content, 150px))")
365
355
  }, createCustomLayout(layoutForKeyPad));
366
- return /*#__PURE__*/_react["default"].createElement(KeyPadContainer, {
356
+
357
+ return /*#__PURE__*/_react["default"].createElement("div", {
367
358
  ref: this.keypadRef,
368
- className: (0, _classnames["default"])(className, mode),
359
+ className: (0, _classnames["default"])(classes.keys, className, classes[mode]),
369
360
  style: style,
370
361
  onFocus: onFocus
371
362
  }, allKeys.map(function (k, index) {
372
363
  var onClick = _this2.buttonClick.bind(_this2, k);
364
+
373
365
  if (!k) {
374
366
  return /*#__PURE__*/_react["default"].createElement("span", {
375
367
  key: "empty-".concat(index)
376
368
  });
377
369
  }
370
+
378
371
  var common = _objectSpread(_objectSpread({
379
372
  onClick: onClick,
373
+ className: (0, _classnames["default"])(classes.labelButton, !keysWithoutBaseSet && classes[k.category], classes[k.extraClass], k.label === ',' && classes.comma, k.label === '.' && classes.dot),
380
374
  disabled: _this2.keyIsNotAllowed(k),
381
375
  key: "".concat(k.label || k.latex || k.command, "-").concat(index)
382
376
  }, k.actions || {}), k.extraProps || {});
377
+
383
378
  if (k.latex) {
384
- return /*#__PURE__*/_react["default"].createElement(StyledLatexButtonWrapper, (0, _extends2["default"])({}, common, {
385
- category: !keysWithoutBaseSet ? k.category : undefined,
386
- "aria-label": k.ariaLabel ? k.ariaLabel : k.name || k.label
387
- }), /*#__PURE__*/_react["default"].createElement(LatexButtonContent, {
388
- latex: k.latex
379
+ return /*#__PURE__*/_react["default"].createElement(LatexButton, (0, _extends2["default"])({
380
+ latex: k.latex,
381
+ key: index
382
+ }, common, {
383
+ className: classes.latexButton,
384
+ ariaLabel: k.ariaLabel ? k.ariaLabel : k.name || k.label
389
385
  }));
390
386
  }
387
+
391
388
  if (k.label) {
392
- return /*#__PURE__*/_react["default"].createElement(StyledButton, (0, _extends2["default"])({}, common, {
393
- category: !keysWithoutBaseSet ? k.category : undefined,
394
- isDelete: k.label === '⌫',
395
- isComma: k.label === ',',
396
- isDot: k.label === '.',
389
+ return /*#__PURE__*/_react["default"].createElement(_Button["default"], (0, _extends2["default"])({
390
+ key: index
391
+ }, common, {
392
+ className: (0, _classnames["default"])(common.className, (0, _defineProperty2["default"])({}, classes.deleteButton, k.label === '')),
397
393
  "aria-label": k.ariaLabel ? k.ariaLabel : k.name || k.label
398
394
  }), k.label);
399
395
  } else {
400
396
  var Icon = k.icon ? k.icon : 'div';
401
- return /*#__PURE__*/_react["default"].createElement(StyledIconButton, (0, _extends2["default"])({
397
+ return /*#__PURE__*/_react["default"].createElement(_IconButton["default"], (0, _extends2["default"])({
402
398
  tabIndex: '-1'
403
399
  }, common, {
404
- category: !keysWithoutBaseSet ? k.category : undefined,
405
- size: "large"
400
+ key: index
406
401
  }), /*#__PURE__*/_react["default"].createElement(Icon, {
407
- className: "icon"
402
+ className: classes.icon
408
403
  }));
409
404
  }
410
405
  }));
411
406
  }
412
407
  }]);
408
+ return KeyPad;
413
409
  }(_react["default"].Component);
410
+
411
+ exports.KeyPad = KeyPad;
414
412
  (0, _defineProperty2["default"])(KeyPad, "propTypes", {
413
+ classes: _propTypes["default"].object.isRequired,
415
414
  className: _propTypes["default"].string,
416
415
  controlledKeypadMode: _propTypes["default"].bool,
417
416
  baseSet: _propTypes["default"].array,
@@ -427,5 +426,85 @@ var KeyPad = exports.KeyPad = /*#__PURE__*/function (_React$Component) {
427
426
  baseSet: _keys.baseSet,
428
427
  noDecimal: false
429
428
  });
430
- var _default = exports["default"] = KeyPad;
431
- //# sourceMappingURL=index.js.map
429
+
430
+ var styles = function styles(theme) {
431
+ return {
432
+ keys: _objectSpread(_objectSpread({}, _commonMqStyles.commonMqKeyboardStyles), {}, {
433
+ width: '100%',
434
+ display: 'grid',
435
+ gridTemplateRows: 'repeat(5, minmax(40px, 60px))',
436
+ gridRowGap: '0px',
437
+ gridColumnGap: '0px',
438
+ gridAutoFlow: 'column'
439
+ }),
440
+ character: {
441
+ textTransform: 'initial !important',
442
+ gridTemplateRows: 'repeat(5, minmax(40px, 50px)) !important'
443
+ },
444
+ language: {
445
+ gridTemplateRows: 'repeat(4, minmax(40px, 50px)) !important',
446
+ '& *': {
447
+ fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important'
448
+ }
449
+ },
450
+ holder: {
451
+ position: 'relative',
452
+ width: '100%',
453
+ height: '100%',
454
+ backgroundColor: '#cef',
455
+ borderRadius: 0,
456
+ padding: "".concat(theme.spacing.unit, "px 0 ").concat(theme.spacing.unit, "px 0")
457
+ },
458
+ labelButton: {
459
+ minWidth: 'auto',
460
+ fontSize: '140% !important',
461
+ backgroundColor: (0, _colorManipulator.lighten)(theme.palette.primary.light, 0.5),
462
+ '&:hover': {
463
+ backgroundColor: (0, _colorManipulator.lighten)(theme.palette.primary.light, 0.7)
464
+ },
465
+ borderRadius: 0
466
+ },
467
+ latexButton: {
468
+ minWidth: 'auto',
469
+ borderRadius: 0,
470
+ backgroundColor: (0, _colorManipulator.lighten)(theme.palette.primary.light, 0.5),
471
+ '&:hover': {
472
+ backgroundColor: (0, _colorManipulator.lighten)(theme.palette.primary.light, 0.7)
473
+ }
474
+ },
475
+ deleteButton: {
476
+ '& > span': {
477
+ fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important'
478
+ }
479
+ },
480
+ base: {},
481
+ operators: {
482
+ backgroundColor: (0, _colorManipulator.lighten)(theme.palette.secondary.light, 0.5),
483
+ '&:hover': {
484
+ backgroundColor: (0, _colorManipulator.lighten)(theme.palette.secondary.light, 0.7)
485
+ }
486
+ },
487
+ comparison: {
488
+ backgroundColor: (0, _colorManipulator.lighten)(_green["default"][500], 0.5),
489
+ '&:hover': {
490
+ backgroundColor: (0, _colorManipulator.lighten)(_green["default"][500], 0.7)
491
+ }
492
+ },
493
+ comma: {
494
+ fontSize: '200% !important',
495
+ lineHeight: '100%'
496
+ },
497
+ dot: {
498
+ fontSize: '200% !important',
499
+ lineHeight: '100%'
500
+ },
501
+ icon: {
502
+ height: '30px'
503
+ }
504
+ };
505
+ };
506
+
507
+ var _default = (0, _styles.withStyles)(styles)(KeyPad);
508
+
509
+ exports["default"] = _default;
510
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/keypad/index.jsx"],"names":["log","LatexButton","theme","root","textTransform","padding","margin","fontSize","latexButton","pointerEvents","transform","marginBottom","backgroundColor","palette","secondary","main","borderTop","width","marginTop","fontFamily","top","lineHeight","left","right","minHeight","border","display","paddingTop","parallelButton","fontStyle","leftRightArrowButton","position","props","buttonClass","latex","classes","mqClassName","MQ","MathQuill","getInterface","span","document","createElement","innerHTML","mathField","StaticMath","parseLatex","e","className","onClick","ariaLabel","createCustomLayout","layoutObj","gridTemplateColumns","columns","gridTemplateRows","rows","gridAutoFlow","KeyPad","setKeypadInteraction","key","onPress","base","extras","transposed","_","flatten","noDecimal","write","label","keypadRef","React","createRef","keyPadElement","current","mainContainer","closest","currentToolbar","controlledKeypadMode","mainContainerPosition","getBoundingClientRect","currentToolbarPosition","difference","height","totalHeight","style","addEventListener","handleKeypadInteraction","removeEventListener","baseSet","additionalKeys","layoutForKeyPad","onFocus","mode","noBaseSet","keysWithoutBaseSet","includes","allKeys","flowKeys","shift","length","Math","floor","keys","map","k","index","buttonClick","bind","common","labelButton","category","extraClass","comma","dot","disabled","keyIsNotAllowed","command","actions","extraProps","name","deleteButton","Icon","icon","Component","PropTypes","object","isRequired","string","bool","array","func","oneOfType","number","styles","commonMqKeyboardStyles","gridRowGap","gridColumnGap","character","language","holder","borderRadius","spacing","unit","minWidth","primary","light","operators","comparison","green"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Button from '@material-ui/core/Button';\nimport IconButton from '@material-ui/core/IconButton';\nimport { withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport { lighten, fade } from '@material-ui/core/styles/colorManipulator';\nimport green from '@material-ui/core/colors/green';\nimport debug from 'debug';\nimport _ from 'lodash';\nimport MathQuill from '@pie-framework/mathquill';\n\nimport * as mq from '../mq';\nimport { baseSet } from '../keys';\nimport { commonMqKeyboardStyles } from '../mq/common-mq-styles';\nimport { sortKeys } from './keys-layout';\n\nconst log = debug('pie-lib:math-inline:keypad');\n\nconst LatexButton = withStyles((theme) => ({\n  root: {\n    textTransform: 'none',\n    padding: 0,\n    margin: 0,\n    fontSize: '110% !important',\n  },\n  latexButton: {\n    pointerEvents: 'none',\n    textTransform: 'none !important',\n    '& .mq-scaled.mq-sqrt-prefix': {\n      transform: 'scale(1, 0.9) !important',\n    },\n    '& .mq-sup-only .mq-sup': {\n      marginBottom: '0.9px !important',\n    },\n    '& .mq-empty': {\n      backgroundColor: `${fade(theme.palette.secondary.main, 0.4)} !important`,\n    },\n    '& .mq-overline .mq-overline-inner': {\n      borderTop: '2px solid black',\n    },\n    '& .mq-non-leaf.mq-overline': {\n      borderTop: 'none !important', // fixing PD-4873 - in OT, it has border-top 1px and adds extra line\n    },\n    '& .mq-overarrow': {\n      width: '30px',\n      marginTop: '0 !important',\n      borderTop: '2px solid black',\n      fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',\n\n      '&.mq-arrow-both': {\n        top: '0px !important',\n        '& *': {\n          lineHeight: '1 !important',\n          borderTop: 'none !important', // fixing PD-4873 - in OT, it has border-top 1px and adds extra line,\n        },\n        '&:before': {\n          fontSize: '80%',\n          left: 'calc(-13%) !important',\n          top: '-0.31em !important',\n        },\n        '&:after': {\n          fontSize: '80% !important',\n          right: 'calc(-13%) !important',\n          top: '-1.5em',\n        },\n        '&.mq-empty:before': {\n          fontSize: '80%',\n          left: 'calc(-13%)',\n          top: '-0.26em',\n        },\n        '&.mq-empty:after': {\n          fontSize: '80%',\n          right: 'calc(-13%)',\n          top: '-0.26em',\n        },\n        '&.mq-empty': {\n          minHeight: '1.4em',\n        },\n      },\n      '&.mq-arrow-right:before': {\n        fontSize: '80%',\n        right: 'calc(-13%) !important',\n        top: '-0.26em !important',\n      },\n      '& .mq-overarrow-inner': {\n        border: 'none !important',\n      },\n      '& .mq-overarrow-inner .mq-overarrow-inner-right': {\n        display: 'none !important',\n      },\n    },\n    '& .mq-root-block': {\n      padding: '5px !important',\n    },\n    '& .mq-overarrow.mq-arrow-both.mq-empty:after': {\n      right: '-6px',\n      fontSize: '80% !important',\n      top: '-3px',\n    },\n    '& .mq-overarrow.mq-arrow-right.mq-empty:before': {\n      right: '-5px',\n      fontSize: '80% !important',\n      top: '-3px',\n    },\n    '& .mq-overarrow.mq-arrow-both.mq-empty:before': {\n      left: '-6px',\n      fontSize: '80% !important',\n      top: '-3px',\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    '& .mq-overarc': {\n      borderTop: '2px solid black !important',\n      '& .mq-overline': {\n        borderTop: 'none !important', // fixing PD-4873 - in OT, it has border-top 1px and adds extra line\n      },\n      '& .mq-overline-inner': {\n        borderTop: 'none !important',\n        paddingTop: '0 !important',\n      },\n    },\n  },\n  parallelButton: {\n    fontStyle: 'italic !important',\n  },\n  leftRightArrowButton: {\n    '& .mq-overarrow.mq-arrow-both': {\n      '& .mq-overline-inner': {\n        borderTop: 'none !important',\n        paddingTop: '0 !important',\n      },\n      '&:after': {\n        position: 'absolute !important',\n        top: '0px !important',\n      },\n    },\n  },\n}))((props) => {\n  let buttonClass;\n\n  if (props.latex === '\\\\parallel') {\n    buttonClass = classNames(props.classes.latexButton, props.mqClassName, props.classes.parallelButton);\n  } else if (props.latex === '\\\\overleftrightarrow{\\\\overline{}}') {\n    buttonClass = classNames(props.classes.latexButton, props.mqClassName, props.classes.leftRightArrowButton);\n  } else {\n    buttonClass = classNames(props.classes.latexButton, props.mqClassName);\n  }\n\n  try {\n    const MQ = MathQuill.getInterface(2);\n    const span = document.createElement('span');\n    span.innerHTML = '';\n    const mathField = MQ.StaticMath(span);\n\n    mathField.parseLatex(props.latex);\n    mathField.latex(props.latex);\n  } catch (e) {\n    // received latex has errors - do not create button\n    return <></>;\n  }\n\n  return (\n    <Button\n      className={classNames(props.classes.root, props.className)}\n      onClick={props.onClick}\n      aria-label={props.ariaLabel}\n    >\n      <mq.Static className={buttonClass} latex={props.latex} />\n    </Button>\n  );\n});\n\nconst createCustomLayout = (layoutObj) => {\n  if (layoutObj) {\n    return {\n      gridTemplateColumns: `repeat(${layoutObj.columns}, minmax(min-content, 150px))`,\n      gridTemplateRows: `repeat(${layoutObj.rows}, minmax(40px, 60px))`,\n      gridAutoFlow: 'initial',\n    };\n  }\n\n  return {};\n};\n\nexport class KeyPad extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object.isRequired,\n    className: PropTypes.string,\n    controlledKeypadMode: PropTypes.bool,\n    baseSet: PropTypes.array,\n    additionalKeys: PropTypes.array,\n    layoutForKeyPad: PropTypes.object,\n    onPress: PropTypes.func.isRequired,\n    onFocus: PropTypes.func,\n    noDecimal: PropTypes.bool,\n    setKeypadInteraction: PropTypes.func,\n    mode: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  };\n  static defaultProps = {\n    baseSet: baseSet,\n    noDecimal: false,\n  };\n\n  constructor(props) {\n    super(props);\n    this.keypadRef = React.createRef();\n  }\n\n  componentDidMount() {\n    const keyPadElement = this.keypadRef?.current;\n    const mainContainer = keyPadElement?.closest('.main-container');\n    const currentToolbar = keyPadElement?.closest('.pie-toolbar');\n\n    // need only for math keyboard so we need also controlledKeypadMode\n    if (this.props.controlledKeypadMode && mainContainer && currentToolbar) {\n      const mainContainerPosition = mainContainer.getBoundingClientRect();\n      const currentToolbarPosition = currentToolbar.getBoundingClientRect();\n      const difference =\n        mainContainerPosition.top +\n        mainContainerPosition.height -\n        (currentToolbarPosition.top + currentToolbarPosition.height);\n      if (difference < 0) {\n        const totalHeight = mainContainerPosition.height + mainContainerPosition.top - difference;\n        // increase the height of the main container if keyboard needs it\n        if (mainContainer) {\n          mainContainer.style.height = `${totalHeight}px`;\n        }\n      }\n    }\n\n    if (keyPadElement) {\n      keyPadElement.addEventListener('touchstart', this.handleKeypadInteraction, true);\n      keyPadElement.addEventListener('mousedown', this.handleKeypadInteraction, true);\n    }\n  }\n\n  componentWillUnmount() {\n    const keyPadElement = this.keypadRef?.current;\n    // need only for math keyboard\n    if (this.props.controlledKeypadMode && keyPadElement) {\n      const mainContainer = keyPadElement.closest('.main-container');\n\n      if (mainContainer) {\n        mainContainer.style.height = 'unset';\n      }\n    }\n\n    if (keyPadElement) {\n      keyPadElement.removeEventListener('touchstart', this.handleKeypadInteraction, true);\n      keyPadElement.removeEventListener('mousedown', this.handleKeypadInteraction, true);\n    }\n  }\n\n  handleKeypadInteraction = () => {\n    // Check if the setKeypadInteraction prop is available, which is used for both\n    // the language keypad and the special characters keypad\n    if (this.props.setKeypadInteraction) {\n      this.props.setKeypadInteraction(true);\n    }\n  };\n\n  buttonClick = (key) => {\n    log('[buttonClick]', key);\n    const { onPress } = this.props;\n\n    onPress(key);\n  };\n\n  flowKeys = (base, extras) => {\n    const transposed = [...sortKeys(base), ...sortKeys(extras)];\n    return _.flatten(transposed);\n  };\n\n  keyIsNotAllowed = (key) => {\n    const { noDecimal } = this.props;\n\n    if (((key.write === '.' && key.label === '.') || (key.write === ',' && key.label === ',')) && noDecimal) {\n      return true;\n    }\n\n    return false;\n  };\n\n  render() {\n    const { classes, className, baseSet, additionalKeys, layoutForKeyPad, onFocus, mode } = this.props;\n\n    const noBaseSet = ['non-negative-integers', 'integers', 'decimals', 'fractions', 'item-authoring', 'language'];\n\n    const keysWithoutBaseSet = noBaseSet.includes(mode);\n    const allKeys = keysWithoutBaseSet\n      ? this.flowKeys([], additionalKeys || [])\n      : this.flowKeys(baseSet, additionalKeys || []); //, ...sortKeys(additionalKeys)];\n\n    const shift = allKeys.length % 5 ? 1 : 0;\n    const style = {\n      gridTemplateColumns: `repeat(${Math.floor(allKeys.length / 5) + shift}, minmax(min-content, 150px))`,\n      ...createCustomLayout(layoutForKeyPad),\n    };\n\n    return (\n      <div\n        ref={this.keypadRef}\n        className={classNames(classes.keys, className, classes[mode])}\n        style={style}\n        onFocus={onFocus}\n      >\n        {allKeys.map((k, index) => {\n          const onClick = this.buttonClick.bind(this, k);\n\n          if (!k) {\n            return <span key={`empty-${index}`} />;\n          }\n\n          const common = {\n            onClick,\n            className: classNames(\n              classes.labelButton,\n              !keysWithoutBaseSet && classes[k.category],\n              classes[k.extraClass],\n              k.label === ',' && classes.comma,\n              k.label === '.' && classes.dot,\n            ),\n            disabled: this.keyIsNotAllowed(k),\n            key: `${k.label || k.latex || k.command}-${index}`,\n            ...(k.actions || {}),\n            ...(k.extraProps || {}),\n          };\n\n          if (k.latex) {\n            return (\n              <LatexButton\n                latex={k.latex}\n                key={index}\n                {...common}\n                className={classes.latexButton}\n                ariaLabel={k.ariaLabel ? k.ariaLabel : k.name || k.label}\n              />\n            );\n          }\n\n          if (k.label) {\n            return (\n              <Button\n                key={index}\n                {...common}\n                className={classNames(common.className, { [classes.deleteButton]: k.label === '⌫' })}\n                aria-label={k.ariaLabel ? k.ariaLabel : k.name || k.label}\n              >\n                {k.label}\n              </Button>\n            );\n          } else {\n            const Icon = k.icon ? k.icon : 'div';\n\n            return (\n              <IconButton tabIndex={'-1'} {...common} key={index}>\n                <Icon className={classes.icon} />\n              </IconButton>\n            );\n          }\n        })}\n      </div>\n    );\n  }\n}\n\nconst styles = (theme) => ({\n  keys: {\n    ...commonMqKeyboardStyles,\n    width: '100%',\n    display: 'grid',\n    gridTemplateRows: 'repeat(5, minmax(40px, 60px))',\n    gridRowGap: '0px',\n    gridColumnGap: '0px',\n    gridAutoFlow: 'column',\n  },\n  character: {\n    textTransform: 'initial !important',\n    gridTemplateRows: 'repeat(5, minmax(40px, 50px)) !important',\n  },\n  language: {\n    gridTemplateRows: 'repeat(4, minmax(40px, 50px)) !important',\n    '& *': {\n      fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',\n    },\n  },\n  holder: {\n    position: 'relative',\n    width: '100%',\n    height: '100%',\n    backgroundColor: '#cef',\n    borderRadius: 0,\n    padding: `${theme.spacing.unit}px 0 ${theme.spacing.unit}px 0`,\n  },\n  labelButton: {\n    minWidth: 'auto',\n    fontSize: '140% !important',\n    backgroundColor: lighten(theme.palette.primary.light, 0.5),\n    '&:hover': {\n      backgroundColor: lighten(theme.palette.primary.light, 0.7),\n    },\n    borderRadius: 0,\n  },\n  latexButton: {\n    minWidth: 'auto',\n    borderRadius: 0,\n    backgroundColor: lighten(theme.palette.primary.light, 0.5),\n    '&:hover': {\n      backgroundColor: lighten(theme.palette.primary.light, 0.7),\n    },\n  },\n  deleteButton: {\n    '& > span': {\n      fontFamily: 'Roboto, Helvetica, Arial, sans-serif !important',\n    },\n  },\n  base: {},\n  operators: {\n    backgroundColor: lighten(theme.palette.secondary.light, 0.5),\n    '&:hover': {\n      backgroundColor: lighten(theme.palette.secondary.light, 0.7),\n    },\n  },\n  comparison: {\n    backgroundColor: lighten(green[500], 0.5),\n    '&:hover': {\n      backgroundColor: lighten(green[500], 0.7),\n    },\n  },\n  comma: {\n    fontSize: '200% !important',\n    lineHeight: '100%',\n  },\n  dot: {\n    fontSize: '200% !important',\n    lineHeight: '100%',\n  },\n  icon: {\n    height: '30px',\n  },\n});\n\nexport default withStyles(styles)(KeyPad);\n"]}