@pie-element/multiple-choice 11.4.4-next.0 → 12.0.0-beta.0

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 (51) hide show
  1. package/configure/lib/__tests__/root.test.js +286 -0
  2. package/configure/lib/defaults.js +3 -5
  3. package/configure/lib/defaults.js.map +1 -1
  4. package/configure/lib/index.js +156 -193
  5. package/configure/lib/index.js.map +1 -1
  6. package/configure/lib/main.js +325 -445
  7. package/configure/lib/main.js.map +1 -1
  8. package/configure/lib/utils.js +9 -9
  9. package/configure/lib/utils.js.map +1 -1
  10. package/configure/package.json +10 -8
  11. package/controller/lib/__tests__/index.test.js +520 -0
  12. package/controller/lib/__tests__/utils.test.js +8 -0
  13. package/controller/lib/defaults.js +3 -4
  14. package/controller/lib/defaults.js.map +1 -1
  15. package/controller/lib/index.js +145 -240
  16. package/controller/lib/index.js.map +1 -1
  17. package/controller/lib/utils.js +5 -17
  18. package/controller/lib/utils.js.map +1 -1
  19. package/controller/package.json +2 -2
  20. package/docs/demo/pie.manifest.json +11 -0
  21. package/lib/__tests__/choice-input-test.js +49 -0
  22. package/lib/__tests__/index-test.js +200 -0
  23. package/lib/__tests__/key-events-test.js +95 -0
  24. package/lib/__tests__/multiple-choice-test.js +101 -0
  25. package/lib/__tests__/session-updater-test.js +70 -0
  26. package/lib/choice-input.js +312 -369
  27. package/lib/choice-input.js.map +1 -1
  28. package/lib/choice.js +164 -220
  29. package/lib/choice.js.map +1 -1
  30. package/lib/feedback-tick.js +75 -115
  31. package/lib/feedback-tick.js.map +1 -1
  32. package/lib/index.js +242 -342
  33. package/lib/index.js.map +1 -1
  34. package/lib/main.js +39 -86
  35. package/lib/main.js.map +1 -1
  36. package/lib/multiple-choice.js +305 -397
  37. package/lib/multiple-choice.js.map +1 -1
  38. package/lib/print.js +40 -78
  39. package/lib/print.js.map +1 -1
  40. package/lib/session-updater.js +5 -16
  41. package/lib/session-updater.js.map +1 -1
  42. package/package.json +13 -16
  43. package/module/configure.js +0 -1
  44. package/module/controller.js +0 -3472
  45. package/module/demo.js +0 -86
  46. package/module/element.js +0 -1
  47. package/module/index.html +0 -21
  48. package/module/manifest.json +0 -14
  49. package/module/print-demo.js +0 -124
  50. package/module/print.html +0 -18
  51. package/module/print.js +0 -1
@@ -1,164 +1,128 @@
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.MultipleChoice = void 0;
9
-
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
7
+ exports.default = exports.MultipleChoice = void 0;
22
8
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
23
-
24
9
  var _react = _interopRequireDefault(require("react"));
25
-
26
10
  var _propTypes = _interopRequireDefault(require("prop-types"));
27
-
28
11
  var _correctAnswerToggle = _interopRequireDefault(require("@pie-lib/correct-answer-toggle"));
29
-
30
12
  var _classnames = _interopRequireDefault(require("classnames"));
31
-
32
- var _styles = require("@material-ui/core/styles");
33
-
13
+ var _styles = require("@mui/material/styles");
14
+ var _Box = _interopRequireDefault(require("@mui/material/Box"));
34
15
  var _renderUi = require("@pie-lib/render-ui");
35
-
36
16
  var _translator = _interopRequireDefault(require("@pie-lib/translator"));
37
-
38
17
  var _choice = _interopRequireDefault(require("./choice"));
39
-
40
- 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); }; }
41
-
42
- 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; } }
43
-
44
- // MultipleChoice
45
- var translator = _translator["default"].translator;
46
-
47
- var styles = function styles(theme) {
48
- return {
49
- main: {
50
- color: _renderUi.color.text(),
51
- backgroundColor: _renderUi.color.background(),
52
- '& *': {
53
- '-webkit-font-smoothing': 'antialiased'
54
- },
55
- position: 'relative',
56
- // remove border from legend tags inside main to override the OT default styles
57
- '& legend': {
58
- border: 'none !important'
59
- }
60
- },
61
- partLabel: {
62
- display: 'block',
63
- fontSize: 'inherit',
64
- margin: '0',
65
- fontWeight: 'normal',
66
- paddingBottom: theme.spacing.unit * 2
67
- },
68
- teacherInstructions: {
69
- marginBottom: theme.spacing.unit * 2
70
- },
71
- horizontalLayout: {
72
- display: 'flex',
73
- flexDirection: 'row',
74
- flexWrap: 'wrap'
75
- },
76
- gridLayout: {
77
- display: 'grid'
78
- },
79
- fieldset: {
80
- border: '0px',
81
- padding: '0.01em 0 0 0',
82
- margin: '0px',
83
- minWidth: '0px',
84
- '&:focus': {
85
- outline: 'none'
86
- }
87
- },
88
- srOnly: {
89
- position: 'absolute',
90
- left: '-10000px',
91
- top: 'auto',
92
- width: '1px',
93
- height: '1px',
94
- overflow: 'hidden'
95
- },
96
- errorText: {
97
- fontSize: theme.typography.fontSize - 2,
98
- color: theme.palette.error.main,
99
- paddingTop: theme.spacing.unit
100
- }
101
- };
102
- };
103
-
104
- var MultipleChoice = /*#__PURE__*/function (_React$Component) {
105
- (0, _inherits2["default"])(MultipleChoice, _React$Component);
106
-
107
- var _super = _createSuper(MultipleChoice);
108
-
109
- function MultipleChoice(props) {
110
- var _this;
111
-
112
- (0, _classCallCheck2["default"])(this, MultipleChoice);
113
- _this = _super.call(this, props);
114
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleChange", function (event) {
115
- var _event$target = event.target,
116
- value = _event$target.value,
117
- checked = _event$target.checked;
118
- var _this$props = _this.props,
119
- maxSelections = _this$props.maxSelections,
120
- onChoiceChanged = _this$props.onChoiceChanged,
121
- session = _this$props.session;
122
-
18
+ const {
19
+ translator
20
+ } = _translator.default;
21
+ const MainContainer = (0, _styles.styled)(_Box.default)({
22
+ color: _renderUi.color.text(),
23
+ backgroundColor: _renderUi.color.background(),
24
+ '& *': {
25
+ '-webkit-font-smoothing': 'antialiased'
26
+ },
27
+ position: 'relative',
28
+ // remove border from legend tags inside main to override the OT default styles
29
+ '& legend': {
30
+ border: 'none !important'
31
+ }
32
+ });
33
+ const PartLabel = (0, _styles.styled)('h2')(({
34
+ theme
35
+ }) => ({
36
+ display: 'block',
37
+ fontSize: 'inherit',
38
+ margin: '0',
39
+ fontWeight: 'normal',
40
+ paddingBottom: theme.spacing(2)
41
+ }));
42
+ const TeacherInstructions = (0, _styles.styled)(_Box.default)(({
43
+ theme
44
+ }) => ({
45
+ marginBottom: theme.spacing(2)
46
+ }));
47
+ const HorizontalLayout = (0, _styles.styled)(_Box.default)({
48
+ display: 'flex',
49
+ flexDirection: 'row',
50
+ flexWrap: 'wrap'
51
+ });
52
+ const GridLayout = (0, _styles.styled)(_Box.default)({
53
+ display: 'grid'
54
+ });
55
+ const StyledFieldset = (0, _styles.styled)('fieldset')({
56
+ border: '0px',
57
+ padding: '0.01em 0 0 0',
58
+ margin: '0px',
59
+ minWidth: '0px',
60
+ '&:focus': {
61
+ outline: 'none'
62
+ }
63
+ });
64
+ const SrOnly = (0, _styles.styled)('h3')({
65
+ position: 'absolute',
66
+ left: '-10000px',
67
+ top: 'auto',
68
+ width: '1px',
69
+ height: '1px',
70
+ overflow: 'hidden'
71
+ });
72
+ const ErrorText = (0, _styles.styled)('div')(({
73
+ theme
74
+ }) => ({
75
+ fontSize: theme.typography.fontSize - 2,
76
+ color: theme.palette.error.main,
77
+ paddingTop: theme.spacing(1)
78
+ }));
79
+ class MultipleChoice extends _react.default.Component {
80
+ constructor(props) {
81
+ super(props);
82
+ // handleChange was added for accessibility. Please see comments and videos from PD-2441.
83
+ (0, _defineProperty2.default)(this, "handleChange", event => {
84
+ const {
85
+ value,
86
+ checked
87
+ } = event.target;
88
+ const {
89
+ maxSelections,
90
+ onChoiceChanged,
91
+ session
92
+ } = this.props;
123
93
  if (session.value && session.value.length >= maxSelections) {
124
94
  // show/hide max selections error when user select/deselect an answer
125
- _this.setState({
95
+ this.setState({
126
96
  maxSelectionsErrorState: checked
127
97
  });
128
-
129
98
  if (checked) {
130
99
  // prevent selecting more answers
131
100
  return;
132
101
  }
133
102
  }
134
-
135
103
  onChoiceChanged({
136
- value: value,
104
+ value,
137
105
  selected: checked,
138
106
  selector: 'Mouse'
139
107
  });
140
108
  });
141
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onToggle", function () {
142
- if (_this.props.mode === 'evaluate') {
143
- _this.setState({
144
- showCorrect: !_this.state.showCorrect
145
- }, function () {
146
- if (_this.props.onShowCorrectToggle) {
147
- _this.props.onShowCorrectToggle();
109
+ (0, _defineProperty2.default)(this, "onToggle", () => {
110
+ if (this.props.mode === 'evaluate') {
111
+ this.setState({
112
+ showCorrect: !this.state.showCorrect
113
+ }, () => {
114
+ if (this.props.onShowCorrectToggle) {
115
+ this.props.onShowCorrectToggle();
148
116
  }
149
117
  });
150
118
  }
151
119
  });
152
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getCorrectness", function () {
153
- var choice = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
154
- var isCorrect = choice.correct;
155
-
156
- var isChecked = _this.isSelected(choice.value);
157
-
158
- if (_this.state.showCorrect) {
120
+ (0, _defineProperty2.default)(this, "getCorrectness", (choice = {}) => {
121
+ const isCorrect = choice.correct;
122
+ const isChecked = this.isSelected(choice.value);
123
+ if (this.state.showCorrect) {
159
124
  return isCorrect ? 'correct' : undefined;
160
125
  }
161
-
162
126
  if (isCorrect) {
163
127
  if (isChecked) {
164
128
  // A correct answer is selected: marked with a green checkmark
@@ -177,301 +141,245 @@ var MultipleChoice = /*#__PURE__*/function (_React$Component) {
177
141
  }
178
142
  }
179
143
  });
180
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleGroupFocus", function (e) {
181
- var fieldset = e.currentTarget;
182
- var activeEl = document.activeElement;
183
-
144
+ (0, _defineProperty2.default)(this, "handleGroupFocus", e => {
145
+ const fieldset = e.currentTarget;
146
+ const activeEl = document.activeElement;
184
147
  if (fieldset.contains(activeEl) && activeEl !== fieldset) {
185
148
  return;
186
- } // Only focus the first input if user is tabbing forward
187
-
149
+ }
188
150
 
151
+ // Only focus the first input if user is tabbing forward
189
152
  if (!e.relatedTarget || fieldset.compareDocumentPosition(e.relatedTarget) & Node.DOCUMENT_POSITION_PRECEDING) {
190
- var _this$firstInputRef;
191
-
192
- if ((_this$firstInputRef = _this.firstInputRef) !== null && _this$firstInputRef !== void 0 && _this$firstInputRef.current) {
193
- _this.firstInputRef.current.focus();
153
+ if (this.firstInputRef?.current) {
154
+ this.firstInputRef.current.focus();
194
155
  }
195
156
  }
196
157
  });
197
- _this.state = {
198
- showCorrect: _this.props.options && _this.props.alwaysShowCorrect || false,
158
+ this.state = {
159
+ showCorrect: this.props.options && this.props.alwaysShowCorrect || false,
199
160
  maxSelectionsErrorState: false
200
161
  };
201
- _this.onToggle = _this.onToggle.bind((0, _assertThisInitialized2["default"])(_this));
202
- _this.firstInputRef = /*#__PURE__*/_react["default"].createRef();
203
- return _this;
162
+ this.onToggle = this.onToggle.bind(this);
163
+ this.firstInputRef = /*#__PURE__*/_react.default.createRef();
164
+ }
165
+ isSelected(value) {
166
+ const sessionValue = this.props.session && this.props.session.value;
167
+ return sessionValue && sessionValue.indexOf && sessionValue.indexOf(value) >= 0;
204
168
  }
169
+ UNSAFE_componentWillReceiveProps(nextProps) {
170
+ if (!nextProps.correctResponse && this.state.showCorrect !== false) {
171
+ this.setState({
172
+ showCorrect: false
173
+ }, () => {
174
+ if (this.props.onShowCorrectToggle) {
175
+ this.props.onShowCorrectToggle();
176
+ }
177
+ });
178
+ }
179
+ if (nextProps.options && nextProps.alwaysShowCorrect && this.state.showCorrect !== true) {
180
+ this.setState({
181
+ showCorrect: true
182
+ }, () => {
183
+ if (this.props.onShowCorrectToggle) {
184
+ this.props.onShowCorrectToggle();
185
+ }
186
+ });
187
+ }
188
+ }
189
+ indexToSymbol(index) {
190
+ if (this.props.keyMode === 'numbers') {
191
+ return `${index + 1}`;
192
+ }
193
+ if (this.props.keyMode === 'letters') {
194
+ return String.fromCharCode(97 + index).toUpperCase();
195
+ }
196
+ return '';
197
+ }
198
+ getChecked(choice) {
199
+ // check for print context: options prop is passed from print.js and alwaysShowCorrect is true
200
+ const isPrintMode = this.props.options && this.props.alwaysShowCorrect;
201
+ if (isPrintMode) {
202
+ return choice.correct || false;
203
+ }
205
204
 
206
- (0, _createClass2["default"])(MultipleChoice, [{
207
- key: "isSelected",
208
- value: function isSelected(value) {
209
- var sessionValue = this.props.session && this.props.session.value;
210
- return sessionValue && sessionValue.indexOf && sessionValue.indexOf(value) >= 0;
211
- } // handleChange was added for accessibility. Please see comments and videos from PD-2441.
205
+ // evaluate mode with show correct toggled
206
+ const isEvaluateMode = this.state.showCorrect && this.props.mode === 'evaluate';
207
+ if (isEvaluateMode) {
208
+ return choice.correct || false;
209
+ }
212
210
 
213
- }, {
214
- key: "UNSAFE_componentWillReceiveProps",
215
- value: function UNSAFE_componentWillReceiveProps(nextProps) {
216
- var _this2 = this;
211
+ // default behavior: show what the user has selected
212
+ return this.isSelected(choice.value);
213
+ }
217
214
 
218
- if (!nextProps.correctResponse && this.state.showCorrect !== false) {
219
- this.setState({
220
- showCorrect: false
221
- }, function () {
222
- if (_this2.props.onShowCorrectToggle) {
223
- _this2.props.onShowCorrectToggle();
224
- }
215
+ // renderHeading function was added for accessibility.
216
+ renderHeading() {
217
+ const {
218
+ mode,
219
+ choiceMode
220
+ } = this.props;
221
+ if (mode !== 'gather') {
222
+ return null;
223
+ }
224
+ return choiceMode === 'radio' ? /*#__PURE__*/_react.default.createElement(SrOnly, null, "Multiple Choice Question") : /*#__PURE__*/_react.default.createElement(SrOnly, null, "Multiple Select Question");
225
+ }
226
+ render() {
227
+ const {
228
+ mode,
229
+ disabled,
230
+ className,
231
+ choices = [],
232
+ choiceMode,
233
+ gridColumns,
234
+ partLabel,
235
+ prompt,
236
+ responseCorrect,
237
+ teacherInstructions,
238
+ alwaysShowCorrect,
239
+ animationsDisabled,
240
+ language,
241
+ isSelectionButtonBelow,
242
+ minSelections,
243
+ maxSelections,
244
+ autoplayAudioEnabled,
245
+ session,
246
+ customAudioButton,
247
+ options
248
+ } = this.props;
249
+ const {
250
+ showCorrect,
251
+ maxSelectionsErrorState
252
+ } = this.state;
253
+ const isEvaluateMode = mode === 'evaluate';
254
+ const showCorrectAnswerToggle = isEvaluateMode && !responseCorrect;
255
+ const columnsStyle = gridColumns > 1 ? {
256
+ gridTemplateColumns: `repeat(${gridColumns}, 1fr)`
257
+ } : undefined;
258
+ const selections = session.value && session.value.length || 0;
259
+ const teacherInstructionsDiv = /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
260
+ tagName: "div",
261
+ className: "prompt",
262
+ defaultClassName: "teacher-instructions",
263
+ prompt: teacherInstructions
264
+ });
265
+ const getMultipleChoiceMinSelectionErrorMessage = () => {
266
+ if (minSelections && maxSelections) {
267
+ return minSelections === maxSelections ? translator.t('translation:multipleChoice:minmaxSelections_equal', {
268
+ lng: language,
269
+ minSelections
270
+ }) : translator.t('translation:multipleChoice:minmaxSelections_range', {
271
+ lng: language,
272
+ minSelections,
273
+ maxSelections
225
274
  });
226
275
  }
227
-
228
- if (nextProps.options && nextProps.alwaysShowCorrect && this.state.showCorrect !== true) {
229
- this.setState({
230
- showCorrect: true
231
- }, function () {
232
- if (_this2.props.onShowCorrectToggle) {
233
- _this2.props.onShowCorrectToggle();
234
- }
276
+ if (minSelections) {
277
+ return translator.t('translation:multipleChoice:minSelections', {
278
+ lng: language,
279
+ minSelections
235
280
  });
236
281
  }
237
- }
238
- }, {
239
- key: "indexToSymbol",
240
- value: function indexToSymbol(index) {
241
- if (this.props.keyMode === 'numbers') {
242
- return "".concat(index + 1);
243
- }
244
-
245
- if (this.props.keyMode === 'letters') {
246
- return String.fromCharCode(97 + index).toUpperCase();
247
- }
248
-
249
282
  return '';
250
- }
251
- }, {
252
- key: "getChecked",
253
- value: function getChecked(choice) {
254
- // check for print context: options prop is passed from print.js and alwaysShowCorrect is true
255
- var isPrintMode = this.props.options && this.props.alwaysShowCorrect;
256
-
257
- if (isPrintMode) {
258
- return choice.correct || false;
259
- } // evaluate mode with show correct toggled
260
-
261
-
262
- var isEvaluateMode = this.state.showCorrect && this.props.mode === 'evaluate';
263
-
264
- if (isEvaluateMode) {
265
- return choice.correct || false;
266
- } // default behavior: show what the user has selected
267
-
268
-
269
- return this.isSelected(choice.value);
270
- } // renderHeading function was added for accessibility.
271
-
272
- }, {
273
- key: "renderHeading",
274
- value: function renderHeading() {
275
- var _this$props2 = this.props,
276
- mode = _this$props2.mode,
277
- choiceMode = _this$props2.choiceMode,
278
- classes = _this$props2.classes;
279
-
280
- if (mode !== 'gather') {
281
- return null;
283
+ };
284
+ const LayoutComponent = this.props.choicesLayout === 'grid' ? GridLayout : this.props.choicesLayout === 'horizontal' ? HorizontalLayout : _Box.default;
285
+ return /*#__PURE__*/_react.default.createElement(MainContainer, {
286
+ id: 'main-container',
287
+ className: (0, _classnames.default)(className, 'multiple-choice')
288
+ }, partLabel && /*#__PURE__*/_react.default.createElement(PartLabel, null, partLabel), this.renderHeading(), teacherInstructions && /*#__PURE__*/_react.default.createElement(TeacherInstructions, null, !animationsDisabled ? /*#__PURE__*/_react.default.createElement(_renderUi.Collapsible, {
289
+ labels: {
290
+ hidden: 'Show Teacher Instructions',
291
+ visible: 'Hide Teacher Instructions'
282
292
  }
283
-
284
- return choiceMode === 'radio' ? /*#__PURE__*/_react["default"].createElement("h3", {
285
- className: classes.srOnly
286
- }, "Multiple Choice Question") : /*#__PURE__*/_react["default"].createElement("h3", {
287
- className: classes.srOnly
288
- }, "Multiple Select Question");
289
- }
290
- }, {
291
- key: "render",
292
- value: function render() {
293
- var _classNames,
294
- _this3 = this;
295
-
296
- var _this$props3 = this.props,
297
- mode = _this$props3.mode,
298
- disabled = _this$props3.disabled,
299
- className = _this$props3.className,
300
- _this$props3$choices = _this$props3.choices,
301
- choices = _this$props3$choices === void 0 ? [] : _this$props3$choices,
302
- choiceMode = _this$props3.choiceMode,
303
- gridColumns = _this$props3.gridColumns,
304
- partLabel = _this$props3.partLabel,
305
- prompt = _this$props3.prompt,
306
- responseCorrect = _this$props3.responseCorrect,
307
- teacherInstructions = _this$props3.teacherInstructions,
308
- classes = _this$props3.classes,
309
- alwaysShowCorrect = _this$props3.alwaysShowCorrect,
310
- animationsDisabled = _this$props3.animationsDisabled,
311
- language = _this$props3.language,
312
- isSelectionButtonBelow = _this$props3.isSelectionButtonBelow,
313
- minSelections = _this$props3.minSelections,
314
- maxSelections = _this$props3.maxSelections,
315
- autoplayAudioEnabled = _this$props3.autoplayAudioEnabled,
316
- session = _this$props3.session,
317
- customAudioButton = _this$props3.customAudioButton,
318
- options = _this$props3.options;
319
- var _this$state = this.state,
320
- showCorrect = _this$state.showCorrect,
321
- maxSelectionsErrorState = _this$state.maxSelectionsErrorState;
322
- var isEvaluateMode = mode === 'evaluate';
323
- var showCorrectAnswerToggle = isEvaluateMode && !responseCorrect;
324
- var columnsStyle = gridColumns > 1 ? {
325
- gridTemplateColumns: "repeat(".concat(gridColumns, ", 1fr)")
326
- } : undefined;
327
- var selections = session.value && session.value.length || 0;
328
-
329
- var teacherInstructionsDiv = /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
330
- tagName: "div",
331
- className: "prompt",
332
- defaultClassName: "teacher-instructions",
333
- prompt: teacherInstructions
334
- });
335
-
336
- var getMultipleChoiceMinSelectionErrorMessage = function getMultipleChoiceMinSelectionErrorMessage() {
337
- if (minSelections && maxSelections) {
338
- return minSelections === maxSelections ? translator.t('translation:multipleChoice:minmaxSelections_equal', {
339
- lng: language,
340
- minSelections: minSelections
341
- }) : translator.t('translation:multipleChoice:minmaxSelections_range', {
342
- lng: language,
343
- minSelections: minSelections,
344
- maxSelections: maxSelections
345
- });
346
- }
347
-
348
- if (minSelections) {
349
- return translator.t('translation:multipleChoice:minSelections', {
350
- lng: language,
351
- minSelections: minSelections
352
- });
353
- }
354
-
355
- return '';
356
- };
357
-
358
- return /*#__PURE__*/_react["default"].createElement("div", {
359
- id: 'main-container',
360
- className: (0, _classnames["default"])(classes.main, className, 'multiple-choice')
361
- }, partLabel && /*#__PURE__*/_react["default"].createElement("h2", {
362
- className: classes.partLabel
363
- }, partLabel), this.renderHeading(), teacherInstructions && /*#__PURE__*/_react["default"].createElement("div", {
364
- className: classes.teacherInstructions
365
- }, !animationsDisabled ? /*#__PURE__*/_react["default"].createElement(_renderUi.Collapsible, {
366
- labels: {
367
- hidden: 'Show Teacher Instructions',
368
- visible: 'Hide Teacher Instructions'
369
- }
370
- }, teacherInstructionsDiv) : teacherInstructionsDiv), /*#__PURE__*/_react["default"].createElement("fieldset", {
371
- tabIndex: 0,
372
- className: classes.fieldset,
373
- onFocus: this.handleGroupFocus,
374
- role: choiceMode === 'radio' ? 'radiogroup' : 'group'
375
- }, /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
376
- className: "prompt",
377
- defaultClassName: "prompt",
378
- prompt: prompt,
379
- tagName: 'legend',
380
- autoplayAudioEnabled: autoplayAudioEnabled,
381
- customAudioButton: customAudioButton
382
- }), !(options && alwaysShowCorrect) && /*#__PURE__*/_react["default"].createElement(_correctAnswerToggle["default"], {
383
- show: showCorrectAnswerToggle,
384
- toggled: showCorrect,
385
- onToggle: this.onToggle.bind(this),
386
- language: language
387
- }), /*#__PURE__*/_react["default"].createElement("div", {
388
- className: (0, _classnames["default"])((_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.gridLayout, this.props.choicesLayout === 'grid'), (0, _defineProperty2["default"])(_classNames, classes.horizontalLayout, this.props.choicesLayout === 'horizontal'), _classNames)),
389
- style: columnsStyle
390
- }, choices.map(function (choice, index) {
391
- return /*#__PURE__*/_react["default"].createElement(_choice["default"], {
392
- autoFocusRef: index === 0 ? _this3.firstInputRef : null,
393
- choicesLayout: _this3.props.choicesLayout,
394
- selectedAnswerBackgroundColor: _this3.props.selectedAnswerBackgroundColor,
395
- selectedAnswerStrokeColor: _this3.props.selectedAnswerStrokeColor,
396
- selectedAnswerStrokeWidth: _this3.props.selectedAnswerStrokeWidth,
397
- hoverAnswerBackgroundColor: _this3.props.hoverAnswerBackgroundColor,
398
- hoverAnswerStrokeColor: _this3.props.hoverAnswerStrokeColor,
399
- hoverAnswerStrokeWidth: _this3.props.hoverAnswerStrokeWidth,
400
- gridColumns: gridColumns,
401
- key: "choice-".concat(index),
402
- choice: choice,
403
- index: index,
404
- choicesLength: choices.length,
405
- showCorrect: showCorrect,
406
- isEvaluateMode: isEvaluateMode,
407
- choiceMode: choiceMode,
408
- disabled: disabled,
409
- tagName: partLabel ? "group-".concat(partLabel) : 'group',
410
- onChoiceChanged: _this3.handleChange,
411
- hideTick: choice.hideTick,
412
- checked: _this3.getChecked(choice),
413
- correctness: isEvaluateMode ? _this3.getCorrectness(choice) : undefined,
414
- displayKey: _this3.indexToSymbol(index),
415
- isSelectionButtonBelow: isSelectionButtonBelow
416
- });
417
- }))), choiceMode === 'checkbox' && selections < minSelections && /*#__PURE__*/_react["default"].createElement("div", {
418
- className: classes.errorText
419
- }, getMultipleChoiceMinSelectionErrorMessage()), choiceMode === 'checkbox' && maxSelectionsErrorState && /*#__PURE__*/_react["default"].createElement("div", {
420
- className: classes.errorText
421
- }, translator.t("translation:multipleChoice:maxSelections_".concat(maxSelections === 1 ? 'one' : 'other'), {
422
- lng: language,
423
- maxSelections: maxSelections
424
- })));
425
- }
426
- }]);
427
- return MultipleChoice;
428
- }(_react["default"].Component);
429
-
293
+ }, teacherInstructionsDiv) : teacherInstructionsDiv), /*#__PURE__*/_react.default.createElement(StyledFieldset, {
294
+ tabIndex: 0,
295
+ onFocus: this.handleGroupFocus,
296
+ role: choiceMode === 'radio' ? 'radiogroup' : 'group'
297
+ }, /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
298
+ className: "prompt",
299
+ defaultClassName: "prompt",
300
+ prompt: prompt,
301
+ tagName: 'legend',
302
+ autoplayAudioEnabled: autoplayAudioEnabled,
303
+ customAudioButton: customAudioButton
304
+ }), !(options && alwaysShowCorrect) && /*#__PURE__*/_react.default.createElement(_correctAnswerToggle.default, {
305
+ show: showCorrectAnswerToggle,
306
+ toggled: showCorrect,
307
+ onToggle: this.onToggle.bind(this),
308
+ language: language
309
+ }), /*#__PURE__*/_react.default.createElement(LayoutComponent, {
310
+ style: columnsStyle
311
+ }, choices.map((choice, index) => /*#__PURE__*/_react.default.createElement(_choice.default, {
312
+ autoFocusRef: index === 0 ? this.firstInputRef : null,
313
+ choicesLayout: this.props.choicesLayout,
314
+ selectedAnswerBackgroundColor: this.props.selectedAnswerBackgroundColor,
315
+ selectedAnswerStrokeColor: this.props.selectedAnswerStrokeColor,
316
+ selectedAnswerStrokeWidth: this.props.selectedAnswerStrokeWidth,
317
+ hoverAnswerBackgroundColor: this.props.hoverAnswerBackgroundColor,
318
+ hoverAnswerStrokeColor: this.props.hoverAnswerStrokeColor,
319
+ hoverAnswerStrokeWidth: this.props.hoverAnswerStrokeWidth,
320
+ gridColumns: gridColumns,
321
+ key: `choice-${index}`,
322
+ choice: choice,
323
+ index: index,
324
+ choicesLength: choices.length,
325
+ showCorrect: showCorrect,
326
+ isEvaluateMode: isEvaluateMode,
327
+ choiceMode: choiceMode,
328
+ disabled: disabled,
329
+ tagName: partLabel ? `group-${partLabel}` : 'group',
330
+ onChoiceChanged: this.handleChange,
331
+ hideTick: choice.hideTick,
332
+ checked: this.getChecked(choice),
333
+ correctness: isEvaluateMode ? this.getCorrectness(choice) : undefined,
334
+ displayKey: this.indexToSymbol(index),
335
+ isSelectionButtonBelow: isSelectionButtonBelow
336
+ })))), choiceMode === 'checkbox' && selections < minSelections && /*#__PURE__*/_react.default.createElement(ErrorText, null, getMultipleChoiceMinSelectionErrorMessage()), choiceMode === 'checkbox' && maxSelectionsErrorState && /*#__PURE__*/_react.default.createElement(ErrorText, null, translator.t(`translation:multipleChoice:maxSelections_${maxSelections === 1 ? 'one' : 'other'}`, {
337
+ lng: language,
338
+ maxSelections
339
+ })));
340
+ }
341
+ }
430
342
  exports.MultipleChoice = MultipleChoice;
431
- (0, _defineProperty2["default"])(MultipleChoice, "propTypes", {
432
- className: _propTypes["default"].string,
433
- mode: _propTypes["default"].oneOf(['gather', 'view', 'evaluate']),
434
- choiceMode: _propTypes["default"].oneOf(['radio', 'checkbox']),
435
- keyMode: _propTypes["default"].oneOf(['numbers', 'letters', 'none']),
436
- choices: _propTypes["default"].array,
437
- partLabel: _propTypes["default"].string,
438
- prompt: _propTypes["default"].string,
439
- teacherInstructions: _propTypes["default"].string,
440
- session: _propTypes["default"].object,
441
- disabled: _propTypes["default"].bool,
442
- onChoiceChanged: _propTypes["default"].func,
443
- responseCorrect: _propTypes["default"].bool,
444
- classes: _propTypes["default"].object.isRequired,
445
- correctResponse: _propTypes["default"].array,
446
- choicesLayout: _propTypes["default"].oneOf(['vertical', 'grid', 'horizontal']),
447
- gridColumns: _propTypes["default"].string,
448
- alwaysShowCorrect: _propTypes["default"].bool,
449
- animationsDisabled: _propTypes["default"].bool,
450
- language: _propTypes["default"].string,
451
- selectedAnswerBackgroundColor: _propTypes["default"].string,
452
- selectedAnswerStrokeColor: _propTypes["default"].string,
453
- selectedAnswerStrokeWidth: _propTypes["default"].string,
454
- hoverAnswerBackgroundColor: _propTypes["default"].string,
455
- hoverAnswerStrokeColor: _propTypes["default"].string,
456
- hoverAnswerStrokeWidth: _propTypes["default"].string,
457
- onShowCorrectToggle: _propTypes["default"].func,
458
- isSelectionButtonBelow: _propTypes["default"].bool,
459
- minSelections: _propTypes["default"].number,
460
- maxSelections: _propTypes["default"].number,
461
- autoplayAudioEnabled: _propTypes["default"].bool,
343
+ (0, _defineProperty2.default)(MultipleChoice, "propTypes", {
344
+ className: _propTypes.default.string,
345
+ mode: _propTypes.default.oneOf(['gather', 'view', 'evaluate']),
346
+ choiceMode: _propTypes.default.oneOf(['radio', 'checkbox']),
347
+ keyMode: _propTypes.default.oneOf(['numbers', 'letters', 'none']),
348
+ choices: _propTypes.default.array,
349
+ partLabel: _propTypes.default.string,
350
+ prompt: _propTypes.default.string,
351
+ teacherInstructions: _propTypes.default.string,
352
+ session: _propTypes.default.object,
353
+ disabled: _propTypes.default.bool,
354
+ onChoiceChanged: _propTypes.default.func,
355
+ responseCorrect: _propTypes.default.bool,
356
+ correctResponse: _propTypes.default.array,
357
+ choicesLayout: _propTypes.default.oneOf(['vertical', 'grid', 'horizontal']),
358
+ gridColumns: _propTypes.default.string,
359
+ alwaysShowCorrect: _propTypes.default.bool,
360
+ animationsDisabled: _propTypes.default.bool,
361
+ language: _propTypes.default.string,
362
+ selectedAnswerBackgroundColor: _propTypes.default.string,
363
+ selectedAnswerStrokeColor: _propTypes.default.string,
364
+ selectedAnswerStrokeWidth: _propTypes.default.string,
365
+ hoverAnswerBackgroundColor: _propTypes.default.string,
366
+ hoverAnswerStrokeColor: _propTypes.default.string,
367
+ hoverAnswerStrokeWidth: _propTypes.default.string,
368
+ onShowCorrectToggle: _propTypes.default.func,
369
+ isSelectionButtonBelow: _propTypes.default.bool,
370
+ minSelections: _propTypes.default.number,
371
+ maxSelections: _propTypes.default.number,
372
+ autoplayAudioEnabled: _propTypes.default.bool,
462
373
  customAudioButton: {
463
- playImage: _propTypes["default"].string,
464
- pauseImage: _propTypes["default"].string
374
+ playImage: _propTypes.default.string,
375
+ pauseImage: _propTypes.default.string
465
376
  },
466
- options: _propTypes["default"].object
377
+ options: _propTypes.default.object
467
378
  });
468
379
  MultipleChoice.defaultProps = {
469
380
  session: {
470
381
  value: []
471
382
  }
472
383
  };
473
-
474
- var _default = (0, _styles.withStyles)(styles)(MultipleChoice);
475
-
476
- exports["default"] = _default;
477
- //# sourceMappingURL=multiple-choice.js.map
384
+ var _default = exports.default = MultipleChoice;
385
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_correctAnswerToggle","_classnames","_styles","_Box","_renderUi","_translator","_choice","translator","Translator","MainContainer","styled","Box","color","text","backgroundColor","background","position","border","PartLabel","theme","display","fontSize","margin","fontWeight","paddingBottom","spacing","TeacherInstructions","marginBottom","HorizontalLayout","flexDirection","flexWrap","GridLayout","StyledFieldset","padding","minWidth","outline","SrOnly","left","top","width","height","overflow","ErrorText","typography","palette","error","main","paddingTop","MultipleChoice","React","Component","constructor","props","_defineProperty2","default","event","value","checked","target","maxSelections","onChoiceChanged","session","length","setState","maxSelectionsErrorState","selected","selector","mode","showCorrect","state","onShowCorrectToggle","choice","isCorrect","correct","isChecked","isSelected","undefined","e","fieldset","currentTarget","activeEl","document","activeElement","contains","relatedTarget","compareDocumentPosition","Node","DOCUMENT_POSITION_PRECEDING","firstInputRef","current","focus","options","alwaysShowCorrect","onToggle","bind","createRef","sessionValue","indexOf","UNSAFE_componentWillReceiveProps","nextProps","correctResponse","indexToSymbol","index","keyMode","String","fromCharCode","toUpperCase","getChecked","isPrintMode","isEvaluateMode","renderHeading","choiceMode","createElement","render","disabled","className","choices","gridColumns","partLabel","prompt","responseCorrect","teacherInstructions","animationsDisabled","language","isSelectionButtonBelow","minSelections","autoplayAudioEnabled","customAudioButton","showCorrectAnswerToggle","columnsStyle","gridTemplateColumns","selections","teacherInstructionsDiv","PreviewPrompt","tagName","defaultClassName","getMultipleChoiceMinSelectionErrorMessage","t","lng","LayoutComponent","choicesLayout","id","classNames","Collapsible","labels","hidden","visible","tabIndex","onFocus","handleGroupFocus","role","show","toggled","style","map","autoFocusRef","selectedAnswerBackgroundColor","selectedAnswerStrokeColor","selectedAnswerStrokeWidth","hoverAnswerBackgroundColor","hoverAnswerStrokeColor","hoverAnswerStrokeWidth","key","choicesLength","handleChange","hideTick","correctness","getCorrectness","displayKey","exports","PropTypes","string","oneOf","array","object","bool","func","number","playImage","pauseImage","defaultProps","_default"],"sources":["../src/multiple-choice.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport CorrectAnswerToggle from '@pie-lib/correct-answer-toggle';\nimport classNames from 'classnames';\nimport { styled } from '@mui/material/styles';\nimport Box from '@mui/material/Box';\nimport { color, Collapsible, PreviewPrompt } from '@pie-lib/render-ui';\nimport Translator from '@pie-lib/translator';\n\nimport Choice from './choice';\n\nconst { translator } = Translator;\n\nconst MainContainer = styled(Box)({\n  color: color.text(),\n  backgroundColor: color.background(),\n  '& *': {\n    '-webkit-font-smoothing': 'antialiased',\n  },\n  position: 'relative',\n  // remove border from legend tags inside main to override the OT default styles\n  '& legend': {\n    border: 'none !important',\n  },\n});\n\nconst PartLabel = styled('h2')(({ theme }) => ({\n  display: 'block',\n  fontSize: 'inherit',\n  margin: '0',\n  fontWeight: 'normal',\n  paddingBottom: theme.spacing(2),\n}));\n\nconst TeacherInstructions = styled(Box)(({ theme }) => ({\n  marginBottom: theme.spacing(2),\n}));\n\nconst HorizontalLayout = styled(Box)({\n  display: 'flex',\n  flexDirection: 'row',\n  flexWrap: 'wrap',\n});\n\nconst GridLayout = styled(Box)({\n  display: 'grid',\n});\n\nconst StyledFieldset = styled('fieldset')({\n  border: '0px',\n  padding: '0.01em 0 0 0',\n  margin: '0px',\n  minWidth: '0px',\n  '&:focus': {\n    outline: 'none',\n  },\n});\n\nconst SrOnly = styled('h3')({\n  position: 'absolute',\n  left: '-10000px',\n  top: 'auto',\n  width: '1px',\n  height: '1px',\n  overflow: 'hidden',\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\nexport class MultipleChoice extends React.Component {\n  static propTypes = {\n    className: PropTypes.string,\n    mode: PropTypes.oneOf(['gather', 'view', 'evaluate']),\n    choiceMode: PropTypes.oneOf(['radio', 'checkbox']),\n    keyMode: PropTypes.oneOf(['numbers', 'letters', 'none']),\n    choices: PropTypes.array,\n    partLabel: PropTypes.string,\n    prompt: PropTypes.string,\n    teacherInstructions: PropTypes.string,\n    session: PropTypes.object,\n    disabled: PropTypes.bool,\n    onChoiceChanged: PropTypes.func,\n    responseCorrect: PropTypes.bool,\n    correctResponse: PropTypes.array,\n    choicesLayout: PropTypes.oneOf(['vertical', 'grid', 'horizontal']),\n    gridColumns: PropTypes.string,\n    alwaysShowCorrect: PropTypes.bool,\n    animationsDisabled: PropTypes.bool,\n    language: PropTypes.string,\n    selectedAnswerBackgroundColor: PropTypes.string,\n    selectedAnswerStrokeColor: PropTypes.string,\n    selectedAnswerStrokeWidth: PropTypes.string,\n    hoverAnswerBackgroundColor: PropTypes.string,\n    hoverAnswerStrokeColor: PropTypes.string,\n    hoverAnswerStrokeWidth: PropTypes.string,\n    onShowCorrectToggle: PropTypes.func,\n    isSelectionButtonBelow: PropTypes.bool,\n    minSelections: PropTypes.number,\n    maxSelections: PropTypes.number,\n    autoplayAudioEnabled: PropTypes.bool,\n    customAudioButton: {\n      playImage: PropTypes.string,\n      pauseImage: PropTypes.string,\n    },\n    options: PropTypes.object,\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      showCorrect: (this.props.options && this.props.alwaysShowCorrect) || false,\n      maxSelectionsErrorState: false,\n    };\n\n    this.onToggle = this.onToggle.bind(this);\n    this.firstInputRef = React.createRef();\n  }\n\n  isSelected(value) {\n    const sessionValue = this.props.session && this.props.session.value;\n\n    return sessionValue && sessionValue.indexOf && sessionValue.indexOf(value) >= 0;\n  }\n\n  // handleChange was added for accessibility. Please see comments and videos from PD-2441.\n  handleChange = (event) => {\n    const { value, checked } = event.target;\n    const { maxSelections, onChoiceChanged, session } = this.props;\n\n    if (session.value && session.value.length >= maxSelections) {\n      // show/hide max selections error when user select/deselect an answer\n      this.setState({ maxSelectionsErrorState: checked });\n\n      if (checked) {\n        // prevent selecting more answers\n        return;\n      }\n    }\n\n    onChoiceChanged({ value, selected: checked, selector: 'Mouse' });\n  };\n\n  onToggle = () => {\n    if (this.props.mode === 'evaluate') {\n      this.setState({ showCorrect: !this.state.showCorrect }, () => {\n        if (this.props.onShowCorrectToggle) {\n          this.props.onShowCorrectToggle();\n        }\n      });\n    }\n  };\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    if (!nextProps.correctResponse && this.state.showCorrect !== false) {\n      this.setState({ showCorrect: false }, () => {\n        if (this.props.onShowCorrectToggle) {\n          this.props.onShowCorrectToggle();\n        }\n      });\n    }\n\n    if (nextProps.options && nextProps.alwaysShowCorrect && this.state.showCorrect !== true) {\n      this.setState({ showCorrect: true }, () => {\n        if (this.props.onShowCorrectToggle) {\n          this.props.onShowCorrectToggle();\n        }\n      });\n    }\n  }\n\n  indexToSymbol(index) {\n    if (this.props.keyMode === 'numbers') {\n      return `${index + 1}`;\n    }\n\n    if (this.props.keyMode === 'letters') {\n      return String.fromCharCode(97 + index).toUpperCase();\n    }\n\n    return '';\n  }\n\n  getCorrectness = (choice = {}) => {\n    const isCorrect = choice.correct;\n    const isChecked = this.isSelected(choice.value);\n\n    if (this.state.showCorrect) {\n      return isCorrect ? 'correct' : undefined;\n    }\n\n    if (isCorrect) {\n      if (isChecked) {\n        // A correct answer is selected: marked with a green checkmark\n        return 'correct';\n      } else {\n        // A correct answer is NOT selected: marked with an orange X\n        return 'incorrect';\n      }\n    } else {\n      if (isChecked) {\n        // An incorrect answer is selected: marked with an orange X\n        return 'incorrect';\n      } else {\n        // An incorrect answer is NOT selected: not marked\n        return undefined;\n      }\n    }\n  };\n\n  getChecked(choice) {\n    // check for print context: options prop is passed from print.js and alwaysShowCorrect is true\n    const isPrintMode = this.props.options && this.props.alwaysShowCorrect;\n\n    if (isPrintMode) {\n      return choice.correct || false;\n    }\n\n    // evaluate mode with show correct toggled\n    const isEvaluateMode = this.state.showCorrect && this.props.mode === 'evaluate';\n\n    if (isEvaluateMode) {\n      return choice.correct || false;\n    }\n\n    // default behavior: show what the user has selected\n    return this.isSelected(choice.value);\n  }\n\n  // renderHeading function was added for accessibility.\n  renderHeading() {\n    const { mode, choiceMode } = this.props;\n\n    if (mode !== 'gather') {\n      return null;\n    }\n\n    return choiceMode === 'radio' ? (\n      <SrOnly>Multiple Choice Question</SrOnly>\n    ) : (\n      <SrOnly>Multiple Select Question</SrOnly>\n    );\n  }\n\n  handleGroupFocus = (e) => {\n    const fieldset = e.currentTarget;\n    const activeEl = document.activeElement;\n\n    if (fieldset.contains(activeEl) && activeEl !== fieldset) {\n      return;\n    }\n\n    // Only focus the first input if user is tabbing forward\n    if (!e.relatedTarget || fieldset.compareDocumentPosition(e.relatedTarget) & Node.DOCUMENT_POSITION_PRECEDING) {\n      if (this.firstInputRef?.current) {\n        this.firstInputRef.current.focus();\n      }\n    }\n  };\n\n  render() {\n    const {\n      mode,\n      disabled,\n      className,\n      choices = [],\n      choiceMode,\n      gridColumns,\n      partLabel,\n      prompt,\n      responseCorrect,\n      teacherInstructions,\n      alwaysShowCorrect,\n      animationsDisabled,\n      language,\n      isSelectionButtonBelow,\n      minSelections,\n      maxSelections,\n      autoplayAudioEnabled,\n      session,\n      customAudioButton,\n      options,\n    } = this.props;\n    const { showCorrect, maxSelectionsErrorState } = this.state;\n    const isEvaluateMode = mode === 'evaluate';\n    const showCorrectAnswerToggle = isEvaluateMode && !responseCorrect;\n    const columnsStyle = gridColumns > 1 ? { gridTemplateColumns: `repeat(${gridColumns}, 1fr)` } : undefined;\n    const selections = (session.value && session.value.length) || 0;\n\n    const teacherInstructionsDiv = (\n      <PreviewPrompt\n        tagName=\"div\"\n        className=\"prompt\"\n        defaultClassName=\"teacher-instructions\"\n        prompt={teacherInstructions}\n      />\n    );\n\n    const getMultipleChoiceMinSelectionErrorMessage = () => {\n      if (minSelections && maxSelections) {\n        return minSelections === maxSelections\n          ? translator.t('translation:multipleChoice:minmaxSelections_equal', { lng: language, minSelections })\n          : translator.t('translation:multipleChoice:minmaxSelections_range', {\n              lng: language,\n              minSelections,\n              maxSelections,\n            });\n      }\n\n      if (minSelections) {\n        return translator.t('translation:multipleChoice:minSelections', { lng: language, minSelections });\n      }\n\n      return '';\n    };\n\n    const LayoutComponent = this.props.choicesLayout === 'grid'\n      ? GridLayout\n      : this.props.choicesLayout === 'horizontal'\n        ? HorizontalLayout\n        : Box;\n\n    return (\n      <MainContainer id={'main-container'} className={classNames(className, 'multiple-choice')}>\n        {partLabel && <PartLabel>{partLabel}</PartLabel>}\n\n        {this.renderHeading()}\n\n        {teacherInstructions && (\n          <TeacherInstructions>\n            {!animationsDisabled ? (\n              <Collapsible\n                labels={{\n                  hidden: 'Show Teacher Instructions',\n                  visible: 'Hide Teacher Instructions',\n                }}\n              >\n                {teacherInstructionsDiv}\n              </Collapsible>\n            ) : (\n              teacherInstructionsDiv\n            )}\n          </TeacherInstructions>\n        )}\n\n        <StyledFieldset\n          tabIndex={0}\n          onFocus={this.handleGroupFocus}\n          role={choiceMode === 'radio' ? 'radiogroup' : 'group'}\n        >\n          <PreviewPrompt\n            className=\"prompt\"\n            defaultClassName=\"prompt\"\n            prompt={prompt}\n            tagName={'legend'}\n            autoplayAudioEnabled={autoplayAudioEnabled}\n            customAudioButton={customAudioButton}\n          />\n\n          {!(options && alwaysShowCorrect) && (\n            <CorrectAnswerToggle\n              show={showCorrectAnswerToggle}\n              toggled={showCorrect}\n              onToggle={this.onToggle.bind(this)}\n              language={language}\n            />\n          )}\n\n          <LayoutComponent style={columnsStyle}>\n            {choices.map((choice, index) => (\n              <Choice\n                autoFocusRef={index === 0 ? this.firstInputRef : null}\n                choicesLayout={this.props.choicesLayout}\n                selectedAnswerBackgroundColor={this.props.selectedAnswerBackgroundColor}\n                selectedAnswerStrokeColor={this.props.selectedAnswerStrokeColor}\n                selectedAnswerStrokeWidth={this.props.selectedAnswerStrokeWidth}\n                hoverAnswerBackgroundColor={this.props.hoverAnswerBackgroundColor}\n                hoverAnswerStrokeColor={this.props.hoverAnswerStrokeColor}\n                hoverAnswerStrokeWidth={this.props.hoverAnswerStrokeWidth}\n                gridColumns={gridColumns}\n                key={`choice-${index}`}\n                choice={choice}\n                index={index}\n                choicesLength={choices.length}\n                showCorrect={showCorrect}\n                isEvaluateMode={isEvaluateMode}\n                choiceMode={choiceMode}\n                disabled={disabled}\n                tagName={partLabel ? `group-${partLabel}` : 'group'}\n                onChoiceChanged={this.handleChange}\n                hideTick={choice.hideTick}\n                checked={this.getChecked(choice)}\n                correctness={isEvaluateMode ? this.getCorrectness(choice) : undefined}\n                displayKey={this.indexToSymbol(index)}\n                isSelectionButtonBelow={isSelectionButtonBelow}\n              />\n            ))}\n          </LayoutComponent>\n        </StyledFieldset>\n\n        {choiceMode === 'checkbox' && selections < minSelections && (\n          <ErrorText>{getMultipleChoiceMinSelectionErrorMessage()}</ErrorText>\n        )}\n        {choiceMode === 'checkbox' && maxSelectionsErrorState && (\n          <ErrorText>\n            {translator.t(`translation:multipleChoice:maxSelections_${maxSelections === 1 ? 'one' : 'other'}`, {\n              lng: language,\n              maxSelections,\n            })}\n          </ErrorText>\n        )}\n      </MainContainer>\n    );\n  }\n}\n\nMultipleChoice.defaultProps = {\n  session: {\n    value: [],\n  },\n};\n\nexport default MultipleChoice;\n"],"mappings":"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","ignoreList":[]}