@pie-element/categorize 11.3.4-next.3 → 12.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/CHANGELOG.md +0 -11
  2. package/configure/CHANGELOG.md +0 -11
  3. package/configure/lib/__tests__/main.test.js +100 -0
  4. package/configure/lib/__tests__/utils.js +39 -0
  5. package/configure/lib/defaults.js +3 -6
  6. package/configure/lib/defaults.js.map +1 -1
  7. package/configure/lib/design/__tests__/builder.test.js +34 -0
  8. package/configure/lib/design/__tests__/buttons.test.js +36 -0
  9. package/configure/lib/design/__tests__/header.test.js +37 -0
  10. package/configure/lib/design/__tests__/index.test.js +125 -0
  11. package/configure/lib/design/__tests__/input-header.test.js +41 -0
  12. package/configure/lib/design/builder.js +16 -34
  13. package/configure/lib/design/builder.js.map +1 -1
  14. package/configure/lib/design/buttons.js +42 -96
  15. package/configure/lib/design/buttons.js.map +1 -1
  16. package/configure/lib/design/categories/RowLabel.js +34 -47
  17. package/configure/lib/design/categories/RowLabel.js.map +1 -1
  18. package/configure/lib/design/categories/__tests__/alternateResponses.test.js +93 -0
  19. package/configure/lib/design/categories/__tests__/category.test.js +65 -0
  20. package/configure/lib/design/categories/__tests__/choice-preview.test.js +52 -0
  21. package/configure/lib/design/categories/__tests__/droppable-placeholder.test.js +63 -0
  22. package/configure/lib/design/categories/__tests__/index.test.js +91 -0
  23. package/configure/lib/design/categories/alternateResponses.js +97 -252
  24. package/configure/lib/design/categories/alternateResponses.js.map +1 -1
  25. package/configure/lib/design/categories/category.js +136 -209
  26. package/configure/lib/design/categories/category.js.map +1 -1
  27. package/configure/lib/design/categories/choice-preview.js +62 -127
  28. package/configure/lib/design/categories/choice-preview.js.map +1 -1
  29. package/configure/lib/design/categories/droppable-placeholder.js +74 -166
  30. package/configure/lib/design/categories/droppable-placeholder.js.map +1 -1
  31. package/configure/lib/design/categories/index.js +196 -385
  32. package/configure/lib/design/categories/index.js.map +1 -1
  33. package/configure/lib/design/choices/__tests__/choice.test.js +62 -0
  34. package/configure/lib/design/choices/__tests__/config.test.js +66 -0
  35. package/configure/lib/design/choices/__tests__/index.test.js +70 -0
  36. package/configure/lib/design/choices/choice.js +156 -265
  37. package/configure/lib/design/choices/choice.js.map +1 -1
  38. package/configure/lib/design/choices/config.js +43 -99
  39. package/configure/lib/design/choices/config.js.map +1 -1
  40. package/configure/lib/design/choices/index.js +149 -237
  41. package/configure/lib/design/choices/index.js.map +1 -1
  42. package/configure/lib/design/header.js +58 -112
  43. package/configure/lib/design/header.js.map +1 -1
  44. package/configure/lib/design/index.js +633 -478
  45. package/configure/lib/design/index.js.map +1 -1
  46. package/configure/lib/design/input-header.js +95 -151
  47. package/configure/lib/design/input-header.js.map +1 -1
  48. package/configure/lib/design/utils.js +5 -16
  49. package/configure/lib/design/utils.js.map +1 -1
  50. package/configure/lib/index.js +121 -184
  51. package/configure/lib/index.js.map +1 -1
  52. package/configure/lib/main.js +31 -75
  53. package/configure/lib/main.js.map +1 -1
  54. package/configure/lib/utils.js +23 -33
  55. package/configure/lib/utils.js.map +1 -1
  56. package/configure/package.json +15 -15
  57. package/controller/CHANGELOG.md +0 -11
  58. package/controller/lib/__tests__/index.test.js +526 -0
  59. package/controller/lib/defaults.js +3 -6
  60. package/controller/lib/defaults.js.map +1 -1
  61. package/controller/lib/index.js +238 -319
  62. package/controller/lib/index.js.map +1 -1
  63. package/controller/lib/utils.js +29 -66
  64. package/controller/lib/utils.js.map +1 -1
  65. package/controller/package.json +5 -5
  66. package/docs/demo/.pie/.configure/package.json +10 -0
  67. package/docs/demo/.pie/.configure/yarn.lock +2181 -0
  68. package/docs/demo/.pie/.controllers/package.json +10 -0
  69. package/docs/demo/.pie/.controllers/yarn.lock +110 -0
  70. package/docs/demo/.pie/info.entry.js +89 -0
  71. package/docs/demo/.pie/info.webpack.config.js +119 -0
  72. package/docs/demo/.pie/package.json +10 -0
  73. package/docs/demo/.pie/yarn.lock +2190 -0
  74. package/docs/demo/pie.manifest.json +11 -0
  75. package/lib/__tests__/index.test.js +197 -0
  76. package/lib/categorize/__tests__/categories.test.js +138 -0
  77. package/lib/categorize/__tests__/category.test.js +137 -0
  78. package/lib/categorize/__tests__/choice.test.js +88 -0
  79. package/lib/categorize/__tests__/choices.test.js +118 -0
  80. package/lib/categorize/__tests__/droppable-placeholder.test.js +96 -0
  81. package/lib/categorize/__tests__/grid-content.test.js +48 -0
  82. package/lib/categorize/__tests__/index.test.js +152 -0
  83. package/lib/categorize/categories.js +107 -165
  84. package/lib/categorize/categories.js.map +1 -1
  85. package/lib/categorize/category.js +74 -124
  86. package/lib/categorize/category.js.map +1 -1
  87. package/lib/categorize/choice.js +119 -246
  88. package/lib/categorize/choice.js.map +1 -1
  89. package/lib/categorize/choices.js +67 -132
  90. package/lib/categorize/choices.js.map +1 -1
  91. package/lib/categorize/droppable-placeholder.js +47 -104
  92. package/lib/categorize/droppable-placeholder.js.map +1 -1
  93. package/lib/categorize/grid-content.js +40 -88
  94. package/lib/categorize/grid-content.js.map +1 -1
  95. package/lib/categorize/index.js +342 -318
  96. package/lib/categorize/index.js.map +1 -1
  97. package/lib/index.js +286 -307
  98. package/lib/index.js.map +1 -1
  99. package/package.json +16 -14
  100. package/esm/configure.js +0 -34401
  101. package/esm/configure.js.map +0 -1
  102. package/esm/controller.js +0 -1468
  103. package/esm/controller.js.map +0 -1
  104. package/esm/element.js +0 -13134
  105. package/esm/element.js.map +0 -1
  106. package/esm/package.json +0 -3
@@ -1,388 +1,412 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports["default"] = exports.Categorize = void 0;
9
-
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
7
+ exports.default = exports.Categorize = void 0;
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
22
9
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
23
-
24
10
  var _react = _interopRequireDefault(require("react"));
25
-
26
11
  var _propTypes = _interopRequireDefault(require("prop-types"));
27
-
28
- var _choices = _interopRequireDefault(require("./choices"));
29
-
30
- var _categories = _interopRequireDefault(require("./categories"));
31
-
12
+ var _debug = _interopRequireDefault(require("debug"));
13
+ var _styles = require("@mui/material/styles");
14
+ var _core = require("@dnd-kit/core");
32
15
  var _correctAnswerToggle = _interopRequireDefault(require("@pie-lib/correct-answer-toggle"));
33
-
34
- var _styles = require("@material-ui/core/styles");
35
-
36
16
  var _categorize = require("@pie-lib/categorize");
37
-
38
17
  var _drag = require("@pie-lib/drag");
39
-
40
18
  var _renderUi = require("@pie-lib/render-ui");
41
-
42
- var _debug = _interopRequireDefault(require("debug"));
43
-
19
+ var _mathRendering = require("@pie-lib/math-rendering");
44
20
  var _translator = _interopRequireDefault(require("@pie-lib/translator"));
45
-
46
21
  var _configUi = require("@pie-lib/config-ui");
47
-
48
- 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); }; }
49
-
50
- 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; } }
51
-
52
- var translator = _translator["default"].translator;
53
- var log = (0, _debug["default"])('@pie-ui:categorize');
54
-
55
- var Categorize = /*#__PURE__*/function (_React$Component) {
56
- (0, _inherits2["default"])(Categorize, _React$Component);
57
-
58
- var _super = _createSuper(Categorize);
59
-
60
- function Categorize(props) {
61
- var _this;
62
-
63
- (0, _classCallCheck2["default"])(this, Categorize);
64
- _this = _super.call(this, props);
65
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "removeChoice", function (c) {
22
+ var _choices = _interopRequireDefault(require("./choices"));
23
+ var _choice = _interopRequireDefault(require("./choice"));
24
+ var _categories = _interopRequireDefault(require("./categories"));
25
+ const {
26
+ translator
27
+ } = _translator.default;
28
+ const log = (0, _debug.default)('@pie-ui:categorize');
29
+ class DragPreviewWrapper extends _react.default.Component {
30
+ constructor(...args) {
31
+ super(...args);
32
+ (0, _defineProperty2.default)(this, "containerRef", /*#__PURE__*/_react.default.createRef());
33
+ }
34
+ componentDidMount() {
35
+ if (this.containerRef.current) {
36
+ (0, _mathRendering.renderMath)(this.containerRef.current);
37
+ }
38
+ }
39
+ render() {
40
+ return /*#__PURE__*/_react.default.createElement("div", {
41
+ ref: this.containerRef
42
+ }, this.props.children);
43
+ }
44
+ }
45
+ class Categorize extends _react.default.Component {
46
+ constructor(props) {
47
+ super(props);
48
+ (0, _defineProperty2.default)(this, "removeChoice", c => {
66
49
  log('[removeChoice]: ', c);
67
- var _this$props = _this.props,
68
- onAnswersChange = _this$props.onAnswersChange,
69
- session = _this$props.session;
70
- var answers = (0, _categorize.removeChoiceFromCategory)(c.id, c.categoryId, c.choiceIndex, session.answers);
50
+ const {
51
+ onAnswersChange,
52
+ session
53
+ } = this.props;
54
+ const answers = (0, _categorize.removeChoiceFromCategory)(c.id, c.categoryId, c.choiceIndex, session.answers);
71
55
  onAnswersChange(answers);
72
56
  });
73
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "dropChoice", function (categoryId, draggedChoice) {
74
- var _this$props2 = _this.props,
75
- session = _this$props2.session,
76
- onAnswersChange = _this$props2.onAnswersChange,
77
- model = _this$props2.model;
78
-
79
- var _ref = model || {},
80
- _ref$maxChoicesPerCat = _ref.maxChoicesPerCategory,
81
- maxChoicesPerCategory = _ref$maxChoicesPerCat === void 0 ? 0 : _ref$maxChoicesPerCat;
82
-
83
- var _ref2 = session || {},
84
- _ref2$answers = _ref2.answers,
85
- answers = _ref2$answers === void 0 ? [] : _ref2$answers;
86
-
87
- var newAnswers;
88
-
57
+ (0, _defineProperty2.default)(this, "dropChoice", (categoryId, draggedChoice) => {
58
+ const {
59
+ session,
60
+ onAnswersChange,
61
+ model
62
+ } = this.props;
63
+ const {
64
+ maxChoicesPerCategory = 0
65
+ } = model || {};
66
+ const {
67
+ answers = []
68
+ } = session || {};
69
+ let newAnswers;
89
70
  if (draggedChoice) {
90
71
  log('[dropChoice] category: ', draggedChoice.categoryId, 'choice: ', draggedChoice);
91
72
  } else {
92
73
  log('[dropChoice] category: ', undefined, 'choice: ', undefined);
93
74
  }
75
+ const answer = answers.find(answer => answer.category === categoryId);
94
76
 
95
- var answer = answers.find(function (answer) {
96
- return answer.category === categoryId;
97
- }); // treat special case to replace the existing choice with the new one when maxChoicesPerCategory = 1
98
-
77
+ // treat special case to replace the existing choice with the new one when maxChoicesPerCategory = 1
99
78
  if (draggedChoice && maxChoicesPerCategory === 1 && answer && answer.choices && answer.choices.length === 1) {
79
+ // First, move the dragged choice to the target category (this will also remove it from source if allowMultiplePlacements is disabled)
100
80
  newAnswers = (0, _categorize.moveChoiceToCategory)(draggedChoice.id, draggedChoice.categoryId, categoryId, draggedChoice.choiceIndex, answers);
101
- newAnswers = (0, _categorize.removeChoiceFromCategory)(answer.choices[0], categoryId, 0, answers);
102
- } // treat special case when there are as many choices as maxChoicesPerCategory is
81
+ // Then, remove the existing choice from the target category (use newAnswers, not answers)
82
+ newAnswers = (0, _categorize.removeChoiceFromCategory)(answer.choices[0], categoryId, 0, newAnswers);
83
+ }
84
+
85
+ // treat special case when there are as many choices as maxChoicesPerCategory is
103
86
  else if (draggedChoice && maxChoicesPerCategory > 1 && answer && answer.choices && answer.choices.length === maxChoicesPerCategory) {
104
87
  newAnswers = draggedChoice.categoryId ? (0, _categorize.moveChoiceToCategory)(draggedChoice.id, draggedChoice.categoryId, draggedChoice.categoryId, draggedChoice.choiceIndex, answers) : (0, _categorize.removeChoiceFromCategory)(draggedChoice.id, draggedChoice.categoryId, draggedChoice.choiceIndex, answers);
105
-
106
- _this.setState({
88
+ this.setState({
107
89
  showMaxChoiceAlert: true
108
90
  });
109
- } // treat special case when there are more choices that maxChoicesPerCategory is (testing purpose in pits)
91
+ }
92
+
93
+ // treat special case when there are more choices that maxChoicesPerCategory is (testing purpose in pits)
110
94
  else if (maxChoicesPerCategory !== 0 && answer && answer.choices && answer.choices.length > maxChoicesPerCategory) {
111
95
  newAnswers = answers;
112
-
113
- _this.setState({
96
+ this.setState({
114
97
  showMaxChoiceAlert: true
115
98
  });
116
99
  } else {
117
- newAnswers = draggedChoice ? (0, _categorize.moveChoiceToCategory)(draggedChoice.id, draggedChoice.categoryId, categoryId, draggedChoice.choiceIndex, answers) : _this.removeChoice(categoryId);
100
+ newAnswers = draggedChoice ? (0, _categorize.moveChoiceToCategory)(draggedChoice.id, draggedChoice.categoryId, categoryId, draggedChoice.choiceIndex, answers) : this.removeChoice(categoryId);
118
101
  }
119
-
120
102
  if (draggedChoice) {
121
103
  onAnswersChange(newAnswers);
122
104
  }
123
105
  });
124
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "toggleShowCorrect", function () {
125
- return _this.setState({
126
- showCorrect: !_this.state.showCorrect
127
- }, function () {
128
- _this.props.onShowCorrectToggle();
129
- });
130
- });
131
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getPositionDirection", function (choicePosition) {
132
- var flexDirection;
133
-
106
+ (0, _defineProperty2.default)(this, "toggleShowCorrect", () => this.setState({
107
+ showCorrect: !this.state.showCorrect
108
+ }, () => {
109
+ this.props.onShowCorrectToggle();
110
+ }));
111
+ (0, _defineProperty2.default)(this, "getPositionDirection", choicePosition => {
112
+ let flexDirection;
134
113
  switch (choicePosition) {
135
114
  case 'left':
136
115
  flexDirection = 'row-reverse';
137
116
  break;
138
-
139
117
  case 'right':
140
118
  flexDirection = 'row';
141
119
  break;
142
-
143
120
  case 'below':
144
121
  flexDirection = 'column';
145
122
  break;
146
-
147
123
  default:
148
124
  // above
149
125
  flexDirection = 'column-reverse';
150
126
  break;
151
127
  }
152
-
153
128
  return flexDirection;
154
129
  });
155
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "existAlternateResponse", function (correctResponse) {
156
- return correctResponse === null || correctResponse === void 0 ? void 0 : correctResponse.some(function (correctRes) {
157
- var _correctRes$alternate;
158
-
159
- return ((_correctRes$alternate = correctRes.alternateResponses) === null || _correctRes$alternate === void 0 ? void 0 : _correctRes$alternate.length) > 0;
160
- });
161
- });
162
- _this.state = {
130
+ (0, _defineProperty2.default)(this, "existAlternateResponse", correctResponse => correctResponse?.some(correctRes => correctRes.alternateResponses?.length > 0));
131
+ this.state = {
163
132
  showCorrect: false,
164
133
  showMaxChoiceAlert: false
165
134
  };
166
- return _this;
167
135
  }
168
-
169
- (0, _createClass2["default"])(Categorize, [{
170
- key: "UNSAFE_componentWillReceiveProps",
171
- value: function UNSAFE_componentWillReceiveProps(nextProps) {
172
- var model = this.props.model;
173
- var nextModel = nextProps.model; // check if the note is the default one for prev language and change to the default one for new language
174
- // this check is necessary in order to diferanciate between default and authour defined note
175
- // and only change between languages for default ones
176
-
177
- if (model.note && model.language && model.language !== nextModel.language && model.note === translator.t('common:commonCorrectAnswerWithAlternates', {
178
- lng: model.language
179
- })) {
180
- model.note = translator.t('common:commonCorrectAnswerWithAlternates', {
181
- lng: nextModel.language
182
- });
183
- }
184
-
185
- this.setState({
186
- showCorrect: false
136
+ UNSAFE_componentWillReceiveProps(nextProps) {
137
+ const {
138
+ model
139
+ } = this.props;
140
+ const {
141
+ model: nextModel
142
+ } = nextProps;
143
+
144
+ // check if the note is the default one for prev language and change to the default one for new language
145
+ // this check is necessary in order to diferanciate between default and authour defined note
146
+ // and only change between languages for default ones
147
+ if (model.note && model.language && model.language !== nextModel.language && model.note === translator.t('common:commonCorrectAnswerWithAlternates', {
148
+ lng: model.language
149
+ })) {
150
+ model.note = translator.t('common:commonCorrectAnswerWithAlternates', {
151
+ lng: nextModel.language
187
152
  });
188
153
  }
189
- }, {
190
- key: "render",
191
- value: function render() {
192
- var _this2 = this;
193
-
194
- var _this$props3 = this.props,
195
- classes = _this$props3.classes,
196
- model = _this$props3.model,
197
- session = _this$props3.session;
198
- var _this$state = this.state,
199
- showCorrect = _this$state.showCorrect,
200
- showMaxChoiceAlert = _this$state.showMaxChoiceAlert;
201
- var choicesPosition = model.choicesPosition,
202
- extraCSSRules = model.extraCSSRules,
203
- note = model.note,
204
- showNote = model.showNote,
205
- env = model.env,
206
- language = model.language,
207
- maxChoicesPerCategory = model.maxChoicesPerCategory,
208
- autoplayAudioEnabled = model.autoplayAudioEnabled,
209
- customAudioButton = model.customAudioButton;
210
-
211
- var _ref3 = env || {},
212
- mode = _ref3.mode,
213
- role = _ref3.role;
214
-
215
- var choicePosition = choicesPosition || 'above';
216
- var style = {
217
- flexDirection: this.getPositionDirection(choicePosition),
218
- gap: '8px'
219
- };
220
-
221
- var _buildState = (0, _categorize.buildState)(model.categories, model.choices, showCorrect ? model.correctResponse : session.answers, model.correctResponse),
222
- categories = _buildState.categories,
223
- choices = _buildState.choices,
224
- correct = _buildState.correct;
225
-
226
- log('[render] disabled: ', model.disabled);
227
- var rowLabels = model.rowLabels,
228
- categoriesPerRow = model.categoriesPerRow,
229
- correctResponse = model.correctResponse,
230
- fontSizeFactor = model.fontSizeFactor;
231
- var nbOfRows = categories && Math.ceil(categories.length / categoriesPerRow) || 0;
232
- var existAlternate = this.existAlternateResponse(correctResponse) || false;
233
- var displayNote = (showCorrect || mode === 'view' && role === 'instructor') && showNote && note && existAlternate;
234
- var alertMessage = translator.t('translation:categorize:limitMaxChoicesPerCategory', {
235
- lng: model.language,
236
- maxChoicesPerCategory: maxChoicesPerCategory
237
- });
238
- var alertTitle = translator.t('common:warning', {
239
- lng: model.language
240
- });
241
- var onCloseText = translator.t('common:cancel', {
242
- lng: model.language
243
- });
244
- var showRationale = model.rationale && ((0, _renderUi.hasText)(model.rationale) || (0, _renderUi.hasMedia)(model.rationale));
245
- var showTeacherInstructions = model.teacherInstructions && ((0, _renderUi.hasText)(model.teacherInstructions) || (0, _renderUi.hasMedia)(model.teacherInstructions));
246
- return /*#__PURE__*/_react["default"].createElement(_renderUi.UiLayout, {
247
- extraCSSRules: extraCSSRules,
248
- id: 'main-container',
249
- className: classes.mainContainer,
250
- fontSizeFactor: fontSizeFactor
251
- }, showTeacherInstructions && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_renderUi.Collapsible, {
252
- labels: {
253
- hidden: 'Show Teacher Instructions',
254
- visible: 'Hide Teacher Instructions'
255
- },
256
- className: classes.collapsible
257
- }, /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
258
- prompt: model.teacherInstructions
259
- }))), model.prompt && /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
260
- prompt: model.prompt,
261
- autoplayAudioEnabled: autoplayAudioEnabled,
262
- customAudioButton: customAudioButton
263
- }), /*#__PURE__*/_react["default"].createElement(_correctAnswerToggle["default"], {
264
- show: showCorrect || correct === false,
265
- toggled: showCorrect,
266
- onToggle: this.toggleShowCorrect,
267
- language: language
268
- }), /*#__PURE__*/_react["default"].createElement("div", {
269
- className: classes.categorize,
270
- style: style
271
- }, /*#__PURE__*/_react["default"].createElement("div", {
272
- style: {
273
- display: 'flex',
274
- flex: 1
275
- }
276
- }, /*#__PURE__*/_react["default"].createElement(_categories["default"], {
277
- model: model,
278
- disabled: model.disabled,
279
- categories: categories,
280
- onDropChoice: this.dropChoice,
281
- onRemoveChoice: this.removeChoice,
282
- rowLabels: (rowLabels || []).slice(0, nbOfRows)
283
- })), /*#__PURE__*/_react["default"].createElement(_choices["default"], {
284
- disabled: model.disabled,
285
- model: model,
286
- choices: choices,
287
- choicePosition: choicePosition,
288
- onDropChoice: this.dropChoice,
289
- onRemoveChoice: this.removeChoice
290
- })), displayNote && /*#__PURE__*/_react["default"].createElement("div", {
291
- className: classes.note,
292
- dangerouslySetInnerHTML: {
293
- __html: note
294
- }
295
- }), showRationale && /*#__PURE__*/_react["default"].createElement(_renderUi.Collapsible, {
296
- labels: {
297
- hidden: 'Show Rationale',
298
- visible: 'Hide Rationale'
299
- },
300
- className: classes.collapsible
301
- }, /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
302
- prompt: model.rationale
303
- })), model.correctness && model.feedback && !showCorrect && /*#__PURE__*/_react["default"].createElement(_renderUi.Feedback, {
304
- correctness: model.correctness,
305
- feedback: model.feedback
306
- }), /*#__PURE__*/_react["default"].createElement(_configUi.AlertDialog, {
307
- title: alertTitle,
308
- text: alertMessage,
309
- open: showMaxChoiceAlert,
310
- onCloseText: onCloseText,
311
- onClose: function onClose() {
312
- return _this2.setState({
313
- showMaxChoiceAlert: false
314
- });
315
- }
316
- }));
317
- }
318
- }]);
319
- return Categorize;
320
- }(_react["default"].Component);
321
-
154
+ this.setState({
155
+ showCorrect: false
156
+ });
157
+ }
158
+ render() {
159
+ const {
160
+ model,
161
+ session
162
+ } = this.props;
163
+ const {
164
+ showCorrect,
165
+ showMaxChoiceAlert
166
+ } = this.state;
167
+ const {
168
+ choicesPosition,
169
+ extraCSSRules,
170
+ note,
171
+ showNote,
172
+ env,
173
+ language,
174
+ maxChoicesPerCategory,
175
+ autoplayAudioEnabled,
176
+ customAudioButton
177
+ } = model;
178
+ const {
179
+ mode,
180
+ role
181
+ } = env || {};
182
+ const choicePosition = choicesPosition || 'above';
183
+ const style = {
184
+ flexDirection: this.getPositionDirection(choicePosition),
185
+ gap: '8px'
186
+ };
187
+ const {
188
+ categories,
189
+ choices,
190
+ correct
191
+ } = (0, _categorize.buildState)(model.categories, model.choices, showCorrect ? model.correctResponse : session.answers, model.correctResponse);
192
+ log('[render] disabled: ', model.disabled);
193
+ const {
194
+ rowLabels,
195
+ categoriesPerRow,
196
+ correctResponse,
197
+ fontSizeFactor
198
+ } = model;
199
+ const nbOfRows = categories && Math.ceil(categories.length / categoriesPerRow) || 0;
200
+ const existAlternate = this.existAlternateResponse(correctResponse) || false;
201
+ const displayNote = (showCorrect || mode === 'view' && role === 'instructor') && showNote && note && existAlternate;
202
+ const alertMessage = translator.t('translation:categorize:limitMaxChoicesPerCategory', {
203
+ lng: model.language,
204
+ maxChoicesPerCategory
205
+ });
206
+ const alertTitle = translator.t('common:warning', {
207
+ lng: model.language
208
+ });
209
+ const onCloseText = translator.t('common:cancel', {
210
+ lng: model.language
211
+ });
212
+ const showRationale = model.rationale && ((0, _renderUi.hasText)(model.rationale) || (0, _renderUi.hasMedia)(model.rationale));
213
+ const showTeacherInstructions = model.teacherInstructions && ((0, _renderUi.hasText)(model.teacherInstructions) || (0, _renderUi.hasMedia)(model.teacherInstructions));
214
+ return /*#__PURE__*/_react.default.createElement(StyledUiLayout, {
215
+ extraCSSRules: extraCSSRules,
216
+ id: 'main-container',
217
+ fontSizeFactor: fontSizeFactor
218
+ }, showTeacherInstructions && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(StyledCollapsible, {
219
+ labels: {
220
+ hidden: 'Show Teacher Instructions',
221
+ visible: 'Hide Teacher Instructions'
222
+ }
223
+ }, /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
224
+ prompt: model.teacherInstructions
225
+ }))), model.prompt && /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
226
+ prompt: model.prompt,
227
+ autoplayAudioEnabled: autoplayAudioEnabled,
228
+ customAudioButton: customAudioButton
229
+ }), /*#__PURE__*/_react.default.createElement(_correctAnswerToggle.default, {
230
+ show: showCorrect || correct === false,
231
+ toggled: showCorrect,
232
+ onToggle: this.toggleShowCorrect,
233
+ language: language
234
+ }), /*#__PURE__*/_react.default.createElement(StyledCategorize, {
235
+ style: style
236
+ }, /*#__PURE__*/_react.default.createElement("div", {
237
+ style: {
238
+ display: 'flex',
239
+ flex: 1
240
+ }
241
+ }, /*#__PURE__*/_react.default.createElement(_categories.default, {
242
+ model: model,
243
+ disabled: model.disabled,
244
+ categories: categories,
245
+ onDropChoice: this.dropChoice,
246
+ onRemoveChoice: this.removeChoice,
247
+ rowLabels: (rowLabels || []).slice(0, nbOfRows)
248
+ })), /*#__PURE__*/_react.default.createElement(_choices.default, {
249
+ disabled: model.disabled,
250
+ model: model,
251
+ choices: choices,
252
+ choicePosition: choicePosition,
253
+ onDropChoice: this.dropChoice,
254
+ onRemoveChoice: this.removeChoice
255
+ })), displayNote && /*#__PURE__*/_react.default.createElement(StyledNote, {
256
+ dangerouslySetInnerHTML: {
257
+ __html: note
258
+ }
259
+ }), showRationale && /*#__PURE__*/_react.default.createElement(StyledCollapsible, {
260
+ labels: {
261
+ hidden: 'Show Rationale',
262
+ visible: 'Hide Rationale'
263
+ }
264
+ }, /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
265
+ prompt: model.rationale
266
+ })), model.correctness && model.feedback && !showCorrect && /*#__PURE__*/_react.default.createElement(_renderUi.Feedback, {
267
+ correctness: model.correctness,
268
+ feedback: model.feedback
269
+ }), /*#__PURE__*/_react.default.createElement(_configUi.AlertDialog, {
270
+ title: alertTitle,
271
+ text: alertMessage,
272
+ open: showMaxChoiceAlert,
273
+ onCloseText: onCloseText,
274
+ onClose: () => this.setState({
275
+ showMaxChoiceAlert: false
276
+ })
277
+ }));
278
+ }
279
+ }
322
280
  exports.Categorize = Categorize;
323
- (0, _defineProperty2["default"])(Categorize, "propTypes", {
324
- classes: _propTypes["default"].object.isRequired,
325
- model: _propTypes["default"].object,
326
- session: _propTypes["default"].shape({
327
- answers: _propTypes["default"].arrayOf(_propTypes["default"].shape({
328
- choice: _propTypes["default"].string,
329
- category: _propTypes["default"].string
281
+ (0, _defineProperty2.default)(Categorize, "propTypes", {
282
+ model: _propTypes.default.object,
283
+ session: _propTypes.default.shape({
284
+ answers: _propTypes.default.arrayOf(_propTypes.default.shape({
285
+ choice: _propTypes.default.string,
286
+ category: _propTypes.default.string
330
287
  }))
331
288
  }),
332
- onAnswersChange: _propTypes["default"].func.isRequired,
333
- onShowCorrectToggle: _propTypes["default"].func.isRequired
289
+ onAnswersChange: _propTypes.default.func.isRequired,
290
+ onShowCorrectToggle: _propTypes.default.func.isRequired,
291
+ pauseMathObserver: _propTypes.default.func,
292
+ resumeMathObserver: _propTypes.default.func
334
293
  });
335
- (0, _defineProperty2["default"])(Categorize, "defaultProps", {
294
+ (0, _defineProperty2.default)(Categorize, "defaultProps", {
336
295
  disabled: false
337
296
  });
338
-
339
- var CategorizeProvider = /*#__PURE__*/function (_React$Component2) {
340
- (0, _inherits2["default"])(CategorizeProvider, _React$Component2);
341
-
342
- var _super2 = _createSuper(CategorizeProvider);
343
-
344
- function CategorizeProvider(props) {
345
- var _this3;
346
-
347
- (0, _classCallCheck2["default"])(this, CategorizeProvider);
348
- _this3 = _super2.call(this, props);
349
- _this3.uid = _drag.uid.generateId();
350
- return _this3;
297
+ class CategorizeProvider extends _react.default.Component {
298
+ constructor(props) {
299
+ super(props);
300
+ (0, _defineProperty2.default)(this, "onDragStart", event => {
301
+ const {
302
+ active
303
+ } = event;
304
+ const {
305
+ pauseMathObserver
306
+ } = this.props;
307
+ if (pauseMathObserver) {
308
+ pauseMathObserver();
309
+ }
310
+ if (active?.data?.current) {
311
+ this.setState({
312
+ activeDragItem: active.data.current
313
+ });
314
+ }
315
+ });
316
+ (0, _defineProperty2.default)(this, "onDragEnd", event => {
317
+ const {
318
+ active,
319
+ over
320
+ } = event;
321
+ const {
322
+ resumeMathObserver
323
+ } = this.props;
324
+ this.setState({
325
+ activeDragItem: null
326
+ });
327
+ if (resumeMathObserver) {
328
+ resumeMathObserver();
329
+ }
330
+ if (!over || !active) {
331
+ return;
332
+ }
333
+ const draggedItem = active.data.current;
334
+ if (draggedItem && draggedItem.type === 'choice') {
335
+ const choiceData = {
336
+ id: draggedItem.id,
337
+ categoryId: draggedItem.categoryId,
338
+ choiceIndex: draggedItem.choiceIndex,
339
+ value: draggedItem.value,
340
+ itemType: draggedItem.itemType
341
+ };
342
+ if (over.id === 'choices-board') {
343
+ if (this.categorizeRef && this.categorizeRef.removeChoice && draggedItem.categoryId) {
344
+ this.categorizeRef.removeChoice(choiceData);
345
+ }
346
+ } else {
347
+ const categoryId = over.id;
348
+ if (this.categorizeRef && this.categorizeRef.dropChoice) {
349
+ this.categorizeRef.dropChoice(categoryId, choiceData);
350
+ }
351
+ }
352
+ }
353
+ });
354
+ (0, _defineProperty2.default)(this, "renderDragOverlay", () => {
355
+ const {
356
+ activeDragItem
357
+ } = this.state;
358
+ const {
359
+ model
360
+ } = this.props;
361
+ if (!activeDragItem) return null;
362
+ if (activeDragItem.type === 'choice') {
363
+ const choice = model.choices?.find(c => c.id === activeDragItem.id);
364
+ if (choice) {
365
+ return /*#__PURE__*/_react.default.createElement(_choice.default, (0, _extends2.default)({
366
+ key: choice.id,
367
+ id: choice.id
368
+ }, choice));
369
+ }
370
+ }
371
+ return null;
372
+ });
373
+ this.uid = _drag.uid.generateId();
374
+ this.state = {
375
+ activeDragItem: null
376
+ };
351
377
  }
352
-
353
- (0, _createClass2["default"])(CategorizeProvider, [{
354
- key: "render",
355
- value: function render() {
356
- return /*#__PURE__*/_react["default"].createElement(_drag.uid.Provider, {
357
- value: this.uid
358
- }, /*#__PURE__*/_react["default"].createElement(Categorize, this.props));
359
- }
360
- }]);
361
- return CategorizeProvider;
362
- }(_react["default"].Component);
363
-
364
- var styles = function styles(theme) {
365
- return {
366
- mainContainer: {
367
- color: _renderUi.color.text(),
368
- backgroundColor: _renderUi.color.background(),
369
- position: 'relative'
370
- },
371
- note: {
372
- marginBottom: theme.spacing.unit * 2
373
- },
374
- categorize: {
375
- marginBottom: theme.spacing.unit,
376
- display: 'flex',
377
- flexDirection: 'column'
378
- },
379
- collapsible: {
380
- paddingBottom: theme.spacing.unit * 2
381
- }
382
- };
383
- };
384
-
385
- var _default = (0, _drag.withDragContext)((0, _styles.withStyles)(styles)(CategorizeProvider));
386
-
387
- exports["default"] = _default;
388
- //# sourceMappingURL=index.js.map
378
+ render() {
379
+ return /*#__PURE__*/_react.default.createElement(_drag.DragProvider, {
380
+ onDragStart: this.onDragStart,
381
+ onDragEnd: this.onDragEnd
382
+ }, /*#__PURE__*/_react.default.createElement(_drag.uid.Provider, {
383
+ value: this.uid
384
+ }, /*#__PURE__*/_react.default.createElement(Categorize, (0, _extends2.default)({
385
+ ref: ref => this.categorizeRef = ref
386
+ }, this.props)), /*#__PURE__*/_react.default.createElement(_core.DragOverlay, null, /*#__PURE__*/_react.default.createElement(DragPreviewWrapper, null, this.renderDragOverlay()))));
387
+ }
388
+ }
389
+ const StyledUiLayout = (0, _styles.styled)(_renderUi.UiLayout)({
390
+ color: _renderUi.color.text(),
391
+ backgroundColor: _renderUi.color.background(),
392
+ position: 'relative'
393
+ });
394
+ const StyledNote = (0, _styles.styled)('div')(({
395
+ theme
396
+ }) => ({
397
+ marginBottom: theme.spacing(2)
398
+ }));
399
+ const StyledCategorize = (0, _styles.styled)('div')(({
400
+ theme
401
+ }) => ({
402
+ marginBottom: theme.spacing(1),
403
+ display: 'flex',
404
+ flexDirection: 'column'
405
+ }));
406
+ const StyledCollapsible = (0, _styles.styled)(_renderUi.Collapsible)(({
407
+ theme
408
+ }) => ({
409
+ paddingBottom: theme.spacing(2)
410
+ }));
411
+ var _default = exports.default = CategorizeProvider;
412
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_debug","_styles","_core","_correctAnswerToggle","_categorize","_drag","_renderUi","_mathRendering","_translator","_configUi","_choices","_choice","_categories","translator","Translator","log","debug","DragPreviewWrapper","React","Component","constructor","args","_defineProperty2","default","createRef","componentDidMount","containerRef","current","renderMath","render","createElement","ref","props","children","Categorize","c","onAnswersChange","session","answers","removeChoiceFromCategory","id","categoryId","choiceIndex","draggedChoice","model","maxChoicesPerCategory","newAnswers","undefined","answer","find","category","choices","length","moveChoiceToCategory","setState","showMaxChoiceAlert","removeChoice","showCorrect","state","onShowCorrectToggle","choicePosition","flexDirection","correctResponse","some","correctRes","alternateResponses","UNSAFE_componentWillReceiveProps","nextProps","nextModel","note","language","t","lng","choicesPosition","extraCSSRules","showNote","env","autoplayAudioEnabled","customAudioButton","mode","role","style","getPositionDirection","gap","categories","correct","buildState","disabled","rowLabels","categoriesPerRow","fontSizeFactor","nbOfRows","Math","ceil","existAlternate","existAlternateResponse","displayNote","alertMessage","alertTitle","onCloseText","showRationale","rationale","hasText","hasMedia","showTeacherInstructions","teacherInstructions","StyledUiLayout","Fragment","StyledCollapsible","labels","hidden","visible","PreviewPrompt","prompt","show","toggled","onToggle","toggleShowCorrect","StyledCategorize","display","flex","onDropChoice","dropChoice","onRemoveChoice","slice","StyledNote","dangerouslySetInnerHTML","__html","correctness","feedback","Feedback","AlertDialog","title","text","open","onClose","exports","PropTypes","object","shape","arrayOf","choice","string","func","isRequired","pauseMathObserver","resumeMathObserver","CategorizeProvider","event","active","data","activeDragItem","over","draggedItem","type","choiceData","value","itemType","categorizeRef","_extends2","key","uid","generateId","DragProvider","onDragStart","onDragEnd","Provider","DragOverlay","renderDragOverlay","styled","UiLayout","color","backgroundColor","background","position","theme","marginBottom","spacing","Collapsible","paddingBottom","_default"],"sources":["../../src/categorize/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debug from 'debug';\nimport { styled } from '@mui/material/styles';\nimport { DragOverlay } from '@dnd-kit/core';\nimport CorrectAnswerToggle from '@pie-lib/correct-answer-toggle';\nimport { buildState, removeChoiceFromCategory, moveChoiceToCategory } from '@pie-lib/categorize';\nimport { DragProvider, uid } from '@pie-lib/drag';\nimport { color, Feedback, Collapsible, hasText, hasMedia, PreviewPrompt, UiLayout } from '@pie-lib/render-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport Translator from '@pie-lib/translator';\nimport { AlertDialog } from '@pie-lib/config-ui';\nimport Choices from './choices';\nimport Choice from './choice';\nimport Categories from './categories';\n\nconst { translator } = Translator;\nconst log = debug('@pie-ui:categorize');\n\nclass DragPreviewWrapper extends React.Component {\n  containerRef = React.createRef();\n\n  componentDidMount() {\n    if (this.containerRef.current) {\n      renderMath(this.containerRef.current);\n    }\n  }\n\n  render() {\n    return <div ref={this.containerRef}>{this.props.children}</div>;\n  }\n}\n\nexport class Categorize extends React.Component {\n  static propTypes = {\n    model: PropTypes.object,\n    session: PropTypes.shape({\n      answers: PropTypes.arrayOf(\n        PropTypes.shape({\n          choice: PropTypes.string,\n          category: PropTypes.string,\n        }),\n      ),\n    }),\n    onAnswersChange: PropTypes.func.isRequired,\n    onShowCorrectToggle: PropTypes.func.isRequired,\n    pauseMathObserver: PropTypes.func,\n    resumeMathObserver: PropTypes.func,\n  };\n\n  static defaultProps = {\n    disabled: false,\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      showCorrect: false,\n      showMaxChoiceAlert: false,\n    };\n  }\n\n  removeChoice = (c) => {\n    log('[removeChoice]: ', c);\n    const { onAnswersChange, session } = this.props;\n    const answers = removeChoiceFromCategory(c.id, c.categoryId, c.choiceIndex, session.answers);\n    onAnswersChange(answers);\n  };\n\n  dropChoice = (categoryId, draggedChoice) => {\n    const { session, onAnswersChange, model } = this.props;\n    const { maxChoicesPerCategory = 0 } = model || {};\n    const { answers = [] } = session || {};\n    let newAnswers;\n    if (draggedChoice) {\n      log('[dropChoice] category: ', draggedChoice.categoryId, 'choice: ', draggedChoice);\n    } else {\n      log('[dropChoice] category: ', undefined, 'choice: ', undefined);\n    }\n\n    const answer = answers.find((answer) => answer.category === categoryId);\n\n    // treat special case to replace the existing choice with the new one when maxChoicesPerCategory = 1\n    if (draggedChoice && maxChoicesPerCategory === 1 && answer && answer.choices && answer.choices.length === 1) {\n      // First, move the dragged choice to the target category (this will also remove it from source if allowMultiplePlacements is disabled)\n      newAnswers = moveChoiceToCategory(\n        draggedChoice.id,\n        draggedChoice.categoryId,\n        categoryId,\n        draggedChoice.choiceIndex,\n        answers,\n      );\n      // Then, remove the existing choice from the target category (use newAnswers, not answers)\n      newAnswers = removeChoiceFromCategory(answer.choices[0], categoryId, 0, newAnswers);\n    }\n\n    // treat special case when there are as many choices as maxChoicesPerCategory is\n    else if (\n      draggedChoice &&\n      maxChoicesPerCategory > 1 &&\n      answer &&\n      answer.choices &&\n      answer.choices.length === maxChoicesPerCategory\n    ) {\n      newAnswers = draggedChoice.categoryId\n        ? moveChoiceToCategory(\n            draggedChoice.id,\n            draggedChoice.categoryId,\n            draggedChoice.categoryId,\n            draggedChoice.choiceIndex,\n            answers,\n          )\n        : removeChoiceFromCategory(draggedChoice.id, draggedChoice.categoryId, draggedChoice.choiceIndex, answers);\n      this.setState({ showMaxChoiceAlert: true });\n    }\n\n    // treat special case when there are more choices that maxChoicesPerCategory is (testing purpose in pits)\n    else if (maxChoicesPerCategory !== 0 && answer && answer.choices && answer.choices.length > maxChoicesPerCategory) {\n      newAnswers = answers;\n      this.setState({ showMaxChoiceAlert: true });\n    } else {\n      newAnswers = draggedChoice\n        ? moveChoiceToCategory(\n            draggedChoice.id,\n            draggedChoice.categoryId,\n            categoryId,\n            draggedChoice.choiceIndex,\n            answers,\n          )\n        : this.removeChoice(categoryId);\n    }\n\n    if (draggedChoice) {\n      onAnswersChange(newAnswers);\n    }\n  };\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    const { model } = this.props;\n    const { model: nextModel } = nextProps;\n\n    // check if the note is the default one for prev language and change to the default one for new language\n    // this check is necessary in order to diferanciate between default and authour defined note\n    // and only change between languages for default ones\n    if (\n      model.note &&\n      model.language &&\n      model.language !== nextModel.language &&\n      model.note === translator.t('common:commonCorrectAnswerWithAlternates', { lng: model.language })\n    ) {\n      model.note = translator.t('common:commonCorrectAnswerWithAlternates', { lng: nextModel.language });\n    }\n\n    this.setState({ showCorrect: false });\n  }\n\n  toggleShowCorrect = () =>\n    this.setState({ showCorrect: !this.state.showCorrect }, () => {\n      this.props.onShowCorrectToggle();\n    });\n\n  getPositionDirection = (choicePosition) => {\n    let flexDirection;\n\n    switch (choicePosition) {\n      case 'left':\n        flexDirection = 'row-reverse';\n        break;\n      case 'right':\n        flexDirection = 'row';\n        break;\n      case 'below':\n        flexDirection = 'column';\n        break;\n      default:\n        // above\n        flexDirection = 'column-reverse';\n        break;\n    }\n\n    return flexDirection;\n  };\n\n  existAlternateResponse = (correctResponse) =>\n    correctResponse?.some((correctRes) => correctRes.alternateResponses?.length > 0);\n\n  render() {\n    const { model, session } = this.props;\n    const { showCorrect, showMaxChoiceAlert } = this.state;\n    const {\n      choicesPosition,\n      extraCSSRules,\n      note,\n      showNote,\n      env,\n      language,\n      maxChoicesPerCategory,\n      autoplayAudioEnabled,\n      customAudioButton,\n    } = model;\n    const { mode, role } = env || {};\n    const choicePosition = choicesPosition || 'above';\n\n    const style = {\n      flexDirection: this.getPositionDirection(choicePosition),\n      gap: '8px',\n    };\n\n    const { categories, choices, correct } = buildState(\n      model.categories,\n      model.choices,\n      showCorrect ? model.correctResponse : session.answers,\n      model.correctResponse,\n    );\n\n    log('[render] disabled: ', model.disabled);\n\n    const { rowLabels, categoriesPerRow, correctResponse, fontSizeFactor } = model;\n    const nbOfRows = (categories && Math.ceil(categories.length / categoriesPerRow)) || 0;\n    const existAlternate = this.existAlternateResponse(correctResponse) || false;\n    const displayNote =\n      (showCorrect || (mode === 'view' && role === 'instructor')) && showNote && note && existAlternate;\n    const alertMessage = translator.t('translation:categorize:limitMaxChoicesPerCategory', {\n      lng: model.language,\n      maxChoicesPerCategory,\n    });\n\n    const alertTitle = translator.t('common:warning', {\n      lng: model.language,\n    });\n\n    const onCloseText = translator.t('common:cancel', {\n      lng: model.language,\n    });\n\n    const showRationale = model.rationale && (hasText(model.rationale) || hasMedia(model.rationale));\n    const showTeacherInstructions =\n      model.teacherInstructions && (hasText(model.teacherInstructions) || hasMedia(model.teacherInstructions));\n\n    return (\n      <StyledUiLayout extraCSSRules={extraCSSRules} id={'main-container'} fontSizeFactor={fontSizeFactor}>\n        {showTeacherInstructions && (\n          <React.Fragment>\n            <StyledCollapsible\n              labels={{\n                hidden: 'Show Teacher Instructions',\n                visible: 'Hide Teacher Instructions',\n              }}\n            >\n              <PreviewPrompt prompt={model.teacherInstructions} />\n            </StyledCollapsible>\n          </React.Fragment>\n        )}\n\n        {model.prompt && (\n          <PreviewPrompt\n            prompt={model.prompt}\n            autoplayAudioEnabled={autoplayAudioEnabled}\n            customAudioButton={customAudioButton}\n          />\n        )}\n\n        <CorrectAnswerToggle\n          show={showCorrect || correct === false}\n          toggled={showCorrect}\n          onToggle={this.toggleShowCorrect}\n          language={language}\n        />\n\n        <StyledCategorize style={style}>\n          <div style={{ display: 'flex', flex: 1 }}>\n            <Categories\n              model={model}\n              disabled={model.disabled}\n              categories={categories}\n              onDropChoice={this.dropChoice}\n              onRemoveChoice={this.removeChoice}\n              rowLabels={(rowLabels || []).slice(0, nbOfRows)}\n            />\n          </div>\n          <Choices\n            disabled={model.disabled}\n            model={model}\n            choices={choices}\n            choicePosition={choicePosition}\n            onDropChoice={this.dropChoice}\n            onRemoveChoice={this.removeChoice}\n          />\n        </StyledCategorize>\n        {displayNote && (\n          <StyledNote\n            dangerouslySetInnerHTML={{\n              __html: note,\n            }}\n          />\n        )}\n\n        {showRationale && (\n          <StyledCollapsible labels={{ hidden: 'Show Rationale', visible: 'Hide Rationale' }}>\n            <PreviewPrompt prompt={model.rationale} />\n          </StyledCollapsible>\n        )}\n\n        {model.correctness && model.feedback && !showCorrect && (\n          <Feedback correctness={model.correctness} feedback={model.feedback} />\n        )}\n        <AlertDialog\n          title={alertTitle}\n          text={alertMessage}\n          open={showMaxChoiceAlert}\n          onCloseText={onCloseText}\n          onClose={() => this.setState({ showMaxChoiceAlert: false })}\n        ></AlertDialog>\n      </StyledUiLayout>\n    );\n  }\n}\n\nclass CategorizeProvider extends React.Component {\n  constructor(props) {\n    super(props);\n    this.uid = uid.generateId();\n    this.state = {\n      activeDragItem: null,\n    };\n  }\n\n  onDragStart = (event) => {\n    const { active } = event;\n    const { pauseMathObserver } = this.props;\n\n    if (pauseMathObserver) {\n      pauseMathObserver();\n    }\n\n    if (active?.data?.current) {\n      this.setState({\n        activeDragItem: active.data.current,\n      });\n    }\n  };\n\n  onDragEnd = (event) => {\n    const { active, over } = event;\n    const { resumeMathObserver } = this.props;\n\n    this.setState({ activeDragItem: null });\n\n    if (resumeMathObserver) {\n      resumeMathObserver();\n    }\n\n    if (!over || !active) {\n      return;\n    }\n\n    const draggedItem = active.data.current;\n\n    if (draggedItem && draggedItem.type === 'choice') {\n      const choiceData = {\n        id: draggedItem.id,\n        categoryId: draggedItem.categoryId,\n        choiceIndex: draggedItem.choiceIndex,\n        value: draggedItem.value,\n        itemType: draggedItem.itemType,\n      };\n\n      if (over.id === 'choices-board') {\n        if (this.categorizeRef && this.categorizeRef.removeChoice && draggedItem.categoryId) {\n          this.categorizeRef.removeChoice(choiceData);\n        }\n      } else {\n        const categoryId = over.id;\n\n        if (this.categorizeRef && this.categorizeRef.dropChoice) {\n          this.categorizeRef.dropChoice(categoryId, choiceData);\n        }\n      }\n    }\n  };\n\n  renderDragOverlay = () => {\n    const { activeDragItem } = this.state;\n    const { model } = this.props;\n\n    if (!activeDragItem) return null;\n\n    if (activeDragItem.type === 'choice') {\n      const choice = model.choices?.find((c) => c.id === activeDragItem.id);\n      if (choice) {\n        return <Choice key={choice.id} id={choice.id} {...choice} />;\n      }\n    }\n\n    return null;\n  };\n\n  render() {\n    return (\n      <DragProvider onDragStart={this.onDragStart} onDragEnd={this.onDragEnd}>\n        <uid.Provider value={this.uid}>\n          <Categorize ref={(ref) => (this.categorizeRef = ref)} {...this.props} />\n          <DragOverlay>\n            <DragPreviewWrapper>{this.renderDragOverlay()}</DragPreviewWrapper>\n          </DragOverlay>\n        </uid.Provider>\n      </DragProvider>\n    );\n  }\n}\n\nconst StyledUiLayout = styled(UiLayout)({\n  color: color.text(),\n  backgroundColor: color.background(),\n  position: 'relative',\n});\n\nconst StyledNote = styled('div')(({ theme }) => ({\n  marginBottom: theme.spacing(2),\n}));\n\nconst StyledCategorize = styled('div')(({ theme }) => ({\n  marginBottom: theme.spacing(1),\n  display: 'flex',\n  flexDirection: 'column',\n}));\n\nconst StyledCollapsible = styled(Collapsible)(({ theme }) => ({\n  paddingBottom: theme.spacing(2),\n}));\n\nexport default CategorizeProvider;\n"],"mappings":"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","ignoreList":[]}