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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/lib/__tests__/math-input-test.js +109 -0
  4. package/lib/horizontal-keypad.js +10 -4
  5. package/lib/index.js +11 -15
  6. package/lib/keypad/__tests__/index.test.js +41 -0
  7. package/lib/keypad/__tests__/keys-layout.test.js +15 -0
  8. package/lib/keypad/index.js +96 -25
  9. package/lib/keypad/keys-layout.js +1 -1
  10. package/lib/keys/__tests__/utils.test.js +60 -0
  11. package/lib/keys/basic-operators.js +1 -1
  12. package/lib/keys/chars.js +1 -1
  13. package/lib/keys/comparison.js +1 -1
  14. package/lib/keys/constants.js +1 -1
  15. package/lib/keys/digits.js +1 -1
  16. package/lib/keys/edit.js +1 -1
  17. package/lib/keys/exponent.js +1 -1
  18. package/lib/keys/fractions.js +1 -1
  19. package/lib/keys/geometry.js +5 -3
  20. package/lib/keys/grades.js +13 -1
  21. package/lib/keys/index.js +1 -1
  22. package/lib/keys/log.js +2 -2
  23. package/lib/keys/logic.js +1 -1
  24. package/lib/keys/matrices.js +1 -1
  25. package/lib/keys/misc.js +1 -1
  26. package/lib/keys/navigation.js +1 -1
  27. package/lib/keys/operators.js +1 -1
  28. package/lib/keys/statistics.js +1 -1
  29. package/lib/keys/sub-sup.js +1 -1
  30. package/lib/keys/trigonometry.js +1 -1
  31. package/lib/keys/utils.js +1 -1
  32. package/lib/keys/vars.js +1 -1
  33. package/lib/math-input.js +1 -1
  34. package/lib/mq/__tests__/input.test.js +119 -0
  35. package/lib/mq/__tests__/static.test.js +74 -0
  36. package/lib/mq/common-mq-styles.js +110 -0
  37. package/lib/mq/custom-elements.js +1 -1
  38. package/lib/mq/index.js +9 -1
  39. package/lib/mq/input.js +13 -11
  40. package/lib/mq/static.js +199 -76
  41. package/lib/updateSpans.js +23 -0
  42. package/package.json +2 -2
  43. package/src/__tests__/__snapshots__/math-input-test.jsx.snap +152 -0
  44. package/src/__tests__/math-input-test.jsx +85 -0
  45. package/src/horizontal-keypad.jsx +14 -1
  46. package/src/index.jsx +1 -10
  47. package/src/keypad/__tests__/__snapshots__/index.test.jsx.snap +193 -0
  48. package/src/keypad/__tests__/index.test.jsx +24 -0
  49. package/src/keypad/__tests__/keys-layout.test.js +15 -0
  50. package/src/keypad/index.jsx +99 -15
  51. package/src/keys/__tests__/utils.test.js +57 -0
  52. package/src/keys/geometry.js +6 -2
  53. package/src/keys/grades.js +11 -0
  54. package/src/keys/log.js +1 -1
  55. package/src/mq/__tests__/__snapshots__/input.test.jsx.snap +9 -0
  56. package/src/mq/__tests__/input.test.jsx +92 -0
  57. package/src/mq/__tests__/static.test.jsx +57 -0
  58. package/src/mq/common-mq-styles.js +105 -0
  59. package/src/mq/index.js +2 -1
  60. package/src/mq/input.jsx +22 -9
  61. package/src/mq/static.jsx +142 -13
  62. package/src/updateSpans.js +15 -0
  63. package/README.md +0 -27
  64. package/lib/horizontal-keypad.js.map +0 -1
  65. package/lib/index.js.map +0 -1
  66. package/lib/keypad/index.js.map +0 -1
  67. package/lib/keypad/keys-layout.js.map +0 -1
  68. package/lib/keys/basic-operators.js.map +0 -1
  69. package/lib/keys/chars.js.map +0 -1
  70. package/lib/keys/comparison.js.map +0 -1
  71. package/lib/keys/constants.js.map +0 -1
  72. package/lib/keys/digits.js.map +0 -1
  73. package/lib/keys/edit.js.map +0 -1
  74. package/lib/keys/exponent.js.map +0 -1
  75. package/lib/keys/fractions.js.map +0 -1
  76. package/lib/keys/geometry.js.map +0 -1
  77. package/lib/keys/grades.js.map +0 -1
  78. package/lib/keys/index.js.map +0 -1
  79. package/lib/keys/log.js.map +0 -1
  80. package/lib/keys/logic.js.map +0 -1
  81. package/lib/keys/matrices.js.map +0 -1
  82. package/lib/keys/misc.js.map +0 -1
  83. package/lib/keys/navigation.js.map +0 -1
  84. package/lib/keys/operators.js.map +0 -1
  85. package/lib/keys/statistics.js.map +0 -1
  86. package/lib/keys/sub-sup.js.map +0 -1
  87. package/lib/keys/trigonometry.js.map +0 -1
  88. package/lib/keys/utils.js.map +0 -1
  89. package/lib/keys/vars.js.map +0 -1
  90. package/lib/math-input.js.map +0 -1
  91. package/lib/mq/custom-elements.js.map +0 -1
  92. package/lib/mq/index.js.map +0 -1
  93. package/lib/mq/input.js.map +0 -1
  94. package/lib/mq/static.js.map +0 -1
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
6
+
7
+ var _enzyme = require("enzyme");
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _input = require("../input");
12
+
13
+ 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; }
14
+
15
+ 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; }
16
+
17
+ describe('Input', function () {
18
+ var w;
19
+ var onChange;
20
+ beforeEach(function () {
21
+ onChange = jest.fn();
22
+ });
23
+
24
+ var wrapper = function wrapper(extras) {
25
+ var defaults = {
26
+ classes: {},
27
+ className: 'className',
28
+ onChange: onChange
29
+ };
30
+
31
+ var props = _objectSpread(_objectSpread({}, defaults), extras);
32
+
33
+ var out = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_input.Input, props));
34
+
35
+ out.mathField = function () {
36
+ return out.instance().mathField;
37
+ };
38
+
39
+ return out;
40
+ };
41
+
42
+ describe('snapshot', function () {
43
+ it('renders', function () {
44
+ w = wrapper();
45
+ expect(w).toMatchSnapshot();
46
+ });
47
+ });
48
+ describe('logic', function () {
49
+ beforeEach(function () {
50
+ w = wrapper();
51
+ });
52
+ describe('clear', function () {
53
+ it('calls latex', function () {
54
+ w.instance().clear();
55
+ expect(w.mathField().latex).toHaveBeenCalledWith('');
56
+ });
57
+ });
58
+ describe('blur', function () {
59
+ it('calls blur', function () {
60
+ w.instance().blur();
61
+ expect(w.mathField().blur).toHaveBeenCalled();
62
+ });
63
+ });
64
+ describe('focus', function () {
65
+ it('calls focus', function () {
66
+ w.instance().focus();
67
+ expect(w.mathField().focus).toHaveBeenCalled();
68
+ });
69
+ });
70
+ describe('command', function () {
71
+ it('calls cmd', function () {
72
+ w.instance().command('foo');
73
+ expect(w.mathField().cmd).toHaveBeenCalledWith('foo');
74
+ });
75
+ it('calls cmd if passed an array', function () {
76
+ w.instance().command(['foo', 'bar']);
77
+ expect(w.mathField().cmd).toHaveBeenCalledWith('foo');
78
+ expect(w.mathField().cmd).toHaveBeenCalledWith('bar');
79
+ });
80
+ });
81
+ describe('keystroke', function () {
82
+ beforeEach(function () {
83
+ w.instance().keystroke('9');
84
+ });
85
+ it('calls keystroke', function () {
86
+ return expect(w.mathField().keystroke).toHaveBeenCalledWith('9');
87
+ });
88
+ it('calls focus', function () {
89
+ return expect(w.mathField().focus).toHaveBeenCalled();
90
+ });
91
+ it('calls latex', function () {
92
+ return expect(w.mathField().latex).toHaveBeenCalled();
93
+ });
94
+ });
95
+ describe('write', function () {
96
+ beforeEach(function () {
97
+ w.instance().write('hi');
98
+ });
99
+ it('calls write', function () {
100
+ return expect(w.mathField().write).toHaveBeenCalledWith('hi');
101
+ });
102
+ it('calls focus', function () {
103
+ return expect(w.mathField().focus).toHaveBeenCalled();
104
+ });
105
+ it('calls latex', function () {
106
+ return expect(w.mathField().latex).toHaveBeenCalled();
107
+ });
108
+ });
109
+ describe('onInputEdit', function () {
110
+ it('calls onChange', function () {
111
+ w = wrapper();
112
+ w.mathField().latex.mockReturnValue('foo');
113
+ w.instance().onInputEdit();
114
+ expect(onChange).toHaveBeenCalledWith('foo');
115
+ });
116
+ });
117
+ });
118
+ });
119
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/mq/__tests__/input.test.jsx"],"names":["describe","w","onChange","beforeEach","jest","fn","wrapper","extras","defaults","classes","className","props","out","mathField","instance","it","expect","toMatchSnapshot","clear","latex","toHaveBeenCalledWith","blur","toHaveBeenCalled","focus","command","cmd","keystroke","write","mockReturnValue","onInputEdit"],"mappings":"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","sourcesContent":["import { shallow } from 'enzyme';\nimport React from 'react';\nimport { Input } from '../input';\n\ndescribe('Input', () => {\n  let w;\n  let onChange;\n\n  beforeEach(() => {\n    onChange = jest.fn();\n  });\n  const wrapper = (extras) => {\n    const defaults = {\n      classes: {},\n      className: 'className',\n      onChange,\n    };\n    const props = { ...defaults, ...extras };\n    const out = shallow(<Input {...props} />);\n\n    out.mathField = () => out.instance().mathField;\n    return out;\n  };\n\n  describe('snapshot', () => {\n    it('renders', () => {\n      w = wrapper();\n      expect(w).toMatchSnapshot();\n    });\n  });\n  describe('logic', () => {\n    beforeEach(() => {\n      w = wrapper();\n    });\n    describe('clear', () => {\n      it('calls latex', () => {\n        w.instance().clear();\n        expect(w.mathField().latex).toHaveBeenCalledWith('');\n      });\n    });\n    describe('blur', () => {\n      it('calls blur', () => {\n        w.instance().blur();\n        expect(w.mathField().blur).toHaveBeenCalled();\n      });\n    });\n    describe('focus', () => {\n      it('calls focus', () => {\n        w.instance().focus();\n        expect(w.mathField().focus).toHaveBeenCalled();\n      });\n    });\n    describe('command', () => {\n      it('calls cmd', () => {\n        w.instance().command('foo');\n        expect(w.mathField().cmd).toHaveBeenCalledWith('foo');\n      });\n      it('calls cmd if passed an array', () => {\n        w.instance().command(['foo', 'bar']);\n        expect(w.mathField().cmd).toHaveBeenCalledWith('foo');\n        expect(w.mathField().cmd).toHaveBeenCalledWith('bar');\n      });\n    });\n\n    describe('keystroke', () => {\n      beforeEach(() => {\n        w.instance().keystroke('9');\n      });\n      it('calls keystroke', () => expect(w.mathField().keystroke).toHaveBeenCalledWith('9'));\n      it('calls focus', () => expect(w.mathField().focus).toHaveBeenCalled());\n      it('calls latex', () => expect(w.mathField().latex).toHaveBeenCalled());\n    });\n\n    describe('write', () => {\n      beforeEach(() => {\n        w.instance().write('hi');\n      });\n      it('calls write', () => expect(w.mathField().write).toHaveBeenCalledWith('hi'));\n      it('calls focus', () => expect(w.mathField().focus).toHaveBeenCalled());\n      it('calls latex', () => expect(w.mathField().latex).toHaveBeenCalled());\n    });\n\n    describe('onInputEdit', () => {\n      it('calls onChange', () => {\n        w = wrapper();\n        w.mathField().latex.mockReturnValue('foo');\n        w.instance().onInputEdit();\n        expect(onChange).toHaveBeenCalledWith('foo');\n      });\n    });\n  });\n});\n"]}
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _enzyme = require("enzyme");
6
+
7
+ var _react = _interopRequireDefault(require("react"));
8
+
9
+ var _static = _interopRequireDefault(require("../static"));
10
+
11
+ var Mathquill = require('@pie-framework/mathquill');
12
+
13
+ jest.mock('@pie-framework/mathquill', function () {
14
+ return {
15
+ StaticMath: jest.fn().mockReturnValue({
16
+ latex: jest.fn(),
17
+ parseLatex: jest.fn()
18
+ }),
19
+ getInterface: jest.fn().mockReturnThis()
20
+ };
21
+ });
22
+ describe('static', function () {
23
+ var w;
24
+ describe('mount', function () {
25
+ beforeEach(function () {
26
+ w = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_static["default"], {
27
+ latex: "foo"
28
+ }), {
29
+ disableLifecycleMethods: true
30
+ });
31
+ w.instance().input = {};
32
+ w.instance().componentDidMount();
33
+ });
34
+ it('set the html', function () {
35
+ expect(Mathquill.getInterface().StaticMath().latex).toBeCalledWith('foo');
36
+ });
37
+ it('calls MQ.StaticMath', function () {
38
+ expect(Mathquill.getInterface().StaticMath).toHaveBeenCalled();
39
+ });
40
+ });
41
+ describe('shouldComponentUpdate', function () {
42
+ it('returns false if there is an error', function () {
43
+ w = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_static["default"], {
44
+ latex: "foo"
45
+ }), {
46
+ disableLifecycleMethods: true
47
+ });
48
+ w.instance().mathField = {
49
+ parseLatex: jest.fn(function (e) {
50
+ throw new Error('boom');
51
+ })
52
+ };
53
+ expect(w.instance().shouldComponentUpdate({
54
+ latex: '\\abs{}'
55
+ })).toEqual(false);
56
+ });
57
+ it('returns true if ??', function () {
58
+ w = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_static["default"], {
59
+ latex: "foo"
60
+ }), {
61
+ disableLifecycleMethods: true
62
+ });
63
+ w.instance().mathField = {
64
+ latex: jest.fn().mockReturnValue('foo'),
65
+ parseLatex: jest.fn().mockReturnValue('foo'),
66
+ innerFields: ['field1', 'field2']
67
+ };
68
+ expect(w.instance().shouldComponentUpdate({
69
+ latex: '\\abs{}'
70
+ })).toEqual(true);
71
+ });
72
+ });
73
+ });
74
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tcS9fX3Rlc3RzX18vc3RhdGljLnRlc3QuanN4Il0sIm5hbWVzIjpbIk1hdGhxdWlsbCIsInJlcXVpcmUiLCJqZXN0IiwibW9jayIsIlN0YXRpY01hdGgiLCJmbiIsIm1vY2tSZXR1cm5WYWx1ZSIsImxhdGV4IiwicGFyc2VMYXRleCIsImdldEludGVyZmFjZSIsIm1vY2tSZXR1cm5UaGlzIiwiZGVzY3JpYmUiLCJ3IiwiYmVmb3JlRWFjaCIsImRpc2FibGVMaWZlY3ljbGVNZXRob2RzIiwiaW5zdGFuY2UiLCJpbnB1dCIsImNvbXBvbmVudERpZE1vdW50IiwiaXQiLCJleHBlY3QiLCJ0b0JlQ2FsbGVkV2l0aCIsInRvSGF2ZUJlZW5DYWxsZWQiLCJtYXRoRmllbGQiLCJlIiwiRXJyb3IiLCJzaG91bGRDb21wb25lbnRVcGRhdGUiLCJ0b0VxdWFsIiwiaW5uZXJGaWVsZHMiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFFQSxJQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQywwQkFBRCxDQUF6Qjs7QUFFQUMsSUFBSSxDQUFDQyxJQUFMLENBQVUsMEJBQVYsRUFBc0M7QUFBQSxTQUFPO0FBQzNDQyxJQUFBQSxVQUFVLEVBQUVGLElBQUksQ0FBQ0csRUFBTCxHQUFVQyxlQUFWLENBQTBCO0FBQ3BDQyxNQUFBQSxLQUFLLEVBQUVMLElBQUksQ0FBQ0csRUFBTCxFQUQ2QjtBQUVwQ0csTUFBQUEsVUFBVSxFQUFFTixJQUFJLENBQUNHLEVBQUw7QUFGd0IsS0FBMUIsQ0FEK0I7QUFLM0NJLElBQUFBLFlBQVksRUFBRVAsSUFBSSxDQUFDRyxFQUFMLEdBQVVLLGNBQVY7QUFMNkIsR0FBUDtBQUFBLENBQXRDO0FBUUFDLFFBQVEsQ0FBQyxRQUFELEVBQVcsWUFBTTtBQUN2QixNQUFJQyxDQUFKO0FBQ0FELEVBQUFBLFFBQVEsQ0FBQyxPQUFELEVBQVUsWUFBTTtBQUN0QkUsSUFBQUEsVUFBVSxDQUFDLFlBQU07QUFDZkQsTUFBQUEsQ0FBQyxHQUFHLG1DQUFRLGdDQUFDLGtCQUFEO0FBQVEsUUFBQSxLQUFLLEVBQUM7QUFBZCxRQUFSLEVBQWdDO0FBQ2xDRSxRQUFBQSx1QkFBdUIsRUFBRTtBQURTLE9BQWhDLENBQUo7QUFJQUYsTUFBQUEsQ0FBQyxDQUFDRyxRQUFGLEdBQWFDLEtBQWIsR0FBcUIsRUFBckI7QUFDQUosTUFBQUEsQ0FBQyxDQUFDRyxRQUFGLEdBQWFFLGlCQUFiO0FBQ0QsS0FQUyxDQUFWO0FBU0FDLElBQUFBLEVBQUUsQ0FBQyxjQUFELEVBQWlCLFlBQU07QUFDdkJDLE1BQUFBLE1BQU0sQ0FBQ25CLFNBQVMsQ0FBQ1MsWUFBVixHQUF5QkwsVUFBekIsR0FBc0NHLEtBQXZDLENBQU4sQ0FBb0RhLGNBQXBELENBQW1FLEtBQW5FO0FBQ0QsS0FGQyxDQUFGO0FBSUFGLElBQUFBLEVBQUUsQ0FBQyxxQkFBRCxFQUF3QixZQUFNO0FBQzlCQyxNQUFBQSxNQUFNLENBQUNuQixTQUFTLENBQUNTLFlBQVYsR0FBeUJMLFVBQTFCLENBQU4sQ0FBNENpQixnQkFBNUM7QUFDRCxLQUZDLENBQUY7QUFHRCxHQWpCTyxDQUFSO0FBbUJBVixFQUFBQSxRQUFRLENBQUMsdUJBQUQsRUFBMEIsWUFBTTtBQUN0Q08sSUFBQUEsRUFBRSxDQUFDLG9DQUFELEVBQXVDLFlBQU07QUFDN0NOLE1BQUFBLENBQUMsR0FBRyxtQ0FBUSxnQ0FBQyxrQkFBRDtBQUFRLFFBQUEsS0FBSyxFQUFDO0FBQWQsUUFBUixFQUFnQztBQUFFRSxRQUFBQSx1QkFBdUIsRUFBRTtBQUEzQixPQUFoQyxDQUFKO0FBQ0FGLE1BQUFBLENBQUMsQ0FBQ0csUUFBRixHQUFhTyxTQUFiLEdBQXlCO0FBQ3ZCZCxRQUFBQSxVQUFVLEVBQUVOLElBQUksQ0FBQ0csRUFBTCxDQUFRLFVBQUNrQixDQUFELEVBQU87QUFDekIsZ0JBQU0sSUFBSUMsS0FBSixDQUFVLE1BQVYsQ0FBTjtBQUNELFNBRlc7QUFEVyxPQUF6QjtBQUtBTCxNQUFBQSxNQUFNLENBQUNQLENBQUMsQ0FBQ0csUUFBRixHQUFhVSxxQkFBYixDQUFtQztBQUFFbEIsUUFBQUEsS0FBSyxFQUFFO0FBQVQsT0FBbkMsQ0FBRCxDQUFOLENBQWlFbUIsT0FBakUsQ0FBeUUsS0FBekU7QUFDRCxLQVJDLENBQUY7QUFVQVIsSUFBQUEsRUFBRSxDQUFDLG9CQUFELEVBQXVCLFlBQU07QUFDN0JOLE1BQUFBLENBQUMsR0FBRyxtQ0FBUSxnQ0FBQyxrQkFBRDtBQUFRLFFBQUEsS0FBSyxFQUFDO0FBQWQsUUFBUixFQUFnQztBQUFFRSxRQUFBQSx1QkFBdUIsRUFBRTtBQUEzQixPQUFoQyxDQUFKO0FBQ0FGLE1BQUFBLENBQUMsQ0FBQ0csUUFBRixHQUFhTyxTQUFiLEdBQXlCO0FBQ3ZCZixRQUFBQSxLQUFLLEVBQUVMLElBQUksQ0FBQ0csRUFBTCxHQUFVQyxlQUFWLENBQTBCLEtBQTFCLENBRGdCO0FBRXZCRSxRQUFBQSxVQUFVLEVBQUVOLElBQUksQ0FBQ0csRUFBTCxHQUFVQyxlQUFWLENBQTBCLEtBQTFCLENBRlc7QUFHdkJxQixRQUFBQSxXQUFXLEVBQUUsQ0FBQyxRQUFELEVBQVcsUUFBWDtBQUhVLE9BQXpCO0FBS0FSLE1BQUFBLE1BQU0sQ0FBQ1AsQ0FBQyxDQUFDRyxRQUFGLEdBQWFVLHFCQUFiLENBQW1DO0FBQUVsQixRQUFBQSxLQUFLLEVBQUU7QUFBVCxPQUFuQyxDQUFELENBQU4sQ0FBaUVtQixPQUFqRSxDQUF5RSxJQUF6RTtBQUNELEtBUkMsQ0FBRjtBQVNELEdBcEJPLENBQVI7QUFxQkQsQ0ExQ08sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNoYWxsb3cgfSBmcm9tICdlbnp5bWUnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBTdGF0aWMgZnJvbSAnLi4vc3RhdGljJztcblxuY29uc3QgTWF0aHF1aWxsID0gcmVxdWlyZSgnQHBpZS1mcmFtZXdvcmsvbWF0aHF1aWxsJyk7XG5cbmplc3QubW9jaygnQHBpZS1mcmFtZXdvcmsvbWF0aHF1aWxsJywgKCkgPT4gKHtcbiAgU3RhdGljTWF0aDogamVzdC5mbigpLm1vY2tSZXR1cm5WYWx1ZSh7XG4gICAgbGF0ZXg6IGplc3QuZm4oKSxcbiAgICBwYXJzZUxhdGV4OiBqZXN0LmZuKCksXG4gIH0pLFxuICBnZXRJbnRlcmZhY2U6IGplc3QuZm4oKS5tb2NrUmV0dXJuVGhpcygpLFxufSkpO1xuXG5kZXNjcmliZSgnc3RhdGljJywgKCkgPT4ge1xuICBsZXQgdztcbiAgZGVzY3JpYmUoJ21vdW50JywgKCkgPT4ge1xuICAgIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgICAgdyA9IHNoYWxsb3coPFN0YXRpYyBsYXRleD1cImZvb1wiIC8+LCB7XG4gICAgICAgIGRpc2FibGVMaWZlY3ljbGVNZXRob2RzOiB0cnVlLFxuICAgICAgfSk7XG5cbiAgICAgIHcuaW5zdGFuY2UoKS5pbnB1dCA9IHt9O1xuICAgICAgdy5pbnN0YW5jZSgpLmNvbXBvbmVudERpZE1vdW50KCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2V0IHRoZSBodG1sJywgKCkgPT4ge1xuICAgICAgZXhwZWN0KE1hdGhxdWlsbC5nZXRJbnRlcmZhY2UoKS5TdGF0aWNNYXRoKCkubGF0ZXgpLnRvQmVDYWxsZWRXaXRoKCdmb28nKTtcbiAgICB9KTtcblxuICAgIGl0KCdjYWxscyBNUS5TdGF0aWNNYXRoJywgKCkgPT4ge1xuICAgICAgZXhwZWN0KE1hdGhxdWlsbC5nZXRJbnRlcmZhY2UoKS5TdGF0aWNNYXRoKS50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdzaG91bGRDb21wb25lbnRVcGRhdGUnLCAoKSA9PiB7XG4gICAgaXQoJ3JldHVybnMgZmFsc2UgaWYgdGhlcmUgaXMgYW4gZXJyb3InLCAoKSA9PiB7XG4gICAgICB3ID0gc2hhbGxvdyg8U3RhdGljIGxhdGV4PVwiZm9vXCIgLz4sIHsgZGlzYWJsZUxpZmVjeWNsZU1ldGhvZHM6IHRydWUgfSk7XG4gICAgICB3Lmluc3RhbmNlKCkubWF0aEZpZWxkID0ge1xuICAgICAgICBwYXJzZUxhdGV4OiBqZXN0LmZuKChlKSA9PiB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdib29tJyk7XG4gICAgICAgIH0pLFxuICAgICAgfTtcbiAgICAgIGV4cGVjdCh3Lmluc3RhbmNlKCkuc2hvdWxkQ29tcG9uZW50VXBkYXRlKHsgbGF0ZXg6ICdcXFxcYWJze30nIH0pKS50b0VxdWFsKGZhbHNlKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZXR1cm5zIHRydWUgaWYgPz8nLCAoKSA9PiB7XG4gICAgICB3ID0gc2hhbGxvdyg8U3RhdGljIGxhdGV4PVwiZm9vXCIgLz4sIHsgZGlzYWJsZUxpZmVjeWNsZU1ldGhvZHM6IHRydWUgfSk7XG4gICAgICB3Lmluc3RhbmNlKCkubWF0aEZpZWxkID0ge1xuICAgICAgICBsYXRleDogamVzdC5mbigpLm1vY2tSZXR1cm5WYWx1ZSgnZm9vJyksXG4gICAgICAgIHBhcnNlTGF0ZXg6IGplc3QuZm4oKS5tb2NrUmV0dXJuVmFsdWUoJ2ZvbycpLFxuICAgICAgICBpbm5lckZpZWxkczogWydmaWVsZDEnLCAnZmllbGQyJ10sXG4gICAgICB9O1xuICAgICAgZXhwZWN0KHcuaW5zdGFuY2UoKS5zaG91bGRDb21wb25lbnRVcGRhdGUoeyBsYXRleDogJ1xcXFxhYnN7fScgfSkpLnRvRXF1YWwodHJ1ZSk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.supsubStyles = exports.longdivStyles = exports["default"] = exports.commonMqKeyboardStyles = exports.commonMqFontStyles = void 0;
9
+
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+
12
+ 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; }
13
+
14
+ 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; }
15
+
16
+ var commonMqFontStyles = {
17
+ fontFamily: 'MJXZERO, MJXTEX !important',
18
+ '-webkit-font-smoothing': 'antialiased !important',
19
+ '& .mq-math-mode > span > var': {
20
+ fontFamily: 'MJXZERO, MJXTEX-I !important'
21
+ },
22
+ '& .mq-math-mode span var': {
23
+ fontFamily: 'MJXZERO, MJXTEX-I !important'
24
+ },
25
+ '& .mq-math-mode .mq-nonSymbola': {
26
+ fontFamily: 'MJXZERO, MJXTEX-I !important'
27
+ },
28
+ '& .mq-math-mode > span > var.mq-operator-name': {
29
+ fontFamily: 'MJXZERO, MJXTEX !important'
30
+ }
31
+ };
32
+ exports.commonMqFontStyles = commonMqFontStyles;
33
+ var longdivStyles = {
34
+ '& .mq-longdiv-inner': {
35
+ marginTop: '-1px',
36
+ marginLeft: '5px !important;',
37
+ '& > .mq-empty': {
38
+ padding: '0 !important',
39
+ marginLeft: '0px !important',
40
+ marginTop: '2px'
41
+ }
42
+ },
43
+ '& .mq-math-mode .mq-longdiv': {
44
+ display: 'inline-flex !important'
45
+ }
46
+ };
47
+ exports.longdivStyles = longdivStyles;
48
+ var supsubStyles = {
49
+ '& .mq-math-mode sup.mq-nthroot': {
50
+ fontSize: '70% !important',
51
+ verticalAlign: '0.5em !important',
52
+ paddingRight: '0.15em'
53
+ },
54
+ '& .mq-math-mode .mq-supsub': {
55
+ fontSize: '70.7% !important'
56
+ },
57
+ '& .mq-supsub ': {
58
+ fontSize: '70.7%'
59
+ },
60
+ '& .mq-math-mode .mq-supsub.mq-sup-only': {
61
+ verticalAlign: '-0.1em !important',
62
+ '& .mq-sup': {
63
+ marginBottom: '0px !important'
64
+ }
65
+ },
66
+
67
+ /* But when the base is a fraction, move it higher */
68
+ '& .mq-math-mode .mq-fraction + .mq-supsub.mq-sup-only': {
69
+ verticalAlign: '0.4em !important'
70
+ },
71
+ '& .mq-math-mode .mq-supsub.mq-sup-only.mq-after-fraction-group': {
72
+ verticalAlign: '0.4em !important'
73
+ }
74
+ };
75
+ exports.supsubStyles = supsubStyles;
76
+ var commonMqKeyboardStyles = {
77
+ '& *': _objectSpread(_objectSpread(_objectSpread({}, commonMqFontStyles), longdivStyles), {}, {
78
+ '& .mq-math-mode .mq-sqrt-prefix': {
79
+ top: '0 !important'
80
+ },
81
+ '& .mq-math-mode .mq-empty': {
82
+ padding: '9px 1px !important'
83
+ },
84
+ '& .mq-math-mode .mq-supsub': {
85
+ fontSize: '70.7% !important'
86
+ },
87
+ '& .mq-math-mode .mq-sqrt-stem': {
88
+ marginTop: '-5px',
89
+ paddingTop: '4px'
90
+ },
91
+ '& .mq-math-mode .mq-paren': {
92
+ verticalAlign: 'middle !important'
93
+ },
94
+ '& .mq-math-mode .mq-overarrow .mq-overarrow-inner .mq-empty': {
95
+ padding: '0 !important'
96
+ },
97
+ '& .mq-math-mode .mq-overline .mq-overline-inner .mq-empty ': {
98
+ padding: '0 !important'
99
+ }
100
+ })
101
+ };
102
+ exports.commonMqKeyboardStyles = commonMqKeyboardStyles;
103
+ var _default = {
104
+ commonMqFontStyles: commonMqFontStyles,
105
+ longdivStyles: longdivStyles,
106
+ supsubStyles: supsubStyles,
107
+ commonMqKeyboardStyles: commonMqKeyboardStyles
108
+ };
109
+ exports["default"] = _default;
110
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tcS9jb21tb24tbXEtc3R5bGVzLmpzIl0sIm5hbWVzIjpbImNvbW1vbk1xRm9udFN0eWxlcyIsImZvbnRGYW1pbHkiLCJsb25nZGl2U3R5bGVzIiwibWFyZ2luVG9wIiwibWFyZ2luTGVmdCIsInBhZGRpbmciLCJkaXNwbGF5Iiwic3Vwc3ViU3R5bGVzIiwiZm9udFNpemUiLCJ2ZXJ0aWNhbEFsaWduIiwicGFkZGluZ1JpZ2h0IiwibWFyZ2luQm90dG9tIiwiY29tbW9uTXFLZXlib2FyZFN0eWxlcyIsInRvcCIsInBhZGRpbmdUb3AiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQUFPLElBQU1BLGtCQUFrQixHQUFHO0FBQ2hDQyxFQUFBQSxVQUFVLEVBQUUsNEJBRG9CO0FBRWhDLDRCQUEwQix3QkFGTTtBQUloQyxrQ0FBZ0M7QUFDOUJBLElBQUFBLFVBQVUsRUFBRTtBQURrQixHQUpBO0FBT2hDLDhCQUE0QjtBQUMxQkEsSUFBQUEsVUFBVSxFQUFFO0FBRGMsR0FQSTtBQVVoQyxvQ0FBa0M7QUFDaENBLElBQUFBLFVBQVUsRUFBRTtBQURvQixHQVZGO0FBYWhDLG1EQUFpRDtBQUMvQ0EsSUFBQUEsVUFBVSxFQUFFO0FBRG1DO0FBYmpCLENBQTNCOztBQWtCQSxJQUFNQyxhQUFhLEdBQUc7QUFDM0IseUJBQXVCO0FBQ3JCQyxJQUFBQSxTQUFTLEVBQUUsTUFEVTtBQUVyQkMsSUFBQUEsVUFBVSxFQUFFLGlCQUZTO0FBSXJCLHFCQUFpQjtBQUNmQyxNQUFBQSxPQUFPLEVBQUUsY0FETTtBQUVmRCxNQUFBQSxVQUFVLEVBQUUsZ0JBRkc7QUFHZkQsTUFBQUEsU0FBUyxFQUFFO0FBSEk7QUFKSSxHQURJO0FBWTNCLGlDQUErQjtBQUM3QkcsSUFBQUEsT0FBTyxFQUFFO0FBRG9CO0FBWkosQ0FBdEI7O0FBaUJBLElBQU1DLFlBQVksR0FBRztBQUMxQixvQ0FBa0M7QUFDaENDLElBQUFBLFFBQVEsRUFBRSxnQkFEc0I7QUFFaENDLElBQUFBLGFBQWEsRUFBRSxrQkFGaUI7QUFHaENDLElBQUFBLFlBQVksRUFBRTtBQUhrQixHQURSO0FBTTFCLGdDQUE4QjtBQUM1QkYsSUFBQUEsUUFBUSxFQUFFO0FBRGtCLEdBTko7QUFTMUIsbUJBQWlCO0FBQ2ZBLElBQUFBLFFBQVEsRUFBRTtBQURLLEdBVFM7QUFZMUIsNENBQTBDO0FBQ3hDQyxJQUFBQSxhQUFhLEVBQUUsbUJBRHlCO0FBR3hDLGlCQUFhO0FBQ1hFLE1BQUFBLFlBQVksRUFBRTtBQURIO0FBSDJCLEdBWmhCOztBQW1CMUI7QUFDQSwyREFBeUQ7QUFDdkRGLElBQUFBLGFBQWEsRUFBRTtBQUR3QyxHQXBCL0I7QUF3QjFCLG9FQUFrRTtBQUNoRUEsSUFBQUEsYUFBYSxFQUFFO0FBRGlEO0FBeEJ4QyxDQUFyQjs7QUE2QkEsSUFBTUcsc0JBQXNCLEdBQUc7QUFDcEMsdURBQ0taLGtCQURMLEdBRUtFLGFBRkw7QUFHRSx1Q0FBbUM7QUFDakNXLE1BQUFBLEdBQUcsRUFBRTtBQUQ0QixLQUhyQztBQU9FLGlDQUE2QjtBQUMzQlIsTUFBQUEsT0FBTyxFQUFFO0FBRGtCLEtBUC9CO0FBV0Usa0NBQThCO0FBQzVCRyxNQUFBQSxRQUFRLEVBQUU7QUFEa0IsS0FYaEM7QUFlRSxxQ0FBaUM7QUFDL0JMLE1BQUFBLFNBQVMsRUFBRSxNQURvQjtBQUUvQlcsTUFBQUEsVUFBVSxFQUFFO0FBRm1CLEtBZm5DO0FBb0JFLGlDQUE2QjtBQUMzQkwsTUFBQUEsYUFBYSxFQUFFO0FBRFksS0FwQi9CO0FBd0JFLG1FQUErRDtBQUM3REosTUFBQUEsT0FBTyxFQUFFO0FBRG9ELEtBeEJqRTtBQTRCRSxrRUFBOEQ7QUFDNURBLE1BQUFBLE9BQU8sRUFBRTtBQURtRDtBQTVCaEU7QUFEb0MsQ0FBL0I7O2VBbUNRO0FBQ2JMLEVBQUFBLGtCQUFrQixFQUFsQkEsa0JBRGE7QUFFYkUsRUFBQUEsYUFBYSxFQUFiQSxhQUZhO0FBR2JLLEVBQUFBLFlBQVksRUFBWkEsWUFIYTtBQUliSyxFQUFBQSxzQkFBc0IsRUFBdEJBO0FBSmEsQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBjb21tb25NcUZvbnRTdHlsZXMgPSB7XG4gIGZvbnRGYW1pbHk6ICdNSlhaRVJPLCBNSlhURVggIWltcG9ydGFudCcsXG4gICctd2Via2l0LWZvbnQtc21vb3RoaW5nJzogJ2FudGlhbGlhc2VkICFpbXBvcnRhbnQnLFxuXG4gICcmIC5tcS1tYXRoLW1vZGUgPiBzcGFuID4gdmFyJzoge1xuICAgIGZvbnRGYW1pbHk6ICdNSlhaRVJPLCBNSlhURVgtSSAhaW1wb3J0YW50JyxcbiAgfSxcbiAgJyYgLm1xLW1hdGgtbW9kZSBzcGFuIHZhcic6IHtcbiAgICBmb250RmFtaWx5OiAnTUpYWkVSTywgTUpYVEVYLUkgIWltcG9ydGFudCcsXG4gIH0sXG4gICcmIC5tcS1tYXRoLW1vZGUgLm1xLW5vblN5bWJvbGEnOiB7XG4gICAgZm9udEZhbWlseTogJ01KWFpFUk8sIE1KWFRFWC1JICFpbXBvcnRhbnQnLFxuICB9LFxuICAnJiAubXEtbWF0aC1tb2RlID4gc3BhbiA+IHZhci5tcS1vcGVyYXRvci1uYW1lJzoge1xuICAgIGZvbnRGYW1pbHk6ICdNSlhaRVJPLCBNSlhURVggIWltcG9ydGFudCcsXG4gIH0sXG59O1xuXG5leHBvcnQgY29uc3QgbG9uZ2RpdlN0eWxlcyA9IHtcbiAgJyYgLm1xLWxvbmdkaXYtaW5uZXInOiB7XG4gICAgbWFyZ2luVG9wOiAnLTFweCcsXG4gICAgbWFyZ2luTGVmdDogJzVweCAhaW1wb3J0YW50OycsXG5cbiAgICAnJiA+IC5tcS1lbXB0eSc6IHtcbiAgICAgIHBhZGRpbmc6ICcwICFpbXBvcnRhbnQnLFxuICAgICAgbWFyZ2luTGVmdDogJzBweCAhaW1wb3J0YW50JyxcbiAgICAgIG1hcmdpblRvcDogJzJweCcsXG4gICAgfSxcbiAgfSxcblxuICAnJiAubXEtbWF0aC1tb2RlIC5tcS1sb25nZGl2Jzoge1xuICAgIGRpc3BsYXk6ICdpbmxpbmUtZmxleCAhaW1wb3J0YW50JyxcbiAgfSxcbn07XG5cbmV4cG9ydCBjb25zdCBzdXBzdWJTdHlsZXMgPSB7XG4gICcmIC5tcS1tYXRoLW1vZGUgc3VwLm1xLW50aHJvb3QnOiB7XG4gICAgZm9udFNpemU6ICc3MCUgIWltcG9ydGFudCcsXG4gICAgdmVydGljYWxBbGlnbjogJzAuNWVtICFpbXBvcnRhbnQnLFxuICAgIHBhZGRpbmdSaWdodDogJzAuMTVlbScsXG4gIH0sXG4gICcmIC5tcS1tYXRoLW1vZGUgLm1xLXN1cHN1Yic6IHtcbiAgICBmb250U2l6ZTogJzcwLjclICFpbXBvcnRhbnQnLFxuICB9LFxuICAnJiAubXEtc3Vwc3ViICc6IHtcbiAgICBmb250U2l6ZTogJzcwLjclJyxcbiAgfSxcbiAgJyYgLm1xLW1hdGgtbW9kZSAubXEtc3Vwc3ViLm1xLXN1cC1vbmx5Jzoge1xuICAgIHZlcnRpY2FsQWxpZ246ICctMC4xZW0gIWltcG9ydGFudCcsXG5cbiAgICAnJiAubXEtc3VwJzoge1xuICAgICAgbWFyZ2luQm90dG9tOiAnMHB4ICFpbXBvcnRhbnQnLFxuICAgIH0sXG4gIH0sXG4gIC8qIEJ1dCB3aGVuIHRoZSBiYXNlIGlzIGEgZnJhY3Rpb24sIG1vdmUgaXQgaGlnaGVyICovXG4gICcmIC5tcS1tYXRoLW1vZGUgLm1xLWZyYWN0aW9uICsgLm1xLXN1cHN1Yi5tcS1zdXAtb25seSc6IHtcbiAgICB2ZXJ0aWNhbEFsaWduOiAnMC40ZW0gIWltcG9ydGFudCcsXG4gIH0sXG5cbiAgJyYgLm1xLW1hdGgtbW9kZSAubXEtc3Vwc3ViLm1xLXN1cC1vbmx5Lm1xLWFmdGVyLWZyYWN0aW9uLWdyb3VwJzoge1xuICAgIHZlcnRpY2FsQWxpZ246ICcwLjRlbSAhaW1wb3J0YW50JyxcbiAgfSxcbn07XG5cbmV4cG9ydCBjb25zdCBjb21tb25NcUtleWJvYXJkU3R5bGVzID0ge1xuICAnJiAqJzoge1xuICAgIC4uLmNvbW1vbk1xRm9udFN0eWxlcyxcbiAgICAuLi5sb25nZGl2U3R5bGVzLFxuICAgICcmIC5tcS1tYXRoLW1vZGUgLm1xLXNxcnQtcHJlZml4Jzoge1xuICAgICAgdG9wOiAnMCAhaW1wb3J0YW50JyxcbiAgICB9LFxuXG4gICAgJyYgLm1xLW1hdGgtbW9kZSAubXEtZW1wdHknOiB7XG4gICAgICBwYWRkaW5nOiAnOXB4IDFweCAhaW1wb3J0YW50JyxcbiAgICB9LFxuXG4gICAgJyYgLm1xLW1hdGgtbW9kZSAubXEtc3Vwc3ViJzoge1xuICAgICAgZm9udFNpemU6ICc3MC43JSAhaW1wb3J0YW50JyxcbiAgICB9LFxuXG4gICAgJyYgLm1xLW1hdGgtbW9kZSAubXEtc3FydC1zdGVtJzoge1xuICAgICAgbWFyZ2luVG9wOiAnLTVweCcsXG4gICAgICBwYWRkaW5nVG9wOiAnNHB4JyxcbiAgICB9LFxuXG4gICAgJyYgLm1xLW1hdGgtbW9kZSAubXEtcGFyZW4nOiB7XG4gICAgICB2ZXJ0aWNhbEFsaWduOiAnbWlkZGxlICFpbXBvcnRhbnQnLFxuICAgIH0sXG5cbiAgICAnJiAubXEtbWF0aC1tb2RlIC5tcS1vdmVyYXJyb3cgLm1xLW92ZXJhcnJvdy1pbm5lciAubXEtZW1wdHknOiB7XG4gICAgICBwYWRkaW5nOiAnMCAhaW1wb3J0YW50JyxcbiAgICB9LFxuXG4gICAgJyYgLm1xLW1hdGgtbW9kZSAubXEtb3ZlcmxpbmUgLm1xLW92ZXJsaW5lLWlubmVyIC5tcS1lbXB0eSAnOiB7XG4gICAgICBwYWRkaW5nOiAnMCAhaW1wb3J0YW50JyxcbiAgICB9LFxuICB9LFxufTtcblxuZXhwb3J0IGRlZmF1bHQge1xuICBjb21tb25NcUZvbnRTdHlsZXMsXG4gIGxvbmdkaXZTdHlsZXMsXG4gIHN1cHN1YlN0eWxlcyxcbiAgY29tbW9uTXFLZXlib2FyZFN0eWxlcyxcbn07XG4iXX0=
@@ -20,4 +20,4 @@ var registerLineBreak = function registerLineBreak(MQ) {
20
20
  };
21
21
 
22
22
  exports.registerLineBreak = registerLineBreak;
23
- //# sourceMappingURL=custom-elements.js.map
23
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tcS9jdXN0b20tZWxlbWVudHMuanMiXSwibmFtZXMiOlsicmVnaXN0ZXJMaW5lQnJlYWsiLCJNUSIsInJlZ2lzdGVyRW1iZWQiLCJodG1sU3RyaW5nIiwidGV4dCIsImxhdGV4Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBTUEsaUJBQWlCLEdBQUcsU0FBcEJBLGlCQUFvQixDQUFTQyxFQUFULEVBQWE7QUFDckNBLEVBQUFBLEVBQUUsQ0FBQ0MsYUFBSCxDQUFpQixTQUFqQixFQUE0QixZQUFNO0FBQ2hDLFdBQU87QUFDTEMsTUFBQUEsVUFBVSxFQUFFLDZCQURQO0FBRUxDLE1BQUFBLElBQUksRUFBRTtBQUFBLGVBQU0sVUFBTjtBQUFBLE9BRkQ7QUFHTEMsTUFBQUEsS0FBSyxFQUFFO0FBQUEsZUFBTSxvQkFBTjtBQUFBO0FBSEYsS0FBUDtBQUtELEdBTkQ7QUFPRCxDQVJEIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgcmVnaXN0ZXJMaW5lQnJlYWsgPSBmdW5jdGlvbihNUSkge1xuICBNUS5yZWdpc3RlckVtYmVkKCduZXdMaW5lJywgKCkgPT4ge1xuICAgIHJldHVybiB7XG4gICAgICBodG1sU3RyaW5nOiAnPGRpdiBjbGFzcz1cIm5ld0xpbmVcIj48L2Rpdj4nLFxuICAgICAgdGV4dDogKCkgPT4gJ3Rlc3RUZXh0JyxcbiAgICAgIGxhdGV4OiAoKSA9PiAnXFxcXGVtYmVke25ld0xpbmV9W10nLFxuICAgIH07XG4gIH0pO1xufTtcblxuZXhwb3J0IHsgcmVnaXN0ZXJMaW5lQnJlYWsgfTtcbiJdfQ==
package/lib/mq/index.js CHANGED
@@ -5,6 +5,12 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
+ Object.defineProperty(exports, "CommonMqStyles", {
9
+ enumerable: true,
10
+ get: function get() {
11
+ return _commonMqStyles["default"];
12
+ }
13
+ });
8
14
  Object.defineProperty(exports, "Input", {
9
15
  enumerable: true,
10
16
  get: function get() {
@@ -21,4 +27,6 @@ Object.defineProperty(exports, "Static", {
21
27
  var _input = _interopRequireDefault(require("./input"));
22
28
 
23
29
  var _static = _interopRequireDefault(require("./static"));
24
- //# sourceMappingURL=index.js.map
30
+
31
+ var _commonMqStyles = _interopRequireDefault(require("./common-mq-styles"));
32
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tcS9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IElucHV0IGZyb20gJy4vaW5wdXQnO1xuaW1wb3J0IFN0YXRpYyBmcm9tICcuL3N0YXRpYyc7XG5pbXBvcnQgQ29tbW9uTXFTdHlsZXMgZnJvbSAnLi9jb21tb24tbXEtc3R5bGVzJztcblxuZXhwb3J0IHsgSW5wdXQsIFN0YXRpYywgQ29tbW9uTXFTdHlsZXMgfTtcbiJdfQ==
package/lib/mq/input.js CHANGED
@@ -97,14 +97,17 @@ var Input = /*#__PURE__*/function (_React$Component) {
97
97
  }
98
98
 
99
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();
100
+ event.preventDefault();
101
+ return;
106
102
  }
107
103
  });
104
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onClick", function (event) {
105
+ var onClick = _this.props.onClick;
106
+
107
+ _this.refresh();
108
+
109
+ onClick && onClick(event);
110
+ });
108
111
  return _this;
109
112
  }
110
113
 
@@ -136,7 +139,7 @@ var Input = /*#__PURE__*/function (_React$Component) {
136
139
 
137
140
  var latex = this.props.latex;
138
141
 
139
- if (latex) {
142
+ if (latex !== undefined && latex !== null) {
140
143
  this.mathField.latex(latex);
141
144
  }
142
145
  }
@@ -204,15 +207,14 @@ var Input = /*#__PURE__*/function (_React$Component) {
204
207
  var _this3 = this;
205
208
 
206
209
  var _this$props = this.props,
207
- onClick = _this$props.onClick,
208
210
  onFocus = _this$props.onFocus,
209
211
  onBlur = _this$props.onBlur,
210
212
  classes = _this$props.classes,
211
213
  className = _this$props.className;
212
214
  return /*#__PURE__*/_react["default"].createElement("span", {
213
215
  className: (0, _classnames["default"])(classes.input, className),
214
- onKeyPress: this.onKeyPress,
215
- onClick: onClick,
216
+ onKeyDown: this.onKeyPress,
217
+ onClick: this.onClick,
216
218
  onFocus: onFocus,
217
219
  onBlur: onBlur,
218
220
  ref: function ref(r) {
@@ -242,4 +244,4 @@ var styles = function styles() {
242
244
  var _default = (0, _styles.withStyles)(styles)(Input);
243
245
 
244
246
  exports["default"] = _default;
245
- //# sourceMappingURL=input.js.map
247
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"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","preventDefault","onClick","Error","MathField","input","handlers","edit","onInputEdit","bind","updateLatex","undefined","v","Array","isArray","forEach","vv","cmd","keystroke","write","nextProps","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\n    const { latex } = this.props;\n\n    if (latex !== undefined && latex !== null) {\n      this.mathField.latex(latex);\n    }\n  }\n\n  clear() {\n    this.mathField.latex('');\n\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\n    this.mathField.focus();\n\n    return this.mathField.latex();\n  }\n\n  keystroke(v) {\n    this.mathField.keystroke(v);\n    this.mathField.focus();\n\n    return this.mathField.latex();\n  }\n\n  write(v) {\n    log('write: ', v);\n    this.mathField.write(v);\n    this.mathField.focus();\n\n    return this.mathField.latex();\n  }\n\n  onInputEdit = () => {\n    log('[onInputEdit] ...');\n    const { onChange } = this.props;\n\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      event.preventDefault();\n      return;\n    }\n  };\n\n  onClick = (event) => {\n    const { onClick } = this.props;\n\n    this.refresh();\n    onClick && onClick(event);\n  };\n\n  shouldComponentUpdate(nextProps) {\n    log('next: ', nextProps.latex);\n    log('current: ', this.mathField.latex());\n\n    return nextProps.latex !== this.mathField.latex();\n  }\n\n  render() {\n    const { onFocus, onBlur, classes, className } = this.props;\n\n    return (\n      <span\n        className={classNames(classes.input, className)}\n        onKeyDown={this.onKeyPress}\n        onClick={this.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"]}