@pie-lib/mask-markup 1.13.46 → 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
@@ -11,6 +11,8 @@ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/cl
11
11
 
12
12
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
13
 
14
+ var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
+
14
16
  var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
15
17
 
16
18
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
@@ -21,9 +23,9 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
21
23
 
22
24
  var _react = _interopRequireDefault(require("react"));
23
25
 
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
26
+ var _reactDom = _interopRequireDefault(require("react-dom"));
25
27
 
26
- var _drag = require("@pie-lib/drag");
28
+ var _propTypes = _interopRequireDefault(require("prop-types"));
27
29
 
28
30
  var _styles = require("@material-ui/core/styles");
29
31
 
@@ -31,12 +33,12 @@ var _Chip = _interopRequireDefault(require("@material-ui/core/Chip"));
31
33
 
32
34
  var _classnames = _interopRequireDefault(require("classnames"));
33
35
 
34
- var _reactDom = _interopRequireDefault(require("react-dom"));
35
-
36
36
  var _mathRendering = require("@pie-lib/math-rendering");
37
37
 
38
38
  var _renderUi = require("@pie-lib/render-ui");
39
39
 
40
+ var _drag = require("@pie-lib/drag");
41
+
40
42
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
41
43
 
42
44
  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; } }
@@ -50,11 +52,60 @@ var BlankContentComp = /*#__PURE__*/function (_React$Component) {
50
52
  var _super = _createSuper(BlankContentComp);
51
53
 
52
54
  function BlankContentComp() {
55
+ var _this;
56
+
53
57
  (0, _classCallCheck2["default"])(this, BlankContentComp);
54
- return _super.apply(this, arguments);
58
+
59
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
60
+ args[_key] = arguments[_key];
61
+ }
62
+
63
+ _this = _super.call.apply(_super, [this].concat(args));
64
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "startDrag", function () {
65
+ var _this$props = _this.props,
66
+ connectDragSource = _this$props.connectDragSource,
67
+ disabled = _this$props.disabled;
68
+
69
+ if (!disabled) {
70
+ connectDragSource(_this.dragContainerRef);
71
+ }
72
+ });
73
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleTouchStart", function (e) {
74
+ e.preventDefault();
75
+ _this.longPressTimer = setTimeout(function () {
76
+ _this.startDrag(e);
77
+ }, 500);
78
+ });
79
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleTouchEnd", function () {
80
+ clearTimeout(_this.longPressTimer);
81
+ });
82
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleTouchMove", function () {
83
+ clearTimeout(_this.longPressTimer);
84
+ });
85
+ return _this;
55
86
  }
56
87
 
57
88
  (0, _createClass2["default"])(BlankContentComp, [{
89
+ key: "componentDidMount",
90
+ value: function componentDidMount() {
91
+ if (this.dragContainerRef) {
92
+ this.dragContainerRef.addEventListener('touchstart', this.handleTouchStart, {
93
+ passive: false
94
+ });
95
+ this.dragContainerRef.addEventListener('touchend', this.handleTouchEnd);
96
+ this.dragContainerRef.addEventListener('touchmove', this.handleTouchMove);
97
+ }
98
+ }
99
+ }, {
100
+ key: "componentWillUnmount",
101
+ value: function componentWillUnmount() {
102
+ if (this.dragContainerRef) {
103
+ this.dragContainerRef.removeEventListener('touchstart', this.handleTouchStart);
104
+ this.dragContainerRef.removeEventListener('touchend', this.handleTouchEnd);
105
+ this.dragContainerRef.removeEventListener('touchmove', this.handleTouchMove);
106
+ }
107
+ }
108
+ }, {
58
109
  key: "componentDidUpdate",
59
110
  value: function componentDidUpdate() {
60
111
  (0, _mathRendering.renderMath)(this.rootRef);
@@ -62,22 +113,26 @@ var BlankContentComp = /*#__PURE__*/function (_React$Component) {
62
113
  }, {
63
114
  key: "render",
64
115
  value: function render() {
65
- var _this = this;
116
+ var _this2 = this;
66
117
 
67
- var _this$props = this.props,
68
- connectDragSource = _this$props.connectDragSource,
69
- choice = _this$props.choice,
70
- classes = _this$props.classes,
71
- disabled = _this$props.disabled; // TODO the Chip element is causing drag problems on touch devices. Avoid using Chip and consider refactoring the code. Keep in mind that Chip is a span with a button role, which interferes with seamless touch device dragging.
118
+ var _this$props2 = this.props,
119
+ connectDragSource = _this$props2.connectDragSource,
120
+ choice = _this$props2.choice,
121
+ classes = _this$props2.classes,
122
+ disabled = _this$props2.disabled; // TODO the Chip element is causing drag problems on touch devices. Avoid using Chip and consider refactoring the code. Keep in mind that Chip is a span with a button role, which interferes with seamless touch device dragging.
72
123
 
73
124
  return connectDragSource( /*#__PURE__*/_react["default"].createElement("span", {
74
- className: (0, _classnames["default"])(classes.choice, disabled && classes.disabled)
125
+ className: (0, _classnames["default"])(classes.choice, disabled && classes.disabled),
126
+ ref: function ref(_ref3) {
127
+ //eslint-disable-next-line
128
+ _this2.dragContainerRef = _reactDom["default"].findDOMNode(_ref3);
129
+ }
75
130
  }, /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
76
131
  clickable: false,
77
132
  disabled: true,
78
133
  ref: function ref(_ref2) {
79
134
  //eslint-disable-next-line
80
- _this.rootRef = _reactDom["default"].findDOMNode(_ref2);
135
+ _this2.rootRef = _reactDom["default"].findDOMNode(_ref2);
81
136
  },
82
137
  className: classes.chip,
83
138
  label: /*#__PURE__*/_react["default"].createElement("span", {
@@ -110,7 +165,7 @@ var BlankContent = (0, _styles.withStyles)(function (theme) {
110
165
  transform: 'translate(0, 0)'
111
166
  },
112
167
  chip: {
113
- backgroundColor: _renderUi.color.background(),
168
+ backgroundColor: _renderUi.color.white(),
114
169
  border: "1px solid ".concat(_renderUi.color.text()),
115
170
  color: _renderUi.color.text(),
116
171
  alignItems: 'center',
@@ -123,16 +178,24 @@ var BlankContent = (0, _styles.withStyles)(function (theme) {
123
178
  // Added for touch devices, for image content.
124
179
  // This will prevent the context menu from appearing and not allowing other interactions with the image.
125
180
  // If interactions with the image in the token will be requested we should handle only the context Menu.
126
- pointerEvents: 'none'
181
+ pointerEvents: 'none',
182
+ borderRadius: '3px',
183
+ paddingTop: '12px',
184
+ paddingBottom: '12px'
127
185
  },
128
186
  chipLabel: {
129
- whiteSpace: 'pre-wrap',
187
+ whiteSpace: 'normal',
130
188
  '& img': {
131
189
  display: 'block',
132
190
  padding: '2px 0'
191
+ },
192
+ '& mjx-frac': {
193
+ fontSize: '120% !important'
133
194
  }
134
195
  },
135
- disabled: {}
196
+ disabled: {
197
+ opacity: 0.6
198
+ }
136
199
  };
137
200
  })(BlankContentComp);
138
201
  exports.BlankContent = BlankContent;
@@ -155,4 +218,4 @@ var DragDropTile = (0, _drag.DragSource)(DRAG_TYPE, tileSource, function (connec
155
218
  })(BlankContent);
156
219
  var _default = DragDropTile;
157
220
  exports["default"] = _default;
158
- //# sourceMappingURL=choice.js.map
221
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/choices/choice.jsx"],"names":["DRAG_TYPE","BlankContentComp","props","connectDragSource","disabled","dragContainerRef","e","preventDefault","longPressTimer","setTimeout","startDrag","clearTimeout","addEventListener","handleTouchStart","passive","handleTouchEnd","handleTouchMove","removeEventListener","rootRef","choice","classes","ref","ReactDOM","findDOMNode","chip","chipLabel","innerHTML","value","undefined","React","Component","PropTypes","bool","object","func","BlankContent","theme","border","palette","primary","main","borderRadius","spacing","unit","margin","transform","backgroundColor","color","white","text","alignItems","display","height","minHeight","fontSize","whiteSpace","maxWidth","pointerEvents","paddingTop","paddingBottom","padding","opacity","tileSource","canDrag","beginDrag","instanceId","DragDropTile","connect","monitor","dragSource","isDragging"],"mappings":"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","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport Chip from '@material-ui/core/Chip';\nimport classnames from 'classnames';\n\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { color } from '@pie-lib/render-ui';\nimport { DragSource } from '@pie-lib/drag';\n\nexport const DRAG_TYPE = 'MaskBlank';\n\nclass BlankContentComp extends React.Component {\n  static propTypes = {\n    disabled: PropTypes.bool,\n    choice: PropTypes.object,\n    classes: PropTypes.object,\n    connectDragSource: PropTypes.func,\n  };\n\n  startDrag = () => {\n    const { connectDragSource, disabled } = this.props;\n    if (!disabled) {\n      connectDragSource(this.dragContainerRef);\n    }\n  };\n\n  // start drag after 500ms (touch and hold duration) for chromebooks and other touch devices PD-4888\n  handleTouchStart = (e) => {\n    e.preventDefault();\n    this.longPressTimer = setTimeout(() => {\n      this.startDrag(e);\n    }, 500);\n  };\n\n  handleTouchEnd = () => {\n    clearTimeout(this.longPressTimer);\n  };\n\n  handleTouchMove = () => {\n    clearTimeout(this.longPressTimer);\n  };\n\n  componentDidMount() {\n    if (this.dragContainerRef) {\n      this.dragContainerRef.addEventListener('touchstart', this.handleTouchStart, { passive: false });\n      this.dragContainerRef.addEventListener('touchend', this.handleTouchEnd);\n      this.dragContainerRef.addEventListener('touchmove', this.handleTouchMove);\n    }\n  }\n\n  componentWillUnmount() {\n    if (this.dragContainerRef) {\n      this.dragContainerRef.removeEventListener('touchstart', this.handleTouchStart);\n      this.dragContainerRef.removeEventListener('touchend', this.handleTouchEnd);\n      this.dragContainerRef.removeEventListener('touchmove', this.handleTouchMove);\n    }\n  }\n\n  componentDidUpdate() {\n    renderMath(this.rootRef);\n  }\n\n  render() {\n    const { connectDragSource, choice, classes, disabled } = this.props;\n\n    // TODO the Chip element is causing drag problems on touch devices. Avoid using Chip and consider refactoring the code. Keep in mind that Chip is a span with a button role, which interferes with seamless touch device dragging.\n\n    return connectDragSource(\n      <span\n        className={classnames(classes.choice, disabled && classes.disabled)}\n        ref={(ref) => {\n          //eslint-disable-next-line\n          this.dragContainerRef = ReactDOM.findDOMNode(ref);\n        }}\n      >\n        <Chip\n          clickable={false}\n          disabled={true}\n          ref={(ref) => {\n            //eslint-disable-next-line\n            this.rootRef = ReactDOM.findDOMNode(ref);\n          }}\n          className={classes.chip}\n          label={\n            <span\n              className={classes.chipLabel}\n              ref={(ref) => {\n                if (ref) {\n                  ref.innerHTML = choice.value || ' ';\n                }\n              }}\n            >\n              {' '}\n            </span>\n          }\n          variant={disabled ? 'outlined' : undefined}\n        />\n      </span>,\n      {},\n    );\n  }\n}\n\nexport const BlankContent = withStyles((theme) => ({\n  choice: {\n    border: `solid 0px ${theme.palette.primary.main}`,\n    borderRadius: theme.spacing.unit * 2,\n    margin: theme.spacing.unit / 2,\n    transform: 'translate(0, 0)',\n  },\n  chip: {\n    backgroundColor: color.white(),\n    border: `1px solid ${color.text()}`,\n    color: color.text(),\n    alignItems: 'center',\n    display: 'inline-flex',\n    height: 'initial',\n    minHeight: '32px',\n    fontSize: 'inherit',\n    whiteSpace: 'pre-wrap',\n    maxWidth: '374px',\n    // Added for touch devices, for image content.\n    // This will prevent the context menu from appearing and not allowing other interactions with the image.\n    // If interactions with the image in the token will be requested we should handle only the context Menu.\n    pointerEvents: 'none',\n    borderRadius: '3px',\n    paddingTop: '12px',\n    paddingBottom: '12px',\n  },\n  chipLabel: {\n    whiteSpace: 'normal',\n    '& img': {\n      display: 'block',\n      padding: '2px 0',\n    },\n    '& mjx-frac': {\n      fontSize: '120% !important',\n    },\n  },\n  disabled: {\n    opacity: 0.6,\n  },\n}))(BlankContentComp);\n\nconst tileSource = {\n  canDrag(props) {\n    return !props.disabled;\n  },\n  beginDrag(props) {\n    return {\n      choice: props.choice,\n      instanceId: props.instanceId,\n    };\n  },\n};\n\nconst DragDropTile = DragSource(DRAG_TYPE, tileSource, (connect, monitor) => ({\n  connectDragSource: connect.dragSource(),\n  isDragging: monitor.isDragging(),\n}))(BlankContent);\n\nexport default DragDropTile;\n"]}
@@ -29,7 +29,11 @@ var _findKey = _interopRequireDefault(require("lodash/findKey"));
29
29
 
30
30
  var _choice = _interopRequireDefault(require("./choice"));
31
31
 
32
- var _dragInTheBlankDp = _interopRequireDefault(require("@pie-lib/drag/lib/drag-in-the-blank-dp"));
32
+ var _drag = require("@pie-lib/drag");
33
+
34
+ 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; }
35
+
36
+ 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; }
33
37
 
34
38
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
35
39
 
@@ -96,10 +100,14 @@ var Choices = /*#__PURE__*/function (_React$Component) {
96
100
  });
97
101
  return foundChoice === undefined;
98
102
  });
99
- var elementStyle = this.getStyleForWrapper();
103
+
104
+ var elementStyle = _objectSpread(_objectSpread({}, this.getStyleForWrapper()), {}, {
105
+ minWidth: '100px'
106
+ });
107
+
100
108
  return /*#__PURE__*/_react["default"].createElement("div", {
101
109
  style: elementStyle
102
- }, /*#__PURE__*/_react["default"].createElement(_dragInTheBlankDp["default"], {
110
+ }, /*#__PURE__*/_react["default"].createElement(_drag.DragDroppablePlaceholder, {
103
111
  disabled: disabled
104
112
  }, filteredChoices.map(function (c, index) {
105
113
  return /*#__PURE__*/_react["default"].createElement(_choice["default"], {
@@ -124,4 +132,4 @@ exports["default"] = Choices;
124
132
  value: _propTypes["default"].object,
125
133
  choicePosition: _propTypes["default"].string.isRequired
126
134
  });
127
- //# sourceMappingURL=index.js.map
135
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jaG9pY2VzL2luZGV4LmpzeCJdLCJuYW1lcyI6WyJDaG9pY2VzIiwiY2hvaWNlUG9zaXRpb24iLCJwcm9wcyIsIm1hcmdpbiIsImRpc2FibGVkIiwiZHVwbGljYXRlcyIsImNob2ljZXMiLCJ2YWx1ZSIsImZpbHRlcmVkQ2hvaWNlcyIsImZpbHRlciIsImMiLCJmb3VuZENob2ljZSIsInYiLCJpZCIsInVuZGVmaW5lZCIsImVsZW1lbnRTdHlsZSIsImdldFN0eWxlRm9yV3JhcHBlciIsIm1pbldpZHRoIiwibWFwIiwiaW5kZXgiLCJSZWFjdCIsIkNvbXBvbmVudCIsIlByb3BUeXBlcyIsImJvb2wiLCJhcnJheU9mIiwic2hhcGUiLCJsYWJlbCIsInN0cmluZyIsIm9iamVjdCIsImlzUmVxdWlyZWQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7SUFFcUJBLE87Ozs7Ozs7Ozs7Ozs7OzsyR0FTRSxZQUFNO0FBQ3pCLFVBQVFDLGNBQVIsR0FBMkIsTUFBS0MsS0FBaEMsQ0FBUUQsY0FBUjs7QUFFQSxjQUFRQSxjQUFSO0FBQ0UsYUFBSyxPQUFMO0FBQ0UsaUJBQU87QUFDTEUsWUFBQUEsTUFBTSxFQUFFO0FBREgsV0FBUDs7QUFJRixhQUFLLE9BQUw7QUFDRSxpQkFBTztBQUNMQSxZQUFBQSxNQUFNLEVBQUU7QUFESCxXQUFQOztBQUlGLGFBQUssT0FBTDtBQUNFLGlCQUFPO0FBQ0xBLFlBQUFBLE1BQU0sRUFBRTtBQURILFdBQVA7O0FBSUY7QUFDRSxpQkFBTztBQUNMQSxZQUFBQSxNQUFNLEVBQUU7QUFESCxXQUFQO0FBakJKO0FBcUJELEs7Ozs7OztXQUVELGtCQUFTO0FBQ1Asd0JBQWlELEtBQUtELEtBQXREO0FBQUEsVUFBUUUsUUFBUixlQUFRQSxRQUFSO0FBQUEsVUFBa0JDLFVBQWxCLGVBQWtCQSxVQUFsQjtBQUFBLFVBQThCQyxPQUE5QixlQUE4QkEsT0FBOUI7QUFBQSxVQUF1Q0MsS0FBdkMsZUFBdUNBLEtBQXZDO0FBQ0EsVUFBTUMsZUFBZSxHQUFHRixPQUFPLENBQUNHLE1BQVIsQ0FBZSxVQUFDQyxDQUFELEVBQU87QUFDNUMsWUFBSUwsVUFBVSxLQUFLLElBQW5CLEVBQXlCO0FBQ3ZCLGlCQUFPLElBQVA7QUFDRDs7QUFDRCxZQUFNTSxXQUFXLEdBQUcseUJBQVFKLEtBQVIsRUFBZSxVQUFDSyxDQUFEO0FBQUEsaUJBQU9BLENBQUMsS0FBS0YsQ0FBQyxDQUFDRyxFQUFmO0FBQUEsU0FBZixDQUFwQjtBQUNBLGVBQU9GLFdBQVcsS0FBS0csU0FBdkI7QUFDRCxPQU51QixDQUF4Qjs7QUFPQSxVQUFNQyxZQUFZLG1DQUFRLEtBQUtDLGtCQUFMLEVBQVI7QUFBbUNDLFFBQUFBLFFBQVEsRUFBRTtBQUE3QyxRQUFsQjs7QUFFQSwwQkFDRTtBQUFLLFFBQUEsS0FBSyxFQUFFRjtBQUFaLHNCQUNFLGdDQUFDLDhCQUFEO0FBQTBCLFFBQUEsUUFBUSxFQUFFWDtBQUFwQyxTQUNHSSxlQUFlLENBQUNVLEdBQWhCLENBQW9CLFVBQUNSLENBQUQsRUFBSVMsS0FBSjtBQUFBLDRCQUNuQixnQ0FBQyxrQkFBRDtBQUFRLFVBQUEsR0FBRyxZQUFLVCxDQUFDLENBQUNILEtBQVAsY0FBZ0JZLEtBQWhCLENBQVg7QUFBb0MsVUFBQSxRQUFRLEVBQUVmLFFBQTlDO0FBQXdELFVBQUEsTUFBTSxFQUFFTTtBQUFoRSxVQURtQjtBQUFBLE9BQXBCLENBREgsQ0FERixDQURGO0FBU0Q7OztFQXZEa0NVLGtCQUFNQyxTOzs7aUNBQXRCckIsTyxlQUNBO0FBQ2pCSSxFQUFBQSxRQUFRLEVBQUVrQixzQkFBVUMsSUFESDtBQUVqQmxCLEVBQUFBLFVBQVUsRUFBRWlCLHNCQUFVQyxJQUZMO0FBR2pCakIsRUFBQUEsT0FBTyxFQUFFZ0Isc0JBQVVFLE9BQVYsQ0FBa0JGLHNCQUFVRyxLQUFWLENBQWdCO0FBQUVDLElBQUFBLEtBQUssRUFBRUosc0JBQVVLLE1BQW5CO0FBQTJCcEIsSUFBQUEsS0FBSyxFQUFFZSxzQkFBVUs7QUFBNUMsR0FBaEIsQ0FBbEIsQ0FIUTtBQUlqQnBCLEVBQUFBLEtBQUssRUFBRWUsc0JBQVVNLE1BSkE7QUFLakIzQixFQUFBQSxjQUFjLEVBQUVxQixzQkFBVUssTUFBVixDQUFpQkU7QUFMaEIsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IGZpbmRLZXkgZnJvbSAnbG9kYXNoL2ZpbmRLZXknO1xuaW1wb3J0IENob2ljZSBmcm9tICcuL2Nob2ljZSc7XG5pbXBvcnQgeyBEcmFnRHJvcHBhYmxlUGxhY2Vob2xkZXIgfSBmcm9tICdAcGllLWxpYi9kcmFnJztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQ2hvaWNlcyBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIGR1cGxpY2F0ZXM6IFByb3BUeXBlcy5ib29sLFxuICAgIGNob2ljZXM6IFByb3BUeXBlcy5hcnJheU9mKFByb3BUeXBlcy5zaGFwZSh7IGxhYmVsOiBQcm9wVHlwZXMuc3RyaW5nLCB2YWx1ZTogUHJvcFR5cGVzLnN0cmluZyB9KSksXG4gICAgdmFsdWU6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgY2hvaWNlUG9zaXRpb246IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgfTtcblxuICBnZXRTdHlsZUZvcldyYXBwZXIgPSAoKSA9PiB7XG4gICAgY29uc3QgeyBjaG9pY2VQb3NpdGlvbiB9ID0gdGhpcy5wcm9wcztcblxuICAgIHN3aXRjaCAoY2hvaWNlUG9zaXRpb24pIHtcbiAgICAgIGNhc2UgJ2Fib3ZlJzpcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBtYXJnaW46ICcwIDAgNDBweCAwJyxcbiAgICAgICAgfTtcblxuICAgICAgY2FzZSAnYmVsb3cnOlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIG1hcmdpbjogJzQwcHggMCAwIDAnLFxuICAgICAgICB9O1xuXG4gICAgICBjYXNlICdyaWdodCc6XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgbWFyZ2luOiAnMCAwIDAgNDBweCcsXG4gICAgICAgIH07XG5cbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgbWFyZ2luOiAnMCA0MHB4IDAgMCcsXG4gICAgICAgIH07XG4gICAgfVxuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGRpc2FibGVkLCBkdXBsaWNhdGVzLCBjaG9pY2VzLCB2YWx1ZSB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBmaWx0ZXJlZENob2ljZXMgPSBjaG9pY2VzLmZpbHRlcigoYykgPT4ge1xuICAgICAgaWYgKGR1cGxpY2F0ZXMgPT09IHRydWUpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgICBjb25zdCBmb3VuZENob2ljZSA9IGZpbmRLZXkodmFsdWUsICh2KSA9PiB2ID09PSBjLmlkKTtcbiAgICAgIHJldHVybiBmb3VuZENob2ljZSA9PT0gdW5kZWZpbmVkO1xuICAgIH0pO1xuICAgIGNvbnN0IGVsZW1lbnRTdHlsZSA9IHsgLi4udGhpcy5nZXRTdHlsZUZvcldyYXBwZXIoKSwgbWluV2lkdGg6ICcxMDBweCcgfTtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IHN0eWxlPXtlbGVtZW50U3R5bGV9PlxuICAgICAgICA8RHJhZ0Ryb3BwYWJsZVBsYWNlaG9sZGVyIGRpc2FibGVkPXtkaXNhYmxlZH0+XG4gICAgICAgICAge2ZpbHRlcmVkQ2hvaWNlcy5tYXAoKGMsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICA8Q2hvaWNlIGtleT17YCR7Yy52YWx1ZX0tJHtpbmRleH1gfSBkaXNhYmxlZD17ZGlzYWJsZWR9IGNob2ljZT17Y30gLz5cbiAgICAgICAgICApKX1cbiAgICAgICAgPC9EcmFnRHJvcHBhYmxlUGxhY2Vob2xkZXI+XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG4iXX0=
@@ -22,4 +22,4 @@ var _default = function _default(s, t) {
22
22
  };
23
23
 
24
24
  exports["default"] = _default;
25
- //# sourceMappingURL=componentize.js.map
25
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb21wb25lbnRpemUuanMiXSwibmFtZXMiOlsiUkVHRVgiLCJzIiwidCIsIm1hcmt1cCIsInJlcGxhY2UiLCJtYXRjaCIsImciXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQU1BLEtBQUssR0FBRyxnQkFBZDs7ZUFFZSxrQkFBQ0MsQ0FBRCxFQUFJQyxDQUFKLEVBQVU7QUFDdkIsTUFBSSxDQUFDRCxDQUFMLEVBQVE7QUFDTixXQUFPO0FBQUVFLE1BQUFBLE1BQU0sRUFBRTtBQUFWLEtBQVA7QUFDRDs7QUFFRCxNQUFNQSxNQUFNLEdBQUdGLENBQUMsQ0FBQ0csT0FBRixDQUFVSixLQUFWLEVBQWlCLFVBQUNLLEtBQUQsRUFBUUMsQ0FBUixFQUFjO0FBQzVDLDRDQUFnQ0osQ0FBaEMsMEJBQStDSSxDQUEvQztBQUNELEdBRmMsQ0FBZjtBQUlBLFNBQU87QUFBRUgsSUFBQUEsTUFBTSxFQUFOQTtBQUFGLEdBQVA7QUFDRCxDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgUkVHRVggPSAvXFx7XFx7KFxcZCspXFx9XFx9L2c7XG5cbmV4cG9ydCBkZWZhdWx0IChzLCB0KSA9PiB7XG4gIGlmICghcykge1xuICAgIHJldHVybiB7IG1hcmt1cDogJycgfTtcbiAgfVxuXG4gIGNvbnN0IG1hcmt1cCA9IHMucmVwbGFjZShSRUdFWCwgKG1hdGNoLCBnKSA9PiB7XG4gICAgcmV0dXJuIGA8c3BhbiBkYXRhLWNvbXBvbmVudD1cIiR7dH1cIiBkYXRhLWlkPVwiJHtnfVwiPjwvc3Bhbj5gO1xuICB9KTtcblxuICByZXR1cm4geyBtYXJrdXAgfTtcbn07XG4iXX0=
@@ -0,0 +1,234 @@
1
+ "use strict";
2
+
3
+ var _typeof = require("@babel/runtime/helpers/typeof");
4
+
5
+ var React = _interopRequireWildcard(require("react"));
6
+
7
+ var _enzyme = require("enzyme");
8
+
9
+ var _blank = require("../blank");
10
+
11
+ 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); }
12
+
13
+ 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; }
14
+
15
+ describe('Blank', function () {
16
+ var onChange = jest.fn();
17
+ var defaultProps = {
18
+ disabled: false,
19
+ value: 'Cow',
20
+ classes: {},
21
+ isOver: false,
22
+ dragItem: {},
23
+ correct: false,
24
+ onChange: onChange
25
+ };
26
+ var wrapper;
27
+ var instance;
28
+ beforeEach(function () {
29
+ wrapper = (0, _enzyme.shallow)( /*#__PURE__*/React.createElement(_blank.BlankContent, defaultProps));
30
+ instance = wrapper.instance();
31
+ });
32
+ describe('render', function () {
33
+ it('renders correctly with default props', function () {
34
+ expect(wrapper).toMatchSnapshot();
35
+ });
36
+ it('renders correctly with disabled prop as true', function () {
37
+ wrapper.setProps({
38
+ disabled: true
39
+ });
40
+ expect(wrapper).toMatchSnapshot();
41
+ });
42
+ it('renders correctly with draggedItem', function () {
43
+ wrapper.setProps({
44
+ dragItem: {
45
+ choice: {
46
+ value: 'Dog'
47
+ }
48
+ }
49
+ });
50
+ expect(wrapper).toMatchSnapshot();
51
+ });
52
+ it('renders correctly with draggedItem and isOver', function () {
53
+ wrapper.setProps({
54
+ dragItem: {
55
+ choice: {
56
+ value: 'Dog'
57
+ }
58
+ },
59
+ isOver: true
60
+ });
61
+ expect(wrapper).toMatchSnapshot();
62
+ });
63
+ });
64
+ describe('onDelete', function () {
65
+ it('should be undefined if disabled is true', function () {
66
+ wrapper.setProps({
67
+ disabled: true
68
+ });
69
+ expect(wrapper.props().onDelete).toEqual(undefined);
70
+ });
71
+ it('should be undefined if no value is set', function () {
72
+ wrapper.setProps({
73
+ disabled: false,
74
+ value: undefined
75
+ });
76
+ expect(wrapper.props().onDelete).toEqual(undefined);
77
+ });
78
+ });
79
+ describe('updateDimensions', function () {
80
+ var span;
81
+ var rootRef;
82
+
83
+ var setSpanDimensions = function setSpanDimensions(height, width) {
84
+ Object.defineProperty(span, 'offsetHeight', {
85
+ value: height,
86
+ configurable: true
87
+ });
88
+ Object.defineProperty(span, 'offsetWidth', {
89
+ value: width,
90
+ configurable: true
91
+ });
92
+ };
93
+
94
+ beforeEach(function () {
95
+ wrapper = (0, _enzyme.shallow)( /*#__PURE__*/React.createElement(_blank.BlankContent, defaultProps));
96
+ instance = wrapper.instance();
97
+ span = document.createElement('span');
98
+ rootRef = document.createElement('span');
99
+ instance.spanRef = span;
100
+ instance.rootRef = rootRef;
101
+ Object.defineProperty(span, 'offsetHeight', {
102
+ value: 0,
103
+ configurable: true
104
+ });
105
+ Object.defineProperty(span, 'offsetWidth', {
106
+ value: 0,
107
+ configurable: true
108
+ });
109
+ });
110
+ it('should update dimensions if span size exceeds the response area size', function () {
111
+ setSpanDimensions(50, 50);
112
+ instance.updateDimensions();
113
+ expect(instance.state).toEqual({
114
+ width: 74,
115
+ height: 74
116
+ });
117
+ });
118
+ it('should not update dimensions if span size does not exceed the response area size', function () {
119
+ wrapper.setProps({
120
+ emptyResponseAreaHeight: 50,
121
+ emptyResponseAreaWidth: 50
122
+ });
123
+ setSpanDimensions(30, 30);
124
+ instance.updateDimensions();
125
+ expect(instance.state).toEqual({
126
+ width: 54,
127
+ // with padding it does exceed (30 + 24 > 50) so it's updating
128
+ height: 54 // with padding it does exceed (30 + 24 > 50) so it's updating
129
+
130
+ });
131
+ });
132
+ it('should handle non-numeric emptyResponseAreaHeight and emptyResponseAreaWidth', function () {
133
+ wrapper.setProps({
134
+ emptyResponseAreaHeight: 'non-numeric',
135
+ emptyResponseAreaWidth: 'non-numeric'
136
+ });
137
+ setSpanDimensions(50, 50);
138
+ instance.updateDimensions();
139
+ expect(instance.state).toEqual({
140
+ width: 74,
141
+ height: 74
142
+ });
143
+ });
144
+ });
145
+ describe('getRootDimensions', function () {
146
+ it('should return state dimensions if set', function () {
147
+ instance.setState({
148
+ height: 50,
149
+ width: 50
150
+ });
151
+ var dimensions = instance.getRootDimensions();
152
+ expect(dimensions).toEqual({
153
+ height: 50,
154
+ width: 50,
155
+ minWidth: 90,
156
+ minHeight: 32
157
+ });
158
+ });
159
+ it('should return state height and props width if state width is not set', function () {
160
+ instance.setState({
161
+ height: 50,
162
+ width: 0
163
+ });
164
+ var dimensions = instance.getRootDimensions();
165
+ expect(dimensions).toEqual({
166
+ height: 50,
167
+ width: 0,
168
+ minWidth: 90,
169
+ minHeight: 32
170
+ });
171
+ });
172
+ it('should return props height and state width if state height is not set', function () {
173
+ instance.setState({
174
+ height: 0,
175
+ width: 50
176
+ });
177
+ var dimensions = instance.getRootDimensions();
178
+ expect(dimensions).toEqual({
179
+ height: 0,
180
+ width: 50,
181
+ minWidth: 90,
182
+ minHeight: 32
183
+ });
184
+ });
185
+ it('should return props dimensions if state dimensions are zero', function () {
186
+ instance.setState({
187
+ height: 0,
188
+ width: 0
189
+ });
190
+ wrapper.setProps({
191
+ emptyResponseAreaHeight: 60,
192
+ emptyResponseAreaWidth: 60
193
+ });
194
+ var dimensions = instance.getRootDimensions();
195
+ expect(dimensions).toEqual({
196
+ height: 60,
197
+ width: 60
198
+ });
199
+ });
200
+ it('should return state dimensions over props dimensions if both are set', function () {
201
+ instance.setState({
202
+ height: 50,
203
+ width: 50
204
+ });
205
+ wrapper.setProps({
206
+ emptyResponseAreaHeight: 60,
207
+ emptyResponseAreaWidth: 60
208
+ });
209
+ var dimensions = instance.getRootDimensions();
210
+ expect(dimensions).toEqual({
211
+ height: 50,
212
+ width: 50
213
+ });
214
+ });
215
+ it('should return minWidth and minHeight if state and props dimensions are zero or undefined', function () {
216
+ instance.setState({
217
+ height: 0,
218
+ width: 0
219
+ });
220
+ wrapper.setProps({
221
+ emptyResponseAreaHeight: undefined,
222
+ emptyResponseAreaWidth: undefined
223
+ });
224
+ var dimensions = instance.getRootDimensions();
225
+ expect(dimensions).toEqual({
226
+ height: 0,
227
+ width: 0,
228
+ minWidth: 90,
229
+ minHeight: 32
230
+ });
231
+ });
232
+ });
233
+ });
234
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/__tests__/blank.test.js"],"names":["describe","onChange","jest","fn","defaultProps","disabled","value","classes","isOver","dragItem","correct","wrapper","instance","beforeEach","it","expect","toMatchSnapshot","setProps","choice","props","onDelete","toEqual","undefined","span","rootRef","setSpanDimensions","height","width","Object","defineProperty","configurable","document","createElement","spanRef","updateDimensions","state","emptyResponseAreaHeight","emptyResponseAreaWidth","setState","dimensions","getRootDimensions","minWidth","minHeight"],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport { shallow } from 'enzyme';\nimport { BlankContent as Blank } from '../blank';\n\ndescribe('Blank', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    disabled: false,\n    value: 'Cow',\n    classes: {},\n    isOver: false,\n    dragItem: {},\n    correct: false,\n    onChange,\n  };\n  let wrapper;\n  let instance;\n\n  beforeEach(() => {\n    wrapper = shallow(<Blank {...defaultProps} />);\n    instance = wrapper.instance();\n  });\n\n  describe('render', () => {\n    it('renders correctly with default props', () => {\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    it('renders correctly with disabled prop as true', () => {\n      wrapper.setProps({ disabled: true });\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    it('renders correctly with draggedItem', () => {\n      wrapper.setProps({ dragItem: { choice: { value: 'Dog' } } });\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    it('renders correctly with draggedItem and isOver', () => {\n      wrapper.setProps({ dragItem: { choice: { value: 'Dog' } }, isOver: true });\n      expect(wrapper).toMatchSnapshot();\n    });\n  });\n\n  describe('onDelete', () => {\n    it('should be undefined if disabled is true', () => {\n      wrapper.setProps({ disabled: true });\n\n      expect(wrapper.props().onDelete).toEqual(undefined);\n    });\n\n    it('should be undefined if no value is set', () => {\n      wrapper.setProps({ disabled: false, value: undefined });\n\n      expect(wrapper.props().onDelete).toEqual(undefined);\n    });\n  });\n\n  describe('updateDimensions', () => {\n    let span;\n    let rootRef;\n\n    const setSpanDimensions = (height, width) => {\n      Object.defineProperty(span, 'offsetHeight', { value: height, configurable: true });\n      Object.defineProperty(span, 'offsetWidth', { value: width, configurable: true });\n    };\n\n    beforeEach(() => {\n      wrapper = shallow(<Blank {...defaultProps} />);\n      instance = wrapper.instance();\n\n      span = document.createElement('span');\n      rootRef = document.createElement('span');\n\n      instance.spanRef = span;\n      instance.rootRef = rootRef;\n\n      Object.defineProperty(span, 'offsetHeight', { value: 0, configurable: true });\n      Object.defineProperty(span, 'offsetWidth', { value: 0, configurable: true });\n    });\n\n    it('should update dimensions if span size exceeds the response area size', () => {\n      setSpanDimensions(50, 50);\n\n      instance.updateDimensions();\n\n      expect(instance.state).toEqual({\n        width: 74,\n        height: 74,\n      });\n    });\n\n    it('should not update dimensions if span size does not exceed the response area size', () => {\n      wrapper.setProps({\n        emptyResponseAreaHeight: 50,\n        emptyResponseAreaWidth: 50,\n      });\n      setSpanDimensions(30, 30);\n\n      instance.updateDimensions();\n\n      expect(instance.state).toEqual({\n        width: 54,  // with padding it does exceed (30 + 24 > 50) so it's updating\n        height: 54, // with padding it does exceed (30 + 24 > 50) so it's updating\n      });\n    });\n\n    it('should handle non-numeric emptyResponseAreaHeight and emptyResponseAreaWidth', () => {\n      wrapper.setProps({\n        emptyResponseAreaHeight: 'non-numeric',\n        emptyResponseAreaWidth: 'non-numeric',\n      });\n      setSpanDimensions(50, 50);\n\n      instance.updateDimensions();\n\n      expect(instance.state).toEqual({\n        width: 74,\n        height: 74,\n      });\n    });\n  });\n\n  describe('getRootDimensions', () => {\n    it('should return state dimensions if set', () => {\n      instance.setState({ height: 50, width: 50 });\n\n      const dimensions = instance.getRootDimensions();\n\n      expect(dimensions).toEqual({\n        height: 50,\n        width: 50,\n        minWidth: 90,\n        minHeight: 32,\n      });\n    });\n\n    it('should return state height and props width if state width is not set', () => {\n      instance.setState({ height: 50, width: 0 });\n\n      const dimensions = instance.getRootDimensions();\n\n      expect(dimensions).toEqual({\n        height: 50,\n        width: 0,\n        minWidth: 90,\n        minHeight: 32,\n      });\n    });\n\n    it('should return props height and state width if state height is not set', () => {\n      instance.setState({ height: 0, width: 50 });\n\n      const dimensions = instance.getRootDimensions();\n\n      expect(dimensions).toEqual({\n        height: 0,\n        width: 50,\n        minWidth: 90,\n        minHeight: 32,\n      });\n    });\n\n    it('should return props dimensions if state dimensions are zero', () => {\n      instance.setState({ height: 0, width: 0 });\n      wrapper.setProps({ emptyResponseAreaHeight: 60, emptyResponseAreaWidth: 60 });\n\n      const dimensions = instance.getRootDimensions();\n\n      expect(dimensions).toEqual({\n        height: 60,\n        width: 60,\n      });\n    });\n\n    it('should return state dimensions over props dimensions if both are set', () => {\n      instance.setState({ height: 50, width: 50 });\n      wrapper.setProps({ emptyResponseAreaHeight: 60, emptyResponseAreaWidth: 60 });\n\n      const dimensions = instance.getRootDimensions();\n\n      expect(dimensions).toEqual({\n        height: 50,\n        width: 50,\n      });\n    });\n\n    it('should return minWidth and minHeight if state and props dimensions are zero or undefined', () => {\n      instance.setState({ height: 0, width: 0 });\n      wrapper.setProps({ emptyResponseAreaHeight: undefined, emptyResponseAreaWidth: undefined });\n\n      const dimensions = instance.getRootDimensions();\n\n      expect(dimensions).toEqual({\n        height: 0,\n        width: 0,\n        minWidth: 90,\n        minHeight: 32,\n      });\n    });\n  });\n});\n"]}
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ var React = _interopRequireWildcard(require("react"));
8
+
9
+ var _enzyme = require("enzyme");
10
+
11
+ var _correctInput = _interopRequireDefault(require("../correct-input"));
12
+
13
+ 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); }
14
+
15
+ 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; }
16
+
17
+ describe('CorrectInput', function () {
18
+ var onChange = jest.fn();
19
+ var defaultProps = {
20
+ disabled: false,
21
+ correct: false,
22
+ variant: 'outlined',
23
+ value: 'Cow',
24
+ onChange: onChange
25
+ };
26
+ var wrapper;
27
+ beforeEach(function () {
28
+ wrapper = (0, _enzyme.shallow)( /*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
29
+ });
30
+ describe('render', function () {
31
+ it('renders correctly with default props', function () {
32
+ expect(wrapper).toMatchSnapshot();
33
+ });
34
+ it('renders correctly with disabled prop as true', function () {
35
+ wrapper.setProps({
36
+ disabled: true
37
+ });
38
+ expect(wrapper).toMatchSnapshot();
39
+ });
40
+ it('renders correctly with correct as false', function () {
41
+ wrapper.setProps({
42
+ correct: false
43
+ });
44
+ expect(wrapper).toMatchSnapshot();
45
+ });
46
+ });
47
+ describe('onChange', function () {
48
+ var event = function event(value) {
49
+ return {
50
+ target: {
51
+ value: value
52
+ }
53
+ };
54
+ };
55
+
56
+ it('should be called', function () {
57
+ var e = event('1');
58
+ wrapper.simulate('change', e);
59
+ expect(onChange).toBeCalledWith(e);
60
+ });
61
+ });
62
+ });
63
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL19fdGVzdHNfXy9jb3JyZWN0LWlucHV0LnRlc3QuanMiXSwibmFtZXMiOlsiZGVzY3JpYmUiLCJvbkNoYW5nZSIsImplc3QiLCJmbiIsImRlZmF1bHRQcm9wcyIsImRpc2FibGVkIiwiY29ycmVjdCIsInZhcmlhbnQiLCJ2YWx1ZSIsIndyYXBwZXIiLCJiZWZvcmVFYWNoIiwiaXQiLCJleHBlY3QiLCJ0b01hdGNoU25hcHNob3QiLCJzZXRQcm9wcyIsImV2ZW50IiwidGFyZ2V0IiwiZSIsInNpbXVsYXRlIiwidG9CZUNhbGxlZFdpdGgiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUNBOzs7Ozs7QUFFQUEsUUFBUSxDQUFDLGNBQUQsRUFBaUIsWUFBTTtBQUM3QixNQUFNQyxRQUFRLEdBQUdDLElBQUksQ0FBQ0MsRUFBTCxFQUFqQjtBQUNBLE1BQU1DLFlBQVksR0FBRztBQUNuQkMsSUFBQUEsUUFBUSxFQUFFLEtBRFM7QUFFbkJDLElBQUFBLE9BQU8sRUFBRSxLQUZVO0FBR25CQyxJQUFBQSxPQUFPLEVBQUUsVUFIVTtBQUluQkMsSUFBQUEsS0FBSyxFQUFFLEtBSlk7QUFLbkJQLElBQUFBLFFBQVEsRUFBUkE7QUFMbUIsR0FBckI7QUFPQSxNQUFJUSxPQUFKO0FBRUFDLEVBQUFBLFVBQVUsQ0FBQyxZQUFNO0FBQ2ZELElBQUFBLE9BQU8sR0FBRyxtQ0FBUSxvQkFBQyx3QkFBRCxFQUFrQkwsWUFBbEIsQ0FBUixDQUFWO0FBQ0QsR0FGUyxDQUFWO0FBSUFKLEVBQUFBLFFBQVEsQ0FBQyxRQUFELEVBQVcsWUFBTTtBQUN2QlcsSUFBQUEsRUFBRSxDQUFDLHNDQUFELEVBQXlDLFlBQU07QUFDL0NDLE1BQUFBLE1BQU0sQ0FBQ0gsT0FBRCxDQUFOLENBQWdCSSxlQUFoQjtBQUNELEtBRkMsQ0FBRjtBQUlBRixJQUFBQSxFQUFFLENBQUMsOENBQUQsRUFBaUQsWUFBTTtBQUN2REYsTUFBQUEsT0FBTyxDQUFDSyxRQUFSLENBQWlCO0FBQUVULFFBQUFBLFFBQVEsRUFBRTtBQUFaLE9BQWpCO0FBQ0FPLE1BQUFBLE1BQU0sQ0FBQ0gsT0FBRCxDQUFOLENBQWdCSSxlQUFoQjtBQUNELEtBSEMsQ0FBRjtBQUtBRixJQUFBQSxFQUFFLENBQUMseUNBQUQsRUFBNEMsWUFBTTtBQUNsREYsTUFBQUEsT0FBTyxDQUFDSyxRQUFSLENBQWlCO0FBQUVSLFFBQUFBLE9BQU8sRUFBRTtBQUFYLE9BQWpCO0FBQ0FNLE1BQUFBLE1BQU0sQ0FBQ0gsT0FBRCxDQUFOLENBQWdCSSxlQUFoQjtBQUNELEtBSEMsQ0FBRjtBQUlELEdBZE8sQ0FBUjtBQWdCQWIsRUFBQUEsUUFBUSxDQUFDLFVBQUQsRUFBYSxZQUFNO0FBQ3pCLFFBQU1lLEtBQUssR0FBRyxTQUFSQSxLQUFRLENBQUNQLEtBQUQ7QUFBQSxhQUFZO0FBQ3hCUSxRQUFBQSxNQUFNLEVBQUU7QUFBRVIsVUFBQUEsS0FBSyxFQUFMQTtBQUFGO0FBRGdCLE9BQVo7QUFBQSxLQUFkOztBQUlBRyxJQUFBQSxFQUFFLENBQUMsa0JBQUQsRUFBcUIsWUFBTTtBQUMzQixVQUFNTSxDQUFDLEdBQUdGLEtBQUssQ0FBQyxHQUFELENBQWY7QUFFQU4sTUFBQUEsT0FBTyxDQUFDUyxRQUFSLENBQWlCLFFBQWpCLEVBQTJCRCxDQUEzQjtBQUVBTCxNQUFBQSxNQUFNLENBQUNYLFFBQUQsQ0FBTixDQUFpQmtCLGNBQWpCLENBQWdDRixDQUFoQztBQUNELEtBTkMsQ0FBRjtBQU9ELEdBWk8sQ0FBUjtBQWFELENBNUNPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBzaGFsbG93IH0gZnJvbSAnZW56eW1lJztcbmltcG9ydCBDb3JyZWN0SW5wdXQgZnJvbSAnLi4vY29ycmVjdC1pbnB1dCc7XG5cbmRlc2NyaWJlKCdDb3JyZWN0SW5wdXQnLCAoKSA9PiB7XG4gIGNvbnN0IG9uQ2hhbmdlID0gamVzdC5mbigpO1xuICBjb25zdCBkZWZhdWx0UHJvcHMgPSB7XG4gICAgZGlzYWJsZWQ6IGZhbHNlLFxuICAgIGNvcnJlY3Q6IGZhbHNlLFxuICAgIHZhcmlhbnQ6ICdvdXRsaW5lZCcsXG4gICAgdmFsdWU6ICdDb3cnLFxuICAgIG9uQ2hhbmdlLFxuICB9O1xuICBsZXQgd3JhcHBlcjtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICB3cmFwcGVyID0gc2hhbGxvdyg8Q29ycmVjdElucHV0IHsuLi5kZWZhdWx0UHJvcHN9IC8+KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3JlbmRlcicsICgpID0+IHtcbiAgICBpdCgncmVuZGVycyBjb3JyZWN0bHkgd2l0aCBkZWZhdWx0IHByb3BzJywgKCkgPT4ge1xuICAgICAgZXhwZWN0KHdyYXBwZXIpLnRvTWF0Y2hTbmFwc2hvdCgpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3JlbmRlcnMgY29ycmVjdGx5IHdpdGggZGlzYWJsZWQgcHJvcCBhcyB0cnVlJywgKCkgPT4ge1xuICAgICAgd3JhcHBlci5zZXRQcm9wcyh7IGRpc2FibGVkOiB0cnVlIH0pO1xuICAgICAgZXhwZWN0KHdyYXBwZXIpLnRvTWF0Y2hTbmFwc2hvdCgpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3JlbmRlcnMgY29ycmVjdGx5IHdpdGggY29ycmVjdCBhcyBmYWxzZScsICgpID0+IHtcbiAgICAgIHdyYXBwZXIuc2V0UHJvcHMoeyBjb3JyZWN0OiBmYWxzZSB9KTtcbiAgICAgIGV4cGVjdCh3cmFwcGVyKS50b01hdGNoU25hcHNob3QoKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ29uQ2hhbmdlJywgKCkgPT4ge1xuICAgIGNvbnN0IGV2ZW50ID0gKHZhbHVlKSA9PiAoe1xuICAgICAgdGFyZ2V0OiB7IHZhbHVlIH0sXG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIGJlIGNhbGxlZCcsICgpID0+IHtcbiAgICAgIGNvbnN0IGUgPSBldmVudCgnMScpO1xuXG4gICAgICB3cmFwcGVyLnNpbXVsYXRlKCdjaGFuZ2UnLCBlKTtcblxuICAgICAgZXhwZWN0KG9uQ2hhbmdlKS50b0JlQ2FsbGVkV2l0aChlKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==