@pie-element/categorize 8.15.1-next.1 → 8.15.1-next.10

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 (61) hide show
  1. package/configure/lib/defaults.js +207 -0
  2. package/configure/lib/defaults.js.map +1 -0
  3. package/configure/lib/design/builder.js +74 -0
  4. package/configure/lib/design/builder.js.map +1 -0
  5. package/configure/lib/design/buttons.js +127 -0
  6. package/configure/lib/design/buttons.js.map +1 -0
  7. package/configure/lib/design/categories/RowLabel.js +78 -0
  8. package/configure/lib/design/categories/RowLabel.js.map +1 -0
  9. package/configure/lib/design/categories/alternateResponses.js +293 -0
  10. package/configure/lib/design/categories/alternateResponses.js.map +1 -0
  11. package/configure/lib/design/categories/category.js +219 -0
  12. package/configure/lib/design/categories/category.js.map +1 -0
  13. package/configure/lib/design/categories/choice-preview.js +136 -0
  14. package/configure/lib/design/categories/choice-preview.js.map +1 -0
  15. package/configure/lib/design/categories/droppable-placeholder.js +187 -0
  16. package/configure/lib/design/categories/droppable-placeholder.js.map +1 -0
  17. package/configure/lib/design/categories/index.js +408 -0
  18. package/configure/lib/design/categories/index.js.map +1 -0
  19. package/configure/lib/design/choices/choice.js +297 -0
  20. package/configure/lib/design/choices/choice.js.map +1 -0
  21. package/configure/lib/design/choices/config.js +114 -0
  22. package/configure/lib/design/choices/config.js.map +1 -0
  23. package/configure/lib/design/choices/index.js +276 -0
  24. package/configure/lib/design/choices/index.js.map +1 -0
  25. package/configure/lib/design/header.js +107 -0
  26. package/configure/lib/design/header.js.map +1 -0
  27. package/configure/lib/design/index.js +538 -0
  28. package/configure/lib/design/index.js.map +1 -0
  29. package/configure/lib/design/input-header.js +166 -0
  30. package/configure/lib/design/input-header.js.map +1 -0
  31. package/configure/lib/design/utils.js +23 -0
  32. package/configure/lib/design/utils.js.map +1 -0
  33. package/configure/lib/index.js +196 -0
  34. package/configure/lib/index.js.map +1 -0
  35. package/configure/lib/main.js +88 -0
  36. package/configure/lib/main.js.map +1 -0
  37. package/configure/lib/utils.js +40 -0
  38. package/configure/lib/utils.js.map +1 -0
  39. package/controller/lib/defaults.js +31 -0
  40. package/controller/lib/defaults.js.map +1 -0
  41. package/controller/lib/index.js +484 -0
  42. package/controller/lib/index.js.map +1 -0
  43. package/controller/lib/utils.js +60 -0
  44. package/controller/lib/utils.js.map +1 -0
  45. package/lib/categorize/categories.js +193 -0
  46. package/lib/categorize/categories.js.map +1 -0
  47. package/lib/categorize/category.js +135 -0
  48. package/lib/categorize/category.js.map +1 -0
  49. package/lib/categorize/choice.js +228 -0
  50. package/lib/categorize/choice.js.map +1 -0
  51. package/lib/categorize/choices.js +162 -0
  52. package/lib/categorize/choices.js.map +1 -0
  53. package/lib/categorize/droppable-placeholder.js +111 -0
  54. package/lib/categorize/droppable-placeholder.js.map +1 -0
  55. package/lib/categorize/grid-content.js +103 -0
  56. package/lib/categorize/grid-content.js.map +1 -0
  57. package/lib/categorize/index.js +368 -0
  58. package/lib/categorize/index.js.map +1 -0
  59. package/lib/index.js +137 -0
  60. package/lib/index.js.map +1 -0
  61. package/package.json +2 -2
@@ -0,0 +1,538 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = exports.Design = void 0;
9
+
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
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
+
24
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
+
26
+ var _utils = require("./utils");
27
+
28
+ var _react = _interopRequireDefault(require("react"));
29
+
30
+ var _propTypes = _interopRequireDefault(require("prop-types"));
31
+
32
+ var _styles = require("@material-ui/core/styles");
33
+
34
+ var _configUi = require("@pie-lib/pie-toolbox/config-ui");
35
+
36
+ var _categorize = require("@pie-lib/pie-toolbox/categorize");
37
+
38
+ var _editableHtml = require("@pie-lib/pie-toolbox/editable-html");
39
+
40
+ var _drag = require("@pie-lib/pie-toolbox/drag");
41
+
42
+ var _categories = _interopRequireDefault(require("./categories"));
43
+
44
+ var _alternateResponses = _interopRequireDefault(require("./categories/alternateResponses"));
45
+
46
+ var _choices = _interopRequireDefault(require("./choices"));
47
+
48
+ var _builder = require("./builder");
49
+
50
+ var _header = _interopRequireDefault(require("./header"));
51
+
52
+ var _utils2 = require("../utils");
53
+
54
+ var _translator = _interopRequireDefault(require("@pie-lib/pie-toolbox/translator"));
55
+
56
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
57
+
58
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
59
+
60
+ 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); }; }
61
+
62
+ 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; } }
63
+
64
+ var translator = _translator["default"].translator;
65
+ var dropdown = _configUi.settings.dropdown,
66
+ Panel = _configUi.settings.Panel,
67
+ toggle = _configUi.settings.toggle,
68
+ radio = _configUi.settings.radio,
69
+ numberField = _configUi.settings.numberField;
70
+ var IdProvider = _drag.uid.Provider;
71
+
72
+ var Design = /*#__PURE__*/function (_React$Component) {
73
+ (0, _inherits2["default"])(Design, _React$Component);
74
+
75
+ var _super = _createSuper(Design);
76
+
77
+ function Design(_props) {
78
+ var _this;
79
+
80
+ (0, _classCallCheck2["default"])(this, Design);
81
+ _this = _super.call(this, _props);
82
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateModel", function (props) {
83
+ var _this$props = _this.props,
84
+ model = _this$props.model,
85
+ onChange = _this$props.onChange;
86
+
87
+ var updatedModel = _objectSpread(_objectSpread({}, model), props);
88
+
89
+ updatedModel.choices = updatedModel.choices.map(function (c) {
90
+ return _objectSpread(_objectSpread({}, c), {}, {
91
+ categoryCount: _this.checkAllowMultiplePlacements(updatedModel.allowMultiplePlacementsEnabled, c)
92
+ });
93
+ }); //Ensure that there are no extra choices in correctResponse, if the user has decided that only one choice may be used.
94
+
95
+ updatedModel.correctResponse = (0, _categorize.ensureNoExtraChoicesInAnswer)(updatedModel.correctResponse || [], updatedModel.choices); //Ensure that there are no extra choices in alternate responses, if the user has decided that only one choice may be used.
96
+
97
+ updatedModel.correctResponse = (0, _categorize.ensureNoExtraChoicesInAlternate)(updatedModel.correctResponse || [], updatedModel.choices); //clean categories
98
+
99
+ updatedModel.categories = updatedModel.categories.map(function (c) {
100
+ return {
101
+ id: c.id,
102
+ label: c.label
103
+ };
104
+ });
105
+ updatedModel.choices = updatedModel.choices.map(function (h) {
106
+ return {
107
+ id: h.id,
108
+ content: h.content,
109
+ categoryCount: h.categoryCount
110
+ };
111
+ }); // ensure that maxChoicesPerCategory is reset if author switch back the corresponding switch (allowMaxChoicesPerCategory)
112
+
113
+ updatedModel.maxChoicesPerCategory = updatedModel.allowMaxChoicesPerCategory ? updatedModel.maxChoicesPerCategory : 0;
114
+ onChange(updatedModel);
115
+ });
116
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeRationale", function (rationale) {
117
+ var _this$props2 = _this.props,
118
+ model = _this$props2.model,
119
+ onChange = _this$props2.onChange;
120
+ onChange(_objectSpread(_objectSpread({}, model), {}, {
121
+ rationale: rationale
122
+ }));
123
+ });
124
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeTeacherInstructions", function (teacherInstructions) {
125
+ var _this$props3 = _this.props,
126
+ model = _this$props3.model,
127
+ onChange = _this$props3.onChange;
128
+ onChange(_objectSpread(_objectSpread({}, model), {}, {
129
+ teacherInstructions: teacherInstructions
130
+ }));
131
+ });
132
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeFeedback", function (feedback) {
133
+ _this.updateModel({
134
+ feedback: feedback
135
+ });
136
+ });
137
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onAddAlternateResponse", function () {
138
+ var correctResponse = _this.props.model.correctResponse;
139
+
140
+ _this.updateModel({
141
+ correctResponse: (correctResponse || []).map(function (cr) {
142
+ return _objectSpread(_objectSpread({}, cr), {}, {
143
+ alternateResponses: [].concat((0, _toConsumableArray2["default"])(cr.alternateResponses || []), [[]])
144
+ });
145
+ })
146
+ });
147
+ });
148
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onPromptChanged", function (prompt) {
149
+ return _this.updateModel({
150
+ prompt: prompt
151
+ });
152
+ });
153
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onRemoveAlternateResponse", function (index) {
154
+ var correctResponse = _this.props.model.correctResponse;
155
+
156
+ _this.updateModel({
157
+ correctResponse: (correctResponse || []).map(function (cr) {
158
+ return _objectSpread(_objectSpread({}, cr), {}, {
159
+ alternateResponses: (cr.alternateResponses || []).filter(function (alt, altIndex) {
160
+ return altIndex !== index;
161
+ })
162
+ });
163
+ })
164
+ });
165
+ });
166
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "countChoiceInCorrectResponse", function (choice) {
167
+ var model = _this.props.model;
168
+ return (0, _categorize.countInAnswer)(choice.id, model.correctResponse);
169
+ });
170
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "checkAllowMultiplePlacements", function (allowMultiplePlacements, c) {
171
+ if (allowMultiplePlacements === _utils2.multiplePlacements.enabled) {
172
+ return 0;
173
+ }
174
+
175
+ if (allowMultiplePlacements === _utils2.multiplePlacements.disabled) {
176
+ return 1;
177
+ }
178
+
179
+ return c.categoryCount || 0;
180
+ });
181
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "isAlertModalOpened", function () {
182
+ var model = _this.props.model;
183
+
184
+ var _ref = model || {},
185
+ _ref$maxChoicesPerCat = _ref.maxChoicesPerCategory,
186
+ maxChoicesPerCategory = _ref$maxChoicesPerCat === void 0 ? 0 : _ref$maxChoicesPerCat;
187
+
188
+ var maxChoices = (0, _utils2.getMaxCategoryChoices)(model); // when maxChoicesPerCategory is set to 0, there is no limit so modal should not be opened
189
+
190
+ return maxChoicesPerCategory !== 0 ? maxChoices > maxChoicesPerCategory : false;
191
+ });
192
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onAlertModalCancel", function () {
193
+ var model = _this.props.model;
194
+ var maxChoices = (0, _utils2.getMaxCategoryChoices)(model);
195
+
196
+ _this.updateModel({
197
+ maxChoicesPerCategory: maxChoices
198
+ });
199
+ });
200
+ _this.uid = _props.uid || _drag.uid.generateId();
201
+ return _this;
202
+ }
203
+
204
+ (0, _createClass2["default"])(Design, [{
205
+ key: "render",
206
+ value: function render() {
207
+ var _this2 = this;
208
+
209
+ var _this$props4 = this.props,
210
+ classes = _this$props4.classes,
211
+ configuration = _this$props4.configuration,
212
+ imageSupport = _this$props4.imageSupport,
213
+ model = _this$props4.model,
214
+ uploadSoundSupport = _this$props4.uploadSoundSupport,
215
+ onConfigurationChanged = _this$props4.onConfigurationChanged;
216
+
217
+ var _ref2 = configuration || {},
218
+ _ref2$allowMultiplePl = _ref2.allowMultiplePlacements,
219
+ allowMultiplePlacements = _ref2$allowMultiplePl === void 0 ? {} : _ref2$allowMultiplePl,
220
+ _ref2$baseInputConfig = _ref2.baseInputConfiguration,
221
+ baseInputConfiguration = _ref2$baseInputConfig === void 0 ? {} : _ref2$baseInputConfig,
222
+ _ref2$categoriesPerRo = _ref2.categoriesPerRow,
223
+ categoriesPerRow = _ref2$categoriesPerRo === void 0 ? {} : _ref2$categoriesPerRo,
224
+ _ref2$choicesPosition = _ref2.choicesPosition,
225
+ choicesPosition = _ref2$choicesPosition === void 0 ? {} : _ref2$choicesPosition,
226
+ _ref2$contentDimensio = _ref2.contentDimensions,
227
+ contentDimensions = _ref2$contentDimensio === void 0 ? {} : _ref2$contentDimensio,
228
+ _ref2$feedback = _ref2.feedback,
229
+ feedback = _ref2$feedback === void 0 ? {} : _ref2$feedback,
230
+ _ref2$lockChoiceOrder = _ref2.lockChoiceOrder,
231
+ lockChoiceOrder = _ref2$lockChoiceOrder === void 0 ? {} : _ref2$lockChoiceOrder,
232
+ _ref2$maxImageHeight = _ref2.maxImageHeight,
233
+ maxImageHeight = _ref2$maxImageHeight === void 0 ? {} : _ref2$maxImageHeight,
234
+ _ref2$maxImageWidth = _ref2.maxImageWidth,
235
+ maxImageWidth = _ref2$maxImageWidth === void 0 ? {} : _ref2$maxImageWidth,
236
+ _ref2$maxPlacements = _ref2.maxPlacements,
237
+ maxPlacements = _ref2$maxPlacements === void 0 ? {} : _ref2$maxPlacements,
238
+ _ref2$minCategoriesPe = _ref2.minCategoriesPerRow,
239
+ minCategoriesPerRow = _ref2$minCategoriesPe === void 0 ? 1 : _ref2$minCategoriesPe,
240
+ _ref2$partialScoring = _ref2.partialScoring,
241
+ partialScoring = _ref2$partialScoring === void 0 ? {} : _ref2$partialScoring,
242
+ _ref2$prompt = _ref2.prompt,
243
+ prompt = _ref2$prompt === void 0 ? {} : _ref2$prompt,
244
+ _ref2$rationale = _ref2.rationale,
245
+ rationale = _ref2$rationale === void 0 ? {} : _ref2$rationale,
246
+ _ref2$scoringType = _ref2.scoringType,
247
+ scoringType = _ref2$scoringType === void 0 ? {} : _ref2$scoringType,
248
+ settingsPanelDisabled = _ref2.settingsPanelDisabled,
249
+ _ref2$spellCheck = _ref2.spellCheck,
250
+ spellCheck = _ref2$spellCheck === void 0 ? {} : _ref2$spellCheck,
251
+ _ref2$studentInstruct = _ref2.studentInstructions,
252
+ studentInstructions = _ref2$studentInstruct === void 0 ? {} : _ref2$studentInstruct,
253
+ _ref2$teacherInstruct = _ref2.teacherInstructions,
254
+ teacherInstructions = _ref2$teacherInstruct === void 0 ? {} : _ref2$teacherInstruct,
255
+ _ref2$withRubric = _ref2.withRubric,
256
+ withRubric = _ref2$withRubric === void 0 ? {} : _ref2$withRubric,
257
+ _ref2$mathMlOptions = _ref2.mathMlOptions,
258
+ mathMlOptions = _ref2$mathMlOptions === void 0 ? {} : _ref2$mathMlOptions,
259
+ _ref2$language = _ref2.language,
260
+ language = _ref2$language === void 0 ? {} : _ref2$language,
261
+ _ref2$languageChoices = _ref2.languageChoices,
262
+ languageChoices = _ref2$languageChoices === void 0 ? {} : _ref2$languageChoices;
263
+
264
+ var _ref3 = model || {},
265
+ allowAlternateEnabled = _ref3.allowAlternateEnabled,
266
+ allowMaxChoicesPerCategory = _ref3.allowMaxChoicesPerCategory,
267
+ errors = _ref3.errors,
268
+ feedbackEnabled = _ref3.feedbackEnabled,
269
+ maxChoicesPerCategory = _ref3.maxChoicesPerCategory,
270
+ promptEnabled = _ref3.promptEnabled,
271
+ rationaleEnabled = _ref3.rationaleEnabled,
272
+ spellCheckEnabled = _ref3.spellCheckEnabled,
273
+ teacherInstructionsEnabled = _ref3.teacherInstructionsEnabled,
274
+ toolbarEditorPosition = _ref3.toolbarEditorPosition;
275
+
276
+ var _ref4 = errors || {},
277
+ promptError = _ref4.prompt,
278
+ rationaleError = _ref4.rationale,
279
+ teacherInstructionsError = _ref4.teacherInstructions;
280
+
281
+ var toolbarOpts = {
282
+ position: toolbarEditorPosition === 'top' ? 'top' : 'bottom'
283
+ };
284
+ var config = model.config || {};
285
+ config.choices = config.choices || {
286
+ label: '',
287
+ columns: 2
288
+ };
289
+ var categories = (0, _builder.buildCategories)(model.categories || [], model.choices || [], model.correctResponse || []);
290
+ var alternateResponses = (0, _builder.buildAlternateResponses)(model.categories || [], model.choices || [], model.correctResponse || []);
291
+ var choices = model.choices.map(function (c) {
292
+ c.correctResponseCount = _this2.countChoiceInCorrectResponse(c); // ensure categoryCount is set even though updatedModel hasn't been called
293
+
294
+ c.categoryCount = _this2.checkAllowMultiplePlacements(model.allowMultiplePlacementsEnabled, c);
295
+ return c;
296
+ });
297
+ var defaultImageMaxWidth = maxImageWidth && maxImageWidth.prompt;
298
+ var defaultImageMaxHeight = maxImageHeight && maxImageHeight.prompt;
299
+ var panelSettings = {
300
+ partialScoring: partialScoring.settings && toggle(partialScoring.label),
301
+ lockChoiceOrder: lockChoiceOrder.settings && toggle(lockChoiceOrder.label),
302
+ categoriesPerRow: categoriesPerRow.settings && numberField(categoriesPerRow.label, {
303
+ label: categoriesPerRow.label,
304
+ min: minCategoriesPerRow,
305
+ max: 6
306
+ }),
307
+ choicesPosition: choicesPosition.settings && radio(choicesPosition.label, ['below', 'above', 'left', 'right']),
308
+ allowMultiplePlacementsEnabled: allowMultiplePlacements.settings && dropdown(allowMultiplePlacements.label, [_utils2.multiplePlacements.enabled, _utils2.multiplePlacements.disabled, _utils2.multiplePlacements.perChoice]),
309
+ allowMaxChoicesPerCategory: maxPlacements.settings && toggle(maxPlacements.label),
310
+ maxChoicesPerCategory: allowMaxChoicesPerCategory === true && numberField(maxPlacements.label, {
311
+ label: '',
312
+ min: 0,
313
+ max: 30
314
+ }),
315
+ promptEnabled: prompt.settings && toggle(prompt.label),
316
+ feedbackEnabled: feedback.settings && toggle(feedback.label),
317
+ // PD-2960: deleted temporary from settings panel
318
+ // allowAlternateEnabled: allowAlternate.settings && toggle(allowAlternate.label),
319
+ 'language.enabled': language.settings && toggle(language.label, true),
320
+ language: language.settings && language.enabled && dropdown(languageChoices.label, languageChoices.options)
321
+ };
322
+ var panelProperties = {
323
+ teacherInstructionsEnabled: teacherInstructions.settings && toggle(teacherInstructions.label),
324
+ studentInstructionsEnabled: studentInstructions.settings && toggle(studentInstructions.label),
325
+ rationaleEnabled: rationale.settings && toggle(rationale.label),
326
+ spellCheckEnabled: spellCheck.settings && toggle(spellCheck.label),
327
+ scoringType: scoringType.settings && radio(scoringType.label, ['auto', 'rubric']),
328
+ rubricEnabled: (withRubric === null || withRubric === void 0 ? void 0 : withRubric.settings) && toggle(withRubric === null || withRubric === void 0 ? void 0 : withRubric.label)
329
+ };
330
+ var isOpened = this.isAlertModalOpened();
331
+ var alertMaxChoicesMsg = translator.t('translation:categorize:maxChoicesPerCategoryRestriction', {
332
+ lng: model.language,
333
+ maxChoicesPerCategory: maxChoicesPerCategory
334
+ });
335
+ return /*#__PURE__*/_react["default"].createElement(IdProvider, {
336
+ value: this.uid
337
+ }, /*#__PURE__*/_react["default"].createElement(_configUi.layout.ConfigLayout, {
338
+ dimensions: contentDimensions,
339
+ hideSettings: settingsPanelDisabled,
340
+ settings: /*#__PURE__*/_react["default"].createElement(Panel, {
341
+ model: model,
342
+ onChangeModel: this.updateModel,
343
+ configuration: configuration,
344
+ onChangeConfiguration: onConfigurationChanged,
345
+ groups: {
346
+ Settings: panelSettings,
347
+ Properties: panelProperties
348
+ },
349
+ modal: /*#__PURE__*/_react["default"].createElement(_configUi.AlertDialog, {
350
+ title: 'Warning',
351
+ text: alertMaxChoicesMsg,
352
+ open: isOpened,
353
+ onClose: this.onAlertModalCancel
354
+ })
355
+ })
356
+ }, teacherInstructionsEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
357
+ label: teacherInstructions.label,
358
+ className: classes.inputContainer
359
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
360
+ className: classes.input,
361
+ markup: model.teacherInstructions || '',
362
+ onChange: this.changeTeacherInstructions,
363
+ imageSupport: imageSupport,
364
+ error: teacherInstructionsError,
365
+ nonEmpty: false,
366
+ toolbarOpts: toolbarOpts,
367
+ pluginProps: (0, _utils.getPluginProps)(teacherInstructions === null || teacherInstructions === void 0 ? void 0 : teacherInstructions.inputConfiguration, baseInputConfiguration),
368
+ spellCheck: spellCheckEnabled,
369
+ maxImageWidth: maxImageWidth && maxImageWidth.teacherInstructions || defaultImageMaxWidth,
370
+ maxImageHeight: maxImageHeight && maxImageHeight.teacherInstructions || defaultImageMaxHeight,
371
+ uploadSoundSupport: uploadSoundSupport,
372
+ languageCharactersProps: [{
373
+ language: 'spanish'
374
+ }, {
375
+ language: 'special'
376
+ }],
377
+ mathMlOptions: mathMlOptions
378
+ }), teacherInstructionsError && /*#__PURE__*/_react["default"].createElement("div", {
379
+ className: classes.errorText
380
+ }, teacherInstructionsError)), promptEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
381
+ label: prompt.label,
382
+ className: classes.inputContainer
383
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
384
+ className: classes.input,
385
+ markup: model.prompt || '',
386
+ onChange: this.onPromptChanged,
387
+ imageSupport: imageSupport,
388
+ error: promptError,
389
+ nonEmpty: false,
390
+ disableUnderline: true,
391
+ toolbarOpts: toolbarOpts,
392
+ pluginProps: (0, _utils.getPluginProps)(prompt === null || prompt === void 0 ? void 0 : prompt.inputConfiguration, baseInputConfiguration),
393
+ spellCheck: spellCheckEnabled,
394
+ maxImageWidth: maxImageWidth && maxImageWidth.prompt,
395
+ maxImageHeight: maxImageHeight && maxImageHeight.prompt,
396
+ uploadSoundSupport: uploadSoundSupport,
397
+ languageCharactersProps: [{
398
+ language: 'spanish'
399
+ }, {
400
+ language: 'special'
401
+ }],
402
+ mathMlOptions: mathMlOptions
403
+ }), promptError && /*#__PURE__*/_react["default"].createElement("div", {
404
+ className: classes.errorText
405
+ }, promptError)), /*#__PURE__*/_react["default"].createElement(_categories["default"], {
406
+ imageSupport: imageSupport,
407
+ uploadSoundSupport: uploadSoundSupport,
408
+ model: model,
409
+ categories: categories || [],
410
+ onModelChanged: this.updateModel,
411
+ toolbarOpts: toolbarOpts,
412
+ spellCheck: spellCheckEnabled,
413
+ configuration: configuration,
414
+ defaultImageMaxWidth: defaultImageMaxWidth,
415
+ defaultImageMaxHeight: defaultImageMaxHeight,
416
+ mathMlOptions: mathMlOptions
417
+ }), /*#__PURE__*/_react["default"].createElement(_choices["default"], {
418
+ imageSupport: imageSupport,
419
+ uploadSoundSupport: uploadSoundSupport,
420
+ choices: choices,
421
+ model: model,
422
+ onModelChanged: this.updateModel,
423
+ toolbarOpts: toolbarOpts,
424
+ spellCheck: spellCheckEnabled,
425
+ configuration: configuration,
426
+ defaultImageMaxWidth: defaultImageMaxWidth,
427
+ defaultImageMaxHeight: defaultImageMaxHeight
428
+ }), allowAlternateEnabled && /*#__PURE__*/_react["default"].createElement(_header["default"], {
429
+ className: classes.alternatesHeader,
430
+ label: "Alternate Responses",
431
+ buttonLabel: "ADD AN ALTERNATE RESPONSE",
432
+ onAdd: this.onAddAlternateResponse
433
+ }), allowAlternateEnabled && alternateResponses.map(function (categoriesList, index) {
434
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, {
435
+ key: index
436
+ }, /*#__PURE__*/_react["default"].createElement(_header["default"], {
437
+ className: classes.alternatesHeader,
438
+ variant: 'subtitle1',
439
+ label: "Alternate Response",
440
+ buttonLabel: "REMOVE ALTERNATE RESPONSE",
441
+ onAdd: function onAdd() {
442
+ return _this2.onRemoveAlternateResponse(index);
443
+ }
444
+ }), /*#__PURE__*/_react["default"].createElement(_alternateResponses["default"], {
445
+ altIndex: index,
446
+ imageSupport: imageSupport,
447
+ model: model,
448
+ configuration: configuration,
449
+ categories: categoriesList,
450
+ onModelChanged: _this2.updateModel,
451
+ uploadSoundSupport: uploadSoundSupport,
452
+ toolbarOpts: toolbarOpts,
453
+ defaultImageMaxWidth: defaultImageMaxWidth,
454
+ defaultImageMaxHeight: defaultImageMaxHeight,
455
+ mathMlOptions: mathMlOptions
456
+ }));
457
+ }), rationaleEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
458
+ label: rationale.label,
459
+ className: classes.inputContainer
460
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
461
+ className: classes.input,
462
+ markup: model.rationale || '',
463
+ onChange: this.changeRationale,
464
+ imageSupport: imageSupport,
465
+ error: rationaleError,
466
+ nonEmpty: false,
467
+ toolbarOpts: toolbarOpts,
468
+ pluginProps: (0, _utils.getPluginProps)(prompt === null || prompt === void 0 ? void 0 : prompt.inputConfiguration, baseInputConfiguration),
469
+ spellCheck: spellCheckEnabled,
470
+ maxImageWidth: maxImageWidth && maxImageWidth.rationale || defaultImageMaxWidth,
471
+ maxImageHeight: maxImageHeight && maxImageHeight.rationale || defaultImageMaxHeight,
472
+ uploadSoundSupport: uploadSoundSupport,
473
+ languageCharactersProps: [{
474
+ language: 'spanish'
475
+ }, {
476
+ language: 'special'
477
+ }],
478
+ mathMlOptions: mathMlOptions
479
+ }), rationaleError && /*#__PURE__*/_react["default"].createElement("div", {
480
+ className: classes.errorText
481
+ }, rationaleError)), feedbackEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.FeedbackConfig, {
482
+ feedback: model.feedback,
483
+ onChange: this.changeFeedback,
484
+ toolbarOpts: toolbarOpts
485
+ })));
486
+ }
487
+ }]);
488
+ return Design;
489
+ }(_react["default"].Component);
490
+
491
+ exports.Design = Design;
492
+ (0, _defineProperty2["default"])(Design, "propTypes", {
493
+ classes: _propTypes["default"].object.isRequired,
494
+ configuration: _propTypes["default"].object,
495
+ className: _propTypes["default"].string,
496
+ onConfigurationChanged: _propTypes["default"].func,
497
+ model: _propTypes["default"].object.isRequired,
498
+ onChange: _propTypes["default"].func.isRequired,
499
+ uid: _propTypes["default"].string,
500
+ imageSupport: _propTypes["default"].shape({
501
+ add: _propTypes["default"].func.isRequired,
502
+ "delete": _propTypes["default"].func.isRequired
503
+ }),
504
+ uploadSoundSupport: _propTypes["default"].shape({
505
+ add: _propTypes["default"].func.isRequired,
506
+ "delete": _propTypes["default"].func.isRequired
507
+ })
508
+ });
509
+
510
+ var styles = function styles(theme) {
511
+ return {
512
+ alternatesHeader: {
513
+ marginBottom: theme.spacing.unit * 2
514
+ },
515
+ text: {
516
+ paddingTop: theme.spacing.unit * 2,
517
+ paddingBottom: theme.spacing.unit * 2
518
+ },
519
+ inputContainer: {
520
+ width: '100%',
521
+ paddingTop: theme.spacing.unit * 2,
522
+ marginBottom: theme.spacing.unit * 2
523
+ },
524
+ title: {
525
+ marginBottom: theme.spacing.unit * 4
526
+ },
527
+ errorText: {
528
+ fontSize: theme.typography.fontSize - 2,
529
+ color: theme.palette.error.main,
530
+ paddingTop: theme.spacing.unit
531
+ }
532
+ };
533
+ };
534
+
535
+ var _default = (0, _drag.withDragContext)((0, _styles.withStyles)(styles)(Design));
536
+
537
+ exports["default"] = _default;
538
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/design/index.jsx"],"names":["translator","Translator","dropdown","settings","Panel","toggle","radio","numberField","IdProvider","uid","Provider","Design","props","model","onChange","updatedModel","choices","map","c","categoryCount","checkAllowMultiplePlacements","allowMultiplePlacementsEnabled","correctResponse","categories","id","label","h","content","maxChoicesPerCategory","allowMaxChoicesPerCategory","rationale","teacherInstructions","feedback","updateModel","cr","alternateResponses","prompt","index","filter","alt","altIndex","choice","allowMultiplePlacements","multiplePlacements","enabled","disabled","maxChoices","generateId","classes","configuration","imageSupport","uploadSoundSupport","onConfigurationChanged","baseInputConfiguration","categoriesPerRow","choicesPosition","contentDimensions","lockChoiceOrder","maxImageHeight","maxImageWidth","maxPlacements","minCategoriesPerRow","partialScoring","scoringType","settingsPanelDisabled","spellCheck","studentInstructions","withRubric","mathMlOptions","language","languageChoices","allowAlternateEnabled","errors","feedbackEnabled","promptEnabled","rationaleEnabled","spellCheckEnabled","teacherInstructionsEnabled","toolbarEditorPosition","promptError","rationaleError","teacherInstructionsError","toolbarOpts","position","config","columns","correctResponseCount","countChoiceInCorrectResponse","defaultImageMaxWidth","defaultImageMaxHeight","panelSettings","min","max","perChoice","options","panelProperties","studentInstructionsEnabled","rubricEnabled","isOpened","isAlertModalOpened","alertMaxChoicesMsg","t","lng","Settings","Properties","onAlertModalCancel","inputContainer","input","changeTeacherInstructions","inputConfiguration","errorText","onPromptChanged","alternatesHeader","onAddAlternateResponse","categoriesList","onRemoveAlternateResponse","changeRationale","changeFeedback","React","Component","PropTypes","object","isRequired","className","string","func","shape","add","styles","theme","marginBottom","spacing","unit","text","paddingTop","paddingBottom","width","title","fontSize","typography","color","palette","error","main"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAKA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;;;AAEA,IAAQA,UAAR,GAAuBC,sBAAvB,CAAQD,UAAR;AACA,IAAQE,QAAR,GAAwDC,kBAAxD,CAAQD,QAAR;AAAA,IAAkBE,KAAlB,GAAwDD,kBAAxD,CAAkBC,KAAlB;AAAA,IAAyBC,MAAzB,GAAwDF,kBAAxD,CAAyBE,MAAzB;AAAA,IAAiCC,KAAjC,GAAwDH,kBAAxD,CAAiCG,KAAjC;AAAA,IAAwCC,WAAxC,GAAwDJ,kBAAxD,CAAwCI,WAAxC;AACA,IAAkBC,UAAlB,GAAiCC,SAAjC,CAAQC,QAAR;;IAEaC,M;;;;;AAmBX,kBAAYC,MAAZ,EAAmB;AAAA;;AAAA;AACjB,8BAAMA,MAAN;AADiB,oGAKL,UAACA,KAAD,EAAW;AACvB,wBAA4B,MAAKA,KAAjC;AAAA,UAAQC,KAAR,eAAQA,KAAR;AAAA,UAAeC,QAAf,eAAeA,QAAf;;AAEA,UAAMC,YAAY,mCACbF,KADa,GAEbD,KAFa,CAAlB;;AAKAG,MAAAA,YAAY,CAACC,OAAb,GAAuBD,YAAY,CAACC,OAAb,CAAqBC,GAArB,CAAyB,UAACC,CAAD;AAAA,+CAC3CA,CAD2C;AAE9CC,UAAAA,aAAa,EAAE,MAAKC,4BAAL,CAAkCL,YAAY,CAACM,8BAA/C,EAA+EH,CAA/E;AAF+B;AAAA,OAAzB,CAAvB,CARuB,CAavB;;AACAH,MAAAA,YAAY,CAACO,eAAb,GAA+B,8CAC7BP,YAAY,CAACO,eAAb,IAAgC,EADH,EAE7BP,YAAY,CAACC,OAFgB,CAA/B,CAduB,CAmBvB;;AACAD,MAAAA,YAAY,CAACO,eAAb,GAA+B,iDAC7BP,YAAY,CAACO,eAAb,IAAgC,EADH,EAE7BP,YAAY,CAACC,OAFgB,CAA/B,CApBuB,CAyBvB;;AACAD,MAAAA,YAAY,CAACQ,UAAb,GAA0BR,YAAY,CAACQ,UAAb,CAAwBN,GAAxB,CAA4B,UAACC,CAAD;AAAA,eAAQ;AAC5DM,UAAAA,EAAE,EAAEN,CAAC,CAACM,EADsD;AAE5DC,UAAAA,KAAK,EAAEP,CAAC,CAACO;AAFmD,SAAR;AAAA,OAA5B,CAA1B;AAKAV,MAAAA,YAAY,CAACC,OAAb,GAAuBD,YAAY,CAACC,OAAb,CAAqBC,GAArB,CAAyB,UAACS,CAAD;AAAA,eAAQ;AACtDF,UAAAA,EAAE,EAAEE,CAAC,CAACF,EADgD;AAEtDG,UAAAA,OAAO,EAAED,CAAC,CAACC,OAF2C;AAGtDR,UAAAA,aAAa,EAAEO,CAAC,CAACP;AAHqC,SAAR;AAAA,OAAzB,CAAvB,CA/BuB,CAqCvB;;AACAJ,MAAAA,YAAY,CAACa,qBAAb,GAAqCb,YAAY,CAACc,0BAAb,GACjCd,YAAY,CAACa,qBADoB,GAEjC,CAFJ;AAIAd,MAAAA,QAAQ,CAACC,YAAD,CAAR;AACD,KAhDkB;AAAA,wGAkDD,UAACe,SAAD,EAAe;AAC/B,yBAA4B,MAAKlB,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AAEAA,MAAAA,QAAQ,iCACHD,KADG;AAENiB,QAAAA,SAAS,EAATA;AAFM,SAAR;AAID,KAzDkB;AAAA,kHA2DS,UAACC,mBAAD,EAAyB;AACnD,yBAA4B,MAAKnB,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AAEAA,MAAAA,QAAQ,iCACHD,KADG;AAENkB,QAAAA,mBAAmB,EAAnBA;AAFM,SAAR;AAID,KAlEkB;AAAA,uGAoEF,UAACC,QAAD,EAAc;AAC7B,YAAKC,WAAL,CAAiB;AAAED,QAAAA,QAAQ,EAARA;AAAF,OAAjB;AACD,KAtEkB;AAAA,+GAwEM,YAAM;AAC7B,UACWV,eADX,GAEI,MAAKV,KAFT,CACEC,KADF,CACWS,eADX;;AAIA,YAAKW,WAAL,CAAiB;AACfX,QAAAA,eAAe,EAAE,CAACA,eAAe,IAAI,EAApB,EAAwBL,GAAxB,CAA4B,UAACiB,EAAD;AAAA,iDACxCA,EADwC;AAE3CC,YAAAA,kBAAkB,gDAAOD,EAAE,CAACC,kBAAH,IAAyB,EAAhC,IAAqC,EAArC;AAFyB;AAAA,SAA5B;AADF,OAAjB;AAMD,KAnFkB;AAAA,wGAqFD,UAACC,MAAD;AAAA,aAAY,MAAKH,WAAL,CAAiB;AAAEG,QAAAA,MAAM,EAANA;AAAF,OAAjB,CAAZ;AAAA,KArFC;AAAA,kHAuFS,UAACC,KAAD,EAAW;AACrC,UACWf,eADX,GAEI,MAAKV,KAFT,CACEC,KADF,CACWS,eADX;;AAIA,YAAKW,WAAL,CAAiB;AACfX,QAAAA,eAAe,EAAE,CAACA,eAAe,IAAI,EAApB,EAAwBL,GAAxB,CAA4B,UAACiB,EAAD;AAAA,iDACxCA,EADwC;AAE3CC,YAAAA,kBAAkB,EAAE,CAACD,EAAE,CAACC,kBAAH,IAAyB,EAA1B,EAA8BG,MAA9B,CAAqC,UAACC,GAAD,EAAMC,QAAN;AAAA,qBAAmBA,QAAQ,KAAKH,KAAhC;AAAA,aAArC;AAFuB;AAAA,SAA5B;AADF,OAAjB;AAMD,KAlGkB;AAAA,qHAoGY,UAACI,MAAD,EAAY;AACzC,UAAQ5B,KAAR,GAAkB,MAAKD,KAAvB,CAAQC,KAAR;AAEA,aAAO,+BAAc4B,MAAM,CAACjB,EAArB,EAAyBX,KAAK,CAACS,eAA/B,CAAP;AACD,KAxGkB;AAAA,qHA0GY,UAACoB,uBAAD,EAA0BxB,CAA1B,EAAgC;AAC7D,UAAIwB,uBAAuB,KAAKC,2BAAmBC,OAAnD,EAA4D;AAC1D,eAAO,CAAP;AACD;;AAED,UAAIF,uBAAuB,KAAKC,2BAAmBE,QAAnD,EAA6D;AAC3D,eAAO,CAAP;AACD;;AAED,aAAO3B,CAAC,CAACC,aAAF,IAAmB,CAA1B;AACD,KApHkB;AAAA,2GAsHE,YAAM;AACzB,UAAQN,KAAR,GAAkB,MAAKD,KAAvB,CAAQC,KAAR;;AACA,iBAAsCA,KAAK,IAAI,EAA/C;AAAA,uCAAQe,qBAAR;AAAA,UAAQA,qBAAR,sCAAgC,CAAhC;;AACA,UAAMkB,UAAU,GAAG,mCAAsBjC,KAAtB,CAAnB,CAHyB,CAIzB;;AACA,aAAOe,qBAAqB,KAAK,CAA1B,GAA8BkB,UAAU,GAAGlB,qBAA3C,GAAmE,KAA1E;AACD,KA5HkB;AAAA,2GA8HE,YAAM;AACzB,UAAQf,KAAR,GAAkB,MAAKD,KAAvB,CAAQC,KAAR;AACA,UAAMiC,UAAU,GAAG,mCAAsBjC,KAAtB,CAAnB;;AACA,YAAKoB,WAAL,CAAiB;AAAEL,QAAAA,qBAAqB,EAAEkB;AAAzB,OAAjB;AACD,KAlIkB;AAEjB,UAAKrC,GAAL,GAAWG,MAAK,CAACH,GAAN,IAAaA,UAAIsC,UAAJ,EAAxB;AAFiB;AAGlB;;;;WAiID,kBAAS;AAAA;;AACP,yBAAoG,KAAKnC,KAAzG;AAAA,UAAQoC,OAAR,gBAAQA,OAAR;AAAA,UAAiBC,aAAjB,gBAAiBA,aAAjB;AAAA,UAAgCC,YAAhC,gBAAgCA,YAAhC;AAAA,UAA8CrC,KAA9C,gBAA8CA,KAA9C;AAAA,UAAqDsC,kBAArD,gBAAqDA,kBAArD;AAAA,UAAyEC,sBAAzE,gBAAyEA,sBAAzE;;AACA,kBAwBIH,aAAa,IAAI,EAxBrB;AAAA,wCACEP,uBADF;AAAA,UACEA,uBADF,sCAC4B,EAD5B;AAAA,wCAEEW,sBAFF;AAAA,UAEEA,sBAFF,sCAE2B,EAF3B;AAAA,wCAGEC,gBAHF;AAAA,UAGEA,gBAHF,sCAGqB,EAHrB;AAAA,wCAIEC,eAJF;AAAA,UAIEA,eAJF,sCAIoB,EAJpB;AAAA,wCAKEC,iBALF;AAAA,UAKEA,iBALF,sCAKsB,EALtB;AAAA,iCAMExB,QANF;AAAA,UAMEA,QANF,+BAMa,EANb;AAAA,wCAOEyB,eAPF;AAAA,UAOEA,eAPF,sCAOoB,EAPpB;AAAA,uCAQEC,cARF;AAAA,UAQEA,cARF,qCAQmB,EARnB;AAAA,sCASEC,aATF;AAAA,UASEA,aATF,oCASkB,EATlB;AAAA,sCAUEC,aAVF;AAAA,UAUEA,aAVF,oCAUkB,EAVlB;AAAA,wCAWEC,mBAXF;AAAA,UAWEA,mBAXF,sCAWwB,CAXxB;AAAA,uCAYEC,cAZF;AAAA,UAYEA,cAZF,qCAYmB,EAZnB;AAAA,+BAaE1B,MAbF;AAAA,UAaEA,MAbF,6BAaW,EAbX;AAAA,kCAcEN,SAdF;AAAA,UAcEA,SAdF,gCAcc,EAdd;AAAA,oCAeEiC,WAfF;AAAA,UAeEA,WAfF,kCAegB,EAfhB;AAAA,UAgBEC,qBAhBF,SAgBEA,qBAhBF;AAAA,mCAiBEC,UAjBF;AAAA,UAiBEA,UAjBF,iCAiBe,EAjBf;AAAA,wCAkBEC,mBAlBF;AAAA,UAkBEA,mBAlBF,sCAkBwB,EAlBxB;AAAA,wCAmBEnC,mBAnBF;AAAA,UAmBEA,mBAnBF,sCAmBwB,EAnBxB;AAAA,mCAoBEoC,UApBF;AAAA,UAoBEA,UApBF,iCAoBe,EApBf;AAAA,sCAqBEC,aArBF;AAAA,UAqBEA,aArBF,oCAqBkB,EArBlB;AAAA,iCAsBEC,QAtBF;AAAA,UAsBEA,QAtBF,+BAsBa,EAtBb;AAAA,wCAuBEC,eAvBF;AAAA,UAuBEA,eAvBF,sCAuBoB,EAvBpB;;AAyBA,kBAWIzD,KAAK,IAAI,EAXb;AAAA,UACE0D,qBADF,SACEA,qBADF;AAAA,UAEE1C,0BAFF,SAEEA,0BAFF;AAAA,UAGE2C,MAHF,SAGEA,MAHF;AAAA,UAIEC,eAJF,SAIEA,eAJF;AAAA,UAKE7C,qBALF,SAKEA,qBALF;AAAA,UAME8C,aANF,SAMEA,aANF;AAAA,UAOEC,gBAPF,SAOEA,gBAPF;AAAA,UAQEC,iBARF,SAQEA,iBARF;AAAA,UASEC,0BATF,SASEA,0BATF;AAAA,UAUEC,qBAVF,SAUEA,qBAVF;;AAYA,kBAIIN,MAAM,IAAI,EAJd;AAAA,UACUO,WADV,SACE3C,MADF;AAAA,UAEa4C,cAFb,SAEElD,SAFF;AAAA,UAGuBmD,wBAHvB,SAGElD,mBAHF;;AAMA,UAAMmD,WAAW,GAAG;AAClBC,QAAAA,QAAQ,EAAEL,qBAAqB,KAAK,KAA1B,GAAkC,KAAlC,GAA0C;AADlC,OAApB;AAIA,UAAMM,MAAM,GAAGvE,KAAK,CAACuE,MAAN,IAAgB,EAA/B;AACAA,MAAAA,MAAM,CAACpE,OAAP,GAAiBoE,MAAM,CAACpE,OAAP,IAAkB;AAAES,QAAAA,KAAK,EAAE,EAAT;AAAa4D,QAAAA,OAAO,EAAE;AAAtB,OAAnC;AAEA,UAAM9D,UAAU,GAAG,8BAAgBV,KAAK,CAACU,UAAN,IAAoB,EAApC,EAAwCV,KAAK,CAACG,OAAN,IAAiB,EAAzD,EAA6DH,KAAK,CAACS,eAAN,IAAyB,EAAtF,CAAnB;AAEA,UAAMa,kBAAkB,GAAG,sCACzBtB,KAAK,CAACU,UAAN,IAAoB,EADK,EAEzBV,KAAK,CAACG,OAAN,IAAiB,EAFQ,EAGzBH,KAAK,CAACS,eAAN,IAAyB,EAHA,CAA3B;AAMA,UAAMN,OAAO,GAAGH,KAAK,CAACG,OAAN,CAAcC,GAAd,CAAkB,UAACC,CAAD,EAAO;AACvCA,QAAAA,CAAC,CAACoE,oBAAF,GAAyB,MAAI,CAACC,4BAAL,CAAkCrE,CAAlC,CAAzB,CADuC,CAEvC;;AACAA,QAAAA,CAAC,CAACC,aAAF,GAAkB,MAAI,CAACC,4BAAL,CAAkCP,KAAK,CAACQ,8BAAxC,EAAwEH,CAAxE,CAAlB;AACA,eAAOA,CAAP;AACD,OALe,CAAhB;AAOA,UAAMsE,oBAAoB,GAAG7B,aAAa,IAAIA,aAAa,CAACvB,MAA5D;AACA,UAAMqD,qBAAqB,GAAG/B,cAAc,IAAIA,cAAc,CAACtB,MAA/D;AAEA,UAAMsD,aAAa,GAAG;AACpB5B,QAAAA,cAAc,EAAEA,cAAc,CAAC3D,QAAf,IAA2BE,MAAM,CAACyD,cAAc,CAACrC,KAAhB,CAD7B;AAEpBgC,QAAAA,eAAe,EAAEA,eAAe,CAACtD,QAAhB,IAA4BE,MAAM,CAACoD,eAAe,CAAChC,KAAjB,CAF/B;AAGpB6B,QAAAA,gBAAgB,EACdA,gBAAgB,CAACnD,QAAjB,IACAI,WAAW,CAAC+C,gBAAgB,CAAC7B,KAAlB,EAAyB;AAClCA,UAAAA,KAAK,EAAE6B,gBAAgB,CAAC7B,KADU;AAElCkE,UAAAA,GAAG,EAAE9B,mBAF6B;AAGlC+B,UAAAA,GAAG,EAAE;AAH6B,SAAzB,CALO;AAUpBrC,QAAAA,eAAe,EAAEA,eAAe,CAACpD,QAAhB,IAA4BG,KAAK,CAACiD,eAAe,CAAC9B,KAAjB,EAAwB,CAAC,OAAD,EAAU,OAAV,EAAmB,MAAnB,EAA2B,OAA3B,CAAxB,CAV9B;AAWpBJ,QAAAA,8BAA8B,EAC5BqB,uBAAuB,CAACvC,QAAxB,IACAD,QAAQ,CAACwC,uBAAuB,CAACjB,KAAzB,EAAgC,CACtCkB,2BAAmBC,OADmB,EAEtCD,2BAAmBE,QAFmB,EAGtCF,2BAAmBkD,SAHmB,CAAhC,CAbU;AAkBpBhE,QAAAA,0BAA0B,EAAE+B,aAAa,CAACzD,QAAd,IAA0BE,MAAM,CAACuD,aAAa,CAACnC,KAAf,CAlBxC;AAmBpBG,QAAAA,qBAAqB,EACnBC,0BAA0B,KAAK,IAA/B,IACAtB,WAAW,CAACqD,aAAa,CAACnC,KAAf,EAAsB;AAC/BA,UAAAA,KAAK,EAAE,EADwB;AAE/BkE,UAAAA,GAAG,EAAE,CAF0B;AAG/BC,UAAAA,GAAG,EAAE;AAH0B,SAAtB,CArBO;AA0BpBlB,QAAAA,aAAa,EAAEtC,MAAM,CAACjC,QAAP,IAAmBE,MAAM,CAAC+B,MAAM,CAACX,KAAR,CA1BpB;AA2BpBgD,QAAAA,eAAe,EAAEzC,QAAQ,CAAC7B,QAAT,IAAqBE,MAAM,CAAC2B,QAAQ,CAACP,KAAV,CA3BxB;AA4BpB;AACA;AACA,4BAAoB4C,QAAQ,CAAClE,QAAT,IAAqBE,MAAM,CAACgE,QAAQ,CAAC5C,KAAV,EAAiB,IAAjB,CA9B3B;AA+BpB4C,QAAAA,QAAQ,EAAEA,QAAQ,CAAClE,QAAT,IAAqBkE,QAAQ,CAACzB,OAA9B,IAAyC1C,QAAQ,CAACoE,eAAe,CAAC7C,KAAjB,EAAwB6C,eAAe,CAACwB,OAAxC;AA/BvC,OAAtB;AAkCA,UAAMC,eAAe,GAAG;AACtBlB,QAAAA,0BAA0B,EAAE9C,mBAAmB,CAAC5B,QAApB,IAAgCE,MAAM,CAAC0B,mBAAmB,CAACN,KAArB,CAD5C;AAEtBuE,QAAAA,0BAA0B,EAAE9B,mBAAmB,CAAC/D,QAApB,IAAgCE,MAAM,CAAC6D,mBAAmB,CAACzC,KAArB,CAF5C;AAGtBkD,QAAAA,gBAAgB,EAAE7C,SAAS,CAAC3B,QAAV,IAAsBE,MAAM,CAACyB,SAAS,CAACL,KAAX,CAHxB;AAItBmD,QAAAA,iBAAiB,EAAEX,UAAU,CAAC9D,QAAX,IAAuBE,MAAM,CAAC4D,UAAU,CAACxC,KAAZ,CAJ1B;AAKtBsC,QAAAA,WAAW,EAAEA,WAAW,CAAC5D,QAAZ,IAAwBG,KAAK,CAACyD,WAAW,CAACtC,KAAb,EAAoB,CAAC,MAAD,EAAS,QAAT,CAApB,CALpB;AAMtBwE,QAAAA,aAAa,EAAE,CAAA9B,UAAU,SAAV,IAAAA,UAAU,WAAV,YAAAA,UAAU,CAAEhE,QAAZ,KAAwBE,MAAM,CAAC8D,UAAD,aAACA,UAAD,uBAACA,UAAU,CAAE1C,KAAb;AANvB,OAAxB;AASA,UAAMyE,QAAQ,GAAG,KAAKC,kBAAL,EAAjB;AACA,UAAMC,kBAAkB,GAAGpG,UAAU,CAACqG,CAAX,CAAa,yDAAb,EAAwE;AACjGC,QAAAA,GAAG,EAAEzF,KAAK,CAACwD,QADsF;AAEjGzC,QAAAA,qBAAqB,EAArBA;AAFiG,OAAxE,CAA3B;AAKA,0BACE,gCAAC,UAAD;AAAY,QAAA,KAAK,EAAE,KAAKnB;AAAxB,sBACE,gCAAC,gBAAD,CAAQ,YAAR;AACE,QAAA,UAAU,EAAE+C,iBADd;AAEE,QAAA,YAAY,EAAEQ,qBAFhB;AAGE,QAAA,QAAQ,eACN,gCAAC,KAAD;AACE,UAAA,KAAK,EAAEnD,KADT;AAEE,UAAA,aAAa,EAAE,KAAKoB,WAFtB;AAGE,UAAA,aAAa,EAAEgB,aAHjB;AAIE,UAAA,qBAAqB,EAAEG,sBAJzB;AAKE,UAAA,MAAM,EAAE;AACNmD,YAAAA,QAAQ,EAAEb,aADJ;AAENc,YAAAA,UAAU,EAAET;AAFN,WALV;AASE,UAAA,KAAK,eACH,gCAAC,qBAAD;AACE,YAAA,KAAK,EAAE,SADT;AAEE,YAAA,IAAI,EAAEK,kBAFR;AAGE,YAAA,IAAI,EAAEF,QAHR;AAIE,YAAA,OAAO,EAAE,KAAKO;AAJhB;AAVJ;AAJJ,SAwBG5B,0BAA0B,iBACzB,gCAAC,wBAAD;AAAgB,QAAA,KAAK,EAAE9C,mBAAmB,CAACN,KAA3C;AAAkD,QAAA,SAAS,EAAEuB,OAAO,CAAC0D;AAArE,sBACE,gCAAC,0BAAD;AACE,QAAA,SAAS,EAAE1D,OAAO,CAAC2D,KADrB;AAEE,QAAA,MAAM,EAAE9F,KAAK,CAACkB,mBAAN,IAA6B,EAFvC;AAGE,QAAA,QAAQ,EAAE,KAAK6E,yBAHjB;AAIE,QAAA,YAAY,EAAE1D,YAJhB;AAKE,QAAA,KAAK,EAAE+B,wBALT;AAME,QAAA,QAAQ,EAAE,KANZ;AAOE,QAAA,WAAW,EAAEC,WAPf;AAQE,QAAA,WAAW,EAAE,2BAAenD,mBAAf,aAAeA,mBAAf,uBAAeA,mBAAmB,CAAE8E,kBAApC,EAAwDxD,sBAAxD,CARf;AASE,QAAA,UAAU,EAAEuB,iBATd;AAUE,QAAA,aAAa,EAAGjB,aAAa,IAAIA,aAAa,CAAC5B,mBAAhC,IAAwDyD,oBAVzE;AAWE,QAAA,cAAc,EAAG9B,cAAc,IAAIA,cAAc,CAAC3B,mBAAlC,IAA0D0D,qBAX5E;AAYE,QAAA,kBAAkB,EAAEtC,kBAZtB;AAaE,QAAA,uBAAuB,EAAE,CAAC;AAAEkB,UAAAA,QAAQ,EAAE;AAAZ,SAAD,EAA0B;AAAEA,UAAAA,QAAQ,EAAE;AAAZ,SAA1B,CAb3B;AAcE,QAAA,aAAa,EAAED;AAdjB,QADF,EAiBGa,wBAAwB,iBAAI;AAAK,QAAA,SAAS,EAAEjC,OAAO,CAAC8D;AAAxB,SAAoC7B,wBAApC,CAjB/B,CAzBJ,EA8CGP,aAAa,iBACZ,gCAAC,wBAAD;AAAgB,QAAA,KAAK,EAAEtC,MAAM,CAACX,KAA9B;AAAqC,QAAA,SAAS,EAAEuB,OAAO,CAAC0D;AAAxD,sBACE,gCAAC,0BAAD;AACE,QAAA,SAAS,EAAE1D,OAAO,CAAC2D,KADrB;AAEE,QAAA,MAAM,EAAE9F,KAAK,CAACuB,MAAN,IAAgB,EAF1B;AAGE,QAAA,QAAQ,EAAE,KAAK2E,eAHjB;AAIE,QAAA,YAAY,EAAE7D,YAJhB;AAKE,QAAA,KAAK,EAAE6B,WALT;AAME,QAAA,QAAQ,EAAE,KANZ;AAOE,QAAA,gBAAgB,MAPlB;AAQE,QAAA,WAAW,EAAEG,WARf;AASE,QAAA,WAAW,EAAE,2BAAe9C,MAAf,aAAeA,MAAf,uBAAeA,MAAM,CAAEyE,kBAAvB,EAA2CxD,sBAA3C,CATf;AAUE,QAAA,UAAU,EAAEuB,iBAVd;AAWE,QAAA,aAAa,EAAEjB,aAAa,IAAIA,aAAa,CAACvB,MAXhD;AAYE,QAAA,cAAc,EAAEsB,cAAc,IAAIA,cAAc,CAACtB,MAZnD;AAaE,QAAA,kBAAkB,EAAEe,kBAbtB;AAcE,QAAA,uBAAuB,EAAE,CAAC;AAAEkB,UAAAA,QAAQ,EAAE;AAAZ,SAAD,EAA0B;AAAEA,UAAAA,QAAQ,EAAE;AAAZ,SAA1B,CAd3B;AAeE,QAAA,aAAa,EAAED;AAfjB,QADF,EAkBGW,WAAW,iBAAI;AAAK,QAAA,SAAS,EAAE/B,OAAO,CAAC8D;AAAxB,SAAoC/B,WAApC,CAlBlB,CA/CJ,eAqEE,gCAAC,sBAAD;AACE,QAAA,YAAY,EAAE7B,YADhB;AAEE,QAAA,kBAAkB,EAAEC,kBAFtB;AAGE,QAAA,KAAK,EAAEtC,KAHT;AAIE,QAAA,UAAU,EAAEU,UAAU,IAAI,EAJ5B;AAKE,QAAA,cAAc,EAAE,KAAKU,WALvB;AAME,QAAA,WAAW,EAAEiD,WANf;AAOE,QAAA,UAAU,EAAEN,iBAPd;AAQE,QAAA,aAAa,EAAE3B,aARjB;AASE,QAAA,oBAAoB,EAAEuC,oBATxB;AAUE,QAAA,qBAAqB,EAAEC,qBAVzB;AAWE,QAAA,aAAa,EAAErB;AAXjB,QArEF,eAmFE,gCAAC,mBAAD;AACE,QAAA,YAAY,EAAElB,YADhB;AAEE,QAAA,kBAAkB,EAAEC,kBAFtB;AAGE,QAAA,OAAO,EAAEnC,OAHX;AAIE,QAAA,KAAK,EAAEH,KAJT;AAKE,QAAA,cAAc,EAAE,KAAKoB,WALvB;AAME,QAAA,WAAW,EAAEiD,WANf;AAOE,QAAA,UAAU,EAAEN,iBAPd;AAQE,QAAA,aAAa,EAAE3B,aARjB;AASE,QAAA,oBAAoB,EAAEuC,oBATxB;AAUE,QAAA,qBAAqB,EAAEC;AAVzB,QAnFF,EAgGGlB,qBAAqB,iBACpB,gCAAC,kBAAD;AACE,QAAA,SAAS,EAAEvB,OAAO,CAACgE,gBADrB;AAEE,QAAA,KAAK,EAAC,qBAFR;AAGE,QAAA,WAAW,EAAC,2BAHd;AAIE,QAAA,KAAK,EAAE,KAAKC;AAJd,QAjGJ,EAwGG1C,qBAAqB,IACpBpC,kBAAkB,CAAClB,GAAnB,CAAuB,UAACiG,cAAD,EAAiB7E,KAAjB,EAA2B;AAChD,4BACE,gCAAC,iBAAD,CAAO,QAAP;AAAgB,UAAA,GAAG,EAAEA;AAArB,wBACE,gCAAC,kBAAD;AACE,UAAA,SAAS,EAAEW,OAAO,CAACgE,gBADrB;AAEE,UAAA,OAAO,EAAE,WAFX;AAGE,UAAA,KAAK,EAAC,oBAHR;AAIE,UAAA,WAAW,EAAC,2BAJd;AAKE,UAAA,KAAK,EAAE;AAAA,mBAAM,MAAI,CAACG,yBAAL,CAA+B9E,KAA/B,CAAN;AAAA;AALT,UADF,eAQE,gCAAC,8BAAD;AACE,UAAA,QAAQ,EAAEA,KADZ;AAEE,UAAA,YAAY,EAAEa,YAFhB;AAGE,UAAA,KAAK,EAAErC,KAHT;AAIE,UAAA,aAAa,EAAEoC,aAJjB;AAKE,UAAA,UAAU,EAAEiE,cALd;AAME,UAAA,cAAc,EAAE,MAAI,CAACjF,WANvB;AAOE,UAAA,kBAAkB,EAAEkB,kBAPtB;AAQE,UAAA,WAAW,EAAE+B,WARf;AASE,UAAA,oBAAoB,EAAEM,oBATxB;AAUE,UAAA,qBAAqB,EAAEC,qBAVzB;AAWE,UAAA,aAAa,EAAErB;AAXjB,UARF,CADF;AAwBD,OAzBD,CAzGJ,EAoIGO,gBAAgB,iBACf,gCAAC,wBAAD;AAAgB,QAAA,KAAK,EAAE7C,SAAS,CAACL,KAAjC;AAAwC,QAAA,SAAS,EAAEuB,OAAO,CAAC0D;AAA3D,sBACE,gCAAC,0BAAD;AACE,QAAA,SAAS,EAAE1D,OAAO,CAAC2D,KADrB;AAEE,QAAA,MAAM,EAAE9F,KAAK,CAACiB,SAAN,IAAmB,EAF7B;AAGE,QAAA,QAAQ,EAAE,KAAKsF,eAHjB;AAIE,QAAA,YAAY,EAAElE,YAJhB;AAKE,QAAA,KAAK,EAAE8B,cALT;AAME,QAAA,QAAQ,EAAE,KANZ;AAOE,QAAA,WAAW,EAAEE,WAPf;AAQE,QAAA,WAAW,EAAE,2BAAe9C,MAAf,aAAeA,MAAf,uBAAeA,MAAM,CAAEyE,kBAAvB,EAA2CxD,sBAA3C,CARf;AASE,QAAA,UAAU,EAAEuB,iBATd;AAUE,QAAA,aAAa,EAAGjB,aAAa,IAAIA,aAAa,CAAC7B,SAAhC,IAA8C0D,oBAV/D;AAWE,QAAA,cAAc,EAAG9B,cAAc,IAAIA,cAAc,CAAC5B,SAAlC,IAAgD2D,qBAXlE;AAYE,QAAA,kBAAkB,EAAEtC,kBAZtB;AAaE,QAAA,uBAAuB,EAAE,CAAC;AAAEkB,UAAAA,QAAQ,EAAE;AAAZ,SAAD,EAA0B;AAAEA,UAAAA,QAAQ,EAAE;AAAZ,SAA1B,CAb3B;AAcE,QAAA,aAAa,EAAED;AAdjB,QADF,EAiBGY,cAAc,iBAAI;AAAK,QAAA,SAAS,EAAEhC,OAAO,CAAC8D;AAAxB,SAAoC9B,cAApC,CAjBrB,CArIJ,EA0JGP,eAAe,iBACd,gCAAC,wBAAD;AAAgB,QAAA,QAAQ,EAAE5D,KAAK,CAACmB,QAAhC;AAA0C,QAAA,QAAQ,EAAE,KAAKqF,cAAzD;AAAyE,QAAA,WAAW,EAAEnC;AAAtF,QA3JJ,CADF,CADF;AAkKD;;;EAhbyBoC,kBAAMC,S;;;iCAArB5G,M,eACQ;AACjBqC,EAAAA,OAAO,EAAEwE,sBAAUC,MAAV,CAAiBC,UADT;AAEjBzE,EAAAA,aAAa,EAAEuE,sBAAUC,MAFR;AAGjBE,EAAAA,SAAS,EAAEH,sBAAUI,MAHJ;AAIjBxE,EAAAA,sBAAsB,EAAEoE,sBAAUK,IAJjB;AAKjBhH,EAAAA,KAAK,EAAE2G,sBAAUC,MAAV,CAAiBC,UALP;AAMjB5G,EAAAA,QAAQ,EAAE0G,sBAAUK,IAAV,CAAeH,UANR;AAOjBjH,EAAAA,GAAG,EAAE+G,sBAAUI,MAPE;AAQjB1E,EAAAA,YAAY,EAAEsE,sBAAUM,KAAV,CAAgB;AAC5BC,IAAAA,GAAG,EAAEP,sBAAUK,IAAV,CAAeH,UADQ;AAE5B,cAAQF,sBAAUK,IAAV,CAAeH;AAFK,GAAhB,CARG;AAYjBvE,EAAAA,kBAAkB,EAAEqE,sBAAUM,KAAV,CAAgB;AAClCC,IAAAA,GAAG,EAAEP,sBAAUK,IAAV,CAAeH,UADc;AAElC,cAAQF,sBAAUK,IAAV,CAAeH;AAFW,GAAhB;AAZH,C;;AAkbrB,IAAMM,MAAM,GAAG,SAATA,MAAS,CAACC,KAAD;AAAA,SAAY;AACzBjB,IAAAA,gBAAgB,EAAE;AAChBkB,MAAAA,YAAY,EAAED,KAAK,CAACE,OAAN,CAAcC,IAAd,GAAqB;AADnB,KADO;AAIzBC,IAAAA,IAAI,EAAE;AACJC,MAAAA,UAAU,EAAEL,KAAK,CAACE,OAAN,CAAcC,IAAd,GAAqB,CAD7B;AAEJG,MAAAA,aAAa,EAAEN,KAAK,CAACE,OAAN,CAAcC,IAAd,GAAqB;AAFhC,KAJmB;AAQzB1B,IAAAA,cAAc,EAAE;AACd8B,MAAAA,KAAK,EAAE,MADO;AAEdF,MAAAA,UAAU,EAAEL,KAAK,CAACE,OAAN,CAAcC,IAAd,GAAqB,CAFnB;AAGdF,MAAAA,YAAY,EAAED,KAAK,CAACE,OAAN,CAAcC,IAAd,GAAqB;AAHrB,KARS;AAazBK,IAAAA,KAAK,EAAE;AACLP,MAAAA,YAAY,EAAED,KAAK,CAACE,OAAN,CAAcC,IAAd,GAAqB;AAD9B,KAbkB;AAgBzBtB,IAAAA,SAAS,EAAE;AACT4B,MAAAA,QAAQ,EAAET,KAAK,CAACU,UAAN,CAAiBD,QAAjB,GAA4B,CAD7B;AAETE,MAAAA,KAAK,EAAEX,KAAK,CAACY,OAAN,CAAcC,KAAd,CAAoBC,IAFlB;AAGTT,MAAAA,UAAU,EAAEL,KAAK,CAACE,OAAN,CAAcC;AAHjB;AAhBc,GAAZ;AAAA,CAAf;;eAuBe,2BAAgB,wBAAWJ,MAAX,EAAmBrH,MAAnB,CAAhB,C","sourcesContent":["import { getPluginProps } from './utils';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport { FeedbackConfig, InputContainer, layout, settings } from '@pie-lib/pie-toolbox/config-ui';\nimport {\n countInAnswer,\n ensureNoExtraChoicesInAnswer,\n ensureNoExtraChoicesInAlternate,\n} from '@pie-lib/pie-toolbox/categorize';\nimport { EditableHtml } from '@pie-lib/pie-toolbox/editable-html';\nimport { uid, withDragContext } from '@pie-lib/pie-toolbox/drag';\n\nimport Categories from './categories';\nimport AlternateResponses from './categories/alternateResponses';\nimport Choices from './choices';\nimport { buildAlternateResponses, buildCategories } from './builder';\nimport Header from './header';\nimport { getMaxCategoryChoices, multiplePlacements } from '../utils';\nimport { AlertDialog } from '@pie-lib/pie-toolbox/config-ui';\nimport Translator from '@pie-lib/pie-toolbox/translator';\n\nconst { translator } = Translator;\nconst { dropdown, Panel, toggle, radio, numberField } = settings;\nconst { Provider: IdProvider } = uid;\n\nexport class Design extends React.Component {\n static propTypes = {\n classes: PropTypes.object.isRequired,\n configuration: PropTypes.object,\n className: PropTypes.string,\n onConfigurationChanged: PropTypes.func,\n model: PropTypes.object.isRequired,\n onChange: PropTypes.func.isRequired,\n uid: PropTypes.string,\n imageSupport: PropTypes.shape({\n add: PropTypes.func.isRequired,\n delete: PropTypes.func.isRequired,\n }),\n uploadSoundSupport: PropTypes.shape({\n add: PropTypes.func.isRequired,\n delete: PropTypes.func.isRequired,\n }),\n };\n\n constructor(props) {\n super(props);\n this.uid = props.uid || uid.generateId();\n }\n\n updateModel = (props) => {\n const { model, onChange } = this.props;\n\n const updatedModel = {\n ...model,\n ...props,\n };\n\n updatedModel.choices = updatedModel.choices.map((c) => ({\n ...c,\n categoryCount: this.checkAllowMultiplePlacements(updatedModel.allowMultiplePlacementsEnabled, c),\n }));\n\n //Ensure that there are no extra choices in correctResponse, if the user has decided that only one choice may be used.\n updatedModel.correctResponse = ensureNoExtraChoicesInAnswer(\n updatedModel.correctResponse || [],\n updatedModel.choices,\n );\n\n //Ensure that there are no extra choices in alternate responses, if the user has decided that only one choice may be used.\n updatedModel.correctResponse = ensureNoExtraChoicesInAlternate(\n updatedModel.correctResponse || [],\n updatedModel.choices,\n );\n\n //clean categories\n updatedModel.categories = updatedModel.categories.map((c) => ({\n id: c.id,\n label: c.label,\n }));\n\n updatedModel.choices = updatedModel.choices.map((h) => ({\n id: h.id,\n content: h.content,\n categoryCount: h.categoryCount,\n }));\n\n // ensure that maxChoicesPerCategory is reset if author switch back the corresponding switch (allowMaxChoicesPerCategory)\n updatedModel.maxChoicesPerCategory = updatedModel.allowMaxChoicesPerCategory\n ? updatedModel.maxChoicesPerCategory\n : 0;\n\n onChange(updatedModel);\n };\n\n changeRationale = (rationale) => {\n const { model, onChange } = this.props;\n\n onChange({\n ...model,\n rationale,\n });\n };\n\n changeTeacherInstructions = (teacherInstructions) => {\n const { model, onChange } = this.props;\n\n onChange({\n ...model,\n teacherInstructions,\n });\n };\n\n changeFeedback = (feedback) => {\n this.updateModel({ feedback });\n };\n\n onAddAlternateResponse = () => {\n const {\n model: { correctResponse },\n } = this.props;\n\n this.updateModel({\n correctResponse: (correctResponse || []).map((cr) => ({\n ...cr,\n alternateResponses: [...(cr.alternateResponses || []), []],\n })),\n });\n };\n\n onPromptChanged = (prompt) => this.updateModel({ prompt });\n\n onRemoveAlternateResponse = (index) => {\n const {\n model: { correctResponse },\n } = this.props;\n\n this.updateModel({\n correctResponse: (correctResponse || []).map((cr) => ({\n ...cr,\n alternateResponses: (cr.alternateResponses || []).filter((alt, altIndex) => altIndex !== index),\n })),\n });\n };\n\n countChoiceInCorrectResponse = (choice) => {\n const { model } = this.props;\n\n return countInAnswer(choice.id, model.correctResponse);\n };\n\n checkAllowMultiplePlacements = (allowMultiplePlacements, c) => {\n if (allowMultiplePlacements === multiplePlacements.enabled) {\n return 0;\n }\n\n if (allowMultiplePlacements === multiplePlacements.disabled) {\n return 1;\n }\n\n return c.categoryCount || 0;\n };\n\n isAlertModalOpened = () => {\n const { model } = this.props;\n const { maxChoicesPerCategory = 0 } = model || {};\n const maxChoices = getMaxCategoryChoices(model);\n // when maxChoicesPerCategory is set to 0, there is no limit so modal should not be opened\n return maxChoicesPerCategory !== 0 ? maxChoices > maxChoicesPerCategory : false;\n };\n\n onAlertModalCancel = () => {\n const { model } = this.props;\n const maxChoices = getMaxCategoryChoices(model);\n this.updateModel({ maxChoicesPerCategory: maxChoices });\n };\n\n render() {\n const { classes, configuration, imageSupport, model, uploadSoundSupport, onConfigurationChanged } = this.props;\n const {\n allowMultiplePlacements = {},\n baseInputConfiguration = {},\n categoriesPerRow = {},\n choicesPosition = {},\n contentDimensions = {},\n feedback = {},\n lockChoiceOrder = {},\n maxImageHeight = {},\n maxImageWidth = {},\n maxPlacements = {},\n minCategoriesPerRow = 1,\n partialScoring = {},\n prompt = {},\n rationale = {},\n scoringType = {},\n settingsPanelDisabled,\n spellCheck = {},\n studentInstructions = {},\n teacherInstructions = {},\n withRubric = {},\n mathMlOptions = {},\n language = {},\n languageChoices = {},\n } = configuration || {};\n const {\n allowAlternateEnabled,\n allowMaxChoicesPerCategory,\n errors,\n feedbackEnabled,\n maxChoicesPerCategory,\n promptEnabled,\n rationaleEnabled,\n spellCheckEnabled,\n teacherInstructionsEnabled,\n toolbarEditorPosition,\n } = model || {};\n const {\n prompt: promptError,\n rationale: rationaleError,\n teacherInstructions: teacherInstructionsError,\n } = errors || {};\n\n const toolbarOpts = {\n position: toolbarEditorPosition === 'top' ? 'top' : 'bottom',\n };\n\n const config = model.config || {};\n config.choices = config.choices || { label: '', columns: 2 };\n\n const categories = buildCategories(model.categories || [], model.choices || [], model.correctResponse || []);\n\n const alternateResponses = buildAlternateResponses(\n model.categories || [],\n model.choices || [],\n model.correctResponse || [],\n );\n\n const choices = model.choices.map((c) => {\n c.correctResponseCount = this.countChoiceInCorrectResponse(c);\n // ensure categoryCount is set even though updatedModel hasn't been called\n c.categoryCount = this.checkAllowMultiplePlacements(model.allowMultiplePlacementsEnabled, c);\n return c;\n });\n\n const defaultImageMaxWidth = maxImageWidth && maxImageWidth.prompt;\n const defaultImageMaxHeight = maxImageHeight && maxImageHeight.prompt;\n\n const panelSettings = {\n partialScoring: partialScoring.settings && toggle(partialScoring.label),\n lockChoiceOrder: lockChoiceOrder.settings && toggle(lockChoiceOrder.label),\n categoriesPerRow:\n categoriesPerRow.settings &&\n numberField(categoriesPerRow.label, {\n label: categoriesPerRow.label,\n min: minCategoriesPerRow,\n max: 6,\n }),\n choicesPosition: choicesPosition.settings && radio(choicesPosition.label, ['below', 'above', 'left', 'right']),\n allowMultiplePlacementsEnabled:\n allowMultiplePlacements.settings &&\n dropdown(allowMultiplePlacements.label, [\n multiplePlacements.enabled,\n multiplePlacements.disabled,\n multiplePlacements.perChoice,\n ]),\n allowMaxChoicesPerCategory: maxPlacements.settings && toggle(maxPlacements.label),\n maxChoicesPerCategory:\n allowMaxChoicesPerCategory === true &&\n numberField(maxPlacements.label, {\n label: '',\n min: 0,\n max: 30,\n }),\n promptEnabled: prompt.settings && toggle(prompt.label),\n feedbackEnabled: feedback.settings && toggle(feedback.label),\n // PD-2960: deleted temporary from settings panel\n // allowAlternateEnabled: allowAlternate.settings && toggle(allowAlternate.label),\n 'language.enabled': language.settings && toggle(language.label, true),\n language: language.settings && language.enabled && dropdown(languageChoices.label, languageChoices.options),\n };\n\n const panelProperties = {\n teacherInstructionsEnabled: teacherInstructions.settings && toggle(teacherInstructions.label),\n studentInstructionsEnabled: studentInstructions.settings && toggle(studentInstructions.label),\n rationaleEnabled: rationale.settings && toggle(rationale.label),\n spellCheckEnabled: spellCheck.settings && toggle(spellCheck.label),\n scoringType: scoringType.settings && radio(scoringType.label, ['auto', 'rubric']),\n rubricEnabled: withRubric?.settings && toggle(withRubric?.label),\n };\n\n const isOpened = this.isAlertModalOpened();\n const alertMaxChoicesMsg = translator.t('translation:categorize:maxChoicesPerCategoryRestriction', {\n lng: model.language,\n maxChoicesPerCategory,\n });\n\n return (\n <IdProvider value={this.uid}>\n <layout.ConfigLayout\n dimensions={contentDimensions}\n hideSettings={settingsPanelDisabled}\n settings={\n <Panel\n model={model}\n onChangeModel={this.updateModel}\n configuration={configuration}\n onChangeConfiguration={onConfigurationChanged}\n groups={{\n Settings: panelSettings,\n Properties: panelProperties,\n }}\n modal={\n <AlertDialog\n title={'Warning'}\n text={alertMaxChoicesMsg}\n open={isOpened}\n onClose={this.onAlertModalCancel}\n />\n }\n />\n }\n >\n {teacherInstructionsEnabled && (\n <InputContainer label={teacherInstructions.label} className={classes.inputContainer}>\n <EditableHtml\n className={classes.input}\n markup={model.teacherInstructions || ''}\n onChange={this.changeTeacherInstructions}\n imageSupport={imageSupport}\n error={teacherInstructionsError}\n nonEmpty={false}\n toolbarOpts={toolbarOpts}\n pluginProps={getPluginProps(teacherInstructions?.inputConfiguration, baseInputConfiguration)}\n spellCheck={spellCheckEnabled}\n maxImageWidth={(maxImageWidth && maxImageWidth.teacherInstructions) || defaultImageMaxWidth}\n maxImageHeight={(maxImageHeight && maxImageHeight.teacherInstructions) || defaultImageMaxHeight}\n uploadSoundSupport={uploadSoundSupport}\n languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n mathMlOptions={mathMlOptions}\n />\n {teacherInstructionsError && <div className={classes.errorText}>{teacherInstructionsError}</div>}\n </InputContainer>\n )}\n\n {promptEnabled && (\n <InputContainer label={prompt.label} className={classes.inputContainer}>\n <EditableHtml\n className={classes.input}\n markup={model.prompt || ''}\n onChange={this.onPromptChanged}\n imageSupport={imageSupport}\n error={promptError}\n nonEmpty={false}\n disableUnderline\n toolbarOpts={toolbarOpts}\n pluginProps={getPluginProps(prompt?.inputConfiguration, baseInputConfiguration)}\n spellCheck={spellCheckEnabled}\n maxImageWidth={maxImageWidth && maxImageWidth.prompt}\n maxImageHeight={maxImageHeight && maxImageHeight.prompt}\n uploadSoundSupport={uploadSoundSupport}\n languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n mathMlOptions={mathMlOptions}\n />\n {promptError && <div className={classes.errorText}>{promptError}</div>}\n </InputContainer>\n )}\n\n <Categories\n imageSupport={imageSupport}\n uploadSoundSupport={uploadSoundSupport}\n model={model}\n categories={categories || []}\n onModelChanged={this.updateModel}\n toolbarOpts={toolbarOpts}\n spellCheck={spellCheckEnabled}\n configuration={configuration}\n defaultImageMaxWidth={defaultImageMaxWidth}\n defaultImageMaxHeight={defaultImageMaxHeight}\n mathMlOptions={mathMlOptions}\n />\n\n <Choices\n imageSupport={imageSupport}\n uploadSoundSupport={uploadSoundSupport}\n choices={choices}\n model={model}\n onModelChanged={this.updateModel}\n toolbarOpts={toolbarOpts}\n spellCheck={spellCheckEnabled}\n configuration={configuration}\n defaultImageMaxWidth={defaultImageMaxWidth}\n defaultImageMaxHeight={defaultImageMaxHeight}\n />\n\n {allowAlternateEnabled && (\n <Header\n className={classes.alternatesHeader}\n label=\"Alternate Responses\"\n buttonLabel=\"ADD AN ALTERNATE RESPONSE\"\n onAdd={this.onAddAlternateResponse}\n />\n )}\n {allowAlternateEnabled &&\n alternateResponses.map((categoriesList, index) => {\n return (\n <React.Fragment key={index}>\n <Header\n className={classes.alternatesHeader}\n variant={'subtitle1'}\n label=\"Alternate Response\"\n buttonLabel=\"REMOVE ALTERNATE RESPONSE\"\n onAdd={() => this.onRemoveAlternateResponse(index)}\n />\n <AlternateResponses\n altIndex={index}\n imageSupport={imageSupport}\n model={model}\n configuration={configuration}\n categories={categoriesList}\n onModelChanged={this.updateModel}\n uploadSoundSupport={uploadSoundSupport}\n toolbarOpts={toolbarOpts}\n defaultImageMaxWidth={defaultImageMaxWidth}\n defaultImageMaxHeight={defaultImageMaxHeight}\n mathMlOptions={mathMlOptions}\n />\n </React.Fragment>\n );\n })}\n\n {rationaleEnabled && (\n <InputContainer label={rationale.label} className={classes.inputContainer}>\n <EditableHtml\n className={classes.input}\n markup={model.rationale || ''}\n onChange={this.changeRationale}\n imageSupport={imageSupport}\n error={rationaleError}\n nonEmpty={false}\n toolbarOpts={toolbarOpts}\n pluginProps={getPluginProps(prompt?.inputConfiguration, baseInputConfiguration)}\n spellCheck={spellCheckEnabled}\n maxImageWidth={(maxImageWidth && maxImageWidth.rationale) || defaultImageMaxWidth}\n maxImageHeight={(maxImageHeight && maxImageHeight.rationale) || defaultImageMaxHeight}\n uploadSoundSupport={uploadSoundSupport}\n languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n mathMlOptions={mathMlOptions}\n />\n {rationaleError && <div className={classes.errorText}>{rationaleError}</div>}\n </InputContainer>\n )}\n\n {feedbackEnabled && (\n <FeedbackConfig feedback={model.feedback} onChange={this.changeFeedback} toolbarOpts={toolbarOpts} />\n )}\n </layout.ConfigLayout>\n </IdProvider>\n );\n }\n}\n\nconst styles = (theme) => ({\n alternatesHeader: {\n marginBottom: theme.spacing.unit * 2,\n },\n text: {\n paddingTop: theme.spacing.unit * 2,\n paddingBottom: theme.spacing.unit * 2,\n },\n inputContainer: {\n width: '100%',\n paddingTop: theme.spacing.unit * 2,\n marginBottom: theme.spacing.unit * 2,\n },\n title: {\n marginBottom: theme.spacing.unit * 4,\n },\n errorText: {\n fontSize: theme.typography.fontSize - 2,\n color: theme.palette.error.main,\n paddingTop: theme.spacing.unit,\n },\n});\n\nexport default withDragContext(withStyles(styles)(Design));\n"],"file":"index.js"}