@pie-element/categorize 8.15.1-next.0 → 8.15.1-next.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 (63) hide show
  1. package/configure/package.json +1 -1
  2. package/controller/package.json +1 -1
  3. package/package.json +3 -3
  4. package/configure/lib/defaults.js +0 -207
  5. package/configure/lib/defaults.js.map +0 -1
  6. package/configure/lib/design/builder.js +0 -74
  7. package/configure/lib/design/builder.js.map +0 -1
  8. package/configure/lib/design/buttons.js +0 -127
  9. package/configure/lib/design/buttons.js.map +0 -1
  10. package/configure/lib/design/categories/RowLabel.js +0 -78
  11. package/configure/lib/design/categories/RowLabel.js.map +0 -1
  12. package/configure/lib/design/categories/alternateResponses.js +0 -293
  13. package/configure/lib/design/categories/alternateResponses.js.map +0 -1
  14. package/configure/lib/design/categories/category.js +0 -219
  15. package/configure/lib/design/categories/category.js.map +0 -1
  16. package/configure/lib/design/categories/choice-preview.js +0 -136
  17. package/configure/lib/design/categories/choice-preview.js.map +0 -1
  18. package/configure/lib/design/categories/droppable-placeholder.js +0 -187
  19. package/configure/lib/design/categories/droppable-placeholder.js.map +0 -1
  20. package/configure/lib/design/categories/index.js +0 -408
  21. package/configure/lib/design/categories/index.js.map +0 -1
  22. package/configure/lib/design/choices/choice.js +0 -297
  23. package/configure/lib/design/choices/choice.js.map +0 -1
  24. package/configure/lib/design/choices/config.js +0 -114
  25. package/configure/lib/design/choices/config.js.map +0 -1
  26. package/configure/lib/design/choices/index.js +0 -276
  27. package/configure/lib/design/choices/index.js.map +0 -1
  28. package/configure/lib/design/header.js +0 -107
  29. package/configure/lib/design/header.js.map +0 -1
  30. package/configure/lib/design/index.js +0 -538
  31. package/configure/lib/design/index.js.map +0 -1
  32. package/configure/lib/design/input-header.js +0 -166
  33. package/configure/lib/design/input-header.js.map +0 -1
  34. package/configure/lib/design/utils.js +0 -23
  35. package/configure/lib/design/utils.js.map +0 -1
  36. package/configure/lib/index.js +0 -196
  37. package/configure/lib/index.js.map +0 -1
  38. package/configure/lib/main.js +0 -88
  39. package/configure/lib/main.js.map +0 -1
  40. package/configure/lib/utils.js +0 -40
  41. package/configure/lib/utils.js.map +0 -1
  42. package/controller/lib/defaults.js +0 -31
  43. package/controller/lib/defaults.js.map +0 -1
  44. package/controller/lib/index.js +0 -484
  45. package/controller/lib/index.js.map +0 -1
  46. package/controller/lib/utils.js +0 -60
  47. package/controller/lib/utils.js.map +0 -1
  48. package/lib/categorize/categories.js +0 -193
  49. package/lib/categorize/categories.js.map +0 -1
  50. package/lib/categorize/category.js +0 -135
  51. package/lib/categorize/category.js.map +0 -1
  52. package/lib/categorize/choice.js +0 -228
  53. package/lib/categorize/choice.js.map +0 -1
  54. package/lib/categorize/choices.js +0 -162
  55. package/lib/categorize/choices.js.map +0 -1
  56. package/lib/categorize/droppable-placeholder.js +0 -111
  57. package/lib/categorize/droppable-placeholder.js.map +0 -1
  58. package/lib/categorize/grid-content.js +0 -103
  59. package/lib/categorize/grid-content.js.map +0 -1
  60. package/lib/categorize/index.js +0 -368
  61. package/lib/categorize/index.js.map +0 -1
  62. package/lib/index.js +0 -137
  63. package/lib/index.js.map +0 -1
@@ -1,538 +0,0 @@
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
@@ -1 +0,0 @@
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":"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","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"}