@pie-element/multiple-choice 9.18.0 → 9.18.1-beta.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 (42) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/configure/CHANGELOG.md +32 -0
  3. package/configure/lib/__tests__/root.test.js +271 -0
  4. package/configure/lib/index.js +1 -1
  5. package/configure/lib/index.js.map +1 -1
  6. package/configure/lib/main.js +6 -6
  7. package/configure/lib/main.js.map +1 -1
  8. package/configure/package.json +4 -2
  9. package/controller/CHANGELOG.md +32 -0
  10. package/controller/lib/__tests__/index.test.js +867 -0
  11. package/controller/lib/__tests__/utils.test.js +8 -0
  12. package/controller/lib/index.js +1 -1
  13. package/controller/lib/index.js.map +1 -1
  14. package/controller/package.json +2 -2
  15. package/docs/demo/pie.manifest.json +11 -0
  16. package/lib/__tests__/choice-input-test.js +131 -0
  17. package/lib/__tests__/index-test.js +183 -0
  18. package/lib/__tests__/key-events-test.js +98 -0
  19. package/lib/__tests__/multiple-choice-test.js +235 -0
  20. package/lib/__tests__/session-updater-test.js +72 -0
  21. package/lib/choice-input.js +1 -1
  22. package/lib/choice-input.js.map +1 -1
  23. package/lib/feedback-tick.js +1 -1
  24. package/lib/feedback-tick.js.map +1 -1
  25. package/lib/index.js +2 -2
  26. package/lib/index.js.map +1 -1
  27. package/lib/main.js +1 -1
  28. package/lib/main.js.map +1 -1
  29. package/lib/multiple-choice.js +4 -4
  30. package/lib/multiple-choice.js.map +1 -1
  31. package/lib/print.js +1 -1
  32. package/lib/print.js.map +1 -1
  33. package/package.json +6 -3
  34. package/module/configure.js +0 -11070
  35. package/module/controller.js +0 -3601
  36. package/module/demo.js +0 -86
  37. package/module/element.js +0 -13448
  38. package/module/index.html +0 -21
  39. package/module/manifest.json +0 -14
  40. package/module/print-demo.js +0 -124
  41. package/module/print.html +0 -18
  42. package/module/print.js +0 -13204
package/CHANGELOG.md CHANGED
@@ -3,6 +3,38 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [9.18.1-beta.1](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice@9.18.0...@pie-element/multiple-choice@9.18.1-beta.1) (2025-07-25)
7
+
8
+ **Note:** Version bump only for package @pie-element/multiple-choice
9
+
10
+
11
+
12
+
13
+
14
+ ## [9.18.1-beta.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice@9.18.0...@pie-element/multiple-choice@9.18.1-beta.0) (2025-07-25)
15
+
16
+ **Note:** Version bump only for package @pie-element/multiple-choice
17
+
18
+
19
+
20
+
21
+
22
+ ## [9.18.1-beta.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice@9.18.0...@pie-element/multiple-choice@9.18.1-beta.0) (2025-07-20)
23
+
24
+ **Note:** Version bump only for package @pie-element/multiple-choice
25
+
26
+
27
+
28
+
29
+
30
+ # [9.19.0-beta.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice@9.18.0...@pie-element/multiple-choice@9.19.0-beta.0) (2025-07-19)
31
+
32
+ **Note:** Version bump only for package @pie-element/multiple-choice
33
+
34
+
35
+
36
+
37
+
6
38
  # [9.18.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice@9.17.0...@pie-element/multiple-choice@9.18.0) (2025-07-18)
7
39
 
8
40
 
@@ -3,6 +3,38 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [7.8.0-beta.3](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-configure@7.7.0...@pie-element/multiple-choice-configure@7.8.0-beta.3) (2025-07-25)
7
+
8
+ **Note:** Version bump only for package @pie-element/multiple-choice-configure
9
+
10
+
11
+
12
+
13
+
14
+ # [7.8.0-beta.2](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-configure@7.7.0...@pie-element/multiple-choice-configure@7.8.0-beta.2) (2025-07-25)
15
+
16
+ **Note:** Version bump only for package @pie-element/multiple-choice-configure
17
+
18
+
19
+
20
+
21
+
22
+ # [7.8.0-beta.1](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-configure@7.7.0...@pie-element/multiple-choice-configure@7.8.0-beta.1) (2025-07-20)
23
+
24
+ **Note:** Version bump only for package @pie-element/multiple-choice-configure
25
+
26
+
27
+
28
+
29
+
30
+ # [7.8.0-beta.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-configure@7.7.0...@pie-element/multiple-choice-configure@7.8.0-beta.0) (2025-07-19)
31
+
32
+ **Note:** Version bump only for package @pie-element/multiple-choice-configure
33
+
34
+
35
+
36
+
37
+
6
38
  # [7.7.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-configure@7.6.10...@pie-element/multiple-choice-configure@7.7.0) (2025-07-18)
7
39
 
8
40
 
@@ -0,0 +1,271 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
6
+
7
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
8
+
9
+ var _enzyme = require("enzyme");
10
+
11
+ var _react = _interopRequireDefault(require("react"));
12
+
13
+ var _main = require("../main");
14
+
15
+ var _defaults = _interopRequireDefault(require("../defaults"));
16
+
17
+ var _configUi = require("@pie-lib/config-ui");
18
+
19
+ var _index = _interopRequireDefault(require("../index"));
20
+
21
+ 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; }
22
+
23
+ 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; }
24
+
25
+ jest.mock('@pie-lib/config-ui', function () {
26
+ return {
27
+ choiceUtils: {
28
+ firstAvailableIndex: jest.fn(),
29
+ normalizeChoices: jest.fn(function (model) {
30
+ return model;
31
+ })
32
+ },
33
+ settings: {
34
+ Panel: function Panel(props) {
35
+ return /*#__PURE__*/_react["default"].createElement("div", props);
36
+ },
37
+ toggle: jest.fn(),
38
+ radio: jest.fn()
39
+ }
40
+ };
41
+ });
42
+
43
+ var model = function model(extras) {
44
+ return _objectSpread(_objectSpread({}, _defaults["default"].model), {}, {
45
+ prompt: 'Which of these northern European countries are EU members?',
46
+ choiceMode: 'checkbox',
47
+ choices: [{
48
+ correct: true,
49
+ value: 'sweden',
50
+ label: 'Sweden',
51
+ feedback: {
52
+ type: 'none',
53
+ value: ''
54
+ }
55
+ }, {
56
+ value: 'iceland',
57
+ label: 'Iceland',
58
+ feedback: {
59
+ type: 'none',
60
+ value: ''
61
+ }
62
+ }, {
63
+ value: 'norway',
64
+ label: 'Norway',
65
+ feedback: {
66
+ type: 'none',
67
+ value: ''
68
+ }
69
+ }, {
70
+ correct: true,
71
+ value: 'finland',
72
+ label: 'Finland',
73
+ feedback: {
74
+ type: 'none',
75
+ value: ''
76
+ }
77
+ }],
78
+ partialScoring: false,
79
+ configure: {}
80
+ }, extras);
81
+ };
82
+
83
+ describe('Main', function () {
84
+ var w;
85
+ var onModelChanged = jest.fn();
86
+ var onConfigurationChanged = jest.fn();
87
+ var initialModel = model();
88
+
89
+ var wrapper = function wrapper(extras) {
90
+ var defaults = {
91
+ onModelChanged: onModelChanged,
92
+ onConfigurationChanged: onConfigurationChanged,
93
+ classes: {},
94
+ model: model()
95
+ };
96
+
97
+ var props = _objectSpread(_objectSpread({}, defaults), extras);
98
+
99
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_main.Main, props));
100
+ };
101
+
102
+ describe('snapshot', function () {
103
+ it('renders with choicePrefix="numbers"', function () {
104
+ w = wrapper({
105
+ model: model({
106
+ choicePrefix: 'numbers'
107
+ })
108
+ });
109
+ expect(w).toMatchSnapshot();
110
+ });
111
+ it('renders with choicePrefix="letters" as default', function () {
112
+ w = wrapper();
113
+ expect(w).toMatchSnapshot();
114
+ });
115
+ });
116
+ describe('logic', function () {
117
+ beforeEach(function () {
118
+ w = wrapper();
119
+ });
120
+ describe('onRemoveChoice', function () {
121
+ it('removes choice', function () {
122
+ w.instance().onRemoveChoice(0);
123
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, initialModel), {}, {
124
+ choices: initialModel.choices.slice(1)
125
+ }));
126
+ });
127
+ });
128
+ describe('createDefaultModel', function () {
129
+ it('sets choicesLayout: horizontal if verticalMode: false', function () {
130
+ var m = _index["default"].createDefaultModel(model({
131
+ verticalMode: false,
132
+ choicesLayout: undefined
133
+ }));
134
+
135
+ expect(m.choicesLayout).toEqual('horizontal');
136
+ });
137
+ it('sets choicesLayout: vertical if verticalMode: true', function () {
138
+ var m = _index["default"].createDefaultModel(model({
139
+ verticalMode: true,
140
+ choicesLayout: undefined
141
+ }));
142
+
143
+ expect(m.choicesLayout).toEqual('vertical');
144
+ });
145
+ it('sets choicesLayout: grid if verticalMode: true && choicesLayout: grid', function () {
146
+ var m = _index["default"].createDefaultModel(model({
147
+ verticalMode: true,
148
+ choicesLayout: 'grid'
149
+ }));
150
+
151
+ expect(m.choicesLayout).toEqual('grid');
152
+ });
153
+ it('sets choicesLayout: vertical', function () {
154
+ var m = _index["default"].createDefaultModel(model());
155
+
156
+ expect(m.choicesLayout).toEqual('vertical');
157
+ });
158
+ });
159
+ describe('onAddChoice', function () {
160
+ it('adds a choice', function () {
161
+ w.instance().onAddChoice();
162
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, initialModel), {}, {
163
+ choices: [].concat((0, _toConsumableArray2["default"])(initialModel.choices), [{
164
+ label: '',
165
+ value: _configUi.choiceUtils.firstAvailableIndex(initialModel.choices.map(function (c) {
166
+ return c.value;
167
+ }), 0),
168
+ feedback: {
169
+ type: 'none'
170
+ }
171
+ }])
172
+ }));
173
+ });
174
+ });
175
+ describe('onChoiceChanged', function () {
176
+ describe('checkbox', function () {
177
+ it('changes choice (there are 2 true values)', function () {
178
+ var newChoices = (0, _toConsumableArray2["default"])(model().choices);
179
+ var choice = {
180
+ correct: true,
181
+ value: 'iceland',
182
+ label: 'Iceland',
183
+ feedback: {
184
+ type: 'none',
185
+ value: ''
186
+ }
187
+ };
188
+ w.instance().onChoiceChanged(1, choice);
189
+ newChoices[1].correct = true;
190
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, initialModel), {}, {
191
+ choices: newChoices
192
+ }));
193
+ });
194
+ });
195
+ describe('radio', function () {
196
+ it('changes choice (there is only one true value)', function () {
197
+ var choice = {
198
+ correct: true,
199
+ value: 'iceland',
200
+ label: 'Iceland',
201
+ feedback: {
202
+ type: 'none',
203
+ value: ''
204
+ }
205
+ };
206
+
207
+ var newModel = _objectSpread(_objectSpread({}, initialModel), {}, {
208
+ choiceMode: 'radio',
209
+ choices: initialModel.choices.slice(0, 2)
210
+ });
211
+
212
+ w = wrapper({
213
+ model: newModel
214
+ });
215
+ w.instance().onChoiceChanged(1, choice);
216
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, newModel), {}, {
217
+ choices: [{
218
+ correct: false,
219
+ value: 'sweden',
220
+ label: 'Sweden',
221
+ feedback: {
222
+ type: 'none',
223
+ value: ''
224
+ }
225
+ }, {
226
+ correct: true,
227
+ value: 'iceland',
228
+ label: 'Iceland',
229
+ feedback: {
230
+ type: 'none',
231
+ value: ''
232
+ }
233
+ }]
234
+ }));
235
+ });
236
+ });
237
+ });
238
+ describe('onPromptChanged', function () {
239
+ it('changes prompt', function () {
240
+ w.instance().onPromptChanged('New Prompt');
241
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, initialModel), {}, {
242
+ prompt: 'New Prompt'
243
+ }));
244
+ });
245
+ });
246
+ describe('onTeacherInstructionsChanged', function () {
247
+ it('changes teacher instructions', function () {
248
+ w.instance().onTeacherInstructionsChanged('New Teacher Instructions');
249
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, initialModel), {}, {
250
+ teacherInstructions: 'New Teacher Instructions'
251
+ }));
252
+ });
253
+ });
254
+ describe('onModelChanged', function () {
255
+ it('changes choice and makes incorrect all other choices', function () {
256
+ w.instance().onModelChanged(_objectSpread(_objectSpread({}, initialModel), {}, {
257
+ choiceMode: 'radio'
258
+ }), 'choiceMode');
259
+ var expectedChoices = model().choices;
260
+ expectedChoices.forEach(function (eC, index) {
261
+ eC.correct = index === 0;
262
+ });
263
+ expect(onModelChanged).toBeCalledWith(_objectSpread(_objectSpread({}, initialModel), {}, {
264
+ choiceMode: 'radio',
265
+ choices: expectedChoices
266
+ }), true);
267
+ });
268
+ });
269
+ });
270
+ });
271
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/root.test.jsx"],"names":["jest","mock","choiceUtils","firstAvailableIndex","fn","normalizeChoices","model","settings","Panel","props","toggle","radio","extras","defaults","prompt","choiceMode","choices","correct","value","label","feedback","type","partialScoring","configure","describe","w","onModelChanged","onConfigurationChanged","initialModel","wrapper","classes","it","choicePrefix","expect","toMatchSnapshot","beforeEach","instance","onRemoveChoice","toBeCalledWith","slice","m","MultipleChoice","createDefaultModel","verticalMode","choicesLayout","undefined","toEqual","onAddChoice","utils","map","c","newChoices","choice","onChoiceChanged","newModel","onPromptChanged","onTeacherInstructionsChanged","teacherInstructions","expectedChoices","forEach","eC","index"],"mappings":"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","sourcesContent":["import { shallow } from 'enzyme';\nimport React from 'react';\n\nimport { Main } from '../main';\nimport defaults from '../defaults';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport MultipleChoice from '../index';\n\njest.mock('@pie-lib/config-ui', () => ({\n  choiceUtils: {\n    firstAvailableIndex: jest.fn(),\n    normalizeChoices: jest.fn((model) => model),\n  },\n  settings: {\n    Panel: (props) => <div {...props} />,\n    toggle: jest.fn(),\n    radio: jest.fn(),\n  },\n}));\n\nconst model = (extras) => ({\n  ...defaults.model,\n  prompt: 'Which of these northern European countries are EU members?',\n  choiceMode: 'checkbox',\n  choices: [\n    {\n      correct: true,\n      value: 'sweden',\n      label: 'Sweden',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      value: 'iceland',\n      label: 'Iceland',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      value: 'norway',\n      label: 'Norway',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      correct: true,\n      value: 'finland',\n      label: 'Finland',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n  ],\n  partialScoring: false,\n  configure: {},\n  ...extras,\n});\n\ndescribe('Main', () => {\n  let w;\n  let onModelChanged = jest.fn();\n  let onConfigurationChanged = jest.fn();\n  let initialModel = model();\n\n  const wrapper = (extras) => {\n    const defaults = {\n      onModelChanged,\n      onConfigurationChanged,\n      classes: {},\n      model: model(),\n    };\n    const props = { ...defaults, ...extras };\n\n    return shallow(<Main {...props} />);\n  };\n\n  describe('snapshot', () => {\n    it('renders with choicePrefix=\"numbers\"', () => {\n      w = wrapper({ model: model({ choicePrefix: 'numbers' }) });\n      expect(w).toMatchSnapshot();\n    });\n\n    it('renders with choicePrefix=\"letters\" as default', () => {\n      w = wrapper();\n      expect(w).toMatchSnapshot();\n    });\n  });\n\n  describe('logic', () => {\n    beforeEach(() => {\n      w = wrapper();\n    });\n    describe('onRemoveChoice', () => {\n      it('removes choice', () => {\n        w.instance().onRemoveChoice(0);\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          choices: initialModel.choices.slice(1),\n        });\n      });\n    });\n\n    describe('createDefaultModel', () => {\n      it('sets choicesLayout: horizontal if verticalMode: false', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: false, choicesLayout: undefined }));\n\n        expect(m.choicesLayout).toEqual('horizontal');\n      });\n\n      it('sets choicesLayout: vertical if verticalMode: true', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: true, choicesLayout: undefined }));\n\n        expect(m.choicesLayout).toEqual('vertical');\n      });\n\n      it('sets choicesLayout: grid if verticalMode: true && choicesLayout: grid', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: true, choicesLayout: 'grid' }));\n\n        expect(m.choicesLayout).toEqual('grid');\n      });\n\n      it('sets choicesLayout: vertical', () => {\n        const m = MultipleChoice.createDefaultModel(model());\n\n        expect(m.choicesLayout).toEqual('vertical');\n      });\n    });\n\n    describe('onAddChoice', () => {\n      it('adds a choice', () => {\n        w.instance().onAddChoice();\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          choices: [\n            ...initialModel.choices,\n            {\n              label: '',\n              value: utils.firstAvailableIndex(\n                initialModel.choices.map((c) => c.value),\n                0,\n              ),\n              feedback: {\n                type: 'none',\n              },\n            },\n          ],\n        });\n      });\n    });\n\n    describe('onChoiceChanged', () => {\n      describe('checkbox', () => {\n        it('changes choice (there are 2 true values)', () => {\n          const newChoices = [...model().choices];\n          let choice = {\n            correct: true,\n            value: 'iceland',\n            label: 'Iceland',\n            feedback: {\n              type: 'none',\n              value: '',\n            },\n          };\n\n          w.instance().onChoiceChanged(1, choice);\n\n          newChoices[1].correct = true;\n\n          expect(onModelChanged).toBeCalledWith({\n            ...initialModel,\n            choices: newChoices,\n          });\n        });\n      });\n\n      describe('radio', () => {\n        it('changes choice (there is only one true value)', () => {\n          let choice = {\n            correct: true,\n            value: 'iceland',\n            label: 'Iceland',\n            feedback: {\n              type: 'none',\n              value: '',\n            },\n          };\n\n          const newModel = { ...initialModel, choiceMode: 'radio', choices: initialModel.choices.slice(0, 2) };\n          w = wrapper({ model: newModel });\n\n          w.instance().onChoiceChanged(1, choice);\n\n          expect(onModelChanged).toBeCalledWith({\n            ...newModel,\n            choices: [\n              {\n                correct: false,\n                value: 'sweden',\n                label: 'Sweden',\n                feedback: {\n                  type: 'none',\n                  value: '',\n                },\n              },\n              {\n                correct: true,\n                value: 'iceland',\n                label: 'Iceland',\n                feedback: {\n                  type: 'none',\n                  value: '',\n                },\n              },\n            ],\n          });\n        });\n      });\n    });\n\n    describe('onPromptChanged', () => {\n      it('changes prompt', () => {\n        w.instance().onPromptChanged('New Prompt');\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          prompt: 'New Prompt',\n        });\n      });\n    });\n\n    describe('onTeacherInstructionsChanged', () => {\n      it('changes teacher instructions', () => {\n        w.instance().onTeacherInstructionsChanged('New Teacher Instructions');\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          teacherInstructions: 'New Teacher Instructions',\n        });\n      });\n    });\n\n    describe('onModelChanged', () => {\n      it('changes choice and makes incorrect all other choices', () => {\n        w.instance().onModelChanged(\n          {\n            ...initialModel,\n            choiceMode: 'radio',\n          },\n          'choiceMode',\n        );\n\n        const expectedChoices = model().choices;\n\n        expectedChoices.forEach((eC, index) => {\n          eC.correct = index === 0;\n        });\n\n        expect(onModelChanged).toBeCalledWith(\n          {\n            ...initialModel,\n            choiceMode: 'radio',\n            choices: expectedChoices,\n          },\n          true,\n        );\n      });\n    });\n  });\n});\n"]}
@@ -33,7 +33,7 @@ var _pieConfigureEvents = require("@pie-framework/pie-configure-events");
33
33
 
34
34
  var _main = _interopRequireDefault(require("./main"));
35
35
 
36
- var _configUi = require("@pie-lib/pie-toolbox/config-ui");
36
+ var _configUi = require("@pie-lib/config-ui");
37
37
 
38
38
  var _defaults = _interopRequireDefault(require("lodash/defaults"));
39
39
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.js"],"names":["log","generateFormattedChoices","choices","choiceCount","length","formattedChoices","i","push","value","label","feedback","type","prepareCustomizationObject","config","model","configuration","sensibleDefaults","answerChoiceCount","MultipleChoice","_model","createDefaultModel","_configuration","onModelChanged","bind","onConfigurationChanged","s","_render","c","info","newConfiguration","language","enabled","languageChoices","options","settings","find","option","_disableSidePanel","reset","resetValue","dispatchEvent","ModelUpdatedEvent","m","dispatchModelUpdated","handler","InsertImageEvent","src","done","DeleteImageEvent","InsertSoundEvent","DeleteSoundEvent","element","React","createElement","Main","disableSidePanel","imageSupport","add","insertImage","onDeleteImage","uploadSoundSupport","insertSound","onDeleteSound","ReactDOM","render","HTMLElement","normalizedModel","utils","normalizeChoices","choicesLayout","verticalMode"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAQA;;AACA;;AACA;;AAEA;;;;;;;;;;AAEA,IAAMA,GAAG,GAAG,uBAAM,2BAAN,CAAZ;;AAEA,IAAMC,wBAAwB,GAAG,SAA3BA,wBAA2B,CAACC,OAAD,EAA8B;AAAA,MAApBC,WAAoB,uEAAN,CAAM;;AAC7D,MAAI,CAACD,OAAD,IAAYA,OAAO,CAACE,MAAR,KAAmB,CAAnC,EAAsC;AACpC,QAAIC,gBAAgB,GAAG,EAAvB;;AAEA,SAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGH,WAApB,EAAiCG,CAAC,EAAlC,EAAsC;AACpCD,MAAAA,gBAAgB,CAACE,IAAjB,CAAsB;AACpBC,QAAAA,KAAK,YAAKF,CAAL,CADe;AAEpBG,QAAAA,KAAK,EAAE,EAFa;AAGpBC,QAAAA,QAAQ,EAAE;AACRC,UAAAA,IAAI,EAAE,MADE;AAERH,UAAAA,KAAK,EAAE;AAFC;AAHU,OAAtB;AAQD;;AAED,WAAOH,gBAAP;AACD;;AAED,SAAOH,OAAP;AACD,CAnBD;;AAqBA,IAAMU,0BAA0B,GAAG,SAA7BA,0BAA6B,CAACC,MAAD,EAASC,KAAT,EAAmB;AACpD,MAAMC,aAAa,GAAG,0BAASF,MAAT,EAAiBG,sBAAiBD,aAAlC,CAAtB;AAEA,SAAO;AACLA,IAAAA,aAAa,EAAbA,aADK;AAELD,IAAAA,KAAK,kCACAA,KADA;AAEHZ,MAAAA,OAAO,EAAED,wBAAwB,CAC9Ba,KAAK,IAAIA,KAAK,CAACZ,OAAhB,IAA4B,EADG,EAE/Ba,aAAa,IAAIA,aAAa,CAACE,iBAFA;AAF9B;AAFA,GAAP;AAUD,CAbD;;IAeqBC,c;;;;;AAenB,4BAAc;AAAA;;AAAA;AACZ;AACA,UAAKC,MAAL,GAAcD,cAAc,CAACE,kBAAf,EAAd;AACA,UAAKC,cAAL,GAAsBL,sBAAiBD,aAAvC;AACA,UAAKO,cAAL,GAAsB,MAAKA,cAAL,CAAoBC,IAApB,gDAAtB;AACA,UAAKC,sBAAL,GAA8B,MAAKA,sBAAL,CAA4BD,IAA5B,gDAA9B;AALY;AAMb;;;;SAED,aAAUE,CAAV,EAAa;AACX,WAAKN,MAAL,GAAcD,cAAc,CAACE,kBAAf,CAAkCK,CAAlC,CAAd;;AAEA,WAAKC,OAAL;AACD;;;SAED,aAAkBC,CAAlB,EAAqB;AAAA;AAAA;;AACnB,UAAMC,IAAI,GAAGhB,0BAA0B,CAACe,CAAD,EAAI,KAAKR,MAAT,CAAvC;AAEA,WAAKG,cAAL,CAAoBM,IAAI,CAACd,KAAzB;;AAEA,UAAMe,gBAAgB,mCACjBb,sBAAiBD,aADA,GAEjBa,IAAI,CAACb,aAFY,CAAtB;;AAIA,WAAKM,cAAL,GAAsBQ,gBAAtB,CATmB,CAWnB;AACA;AACA;AACA;;AACA,UAAIA,gBAAJ,aAAIA,gBAAJ,wCAAIA,gBAAgB,CAAEC,QAAtB,kDAAI,sBAA4BC,OAAhC,EAAyC;AAAA;;AACvC,YAAIF,gBAAJ,aAAIA,gBAAJ,yCAAIA,gBAAgB,CAAEG,eAAtB,6EAAI,uBAAmCC,OAAvC,mDAAI,uBAA4C7B,MAAhD,EAAwD;AACtD,eAAKe,MAAL,CAAYW,QAAZ,GAAuBD,gBAAvB,aAAuBA,gBAAvB,uBAAuBA,gBAAgB,CAAEG,eAAlB,CAAkCC,OAAlC,CAA0C,CAA1C,EAA6CzB,KAApE;AACD;AACF,OAJD,MAIO,IAAIqB,gBAAgB,CAACC,QAAjB,CAA0BI,QAA1B,IAAsC,KAAKf,MAAL,CAAYW,QAAtD,EAAgE;AACrE,aAAKT,cAAL,CAAoBS,QAApB,CAA6BC,OAA7B,GAAuC,IAAvC;;AAEA,YAAI,CAAC,KAAKV,cAAL,CAAoBW,eAApB,CAAoCC,OAArC,IAAgD,CAAC,KAAKZ,cAAL,CAAoBW,eAApB,CAAoCC,OAApC,CAA4C7B,MAAjG,EAAyG;AACvG,eAAKiB,cAAL,CAAoBW,eAApB,CAAoCC,OAApC,GAA8C,EAA9C;AACD,SALoE,CAOrE;AACA;;;AACA,YAAI,CAAC,KAAKZ,cAAL,CAAoBW,eAApB,CAAoCC,OAApC,CAA4CE,IAA5C,CAAiD,UAAAC,MAAM;AAAA,iBAAIA,MAAM,CAAC5B,KAAP,KAAiB,MAAI,CAACW,MAAL,CAAYW,QAAjC;AAAA,SAAvD,CAAL,EAAwG;AACtG,eAAKT,cAAL,CAAoBW,eAApB,CAAoCC,OAApC,CAA4C1B,IAA5C,CAAiD;AAC/CC,YAAAA,KAAK,EAAE,KAAKW,MAAL,CAAYW,QAD4B;AAE/CrB,YAAAA,KAAK,EAAE,KAAKU,MAAL,CAAYW;AAF4B,WAAjD;AAID;AACF,OAfM,MAeA;AACL,eAAO,KAAKX,MAAL,CAAYW,QAAnB;AACD;;AAED,WAAKJ,OAAL;AACD;;;SAED,aAAqBD,CAArB,EAAwB;AACtB,WAAKY,iBAAL,GAAyBZ,CAAzB;;AACA,WAAKC,OAAL;AACD;;;WAED,8BAAqBY,KAArB,EAA4B;AAC1B,UAAMC,UAAU,GAAG,CAAC,CAACD,KAArB;AAEA,WAAKE,aAAL,CAAmB,IAAIC,qCAAJ,CAAsB,KAAKtB,MAA3B,EAAmCoB,UAAnC,CAAnB;AACD;;;WAED,wBAAeG,CAAf,EAAkBJ,KAAlB,EAAyB;AACvB,WAAKnB,MAAL,GAAcuB,CAAd;;AACA,WAAKhB,OAAL;;AAEA,WAAKiB,oBAAL,CAA0BL,KAA1B;AACD;;;WAED,gCAAuBX,CAAvB,EAA0B;AACxB,WAAKN,cAAL,GAAsBT,0BAA0B,CAACe,CAAD,EAAI,KAAKR,MAAT,CAA1B,CAA2CJ,aAAjE;;AAEA,UAAI,KAAKI,MAAT,EAAiB;AACf,aAAKG,cAAL,CAAoB,KAAKH,MAAzB;AACD;;AAED,WAAKO,OAAL;AACD;AAED;;;;WACA,qBAAYkB,OAAZ,EAAqB;AACnB,WAAKJ,aAAL,CAAmB,IAAIK,oCAAJ,CAAqBD,OAArB,CAAnB;AACD;;;WAED,uBAAcE,GAAd,EAAmBC,IAAnB,EAAyB;AACvB,WAAKP,aAAL,CAAmB,IAAIQ,oCAAJ,CAAqBF,GAArB,EAA0BC,IAA1B,CAAnB;AACD;;;WAED,qBAAYH,OAAZ,EAAqB;AACnB,WAAKJ,aAAL,CAAmB,IAAIS,oCAAJ,CAAqBL,OAArB,CAAnB;AACD;;;WAED,uBAAcE,GAAd,EAAmBC,IAAnB,EAAyB;AACvB,WAAKP,aAAL,CAAmB,IAAIU,oCAAJ,CAAqBJ,GAArB,EAA0BC,IAA1B,CAAnB;AACD;;;WAED,mBAAU;AACR/C,MAAAA,GAAG,CAAC,SAAD,CAAH;;AACA,UAAImD,OAAO,gBAAGC,kBAAMC,aAAN,CAAoBC,gBAApB,EAA0B;AACtCxC,QAAAA,KAAK,EAAE,KAAKK,MAD0B;AAEtCJ,QAAAA,aAAa,EAAE,KAAKM,cAFkB;AAGtCC,QAAAA,cAAc,EAAE,KAAKA,cAHiB;AAItCE,QAAAA,sBAAsB,EAAE,KAAKA,sBAJS;AAKtC+B,QAAAA,gBAAgB,EAAE,KAAKlB,iBALe;AAMtCmB,QAAAA,YAAY,EAAE;AACZC,UAAAA,GAAG,EAAE,KAAKC,WAAL,CAAiBnC,IAAjB,CAAsB,IAAtB,CADO;AAEZ,oBAAQ,KAAKoC,aAAL,CAAmBpC,IAAnB,CAAwB,IAAxB;AAFI,SANwB;AAUtCqC,QAAAA,kBAAkB,EAAE;AAClBH,UAAAA,GAAG,EAAE,KAAKI,WAAL,CAAiBtC,IAAjB,CAAsB,IAAtB,CADa;AAElB,oBAAQ,KAAKuC,aAAL,CAAmBvC,IAAnB,CAAwB,IAAxB;AAFU;AAVkB,OAA1B,CAAd;;AAgBAwC,2BAASC,MAAT,CAAgBb,OAAhB,EAAyB,IAAzB;AACD;;;kDAtIyCc,W;;;iCAAvB/C,c,wBACS,YAAgB;AAAA,MAAfJ,KAAe,uEAAP,EAAO;;AAC1C,MAAMoD,eAAe,GAAGC,sBAAMC,gBAAN,+CACnBpD,sBAAiBF,KADE,GAEnBA,KAFmB;AAGtBZ,IAAAA,OAAO,EAAED,wBAAwB,CAAEa,KAAK,IAAIA,KAAK,CAACZ,OAAhB,IAA4B,EAA7B;AAHX,KAAxB,CAD0C,CAO1C;;;AACAgE,EAAAA,eAAe,CAACG,aAAhB,GACEvD,KAAK,CAACuD,aAAN,IAAwBvD,KAAK,CAACwD,YAAN,KAAuB,KAAvB,IAAgC,YAAxD,IAAyEtD,sBAAiBF,KAAjB,CAAuBuD,aADlG;AAGA,SAAOH,eAAP;AACD,C","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport debug from 'debug';\nimport {\n DeleteImageEvent,\n InsertImageEvent,\n ModelUpdatedEvent,\n InsertSoundEvent,\n DeleteSoundEvent,\n} from '@pie-framework/pie-configure-events';\n\nimport Main from './main';\nimport { choiceUtils as utils } from '@pie-lib/pie-toolbox/config-ui';\nimport defaults from 'lodash/defaults';\n\nimport sensibleDefaults from './defaults';\n\nconst log = debug('multiple-choice:configure');\n\nconst generateFormattedChoices = (choices, choiceCount = 0) => {\n if (!choices || choices.length === 0) {\n let formattedChoices = [];\n\n for (let i = 0; i < choiceCount; i++) {\n formattedChoices.push({\n value: `${i}`,\n label: '',\n feedback: {\n type: 'none',\n value: '',\n },\n });\n }\n\n return formattedChoices;\n }\n\n return choices;\n};\n\nconst prepareCustomizationObject = (config, model) => {\n const configuration = defaults(config, sensibleDefaults.configuration);\n\n return {\n configuration,\n model: {\n ...model,\n choices: generateFormattedChoices(\n (model && model.choices) || [],\n configuration && configuration.answerChoiceCount,\n ),\n },\n };\n};\n\nexport default class MultipleChoice extends HTMLElement {\n static createDefaultModel = (model = {}) => {\n const normalizedModel = utils.normalizeChoices({\n ...sensibleDefaults.model,\n ...model,\n choices: generateFormattedChoices((model && model.choices) || []),\n });\n\n // This is used for offering support for old models which have the property \"verticalMode\"\n normalizedModel.choicesLayout =\n model.choicesLayout || (model.verticalMode === false && 'horizontal') || sensibleDefaults.model.choicesLayout;\n\n return normalizedModel;\n };\n\n constructor() {\n super();\n this._model = MultipleChoice.createDefaultModel();\n this._configuration = sensibleDefaults.configuration;\n this.onModelChanged = this.onModelChanged.bind(this);\n this.onConfigurationChanged = this.onConfigurationChanged.bind(this);\n }\n\n set model(s) {\n this._model = MultipleChoice.createDefaultModel(s);\n\n this._render();\n }\n\n set configuration(c) {\n const info = prepareCustomizationObject(c, this._model);\n\n this.onModelChanged(info.model);\n\n const newConfiguration = {\n ...sensibleDefaults.configuration,\n ...info.configuration,\n };\n this._configuration = newConfiguration;\n\n // if language:enabled is true, then the corresponding default item model should include a language value;\n // if it is false, then the language field should be omitted from the item model.\n // if a default item model includes a language value (e.g., en_US) and the corresponding authoring view settings have language:settings = true,\n // then (a) language:enabled should also be true, and (b) that default language value should be represented in languageChoices[] (as a key).\n if (newConfiguration?.language?.enabled) {\n if (newConfiguration?.languageChoices?.options?.length) {\n this._model.language = newConfiguration?.languageChoices.options[0].value;\n }\n } else if (newConfiguration.language.settings && this._model.language) {\n this._configuration.language.enabled = true;\n\n if (!this._configuration.languageChoices.options || !this._configuration.languageChoices.options.length) {\n this._configuration.languageChoices.options = [];\n }\n\n // check if the language is already included in the languageChoices.options array\n // and if not, then add it.\n if (!this._configuration.languageChoices.options.find(option => option.value === this._model.language)) {\n this._configuration.languageChoices.options.push({\n value: this._model.language,\n label: this._model.language,\n });\n }\n } else {\n delete this._model.language;\n }\n\n this._render();\n }\n\n set disableSidePanel(s) {\n this._disableSidePanel = s;\n this._render();\n }\n\n dispatchModelUpdated(reset) {\n const resetValue = !!reset;\n\n this.dispatchEvent(new ModelUpdatedEvent(this._model, resetValue));\n }\n\n onModelChanged(m, reset) {\n this._model = m;\n this._render();\n\n this.dispatchModelUpdated(reset);\n }\n\n onConfigurationChanged(c) {\n this._configuration = prepareCustomizationObject(c, this._model).configuration;\n\n if (this._model) {\n this.onModelChanged(this._model);\n }\n\n this._render();\n }\n\n /** @param {done, progress, file} handler */\n insertImage(handler) {\n this.dispatchEvent(new InsertImageEvent(handler));\n }\n\n onDeleteImage(src, done) {\n this.dispatchEvent(new DeleteImageEvent(src, done));\n }\n\n insertSound(handler) {\n this.dispatchEvent(new InsertSoundEvent(handler));\n }\n\n onDeleteSound(src, done) {\n this.dispatchEvent(new DeleteSoundEvent(src, done));\n }\n\n _render() {\n log('_render');\n let element = React.createElement(Main, {\n model: this._model,\n configuration: this._configuration,\n onModelChanged: this.onModelChanged,\n onConfigurationChanged: this.onConfigurationChanged,\n disableSidePanel: this._disableSidePanel,\n imageSupport: {\n add: this.insertImage.bind(this),\n delete: this.onDeleteImage.bind(this),\n },\n uploadSoundSupport: {\n add: this.insertSound.bind(this),\n delete: this.onDeleteSound.bind(this),\n },\n });\n\n ReactDOM.render(element, this);\n }\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../src/index.js"],"names":["log","generateFormattedChoices","choices","choiceCount","length","formattedChoices","i","push","value","label","feedback","type","prepareCustomizationObject","config","model","configuration","sensibleDefaults","answerChoiceCount","MultipleChoice","_model","createDefaultModel","_configuration","onModelChanged","bind","onConfigurationChanged","s","_render","c","info","newConfiguration","language","enabled","languageChoices","options","settings","find","option","_disableSidePanel","reset","resetValue","dispatchEvent","ModelUpdatedEvent","m","dispatchModelUpdated","handler","InsertImageEvent","src","done","DeleteImageEvent","InsertSoundEvent","DeleteSoundEvent","element","React","createElement","Main","disableSidePanel","imageSupport","add","insertImage","onDeleteImage","uploadSoundSupport","insertSound","onDeleteSound","ReactDOM","render","HTMLElement","normalizedModel","utils","normalizeChoices","choicesLayout","verticalMode"],"mappings":"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","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport debug from 'debug';\nimport {\n DeleteImageEvent,\n InsertImageEvent,\n ModelUpdatedEvent,\n InsertSoundEvent,\n DeleteSoundEvent,\n} from '@pie-framework/pie-configure-events';\n\nimport Main from './main';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport defaults from 'lodash/defaults';\n\nimport sensibleDefaults from './defaults';\n\nconst log = debug('multiple-choice:configure');\n\nconst generateFormattedChoices = (choices, choiceCount = 0) => {\n if (!choices || choices.length === 0) {\n let formattedChoices = [];\n\n for (let i = 0; i < choiceCount; i++) {\n formattedChoices.push({\n value: `${i}`,\n label: '',\n feedback: {\n type: 'none',\n value: '',\n },\n });\n }\n\n return formattedChoices;\n }\n\n return choices;\n};\n\nconst prepareCustomizationObject = (config, model) => {\n const configuration = defaults(config, sensibleDefaults.configuration);\n\n return {\n configuration,\n model: {\n ...model,\n choices: generateFormattedChoices(\n (model && model.choices) || [],\n configuration && configuration.answerChoiceCount,\n ),\n },\n };\n};\n\nexport default class MultipleChoice extends HTMLElement {\n static createDefaultModel = (model = {}) => {\n const normalizedModel = utils.normalizeChoices({\n ...sensibleDefaults.model,\n ...model,\n choices: generateFormattedChoices((model && model.choices) || []),\n });\n\n // This is used for offering support for old models which have the property \"verticalMode\"\n normalizedModel.choicesLayout =\n model.choicesLayout || (model.verticalMode === false && 'horizontal') || sensibleDefaults.model.choicesLayout;\n\n return normalizedModel;\n };\n\n constructor() {\n super();\n this._model = MultipleChoice.createDefaultModel();\n this._configuration = sensibleDefaults.configuration;\n this.onModelChanged = this.onModelChanged.bind(this);\n this.onConfigurationChanged = this.onConfigurationChanged.bind(this);\n }\n\n set model(s) {\n this._model = MultipleChoice.createDefaultModel(s);\n\n this._render();\n }\n\n set configuration(c) {\n const info = prepareCustomizationObject(c, this._model);\n\n this.onModelChanged(info.model);\n\n const newConfiguration = {\n ...sensibleDefaults.configuration,\n ...info.configuration,\n };\n this._configuration = newConfiguration;\n\n // if language:enabled is true, then the corresponding default item model should include a language value;\n // if it is false, then the language field should be omitted from the item model.\n // if a default item model includes a language value (e.g., en_US) and the corresponding authoring view settings have language:settings = true,\n // then (a) language:enabled should also be true, and (b) that default language value should be represented in languageChoices[] (as a key).\n if (newConfiguration?.language?.enabled) {\n if (newConfiguration?.languageChoices?.options?.length) {\n this._model.language = newConfiguration?.languageChoices.options[0].value;\n }\n } else if (newConfiguration.language.settings && this._model.language) {\n this._configuration.language.enabled = true;\n\n if (!this._configuration.languageChoices.options || !this._configuration.languageChoices.options.length) {\n this._configuration.languageChoices.options = [];\n }\n\n // check if the language is already included in the languageChoices.options array\n // and if not, then add it.\n if (!this._configuration.languageChoices.options.find(option => option.value === this._model.language)) {\n this._configuration.languageChoices.options.push({\n value: this._model.language,\n label: this._model.language,\n });\n }\n } else {\n delete this._model.language;\n }\n\n this._render();\n }\n\n set disableSidePanel(s) {\n this._disableSidePanel = s;\n this._render();\n }\n\n dispatchModelUpdated(reset) {\n const resetValue = !!reset;\n\n this.dispatchEvent(new ModelUpdatedEvent(this._model, resetValue));\n }\n\n onModelChanged(m, reset) {\n this._model = m;\n this._render();\n\n this.dispatchModelUpdated(reset);\n }\n\n onConfigurationChanged(c) {\n this._configuration = prepareCustomizationObject(c, this._model).configuration;\n\n if (this._model) {\n this.onModelChanged(this._model);\n }\n\n this._render();\n }\n\n /** @param {done, progress, file} handler */\n insertImage(handler) {\n this.dispatchEvent(new InsertImageEvent(handler));\n }\n\n onDeleteImage(src, done) {\n this.dispatchEvent(new DeleteImageEvent(src, done));\n }\n\n insertSound(handler) {\n this.dispatchEvent(new InsertSoundEvent(handler));\n }\n\n onDeleteSound(src, done) {\n this.dispatchEvent(new DeleteSoundEvent(src, done));\n }\n\n _render() {\n log('_render');\n let element = React.createElement(Main, {\n model: this._model,\n configuration: this._configuration,\n onModelChanged: this.onModelChanged,\n onConfigurationChanged: this.onConfigurationChanged,\n disableSidePanel: this._disableSidePanel,\n imageSupport: {\n add: this.insertImage.bind(this),\n delete: this.onDeleteImage.bind(this),\n },\n uploadSoundSupport: {\n add: this.insertSound.bind(this),\n delete: this.onDeleteSound.bind(this),\n },\n });\n\n ReactDOM.render(element, this);\n }\n}\n"],"file":"index.js"}
@@ -27,11 +27,11 @@ var _react = _interopRequireDefault(require("react"));
27
27
 
28
28
  var _propTypes = _interopRequireDefault(require("prop-types"));
29
29
 
30
- var _editableHtml = require("@pie-lib/pie-toolbox/editable-html");
30
+ var _editableHtml = _interopRequireDefault(require("@pie-lib/editable-html"));
31
31
 
32
- var _configUi = require("@pie-lib/pie-toolbox/config-ui");
32
+ var _configUi = require("@pie-lib/config-ui");
33
33
 
34
- var _renderUi = require("@pie-lib/pie-toolbox/render-ui");
34
+ var _renderUi = require("@pie-lib/render-ui");
35
35
 
36
36
  var _styles = require("@material-ui/core/styles");
37
37
 
@@ -270,7 +270,7 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
270
270
  }, teacherInstructionsEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
271
271
  label: teacherInstructions.label,
272
272
  className: classes.promptHolder
273
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
273
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
274
274
  className: classes.prompt,
275
275
  markup: model.teacherInstructions || '',
276
276
  onChange: onTeacherInstructionsChanged,
@@ -294,7 +294,7 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
294
294
  }, teacherInstructionsError)), promptEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
295
295
  label: prompt.label,
296
296
  className: classes.promptHolder
297
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
297
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
298
298
  className: classes.prompt,
299
299
  markup: model.prompt,
300
300
  onChange: onPromptChanged,
@@ -370,7 +370,7 @@ var Design = (0, _styles.withStyles)(styles)(function (props) {
370
370
  key: "rationale-".concat(index),
371
371
  label: rationale.label,
372
372
  className: classes.rationaleHolder
373
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml.EditableHtml, {
373
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
374
374
  className: classes.rationale,
375
375
  markup: choice.rationale || '',
376
376
  onChange: function onChange(c) {