@pie-element/categorize 8.6.1-next.42 → 8.6.1-next.43

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 +134 -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 +72 -0
  8. package/configure/lib/design/categories/RowLabel.js.map +1 -0
  9. package/configure/lib/design/categories/alternateResponses.js +291 -0
  10. package/configure/lib/design/categories/alternateResponses.js.map +1 -0
  11. package/configure/lib/design/categories/category.js +213 -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 +406 -0
  18. package/configure/lib/design/categories/index.js.map +1 -0
  19. package/configure/lib/design/choices/choice.js +294 -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 +275 -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 +513 -0
  28. package/configure/lib/design/index.js.map +1 -0
  29. package/configure/lib/design/input-header.js +168 -0
  30. package/configure/lib/design/input-header.js.map +1 -0
  31. package/configure/lib/index.js +196 -0
  32. package/configure/lib/index.js.map +1 -0
  33. package/configure/lib/main.js +88 -0
  34. package/configure/lib/main.js.map +1 -0
  35. package/configure/lib/utils.js +40 -0
  36. package/configure/lib/utils.js.map +1 -0
  37. package/configure/package.json +1 -1
  38. package/controller/lib/defaults.js +31 -0
  39. package/controller/lib/defaults.js.map +1 -0
  40. package/controller/lib/index.js +469 -0
  41. package/controller/lib/index.js.map +1 -0
  42. package/controller/lib/utils.js +60 -0
  43. package/controller/lib/utils.js.map +1 -0
  44. package/controller/package.json +1 -1
  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 +3 -3
@@ -0,0 +1,513 @@
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 _react = _interopRequireDefault(require("react"));
27
+
28
+ var _propTypes = _interopRequireDefault(require("prop-types"));
29
+
30
+ var _styles = require("@material-ui/core/styles");
31
+
32
+ var _configUi = require("@pie-lib/pie-toolbox/config-ui");
33
+
34
+ var _categorize = require("@pie-lib/pie-toolbox/categorize");
35
+
36
+ var _editableHtml = require("@pie-lib/pie-toolbox/editable-html");
37
+
38
+ var _drag = require("@pie-lib/pie-toolbox/drag");
39
+
40
+ var _categories = _interopRequireDefault(require("./categories"));
41
+
42
+ var _alternateResponses = _interopRequireDefault(require("./categories/alternateResponses"));
43
+
44
+ var _choices = _interopRequireDefault(require("./choices"));
45
+
46
+ var _builder = require("./builder");
47
+
48
+ var _header = _interopRequireDefault(require("./header"));
49
+
50
+ var _utils = require("../utils");
51
+
52
+ var _translator = _interopRequireDefault(require("@pie-lib/pie-toolbox/translator"));
53
+
54
+ 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; }
55
+
56
+ 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; }
57
+
58
+ 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); }; }
59
+
60
+ 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; } }
61
+
62
+ var translator = _translator["default"].translator;
63
+ var dropdown = _configUi.settings.dropdown,
64
+ Panel = _configUi.settings.Panel,
65
+ toggle = _configUi.settings.toggle,
66
+ radio = _configUi.settings.radio,
67
+ numberField = _configUi.settings.numberField;
68
+ var IdProvider = _drag.uid.Provider;
69
+
70
+ var Design = /*#__PURE__*/function (_React$Component) {
71
+ (0, _inherits2["default"])(Design, _React$Component);
72
+
73
+ var _super = _createSuper(Design);
74
+
75
+ function Design(_props) {
76
+ var _this;
77
+
78
+ (0, _classCallCheck2["default"])(this, Design);
79
+ _this = _super.call(this, _props);
80
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateModel", function (props) {
81
+ var _this$props = _this.props,
82
+ model = _this$props.model,
83
+ onChange = _this$props.onChange;
84
+
85
+ var updatedModel = _objectSpread(_objectSpread({}, model), props);
86
+
87
+ updatedModel.choices = updatedModel.choices.map(function (c) {
88
+ return _objectSpread(_objectSpread({}, c), {}, {
89
+ categoryCount: _this.checkAllowMultiplePlacements(updatedModel.allowMultiplePlacementsEnabled, c)
90
+ });
91
+ }); //Ensure that there are no extra choices in correctResponse, if the user has decided that only one choice may be used.
92
+
93
+ 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.
94
+
95
+ updatedModel.correctResponse = (0, _categorize.ensureNoExtraChoicesInAlternate)(updatedModel.correctResponse || [], updatedModel.choices); //clean categories
96
+
97
+ updatedModel.categories = updatedModel.categories.map(function (c) {
98
+ return {
99
+ id: c.id,
100
+ label: c.label
101
+ };
102
+ });
103
+ updatedModel.choices = updatedModel.choices.map(function (h) {
104
+ return {
105
+ id: h.id,
106
+ content: h.content,
107
+ categoryCount: h.categoryCount
108
+ };
109
+ }); // ensure that maxChoicesPerCategory is reset if author switch back the corresponding switch (allowMaxChoicesPerCategory)
110
+
111
+ updatedModel.maxChoicesPerCategory = updatedModel.allowMaxChoicesPerCategory ? updatedModel.maxChoicesPerCategory : 0;
112
+ onChange(updatedModel);
113
+ });
114
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeRationale", function (rationale) {
115
+ var _this$props2 = _this.props,
116
+ model = _this$props2.model,
117
+ onChange = _this$props2.onChange;
118
+ onChange(_objectSpread(_objectSpread({}, model), {}, {
119
+ rationale: rationale
120
+ }));
121
+ });
122
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeTeacherInstructions", function (teacherInstructions) {
123
+ var _this$props3 = _this.props,
124
+ model = _this$props3.model,
125
+ onChange = _this$props3.onChange;
126
+ onChange(_objectSpread(_objectSpread({}, model), {}, {
127
+ teacherInstructions: teacherInstructions
128
+ }));
129
+ });
130
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeFeedback", function (feedback) {
131
+ _this.updateModel({
132
+ feedback: feedback
133
+ });
134
+ });
135
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onAddAlternateResponse", function () {
136
+ var correctResponse = _this.props.model.correctResponse;
137
+
138
+ _this.updateModel({
139
+ correctResponse: (correctResponse || []).map(function (cr) {
140
+ return _objectSpread(_objectSpread({}, cr), {}, {
141
+ alternateResponses: [].concat((0, _toConsumableArray2["default"])(cr.alternateResponses || []), [[]])
142
+ });
143
+ })
144
+ });
145
+ });
146
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onPromptChanged", function (prompt) {
147
+ return _this.updateModel({
148
+ prompt: prompt
149
+ });
150
+ });
151
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onRemoveAlternateResponse", function (index) {
152
+ var correctResponse = _this.props.model.correctResponse;
153
+
154
+ _this.updateModel({
155
+ correctResponse: (correctResponse || []).map(function (cr) {
156
+ return _objectSpread(_objectSpread({}, cr), {}, {
157
+ alternateResponses: (cr.alternateResponses || []).filter(function (alt, altIndex) {
158
+ return altIndex !== index;
159
+ })
160
+ });
161
+ })
162
+ });
163
+ });
164
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "countChoiceInCorrectResponse", function (choice) {
165
+ var model = _this.props.model;
166
+ return (0, _categorize.countInAnswer)(choice.id, model.correctResponse);
167
+ });
168
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "checkAllowMultiplePlacements", function (allowMultiplePlacements, c) {
169
+ if (allowMultiplePlacements === _utils.multiplePlacements.enabled) {
170
+ return 0;
171
+ }
172
+
173
+ if (allowMultiplePlacements === _utils.multiplePlacements.disabled) {
174
+ return 1;
175
+ }
176
+
177
+ return c.categoryCount || 0;
178
+ });
179
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "isAlertModalOpened", function () {
180
+ var model = _this.props.model;
181
+
182
+ var _ref = model || {},
183
+ _ref$maxChoicesPerCat = _ref.maxChoicesPerCategory,
184
+ maxChoicesPerCategory = _ref$maxChoicesPerCat === void 0 ? 0 : _ref$maxChoicesPerCat;
185
+
186
+ var maxChoices = (0, _utils.getMaxCategoryChoices)(model); // when maxChoicesPerCategory is set to 0, there is no limit so modal should not be opened
187
+
188
+ return maxChoicesPerCategory !== 0 ? maxChoices > maxChoicesPerCategory : false;
189
+ });
190
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onAlertModalCancel", function () {
191
+ var model = _this.props.model;
192
+ var maxChoices = (0, _utils.getMaxCategoryChoices)(model);
193
+
194
+ _this.updateModel({
195
+ maxChoicesPerCategory: maxChoices
196
+ });
197
+ });
198
+ _this.uid = _props.uid || _drag.uid.generateId();
199
+ return _this;
200
+ }
201
+
202
+ (0, _createClass2["default"])(Design, [{
203
+ key: "render",
204
+ value: function render() {
205
+ var _this2 = this;
206
+
207
+ var _this$props4 = this.props,
208
+ classes = _this$props4.classes,
209
+ configuration = _this$props4.configuration,
210
+ imageSupport = _this$props4.imageSupport,
211
+ model = _this$props4.model,
212
+ uploadSoundSupport = _this$props4.uploadSoundSupport,
213
+ onConfigurationChanged = _this$props4.onConfigurationChanged;
214
+
215
+ var _ref2 = configuration || {},
216
+ _ref2$allowMultiplePl = _ref2.allowMultiplePlacements,
217
+ allowMultiplePlacements = _ref2$allowMultiplePl === void 0 ? {} : _ref2$allowMultiplePl,
218
+ _ref2$allowAlternate = _ref2.allowAlternate,
219
+ allowAlternate = _ref2$allowAlternate === void 0 ? {} : _ref2$allowAlternate,
220
+ _ref2$categoriesPerRo = _ref2.categoriesPerRow,
221
+ categoriesPerRow = _ref2$categoriesPerRo === void 0 ? {} : _ref2$categoriesPerRo,
222
+ _ref2$choicesPosition = _ref2.choicesPosition,
223
+ choicesPosition = _ref2$choicesPosition === void 0 ? {} : _ref2$choicesPosition,
224
+ _ref2$contentDimensio = _ref2.contentDimensions,
225
+ contentDimensions = _ref2$contentDimensio === void 0 ? {} : _ref2$contentDimensio,
226
+ _ref2$feedback = _ref2.feedback,
227
+ feedback = _ref2$feedback === void 0 ? {} : _ref2$feedback,
228
+ _ref2$lockChoiceOrder = _ref2.lockChoiceOrder,
229
+ lockChoiceOrder = _ref2$lockChoiceOrder === void 0 ? {} : _ref2$lockChoiceOrder,
230
+ _ref2$maxImageHeight = _ref2.maxImageHeight,
231
+ maxImageHeight = _ref2$maxImageHeight === void 0 ? {} : _ref2$maxImageHeight,
232
+ _ref2$maxImageWidth = _ref2.maxImageWidth,
233
+ maxImageWidth = _ref2$maxImageWidth === void 0 ? {} : _ref2$maxImageWidth,
234
+ _ref2$maxPlacements = _ref2.maxPlacements,
235
+ maxPlacements = _ref2$maxPlacements === void 0 ? {} : _ref2$maxPlacements,
236
+ _ref2$minCategoriesPe = _ref2.minCategoriesPerRow,
237
+ minCategoriesPerRow = _ref2$minCategoriesPe === void 0 ? 1 : _ref2$minCategoriesPe,
238
+ _ref2$partialScoring = _ref2.partialScoring,
239
+ partialScoring = _ref2$partialScoring === void 0 ? {} : _ref2$partialScoring,
240
+ _ref2$prompt = _ref2.prompt,
241
+ prompt = _ref2$prompt === void 0 ? {} : _ref2$prompt,
242
+ _ref2$rationale = _ref2.rationale,
243
+ rationale = _ref2$rationale === void 0 ? {} : _ref2$rationale,
244
+ _ref2$scoringType = _ref2.scoringType,
245
+ scoringType = _ref2$scoringType === void 0 ? {} : _ref2$scoringType,
246
+ settingsPanelDisabled = _ref2.settingsPanelDisabled,
247
+ _ref2$spellCheck = _ref2.spellCheck,
248
+ spellCheck = _ref2$spellCheck === void 0 ? {} : _ref2$spellCheck,
249
+ _ref2$studentInstruct = _ref2.studentInstructions,
250
+ studentInstructions = _ref2$studentInstruct === void 0 ? {} : _ref2$studentInstruct,
251
+ _ref2$teacherInstruct = _ref2.teacherInstructions,
252
+ teacherInstructions = _ref2$teacherInstruct === void 0 ? {} : _ref2$teacherInstruct,
253
+ _ref2$withRubric = _ref2.withRubric,
254
+ withRubric = _ref2$withRubric === void 0 ? {} : _ref2$withRubric,
255
+ _ref2$mathMlOptions = _ref2.mathMlOptions,
256
+ mathMlOptions = _ref2$mathMlOptions === void 0 ? {} : _ref2$mathMlOptions,
257
+ _ref2$language = _ref2.language,
258
+ language = _ref2$language === void 0 ? {} : _ref2$language,
259
+ _ref2$languageChoices = _ref2.languageChoices,
260
+ languageChoices = _ref2$languageChoices === void 0 ? {} : _ref2$languageChoices;
261
+
262
+ var _ref3 = model || {},
263
+ allowAlternateEnabled = _ref3.allowAlternateEnabled,
264
+ allowMaxChoicesPerCategory = _ref3.allowMaxChoicesPerCategory,
265
+ feedbackEnabled = _ref3.feedbackEnabled,
266
+ maxChoicesPerCategory = _ref3.maxChoicesPerCategory,
267
+ promptEnabled = _ref3.promptEnabled,
268
+ rationaleEnabled = _ref3.rationaleEnabled,
269
+ spellCheckEnabled = _ref3.spellCheckEnabled,
270
+ teacherInstructionsEnabled = _ref3.teacherInstructionsEnabled,
271
+ toolbarEditorPosition = _ref3.toolbarEditorPosition;
272
+
273
+ var toolbarOpts = {
274
+ position: toolbarEditorPosition === 'top' ? 'top' : 'bottom'
275
+ };
276
+ var config = model.config || {};
277
+ config.choices = config.choices || {
278
+ label: '',
279
+ columns: 2
280
+ };
281
+ var categories = (0, _builder.buildCategories)(model.categories || [], model.choices || [], model.correctResponse || []);
282
+ var alternateResponses = (0, _builder.buildAlternateResponses)(model.categories || [], model.choices || [], model.correctResponse || []);
283
+ var choices = model.choices.map(function (c) {
284
+ c.correctResponseCount = _this2.countChoiceInCorrectResponse(c); // ensure categoryCount is set even though updatedModel hasn't been called
285
+
286
+ c.categoryCount = _this2.checkAllowMultiplePlacements(model.allowMultiplePlacementsEnabled, c);
287
+ return c;
288
+ });
289
+ var defaultImageMaxWidth = maxImageWidth && maxImageWidth.prompt;
290
+ var defaultImageMaxHeight = maxImageHeight && maxImageHeight.prompt;
291
+ var panelSettings = {
292
+ partialScoring: partialScoring.settings && toggle(partialScoring.label),
293
+ lockChoiceOrder: lockChoiceOrder.settings && toggle(lockChoiceOrder.label),
294
+ categoriesPerRow: categoriesPerRow.settings && numberField(categoriesPerRow.label, {
295
+ label: categoriesPerRow.label,
296
+ min: minCategoriesPerRow,
297
+ max: 6
298
+ }),
299
+ choicesPosition: choicesPosition.settings && radio(choicesPosition.label, ['below', 'above', 'left', 'right']),
300
+ allowMultiplePlacementsEnabled: allowMultiplePlacements.settings && dropdown(allowMultiplePlacements.label, [_utils.multiplePlacements.enabled, _utils.multiplePlacements.disabled, _utils.multiplePlacements.perChoice]),
301
+ allowMaxChoicesPerCategory: maxPlacements.settings && toggle(maxPlacements.label),
302
+ maxChoicesPerCategory: allowMaxChoicesPerCategory === true && numberField(maxPlacements.label, {
303
+ label: '',
304
+ min: 0,
305
+ max: 30
306
+ }),
307
+ promptEnabled: prompt.settings && toggle(prompt.label),
308
+ feedbackEnabled: feedback.settings && toggle(feedback.label),
309
+ // PD-2960: deleted temporary from settings panel
310
+ // allowAlternateEnabled: allowAlternate.settings && toggle(allowAlternate.label),
311
+ 'language.enabled': language.settings && toggle(language.label, true),
312
+ language: language.settings && language.enabled && dropdown(languageChoices.label, languageChoices.options)
313
+ };
314
+ var panelProperties = {
315
+ teacherInstructionsEnabled: teacherInstructions.settings && toggle(teacherInstructions.label),
316
+ studentInstructionsEnabled: studentInstructions.settings && toggle(studentInstructions.label),
317
+ rationaleEnabled: rationale.settings && toggle(rationale.label),
318
+ spellCheckEnabled: spellCheck.settings && toggle(spellCheck.label),
319
+ scoringType: scoringType.settings && radio(scoringType.label, ['auto', 'rubric']),
320
+ rubricEnabled: (withRubric === null || withRubric === void 0 ? void 0 : withRubric.settings) && toggle(withRubric === null || withRubric === void 0 ? void 0 : withRubric.label)
321
+ };
322
+ var isOpened = this.isAlertModalOpened();
323
+ var alertMaxChoicesMsg = translator.t('translation:categorize:maxChoicesPerCategoryRestriction', {
324
+ lng: model.language,
325
+ maxChoicesPerCategory: maxChoicesPerCategory
326
+ });
327
+ return /*#__PURE__*/_react["default"].createElement(IdProvider, {
328
+ value: this.uid
329
+ }, /*#__PURE__*/_react["default"].createElement(_configUi.layout.ConfigLayout, {
330
+ dimensions: contentDimensions,
331
+ hideSettings: settingsPanelDisabled,
332
+ settings: /*#__PURE__*/_react["default"].createElement(Panel, {
333
+ model: model,
334
+ onChangeModel: this.updateModel,
335
+ configuration: configuration,
336
+ onChangeConfiguration: onConfigurationChanged,
337
+ groups: {
338
+ Settings: panelSettings,
339
+ Properties: panelProperties
340
+ },
341
+ modal: /*#__PURE__*/_react["default"].createElement(_configUi.AlertDialog, {
342
+ title: 'Warning',
343
+ text: alertMaxChoicesMsg,
344
+ open: isOpened,
345
+ onClose: this.onAlertModalCancel
346
+ })
347
+ })
348
+ }, teacherInstructionsEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
349
+ label: teacherInstructions.label,
350
+ className: classes.inputContainer
351
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
352
+ className: classes.input,
353
+ markup: model.teacherInstructions || '',
354
+ onChange: this.changeTeacherInstructions,
355
+ imageSupport: imageSupport,
356
+ nonEmpty: false,
357
+ toolbarOpts: toolbarOpts,
358
+ spellCheck: spellCheckEnabled,
359
+ maxImageWidth: maxImageWidth && maxImageWidth.teacherInstructions || defaultImageMaxWidth,
360
+ maxImageHeight: maxImageHeight && maxImageHeight.teacherInstructions || defaultImageMaxHeight,
361
+ uploadSoundSupport: uploadSoundSupport,
362
+ languageCharactersProps: [{
363
+ language: 'spanish'
364
+ }, {
365
+ language: 'special'
366
+ }],
367
+ mathMlOptions: mathMlOptions
368
+ })), promptEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
369
+ label: prompt.label,
370
+ className: classes.inputContainer
371
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
372
+ className: classes.input,
373
+ markup: model.prompt || '',
374
+ onChange: this.onPromptChanged,
375
+ imageSupport: imageSupport,
376
+ nonEmpty: false,
377
+ disableUnderline: true,
378
+ toolbarOpts: toolbarOpts,
379
+ spellCheck: spellCheckEnabled,
380
+ maxImageWidth: maxImageWidth && maxImageWidth.prompt,
381
+ maxImageHeight: maxImageHeight && maxImageHeight.prompt,
382
+ uploadSoundSupport: uploadSoundSupport,
383
+ languageCharactersProps: [{
384
+ language: 'spanish'
385
+ }, {
386
+ language: 'special'
387
+ }],
388
+ mathMlOptions: mathMlOptions
389
+ })), /*#__PURE__*/_react["default"].createElement(_categories["default"], {
390
+ imageSupport: imageSupport,
391
+ uploadSoundSupport: uploadSoundSupport,
392
+ model: model,
393
+ categories: categories || [],
394
+ onModelChanged: this.updateModel,
395
+ toolbarOpts: toolbarOpts,
396
+ spellCheck: spellCheckEnabled,
397
+ configuration: configuration,
398
+ defaultImageMaxWidth: defaultImageMaxWidth,
399
+ defaultImageMaxHeight: defaultImageMaxHeight,
400
+ mathMlOptions: mathMlOptions
401
+ }), /*#__PURE__*/_react["default"].createElement(_choices["default"], {
402
+ imageSupport: imageSupport,
403
+ uploadSoundSupport: uploadSoundSupport,
404
+ choices: choices,
405
+ model: model,
406
+ onModelChanged: this.updateModel,
407
+ toolbarOpts: toolbarOpts,
408
+ spellCheck: spellCheckEnabled,
409
+ configuration: configuration,
410
+ defaultImageMaxWidth: defaultImageMaxWidth,
411
+ defaultImageMaxHeight: defaultImageMaxHeight
412
+ }), allowAlternateEnabled && /*#__PURE__*/_react["default"].createElement(_header["default"], {
413
+ className: classes.alternatesHeader,
414
+ label: "Alternate Responses",
415
+ buttonLabel: "ADD AN ALTERNATE RESPONSE",
416
+ onAdd: this.onAddAlternateResponse
417
+ }), allowAlternateEnabled && alternateResponses.map(function (categoriesList, index) {
418
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, {
419
+ key: index
420
+ }, /*#__PURE__*/_react["default"].createElement(_header["default"], {
421
+ className: classes.alternatesHeader,
422
+ variant: 'subtitle1',
423
+ label: "Alternate Response",
424
+ buttonLabel: "REMOVE ALTERNATE RESPONSE",
425
+ onAdd: function onAdd() {
426
+ return _this2.onRemoveAlternateResponse(index);
427
+ }
428
+ }), /*#__PURE__*/_react["default"].createElement(_alternateResponses["default"], {
429
+ altIndex: index,
430
+ imageSupport: imageSupport,
431
+ model: model,
432
+ configuration: configuration,
433
+ categories: categoriesList,
434
+ onModelChanged: _this2.updateModel,
435
+ uploadSoundSupport: uploadSoundSupport,
436
+ toolbarOpts: toolbarOpts,
437
+ defaultImageMaxWidth: defaultImageMaxWidth,
438
+ defaultImageMaxHeight: defaultImageMaxHeight,
439
+ mathMlOptions: mathMlOptions
440
+ }));
441
+ }), rationaleEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
442
+ label: rationale.label,
443
+ className: classes.inputContainer
444
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
445
+ className: classes.input,
446
+ markup: model.rationale || '',
447
+ onChange: this.changeRationale,
448
+ imageSupport: imageSupport,
449
+ nonEmpty: false,
450
+ toolbarOpts: toolbarOpts,
451
+ spellCheck: spellCheckEnabled,
452
+ maxImageWidth: maxImageWidth && maxImageWidth.rationale || defaultImageMaxWidth,
453
+ maxImageHeight: maxImageHeight && maxImageHeight.rationale || defaultImageMaxHeight,
454
+ uploadSoundSupport: uploadSoundSupport,
455
+ languageCharactersProps: [{
456
+ language: 'spanish'
457
+ }, {
458
+ language: 'special'
459
+ }],
460
+ mathMlOptions: mathMlOptions
461
+ })), feedbackEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.FeedbackConfig, {
462
+ feedback: model.feedback,
463
+ onChange: this.changeFeedback,
464
+ toolbarOpts: toolbarOpts
465
+ })));
466
+ }
467
+ }]);
468
+ return Design;
469
+ }(_react["default"].Component);
470
+
471
+ exports.Design = Design;
472
+ (0, _defineProperty2["default"])(Design, "propTypes", {
473
+ classes: _propTypes["default"].object.isRequired,
474
+ configuration: _propTypes["default"].object,
475
+ className: _propTypes["default"].string,
476
+ onConfigurationChanged: _propTypes["default"].func,
477
+ model: _propTypes["default"].object.isRequired,
478
+ onChange: _propTypes["default"].func.isRequired,
479
+ uid: _propTypes["default"].string,
480
+ imageSupport: _propTypes["default"].shape({
481
+ add: _propTypes["default"].func.isRequired,
482
+ "delete": _propTypes["default"].func.isRequired
483
+ }),
484
+ uploadSoundSupport: _propTypes["default"].shape({
485
+ add: _propTypes["default"].func.isRequired,
486
+ "delete": _propTypes["default"].func.isRequired
487
+ })
488
+ });
489
+
490
+ var styles = function styles(theme) {
491
+ return {
492
+ alternatesHeader: {
493
+ marginBottom: theme.spacing.unit * 2
494
+ },
495
+ text: {
496
+ paddingTop: theme.spacing.unit * 2,
497
+ paddingBottom: theme.spacing.unit * 2
498
+ },
499
+ inputContainer: {
500
+ width: '100%',
501
+ paddingTop: theme.spacing.unit * 2,
502
+ marginBottom: theme.spacing.unit * 2
503
+ },
504
+ title: {
505
+ marginBottom: theme.spacing.unit * 4
506
+ }
507
+ };
508
+ };
509
+
510
+ var _default = (0, _drag.withDragContext)((0, _styles.withStyles)(styles)(Design));
511
+
512
+ exports["default"] = _default;
513
+ //# 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","allowAlternate","categoriesPerRow","choicesPosition","contentDimensions","lockChoiceOrder","maxImageHeight","maxImageWidth","maxPlacements","minCategoriesPerRow","partialScoring","scoringType","settingsPanelDisabled","spellCheck","studentInstructions","withRubric","mathMlOptions","language","languageChoices","allowAlternateEnabled","feedbackEnabled","promptEnabled","rationaleEnabled","spellCheckEnabled","teacherInstructionsEnabled","toolbarEditorPosition","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","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"],"mappings":"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","sourcesContent":["import 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 { countInAnswer, ensureNoExtraChoicesInAnswer, ensureNoExtraChoicesInAlternate } 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 ? updatedModel.maxChoicesPerCategory : 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\n render() {\n const { classes, configuration, imageSupport, model, uploadSoundSupport, onConfigurationChanged } = this.props;\n const {\n allowMultiplePlacements = {},\n allowAlternate = {},\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 feedbackEnabled,\n maxChoicesPerCategory,\n promptEnabled,\n rationaleEnabled,\n spellCheckEnabled,\n teacherInstructionsEnabled,\n toolbarEditorPosition,\n } = model || {};\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', {lng: model.language, maxChoicesPerCategory });\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={<AlertDialog\n title={'Warning'}\n text={alertMaxChoicesMsg}\n open={isOpened}\n onClose={this.onAlertModalCancel}\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 nonEmpty={false}\n toolbarOpts={toolbarOpts}\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 </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 nonEmpty={false}\n disableUnderline\n toolbarOpts={toolbarOpts}\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 </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 nonEmpty={false}\n toolbarOpts={toolbarOpts}\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 </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});\n\nexport default withDragContext(withStyles(styles)(Design));\n"],"file":"index.js"}