@pie-lib/editable-html 11.21.2 → 11.21.3-next.155

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 (159) hide show
  1. package/CHANGELOG.md +6 -76
  2. package/esm/package.json +3 -0
  3. package/lib/block-tags.js +2 -3
  4. package/lib/block-tags.js.map +1 -1
  5. package/lib/constants.js +3 -6
  6. package/lib/constants.js.map +1 -1
  7. package/lib/editor.js +350 -481
  8. package/lib/editor.js.map +1 -1
  9. package/lib/index.js +18 -79
  10. package/lib/index.js.map +1 -1
  11. package/lib/parse-html.js +7 -7
  12. package/lib/parse-html.js.map +1 -1
  13. package/lib/plugins/characters/custom-popper.js +28 -44
  14. package/lib/plugins/characters/custom-popper.js.map +1 -1
  15. package/lib/plugins/characters/index.js +23 -63
  16. package/lib/plugins/characters/index.js.map +1 -1
  17. package/lib/plugins/characters/utils.js +3 -6
  18. package/lib/plugins/characters/utils.js.map +1 -1
  19. package/lib/plugins/css/icons/index.js +13 -25
  20. package/lib/plugins/css/icons/index.js.map +1 -1
  21. package/lib/plugins/css/index.js +34 -93
  22. package/lib/plugins/css/index.js.map +1 -1
  23. package/lib/plugins/customPlugin/index.js +10 -26
  24. package/lib/plugins/customPlugin/index.js.map +1 -1
  25. package/lib/plugins/html/icons/index.js +17 -25
  26. package/lib/plugins/html/icons/index.js.map +1 -1
  27. package/lib/plugins/html/index.js +4 -13
  28. package/lib/plugins/html/index.js.map +1 -1
  29. package/lib/plugins/image/alt-dialog.js +20 -49
  30. package/lib/plugins/image/alt-dialog.js.map +1 -1
  31. package/lib/plugins/image/component.js +118 -194
  32. package/lib/plugins/image/component.js.map +1 -1
  33. package/lib/plugins/image/image-toolbar.js +48 -88
  34. package/lib/plugins/image/image-toolbar.js.map +1 -1
  35. package/lib/plugins/image/index.js +6 -46
  36. package/lib/plugins/image/index.js.map +1 -1
  37. package/lib/plugins/image/insert-image-handler.js +10 -31
  38. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  39. package/lib/plugins/index.js +46 -106
  40. package/lib/plugins/index.js.map +1 -1
  41. package/lib/plugins/list/index.js +27 -73
  42. package/lib/plugins/list/index.js.map +1 -1
  43. package/lib/plugins/math/index.js +64 -116
  44. package/lib/plugins/math/index.js.map +1 -1
  45. package/lib/plugins/media/index.js +27 -84
  46. package/lib/plugins/media/index.js.map +1 -1
  47. package/lib/plugins/media/media-dialog.js +192 -307
  48. package/lib/plugins/media/media-dialog.js.map +1 -1
  49. package/lib/plugins/media/media-toolbar.js +40 -65
  50. package/lib/plugins/media/media-toolbar.js.map +1 -1
  51. package/lib/plugins/media/media-wrapper.js +20 -49
  52. package/lib/plugins/media/media-wrapper.js.map +1 -1
  53. package/lib/plugins/rendering/index.js +5 -15
  54. package/lib/plugins/rendering/index.js.map +1 -1
  55. package/lib/plugins/respArea/drag-in-the-blank/choice.js +233 -251
  56. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  57. package/lib/plugins/respArea/drag-in-the-blank/index.js +17 -59
  58. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  59. package/lib/plugins/respArea/drag-in-the-blank/utils.js +38 -0
  60. package/lib/plugins/respArea/drag-in-the-blank/utils.js.map +1 -0
  61. package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -10
  62. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  63. package/lib/plugins/respArea/icons/index.js +22 -45
  64. package/lib/plugins/respArea/icons/index.js.map +1 -1
  65. package/lib/plugins/respArea/index.js +5 -59
  66. package/lib/plugins/respArea/index.js.map +1 -1
  67. package/lib/plugins/respArea/inline-dropdown/index.js +2 -10
  68. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  69. package/lib/plugins/respArea/math-templated/index.js +91 -109
  70. package/lib/plugins/respArea/math-templated/index.js.map +1 -1
  71. package/lib/plugins/respArea/utils.js +12 -42
  72. package/lib/plugins/respArea/utils.js.map +1 -1
  73. package/lib/plugins/table/CustomTablePlugin.js +24 -41
  74. package/lib/plugins/table/CustomTablePlugin.js.map +1 -1
  75. package/lib/plugins/table/icons/index.js +21 -35
  76. package/lib/plugins/table/icons/index.js.map +1 -1
  77. package/lib/plugins/table/index.js +48 -118
  78. package/lib/plugins/table/index.js.map +1 -1
  79. package/lib/plugins/table/table-toolbar.js +37 -86
  80. package/lib/plugins/table/table-toolbar.js.map +1 -1
  81. package/lib/plugins/textAlign/icons/index.js +25 -64
  82. package/lib/plugins/textAlign/icons/index.js.map +1 -1
  83. package/lib/plugins/textAlign/index.js +0 -8
  84. package/lib/plugins/textAlign/index.js.map +1 -1
  85. package/lib/plugins/toolbar/default-toolbar.js +30 -79
  86. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  87. package/lib/plugins/toolbar/done-button.js +16 -34
  88. package/lib/plugins/toolbar/done-button.js.map +1 -1
  89. package/lib/plugins/toolbar/editor-and-toolbar.js +174 -202
  90. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  91. package/lib/plugins/toolbar/index.js +0 -5
  92. package/lib/plugins/toolbar/index.js.map +1 -1
  93. package/lib/plugins/toolbar/toolbar-buttons.js +59 -108
  94. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  95. package/lib/plugins/toolbar/toolbar.js +93 -162
  96. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  97. package/lib/plugins/utils.js +5 -25
  98. package/lib/plugins/utils.js.map +1 -1
  99. package/lib/serialization.js +47 -153
  100. package/lib/serialization.js.map +1 -1
  101. package/lib/shared/alert-dialog.js +35 -42
  102. package/lib/theme.js +1 -2
  103. package/lib/theme.js.map +1 -1
  104. package/package.json +26 -14
  105. package/src/__tests__/editor-utils.test.js +162 -0
  106. package/src/__tests__/utils.js +1 -1
  107. package/src/editor.jsx +175 -153
  108. package/src/index.jsx +0 -3
  109. package/src/plugins/characters/custom-popper.js +25 -25
  110. package/src/plugins/characters/index.jsx +15 -5
  111. package/src/plugins/css/icons/index.jsx +11 -13
  112. package/src/plugins/css/index.jsx +16 -11
  113. package/src/plugins/html/icons/index.jsx +17 -14
  114. package/src/plugins/image/__tests__/component.test.jsx +61 -29
  115. package/src/plugins/image/__tests__/image-toolbar-logic.test.jsx +69 -17
  116. package/src/plugins/image/__tests__/image-toolbar.test.jsx +6 -4
  117. package/src/plugins/image/alt-dialog.jsx +9 -8
  118. package/src/plugins/image/component.jsx +68 -92
  119. package/src/plugins/image/image-toolbar.jsx +31 -28
  120. package/src/plugins/image/index.jsx +1 -1
  121. package/src/plugins/index.jsx +12 -10
  122. package/src/plugins/math/__tests__/index.test.jsx +45 -26
  123. package/src/plugins/math/index.jsx +1 -1
  124. package/src/plugins/media/index.jsx +6 -5
  125. package/src/plugins/media/media-dialog.js +65 -76
  126. package/src/plugins/media/media-toolbar.jsx +32 -33
  127. package/src/plugins/media/media-wrapper.jsx +10 -13
  128. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +240 -167
  129. package/src/plugins/respArea/drag-in-the-blank/index.jsx +27 -56
  130. package/src/plugins/respArea/drag-in-the-blank/utils.js +14 -0
  131. package/src/plugins/respArea/icons/index.jsx +16 -16
  132. package/src/plugins/respArea/math-templated/index.jsx +88 -89
  133. package/src/plugins/respArea/utils.jsx +5 -3
  134. package/src/plugins/table/__tests__/table-toolbar.test.jsx +40 -7
  135. package/src/plugins/table/icons/index.jsx +16 -16
  136. package/src/plugins/table/index.jsx +35 -19
  137. package/src/plugins/table/table-toolbar.jsx +18 -19
  138. package/src/plugins/textAlign/icons/index.jsx +13 -4
  139. package/src/plugins/textAlign/index.jsx +0 -3
  140. package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +102 -69
  141. package/src/plugins/toolbar/__tests__/editor-and-toolbar.test.jsx +14 -11
  142. package/src/plugins/toolbar/__tests__/toolbar-buttons.test.jsx +81 -35
  143. package/src/plugins/toolbar/__tests__/toolbar.test.jsx +44 -38
  144. package/src/plugins/toolbar/default-toolbar.jsx +18 -21
  145. package/src/plugins/toolbar/done-button.jsx +16 -22
  146. package/src/plugins/toolbar/editor-and-toolbar.jsx +134 -158
  147. package/src/plugins/toolbar/toolbar-buttons.jsx +30 -46
  148. package/src/plugins/toolbar/toolbar.jsx +57 -79
  149. package/src/serialization.jsx +3 -3
  150. package/src/__tests__/editor.test.jsx +0 -363
  151. package/src/plugins/image/__tests__/__snapshots__/component.test.jsx.snap +0 -51
  152. package/src/plugins/image/__tests__/__snapshots__/image-toolbar-logic.test.jsx.snap +0 -27
  153. package/src/plugins/image/__tests__/__snapshots__/image-toolbar.test.jsx.snap +0 -44
  154. package/src/plugins/math/__tests__/__snapshots__/index.test.jsx.snap +0 -48
  155. package/src/plugins/table/__tests__/__snapshots__/table-toolbar.test.jsx.snap +0 -44
  156. package/src/plugins/toolbar/__tests__/__snapshots__/default-toolbar.test.jsx.snap +0 -923
  157. package/src/plugins/toolbar/__tests__/__snapshots__/editor-and-toolbar.test.jsx.snap +0 -20
  158. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar-buttons.test.jsx.snap +0 -36
  159. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar.test.jsx.snap +0 -46
@@ -1,289 +1,271 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.tileTarget = exports.tileSource = exports["default"] = exports.BlankContent = void 0;
9
-
10
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
-
12
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
-
14
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
-
16
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
17
-
18
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
19
-
20
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
21
-
22
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
23
-
8
+ exports.BlankContent = BlankContent;
9
+ exports["default"] = void 0;
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
24
11
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
-
26
- var _react = _interopRequireDefault(require("react"));
27
-
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+ var _react = _interopRequireWildcard(require("react"));
28
14
  var _propTypes = _interopRequireDefault(require("prop-types"));
29
-
30
- var _isUndefined = _interopRequireDefault(require("lodash/isUndefined"));
31
-
32
- var _drag = require("@pie-lib/drag");
33
-
15
+ var _classnames = _interopRequireDefault(require("classnames"));
16
+ var _core = require("@dnd-kit/core");
34
17
  var _renderUi = require("@pie-lib/render-ui");
35
-
36
18
  var _mathRendering = require("@pie-lib/math-rendering");
37
-
38
- var _styles = require("@material-ui/core/styles");
39
-
40
- var _classnames = _interopRequireDefault(require("classnames"));
41
-
19
+ var _styles = require("@mui/material/styles");
42
20
  var _icons = require("../icons");
43
-
44
- var _excluded = ["connectDropTarget", "connectDragSource"];
45
-
46
- 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); }; }
47
-
48
- 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; } }
49
-
50
- var useStyles = (0, _styles.withStyles)(function (theme) {
21
+ var _utils = require("./utils");
22
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
23
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
24
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
25
+ var StyledContent = (0, _styles.styled)('span')(function (_ref) {
26
+ var theme = _ref.theme;
51
27
  return {
52
- content: {
53
- border: "solid 0px ".concat(theme.palette.primary.main),
54
- '& mjx-frac': {
55
- fontSize: '120% !important'
56
- }
28
+ border: "solid 0px ".concat(theme.palette.primary.main),
29
+ '& mjx-frac': {
30
+ fontSize: '120% !important'
57
31
  },
58
- chip: {
32
+ '&.chip': {
59
33
  minWidth: '90px'
60
34
  },
61
- correct: {
35
+ '&.correct': {
62
36
  border: "solid 1px ".concat(_renderUi.color.correct())
63
37
  },
64
- incorrect: {
38
+ '&.incorrect': {
65
39
  border: "solid 1px ".concat(theme.palette.error.main)
66
40
  },
67
- selected: {
41
+ '&.selected': {
68
42
  border: "2px solid ".concat(_renderUi.color.primaryDark(), " !important")
69
43
  }
70
44
  };
71
45
  });
72
-
73
- var BlankContent = /*#__PURE__*/function (_React$Component) {
74
- (0, _inherits2["default"])(BlankContent, _React$Component);
75
-
76
- var _super = _createSuper(BlankContent);
77
-
78
- function BlankContent(props) {
79
- var _this;
80
-
81
- (0, _classCallCheck2["default"])(this, BlankContent);
82
- _this = _super.call(this, props);
83
- _this.handleClick = _this.handleClick.bind((0, _assertThisInitialized2["default"])(_this));
84
- _this.state = {
85
- hoveredElementSize: null
86
- };
87
- return _this;
88
- }
89
-
90
- (0, _createClass2["default"])(BlankContent, [{
91
- key: "componentDidMount",
92
- value: function componentDidMount() {
93
- document.addEventListener('click', this.handleClick);
94
- }
95
- }, {
96
- key: "componentWillUnmount",
97
- value: function componentWillUnmount() {
98
- document.removeEventListener('click', this.handleClick);
99
- }
100
- }, {
101
- key: "handleClick",
102
- value: function handleClick(event) {
103
- var classes = this.props.classes;
104
-
105
- if (this.elementRef) {
106
- this.elementRef.className = this.elementRef.contains(event.target) ? classes.selected : '';
107
- }
46
+ function BlankContent(_ref2) {
47
+ var _dragItem$value2, _dragItem$value3;
48
+ var n = _ref2.n,
49
+ children = _ref2.children,
50
+ isDragging = _ref2.isDragging,
51
+ isOver = _ref2.isOver,
52
+ dragItem = _ref2.dragItem,
53
+ value = _ref2.value,
54
+ externalStyle = _ref2.style;
55
+ var _useState = (0, _react.useState)(null),
56
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
57
+ hoveredElementSize = _useState2[0],
58
+ setHoveredElementSize = _useState2[1];
59
+ var elementRef = (0, _react.useRef)(null);
60
+ var handleClick = function handleClick(event) {
61
+ if (!elementRef.current) return;
62
+ if (elementRef.current.contains(event.target)) {
63
+ elementRef.current.classList.add('selected');
64
+ } else {
65
+ elementRef.current.classList.remove('selected');
108
66
  }
109
- }, {
110
- key: "getSnapshotBeforeUpdate",
111
- value: function getSnapshotBeforeUpdate(prevProps) {
112
- if (!prevProps.isOver && this.props.isOver && this.elementRef) {
113
- var node = this.elementRef;
114
- return {
115
- width: node.offsetWidth,
116
- height: node.offsetHeight
117
- };
118
- }
119
-
120
- return null;
67
+ };
68
+ (0, _react.useEffect)(function () {
69
+ document.addEventListener('click', handleClick);
70
+ return function () {
71
+ document.removeEventListener('click', handleClick);
72
+ };
73
+ }, []);
74
+ (0, _react.useEffect)(function () {
75
+ var _dragItem$value;
76
+ // Render math for the current value or preview
77
+ var currentContent = isOver && (dragItem === null || dragItem === void 0 || (_dragItem$value = dragItem.value) === null || _dragItem$value === void 0 ? void 0 : _dragItem$value.value) || (value === null || value === void 0 ? void 0 : value.value);
78
+ if (!currentContent) return;
79
+ if (elementRef.current && typeof _mathRendering.renderMath === 'function') {
80
+ (0, _mathRendering.renderMath)(elementRef.current);
121
81
  }
122
- }, {
123
- key: "componentDidUpdate",
124
- value: function componentDidUpdate(prevProps, prevState, snapshot) {
125
- if (this.elementRef && typeof _mathRendering.renderMath === 'function') {
126
- (0, _mathRendering.renderMath)(this.elementRef);
127
- }
128
-
129
- if (snapshot && (!this.state.hoveredElementSize || this.state.hoveredElementSize.width !== snapshot.width || this.state.hoveredElementSize.height !== snapshot.height)) {
130
- this.setState({
131
- hoveredElementSize: snapshot
132
- });
133
- return;
134
- }
135
-
136
- if (prevProps.isOver && !this.props.isOver && this.state.hoveredElementSize) {
137
- this.setState({
138
- hoveredElementSize: null
139
- });
140
- }
82
+ }, [value === null || value === void 0 ? void 0 : value.id, value === null || value === void 0 ? void 0 : value.value, isOver, dragItem === null || dragItem === void 0 || (_dragItem$value2 = dragItem.value) === null || _dragItem$value2 === void 0 ? void 0 : _dragItem$value2.id, dragItem === null || dragItem === void 0 || (_dragItem$value3 = dragItem.value) === null || _dragItem$value3 === void 0 ? void 0 : _dragItem$value3.value]);
83
+ (0, _react.useEffect)(function () {
84
+ if (isOver && elementRef.current && !hoveredElementSize) {
85
+ var node = elementRef.current;
86
+ setHoveredElementSize({
87
+ width: node.offsetWidth,
88
+ height: node.offsetHeight
89
+ });
90
+ } else if (!isOver && hoveredElementSize) {
91
+ setHoveredElementSize(null);
141
92
  }
142
- }, {
143
- key: "render",
144
- value: function render() {
145
- var _this2 = this;
146
-
147
- var _this$props = this.props,
148
- n = _this$props.n,
149
- children = _this$props.children,
150
- isDragging = _this$props.isDragging,
151
- dragItem = _this$props.dragItem,
152
- isOver = _this$props.isOver,
153
- value = _this$props.value;
154
- var hoveredElementSize = this.state.hoveredElementSize;
155
- var label = dragItem && isOver ? dragItem.value.value : value.value || "\xA0";
156
- var finalLabel = isDragging ? "\xA0" : label;
157
- var hasGrip = finalLabel !== "\xA0";
158
- var isPreview = dragItem && isOver;
159
- return /*#__PURE__*/_react["default"].createElement("div", {
160
- ref: function ref(_ref) {
161
- return _this2.elementRef = _ref;
162
- },
163
- style: {
164
- display: 'inline-flex',
165
- minWidth: '178px',
166
- minHeight: '36px',
167
- background: isPreview ? "".concat(_renderUi.color.defaults.BORDER_LIGHT) : "".concat(_renderUi.color.defaults.WHITE),
168
- border: isPreview ? "1px solid ".concat(_renderUi.color.defaults.BORDER_DARK) : "1px solid ".concat(_renderUi.color.defaults.BORDER_LIGHT),
169
- boxSizing: 'border-box',
170
- borderRadius: '3px',
171
- overflow: 'hidden',
172
- position: 'relative',
173
- padding: '8px 8px 8px 35px',
174
- width: hoveredElementSize ? hoveredElementSize.width : undefined,
175
- height: hoveredElementSize ? hoveredElementSize.height : undefined
176
- },
177
- "data-key": n.key,
178
- contentEditable: false
179
- }, hasGrip && /*#__PURE__*/_react["default"].createElement(_icons.GripIcon, {
180
- style: {
181
- position: 'absolute',
182
- top: '6px',
183
- left: '15px',
184
- color: '#9B9B9B'
185
- },
186
- contentEditable: false
187
- }), /*#__PURE__*/_react["default"].createElement("span", {
188
- dangerouslySetInnerHTML: {
189
- __html: finalLabel
190
- }
191
- }), children);
93
+ }, [isOver, hoveredElementSize]);
94
+ var label = dragItem && dragItem.value && isOver ? dragItem.value.value : value.value || "\xA0";
95
+ var finalLabel = isDragging ? "\xA0" : label;
96
+ var hasGrip = finalLabel !== "\xA0";
97
+ var isPreview = dragItem && isOver;
98
+ var hasContent = finalLabel !== "\xA0";
99
+ var containsHTML = hasContent && /<[^>]+>/.test(finalLabel);
100
+ var spanProps = _objectSpread({
101
+ key: "".concat(n.key, "-").concat(isPreview ? 'preview' : 'value')
102
+ }, hasContent && {
103
+ 'data-latex': '',
104
+ 'data-raw': finalLabel
105
+ });
106
+ return /*#__PURE__*/_react["default"].createElement("div", {
107
+ ref: elementRef,
108
+ style: _objectSpread({
109
+ display: 'inline-flex',
110
+ minWidth: '178px',
111
+ minHeight: '36px',
112
+ background: isPreview ? "".concat(_renderUi.color.defaults.BORDER_LIGHT) : "".concat(_renderUi.color.defaults.WHITE),
113
+ border: isPreview ? "1px solid ".concat(_renderUi.color.defaults.BORDER_DARK) : "1px solid ".concat(_renderUi.color.defaults.BORDER_LIGHT),
114
+ boxSizing: 'border-box',
115
+ borderRadius: '3px',
116
+ overflow: 'hidden',
117
+ position: 'relative',
118
+ padding: '8px 8px 8px 35px',
119
+ width: hoveredElementSize ? hoveredElementSize.width : undefined,
120
+ height: hoveredElementSize ? hoveredElementSize.height : undefined
121
+ }, externalStyle),
122
+ "data-key": n.key,
123
+ contentEditable: false
124
+ }, hasGrip && /*#__PURE__*/_react["default"].createElement(_icons.GripIcon, {
125
+ style: {
126
+ position: 'absolute',
127
+ top: '6px',
128
+ left: '15px',
129
+ color: '#9B9B9B'
130
+ },
131
+ contentEditable: false
132
+ }), containsHTML ? /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({}, spanProps, {
133
+ dangerouslySetInnerHTML: {
134
+ __html: finalLabel
192
135
  }
193
- }]);
194
- return BlankContent;
195
- }(_react["default"].Component);
196
-
197
- exports.BlankContent = BlankContent;
198
- (0, _defineProperty2["default"])(BlankContent, "propTypes", {
136
+ })) : /*#__PURE__*/_react["default"].createElement("span", spanProps, finalLabel), children);
137
+ }
138
+ BlankContent.propTypes = {
199
139
  n: _propTypes["default"].object,
200
140
  children: _propTypes["default"].func,
201
141
  isDragging: _propTypes["default"].bool,
202
142
  isOver: _propTypes["default"].bool,
203
143
  dragItem: _propTypes["default"].object,
204
144
  value: _propTypes["default"].object,
205
- classes: _propTypes["default"].object
206
- });
207
- var StyledBlankContent = useStyles(BlankContent);
208
- var connectedBlankContent = useStyles(function (_ref2) {
209
- var connectDropTarget = _ref2.connectDropTarget,
210
- connectDragSource = _ref2.connectDragSource,
211
- props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
212
- var classes = props.classes,
213
- isOver = props.isOver,
214
- value = props.value;
215
-
216
- var dragContent = /*#__PURE__*/_react["default"].createElement(StyledBlankContent, props);
217
-
218
- var dragEl = !value ? dragContent : connectDragSource( /*#__PURE__*/_react["default"].createElement("span", null, dragContent));
219
-
220
- var content = /*#__PURE__*/_react["default"].createElement("span", {
221
- className: (0, _classnames["default"])(classes.content, isOver && classes.over)
222
- }, dragEl);
223
-
224
- return connectDropTarget ? connectDropTarget(content) : content;
225
- });
226
- var tileTarget = {
227
- drop: function drop(props, monitor) {
228
- var draggedItem = monitor.getItem();
229
- var shouldDrop = (0, _isUndefined["default"])(draggedItem.value.index) || (0, _isUndefined["default"])(props.value.index) || draggedItem.value.index !== props.value.index;
230
-
231
- if (shouldDrop) {
232
- props.onChange(draggedItem.value);
233
- }
234
-
235
- return {
236
- dropped: shouldDrop
237
- };
238
- },
239
- canDrop: function canDrop(props, monitor) {
240
- var draggedItem = monitor.getItem();
241
- return draggedItem.instanceId === props.instanceId;
242
- }
145
+ disabled: _propTypes["default"].bool,
146
+ style: _propTypes["default"].object
243
147
  };
244
- exports.tileTarget = tileTarget;
245
- var DropTile = (0, _drag.DropTarget)('drag-in-the-blank-choice', tileTarget, function (connect, monitor) {
246
- return {
247
- connectDropTarget: connect.dropTarget(),
248
- isOver: monitor.isOver({
249
- shallow: true
148
+ function DragDropChoice(_ref3) {
149
+ var _dragItem$data;
150
+ var value = _ref3.value,
151
+ disabled = _ref3.disabled,
152
+ instanceId = _ref3.instanceId,
153
+ children = _ref3.children,
154
+ n = _ref3.n,
155
+ nodeProps = _ref3.nodeProps,
156
+ opts = _ref3.opts;
157
+ var _useDraggable = (0, _core.useDraggable)({
158
+ id: "drag-".concat(n.key),
159
+ disabled: disabled || !(value !== null && value !== void 0 && value.value),
160
+ data: {
161
+ id: "drag-".concat(n.key),
162
+ value: value,
163
+ instanceId: instanceId,
164
+ nodeProps: nodeProps,
165
+ n: n,
166
+ opts: opts,
167
+ type: 'drag-in-the-blank-placed-choice',
168
+ fromChoice: !value,
169
+ onRemove: function onRemove(draggedData) {
170
+ return (0, _utils.onRemoveResponse)(nodeProps, draggedData.value);
171
+ },
172
+ onDrop: function onDrop(draggedData, dropData) {
173
+ // check if we're dropping into a blank
174
+ var isValidBlank = (dropData === null || dropData === void 0 ? void 0 : dropData.type) === 'drag-in-the-blank-drop-choice';
175
+ if (!isValidBlank) return;
176
+
177
+ // place into blank
178
+ (0, _utils.onValueChange)(nodeProps, n, draggedData.value);
179
+ if (!opts.options.duplicates && draggedData.fromChoice) {
180
+ (0, _utils.onRemoveResponse)(nodeProps, draggedData.value);
181
+ }
182
+ }
183
+ }
250
184
  }),
251
- dragItem: monitor.getItem()
252
- };
253
- })(connectedBlankContent);
254
- var tileSource = {
255
- canDrag: function canDrag(props) {
256
- return !props.disabled && !!props.value;
257
- },
258
- beginDrag: function beginDrag(props) {
259
- return {
260
- id: props.targetId,
261
- value: props.value,
262
- instanceId: props.instanceId,
263
- fromChoice: true
264
- };
265
- },
266
- endDrag: function endDrag(props, monitor) {
267
- // this will be null if it did not drop
268
- var dropResult = monitor.getDropResult();
269
-
270
- if (!dropResult || dropResult.dropped && !props.duplicates) {
271
- var draggedItem = monitor.getItem();
272
-
273
- if (draggedItem.fromChoice) {
274
- props.removeResponse(draggedItem.value);
185
+ dragAttributes = _useDraggable.attributes,
186
+ dragListeners = _useDraggable.listeners,
187
+ setDragNodeRef = _useDraggable.setNodeRef,
188
+ isDragging = _useDraggable.isDragging;
189
+ var _useDroppable = (0, _core.useDroppable)({
190
+ id: "drop-".concat(n.key),
191
+ data: {
192
+ type: 'drag-in-the-blank-drop-choice',
193
+ accepts: ['drag-in-the-blank-choice', 'drag-in-the-blank-placed-choice'],
194
+ instanceId: instanceId,
195
+ value: value,
196
+ id: "drop-".concat(n.key),
197
+ nodeProps: nodeProps,
198
+ n: n,
199
+ opts: opts,
200
+ onDrop: function onDrop(draggedData, dropData) {
201
+ // check if we're dropping into a blank
202
+ var isValidBlank = (dropData === null || dropData === void 0 ? void 0 : dropData.type) === 'drag-in-the-blank-drop-choice';
203
+ if (!isValidBlank) return;
204
+
205
+ // if the dragged and dropped data are the same, do nothing
206
+ if (draggedData.value.id === dropData.value.id) return;
207
+ if (draggedData.type === 'drag-in-the-blank-choice') {
208
+ // place into blank
209
+ (0, _utils.onValueChange)(nodeProps, n, draggedData.value);
210
+ if (!opts.options.duplicates && draggedData.fromChoice) {
211
+ (0, _utils.onRemoveResponse)(nodeProps, draggedData.value);
212
+ }
213
+ return;
214
+ }
215
+
216
+ // moving placed choice between blanks
217
+ if (draggedData.type === 'drag-in-the-blank-placed-choice') {
218
+ // clear target blank
219
+ (0, _utils.onRemoveResponse)(nodeProps, dropData.value);
220
+
221
+ // set new blank value
222
+ (0, _utils.onValueChange)(nodeProps, n, draggedData.value);
223
+
224
+ // clear original blank - slight delay to ensure state updates correctly
225
+ setTimeout(function () {
226
+ return (0, _utils.onRemoveResponse)(nodeProps, draggedData.value);
227
+ }, 10);
228
+ }
229
+ }
275
230
  }
276
- }
277
- }
278
- };
279
- exports.tileSource = tileSource;
280
-
281
- var _default = (0, _drag.DragSource)('drag-in-the-blank-choice', tileSource, function (connect, monitor) {
282
- return {
283
- connectDragSource: connect.dragSource(),
284
- isDragging: monitor.isDragging()
231
+ }),
232
+ setDropNodeRef = _useDroppable.setNodeRef,
233
+ isOver = _useDroppable.isOver,
234
+ dragItem = _useDroppable.active;
235
+ var setNodeRef = function setNodeRef(node) {
236
+ setDragNodeRef(node);
237
+ setDropNodeRef(node);
285
238
  };
286
- })(DropTile);
287
-
288
- exports["default"] = _default;
239
+ var dragContent = /*#__PURE__*/_react["default"].createElement(BlankContent, {
240
+ n: n,
241
+ isDragging: isDragging,
242
+ isOver: isOver,
243
+ dragItem: dragItem === null || dragItem === void 0 || (_dragItem$data = dragItem.data) === null || _dragItem$data === void 0 ? void 0 : _dragItem$data.current,
244
+ value: value,
245
+ disabled: disabled
246
+ }, children);
247
+ var dragEl = !value ? /*#__PURE__*/_react["default"].createElement("span", {
248
+ ref: setDropNodeRef
249
+ }, dragContent) : /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({
250
+ ref: setNodeRef
251
+ }, dragAttributes, dragListeners), dragContent);
252
+ var content = /*#__PURE__*/_react["default"].createElement(StyledContent, {
253
+ className: (0, _classnames["default"])(isOver && 'over')
254
+ }, dragEl);
255
+ return content;
256
+ }
257
+ DragDropChoice.propTypes = {
258
+ value: _propTypes["default"].object,
259
+ disabled: _propTypes["default"].bool,
260
+ instanceId: _propTypes["default"].string,
261
+ children: _propTypes["default"].node,
262
+ n: _propTypes["default"].object.isRequired,
263
+ nodeProps: _propTypes["default"].object.isRequired,
264
+ opts: _propTypes["default"].shape({
265
+ options: _propTypes["default"].shape({
266
+ duplicates: _propTypes["default"].bool
267
+ })
268
+ }).isRequired
269
+ };
270
+ var _default = exports["default"] = DragDropChoice;
289
271
  //# sourceMappingURL=choice.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/plugins/respArea/drag-in-the-blank/choice.jsx"],"names":["useStyles","theme","content","border","palette","primary","main","fontSize","chip","minWidth","correct","color","incorrect","error","selected","primaryDark","BlankContent","props","handleClick","bind","state","hoveredElementSize","document","addEventListener","removeEventListener","event","classes","elementRef","className","contains","target","prevProps","isOver","node","width","offsetWidth","height","offsetHeight","prevState","snapshot","renderMath","setState","n","children","isDragging","dragItem","value","label","finalLabel","hasGrip","isPreview","ref","display","minHeight","background","defaults","BORDER_LIGHT","WHITE","BORDER_DARK","boxSizing","borderRadius","overflow","position","padding","undefined","key","top","left","__html","React","Component","PropTypes","object","func","bool","StyledBlankContent","connectedBlankContent","connectDropTarget","connectDragSource","dragContent","dragEl","over","tileTarget","drop","monitor","draggedItem","getItem","shouldDrop","index","onChange","dropped","canDrop","instanceId","DropTile","connect","dropTarget","shallow","tileSource","canDrag","disabled","beginDrag","id","targetId","fromChoice","endDrag","dropResult","getDropResult","duplicates","removeResponse","dragSource"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport isUndefined from 'lodash/isUndefined';\nimport { DragSource, DropTarget } from '@pie-lib/drag';\nimport { color } from '@pie-lib/render-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { withStyles } from '@material-ui/core/styles';\nimport classnames from 'classnames';\n\nimport { GripIcon } from '../icons';\n\nconst useStyles = withStyles((theme) => ({\n content: {\n border: `solid 0px ${theme.palette.primary.main}`,\n '& mjx-frac': {\n fontSize: '120% !important',\n },\n },\n chip: {\n minWidth: '90px',\n },\n correct: {\n border: `solid 1px ${color.correct()}`,\n },\n incorrect: {\n border: `solid 1px ${theme.palette.error.main}`,\n },\n selected: {\n border: `2px solid ${color.primaryDark()} !important`,\n },\n}));\n\nexport class BlankContent extends React.Component {\n static propTypes = {\n n: PropTypes.object,\n children: PropTypes.func,\n isDragging: PropTypes.bool,\n isOver: PropTypes.bool,\n dragItem: PropTypes.object,\n value: PropTypes.object,\n classes: PropTypes.object,\n };\n\n constructor(props) {\n super(props);\n\n this.handleClick = this.handleClick.bind(this);\n this.state = { hoveredElementSize: null };\n }\n\n componentDidMount() {\n document.addEventListener('click', this.handleClick);\n }\n\n componentWillUnmount() {\n document.removeEventListener('click', this.handleClick);\n }\n\n handleClick(event) {\n const { classes } = this.props;\n\n if (this.elementRef) {\n this.elementRef.className = this.elementRef.contains(event.target) ? classes.selected : '';\n }\n }\n\n getSnapshotBeforeUpdate(prevProps) {\n if (!prevProps.isOver && this.props.isOver && this.elementRef) {\n const node = this.elementRef;\n return { width: node.offsetWidth, height: node.offsetHeight };\n }\n return null;\n }\n\n componentDidUpdate(prevProps, prevState, snapshot) {\n if (this.elementRef && typeof renderMath === 'function') {\n renderMath(this.elementRef);\n }\n\n if (\n snapshot &&\n (!this.state.hoveredElementSize ||\n this.state.hoveredElementSize.width !== snapshot.width ||\n this.state.hoveredElementSize.height !== snapshot.height)\n ) {\n this.setState({ hoveredElementSize: snapshot });\n return;\n }\n\n if (prevProps.isOver && !this.props.isOver && this.state.hoveredElementSize) {\n this.setState({ hoveredElementSize: null });\n }\n }\n\n render() {\n const { n, children, isDragging, dragItem, isOver, value } = this.props;\n const { hoveredElementSize } = this.state;\n\n const label = dragItem && isOver ? dragItem.value.value : value.value || '\\u00A0';\n const finalLabel = isDragging ? '\\u00A0' : label;\n const hasGrip = finalLabel !== '\\u00A0';\n const isPreview = dragItem && isOver;\n\n return (\n <div\n ref={(ref) => (this.elementRef = ref)}\n style={{\n display: 'inline-flex',\n minWidth: '178px',\n minHeight: '36px',\n background: isPreview ? `${color.defaults.BORDER_LIGHT}` : `${color.defaults.WHITE}`,\n border: isPreview ? `1px solid ${color.defaults.BORDER_DARK}` : `1px solid ${color.defaults.BORDER_LIGHT}`,\n boxSizing: 'border-box',\n borderRadius: '3px',\n overflow: 'hidden',\n position: 'relative',\n padding: '8px 8px 8px 35px',\n width: hoveredElementSize ? hoveredElementSize.width : undefined,\n height: hoveredElementSize ? hoveredElementSize.height : undefined,\n }}\n data-key={n.key}\n contentEditable={false}\n >\n {hasGrip && (\n <GripIcon\n style={{\n position: 'absolute',\n top: '6px',\n left: '15px',\n color: '#9B9B9B',\n }}\n contentEditable={false}\n />\n )}\n <span\n dangerouslySetInnerHTML={{\n __html: finalLabel,\n }}\n />\n {children}\n </div>\n );\n }\n}\n\nconst StyledBlankContent = useStyles(BlankContent);\n\nconst connectedBlankContent = useStyles(({ connectDropTarget, connectDragSource, ...props }) => {\n const { classes, isOver, value } = props;\n const dragContent = <StyledBlankContent {...props} />;\n const dragEl = !value ? dragContent : connectDragSource(<span>{dragContent}</span>);\n const content = <span className={classnames(classes.content, isOver && classes.over)}>{dragEl}</span>;\n\n return connectDropTarget ? connectDropTarget(content) : content;\n});\n\nexport const tileTarget = {\n drop(props, monitor) {\n const draggedItem = monitor.getItem();\n const shouldDrop =\n isUndefined(draggedItem.value.index) ||\n isUndefined(props.value.index) ||\n draggedItem.value.index !== props.value.index;\n\n if (shouldDrop) {\n props.onChange(draggedItem.value);\n }\n\n return {\n dropped: shouldDrop,\n };\n },\n canDrop(props, monitor) {\n const draggedItem = monitor.getItem();\n\n return draggedItem.instanceId === props.instanceId;\n },\n};\n\nconst DropTile = DropTarget('drag-in-the-blank-choice', tileTarget, (connect, monitor) => ({\n connectDropTarget: connect.dropTarget(),\n isOver: monitor.isOver({ shallow: true }),\n dragItem: monitor.getItem(),\n}))(connectedBlankContent);\n\nexport const tileSource = {\n canDrag(props) {\n return !props.disabled && !!props.value;\n },\n beginDrag(props) {\n return {\n id: props.targetId,\n value: props.value,\n instanceId: props.instanceId,\n fromChoice: true,\n };\n },\n endDrag(props, monitor) {\n // this will be null if it did not drop\n const dropResult = monitor.getDropResult();\n\n if (!dropResult || (dropResult.dropped && !props.duplicates)) {\n const draggedItem = monitor.getItem();\n\n if (draggedItem.fromChoice) {\n props.removeResponse(draggedItem.value);\n }\n }\n },\n};\n\nexport default DragSource('drag-in-the-blank-choice', tileSource, (connect, monitor) => ({\n connectDragSource: connect.dragSource(),\n isDragging: monitor.isDragging(),\n}))(DropTile);\n"],"file":"choice.js"}
1
+ {"version":3,"file":"choice.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_classnames","_core","_renderUi","_mathRendering","_styles","_icons","_utils","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","StyledContent","styled","_ref","theme","border","concat","palette","primary","main","fontSize","minWidth","color","correct","error","primaryDark","BlankContent","_ref2","_dragItem$value2","_dragItem$value3","children","isDragging","isOver","dragItem","value","externalStyle","style","_useState","useState","_useState2","_slicedToArray2","hoveredElementSize","setHoveredElementSize","elementRef","useRef","handleClick","event","current","contains","target","classList","add","remove","useEffect","document","addEventListener","removeEventListener","_dragItem$value","currentContent","renderMath","id","node","width","offsetWidth","height","offsetHeight","label","finalLabel","hasGrip","isPreview","hasContent","containsHTML","test","spanProps","key","createElement","ref","display","minHeight","background","defaults","BORDER_LIGHT","WHITE","BORDER_DARK","boxSizing","borderRadius","overflow","position","padding","undefined","contentEditable","GripIcon","top","left","_extends2","dangerouslySetInnerHTML","__html","propTypes","PropTypes","object","func","bool","disabled","DragDropChoice","_ref3","_dragItem$data","instanceId","nodeProps","opts","_useDraggable","useDraggable","data","type","fromChoice","onRemove","draggedData","onRemoveResponse","onDrop","dropData","isValidBlank","onValueChange","options","duplicates","dragAttributes","attributes","dragListeners","listeners","setDragNodeRef","setNodeRef","_useDroppable","useDroppable","accepts","setTimeout","setDropNodeRef","active","dragContent","dragEl","content","className","classnames","string","isRequired","shape","_default","exports"],"sources":["../../../../src/plugins/respArea/drag-in-the-blank/choice.jsx"],"sourcesContent":["import React, { useRef, useEffect, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport { useDraggable, useDroppable } from '@dnd-kit/core';\nimport { color } from '@pie-lib/render-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { styled } from '@mui/material/styles';\n\nimport { GripIcon } from '../icons';\nimport { onValueChange, onRemoveResponse } from './utils';\n\nconst StyledContent = styled('span')(({ theme }) => ({\n border: `solid 0px ${theme.palette.primary.main}`,\n '& mjx-frac': {\n fontSize: '120% !important',\n },\n '&.chip': {\n minWidth: '90px',\n },\n '&.correct': {\n border: `solid 1px ${color.correct()}`,\n },\n '&.incorrect': {\n border: `solid 1px ${theme.palette.error.main}`,\n },\n '&.selected': {\n border: `2px solid ${color.primaryDark()} !important`,\n },\n}));\n\nexport function BlankContent({\n n,\n children,\n isDragging,\n isOver,\n dragItem,\n value,\n style: externalStyle\n}) {\n const [hoveredElementSize, setHoveredElementSize] = useState(null);\n const elementRef = useRef(null);\n\n const handleClick = (event) => {\n if (!elementRef.current) return;\n\n if (elementRef.current.contains(event.target)) {\n elementRef.current.classList.add('selected');\n } else {\n elementRef.current.classList.remove('selected');\n }\n };\n\n useEffect(() => {\n document.addEventListener('click', handleClick);\n return () => {\n document.removeEventListener('click', handleClick);\n };\n }, []);\n\n useEffect(() => {\n // Render math for the current value or preview\n const currentContent = (isOver && dragItem?.value?.value) || value?.value;\n\n if (!currentContent) return;\n\n if (elementRef.current && typeof renderMath === 'function') {\n renderMath(elementRef.current);\n }\n }, [value?.id, value?.value, isOver, dragItem?.value?.id, dragItem?.value?.value]);\n\n useEffect(() => {\n if (isOver && elementRef.current && !hoveredElementSize) {\n const node = elementRef.current;\n setHoveredElementSize({ width: node.offsetWidth, height: node.offsetHeight });\n } else if (!isOver && hoveredElementSize) {\n setHoveredElementSize(null);\n }\n }, [isOver, hoveredElementSize]);\n\n const label = dragItem && dragItem.value && isOver ? dragItem.value.value : value.value || '\\u00A0';\n const finalLabel = isDragging ? '\\u00A0' : label;\n const hasGrip = finalLabel !== '\\u00A0';\n const isPreview = dragItem && isOver;\n const hasContent = finalLabel !== '\\u00A0';\n const containsHTML = hasContent && /<[^>]+>/.test(finalLabel);\n\n const spanProps = {\n key: `${n.key}-${isPreview ? 'preview' : 'value'}`,\n ...(hasContent && { 'data-latex': '', 'data-raw': finalLabel }),\n };\n\n return (\n <div\n ref={elementRef}\n style={{\n display: 'inline-flex',\n minWidth: '178px',\n minHeight: '36px',\n background: isPreview ? `${color.defaults.BORDER_LIGHT}` : `${color.defaults.WHITE}`,\n border: isPreview ? `1px solid ${color.defaults.BORDER_DARK}` : `1px solid ${color.defaults.BORDER_LIGHT}`,\n boxSizing: 'border-box',\n borderRadius: '3px',\n overflow: 'hidden',\n position: 'relative',\n padding: '8px 8px 8px 35px',\n width: hoveredElementSize ? hoveredElementSize.width : undefined,\n height: hoveredElementSize ? hoveredElementSize.height : undefined,\n ...externalStyle,\n }}\n data-key={n.key}\n contentEditable={false}\n >\n {hasGrip && (\n <GripIcon\n style={{\n position: 'absolute',\n top: '6px',\n left: '15px',\n color: '#9B9B9B',\n }}\n contentEditable={false}\n />\n )}\n {containsHTML ? (\n <span {...spanProps} dangerouslySetInnerHTML={{ __html: finalLabel }} />\n ) : (\n <span {...spanProps}>{finalLabel}</span>\n )}\n {children}\n </div>\n );\n}\n\nBlankContent.propTypes = {\n n: PropTypes.object,\n children: PropTypes.func,\n isDragging: PropTypes.bool,\n isOver: PropTypes.bool,\n dragItem: PropTypes.object,\n value: PropTypes.object,\n disabled: PropTypes.bool,\n style: PropTypes.object,\n};\n\nfunction DragDropChoice({\n value,\n disabled,\n instanceId,\n children,\n n,\n nodeProps,\n opts,\n}) {\n const {\n attributes: dragAttributes,\n listeners: dragListeners,\n setNodeRef: setDragNodeRef,\n isDragging,\n } = useDraggable({\n id: `drag-${n.key}`,\n disabled: disabled || !value?.value,\n data: {\n id: `drag-${n.key}`,\n value,\n instanceId,\n nodeProps,\n n,\n opts,\n type: 'drag-in-the-blank-placed-choice',\n fromChoice: !value,\n onRemove: (draggedData) => onRemoveResponse(nodeProps, draggedData.value),\n onDrop: (draggedData, dropData) => {\n // check if we're dropping into a blank\n const isValidBlank =\n dropData?.type === 'drag-in-the-blank-drop-choice';\n\n if (!isValidBlank) return;\n\n // place into blank\n onValueChange(nodeProps, n, draggedData.value);\n\n if (!opts.options.duplicates && draggedData.fromChoice) {\n onRemoveResponse(nodeProps, draggedData.value);\n }\n }\n }\n });\n\n const {\n setNodeRef: setDropNodeRef,\n isOver,\n active: dragItem,\n } = useDroppable({\n id: `drop-${n.key}`,\n data: {\n type: 'drag-in-the-blank-drop-choice',\n accepts: ['drag-in-the-blank-choice', 'drag-in-the-blank-placed-choice'],\n instanceId: instanceId,\n value: value,\n id: `drop-${n.key}`,\n nodeProps,\n n,\n opts,\n onDrop: (draggedData, dropData) => {\n // check if we're dropping into a blank\n const isValidBlank =\n dropData?.type === 'drag-in-the-blank-drop-choice';\n\n if (!isValidBlank) return;\n\n // if the dragged and dropped data are the same, do nothing\n if (draggedData.value.id === dropData.value.id) return;\n\n if (draggedData.type === 'drag-in-the-blank-choice') {\n // place into blank\n onValueChange(nodeProps, n, draggedData.value);\n\n if (!opts.options.duplicates && draggedData.fromChoice) {\n onRemoveResponse(nodeProps, draggedData.value);\n }\n return;\n }\n\n // moving placed choice between blanks\n if (draggedData.type === 'drag-in-the-blank-placed-choice') {\n // clear target blank\n onRemoveResponse(nodeProps, dropData.value);\n\n // set new blank value\n onValueChange(nodeProps, n, draggedData.value);\n\n // clear original blank - slight delay to ensure state updates correctly\n setTimeout(() => onRemoveResponse(nodeProps, draggedData.value), 10);\n }\n }\n }\n });\n\n const setNodeRef = (node) => {\n setDragNodeRef(node);\n setDropNodeRef(node);\n };\n\n const dragContent = (\n <BlankContent\n n={n}\n isDragging={isDragging}\n isOver={isOver}\n dragItem={dragItem?.data?.current}\n value={value}\n disabled={disabled}\n >\n {children}\n </BlankContent>\n );\n\n const dragEl = !value ? (\n <span ref={setDropNodeRef}>{dragContent}</span>\n ) : (\n <span ref={setNodeRef} {...dragAttributes} {...dragListeners}>\n {dragContent}\n </span>\n );\n\n const content = (\n <StyledContent className={classnames(isOver && 'over')}>\n {dragEl}\n </StyledContent>\n );\n\n return content;\n}\n\nDragDropChoice.propTypes = {\n value: PropTypes.object,\n disabled: PropTypes.bool,\n instanceId: PropTypes.string,\n children: PropTypes.node,\n n: PropTypes.object.isRequired,\n nodeProps: PropTypes.object.isRequired,\n opts: PropTypes.shape({\n options: PropTypes.shape({\n duplicates: PropTypes.bool,\n }),\n }).isRequired,\n};\n\nexport default DragDropChoice;\n"],"mappings":"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","ignoreList":[]}