@pie-lib/mask-markup 1.13.47-next.1 → 1.15.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 (76) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/lib/__tests__/drag-in-the-blank.test.js +71 -0
  4. package/lib/__tests__/index.test.js +50 -0
  5. package/lib/__tests__/mask.test.js +149 -0
  6. package/lib/__tests__/serialization.test.js +45 -0
  7. package/lib/__tests__/utils.js +17 -0
  8. package/lib/__tests__/with-mask.test.js +65 -0
  9. package/lib/choices/__tests__/index.test.js +85 -0
  10. package/lib/choices/choice.js +81 -18
  11. package/lib/choices/index.js +12 -4
  12. package/lib/componentize.js +1 -1
  13. package/lib/components/__tests__/blank.test.js +234 -0
  14. package/lib/components/__tests__/correct-input.test.js +63 -0
  15. package/lib/components/__tests__/dropdown.test.js +70 -0
  16. package/lib/components/__tests__/input.test.js +64 -0
  17. package/lib/components/blank.js +147 -35
  18. package/lib/components/correct-input.js +9 -4
  19. package/lib/components/dropdown.js +183 -50
  20. package/lib/components/input.js +1 -1
  21. package/lib/constructed-response.js +88 -24
  22. package/lib/customizable.js +48 -0
  23. package/lib/drag-in-the-blank.js +35 -9
  24. package/lib/index.js +9 -1
  25. package/lib/inline-dropdown.js +4 -2
  26. package/lib/mask.js +46 -7
  27. package/lib/serialization.js +1 -1
  28. package/lib/with-mask.js +35 -3
  29. package/package.json +5 -5
  30. package/src/__tests__/__snapshots__/drag-in-the-blank.test.js.snap +316 -0
  31. package/src/__tests__/__snapshots__/mask.test.js.snap +55 -0
  32. package/src/__tests__/__snapshots__/with-mask.test.js.snap +62 -0
  33. package/src/__tests__/drag-in-the-blank.test.js +71 -0
  34. package/src/__tests__/index.test.js +39 -0
  35. package/src/__tests__/mask.test.js +152 -0
  36. package/src/__tests__/serialization.test.js +54 -0
  37. package/src/__tests__/utils.js +1 -0
  38. package/src/__tests__/with-mask.test.js +51 -0
  39. package/src/choices/__tests__/__snapshots__/index.test.js.snap +209 -0
  40. package/src/choices/__tests__/index.test.js +62 -0
  41. package/src/choices/choice.jsx +60 -6
  42. package/src/choices/index.jsx +2 -2
  43. package/src/components/__tests__/__snapshots__/blank.test.js.snap +111 -0
  44. package/src/components/__tests__/__snapshots__/correct-input.test.js.snap +64 -0
  45. package/src/components/__tests__/__snapshots__/dropdown.test.js.snap +133 -0
  46. package/src/components/__tests__/__snapshots__/input.test.js.snap +34 -0
  47. package/src/components/__tests__/blank.test.js +202 -0
  48. package/src/components/__tests__/correct-input.test.js +49 -0
  49. package/src/components/__tests__/dropdown.test.js +51 -0
  50. package/src/components/__tests__/input.test.js +50 -0
  51. package/src/components/blank.jsx +139 -28
  52. package/src/components/correct-input.jsx +6 -1
  53. package/src/components/dropdown.jsx +192 -71
  54. package/src/constructed-response.jsx +76 -18
  55. package/src/customizable.jsx +35 -0
  56. package/src/drag-in-the-blank.jsx +26 -3
  57. package/src/index.js +10 -1
  58. package/src/inline-dropdown.jsx +2 -0
  59. package/src/mask.jsx +30 -5
  60. package/src/serialization.js +1 -1
  61. package/src/with-mask.jsx +39 -2
  62. package/README.md +0 -14
  63. package/lib/choices/choice.js.map +0 -1
  64. package/lib/choices/index.js.map +0 -1
  65. package/lib/componentize.js.map +0 -1
  66. package/lib/components/blank.js.map +0 -1
  67. package/lib/components/correct-input.js.map +0 -1
  68. package/lib/components/dropdown.js.map +0 -1
  69. package/lib/components/input.js.map +0 -1
  70. package/lib/constructed-response.js.map +0 -1
  71. package/lib/drag-in-the-blank.js.map +0 -1
  72. package/lib/index.js.map +0 -1
  73. package/lib/inline-dropdown.js.map +0 -1
  74. package/lib/mask.js.map +0 -1
  75. package/lib/serialization.js.map +0 -1
  76. package/lib/with-mask.js.map +0 -1
@@ -33,6 +33,10 @@ var _blank = _interopRequireDefault(require("./components/blank"));
33
33
 
34
34
  var _withMask = require("./with-mask");
35
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
+
36
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); }; }
37
41
 
38
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; } }
@@ -48,7 +52,9 @@ var Masked = (0, _withMask.withMask)('blank', function (props) {
48
52
  duplicates = props.duplicates,
49
53
  correctResponse = props.correctResponse,
50
54
  feedback = props.feedback,
51
- showCorrectAnswer = props.showCorrectAnswer;
55
+ showCorrectAnswer = props.showCorrectAnswer,
56
+ emptyResponseAreaWidth = props.emptyResponseAreaWidth,
57
+ emptyResponseAreaHeight = props.emptyResponseAreaHeight;
52
58
  var choiceId = showCorrectAnswer ? correctResponse[dataset.id] : data[dataset.id]; // eslint-disable-next-line react/prop-types
53
59
 
54
60
  var choice = choiceId && props.choices.find(function (c) {
@@ -61,6 +67,8 @@ var Masked = (0, _withMask.withMask)('blank', function (props) {
61
67
  duplicates: duplicates,
62
68
  choice: choice,
63
69
  id: dataset.id,
70
+ emptyResponseAreaWidth: emptyResponseAreaWidth,
71
+ emptyResponseAreaHeight: emptyResponseAreaHeight,
64
72
  onChange: onChange
65
73
  });
66
74
  }
@@ -84,14 +92,19 @@ var DragInTheBlank = /*#__PURE__*/function (_React$Component) {
84
92
  _this = _super.call.apply(_super, [this].concat(args));
85
93
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getPositionDirection", function (choicePosition) {
86
94
  var flexDirection;
95
+ var justifyContent;
96
+ var alignItems;
87
97
 
88
98
  switch (choicePosition) {
89
99
  case 'left':
90
100
  flexDirection = 'row';
101
+ alignItems = 'center';
91
102
  break;
92
103
 
93
104
  case 'right':
94
105
  flexDirection = 'row-reverse';
106
+ justifyContent = 'flex-end';
107
+ alignItems = 'center';
95
108
  break;
96
109
 
97
110
  case 'below':
@@ -104,7 +117,11 @@ var DragInTheBlank = /*#__PURE__*/function (_React$Component) {
104
117
  break;
105
118
  }
106
119
 
107
- return flexDirection;
120
+ return {
121
+ flexDirection: flexDirection,
122
+ justifyContent: justifyContent,
123
+ alignItems: alignItems
124
+ };
108
125
  });
109
126
  return _this;
110
127
  }
@@ -137,12 +154,16 @@ var DragInTheBlank = /*#__PURE__*/function (_React$Component) {
137
154
  correctResponse = _this$props.correctResponse,
138
155
  disabled = _this$props.disabled,
139
156
  feedback = _this$props.feedback,
140
- showCorrectAnswer = _this$props.showCorrectAnswer;
157
+ showCorrectAnswer = _this$props.showCorrectAnswer,
158
+ emptyResponseAreaWidth = _this$props.emptyResponseAreaWidth,
159
+ emptyResponseAreaHeight = _this$props.emptyResponseAreaHeight;
141
160
  var choicePosition = choicesPosition || 'below';
142
- var style = {
161
+
162
+ var style = _objectSpread({
143
163
  display: 'flex',
144
- flexDirection: this.getPositionDirection(choicePosition)
145
- };
164
+ minWidth: '100px'
165
+ }, this.getPositionDirection(choicePosition));
166
+
146
167
  return /*#__PURE__*/_react["default"].createElement("div", {
147
168
  ref: function ref(_ref) {
148
169
  return _ref && (_this2.rootRef = _ref);
@@ -155,6 +176,7 @@ var DragInTheBlank = /*#__PURE__*/function (_React$Component) {
155
176
  value: value,
156
177
  disabled: disabled
157
178
  }), /*#__PURE__*/_react["default"].createElement(Masked, {
179
+ elementType: 'drag-in-the-blank',
158
180
  markup: markup,
159
181
  layout: layout,
160
182
  value: value,
@@ -164,7 +186,9 @@ var DragInTheBlank = /*#__PURE__*/function (_React$Component) {
164
186
  duplicates: duplicates,
165
187
  feedback: feedback,
166
188
  correctResponse: correctResponse,
167
- showCorrectAnswer: showCorrectAnswer
189
+ showCorrectAnswer: showCorrectAnswer,
190
+ emptyResponseAreaWidth: emptyResponseAreaWidth,
191
+ emptyResponseAreaHeight: emptyResponseAreaHeight
168
192
  }));
169
193
  }
170
194
  }]);
@@ -186,6 +210,8 @@ exports["default"] = DragInTheBlank;
186
210
  disabled: _propTypes["default"].bool,
187
211
  feedback: _propTypes["default"].object,
188
212
  correctResponse: _propTypes["default"].object,
189
- showCorrectAnswer: _propTypes["default"].bool
213
+ showCorrectAnswer: _propTypes["default"].bool,
214
+ emptyResponseAreaWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
215
+ emptyResponseAreaHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number])
190
216
  });
191
- //# sourceMappingURL=drag-in-the-blank.js.map
217
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/drag-in-the-blank.jsx"],"names":["Masked","props","node","data","onChange","dataset","component","disabled","duplicates","correctResponse","feedback","showCorrectAnswer","emptyResponseAreaWidth","emptyResponseAreaHeight","choiceId","id","choice","choices","find","c","type","DragInTheBlank","choicePosition","flexDirection","justifyContent","alignItems","rootRef","markup","layout","value","choicesPosition","style","display","minWidth","getPositionDirection","ref","React","Component","PropTypes","string","object","arrayOf","shape","label","func","bool","oneOfType","number"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport Choices from './choices';\nimport Blank from './components/blank';\nimport { withMask } from './with-mask';\n\n// eslint-disable-next-line react/display-name\nconst Masked = withMask('blank', (props) => (node, data, onChange) => {\n  const dataset = node.data ? node.data.dataset || {} : {};\n  if (dataset.component === 'blank') {\n    // eslint-disable-next-line react/prop-types\n    const {\n      disabled,\n      duplicates,\n      correctResponse,\n      feedback,\n      showCorrectAnswer,\n      emptyResponseAreaWidth,\n      emptyResponseAreaHeight,\n    } = props;\n    const choiceId = showCorrectAnswer ? correctResponse[dataset.id] : data[dataset.id];\n    // eslint-disable-next-line react/prop-types\n    const choice = choiceId && props.choices.find((c) => c.id === choiceId);\n\n    return (\n      <Blank\n        key={`${node.type}-${dataset.id}`}\n        correct={showCorrectAnswer || (feedback && feedback[dataset.id])}\n        disabled={disabled}\n        duplicates={duplicates}\n        choice={choice}\n        id={dataset.id}\n        emptyResponseAreaWidth={emptyResponseAreaWidth}\n        emptyResponseAreaHeight={emptyResponseAreaHeight}\n        onChange={onChange}\n      />\n    );\n  }\n});\n\nexport default class DragInTheBlank extends React.Component {\n  static propTypes = {\n    markup: PropTypes.string,\n    layout: PropTypes.object,\n    choicesPosition: PropTypes.string,\n    choices: PropTypes.arrayOf(PropTypes.shape({ label: PropTypes.string, value: PropTypes.string })),\n    value: PropTypes.object,\n    onChange: PropTypes.func,\n    duplicates: PropTypes.bool,\n    disabled: PropTypes.bool,\n    feedback: PropTypes.object,\n    correctResponse: PropTypes.object,\n    showCorrectAnswer: PropTypes.bool,\n    emptyResponseAreaWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    emptyResponseAreaHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  };\n\n  UNSAFE_componentWillReceiveProps() {\n    if (this.rootRef) {\n      renderMath(this.rootRef);\n    }\n  }\n\n  componentDidUpdate() {\n    renderMath(this.rootRef);\n  }\n\n  getPositionDirection = (choicePosition) => {\n    let flexDirection;\n    let justifyContent;\n    let alignItems;\n\n    switch (choicePosition) {\n      case 'left':\n        flexDirection = 'row';\n        alignItems = 'center';\n        break;\n      case 'right':\n        flexDirection = 'row-reverse';\n        justifyContent = 'flex-end';\n        alignItems = 'center';\n        break;\n      case 'below':\n        flexDirection = 'column-reverse';\n        break;\n      default:\n        // above\n        flexDirection = 'column';\n        break;\n    }\n\n    return { flexDirection, justifyContent, alignItems };\n  };\n\n  render() {\n    const {\n      markup,\n      duplicates,\n      layout,\n      value,\n      onChange,\n      choicesPosition,\n      choices,\n      correctResponse,\n      disabled,\n      feedback,\n      showCorrectAnswer,\n      emptyResponseAreaWidth,\n      emptyResponseAreaHeight,\n    } = this.props;\n\n    const choicePosition = choicesPosition || 'below';\n    const style = {\n      display: 'flex',\n      minWidth: '100px',\n      ...this.getPositionDirection(choicePosition),\n    };\n\n    return (\n      <div ref={(ref) => ref && (this.rootRef = ref)} style={style}>\n        <Choices\n          choicePosition={choicePosition}\n          duplicates={duplicates}\n          choices={choices}\n          value={value}\n          disabled={disabled}\n        />\n        <Masked\n          elementType={'drag-in-the-blank'}\n          markup={markup}\n          layout={layout}\n          value={value}\n          choices={choices}\n          onChange={onChange}\n          disabled={disabled}\n          duplicates={duplicates}\n          feedback={feedback}\n          correctResponse={correctResponse}\n          showCorrectAnswer={showCorrectAnswer}\n          emptyResponseAreaWidth={emptyResponseAreaWidth}\n          emptyResponseAreaHeight={emptyResponseAreaHeight}\n        />\n      </div>\n    );\n  }\n}\n"]}
package/lib/index.js CHANGED
@@ -11,6 +11,12 @@ Object.defineProperty(exports, "ConstructedResponse", {
11
11
  return _constructedResponse["default"];
12
12
  }
13
13
  });
14
+ Object.defineProperty(exports, "Customizable", {
15
+ enumerable: true,
16
+ get: function get() {
17
+ return _customizable["default"];
18
+ }
19
+ });
14
20
  Object.defineProperty(exports, "DragInTheBlank", {
15
21
  enumerable: true,
16
22
  get: function get() {
@@ -48,7 +54,9 @@ var _dragInTheBlank = _interopRequireDefault(require("./drag-in-the-blank"));
48
54
 
49
55
  var _constructedResponse = _interopRequireDefault(require("./constructed-response"));
50
56
 
57
+ var _customizable = _interopRequireDefault(require("./customizable"));
58
+
51
59
  var _inlineDropdown = _interopRequireDefault(require("./inline-dropdown"));
52
60
 
53
61
  var _componentize = _interopRequireDefault(require("./componentize"));
54
- //# sourceMappingURL=index.js.map
62
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgd2l0aE1hc2ssIGJ1aWxkTGF5b3V0RnJvbU1hcmt1cCB9IGZyb20gJy4vd2l0aC1tYXNrJztcbmltcG9ydCBEcmFnSW5UaGVCbGFuayBmcm9tICcuL2RyYWctaW4tdGhlLWJsYW5rJztcbmltcG9ydCBDb25zdHJ1Y3RlZFJlc3BvbnNlIGZyb20gJy4vY29uc3RydWN0ZWQtcmVzcG9uc2UnO1xuaW1wb3J0IEN1c3RvbWl6YWJsZSBmcm9tICcuL2N1c3RvbWl6YWJsZSc7XG5pbXBvcnQgSW5saW5lRHJvcGRvd24gZnJvbSAnLi9pbmxpbmUtZHJvcGRvd24nO1xuaW1wb3J0IGNvbXBvbmVudGl6ZSBmcm9tICcuL2NvbXBvbmVudGl6ZSc7XG5cbmV4cG9ydCB7XG4gIHdpdGhNYXNrLFxuICBidWlsZExheW91dEZyb21NYXJrdXAsXG4gIERyYWdJblRoZUJsYW5rLFxuICBDb25zdHJ1Y3RlZFJlc3BvbnNlLFxuICBJbmxpbmVEcm9wZG93bixcbiAgY29tcG9uZW50aXplLFxuICBDdXN0b21pemFibGUsXG59O1xuIl19
@@ -33,14 +33,16 @@ var _default = (0, _withMask.withMask)('dropdown', function (props) {
33
33
  correct: feedback && feedback[dataset.id] && feedback[dataset.id] === 'correct',
34
34
  disabled: disabled || showCorrectAnswer,
35
35
  value: finalChoice,
36
+ correctValue: showCorrectAnswer ? correctAnswer && correctAnswer.label : undefined,
36
37
  id: dataset.id,
37
38
  onChange: onChange,
38
39
  choices: choices[dataset.id],
39
- showCorrectAnswer: showCorrectAnswer
40
+ showCorrectAnswer: showCorrectAnswer,
41
+ singleQuery: Object.keys(choices).length == 1
40
42
  });
41
43
  }
42
44
  };
43
45
  });
44
46
 
45
47
  exports["default"] = _default;
46
- //# sourceMappingURL=inline-dropdown.js.map
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmxpbmUtZHJvcGRvd24uanN4Il0sIm5hbWVzIjpbInByb3BzIiwibm9kZSIsImRhdGEiLCJvbkNoYW5nZSIsImRhdGFzZXQiLCJjb21wb25lbnQiLCJjaG9pY2VzIiwiZGlzYWJsZWQiLCJmZWVkYmFjayIsInNob3dDb3JyZWN0QW5zd2VyIiwiY29ycmVjdEFuc3dlciIsImlkIiwiZmluZCIsImMiLCJjb3JyZWN0IiwiZmluYWxDaG9pY2UiLCJ2YWx1ZSIsInR5cGUiLCJsYWJlbCIsInVuZGVmaW5lZCIsIk9iamVjdCIsImtleXMiLCJsZW5ndGgiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUVBO2VBQ2Usd0JBQVMsVUFBVCxFQUFxQixVQUFDQSxLQUFEO0FBQUEsU0FBVyxVQUFDQyxJQUFELEVBQU9DLElBQVAsRUFBYUMsUUFBYixFQUEwQjtBQUN2RSxRQUFNQyxPQUFPLEdBQUdILElBQUksQ0FBQ0MsSUFBTCxHQUFZRCxJQUFJLENBQUNDLElBQUwsQ0FBVUUsT0FBVixJQUFxQixFQUFqQyxHQUFzQyxFQUF0RDs7QUFDQSxRQUFJQSxPQUFPLENBQUNDLFNBQVIsS0FBc0IsVUFBMUIsRUFBc0M7QUFDcEM7QUFDQSxVQUFRQyxPQUFSLEdBQTJETixLQUEzRCxDQUFRTSxPQUFSO0FBQUEsVUFBaUJDLFFBQWpCLEdBQTJEUCxLQUEzRCxDQUFpQk8sUUFBakI7QUFBQSxVQUEyQkMsUUFBM0IsR0FBMkRSLEtBQTNELENBQTJCUSxRQUEzQjtBQUFBLFVBQXFDQyxpQkFBckMsR0FBMkRULEtBQTNELENBQXFDUyxpQkFBckM7QUFDQSxVQUFNQyxhQUFhLEdBQUdKLE9BQU8sSUFBSUEsT0FBTyxDQUFDRixPQUFPLENBQUNPLEVBQVQsQ0FBbEIsSUFBa0NMLE9BQU8sQ0FBQ0YsT0FBTyxDQUFDTyxFQUFULENBQVAsQ0FBb0JDLElBQXBCLENBQXlCLFVBQUNDLENBQUQ7QUFBQSxlQUFPQSxDQUFDLENBQUNDLE9BQVQ7QUFBQSxPQUF6QixDQUF4RDtBQUNBLFVBQU1DLFdBQVcsR0FBR04saUJBQWlCLEdBQUdDLGFBQWEsSUFBSUEsYUFBYSxDQUFDTSxLQUFsQyxHQUEwQ2QsSUFBSSxDQUFDRSxPQUFPLENBQUNPLEVBQVQsQ0FBbkY7QUFFQSwwQkFDRSxnQ0FBQyxvQkFBRDtBQUNFLFFBQUEsR0FBRyxZQUFLVixJQUFJLENBQUNnQixJQUFWLHVCQUEyQmIsT0FBTyxDQUFDTyxFQUFuQyxDQURMO0FBRUUsUUFBQSxPQUFPLEVBQUVILFFBQVEsSUFBSUEsUUFBUSxDQUFDSixPQUFPLENBQUNPLEVBQVQsQ0FBcEIsSUFBb0NILFFBQVEsQ0FBQ0osT0FBTyxDQUFDTyxFQUFULENBQVIsS0FBeUIsU0FGeEU7QUFHRSxRQUFBLFFBQVEsRUFBRUosUUFBUSxJQUFJRSxpQkFIeEI7QUFJRSxRQUFBLEtBQUssRUFBRU0sV0FKVDtBQUtFLFFBQUEsWUFBWSxFQUFFTixpQkFBaUIsR0FBR0MsYUFBYSxJQUFJQSxhQUFhLENBQUNRLEtBQWxDLEdBQTBDQyxTQUwzRTtBQU1FLFFBQUEsRUFBRSxFQUFFZixPQUFPLENBQUNPLEVBTmQ7QUFPRSxRQUFBLFFBQVEsRUFBRVIsUUFQWjtBQVFFLFFBQUEsT0FBTyxFQUFFRyxPQUFPLENBQUNGLE9BQU8sQ0FBQ08sRUFBVCxDQVJsQjtBQVNFLFFBQUEsaUJBQWlCLEVBQUVGLGlCQVRyQjtBQVVFLFFBQUEsV0FBVyxFQUFFVyxNQUFNLENBQUNDLElBQVAsQ0FBWWYsT0FBWixFQUFxQmdCLE1BQXJCLElBQStCO0FBVjlDLFFBREY7QUFjRDtBQUNGLEdBdkJtQztBQUFBLENBQXJCLEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IERyb3Bkb3duIGZyb20gJy4vY29tcG9uZW50cy9kcm9wZG93bic7XG5pbXBvcnQgeyB3aXRoTWFzayB9IGZyb20gJy4vd2l0aC1tYXNrJztcblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0L2Rpc3BsYXktbmFtZVxuZXhwb3J0IGRlZmF1bHQgd2l0aE1hc2soJ2Ryb3Bkb3duJywgKHByb3BzKSA9PiAobm9kZSwgZGF0YSwgb25DaGFuZ2UpID0+IHtcbiAgY29uc3QgZGF0YXNldCA9IG5vZGUuZGF0YSA/IG5vZGUuZGF0YS5kYXRhc2V0IHx8IHt9IDoge307XG4gIGlmIChkYXRhc2V0LmNvbXBvbmVudCA9PT0gJ2Ryb3Bkb3duJykge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9wcm9wLXR5cGVzXG4gICAgY29uc3QgeyBjaG9pY2VzLCBkaXNhYmxlZCwgZmVlZGJhY2ssIHNob3dDb3JyZWN0QW5zd2VyIH0gPSBwcm9wcztcbiAgICBjb25zdCBjb3JyZWN0QW5zd2VyID0gY2hvaWNlcyAmJiBjaG9pY2VzW2RhdGFzZXQuaWRdICYmIGNob2ljZXNbZGF0YXNldC5pZF0uZmluZCgoYykgPT4gYy5jb3JyZWN0KTtcbiAgICBjb25zdCBmaW5hbENob2ljZSA9IHNob3dDb3JyZWN0QW5zd2VyID8gY29ycmVjdEFuc3dlciAmJiBjb3JyZWN0QW5zd2VyLnZhbHVlIDogZGF0YVtkYXRhc2V0LmlkXTtcblxuICAgIHJldHVybiAoXG4gICAgICA8RHJvcGRvd25cbiAgICAgICAga2V5PXtgJHtub2RlLnR5cGV9LWRyb3Bkb3duLSR7ZGF0YXNldC5pZH1gfVxuICAgICAgICBjb3JyZWN0PXtmZWVkYmFjayAmJiBmZWVkYmFja1tkYXRhc2V0LmlkXSAmJiBmZWVkYmFja1tkYXRhc2V0LmlkXSA9PT0gJ2NvcnJlY3QnfVxuICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWQgfHwgc2hvd0NvcnJlY3RBbnN3ZXJ9XG4gICAgICAgIHZhbHVlPXtmaW5hbENob2ljZX1cbiAgICAgICAgY29ycmVjdFZhbHVlPXtzaG93Q29ycmVjdEFuc3dlciA/IGNvcnJlY3RBbnN3ZXIgJiYgY29ycmVjdEFuc3dlci5sYWJlbCA6IHVuZGVmaW5lZH1cbiAgICAgICAgaWQ9e2RhdGFzZXQuaWR9XG4gICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgY2hvaWNlcz17Y2hvaWNlc1tkYXRhc2V0LmlkXX1cbiAgICAgICAgc2hvd0NvcnJlY3RBbnN3ZXI9e3Nob3dDb3JyZWN0QW5zd2VyfVxuICAgICAgICBzaW5nbGVRdWVyeT17T2JqZWN0LmtleXMoY2hvaWNlcykubGVuZ3RoID09IDF9XG4gICAgICAvPlxuICAgICk7XG4gIH1cbn0pO1xuIl19
package/lib/mask.js CHANGED
@@ -33,6 +33,8 @@ var _styles = require("@material-ui/core/styles");
33
33
 
34
34
  var _serialization = require("./serialization");
35
35
 
36
+ var _classnames = _interopRequireDefault(require("classnames"));
37
+
36
38
  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
39
 
38
40
  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; }
@@ -53,6 +55,18 @@ var Paragraph = (0, _styles.withStyles)(function (theme) {
53
55
  className: props.classes.para
54
56
  }, props.children);
55
57
  });
58
+ var Spacer = (0, _styles.withStyles)(function () {
59
+ return {
60
+ spacer: {
61
+ display: 'inline-block',
62
+ width: '.75em'
63
+ }
64
+ };
65
+ })(function (props) {
66
+ return /*#__PURE__*/_react["default"].createElement("span", {
67
+ className: props.classes.spacer
68
+ });
69
+ });
56
70
  var restrictWhitespaceTypes = ['tbody', 'tr'];
57
71
 
58
72
  var addText = function addText(parentNode, text) {
@@ -78,7 +92,7 @@ var getMark = function getMark(n) {
78
92
  return null;
79
93
  };
80
94
 
81
- var renderChildren = function renderChildren(layout, value, onChange, rootRenderChildren, parentNode) {
95
+ var renderChildren = function renderChildren(layout, value, onChange, rootRenderChildren, parentNode, elementType) {
82
96
  if (!value) {
83
97
  return null;
84
98
  }
@@ -101,6 +115,13 @@ var renderChildren = function renderChildren(layout, value, onChange, rootRender
101
115
 
102
116
  if (c) {
103
117
  children.push(c);
118
+
119
+ if ((parentNode === null || parentNode === void 0 ? void 0 : parentNode.type) !== 'td' && elementType === 'drag-in-the-blank') {
120
+ children.push( /*#__PURE__*/_react["default"].createElement(Spacer, {
121
+ key: "spacer-".concat(index)
122
+ }));
123
+ }
124
+
104
125
  return;
105
126
  }
106
127
  }
@@ -127,9 +148,15 @@ var renderChildren = function renderChildren(layout, value, onChange, rootRender
127
148
  }
128
149
  } else if (content.length > 0) {
129
150
  children.push(content);
151
+
152
+ if ((parentNode === null || parentNode === void 0 ? void 0 : parentNode.type) !== 'td' && elementType === 'drag-in-the-blank') {
153
+ children.push( /*#__PURE__*/_react["default"].createElement(Spacer, {
154
+ key: "spacer-".concat(index)
155
+ }));
156
+ }
130
157
  }
131
158
  } else {
132
- var subNodes = renderChildren(n, value, onChange, rootRenderChildren, n);
159
+ var subNodes = renderChildren(n, value, onChange, rootRenderChildren, n, elementType);
133
160
 
134
161
  if (n.type === 'p' || n.type === 'paragraph') {
135
162
  children.push( /*#__PURE__*/_react["default"].createElement(Paragraph, {
@@ -158,11 +185,21 @@ var MaskContainer = (0, _styles.withStyles)(function () {
158
185
  return {
159
186
  main: {
160
187
  display: 'initial'
188
+ },
189
+ tableStyle: {
190
+ '&:not(.MathJax) table': {
191
+ borderCollapse: 'collapse'
192
+ },
193
+ // align table content to left as per STAR requirement PD-3687
194
+ '&:not(.MathJax) table td, &:not(.MathJax) table th': {
195
+ padding: '8px 12px',
196
+ textAlign: 'left'
197
+ }
161
198
  }
162
199
  };
163
200
  })(function (props) {
164
201
  return /*#__PURE__*/_react["default"].createElement("div", {
165
- className: props.classes.main
202
+ className: (0, _classnames["default"])(props.classes.main, props.classes.tableStyle)
166
203
  }, props.children);
167
204
  });
168
205
  /**
@@ -197,8 +234,9 @@ var Mask = /*#__PURE__*/function (_React$Component) {
197
234
  value: function render() {
198
235
  var _this$props = this.props,
199
236
  value = _this$props.value,
200
- layout = _this$props.layout;
201
- var children = renderChildren(layout, value, this.handleChange, this.props.renderChildren);
237
+ layout = _this$props.layout,
238
+ elementType = _this$props.elementType;
239
+ var children = renderChildren(layout, value, this.handleChange, this.props.renderChildren, null, elementType);
202
240
  return /*#__PURE__*/_react["default"].createElement(MaskContainer, null, children);
203
241
  }
204
242
  }]);
@@ -210,6 +248,7 @@ exports["default"] = Mask;
210
248
  renderChildren: _propTypes["default"].func,
211
249
  layout: _propTypes["default"].object,
212
250
  value: _propTypes["default"].object,
213
- onChange: _propTypes["default"].func
251
+ onChange: _propTypes["default"].func,
252
+ elementType: _propTypes["default"].string
214
253
  });
215
- //# sourceMappingURL=mask.js.map
254
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/mask.jsx"],"names":["Paragraph","theme","para","paddingTop","spacing","unit","paddingBottom","props","classes","children","Spacer","spacer","display","width","restrictWhitespaceTypes","addText","parentNode","text","isWhitespace","trim","parentType","type","includes","undefined","getMark","n","mark","leaves","find","leave","length","marks","renderChildren","layout","value","onChange","rootRenderChildren","elementType","nodes","forEach","index","key","isMath","push","__html","innerHTML","c","object","content","reduce","acc","l","t","extraText","markKey","MARK_TAGS","Tag","subNodes","data","attributes","MaskContainer","main","tableStyle","borderCollapse","padding","textAlign","Mask","id","handleChange","React","Component","PropTypes","func","string"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport get from 'lodash/get';\nimport { withStyles } from '@material-ui/core/styles';\nimport { MARK_TAGS } from './serialization';\nimport cx from 'classnames';\n\nconst Paragraph = withStyles((theme) => ({\n  para: {\n    paddingTop: 2 * theme.spacing.unit,\n    paddingBottom: 2 * theme.spacing.unit,\n  },\n}))((props) => <div className={props.classes.para}>{props.children}</div>);\n\nconst Spacer = withStyles(() => ({\n  spacer: {\n    display: 'inline-block',\n    width: '.75em',\n  },\n}))((props) => <span className={props.classes.spacer} />);\n\nconst restrictWhitespaceTypes = ['tbody', 'tr'];\n\nconst addText = (parentNode, text) => {\n  const isWhitespace = text.trim() === '';\n  const parentType = parentNode && parentNode.type;\n\n  if (isWhitespace && restrictWhitespaceTypes.includes(parentType)) {\n    return undefined;\n  } else {\n    return text;\n  }\n};\n\nconst getMark = (n) => {\n  const mark = n.leaves.find((leave) => get(leave, 'marks', []).length);\n\n  if (mark) {\n    return mark.marks[0];\n  }\n\n  return null;\n};\n\nexport const renderChildren = (layout, value, onChange, rootRenderChildren, parentNode, elementType) => {\n  if (!value) {\n    return null;\n  }\n\n  const children = [];\n\n  (layout.nodes || []).forEach((n, index) => {\n    const key = n.type ? `${n.type}-${index}` : `${index}`;\n\n    if (n.isMath) {\n      children.push(\n        <span\n          dangerouslySetInnerHTML={{\n            __html: `<math displaystyle=\"true\">${n.nodes[0].innerHTML}</math>`,\n          }}\n        />,\n      );\n      return children;\n    }\n\n    if (rootRenderChildren) {\n      const c = rootRenderChildren(n, value, onChange);\n      if (c) {\n        children.push(c);\n        if (parentNode?.type !== 'td' && elementType === 'drag-in-the-blank') {\n          children.push(<Spacer key={`spacer-${index}`} />);\n        }\n        return;\n      }\n    }\n\n    if (n.object === 'text') {\n      const content = n.leaves.reduce((acc, l) => {\n        const t = l.text;\n        const extraText = addText(parentNode, t);\n        return extraText ? acc + extraText : acc;\n      }, '');\n      const mark = getMark(n);\n\n      if (mark) {\n        let markKey;\n\n        for (markKey in MARK_TAGS) {\n          if (MARK_TAGS[markKey] === mark.type) {\n            const Tag = markKey;\n\n            children.push(<Tag key={key}>{content}</Tag>);\n            break;\n          }\n        }\n      } else if (content.length > 0) {\n        children.push(content);\n        if (parentNode?.type !== 'td' && elementType === 'drag-in-the-blank') {\n          children.push(<Spacer key={`spacer-${index}`} />);\n        }\n      }\n    } else {\n      const subNodes = renderChildren(n, value, onChange, rootRenderChildren, n, elementType);\n      if (n.type === 'p' || n.type === 'paragraph') {\n        children.push(<Paragraph key={key}>{subNodes}</Paragraph>);\n      } else {\n        const Tag = n.type;\n        if (n.nodes && n.nodes.length > 0) {\n          children.push(\n            <Tag key={key} {...n.data.attributes}>\n              {subNodes}\n            </Tag>,\n          );\n        } else {\n          children.push(<Tag key={key} {...n.data.attributes} />);\n        }\n      }\n    }\n  });\n  return children;\n};\n\nconst MaskContainer = withStyles(() => ({\n  main: {\n    display: 'initial',\n  },\n  tableStyle: {\n    '&:not(.MathJax) table': {\n      borderCollapse: 'collapse',\n    },\n    // align table content to left as per STAR requirement PD-3687\n    '&:not(.MathJax) table td, &:not(.MathJax) table th': {\n      padding: '8px 12px',\n      textAlign: 'left',\n    },\n  },\n}))((props) => <div className={cx(props.classes.main, props.classes.tableStyle)}>{props.children}</div>);\n\n/**\n * Renders a layout that uses the slate.js Value model structure.\n */\nexport default class Mask extends React.Component {\n  static propTypes = {\n    renderChildren: PropTypes.func,\n    layout: PropTypes.object,\n    value: PropTypes.object,\n    onChange: PropTypes.func,\n    elementType: PropTypes.string,\n  };\n\n  handleChange = (id, value) => {\n    const data = { ...this.props.value, [id]: value };\n    this.props.onChange(data);\n  };\n\n  render() {\n    const { value, layout, elementType } = this.props;\n    const children = renderChildren(layout, value, this.handleChange, this.props.renderChildren, null, elementType);\n\n    return <MaskContainer>{children}</MaskContainer>;\n  }\n}\n"]}
@@ -204,4 +204,4 @@ var deserialize = function deserialize(s) {
204
204
  };
205
205
 
206
206
  exports.deserialize = deserialize;
207
- //# sourceMappingURL=serialization.js.map
207
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/serialization.js"],"names":["log","INLINE","MARK","TEXT_NODE","COMMENT_NODE","attr","el","attributes","length","undefined","out","i","a","name","value","getObject","type","includes","parseStyleString","s","regex","match","result","exec","trim","reactAttributes","o","camelize","addUnits","handleStyles","attribute","styleString","getAttribute","handleClass","acc","classNames","attributesToMap","style","className","MARK_TAGS","b","em","u","code","strong","marks","deserialize","next","mark","tagName","toLowerCase","object","nodes","childNodes","rules","nodeType","leaves","text","textContent","normalAttrs","controls","allAttrs","reduce","isMath","data","dataset","html","Html","defaultBlock","toJSON"],"mappings":"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","sourcesContent":["import Html from 'slate-html-serializer';\nimport { object as toStyleObject } from 'to-style';\nimport debug from 'debug';\n\nconst log = debug('@pie-lib:mask-markup:serialization');\n\nconst INLINE = ['span'];\nconst MARK = ['em', 'strong', 'u'];\nconst TEXT_NODE = 3;\nconst COMMENT_NODE = 8;\n\nconst attr = (el) => {\n  if (!el.attributes || el.attributes.length <= 0) {\n    return undefined;\n  }\n\n  const out = {};\n  let i;\n\n  for (i = 0; i < el.attributes.length; i++) {\n    const a = el.attributes[i];\n\n    out[a.name] = a.value;\n  }\n\n  return out;\n};\n\nconst getObject = (type) => {\n  if (INLINE.includes(type)) {\n    return 'inline';\n  } else if (MARK.includes(type)) {\n    return 'mark';\n  }\n  return 'block';\n};\n\nexport const parseStyleString = (s) => {\n  const regex = /([\\w-]*)\\s*:\\s*([^;]*)/g;\n  let match;\n  const result = {};\n  while ((match = regex.exec(s))) {\n    result[match[1]] = match[2].trim();\n  }\n  return result;\n};\n\nexport const reactAttributes = (o) => toStyleObject(o, { camelize: true, addUnits: false });\n\nconst handleStyles = (el, attribute) => {\n  const styleString = el.getAttribute(attribute);\n\n  return reactAttributes(parseStyleString(styleString));\n};\n\nconst handleClass = (el, acc, attribute) => {\n  const classNames = el.getAttribute(attribute);\n\n  delete acc.class;\n\n  return classNames;\n};\n\nconst attributesToMap = (el) => (acc, attribute) => {\n  if (!el.getAttribute) {\n    return acc;\n  }\n\n  const value = el.getAttribute(attribute);\n\n  if (value) {\n    switch (attribute) {\n      case 'style':\n        acc.style = handleStyles(el, attribute);\n        break;\n      case 'class':\n        acc.className = handleClass(el, acc, attribute);\n        break;\n      default:\n        acc[attribute] = el.getAttribute(attribute);\n        break;\n    }\n  }\n\n  return acc;\n};\n\nconst attributes = ['border', 'class', 'style'];\n\n/**\n * Tags to marks.\n *\n * @type {Object}\n */\n\nexport const MARK_TAGS = {\n  b: 'bold',\n  em: 'italic',\n  u: 'underline',\n  s: 'strikethrough',\n  code: 'code',\n  strong: 'strong',\n};\n\nconst marks = {\n  deserialize(el, next) {\n    const mark = MARK_TAGS[el.tagName.toLowerCase()];\n    if (!mark) return;\n    log('[deserialize] mark: ', mark);\n    return {\n      object: 'mark',\n      type: mark,\n      nodes: next(el.childNodes),\n    };\n  },\n};\n\nconst rules = [\n  marks,\n  {\n    /**\n     * deserialize everything, we're not fussy about the dom structure for now.\n     */\n    deserialize: (el, next) => {\n      if (el.nodeType === COMMENT_NODE) {\n        return undefined;\n      }\n\n      if (el.nodeType === TEXT_NODE) {\n        return {\n          object: 'text',\n          leaves: [{ text: el.textContent }],\n        };\n      }\n\n      const type = el.tagName.toLowerCase();\n\n      const normalAttrs = attr(el) || {};\n\n      if (type == 'audio' && normalAttrs.controls == '') {\n        normalAttrs.controls = true;\n      }\n\n      const allAttrs = attributes.reduce(attributesToMap(el), { ...normalAttrs });\n      const object = getObject(type);\n\n      if (el.tagName.toLowerCase() === 'math') {\n        return {\n          isMath: true,\n          nodes: [el],\n        };\n      }\n\n      return {\n        object,\n        type,\n        data: { dataset: { ...el.dataset }, attributes: { ...allAttrs } },\n        nodes: next(el.childNodes),\n      };\n    },\n  },\n];\n\n/**\n * Create a new serializer instance with our `rules` from above.\n * Having a default div block will just put every div on it's own line, which is not ideal.\n */\nconst html = new Html({ rules, defaultBlock: 'span' });\n\nexport const deserialize = (s) => html.deserialize(s, { toJSON: true });"]}
package/lib/with-mask.js CHANGED
@@ -21,6 +21,8 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
21
21
 
22
22
  var _react = _interopRequireDefault(require("react"));
23
23
 
24
+ var _reactDom = _interopRequireDefault(require("react-dom"));
25
+
24
26
  var _propTypes = _interopRequireDefault(require("prop-types"));
25
27
 
26
28
  var _mask = _interopRequireDefault(require("./mask"));
@@ -57,15 +59,43 @@ var withMask = function withMask(type, renderChildren) {
57
59
  }
58
60
 
59
61
  (0, _createClass2["default"])(WithMask, [{
62
+ key: "componentDidUpdate",
63
+ value: function componentDidUpdate(prevProps) {
64
+ if (this.props.markup !== prevProps.markup) {
65
+ // eslint-disable-next-line
66
+ var domNode = _reactDom["default"].findDOMNode(this); // Query all elements that may contain outdated MathJax renderings
67
+
68
+
69
+ var mathElements = domNode && domNode.querySelectorAll('[data-latex][data-math-handled="true"]'); // Clean up for fresh MathJax processing
70
+
71
+ (mathElements || []).forEach(function (el) {
72
+ // Remove the MathJax container to allow for clean updates
73
+ var mjxContainer = el.querySelector('mjx-container');
74
+
75
+ if (mjxContainer) {
76
+ el.removeChild(mjxContainer);
77
+ } // Update the innerHTML to match the raw LaTeX data, ensuring it is reprocessed correctly
78
+
79
+
80
+ var latexCode = el.getAttribute('data-raw');
81
+ el.innerHTML = latexCode; // Remove the attribute to signal that MathJax should reprocess this element
82
+
83
+ el.removeAttribute('data-math-handled');
84
+ });
85
+ }
86
+ }
87
+ }, {
60
88
  key: "render",
61
89
  value: function render() {
62
90
  var _this$props = this.props,
63
91
  markup = _this$props.markup,
64
92
  layout = _this$props.layout,
65
93
  value = _this$props.value,
66
- onChange = _this$props.onChange;
94
+ onChange = _this$props.onChange,
95
+ elementType = _this$props.elementType;
67
96
  var maskLayout = layout ? layout : buildLayoutFromMarkup(markup, type);
68
97
  return /*#__PURE__*/_react["default"].createElement(_mask["default"], {
98
+ elementType: elementType,
69
99
  layout: maskLayout,
70
100
  value: value,
71
101
  onChange: onChange,
@@ -85,9 +115,11 @@ var withMask = function withMask(type, renderChildren) {
85
115
  */
86
116
  layout: _propTypes["default"].object,
87
117
  value: _propTypes["default"].object,
88
- onChange: _propTypes["default"].func
118
+ onChange: _propTypes["default"].func,
119
+ customMarkMarkupComponent: _propTypes["default"].func,
120
+ elementType: _propTypes["default"].string
89
121
  }), _class;
90
122
  };
91
123
 
92
124
  exports.withMask = withMask;
93
- //# sourceMappingURL=with-mask.js.map
125
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy93aXRoLW1hc2suanN4Il0sIm5hbWVzIjpbImJ1aWxkTGF5b3V0RnJvbU1hcmt1cCIsIm1hcmt1cCIsInR5cGUiLCJwcm9jZXNzZWQiLCJ2YWx1ZSIsImRvY3VtZW50Iiwid2l0aE1hc2siLCJyZW5kZXJDaGlsZHJlbiIsInByZXZQcm9wcyIsInByb3BzIiwiZG9tTm9kZSIsIlJlYWN0RE9NIiwiZmluZERPTU5vZGUiLCJtYXRoRWxlbWVudHMiLCJxdWVyeVNlbGVjdG9yQWxsIiwiZm9yRWFjaCIsImVsIiwibWp4Q29udGFpbmVyIiwicXVlcnlTZWxlY3RvciIsInJlbW92ZUNoaWxkIiwibGF0ZXhDb2RlIiwiZ2V0QXR0cmlidXRlIiwiaW5uZXJIVE1MIiwicmVtb3ZlQXR0cmlidXRlIiwibGF5b3V0Iiwib25DaGFuZ2UiLCJlbGVtZW50VHlwZSIsIm1hc2tMYXlvdXQiLCJSZWFjdCIsIkNvbXBvbmVudCIsIlByb3BUeXBlcyIsInN0cmluZyIsIm9iamVjdCIsImZ1bmMiLCJjdXN0b21NYXJrTWFya3VwQ29tcG9uZW50Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7O0FBRU8sSUFBTUEscUJBQXFCLEdBQUcsU0FBeEJBLHFCQUF3QixDQUFDQyxNQUFELEVBQVNDLElBQVQsRUFBa0I7QUFDckQsc0JBQThCLCtCQUFhRCxNQUFiLEVBQXFCQyxJQUFyQixDQUE5QjtBQUFBLE1BQWdCQyxTQUFoQixpQkFBUUYsTUFBUjs7QUFDQSxNQUFNRyxLQUFLLEdBQUcsZ0NBQVlELFNBQVosQ0FBZDtBQUNBLFNBQU9DLEtBQUssQ0FBQ0MsUUFBYjtBQUNELENBSk07Ozs7QUFNQSxJQUFNQyxRQUFRLEdBQUcsU0FBWEEsUUFBVyxDQUFDSixJQUFELEVBQU9LLGNBQVAsRUFBMEI7QUFBQTs7QUFDaEQ7QUFBQTs7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFBQTtBQUFBO0FBQUEsYUFnQkUsNEJBQW1CQyxTQUFuQixFQUE4QjtBQUM1QixZQUFJLEtBQUtDLEtBQUwsQ0FBV1IsTUFBWCxLQUFzQk8sU0FBUyxDQUFDUCxNQUFwQyxFQUE0QztBQUMxQztBQUNBLGNBQU1TLE9BQU8sR0FBR0MscUJBQVNDLFdBQVQsQ0FBcUIsSUFBckIsQ0FBaEIsQ0FGMEMsQ0FHMUM7OztBQUNBLGNBQU1DLFlBQVksR0FBR0gsT0FBTyxJQUFJQSxPQUFPLENBQUNJLGdCQUFSLENBQXlCLHdDQUF6QixDQUFoQyxDQUowQyxDQU0xQzs7QUFDQSxXQUFDRCxZQUFZLElBQUksRUFBakIsRUFBcUJFLE9BQXJCLENBQTZCLFVBQUNDLEVBQUQsRUFBUTtBQUNuQztBQUNBLGdCQUFNQyxZQUFZLEdBQUdELEVBQUUsQ0FBQ0UsYUFBSCxDQUFpQixlQUFqQixDQUFyQjs7QUFFQSxnQkFBSUQsWUFBSixFQUFrQjtBQUNoQkQsY0FBQUEsRUFBRSxDQUFDRyxXQUFILENBQWVGLFlBQWY7QUFDRCxhQU5rQyxDQVFuQzs7O0FBQ0EsZ0JBQU1HLFNBQVMsR0FBR0osRUFBRSxDQUFDSyxZQUFILENBQWdCLFVBQWhCLENBQWxCO0FBQ0FMLFlBQUFBLEVBQUUsQ0FBQ00sU0FBSCxHQUFlRixTQUFmLENBVm1DLENBWW5DOztBQUNBSixZQUFBQSxFQUFFLENBQUNPLGVBQUgsQ0FBbUIsbUJBQW5CO0FBQ0QsV0FkRDtBQWVEO0FBQ0Y7QUF4Q0g7QUFBQTtBQUFBLGFBMENFLGtCQUFTO0FBQ1AsMEJBQXlELEtBQUtkLEtBQTlEO0FBQUEsWUFBUVIsTUFBUixlQUFRQSxNQUFSO0FBQUEsWUFBZ0J1QixNQUFoQixlQUFnQkEsTUFBaEI7QUFBQSxZQUF3QnBCLEtBQXhCLGVBQXdCQSxLQUF4QjtBQUFBLFlBQStCcUIsUUFBL0IsZUFBK0JBLFFBQS9CO0FBQUEsWUFBeUNDLFdBQXpDLGVBQXlDQSxXQUF6QztBQUVBLFlBQU1DLFVBQVUsR0FBR0gsTUFBTSxHQUFHQSxNQUFILEdBQVl4QixxQkFBcUIsQ0FBQ0MsTUFBRCxFQUFTQyxJQUFULENBQTFEO0FBQ0EsNEJBQ0UsZ0NBQUMsZ0JBQUQ7QUFDRSxVQUFBLFdBQVcsRUFBRXdCLFdBRGY7QUFFRSxVQUFBLE1BQU0sRUFBRUMsVUFGVjtBQUdFLFVBQUEsS0FBSyxFQUFFdkIsS0FIVDtBQUlFLFVBQUEsUUFBUSxFQUFFcUIsUUFKWjtBQUtFLFVBQUEsY0FBYyxFQUFFbEIsY0FBYyxDQUFDLEtBQUtFLEtBQU47QUFMaEMsVUFERjtBQVNEO0FBdkRIO0FBQUE7QUFBQSxJQUE4Qm1CLGtCQUFNQyxTQUFwQyx5REFDcUI7QUFDakI7QUFDTjtBQUNBO0FBQ001QixJQUFBQSxNQUFNLEVBQUU2QixzQkFBVUMsTUFKRDs7QUFLakI7QUFDTjtBQUNBO0FBQ01QLElBQUFBLE1BQU0sRUFBRU0sc0JBQVVFLE1BUkQ7QUFTakI1QixJQUFBQSxLQUFLLEVBQUUwQixzQkFBVUUsTUFUQTtBQVVqQlAsSUFBQUEsUUFBUSxFQUFFSyxzQkFBVUcsSUFWSDtBQVdqQkMsSUFBQUEseUJBQXlCLEVBQUVKLHNCQUFVRyxJQVhwQjtBQVlqQlAsSUFBQUEsV0FBVyxFQUFFSSxzQkFBVUM7QUFaTixHQURyQjtBQXlERCxDQTFETSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUmVhY3RET00gZnJvbSAncmVhY3QtZG9tJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgTWFzayBmcm9tICcuL21hc2snO1xuaW1wb3J0IGNvbXBvbmVudGl6ZSBmcm9tICcuL2NvbXBvbmVudGl6ZSc7XG5pbXBvcnQgeyBkZXNlcmlhbGl6ZSB9IGZyb20gJy4vc2VyaWFsaXphdGlvbic7XG5cbmV4cG9ydCBjb25zdCBidWlsZExheW91dEZyb21NYXJrdXAgPSAobWFya3VwLCB0eXBlKSA9PiB7XG4gIGNvbnN0IHsgbWFya3VwOiBwcm9jZXNzZWQgfSA9IGNvbXBvbmVudGl6ZShtYXJrdXAsIHR5cGUpO1xuICBjb25zdCB2YWx1ZSA9IGRlc2VyaWFsaXplKHByb2Nlc3NlZCk7XG4gIHJldHVybiB2YWx1ZS5kb2N1bWVudDtcbn07XG5cbmV4cG9ydCBjb25zdCB3aXRoTWFzayA9ICh0eXBlLCByZW5kZXJDaGlsZHJlbikgPT4ge1xuICByZXR1cm4gY2xhc3MgV2l0aE1hc2sgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICAgIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgICAvKipcbiAgICAgICAqIEF0IHRoZSBzdGFydCB3ZSdsbCBwcm9iYWJseSB3b3JrIHdpdGggbWFya3VwXG4gICAgICAgKi9cbiAgICAgIG1hcmt1cDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICAgIC8qKlxuICAgICAgICogT25jZSB3ZSBzdGFydCBhdXRob3JpbmcsIGl0IG1heSBtYWtlIHNlbnNlIGZvciB1c2UgdG8gdXMgbGF5b3V0LCB3aGljaCB3aWxsIGJlIGEgc2ltcGxlIGpzIG9iamVjdCB0aGF0IG1hcHMgdG8gYHNsYXRlLlZhbHVlYC5cbiAgICAgICAqL1xuICAgICAgbGF5b3V0OiBQcm9wVHlwZXMub2JqZWN0LFxuICAgICAgdmFsdWU6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMsXG4gICAgICBjdXN0b21NYXJrTWFya3VwQ29tcG9uZW50OiBQcm9wVHlwZXMuZnVuYyxcbiAgICAgIGVsZW1lbnRUeXBlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIH07XG5cbiAgICBjb21wb25lbnREaWRVcGRhdGUocHJldlByb3BzKSB7XG4gICAgICBpZiAodGhpcy5wcm9wcy5tYXJrdXAgIT09IHByZXZQcm9wcy5tYXJrdXApIHtcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgICAgIGNvbnN0IGRvbU5vZGUgPSBSZWFjdERPTS5maW5kRE9NTm9kZSh0aGlzKTtcbiAgICAgICAgLy8gUXVlcnkgYWxsIGVsZW1lbnRzIHRoYXQgbWF5IGNvbnRhaW4gb3V0ZGF0ZWQgTWF0aEpheCByZW5kZXJpbmdzXG4gICAgICAgIGNvbnN0IG1hdGhFbGVtZW50cyA9IGRvbU5vZGUgJiYgZG9tTm9kZS5xdWVyeVNlbGVjdG9yQWxsKCdbZGF0YS1sYXRleF1bZGF0YS1tYXRoLWhhbmRsZWQ9XCJ0cnVlXCJdJyk7XG5cbiAgICAgICAgLy8gQ2xlYW4gdXAgZm9yIGZyZXNoIE1hdGhKYXggcHJvY2Vzc2luZ1xuICAgICAgICAobWF0aEVsZW1lbnRzIHx8IFtdKS5mb3JFYWNoKChlbCkgPT4ge1xuICAgICAgICAgIC8vIFJlbW92ZSB0aGUgTWF0aEpheCBjb250YWluZXIgdG8gYWxsb3cgZm9yIGNsZWFuIHVwZGF0ZXNcbiAgICAgICAgICBjb25zdCBtanhDb250YWluZXIgPSBlbC5xdWVyeVNlbGVjdG9yKCdtangtY29udGFpbmVyJyk7XG5cbiAgICAgICAgICBpZiAobWp4Q29udGFpbmVyKSB7XG4gICAgICAgICAgICBlbC5yZW1vdmVDaGlsZChtanhDb250YWluZXIpO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIC8vIFVwZGF0ZSB0aGUgaW5uZXJIVE1MIHRvIG1hdGNoIHRoZSByYXcgTGFUZVggZGF0YSwgZW5zdXJpbmcgaXQgaXMgcmVwcm9jZXNzZWQgY29ycmVjdGx5XG4gICAgICAgICAgY29uc3QgbGF0ZXhDb2RlID0gZWwuZ2V0QXR0cmlidXRlKCdkYXRhLXJhdycpO1xuICAgICAgICAgIGVsLmlubmVySFRNTCA9IGxhdGV4Q29kZTtcblxuICAgICAgICAgIC8vIFJlbW92ZSB0aGUgYXR0cmlidXRlIHRvIHNpZ25hbCB0aGF0IE1hdGhKYXggc2hvdWxkIHJlcHJvY2VzcyB0aGlzIGVsZW1lbnRcbiAgICAgICAgICBlbC5yZW1vdmVBdHRyaWJ1dGUoJ2RhdGEtbWF0aC1oYW5kbGVkJyk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJlbmRlcigpIHtcbiAgICAgIGNvbnN0IHsgbWFya3VwLCBsYXlvdXQsIHZhbHVlLCBvbkNoYW5nZSwgZWxlbWVudFR5cGUgfSA9IHRoaXMucHJvcHM7XG5cbiAgICAgIGNvbnN0IG1hc2tMYXlvdXQgPSBsYXlvdXQgPyBsYXlvdXQgOiBidWlsZExheW91dEZyb21NYXJrdXAobWFya3VwLCB0eXBlKTtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxNYXNrXG4gICAgICAgICAgZWxlbWVudFR5cGU9e2VsZW1lbnRUeXBlfVxuICAgICAgICAgIGxheW91dD17bWFza0xheW91dH1cbiAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHJlbmRlckNoaWxkcmVuPXtyZW5kZXJDaGlsZHJlbih0aGlzLnByb3BzKX1cbiAgICAgICAgLz5cbiAgICAgICk7XG4gICAgfVxuICB9O1xufTtcbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pie-lib/mask-markup",
3
- "version": "1.13.47-next.1+23991a09",
3
+ "version": "1.15.0-beta.0",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "module": "src/index.js",
@@ -9,9 +9,9 @@
9
9
  },
10
10
  "dependencies": {
11
11
  "@material-ui/core": "^3.9.3",
12
- "@pie-lib/drag": "^2.2.10-next.1+23991a09",
13
- "@pie-lib/math-rendering": "2.5.18",
14
- "@pie-lib/render-ui": "^4.15.10-next.1+23991a09",
12
+ "@pie-lib/drag": "^2.4.0-beta.0",
13
+ "@pie-lib/math-rendering": "^3.4.0-beta.0",
14
+ "@pie-lib/render-ui": "^4.17.0-beta.0",
15
15
  "classnames": "^2.2.6",
16
16
  "debug": "^4.1.1",
17
17
  "immutable": ">=3.8.1",
@@ -27,5 +27,5 @@
27
27
  "keywords": [],
28
28
  "author": "",
29
29
  "license": "ISC",
30
- "gitHead": "23991a09b77492c24dcb5235049667cdcc211d80"
30
+ "gitHead": "3818c24530f62b5bb9be7a2c6aa5428f13a17e0a"
31
31
  }