@pie-element/multiple-choice 11.1.0 → 11.2.0-mui-update.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 (46) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/configure/CHANGELOG.md +11 -0
  3. package/configure/lib/__tests__/root.test.js +248 -0
  4. package/configure/lib/defaults.js +3 -5
  5. package/configure/lib/defaults.js.map +1 -1
  6. package/configure/lib/index.js +128 -204
  7. package/configure/lib/index.js.map +1 -1
  8. package/configure/lib/main.js +325 -445
  9. package/configure/lib/main.js.map +1 -1
  10. package/configure/lib/utils.js +9 -9
  11. package/configure/lib/utils.js.map +1 -1
  12. package/configure/package.json +10 -8
  13. package/controller/CHANGELOG.md +11 -0
  14. package/controller/lib/__tests__/index.test.js +520 -0
  15. package/controller/lib/__tests__/utils.test.js +8 -0
  16. package/controller/lib/defaults.js +3 -4
  17. package/controller/lib/defaults.js.map +1 -1
  18. package/controller/lib/index.js +145 -240
  19. package/controller/lib/index.js.map +1 -1
  20. package/controller/lib/utils.js +5 -17
  21. package/controller/lib/utils.js.map +1 -1
  22. package/controller/package.json +2 -2
  23. package/docs/demo/pie.manifest.json +11 -0
  24. package/lib/__tests__/choice-input-test.js +117 -0
  25. package/lib/__tests__/index-test.js +151 -0
  26. package/lib/__tests__/key-events-test.js +95 -0
  27. package/lib/__tests__/multiple-choice-test.js +223 -0
  28. package/lib/__tests__/session-updater-test.js +70 -0
  29. package/lib/choice-input.js +312 -369
  30. package/lib/choice-input.js.map +1 -1
  31. package/lib/choice.js +164 -219
  32. package/lib/choice.js.map +1 -1
  33. package/lib/feedback-tick.js +71 -115
  34. package/lib/feedback-tick.js.map +1 -1
  35. package/lib/index.js +233 -329
  36. package/lib/index.js.map +1 -1
  37. package/lib/main.js +36 -90
  38. package/lib/main.js.map +1 -1
  39. package/lib/multiple-choice.js +305 -388
  40. package/lib/multiple-choice.js.map +1 -1
  41. package/lib/print.js +41 -78
  42. package/lib/print.js.map +1 -1
  43. package/lib/session-updater.js +5 -16
  44. package/lib/session-updater.js.map +1 -1
  45. package/package.json +13 -10
  46. package/LICENSE.md +0 -5
@@ -1,238 +1,184 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports["default"] = exports.Main = void 0;
9
-
7
+ exports.default = exports.Main = void 0;
10
8
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
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
9
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
-
26
10
  var _react = _interopRequireDefault(require("react"));
27
-
28
11
  var _propTypes = _interopRequireDefault(require("prop-types"));
29
-
12
+ var _styles = require("@mui/material/styles");
30
13
  var _editableHtml = _interopRequireDefault(require("@pie-lib/editable-html"));
31
-
32
14
  var _configUi = require("@pie-lib/config-ui");
33
-
34
15
  var _renderUi = require("@pie-lib/render-ui");
35
-
36
- var _styles = require("@material-ui/core/styles");
37
-
38
- var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
39
-
40
- var _Tooltip = _interopRequireDefault(require("@material-ui/core/Tooltip"));
41
-
42
- var _Typography = _interopRequireDefault(require("@material-ui/core/Typography"));
43
-
44
- var _Info = _interopRequireDefault(require("@material-ui/icons/Info"));
45
-
16
+ var _Button = _interopRequireDefault(require("@mui/material/Button"));
17
+ var _Tooltip = _interopRequireDefault(require("@mui/material/Tooltip"));
18
+ var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
19
+ var _Box = _interopRequireDefault(require("@mui/material/Box"));
20
+ var _Info = _interopRequireDefault(require("@mui/icons-material/Info"));
46
21
  var _merge = _interopRequireDefault(require("lodash/merge"));
47
-
48
22
  var _utils = require("./utils");
49
-
50
- 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); }; }
51
-
52
- 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; } }
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
- var Panel = _configUi.settings.Panel,
59
- toggle = _configUi.settings.toggle,
60
- radio = _configUi.settings.radio,
61
- dropdown = _configUi.settings.dropdown;
62
- var MAX_CHOICES = 9;
63
-
64
- var styles = function styles(theme) {
65
- return {
66
- promptHolder: {
67
- width: '100%',
68
- paddingTop: theme.spacing.unit * 2,
69
- marginBottom: theme.spacing.unit * 2
70
- },
71
- rationaleHolder: {
72
- flex: 1,
73
- marginTop: theme.spacing.unit * 1.5,
74
- paddingTop: theme.spacing.unit * 2,
75
- marginLeft: theme.spacing.unit * 3.5
76
- },
77
- choiceConfigurationHolder: {
78
- display: 'flex',
79
- flexDirection: 'column',
80
- marginBottom: theme.spacing.unit
81
- },
82
- choiceConfiguration: {
83
- width: '100%'
84
- },
85
- switchElement: {
86
- justifyContent: 'space-between',
87
- margin: 0
88
- },
89
- addButton: {
90
- marginTop: theme.spacing.unit,
91
- "float": 'right'
92
- },
93
- disableButton: {
94
- cursor: 'not-allowed',
95
- pointerEvents: 'all',
96
- backgroundColor: _renderUi.color.disabled(),
97
- '&:hover': {
98
- backgroundColor: _renderUi.color.disabled()
99
- },
100
- '&:focus': {
101
- backgroundColor: _renderUi.color.disabled()
102
- }
103
- },
104
- flexContainer: {
105
- display: 'flex',
106
- alignItems: 'center'
107
- },
108
- titleText: {
109
- fontSize: theme.typography.fontSize + 2,
110
- marginRight: theme.spacing.unit
111
- },
112
- tooltip: {
113
- fontSize: theme.typography.fontSize - 2,
114
- whiteSpace: 'pre',
115
- maxWidth: '500px'
116
- },
117
- errorText: {
118
- fontSize: theme.typography.fontSize - 2,
119
- color: theme.palette.error.main,
120
- paddingTop: theme.spacing.unit
121
- }
122
- };
123
- };
124
-
125
- var Design = (0, _styles.withStyles)(styles)(function (props) {
126
- var _configuration$teache, _configuration$prompt;
127
-
128
- var classes = props.classes,
129
- model = props.model,
130
- configuration = props.configuration,
131
- onPromptChanged = props.onPromptChanged,
132
- onChoiceChanged = props.onChoiceChanged,
133
- onRemoveChoice = props.onRemoveChoice,
134
- onAddChoice = props.onAddChoice,
135
- imageSupport = props.imageSupport,
136
- uploadSoundSupport = props.uploadSoundSupport,
137
- onChangeModel = props.onChangeModel,
138
- onConfigurationChanged = props.onConfigurationChanged,
139
- onTeacherInstructionsChanged = props.onTeacherInstructionsChanged;
140
-
141
- var _ref = configuration || {},
142
- _ref$addChoiceButton = _ref.addChoiceButton,
143
- addChoiceButton = _ref$addChoiceButton === void 0 ? {} : _ref$addChoiceButton,
144
- _ref$contentDimension = _ref.contentDimensions,
145
- contentDimensions = _ref$contentDimension === void 0 ? {} : _ref$contentDimension,
146
- _ref$feedback = _ref.feedback,
147
- feedback = _ref$feedback === void 0 ? {} : _ref$feedback,
148
- _ref$deleteChoice = _ref.deleteChoice,
149
- deleteChoice = _ref$deleteChoice === void 0 ? {} : _ref$deleteChoice,
150
- _ref$choiceMode = _ref.choiceMode,
151
- choiceMode = _ref$choiceMode === void 0 ? {} : _ref$choiceMode,
152
- _ref$choicePrefix = _ref.choicePrefix,
153
- choicePrefix = _ref$choicePrefix === void 0 ? {} : _ref$choicePrefix,
154
- _ref$partialScoring = _ref.partialScoring,
155
- partialScoring = _ref$partialScoring === void 0 ? {} : _ref$partialScoring,
156
- _ref$lockChoiceOrder = _ref.lockChoiceOrder,
157
- lockChoiceOrder = _ref$lockChoiceOrder === void 0 ? {} : _ref$lockChoiceOrder,
158
- _ref$teacherInstructi = _ref.teacherInstructions,
159
- teacherInstructions = _ref$teacherInstructi === void 0 ? {} : _ref$teacherInstructi,
160
- _ref$studentInstructi = _ref.studentInstructions,
161
- studentInstructions = _ref$studentInstructi === void 0 ? {} : _ref$studentInstructi,
162
- _ref$rationale = _ref.rationale,
163
- rationale = _ref$rationale === void 0 ? {} : _ref$rationale,
164
- _ref$scoringType = _ref.scoringType,
165
- scoringType = _ref$scoringType === void 0 ? {} : _ref$scoringType,
166
- _ref$sequentialChoice = _ref.sequentialChoiceLabels,
167
- sequentialChoiceLabels = _ref$sequentialChoice === void 0 ? {} : _ref$sequentialChoice,
168
- settingsPanelDisabled = _ref.settingsPanelDisabled,
169
- choicesLayout = _ref.choicesLayout,
170
- _ref$spellCheck = _ref.spellCheck,
171
- spellCheck = _ref$spellCheck === void 0 ? {} : _ref$spellCheck,
172
- gridColumns = _ref.gridColumns,
173
- _ref$maxImageWidth = _ref.maxImageWidth,
174
- maxImageWidth = _ref$maxImageWidth === void 0 ? {} : _ref$maxImageWidth,
175
- _ref$maxImageHeight = _ref.maxImageHeight,
176
- maxImageHeight = _ref$maxImageHeight === void 0 ? {} : _ref$maxImageHeight,
177
- _ref$prompt = _ref.prompt,
178
- prompt = _ref$prompt === void 0 ? {} : _ref$prompt,
179
- _ref$withRubric = _ref.withRubric,
180
- withRubric = _ref$withRubric === void 0 ? {} : _ref$withRubric,
181
- _ref$mathMlOptions = _ref.mathMlOptions,
182
- mathMlOptions = _ref$mathMlOptions === void 0 ? {} : _ref$mathMlOptions,
183
- _ref$language = _ref.language,
184
- language = _ref$language === void 0 ? {} : _ref$language,
185
- _ref$languageChoices = _ref.languageChoices,
186
- languageChoices = _ref$languageChoices === void 0 ? {} : _ref$languageChoices;
187
-
188
- var _ref2 = configuration || {},
189
- maxAnswerChoices = _ref2.maxAnswerChoices;
190
-
191
- var _ref3 = model || {},
192
- limitChoicesNumber = _ref3.limitChoicesNumber,
193
- teacherInstructionsEnabled = _ref3.teacherInstructionsEnabled,
194
- rationaleEnabled = _ref3.rationaleEnabled,
195
- feedbackEnabled = _ref3.feedbackEnabled,
196
- promptEnabled = _ref3.promptEnabled,
197
- spellCheckEnabled = _ref3.spellCheckEnabled,
198
- choices = _ref3.choices,
199
- errors = _ref3.errors,
200
- toolbarEditorPosition = _ref3.toolbarEditorPosition,
201
- extraCSSRules = _ref3.extraCSSRules;
202
-
203
- var _ref4 = errors || {},
204
- answerChoicesError = _ref4.answerChoices,
205
- choicesErrors = _ref4.choices,
206
- correctResponseError = _ref4.correctResponse,
207
- promptError = _ref4.prompt,
208
- rationaleErrors = _ref4.rationale,
209
- teacherInstructionsError = _ref4.teacherInstructions;
210
-
211
- var nrOfColumnsAvailable = choices !== null && choices !== void 0 && choices.length ? Array.from({
23
+ const {
24
+ Panel,
25
+ toggle,
26
+ radio,
27
+ dropdown
28
+ } = _configUi.settings;
29
+ const MAX_CHOICES = 9;
30
+ const PromptHolder = (0, _styles.styled)(_configUi.InputContainer)(({
31
+ theme
32
+ }) => ({
33
+ width: '100%',
34
+ paddingTop: theme.spacing(2),
35
+ marginBottom: theme.spacing(2)
36
+ }));
37
+ const RationaleHolder = (0, _styles.styled)(_configUi.InputContainer)(({
38
+ theme
39
+ }) => ({
40
+ flex: 1,
41
+ marginTop: theme.spacing(1.5),
42
+ paddingTop: theme.spacing(2),
43
+ marginLeft: theme.spacing(3.5)
44
+ }));
45
+ const ChoiceConfigurationHolder = (0, _styles.styled)(_configUi.InputContainer)(({
46
+ theme
47
+ }) => ({
48
+ display: 'flex',
49
+ flexDirection: 'column',
50
+ marginBottom: theme.spacing(1),
51
+ width: '100%'
52
+ }));
53
+ const AddButton = (0, _styles.styled)(_Button.default)(({
54
+ theme
55
+ }) => ({
56
+ marginTop: theme.spacing(1),
57
+ float: 'right'
58
+ }));
59
+ const DisableButton = (0, _styles.styled)(AddButton)({
60
+ cursor: 'not-allowed',
61
+ pointerEvents: 'all',
62
+ backgroundColor: _renderUi.color.disabled(),
63
+ '&:hover': {
64
+ backgroundColor: _renderUi.color.disabled()
65
+ },
66
+ '&:focus': {
67
+ backgroundColor: _renderUi.color.disabled()
68
+ }
69
+ });
70
+ const FlexContainer = (0, _styles.styled)(_Box.default)({
71
+ display: 'flex',
72
+ alignItems: 'center'
73
+ });
74
+ const TitleText = (0, _styles.styled)(_Typography.default)(({
75
+ theme
76
+ }) => ({
77
+ fontSize: theme.typography.fontSize + 2,
78
+ marginRight: theme.spacing(1)
79
+ }));
80
+ const StyledTooltip = (0, _styles.styled)(_Tooltip.default)(({
81
+ theme
82
+ }) => ({
83
+ '& .MuiTooltip-tooltip': {
84
+ fontSize: theme.typography.fontSize - 2,
85
+ whiteSpace: 'pre',
86
+ maxWidth: '500px'
87
+ }
88
+ }));
89
+ const ErrorText = (0, _styles.styled)('div')(({
90
+ theme
91
+ }) => ({
92
+ fontSize: theme.typography.fontSize - 2,
93
+ color: theme.palette.error.main,
94
+ paddingTop: theme.spacing(1)
95
+ }));
96
+ const Design = props => {
97
+ const {
98
+ model,
99
+ configuration,
100
+ onPromptChanged,
101
+ onChoiceChanged,
102
+ onRemoveChoice,
103
+ onAddChoice,
104
+ imageSupport,
105
+ uploadSoundSupport,
106
+ onChangeModel,
107
+ onConfigurationChanged,
108
+ onTeacherInstructionsChanged
109
+ } = props;
110
+ const {
111
+ addChoiceButton = {},
112
+ contentDimensions = {},
113
+ feedback = {},
114
+ deleteChoice = {},
115
+ choiceMode = {},
116
+ choicePrefix = {},
117
+ partialScoring = {},
118
+ lockChoiceOrder = {},
119
+ teacherInstructions = {},
120
+ studentInstructions = {},
121
+ rationale = {},
122
+ scoringType = {},
123
+ sequentialChoiceLabels = {},
124
+ settingsPanelDisabled,
125
+ choicesLayout,
126
+ spellCheck = {},
127
+ gridColumns,
128
+ maxImageWidth = {},
129
+ maxImageHeight = {},
130
+ prompt = {},
131
+ withRubric = {},
132
+ mathMlOptions = {},
133
+ language = {},
134
+ languageChoices = {}
135
+ } = configuration || {};
136
+ let {
137
+ maxAnswerChoices
138
+ } = configuration || {};
139
+ const {
140
+ limitChoicesNumber,
141
+ teacherInstructionsEnabled,
142
+ rationaleEnabled,
143
+ feedbackEnabled,
144
+ promptEnabled,
145
+ spellCheckEnabled,
146
+ choices,
147
+ errors,
148
+ toolbarEditorPosition,
149
+ extraCSSRules
150
+ } = model || {};
151
+ const {
152
+ answerChoices: answerChoicesError,
153
+ choices: choicesErrors,
154
+ correctResponse: correctResponseError,
155
+ prompt: promptError,
156
+ rationale: rationaleErrors,
157
+ teacherInstructions: teacherInstructionsError
158
+ } = errors || {};
159
+ const nrOfColumnsAvailable = choices?.length ? Array.from({
212
160
  length: choices.length
213
- }, function (_, i) {
214
- return "".concat(i + 1);
215
- }) : [];
216
- var _configuration$baseIn = configuration.baseInputConfiguration,
217
- baseInputConfiguration = _configuration$baseIn === void 0 ? {} : _configuration$baseIn;
218
- var toolbarOpts = {
161
+ }, (_, i) => `${i + 1}`) : [];
162
+ const {
163
+ baseInputConfiguration = {}
164
+ } = configuration;
165
+ const toolbarOpts = {
219
166
  position: toolbarEditorPosition === 'top' ? 'top' : 'bottom'
220
- }; // if old property is used, set maxAnswerChoices to 9
167
+ };
221
168
 
169
+ // if old property is used, set maxAnswerChoices to 9
222
170
  if (limitChoicesNumber) {
223
171
  maxAnswerChoices = MAX_CHOICES;
224
172
  }
225
-
226
- var getPluginProps = function getPluginProps() {
227
- var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
228
- return _objectSpread(_objectSpread({}, baseInputConfiguration), props);
229
- };
230
-
231
- var validationMessage = (0, _utils.generateValidationMessage)(configuration);
232
- var defaultImageMaxWidth = maxImageWidth && maxImageWidth.prompt;
233
- var defaultImageMaxHeight = maxImageHeight && maxImageHeight.prompt;
234
- var addChoiceButtonTooltip = maxAnswerChoices && (choices === null || choices === void 0 ? void 0 : choices.length) >= maxAnswerChoices ? "Only ".concat(maxAnswerChoices, " allowed maximum") : '';
235
- var panelSettings = {
173
+ const getPluginProps = (props = {}) => ({
174
+ ...baseInputConfiguration,
175
+ ...props
176
+ });
177
+ const validationMessage = (0, _utils.generateValidationMessage)(configuration);
178
+ const defaultImageMaxWidth = maxImageWidth && maxImageWidth.prompt;
179
+ const defaultImageMaxHeight = maxImageHeight && maxImageHeight.prompt;
180
+ const addChoiceButtonTooltip = maxAnswerChoices && choices?.length >= maxAnswerChoices ? `Only ${maxAnswerChoices} allowed maximum` : '';
181
+ const panelSettings = {
236
182
  choiceMode: choiceMode.settings && radio(choiceMode.label, ['checkbox', 'radio']),
237
183
  'sequentialChoiceLabels.enabled': sequentialChoiceLabels.settings && toggle(sequentialChoiceLabels.label, true),
238
184
  choicePrefix: choicePrefix.settings && radio(choicePrefix.label, ['numbers', 'letters']),
@@ -244,20 +190,21 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
244
190
  'language.enabled': language.settings && toggle(language.label, true),
245
191
  language: language.settings && language.enabled && dropdown(languageChoices.label, languageChoices.options)
246
192
  };
247
- var panelProperties = {
193
+ const panelProperties = {
248
194
  teacherInstructionsEnabled: teacherInstructions.settings && toggle(teacherInstructions.label),
249
195
  studentInstructionsEnabled: studentInstructions.settings && toggle(studentInstructions.label),
250
196
  promptEnabled: prompt.settings && toggle(prompt.label),
251
197
  rationaleEnabled: rationale.settings && toggle(rationale.label),
252
198
  spellCheckEnabled: spellCheck.settings && toggle(spellCheck.label),
253
199
  scoringType: scoringType.settings && radio(scoringType.label, ['auto', 'rubric']),
254
- rubricEnabled: (withRubric === null || withRubric === void 0 ? void 0 : withRubric.settings) && toggle(withRubric === null || withRubric === void 0 ? void 0 : withRubric.label)
200
+ rubricEnabled: withRubric?.settings && toggle(withRubric?.label)
255
201
  };
256
- return /*#__PURE__*/_react["default"].createElement(_configUi.layout.ConfigLayout, {
202
+ return /*#__PURE__*/_react.default.createElement(_configUi.layout.ConfigLayout, {
257
203
  dimensions: contentDimensions,
258
204
  hideSettings: settingsPanelDisabled,
259
205
  extraCSSRules: extraCSSRules,
260
- settings: /*#__PURE__*/_react["default"].createElement(Panel, {
206
+ classes: {},
207
+ settings: /*#__PURE__*/_react.default.createElement(Panel, {
261
208
  model: model,
262
209
  onChangeModel: onChangeModel,
263
210
  configuration: configuration,
@@ -267,18 +214,17 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
267
214
  Properties: panelProperties
268
215
  }
269
216
  })
270
- }, teacherInstructionsEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
271
- label: teacherInstructions.label,
272
- className: classes.promptHolder
273
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
274
- className: classes.prompt,
217
+ }, teacherInstructionsEnabled && /*#__PURE__*/_react.default.createElement(PromptHolder, {
218
+ label: teacherInstructions.label
219
+ }, /*#__PURE__*/_react.default.createElement(_editableHtml.default, {
275
220
  markup: model.teacherInstructions || '',
276
221
  onChange: onTeacherInstructionsChanged,
277
222
  imageSupport: imageSupport,
278
223
  nonEmpty: false,
224
+ disableUnderline: true,
279
225
  error: teacherInstructionsError,
280
226
  toolbarOpts: toolbarOpts,
281
- pluginProps: getPluginProps(configuration === null || configuration === void 0 ? void 0 : (_configuration$teache = configuration.teacherInstructions) === null || _configuration$teache === void 0 ? void 0 : _configuration$teache.inputConfiguration),
227
+ pluginProps: getPluginProps(configuration?.teacherInstructions?.inputConfiguration),
282
228
  spellCheck: spellCheckEnabled,
283
229
  maxImageWidth: maxImageWidth && maxImageWidth.teacherInstructions || defaultImageMaxWidth,
284
230
  maxImageHeight: maxImageHeight && maxImageHeight.teacherInstructions || defaultImageMaxHeight,
@@ -289,13 +235,9 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
289
235
  language: 'special'
290
236
  }],
291
237
  mathMlOptions: mathMlOptions
292
- }), teacherInstructionsError && /*#__PURE__*/_react["default"].createElement("div", {
293
- className: classes.errorText
294
- }, teacherInstructionsError)), promptEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
295
- label: prompt.label,
296
- className: classes.promptHolder
297
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
298
- className: classes.prompt,
238
+ }), teacherInstructionsError && /*#__PURE__*/_react.default.createElement(ErrorText, null, teacherInstructionsError)), promptEnabled && /*#__PURE__*/_react.default.createElement(PromptHolder, {
239
+ label: prompt.label
240
+ }, /*#__PURE__*/_react.default.createElement(_editableHtml.default, {
299
241
  markup: model.prompt,
300
242
  onChange: onPromptChanged,
301
243
  imageSupport: imageSupport,
@@ -303,7 +245,7 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
303
245
  disableUnderline: true,
304
246
  error: promptError,
305
247
  toolbarOpts: toolbarOpts,
306
- pluginProps: getPluginProps(configuration === null || configuration === void 0 ? void 0 : (_configuration$prompt = configuration.prompt) === null || _configuration$prompt === void 0 ? void 0 : _configuration$prompt.inputConfiguration),
248
+ pluginProps: getPluginProps(configuration?.prompt?.inputConfiguration),
307
249
  spellCheck: spellCheckEnabled,
308
250
  maxImageWidth: maxImageWidth && maxImageWidth.prompt,
309
251
  maxImageHeight: maxImageHeight && maxImageHeight.prompt,
@@ -314,284 +256,222 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
314
256
  language: 'special'
315
257
  }],
316
258
  mathMlOptions: mathMlOptions
317
- }), promptError && /*#__PURE__*/_react["default"].createElement("div", {
318
- className: classes.errorText
319
- }, promptError)), /*#__PURE__*/_react["default"].createElement("div", {
320
- className: classes.flexContainer
321
- }, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
322
- className: classes.titleText,
259
+ }), promptError && /*#__PURE__*/_react.default.createElement(ErrorText, null, promptError)), /*#__PURE__*/_react.default.createElement(FlexContainer, null, /*#__PURE__*/_react.default.createElement(TitleText, {
323
260
  component: 'div'
324
- }, "Choices"), /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
325
- classes: {
326
- tooltip: classes.tooltip
327
- },
261
+ }, "Choices"), /*#__PURE__*/_react.default.createElement(StyledTooltip, {
328
262
  disableFocusListener: true,
329
263
  disableTouchListener: true,
330
264
  placement: 'right',
331
265
  title: validationMessage
332
- }, /*#__PURE__*/_react["default"].createElement(_Info["default"], {
266
+ }, /*#__PURE__*/_react.default.createElement(_Info.default, {
333
267
  fontSize: 'small',
334
268
  color: 'primary'
335
- }))), choices.map(function (choice, index) {
336
- var _configuration$choice, _configuration$ration;
337
-
338
- return /*#__PURE__*/_react["default"].createElement("div", {
339
- key: "choice-".concat(index),
340
- className: classes.choiceConfigurationHolder
341
- }, /*#__PURE__*/_react["default"].createElement(_configUi.ChoiceConfiguration, {
342
- key: index,
343
- index: index + 1,
344
- useLetterOrdering: model.choicePrefix === 'letters',
345
- className: classes.choiceConfiguration,
346
- mode: model.choiceMode,
347
- data: choice,
348
- defaultFeedback: {},
349
- imageSupport: imageSupport,
350
- disableImageAlignmentButtons: true,
351
- onDelete: function onDelete() {
352
- return onRemoveChoice(index);
353
- },
354
- onChange: function onChange(c) {
355
- return onChoiceChanged(index, c);
356
- },
357
- allowFeedBack: feedbackEnabled,
358
- allowDelete: deleteChoice.settings,
359
- noLabels: true,
360
- pluginOpts: getPluginProps(configuration === null || configuration === void 0 ? void 0 : (_configuration$choice = configuration.choices) === null || _configuration$choice === void 0 ? void 0 : _configuration$choice.inputConfiguration),
361
- toolbarOpts: toolbarOpts,
362
- spellCheck: spellCheckEnabled,
363
- error: (choicesErrors === null || choicesErrors === void 0 ? void 0 : choicesErrors[choice.value]) || null,
364
- noCorrectAnswerError: correctResponseError,
365
- maxImageWidth: maxImageWidth && maxImageWidth.choices || defaultImageMaxWidth,
366
- maxImageHeight: maxImageHeight && maxImageHeight.choices || defaultImageMaxHeight,
367
- uploadSoundSupport: uploadSoundSupport,
368
- mathMlOptions: mathMlOptions
369
- }), rationaleEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
370
- key: "rationale-".concat(index),
371
- label: rationale.label,
372
- className: classes.rationaleHolder
373
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
374
- className: classes.rationale,
375
- markup: choice.rationale || '',
376
- onChange: function onChange(c) {
377
- return onChoiceChanged(index, _objectSpread(_objectSpread({}, choice), {}, {
378
- rationale: c
379
- }));
380
- },
381
- imageSupport: imageSupport,
382
- error: (rationaleErrors === null || rationaleErrors === void 0 ? void 0 : rationaleErrors[choice.value]) || null,
383
- toolbarOpts: toolbarOpts,
384
- pluginProps: getPluginProps(configuration === null || configuration === void 0 ? void 0 : (_configuration$ration = configuration.rationale) === null || _configuration$ration === void 0 ? void 0 : _configuration$ration.inputConfiguration),
385
- spellCheck: spellCheckEnabled,
386
- maxImageWidth: maxImageWidth && maxImageWidth.rationale || defaultImageMaxWidth,
387
- maxImageHeight: maxImageHeight && maxImageHeight.rationale || defaultImageMaxHeight,
388
- uploadSoundSupport: uploadSoundSupport,
389
- languageCharactersProps: [{
390
- language: 'spanish'
391
- }, {
392
- language: 'special'
393
- }],
394
- mathMlOptions: mathMlOptions
395
- }), (rationaleErrors === null || rationaleErrors === void 0 ? void 0 : rationaleErrors[choice.value]) && /*#__PURE__*/_react["default"].createElement("div", {
396
- className: classes.errorText
397
- }, rationaleErrors === null || rationaleErrors === void 0 ? void 0 : rationaleErrors[choice.value])));
398
- }), correctResponseError && /*#__PURE__*/_react["default"].createElement("div", {
399
- className: classes.errorText
400
- }, correctResponseError), answerChoicesError && /*#__PURE__*/_react["default"].createElement("div", {
401
- className: classes.errorText
402
- }, answerChoicesError), addChoiceButton.settings && /*#__PURE__*/_react["default"].createElement(_Tooltip["default"], {
403
- title: addChoiceButtonTooltip,
404
- classes: {
405
- tooltip: classes.tooltip
406
- }
407
- }, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
408
- classes: {
409
- root: maxAnswerChoices && (choices === null || choices === void 0 ? void 0 : choices.length) >= maxAnswerChoices && classes.disableButton
410
- },
411
- className: classes.addButton,
269
+ }))), choices.map((choice, index) => /*#__PURE__*/_react.default.createElement(ChoiceConfigurationHolder, {
270
+ key: `choice-${index}`
271
+ }, /*#__PURE__*/_react.default.createElement(_configUi.ChoiceConfiguration, {
272
+ key: index,
273
+ index: index + 1,
274
+ useLetterOrdering: model.choicePrefix === 'letters',
275
+ mode: model.choiceMode,
276
+ data: choice,
277
+ defaultFeedback: {},
278
+ imageSupport: imageSupport,
279
+ disableImageAlignmentButtons: true,
280
+ onDelete: () => onRemoveChoice(index),
281
+ onChange: c => onChoiceChanged(index, c),
282
+ allowFeedBack: feedbackEnabled,
283
+ allowDelete: deleteChoice.settings,
284
+ noLabels: true,
285
+ pluginOpts: getPluginProps(configuration?.choices?.inputConfiguration),
286
+ toolbarOpts: toolbarOpts,
287
+ spellCheck: spellCheckEnabled,
288
+ error: choicesErrors?.[choice.value] || null,
289
+ noCorrectAnswerError: correctResponseError,
290
+ maxImageWidth: maxImageWidth && maxImageWidth.choices || defaultImageMaxWidth,
291
+ maxImageHeight: maxImageHeight && maxImageHeight.choices || defaultImageMaxHeight,
292
+ uploadSoundSupport: uploadSoundSupport,
293
+ mathMlOptions: mathMlOptions
294
+ }), rationaleEnabled && /*#__PURE__*/_react.default.createElement(RationaleHolder, {
295
+ key: `rationale-${index}`,
296
+ label: rationale.label
297
+ }, /*#__PURE__*/_react.default.createElement(_editableHtml.default, {
298
+ markup: choice.rationale || '',
299
+ onChange: c => onChoiceChanged(index, {
300
+ ...choice,
301
+ rationale: c
302
+ }),
303
+ imageSupport: imageSupport,
304
+ error: rationaleErrors?.[choice.value] || null,
305
+ toolbarOpts: toolbarOpts,
306
+ pluginProps: getPluginProps(configuration?.rationale?.inputConfiguration),
307
+ spellCheck: spellCheckEnabled,
308
+ maxImageWidth: maxImageWidth && maxImageWidth.rationale || defaultImageMaxWidth,
309
+ maxImageHeight: maxImageHeight && maxImageHeight.rationale || defaultImageMaxHeight,
310
+ uploadSoundSupport: uploadSoundSupport,
311
+ languageCharactersProps: [{
312
+ language: 'spanish'
313
+ }, {
314
+ language: 'special'
315
+ }],
316
+ mathMlOptions: mathMlOptions
317
+ }), rationaleErrors?.[choice.value] && /*#__PURE__*/_react.default.createElement(ErrorText, null, rationaleErrors?.[choice.value])))), correctResponseError && /*#__PURE__*/_react.default.createElement(ErrorText, null, correctResponseError), answerChoicesError && /*#__PURE__*/_react.default.createElement(ErrorText, null, answerChoicesError), addChoiceButton.settings && /*#__PURE__*/_react.default.createElement(StyledTooltip, {
318
+ title: addChoiceButtonTooltip
319
+ }, maxAnswerChoices && choices?.length >= maxAnswerChoices ? /*#__PURE__*/_react.default.createElement(DisableButton, {
320
+ variant: "contained",
321
+ color: "primary",
322
+ onClick: onAddChoice,
323
+ disabled: true
324
+ }, addChoiceButton.label) : /*#__PURE__*/_react.default.createElement(AddButton, {
412
325
  variant: "contained",
413
326
  color: "primary",
414
327
  onClick: onAddChoice
415
328
  }, addChoiceButton.label)));
416
- });
417
-
418
- var Main = /*#__PURE__*/function (_React$Component) {
419
- (0, _inherits2["default"])(Main, _React$Component);
420
-
421
- var _super = _createSuper(Main);
422
-
423
- function Main() {
424
- var _this;
425
-
426
- (0, _classCallCheck2["default"])(this, Main);
427
-
428
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
429
- args[_key] = arguments[_key];
430
- }
431
-
432
- _this = _super.call.apply(_super, [this].concat(args));
433
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
329
+ };
330
+ class Main extends _react.default.Component {
331
+ constructor(...args) {
332
+ super(...args);
333
+ (0, _defineProperty2.default)(this, "state", {
434
334
  showWarning: false
435
335
  });
436
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onRemoveChoice", function (index) {
437
- var _this$props = _this.props,
438
- model = _this$props.model,
439
- configuration = _this$props.configuration,
440
- onModelChanged = _this$props.onModelChanged;
441
-
442
- var _ref5 = configuration || {},
443
- minAnswerChoices = _ref5.minAnswerChoices;
444
-
336
+ (0, _defineProperty2.default)(this, "onRemoveChoice", index => {
337
+ const {
338
+ model,
339
+ configuration,
340
+ onModelChanged
341
+ } = this.props;
342
+ const {
343
+ minAnswerChoices
344
+ } = configuration || {};
445
345
  if (minAnswerChoices && model.choices.length === minAnswerChoices) {
446
- _this.setState({
346
+ this.setState({
447
347
  showWarning: true
448
348
  });
449
-
450
349
  return;
451
350
  }
452
-
453
351
  model.choices.splice(index, 1);
454
352
  onModelChanged(model);
455
353
  });
456
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onAddChoice", function () {
457
- var _this$props2 = _this.props,
458
- model = _this$props2.model,
459
- configuration = _this$props2.configuration,
460
- onModelChanged = _this$props2.onModelChanged;
461
-
462
- var _ref6 = configuration || {},
463
- maxAnswerChoices = _ref6.maxAnswerChoices;
464
-
465
- var _ref7 = model || {},
466
- limitChoicesNumber = _ref7.limitChoicesNumber; // if old property is used, set maxAnswerChoices to 9
467
-
468
-
354
+ (0, _defineProperty2.default)(this, "onAddChoice", () => {
355
+ const {
356
+ model,
357
+ configuration,
358
+ onModelChanged
359
+ } = this.props;
360
+ let {
361
+ maxAnswerChoices
362
+ } = configuration || {};
363
+ const {
364
+ limitChoicesNumber
365
+ } = model || {};
366
+
367
+ // if old property is used, set maxAnswerChoices to 9
469
368
  if (limitChoicesNumber) {
470
369
  maxAnswerChoices = MAX_CHOICES;
471
370
  }
472
-
473
371
  if (maxAnswerChoices && model.choices.length >= maxAnswerChoices) {
474
372
  return;
475
373
  }
476
-
477
374
  model.choices.push({
478
375
  label: '',
479
- value: _configUi.choiceUtils.firstAvailableIndex(model.choices.map(function (c) {
480
- return c.value;
481
- }), 0),
376
+ value: _configUi.choiceUtils.firstAvailableIndex(model.choices.map(c => c.value), 0),
482
377
  feedback: {
483
378
  type: 'none'
484
379
  }
485
380
  });
486
381
  onModelChanged(model);
487
382
  });
488
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChoiceChanged", function (index, choice) {
489
- var _this$props3 = _this.props,
490
- model = _this$props3.model,
491
- onModelChanged = _this$props3.onModelChanged;
492
-
383
+ (0, _defineProperty2.default)(this, "onChoiceChanged", (index, choice) => {
384
+ const {
385
+ model,
386
+ onModelChanged
387
+ } = this.props;
493
388
  if (choice.correct && model.choiceMode === 'radio') {
494
- model.choices = model.choices.map(function (c) {
495
- return (0, _merge["default"])({}, c, {
496
- correct: false
497
- });
498
- });
389
+ model.choices = model.choices.map(c => (0, _merge.default)({}, c, {
390
+ correct: false
391
+ }));
499
392
  }
500
-
501
393
  model.choices.splice(index, 1, choice);
502
394
  onModelChanged(model);
503
395
  });
504
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onPromptChanged", function (prompt) {
505
- _this.props.onModelChanged(_objectSpread(_objectSpread({}, _this.props.model), {}, {
506
- prompt: prompt
507
- }));
396
+ (0, _defineProperty2.default)(this, "onPromptChanged", prompt => {
397
+ this.props.onModelChanged({
398
+ ...this.props.model,
399
+ prompt
400
+ });
508
401
  });
509
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onTeacherInstructionsChanged", function (teacherInstructions) {
510
- _this.props.onModelChanged(_objectSpread(_objectSpread({}, _this.props.model), {}, {
511
- teacherInstructions: teacherInstructions
512
- }));
402
+ (0, _defineProperty2.default)(this, "onTeacherInstructionsChanged", teacherInstructions => {
403
+ this.props.onModelChanged({
404
+ ...this.props.model,
405
+ teacherInstructions
406
+ });
513
407
  });
514
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onModelChanged", function (model, key) {
515
- var onModelChanged = _this.props.onModelChanged;
516
-
408
+ (0, _defineProperty2.default)(this, "onModelChanged", (model, key) => {
409
+ const {
410
+ onModelChanged
411
+ } = this.props;
517
412
  switch (key) {
518
413
  case 'choiceMode':
519
414
  {
520
- var value = model.choiceMode;
521
-
415
+ let value = model.choiceMode;
522
416
  if (value === 'radio') {
523
- var correctFound = false;
524
- model.choices = model.choices.map(function (c) {
417
+ let correctFound = false;
418
+ model.choices = model.choices.map(c => {
525
419
  if (correctFound) {
526
420
  c.correct = false;
527
421
  return c;
528
422
  }
529
-
530
423
  if (c.correct) {
531
424
  correctFound = true;
532
425
  }
533
-
534
426
  return c;
535
427
  });
536
428
  }
537
-
538
429
  onModelChanged(model, true);
539
430
  break;
540
431
  }
541
-
542
432
  default:
543
433
  onModelChanged(model);
544
434
  break;
545
435
  }
546
436
  });
547
- return _this;
548
437
  }
549
-
550
- (0, _createClass2["default"])(Main, [{
551
- key: "render",
552
- value: function render() {
553
- var _this2 = this;
554
-
555
- var _this$props$configura = this.props.configuration;
556
- _this$props$configura = _this$props$configura === void 0 ? {} : _this$props$configura;
557
- var minAnswerChoices = _this$props$configura.minAnswerChoices;
558
- var showWarning = this.state.showWarning;
559
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_configUi.AlertDialog, {
560
- open: showWarning,
561
- title: "Warning",
562
- text: "There can't be less than ".concat(minAnswerChoices || 0, " choices."),
563
- onConfirm: function onConfirm() {
564
- return _this2.setState({
565
- showWarning: false
566
- });
567
- }
568
- }), /*#__PURE__*/_react["default"].createElement(Design, (0, _extends2["default"])({}, this.props, {
569
- onChangeModel: this.onModelChanged,
570
- onRemoveChoice: this.onRemoveChoice,
571
- onChoiceChanged: this.onChoiceChanged,
572
- onAddChoice: this.onAddChoice,
573
- onPromptChanged: this.onPromptChanged,
574
- onTeacherInstructionsChanged: this.onTeacherInstructionsChanged
575
- })));
576
- }
577
- }]);
578
- return Main;
579
- }(_react["default"].Component);
580
-
438
+ render() {
439
+ const {
440
+ configuration: {
441
+ minAnswerChoices
442
+ } = {}
443
+ } = this.props;
444
+ const {
445
+ showWarning
446
+ } = this.state;
447
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_configUi.AlertDialog, {
448
+ open: showWarning,
449
+ title: "Warning",
450
+ text: `There can't be less than ${minAnswerChoices || 0} choices.`,
451
+ onConfirm: () => this.setState({
452
+ showWarning: false
453
+ })
454
+ }), /*#__PURE__*/_react.default.createElement(Design, (0, _extends2.default)({}, this.props, {
455
+ onChangeModel: this.onModelChanged,
456
+ onRemoveChoice: this.onRemoveChoice,
457
+ onChoiceChanged: this.onChoiceChanged,
458
+ onAddChoice: this.onAddChoice,
459
+ onPromptChanged: this.onPromptChanged,
460
+ onTeacherInstructionsChanged: this.onTeacherInstructionsChanged
461
+ })));
462
+ }
463
+ }
581
464
  exports.Main = Main;
582
- (0, _defineProperty2["default"])(Main, "propTypes", {
583
- model: _propTypes["default"].object.isRequired,
584
- configuration: _propTypes["default"].object.isRequired,
585
- disableSidePanel: _propTypes["default"].bool,
586
- onModelChanged: _propTypes["default"].func.isRequired,
587
- onConfigurationChanged: _propTypes["default"].func.isRequired,
588
- classes: _propTypes["default"].object.isRequired,
589
- imageSupport: _propTypes["default"].shape({
590
- add: _propTypes["default"].func.isRequired,
591
- "delete": _propTypes["default"].func.isRequired
465
+ (0, _defineProperty2.default)(Main, "propTypes", {
466
+ model: _propTypes.default.object.isRequired,
467
+ configuration: _propTypes.default.object.isRequired,
468
+ disableSidePanel: _propTypes.default.bool,
469
+ onModelChanged: _propTypes.default.func.isRequired,
470
+ onConfigurationChanged: _propTypes.default.func.isRequired,
471
+ imageSupport: _propTypes.default.shape({
472
+ add: _propTypes.default.func.isRequired,
473
+ delete: _propTypes.default.func.isRequired
592
474
  })
593
475
  });
594
- var Styled = (0, _styles.withStyles)(styles)(Main);
595
- var _default = Styled;
596
- exports["default"] = _default;
597
- //# sourceMappingURL=main.js.map
476
+ var _default = exports.default = Main;
477
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_styles","_editableHtml","_configUi","_renderUi","_Button","_Tooltip","_Typography","_Box","_Info","_merge","_utils","Panel","toggle","radio","dropdown","settings","MAX_CHOICES","PromptHolder","styled","InputContainer","theme","width","paddingTop","spacing","marginBottom","RationaleHolder","flex","marginTop","marginLeft","ChoiceConfigurationHolder","display","flexDirection","AddButton","Button","float","DisableButton","cursor","pointerEvents","backgroundColor","color","disabled","FlexContainer","Box","alignItems","TitleText","Typography","fontSize","typography","marginRight","StyledTooltip","Tooltip","whiteSpace","maxWidth","ErrorText","palette","error","main","Design","props","model","configuration","onPromptChanged","onChoiceChanged","onRemoveChoice","onAddChoice","imageSupport","uploadSoundSupport","onChangeModel","onConfigurationChanged","onTeacherInstructionsChanged","addChoiceButton","contentDimensions","feedback","deleteChoice","choiceMode","choicePrefix","partialScoring","lockChoiceOrder","teacherInstructions","studentInstructions","rationale","scoringType","sequentialChoiceLabels","settingsPanelDisabled","choicesLayout","spellCheck","gridColumns","maxImageWidth","maxImageHeight","prompt","withRubric","mathMlOptions","language","languageChoices","maxAnswerChoices","limitChoicesNumber","teacherInstructionsEnabled","rationaleEnabled","feedbackEnabled","promptEnabled","spellCheckEnabled","choices","errors","toolbarEditorPosition","extraCSSRules","answerChoices","answerChoicesError","choicesErrors","correctResponse","correctResponseError","promptError","rationaleErrors","teacherInstructionsError","nrOfColumnsAvailable","length","Array","from","_","i","baseInputConfiguration","toolbarOpts","position","getPluginProps","validationMessage","generateValidationMessage","defaultImageMaxWidth","defaultImageMaxHeight","addChoiceButtonTooltip","panelSettings","label","enabled","options","panelProperties","studentInstructionsEnabled","rubricEnabled","default","createElement","layout","ConfigLayout","dimensions","hideSettings","classes","onChangeConfiguration","groups","Settings","Properties","markup","onChange","nonEmpty","disableUnderline","pluginProps","inputConfiguration","languageCharactersProps","component","disableFocusListener","disableTouchListener","placement","title","map","choice","index","key","ChoiceConfiguration","useLetterOrdering","mode","data","defaultFeedback","disableImageAlignmentButtons","onDelete","c","allowFeedBack","allowDelete","noLabels","pluginOpts","value","noCorrectAnswerError","variant","onClick","Main","React","Component","constructor","args","_defineProperty2","showWarning","onModelChanged","minAnswerChoices","setState","splice","push","utils","firstAvailableIndex","type","correct","merge","correctFound","render","state","Fragment","AlertDialog","open","text","onConfirm","_extends2","exports","PropTypes","object","isRequired","disableSidePanel","bool","func","shape","add","delete","_default"],"sources":["../src/main.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\nimport EditableHtml from '@pie-lib/editable-html';\nimport {\n  AlertDialog,\n  InputContainer,\n  ChoiceConfiguration,\n  settings,\n  layout,\n  choiceUtils as utils,\n} from '@pie-lib/config-ui';\nimport { color } from '@pie-lib/render-ui';\nimport Button from '@mui/material/Button';\nimport Tooltip from '@mui/material/Tooltip';\nimport Typography from '@mui/material/Typography';\nimport Box from '@mui/material/Box';\nimport Info from '@mui/icons-material/Info';\nimport merge from 'lodash/merge';\nimport { generateValidationMessage } from './utils';\n\nconst { Panel, toggle, radio, dropdown } = settings;\n\nconst MAX_CHOICES = 9;\n\nconst PromptHolder = styled(InputContainer)(({ theme }) => ({\n  width: '100%',\n  paddingTop: theme.spacing(2),\n  marginBottom: theme.spacing(2),\n}));\n\nconst RationaleHolder = styled(InputContainer)(({ theme }) => ({\n  flex: 1,\n  marginTop: theme.spacing(1.5),\n  paddingTop: theme.spacing(2),\n  marginLeft: theme.spacing(3.5),\n}));\n\nconst ChoiceConfigurationHolder = styled(InputContainer)(({ theme }) => ({\n  display: 'flex',\n  flexDirection: 'column',\n  marginBottom: theme.spacing(1),\n  width: '100%',\n}));\n\n\nconst AddButton = styled(Button)(({ theme }) => ({\n  marginTop: theme.spacing(1),\n  float: 'right',\n}));\n\nconst DisableButton = styled(AddButton)({\n  cursor: 'not-allowed',\n  pointerEvents: 'all',\n  backgroundColor: color.disabled(),\n  '&:hover': {\n    backgroundColor: color.disabled(),\n  },\n  '&:focus': {\n    backgroundColor: color.disabled(),\n  },\n});\n\nconst FlexContainer = styled(Box)({\n  display: 'flex',\n  alignItems: 'center',\n});\n\nconst TitleText = styled(Typography)(({ theme }) => ({\n  fontSize: theme.typography.fontSize + 2,\n  marginRight: theme.spacing(1),\n}));\n\nconst StyledTooltip = styled(Tooltip)(({ theme }) => ({\n  '& .MuiTooltip-tooltip': {\n    fontSize: theme.typography.fontSize - 2,\n    whiteSpace: 'pre',\n    maxWidth: '500px',\n  },\n}));\n\nconst ErrorText = styled('div')(({ theme }) => ({\n  fontSize: theme.typography.fontSize - 2,\n  color: theme.palette.error.main,\n  paddingTop: theme.spacing(1),\n}));\n\nconst Design = (props) => {\n  const {\n    model,\n    configuration,\n    onPromptChanged,\n    onChoiceChanged,\n    onRemoveChoice,\n    onAddChoice,\n    imageSupport,\n    uploadSoundSupport,\n    onChangeModel,\n    onConfigurationChanged,\n    onTeacherInstructionsChanged,\n  } = props;\n\n  const {\n    addChoiceButton = {},\n    contentDimensions = {},\n    feedback = {},\n    deleteChoice = {},\n    choiceMode = {},\n    choicePrefix = {},\n    partialScoring = {},\n    lockChoiceOrder = {},\n    teacherInstructions = {},\n    studentInstructions = {},\n    rationale = {},\n    scoringType = {},\n    sequentialChoiceLabels = {},\n    settingsPanelDisabled,\n    choicesLayout,\n    spellCheck = {},\n    gridColumns,\n    maxImageWidth = {},\n    maxImageHeight = {},\n    prompt = {},\n    withRubric = {},\n    mathMlOptions = {},\n    language = {},\n    languageChoices = {},\n  } = configuration || {};\n  let { maxAnswerChoices } = configuration || {};\n  const {\n    limitChoicesNumber,\n    teacherInstructionsEnabled,\n    rationaleEnabled,\n    feedbackEnabled,\n    promptEnabled,\n    spellCheckEnabled,\n    choices,\n    errors,\n    toolbarEditorPosition,\n    extraCSSRules,\n  } = model || {};\n\n  const {\n    answerChoices: answerChoicesError,\n    choices: choicesErrors,\n    correctResponse: correctResponseError,\n    prompt: promptError,\n    rationale: rationaleErrors,\n    teacherInstructions: teacherInstructionsError,\n  } = errors || {};\n  const nrOfColumnsAvailable = choices?.length ? Array.from({ length: choices.length }, (_, i) => `${i + 1}`) : [];\n\n  const { baseInputConfiguration = {} } = configuration;\n  const toolbarOpts = {\n    position: toolbarEditorPosition === 'top' ? 'top' : 'bottom',\n  };\n\n  // if old property is used, set maxAnswerChoices to 9\n  if (limitChoicesNumber) {\n    maxAnswerChoices = MAX_CHOICES;\n  }\n\n  const getPluginProps = (props = {}) => ({\n    ...baseInputConfiguration,\n    ...props,\n  });\n\n  const validationMessage = generateValidationMessage(configuration);\n  const defaultImageMaxWidth = maxImageWidth && maxImageWidth.prompt;\n  const defaultImageMaxHeight = maxImageHeight && maxImageHeight.prompt;\n  const addChoiceButtonTooltip =\n    maxAnswerChoices && choices?.length >= maxAnswerChoices ? `Only ${maxAnswerChoices} allowed maximum` : '';\n\n  const panelSettings = {\n    choiceMode: choiceMode.settings && radio(choiceMode.label, ['checkbox', 'radio']),\n    'sequentialChoiceLabels.enabled': sequentialChoiceLabels.settings && toggle(sequentialChoiceLabels.label, true),\n    choicePrefix: choicePrefix.settings && radio(choicePrefix.label, ['numbers', 'letters']),\n    partialScoring: partialScoring.settings && toggle(partialScoring.label),\n    lockChoiceOrder: lockChoiceOrder.settings && toggle(lockChoiceOrder.label),\n    feedbackEnabled: feedback.settings && toggle(feedback.label),\n    choicesLayout: choicesLayout.settings && dropdown(choicesLayout.label, ['vertical', 'grid', 'horizontal']),\n    gridColumns:\n      choicesLayout.settings &&\n      model.choicesLayout === 'grid' &&\n      nrOfColumnsAvailable.length > 0 &&\n      dropdown(gridColumns.label, nrOfColumnsAvailable),\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    promptEnabled: prompt.settings && toggle(prompt.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  return (\n    <layout.ConfigLayout\n      dimensions={contentDimensions}\n      hideSettings={settingsPanelDisabled}\n      extraCSSRules={extraCSSRules}\n      classes={{}}\n      settings={\n        <Panel\n          model={model}\n          onChangeModel={onChangeModel}\n          configuration={configuration}\n          onChangeConfiguration={onConfigurationChanged}\n          groups={{\n            Settings: panelSettings,\n            Properties: panelProperties,\n          }}\n        />\n      }\n    >\n      {teacherInstructionsEnabled && (\n        <PromptHolder label={teacherInstructions.label}>\n            <EditableHtml\n              markup={model.teacherInstructions || ''}\n              onChange={onTeacherInstructionsChanged}\n              imageSupport={imageSupport}\n              nonEmpty={false}\n              disableUnderline\n              error={teacherInstructionsError}\n              toolbarOpts={toolbarOpts}\n              pluginProps={getPluginProps(configuration?.teacherInstructions?.inputConfiguration)}\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 && <ErrorText>{teacherInstructionsError}</ErrorText>}\n        </PromptHolder>\n      )}\n\n      {promptEnabled && (\n        <PromptHolder label={prompt.label}>\n            <EditableHtml\n              markup={model.prompt}\n              onChange={onPromptChanged}\n              imageSupport={imageSupport}\n              nonEmpty={false}\n              disableUnderline\n              error={promptError}\n              toolbarOpts={toolbarOpts}\n              pluginProps={getPluginProps(configuration?.prompt?.inputConfiguration)}\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 && <ErrorText>{promptError}</ErrorText>}\n        </PromptHolder>\n      )}\n\n      <FlexContainer>\n        <TitleText component={'div'}>\n          Choices\n        </TitleText>\n        <StyledTooltip\n          disableFocusListener\n          disableTouchListener\n          placement={'right'}\n          title={validationMessage}\n        >\n          <Info fontSize={'small'} color={'primary'} />\n        </StyledTooltip>\n      </FlexContainer>\n\n      {choices.map((choice, index) => (\n        <ChoiceConfigurationHolder key={`choice-${index}`}>\n          <ChoiceConfiguration\n            key={index}\n            index={index + 1}\n            useLetterOrdering={model.choicePrefix === 'letters'}\n            mode={model.choiceMode}\n            data={choice}\n            defaultFeedback={{}}\n            imageSupport={imageSupport}\n            disableImageAlignmentButtons={true}\n            onDelete={() => onRemoveChoice(index)}\n            onChange={(c) => onChoiceChanged(index, c)}\n            allowFeedBack={feedbackEnabled}\n            allowDelete={deleteChoice.settings}\n            noLabels\n            pluginOpts={getPluginProps(configuration?.choices?.inputConfiguration)}\n            toolbarOpts={toolbarOpts}\n            spellCheck={spellCheckEnabled}\n            error={choicesErrors?.[choice.value] || null}\n            noCorrectAnswerError={correctResponseError}\n            maxImageWidth={(maxImageWidth && maxImageWidth.choices) || defaultImageMaxWidth}\n            maxImageHeight={(maxImageHeight && maxImageHeight.choices) || defaultImageMaxHeight}\n            uploadSoundSupport={uploadSoundSupport}\n            mathMlOptions={mathMlOptions}\n          />\n\n          {rationaleEnabled && (\n            <RationaleHolder key={`rationale-${index}`} label={rationale.label}>\n                <EditableHtml\n                  markup={choice.rationale || ''}\n                  onChange={(c) => onChoiceChanged(index, { ...choice, rationale: c })}\n                  imageSupport={imageSupport}\n                  error={rationaleErrors?.[choice.value] || null}\n                  toolbarOpts={toolbarOpts}\n                  pluginProps={getPluginProps(configuration?.rationale?.inputConfiguration)}\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                {rationaleErrors?.[choice.value] && (\n                  <ErrorText>{rationaleErrors?.[choice.value]}</ErrorText>\n                )}\n            </RationaleHolder>\n          )}\n        </ChoiceConfigurationHolder>\n      ))}\n\n      {correctResponseError && <ErrorText>{correctResponseError}</ErrorText>}\n      {answerChoicesError && <ErrorText>{answerChoicesError}</ErrorText>}\n\n      {addChoiceButton.settings && (\n        <StyledTooltip title={addChoiceButtonTooltip}>\n          {maxAnswerChoices && choices?.length >= maxAnswerChoices ? (\n            <DisableButton\n              variant=\"contained\"\n              color=\"primary\"\n              onClick={onAddChoice}\n              disabled\n            >\n              {addChoiceButton.label}\n            </DisableButton>\n          ) : (\n            <AddButton\n              variant=\"contained\"\n              color=\"primary\"\n              onClick={onAddChoice}\n            >\n              {addChoiceButton.label}\n            </AddButton>\n          )}\n        </StyledTooltip>\n      )}\n    </layout.ConfigLayout>\n  );\n};\n\nexport class Main extends React.Component {\n  static propTypes = {\n    model: PropTypes.object.isRequired,\n    configuration: PropTypes.object.isRequired,\n    disableSidePanel: PropTypes.bool,\n    onModelChanged: PropTypes.func.isRequired,\n    onConfigurationChanged: PropTypes.func.isRequired,\n    imageSupport: PropTypes.shape({\n      add: PropTypes.func.isRequired,\n      delete: PropTypes.func.isRequired,\n    }),\n  };\n\n  state = { showWarning: false };\n\n  onRemoveChoice = (index) => {\n    const { model, configuration, onModelChanged } = this.props;\n    const { minAnswerChoices } = configuration || {};\n\n    if (minAnswerChoices && model.choices.length === minAnswerChoices) {\n      this.setState({ showWarning: true });\n\n      return;\n    }\n\n    model.choices.splice(index, 1);\n    onModelChanged(model);\n  };\n\n  onAddChoice = () => {\n    const { model, configuration, onModelChanged } = this.props;\n    let { maxAnswerChoices } = configuration || {};\n    const { limitChoicesNumber } = model || {};\n\n    // if old property is used, set maxAnswerChoices to 9\n    if (limitChoicesNumber) {\n      maxAnswerChoices = MAX_CHOICES;\n    }\n\n    if (maxAnswerChoices && model.choices.length >= maxAnswerChoices) {\n      return;\n    }\n\n    model.choices.push({\n      label: '',\n      value: utils.firstAvailableIndex(\n        model.choices.map((c) => c.value),\n        0,\n      ),\n      feedback: { type: 'none' },\n    });\n\n    onModelChanged(model);\n  };\n\n  onChoiceChanged = (index, choice) => {\n    const { model, onModelChanged } = this.props;\n\n    if (choice.correct && model.choiceMode === 'radio') {\n      model.choices = model.choices.map((c) => merge({}, c, { correct: false }));\n    }\n\n    model.choices.splice(index, 1, choice);\n    onModelChanged(model);\n  };\n\n  onPromptChanged = (prompt) => {\n    this.props.onModelChanged({\n      ...this.props.model,\n      prompt,\n    });\n  };\n\n  onTeacherInstructionsChanged = (teacherInstructions) => {\n    this.props.onModelChanged({\n      ...this.props.model,\n      teacherInstructions,\n    });\n  };\n\n  onModelChanged = (model, key) => {\n    const { onModelChanged } = this.props;\n\n    switch (key) {\n      case 'choiceMode': {\n        let value = model.choiceMode;\n\n        if (value === 'radio') {\n          let correctFound = false;\n\n          model.choices = model.choices.map((c) => {\n            if (correctFound) {\n              c.correct = false;\n\n              return c;\n            }\n\n            if (c.correct) {\n              correctFound = true;\n            }\n\n            return c;\n          });\n        }\n\n        onModelChanged(model, true);\n        break;\n      }\n\n      default:\n        onModelChanged(model);\n        break;\n    }\n  };\n\n  render() {\n    const { configuration: { minAnswerChoices } = {} } = this.props;\n    const { showWarning } = this.state;\n\n    return (\n      <React.Fragment>\n        <AlertDialog\n          open={showWarning}\n          title=\"Warning\"\n          text={`There can't be less than ${minAnswerChoices || 0} choices.`}\n          onConfirm={() => this.setState({ showWarning: false })}\n        />\n        <Design\n          {...this.props}\n          onChangeModel={this.onModelChanged}\n          onRemoveChoice={this.onRemoveChoice}\n          onChoiceChanged={this.onChoiceChanged}\n          onAddChoice={this.onAddChoice}\n          onPromptChanged={this.onPromptChanged}\n          onTeacherInstructionsChanged={this.onTeacherInstructionsChanged}\n        />\n      </React.Fragment>\n    );\n  }\n}\n\nexport default Main;\n"],"mappings":"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","ignoreList":[]}