@pie-element/multiple-choice 9.18.1-next.0 → 9.19.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.
- package/CHANGELOG.md +8 -0
- package/configure/CHANGELOG.md +8 -0
- package/configure/lib/__tests__/root.test.js +271 -0
- package/configure/lib/defaults.js +1 -1
- package/configure/lib/index.js +2 -2
- package/configure/lib/main.js +7 -7
- package/configure/lib/utils.js +1 -1
- package/configure/package.json +4 -2
- package/controller/CHANGELOG.md +8 -0
- package/controller/lib/__tests__/index.test.js +867 -0
- package/controller/lib/__tests__/utils.test.js +8 -0
- package/controller/lib/defaults.js +1 -1
- package/controller/lib/index.js +2 -2
- package/controller/lib/utils.js +1 -1
- package/controller/package.json +2 -2
- package/docs/demo/pie.manifest.json +11 -0
- package/lib/__tests__/choice-input-test.js +131 -0
- package/lib/__tests__/index-test.js +183 -0
- package/lib/__tests__/key-events-test.js +98 -0
- package/lib/__tests__/multiple-choice-test.js +235 -0
- package/lib/__tests__/session-updater-test.js +72 -0
- package/lib/choice-input.js +2 -2
- package/lib/choice.js +1 -1
- package/lib/feedback-tick.js +2 -2
- package/lib/index.js +3 -3
- package/lib/main.js +2 -2
- package/lib/multiple-choice.js +5 -5
- package/lib/print.js +2 -2
- package/lib/session-updater.js +1 -1
- package/package.json +5 -2
- package/configure/lib/defaults.js.map +0 -1
- package/configure/lib/index.js.map +0 -1
- package/configure/lib/main.js.map +0 -1
- package/configure/lib/utils.js.map +0 -1
- package/controller/lib/defaults.js.map +0 -1
- package/controller/lib/index.js.map +0 -1
- package/controller/lib/utils.js.map +0 -1
- package/lib/choice-input.js.map +0 -1
- package/lib/choice.js.map +0 -1
- package/lib/feedback-tick.js.map +0 -1
- package/lib/index.js.map +0 -1
- package/lib/main.js.map +0 -1
- package/lib/multiple-choice.js.map +0 -1
- package/lib/print.js.map +0 -1
- package/lib/session-updater.js.map +0 -1
- package/module/configure.js +0 -11070
- package/module/controller.js +0 -3601
- package/module/demo.js +0 -86
- package/module/element.js +0 -13448
- package/module/index.html +0 -21
- package/module/manifest.json +0 -14
- package/module/print-demo.js +0 -124
- package/module/print.html +0 -18
- package/module/print.js +0 -13204
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
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.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)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @pie-element/multiple-choice
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
6
14
|
# [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
15
|
|
|
8
16
|
|
package/configure/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
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.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)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @pie-element/multiple-choice-configure
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
6
14
|
# [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
15
|
|
|
8
16
|
|
|
@@ -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":";;;;;;;;AAAA;;AACA;;AAEA;;AACA;;AACA;;AACA;;;;;;AAEAA,IAAI,CAACC,IAAL,CAAU,oBAAV,EAAgC;AAAA,SAAO;AACrCC,IAAAA,WAAW,EAAE;AACXC,MAAAA,mBAAmB,EAAEH,IAAI,CAACI,EAAL,EADV;AAEXC,MAAAA,gBAAgB,EAAEL,IAAI,CAACI,EAAL,CAAQ,UAACE,KAAD;AAAA,eAAWA,KAAX;AAAA,OAAR;AAFP,KADwB;AAKrCC,IAAAA,QAAQ,EAAE;AACRC,MAAAA,KAAK,EAAE,eAACC,KAAD;AAAA,4BAAW,uCAASA,KAAT,CAAX;AAAA,OADC;AAERC,MAAAA,MAAM,EAAEV,IAAI,CAACI,EAAL,EAFA;AAGRO,MAAAA,KAAK,EAAEX,IAAI,CAACI,EAAL;AAHC;AAL2B,GAAP;AAAA,CAAhC;;AAYA,IAAME,KAAK,GAAG,SAARA,KAAQ,CAACM,MAAD;AAAA,yCACTC,qBAASP,KADA;AAEZQ,IAAAA,MAAM,EAAE,4DAFI;AAGZC,IAAAA,UAAU,EAAE,UAHA;AAIZC,IAAAA,OAAO,EAAE,CACP;AACEC,MAAAA,OAAO,EAAE,IADX;AAEEC,MAAAA,KAAK,EAAE,QAFT;AAGEC,MAAAA,KAAK,EAAE,QAHT;AAIEC,MAAAA,QAAQ,EAAE;AACRC,QAAAA,IAAI,EAAE,MADE;AAERH,QAAAA,KAAK,EAAE;AAFC;AAJZ,KADO,EAUP;AACEA,MAAAA,KAAK,EAAE,SADT;AAEEC,MAAAA,KAAK,EAAE,SAFT;AAGEC,MAAAA,QAAQ,EAAE;AACRC,QAAAA,IAAI,EAAE,MADE;AAERH,QAAAA,KAAK,EAAE;AAFC;AAHZ,KAVO,EAkBP;AACEA,MAAAA,KAAK,EAAE,QADT;AAEEC,MAAAA,KAAK,EAAE,QAFT;AAGEC,MAAAA,QAAQ,EAAE;AACRC,QAAAA,IAAI,EAAE,MADE;AAERH,QAAAA,KAAK,EAAE;AAFC;AAHZ,KAlBO,EA0BP;AACED,MAAAA,OAAO,EAAE,IADX;AAEEC,MAAAA,KAAK,EAAE,SAFT;AAGEC,MAAAA,KAAK,EAAE,SAHT;AAIEC,MAAAA,QAAQ,EAAE;AACRC,QAAAA,IAAI,EAAE,MADE;AAERH,QAAAA,KAAK,EAAE;AAFC;AAJZ,KA1BO,CAJG;AAwCZI,IAAAA,cAAc,EAAE,KAxCJ;AAyCZC,IAAAA,SAAS,EAAE;AAzCC,KA0CTX,MA1CS;AAAA,CAAd;;AA6CAY,QAAQ,CAAC,MAAD,EAAS,YAAM;AACrB,MAAIC,CAAJ;AACA,MAAIC,cAAc,GAAG1B,IAAI,CAACI,EAAL,EAArB;AACA,MAAIuB,sBAAsB,GAAG3B,IAAI,CAACI,EAAL,EAA7B;AACA,MAAIwB,YAAY,GAAGtB,KAAK,EAAxB;;AAEA,MAAMuB,OAAO,GAAG,SAAVA,OAAU,CAACjB,MAAD,EAAY;AAC1B,QAAMC,QAAQ,GAAG;AACfa,MAAAA,cAAc,EAAdA,cADe;AAEfC,MAAAA,sBAAsB,EAAtBA,sBAFe;AAGfG,MAAAA,OAAO,EAAE,EAHM;AAIfxB,MAAAA,KAAK,EAAEA,KAAK;AAJG,KAAjB;;AAMA,QAAMG,KAAK,mCAAQI,QAAR,GAAqBD,MAArB,CAAX;;AAEA,WAAO,mCAAQ,gCAAC,UAAD,EAAUH,KAAV,CAAR,CAAP;AACD,GAVD;;AAYAe,EAAAA,QAAQ,CAAC,UAAD,EAAa,YAAM;AACzBO,IAAAA,EAAE,CAAC,qCAAD,EAAwC,YAAM;AAC9CN,MAAAA,CAAC,GAAGI,OAAO,CAAC;AAAEvB,QAAAA,KAAK,EAAEA,KAAK,CAAC;AAAE0B,UAAAA,YAAY,EAAE;AAAhB,SAAD;AAAd,OAAD,CAAX;AACAC,MAAAA,MAAM,CAACR,CAAD,CAAN,CAAUS,eAAV;AACD,KAHC,CAAF;AAKAH,IAAAA,EAAE,CAAC,gDAAD,EAAmD,YAAM;AACzDN,MAAAA,CAAC,GAAGI,OAAO,EAAX;AACAI,MAAAA,MAAM,CAACR,CAAD,CAAN,CAAUS,eAAV;AACD,KAHC,CAAF;AAID,GAVO,CAAR;AAYAV,EAAAA,QAAQ,CAAC,OAAD,EAAU,YAAM;AACtBW,IAAAA,UAAU,CAAC,YAAM;AACfV,MAAAA,CAAC,GAAGI,OAAO,EAAX;AACD,KAFS,CAAV;AAGAL,IAAAA,QAAQ,CAAC,gBAAD,EAAmB,YAAM;AAC/BO,MAAAA,EAAE,CAAC,gBAAD,EAAmB,YAAM;AACzBN,QAAAA,CAAC,CAACW,QAAF,GAAaC,cAAb,CAA4B,CAA5B;AAEAJ,QAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCACKV,YADL;AAEEZ,UAAAA,OAAO,EAAEY,YAAY,CAACZ,OAAb,CAAqBuB,KAArB,CAA2B,CAA3B;AAFX;AAID,OAPC,CAAF;AAQD,KATO,CAAR;AAWAf,IAAAA,QAAQ,CAAC,oBAAD,EAAuB,YAAM;AACnCO,MAAAA,EAAE,CAAC,uDAAD,EAA0D,YAAM;AAChE,YAAMS,CAAC,GAAGC,kBAAeC,kBAAf,CAAkCpC,KAAK,CAAC;AAAEqC,UAAAA,YAAY,EAAE,KAAhB;AAAuBC,UAAAA,aAAa,EAAEC;AAAtC,SAAD,CAAvC,CAAV;;AAEAZ,QAAAA,MAAM,CAACO,CAAC,CAACI,aAAH,CAAN,CAAwBE,OAAxB,CAAgC,YAAhC;AACD,OAJC,CAAF;AAMAf,MAAAA,EAAE,CAAC,oDAAD,EAAuD,YAAM;AAC7D,YAAMS,CAAC,GAAGC,kBAAeC,kBAAf,CAAkCpC,KAAK,CAAC;AAAEqC,UAAAA,YAAY,EAAE,IAAhB;AAAsBC,UAAAA,aAAa,EAAEC;AAArC,SAAD,CAAvC,CAAV;;AAEAZ,QAAAA,MAAM,CAACO,CAAC,CAACI,aAAH,CAAN,CAAwBE,OAAxB,CAAgC,UAAhC;AACD,OAJC,CAAF;AAMAf,MAAAA,EAAE,CAAC,uEAAD,EAA0E,YAAM;AAChF,YAAMS,CAAC,GAAGC,kBAAeC,kBAAf,CAAkCpC,KAAK,CAAC;AAAEqC,UAAAA,YAAY,EAAE,IAAhB;AAAsBC,UAAAA,aAAa,EAAE;AAArC,SAAD,CAAvC,CAAV;;AAEAX,QAAAA,MAAM,CAACO,CAAC,CAACI,aAAH,CAAN,CAAwBE,OAAxB,CAAgC,MAAhC;AACD,OAJC,CAAF;AAMAf,MAAAA,EAAE,CAAC,8BAAD,EAAiC,YAAM;AACvC,YAAMS,CAAC,GAAGC,kBAAeC,kBAAf,CAAkCpC,KAAK,EAAvC,CAAV;;AAEA2B,QAAAA,MAAM,CAACO,CAAC,CAACI,aAAH,CAAN,CAAwBE,OAAxB,CAAgC,UAAhC;AACD,OAJC,CAAF;AAKD,KAxBO,CAAR;AA0BAtB,IAAAA,QAAQ,CAAC,aAAD,EAAgB,YAAM;AAC5BO,MAAAA,EAAE,CAAC,eAAD,EAAkB,YAAM;AACxBN,QAAAA,CAAC,CAACW,QAAF,GAAaW,WAAb;AAEAd,QAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCACKV,YADL;AAEEZ,UAAAA,OAAO,gDACFY,YAAY,CAACZ,OADX,IAEL;AACEG,YAAAA,KAAK,EAAE,EADT;AAEED,YAAAA,KAAK,EAAE8B,sBAAM7C,mBAAN,CACLyB,YAAY,CAACZ,OAAb,CAAqBiC,GAArB,CAAyB,UAACC,CAAD;AAAA,qBAAOA,CAAC,CAAChC,KAAT;AAAA,aAAzB,CADK,EAEL,CAFK,CAFT;AAMEE,YAAAA,QAAQ,EAAE;AACRC,cAAAA,IAAI,EAAE;AADE;AANZ,WAFK;AAFT;AAgBD,OAnBC,CAAF;AAoBD,KArBO,CAAR;AAuBAG,IAAAA,QAAQ,CAAC,iBAAD,EAAoB,YAAM;AAChCA,MAAAA,QAAQ,CAAC,UAAD,EAAa,YAAM;AACzBO,QAAAA,EAAE,CAAC,0CAAD,EAA6C,YAAM;AACnD,cAAMoB,UAAU,uCAAO7C,KAAK,GAAGU,OAAf,CAAhB;AACA,cAAIoC,MAAM,GAAG;AACXnC,YAAAA,OAAO,EAAE,IADE;AAEXC,YAAAA,KAAK,EAAE,SAFI;AAGXC,YAAAA,KAAK,EAAE,SAHI;AAIXC,YAAAA,QAAQ,EAAE;AACRC,cAAAA,IAAI,EAAE,MADE;AAERH,cAAAA,KAAK,EAAE;AAFC;AAJC,WAAb;AAUAO,UAAAA,CAAC,CAACW,QAAF,GAAaiB,eAAb,CAA6B,CAA7B,EAAgCD,MAAhC;AAEAD,UAAAA,UAAU,CAAC,CAAD,CAAV,CAAclC,OAAd,GAAwB,IAAxB;AAEAgB,UAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCACKV,YADL;AAEEZ,YAAAA,OAAO,EAAEmC;AAFX;AAID,SApBC,CAAF;AAqBD,OAtBO,CAAR;AAwBA3B,MAAAA,QAAQ,CAAC,OAAD,EAAU,YAAM;AACtBO,QAAAA,EAAE,CAAC,+CAAD,EAAkD,YAAM;AACxD,cAAIqB,MAAM,GAAG;AACXnC,YAAAA,OAAO,EAAE,IADE;AAEXC,YAAAA,KAAK,EAAE,SAFI;AAGXC,YAAAA,KAAK,EAAE,SAHI;AAIXC,YAAAA,QAAQ,EAAE;AACRC,cAAAA,IAAI,EAAE,MADE;AAERH,cAAAA,KAAK,EAAE;AAFC;AAJC,WAAb;;AAUA,cAAMoC,QAAQ,mCAAQ1B,YAAR;AAAsBb,YAAAA,UAAU,EAAE,OAAlC;AAA2CC,YAAAA,OAAO,EAAEY,YAAY,CAACZ,OAAb,CAAqBuB,KAArB,CAA2B,CAA3B,EAA8B,CAA9B;AAApD,YAAd;;AACAd,UAAAA,CAAC,GAAGI,OAAO,CAAC;AAAEvB,YAAAA,KAAK,EAAEgD;AAAT,WAAD,CAAX;AAEA7B,UAAAA,CAAC,CAACW,QAAF,GAAaiB,eAAb,CAA6B,CAA7B,EAAgCD,MAAhC;AAEAnB,UAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCACKgB,QADL;AAEEtC,YAAAA,OAAO,EAAE,CACP;AACEC,cAAAA,OAAO,EAAE,KADX;AAEEC,cAAAA,KAAK,EAAE,QAFT;AAGEC,cAAAA,KAAK,EAAE,QAHT;AAIEC,cAAAA,QAAQ,EAAE;AACRC,gBAAAA,IAAI,EAAE,MADE;AAERH,gBAAAA,KAAK,EAAE;AAFC;AAJZ,aADO,EAUP;AACED,cAAAA,OAAO,EAAE,IADX;AAEEC,cAAAA,KAAK,EAAE,SAFT;AAGEC,cAAAA,KAAK,EAAE,SAHT;AAIEC,cAAAA,QAAQ,EAAE;AACRC,gBAAAA,IAAI,EAAE,MADE;AAERH,gBAAAA,KAAK,EAAE;AAFC;AAJZ,aAVO;AAFX;AAuBD,SAvCC,CAAF;AAwCD,OAzCO,CAAR;AA0CD,KAnEO,CAAR;AAqEAM,IAAAA,QAAQ,CAAC,iBAAD,EAAoB,YAAM;AAChCO,MAAAA,EAAE,CAAC,gBAAD,EAAmB,YAAM;AACzBN,QAAAA,CAAC,CAACW,QAAF,GAAamB,eAAb,CAA6B,YAA7B;AAEAtB,QAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCACKV,YADL;AAEEd,UAAAA,MAAM,EAAE;AAFV;AAID,OAPC,CAAF;AAQD,KATO,CAAR;AAWAU,IAAAA,QAAQ,CAAC,8BAAD,EAAiC,YAAM;AAC7CO,MAAAA,EAAE,CAAC,8BAAD,EAAiC,YAAM;AACvCN,QAAAA,CAAC,CAACW,QAAF,GAAaoB,4BAAb,CAA0C,0BAA1C;AAEAvB,QAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCACKV,YADL;AAEE6B,UAAAA,mBAAmB,EAAE;AAFvB;AAID,OAPC,CAAF;AAQD,KATO,CAAR;AAWAjC,IAAAA,QAAQ,CAAC,gBAAD,EAAmB,YAAM;AAC/BO,MAAAA,EAAE,CAAC,sDAAD,EAAyD,YAAM;AAC/DN,QAAAA,CAAC,CAACW,QAAF,GAAaV,cAAb,iCAEOE,YAFP;AAGIb,UAAAA,UAAU,EAAE;AAHhB,YAKE,YALF;AAQA,YAAM2C,eAAe,GAAGpD,KAAK,GAAGU,OAAhC;AAEA0C,QAAAA,eAAe,CAACC,OAAhB,CAAwB,UAACC,EAAD,EAAKC,KAAL,EAAe;AACrCD,UAAAA,EAAE,CAAC3C,OAAH,GAAa4C,KAAK,KAAK,CAAvB;AACD,SAFD;AAIA5B,QAAAA,MAAM,CAACP,cAAD,CAAN,CAAuBY,cAAvB,iCAEOV,YAFP;AAGIb,UAAAA,UAAU,EAAE,OAHhB;AAIIC,UAAAA,OAAO,EAAE0C;AAJb,YAME,IANF;AAQD,OAvBC,CAAF;AAwBD,KAzBO,CAAR;AA0BD,GArLO,CAAR;AAsLD,CApNO,CAAR","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"]}
|
|
@@ -199,4 +199,4 @@ var _default = {
|
|
|
199
199
|
}
|
|
200
200
|
};
|
|
201
201
|
exports["default"] = _default;
|
|
202
|
-
//# sourceMappingURL=defaults.js.map
|
|
202
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/defaults.js"],"names":["model","choiceMode","choicePrefix","choices","choicesLayout","feedbackEnabled","gridColumns","lockChoiceOrder","partialScoring","prompt","promptEnabled","rationale","rationaleEnabled","scoringType","studentInstructionsEnabled","teacherInstructions","teacherInstructionsEnabled","toolbarEditorPosition","selectedAnswerBackgroundColor","keyboardEventsEnabled","configuration","baseInputConfiguration","audio","disabled","video","image","textAlign","showParagraphs","separateParagraphs","inputConfiguration","spellCheck","label","settings","enabled","answerChoiceCount","addChoiceButton","deleteChoice","feedback","required","studentInstructions","minAnswerChoices","maxAnswerChoices","maxImageWidth","maxImageHeight","withRubric","mathMlOptions","mmlOutput","mmlEditing","language","languageChoices","options"],"mappings":"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","sourcesContent":["/** NOTE: teacherInstructions, studentInstructions, rationale & scoringType\n * functionalities are not defined yet - the value for those can belong to\n * model or to configure\n */\nexport default {\n  model: {\n    choiceMode: 'checkbox',\n    choicePrefix: 'letters',\n    choices: [],\n    choicesLayout: 'vertical',\n    feedbackEnabled: false,\n    gridColumns: 2,\n    lockChoiceOrder: true,\n    partialScoring: true,\n    prompt: '',\n    promptEnabled: true,\n    rationale: '',\n    rationaleEnabled: true,\n    scoringType: 'auto',\n    studentInstructionsEnabled: true,\n    teacherInstructions: '',\n    teacherInstructionsEnabled: true,\n    toolbarEditorPosition: 'bottom',\n    selectedAnswerBackgroundColor: 'initial',\n    keyboardEventsEnabled: false,\n  },\n  configuration: {\n    baseInputConfiguration: {\n      audio: { disabled: false },\n      video: { disabled: false },\n      image: { disabled: false },\n      textAlign: { disabled: true },\n      showParagraphs: { disabled: false },\n      separateParagraphs: { disabled: true },\n    },\n    choices: {\n      inputConfiguration: {\n        audio: { disabled: false },\n        video: { disabled: false },\n        image: { disabled: false },\n      },\n    },\n    spellCheck: {\n      label: 'Spellcheck',\n      settings: false,\n      enabled: true,\n    },\n    choicesLayout: {\n      settings: false,\n      label: 'Choices Layout',\n    },\n    gridColumns: {\n      label: 'Grid columns',\n    },\n    answerChoiceCount: 0,\n    addChoiceButton: {\n      settings: true,\n      label: 'Add a Choice',\n    },\n    choiceMode: {\n      settings: true,\n      label: 'Response Type',\n    },\n    choicePrefix: {\n      settings: true,\n      label: 'Choice Labels',\n    },\n    deleteChoice: {\n      settings: true,\n    },\n    feedback: {\n      settings: true,\n      label: 'Feedback',\n    },\n    prompt: {\n      settings: true,\n      label: 'Prompt',\n      inputConfiguration: {\n        audio: { disabled: false },\n        video: { disabled: false },\n        image: { disabled: false },\n      },\n      required: false,\n    },\n    lockChoiceOrder: {\n      settings: true,\n      label: 'Lock Choice Order',\n    },\n    partialScoring: {\n      settings: false,\n      label: 'Allow Partial Scoring',\n    },\n    rationale: {\n      settings: true,\n      label: 'Rationale',\n      inputConfiguration: {\n        audio: { disabled: true },\n        video: { disabled: true },\n        image: { disabled: false },\n      },\n      required: false,\n    },\n    scoringType: {\n      settings: false,\n      label: 'Scoring Type',\n    },\n    studentInstructions: {\n      settings: false,\n      label: 'Student Instructions',\n    },\n    teacherInstructions: {\n      settings: true,\n      label: 'Teacher Instructions',\n      inputConfiguration: {\n        audio: { disabled: false },\n        video: { disabled: false },\n        image: { disabled: false },\n      },\n      required: false,\n    },\n    toolbarEditorPosition: {\n      settings: false,\n      label: 'Toolbar Editor Position',\n    },\n    minAnswerChoices: 2,\n    maxAnswerChoices: 5,\n    maxImageWidth: {\n      teacherInstructions: 300,\n      prompt: 300,\n      rationale: 636,\n      choices: 900,\n    },\n    maxImageHeight: {\n      teacherInstructions: 300,\n      prompt: 300,\n      rationale: 300,\n      choices: 300,\n    },\n    withRubric: {\n      settings: false,\n      label: 'Add Rubric',\n    },\n    mathMlOptions: {\n      mmlOutput: false,\n      mmlEditing: false,\n    },\n    language: {\n      settings: false,\n      label: 'Specify Language',\n      enabled: false,\n    },\n    languageChoices: {\n      label: 'Language Choices',\n      options: [],\n    },\n  },\n};\n"]}
|
package/configure/lib/index.js
CHANGED
|
@@ -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/
|
|
36
|
+
var _configUi = require("@pie-lib/config-ui");
|
|
37
37
|
|
|
38
38
|
var _defaults = _interopRequireDefault(require("lodash/defaults"));
|
|
39
39
|
|
|
@@ -245,4 +245,4 @@ exports["default"] = MultipleChoice;
|
|
|
245
245
|
normalizedModel.choicesLayout = model.choicesLayout || model.verticalMode === false && 'horizontal' || _defaults2["default"].model.choicesLayout;
|
|
246
246
|
return normalizedModel;
|
|
247
247
|
});
|
|
248
|
-
//# sourceMappingURL=index.js.map
|
|
248
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"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"]}
|
package/configure/lib/main.js
CHANGED
|
@@ -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/
|
|
30
|
+
var _editableHtml = _interopRequireDefault(require("@pie-lib/editable-html"));
|
|
31
31
|
|
|
32
|
-
var _configUi = require("@pie-lib/
|
|
32
|
+
var _configUi = require("@pie-lib/config-ui");
|
|
33
33
|
|
|
34
|
-
var _renderUi = require("@pie-lib/
|
|
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
|
|
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
|
|
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
|
|
373
|
+
}, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
|
|
374
374
|
className: classes.rationale,
|
|
375
375
|
markup: choice.rationale || '',
|
|
376
376
|
onChange: function onChange(c) {
|
|
@@ -594,4 +594,4 @@ exports.Main = Main;
|
|
|
594
594
|
var Styled = (0, _styles.withStyles)(styles)(Main);
|
|
595
595
|
var _default = Styled;
|
|
596
596
|
exports["default"] = _default;
|
|
597
|
-
//# sourceMappingURL=main.js.map
|
|
597
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/main.jsx"],"names":["Panel","settings","toggle","radio","dropdown","MAX_CHOICES","styles","theme","promptHolder","width","paddingTop","spacing","unit","marginBottom","rationaleHolder","flex","marginTop","marginLeft","choiceConfigurationHolder","display","flexDirection","choiceConfiguration","switchElement","justifyContent","margin","addButton","disableButton","cursor","pointerEvents","backgroundColor","color","disabled","flexContainer","alignItems","titleText","fontSize","typography","marginRight","tooltip","whiteSpace","maxWidth","errorText","palette","error","main","Design","props","classes","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","answerChoicesError","answerChoices","choicesErrors","correctResponseError","correctResponse","promptError","rationaleErrors","teacherInstructionsError","nrOfColumnsAvailable","length","Array","from","_","i","baseInputConfiguration","toolbarOpts","position","getPluginProps","validationMessage","defaultImageMaxWidth","defaultImageMaxHeight","addChoiceButtonTooltip","panelSettings","label","enabled","options","panelProperties","studentInstructionsEnabled","rubricEnabled","Settings","Properties","inputConfiguration","map","choice","index","c","value","root","Main","showWarning","onModelChanged","minAnswerChoices","setState","splice","push","utils","firstAvailableIndex","type","correct","key","correctFound","state","React","Component","PropTypes","object","isRequired","disableSidePanel","bool","func","shape","add","Styled"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\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 { withStyles } from '@material-ui/core/styles';\nimport Button from '@material-ui/core/Button';\nimport Tooltip from '@material-ui/core/Tooltip';\nimport Typography from '@material-ui/core/Typography';\nimport Info from '@material-ui/icons/Info';\nimport merge from 'lodash/merge';\nimport { generateValidationMessage } from './utils';\n\nconst { Panel, toggle, radio, dropdown } = settings;\n\nconst MAX_CHOICES = 9;\n\nconst styles = (theme) => ({\n  promptHolder: {\n    width: '100%',\n    paddingTop: theme.spacing.unit * 2,\n    marginBottom: theme.spacing.unit * 2,\n  },\n  rationaleHolder: {\n    flex: 1,\n    marginTop: theme.spacing.unit * 1.5,\n    paddingTop: theme.spacing.unit * 2,\n    marginLeft: theme.spacing.unit * 3.5,\n  },\n  choiceConfigurationHolder: {\n    display: 'flex',\n    flexDirection: 'column',\n    marginBottom: theme.spacing.unit,\n  },\n  choiceConfiguration: {\n    width: '100%',\n  },\n  switchElement: {\n    justifyContent: 'space-between',\n    margin: 0,\n  },\n  addButton: {\n    marginTop: theme.spacing.unit,\n    float: 'right',\n  },\n  disableButton: {\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  flexContainer: {\n    display: 'flex',\n    alignItems: 'center',\n  },\n  titleText: {\n    fontSize: theme.typography.fontSize + 2,\n    marginRight: theme.spacing.unit,\n  },\n  tooltip: {\n    fontSize: theme.typography.fontSize - 2,\n    whiteSpace: 'pre',\n    maxWidth: '500px',\n  },\n  errorText: {\n    fontSize: theme.typography.fontSize - 2,\n    color: theme.palette.error.main,\n    paddingTop: theme.spacing.unit,\n  },\n});\n\nconst Design = withStyles(styles)((props) => {\n  const {\n    classes,\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      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        <InputContainer label={teacherInstructions.label} className={classes.promptHolder}>\n          <EditableHtml\n            className={classes.prompt}\n            markup={model.teacherInstructions || ''}\n            onChange={onTeacherInstructionsChanged}\n            imageSupport={imageSupport}\n            nonEmpty={false}\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 && <div className={classes.errorText}>{teacherInstructionsError}</div>}\n        </InputContainer>\n      )}\n\n      {promptEnabled && (\n        <InputContainer label={prompt.label} className={classes.promptHolder}>\n          <EditableHtml\n            className={classes.prompt}\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 && <div className={classes.errorText}>{promptError}</div>}\n        </InputContainer>\n      )}\n\n      <div className={classes.flexContainer}>\n        <Typography className={classes.titleText} component={'div'}>Choices</Typography>\n        <Tooltip\n          classes={{ tooltip: classes.tooltip }}\n          disableFocusListener\n          disableTouchListener\n          placement={'right'}\n          title={validationMessage}\n        >\n          <Info fontSize={'small'} color={'primary'} />\n        </Tooltip>\n      </div>\n\n      {choices.map((choice, index) => (\n        <div key={`choice-${index}`} className={classes.choiceConfigurationHolder}>\n          <ChoiceConfiguration\n            key={index}\n            index={index + 1}\n            useLetterOrdering={model.choicePrefix === 'letters'}\n            className={classes.choiceConfiguration}\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            <InputContainer key={`rationale-${index}`} label={rationale.label} className={classes.rationaleHolder}>\n              <EditableHtml\n                className={classes.rationale}\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                <div className={classes.errorText}>{rationaleErrors?.[choice.value]}</div>\n              )}\n            </InputContainer>\n          )}\n        </div>\n      ))}\n\n      {correctResponseError && <div className={classes.errorText}>{correctResponseError}</div>}\n      {answerChoicesError && <div className={classes.errorText}>{answerChoicesError}</div>}\n\n      {addChoiceButton.settings && (\n        <Tooltip title={addChoiceButtonTooltip} classes={{ tooltip: classes.tooltip }}>\n          <Button\n            classes={{ root: maxAnswerChoices && choices?.length >= maxAnswerChoices && classes.disableButton }}\n            className={classes.addButton}\n            variant=\"contained\"\n            color=\"primary\"\n            onClick={onAddChoice}\n          >\n            {addChoiceButton.label}\n          </Button>\n        </Tooltip>\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    classes: PropTypes.object.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\nconst Styled = withStyles(styles)(Main);\n\nexport default Styled;\n"]}
|
package/configure/lib/utils.js
CHANGED
|
@@ -15,4 +15,4 @@ var generateValidationMessage = function generateValidationMessage(config) {
|
|
|
15
15
|
};
|
|
16
16
|
|
|
17
17
|
exports.generateValidationMessage = generateValidationMessage;
|
|
18
|
-
//# sourceMappingURL=
|
|
18
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6WyJnZW5lcmF0ZVZhbGlkYXRpb25NZXNzYWdlIiwiY29uZmlnIiwibWluQW5zd2VyQ2hvaWNlcyIsIm1heEFuc3dlckNob2ljZXMiLCJhbnN3ZXJDaG9pY2VzTWVzc2FnZSIsImNvcnJlY3RBbnN3ZXJNZXNzYWdlIiwibWVzc2FnZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFPLElBQU1BLHlCQUF5QixHQUFHLFNBQTVCQSx5QkFBNEIsQ0FBQ0MsTUFBRCxFQUFZO0FBQ25ELE1BQVFDLGdCQUFSLEdBQStDRCxNQUEvQyxDQUFRQyxnQkFBUjtBQUFBLE1BQTBCQyxnQkFBMUIsR0FBK0NGLE1BQS9DLENBQTBCRSxnQkFBMUI7QUFFQSxNQUFNQyxvQkFBb0IsR0FDeEIscUNBQThCRixnQkFBOUIsVUFDQ0MsZ0JBQWdCLHlCQUFrQkEsZ0JBQWxCLFNBQXdDLEVBRHpELElBRUEseUJBRkEsR0FHQSx1REFKRjtBQU1BLE1BQU1FLG9CQUFvQixHQUFHLHFDQUE3QjtBQUVBLE1BQU1DLE9BQU8sR0FBRyw2QkFBNkJGLG9CQUE3QixHQUFvREMsb0JBQXBFO0FBRUEsU0FBT0MsT0FBUDtBQUNELENBZE0iLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZ2VuZXJhdGVWYWxpZGF0aW9uTWVzc2FnZSA9IChjb25maWcpID0+IHtcbiAgY29uc3QgeyBtaW5BbnN3ZXJDaG9pY2VzLCBtYXhBbnN3ZXJDaG9pY2VzIH0gPSBjb25maWc7XG5cbiAgY29uc3QgYW5zd2VyQ2hvaWNlc01lc3NhZ2UgPVxuICAgIGBcXG5UaGVyZSBzaG91bGQgYmUgYXQgbGVhc3QgJHttaW5BbnN3ZXJDaG9pY2VzfSBgICtcbiAgICAobWF4QW5zd2VyQ2hvaWNlcyA/IGBhbmQgYXQgbW9zdCAke21heEFuc3dlckNob2ljZXN9IGAgOiAnJykgK1xuICAgICdhbnN3ZXIgY2hvaWNlcyBkZWZpbmVkLicgK1xuICAgICdcXG5FdmVyeSBhbnN3ZXIgY2hvaWNlIHNob3VsZCBiZSBub24tYmxhbmsgYW5kIHVuaXF1ZS4nO1xuXG4gIGNvbnN0IGNvcnJlY3RBbnN3ZXJNZXNzYWdlID0gJ1xcbkEgY29ycmVjdCBhbnN3ZXIgbXVzdCBiZSBkZWZpbmVkLic7XG5cbiAgY29uc3QgbWVzc2FnZSA9ICdWYWxpZGF0aW9uIHJlcXVpcmVtZW50czonICsgYW5zd2VyQ2hvaWNlc01lc3NhZ2UgKyBjb3JyZWN0QW5zd2VyTWVzc2FnZTtcblxuICByZXR1cm4gbWVzc2FnZTtcbn07XG4iXX0=
|
package/configure/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pie-element/multiple-choice-configure",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.8.0-beta.0",
|
|
4
4
|
"private": true,
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"module": "src/index.js",
|
|
@@ -8,7 +8,9 @@
|
|
|
8
8
|
"@material-ui/core": "^3.9.2",
|
|
9
9
|
"@material-ui/icons": "^3.0.1",
|
|
10
10
|
"@pie-framework/pie-configure-events": "^1.3.0",
|
|
11
|
-
"@pie-lib/
|
|
11
|
+
"@pie-lib/config-ui": "^11.11.0-beta.0",
|
|
12
|
+
"@pie-lib/editable-html": "^11.3.0-beta.0",
|
|
13
|
+
"@pie-lib/render-ui": "^4.17.0-beta.0",
|
|
12
14
|
"debug": "^3.1.0",
|
|
13
15
|
"lodash": "^4.17.15",
|
|
14
16
|
"prop-types": "^15.6.2",
|
package/controller/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
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
|
+
# [5.11.0-beta.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-controller@5.10.0...@pie-element/multiple-choice-controller@5.11.0-beta.0) (2025-07-19)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @pie-element/multiple-choice-controller
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
6
14
|
# [5.10.0](https://github.com/pie-framework/pie-elements/compare/@pie-element/multiple-choice-controller@5.9.10...@pie-element/multiple-choice-controller@5.10.0) (2025-07-18)
|
|
7
15
|
|
|
8
16
|
|