@pie-element/multiple-choice 11.4.4-next.0 → 12.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/configure/lib/__tests__/root.test.js +286 -0
- package/configure/lib/defaults.js +3 -5
- package/configure/lib/defaults.js.map +1 -1
- package/configure/lib/index.js +156 -193
- package/configure/lib/index.js.map +1 -1
- package/configure/lib/main.js +325 -445
- package/configure/lib/main.js.map +1 -1
- package/configure/lib/utils.js +9 -9
- package/configure/lib/utils.js.map +1 -1
- package/configure/package.json +10 -8
- package/controller/lib/__tests__/index.test.js +520 -0
- package/controller/lib/__tests__/utils.test.js +8 -0
- package/controller/lib/defaults.js +3 -4
- package/controller/lib/defaults.js.map +1 -1
- package/controller/lib/index.js +145 -240
- package/controller/lib/index.js.map +1 -1
- package/controller/lib/utils.js +5 -17
- package/controller/lib/utils.js.map +1 -1
- package/controller/package.json +2 -2
- package/docs/demo/pie.manifest.json +11 -0
- package/lib/__tests__/choice-input-test.js +49 -0
- package/lib/__tests__/index-test.js +200 -0
- package/lib/__tests__/key-events-test.js +95 -0
- package/lib/__tests__/multiple-choice-test.js +101 -0
- package/lib/__tests__/session-updater-test.js +70 -0
- package/lib/choice-input.js +312 -369
- package/lib/choice-input.js.map +1 -1
- package/lib/choice.js +164 -220
- package/lib/choice.js.map +1 -1
- package/lib/feedback-tick.js +75 -115
- package/lib/feedback-tick.js.map +1 -1
- package/lib/index.js +242 -342
- package/lib/index.js.map +1 -1
- package/lib/main.js +39 -86
- package/lib/main.js.map +1 -1
- package/lib/multiple-choice.js +305 -397
- package/lib/multiple-choice.js.map +1 -1
- package/lib/print.js +40 -78
- package/lib/print.js.map +1 -1
- package/lib/session-updater.js +5 -16
- package/lib/session-updater.js.map +1 -1
- package/package.json +13 -16
- package/module/configure.js +0 -1
- package/module/controller.js +0 -3472
- package/module/demo.js +0 -86
- package/module/element.js +0 -1
- 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 -1
package/controller/lib/utils.js
CHANGED
|
@@ -1,28 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.isResponseCorrect = exports.getCorrectResponse = void 0;
|
|
9
|
-
|
|
10
8
|
var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
|
|
11
|
-
|
|
12
|
-
var getCorrectResponse = function getCorrectResponse(choices) {
|
|
13
|
-
return choices.filter(function (c) {
|
|
14
|
-
return c.correct;
|
|
15
|
-
}).map(function (c) {
|
|
16
|
-
return c.value;
|
|
17
|
-
}).sort();
|
|
18
|
-
};
|
|
19
|
-
|
|
9
|
+
const getCorrectResponse = choices => choices.filter(c => c.correct).map(c => c.value).sort();
|
|
20
10
|
exports.getCorrectResponse = getCorrectResponse;
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
return session && (0, _isEqual["default"])((session.value || []).sort(), correctResponse);
|
|
11
|
+
const isResponseCorrect = (question, session) => {
|
|
12
|
+
let correctResponse = getCorrectResponse(question.choices);
|
|
13
|
+
return session && (0, _isEqual.default)((session.value || []).sort(), correctResponse);
|
|
25
14
|
};
|
|
26
|
-
|
|
27
15
|
exports.isResponseCorrect = isResponseCorrect;
|
|
28
|
-
//# sourceMappingURL=
|
|
16
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfaXNFcXVhbCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZ2V0Q29ycmVjdFJlc3BvbnNlIiwiY2hvaWNlcyIsImZpbHRlciIsImMiLCJjb3JyZWN0IiwibWFwIiwidmFsdWUiLCJzb3J0IiwiZXhwb3J0cyIsImlzUmVzcG9uc2VDb3JyZWN0IiwicXVlc3Rpb24iLCJzZXNzaW9uIiwiY29ycmVjdFJlc3BvbnNlIiwiaXNFcXVhbCJdLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaXNFcXVhbCBmcm9tICdsb2Rhc2gvaXNFcXVhbCc7XG5cbmV4cG9ydCBjb25zdCBnZXRDb3JyZWN0UmVzcG9uc2UgPSAoY2hvaWNlcykgPT5cbiAgY2hvaWNlc1xuICAgIC5maWx0ZXIoKGMpID0+IGMuY29ycmVjdClcbiAgICAubWFwKChjKSA9PiBjLnZhbHVlKVxuICAgIC5zb3J0KCk7XG5cbmV4cG9ydCBjb25zdCBpc1Jlc3BvbnNlQ29ycmVjdCA9IChxdWVzdGlvbiwgc2Vzc2lvbikgPT4ge1xuICBsZXQgY29ycmVjdFJlc3BvbnNlID0gZ2V0Q29ycmVjdFJlc3BvbnNlKHF1ZXN0aW9uLmNob2ljZXMpO1xuICByZXR1cm4gc2Vzc2lvbiAmJiBpc0VxdWFsKChzZXNzaW9uLnZhbHVlIHx8IFtdKS5zb3J0KCksIGNvcnJlY3RSZXNwb25zZSk7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsUUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBRU8sTUFBTUMsa0JBQWtCLEdBQUlDLE9BQU8sSUFDeENBLE9BQU8sQ0FDSkMsTUFBTSxDQUFFQyxDQUFDLElBQUtBLENBQUMsQ0FBQ0MsT0FBTyxDQUFDLENBQ3hCQyxHQUFHLENBQUVGLENBQUMsSUFBS0EsQ0FBQyxDQUFDRyxLQUFLLENBQUMsQ0FDbkJDLElBQUksQ0FBQyxDQUFDO0FBQUNDLE9BQUEsQ0FBQVIsa0JBQUEsR0FBQUEsa0JBQUE7QUFFTCxNQUFNUyxpQkFBaUIsR0FBR0EsQ0FBQ0MsUUFBUSxFQUFFQyxPQUFPLEtBQUs7RUFDdEQsSUFBSUMsZUFBZSxHQUFHWixrQkFBa0IsQ0FBQ1UsUUFBUSxDQUFDVCxPQUFPLENBQUM7RUFDMUQsT0FBT1UsT0FBTyxJQUFJLElBQUFFLGdCQUFPLEVBQUMsQ0FBQ0YsT0FBTyxDQUFDTCxLQUFLLElBQUksRUFBRSxFQUFFQyxJQUFJLENBQUMsQ0FBQyxFQUFFSyxlQUFlLENBQUM7QUFDMUUsQ0FBQztBQUFDSixPQUFBLENBQUFDLGlCQUFBLEdBQUFBLGlCQUFBIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"utils.js","names":["_isEqual","_interopRequireDefault","require","getCorrectResponse","choices","filter","c","correct","map","value","sort","exports","isResponseCorrect","question","session","correctResponse","isEqual"],"sources":["../src/utils.js"],"sourcesContent":["import isEqual from 'lodash/isEqual';\n\nexport const getCorrectResponse = (choices) =>\n choices\n .filter((c) => c.correct)\n .map((c) => c.value)\n .sort();\n\nexport const isResponseCorrect = (question, session) => {\n let correctResponse = getCorrectResponse(question.choices);\n return session && isEqual((session.value || []).sort(), correctResponse);\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEO,MAAMC,kBAAkB,GAAIC,OAAO,IACxCA,OAAO,CACJC,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACC,OAAO,CAAC,CACxBC,GAAG,CAAEF,CAAC,IAAKA,CAAC,CAACG,KAAK,CAAC,CACnBC,IAAI,CAAC,CAAC;AAACC,OAAA,CAAAR,kBAAA,GAAAA,kBAAA;AAEL,MAAMS,iBAAiB,GAAGA,CAACC,QAAQ,EAAEC,OAAO,KAAK;EACtD,IAAIC,eAAe,GAAGZ,kBAAkB,CAACU,QAAQ,CAACT,OAAO,CAAC;EAC1D,OAAOU,OAAO,IAAI,IAAAE,gBAAO,EAAC,CAACF,OAAO,CAACL,KAAK,IAAI,EAAE,EAAEC,IAAI,CAAC,CAAC,EAAEK,eAAe,CAAC;AAC1E,CAAC;AAACJ,OAAA,CAAAC,iBAAA,GAAAA,iBAAA","ignoreList":[]}
|
package/controller/package.json
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pie-element/multiple-choice-controller",
|
|
3
3
|
"private": true,
|
|
4
|
-
"version": "
|
|
4
|
+
"version": "7.0.0-beta.0",
|
|
5
5
|
"description": "",
|
|
6
6
|
"main": "lib/index.js",
|
|
7
7
|
"module": "src/index.js",
|
|
8
8
|
"author": "",
|
|
9
9
|
"license": "ISC",
|
|
10
10
|
"dependencies": {
|
|
11
|
-
"@pie-lib/controller-utils": "0.22.
|
|
11
|
+
"@pie-lib/controller-utils": "0.22.4-next.0",
|
|
12
12
|
"debug": "^3.1.0",
|
|
13
13
|
"lodash": "^4.17.15"
|
|
14
14
|
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _react2 = require("@testing-library/react");
|
|
7
|
+
var _choiceInput = require("../choice-input");
|
|
8
|
+
describe('ChoiceInput', () => {
|
|
9
|
+
let onChange;
|
|
10
|
+
const mkWrapper = (opts = {}) => {
|
|
11
|
+
const defaultOpts = {
|
|
12
|
+
checked: false,
|
|
13
|
+
disabled: false,
|
|
14
|
+
choiceMode: 'checkbox',
|
|
15
|
+
label: 'label',
|
|
16
|
+
displayKey: '1',
|
|
17
|
+
correctness: 'correct',
|
|
18
|
+
value: 'value',
|
|
19
|
+
classes: {
|
|
20
|
+
label: 'label'
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
const finalOpts = {
|
|
24
|
+
...defaultOpts,
|
|
25
|
+
...opts
|
|
26
|
+
};
|
|
27
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_choiceInput.ChoiceInput, (0, _extends2.default)({}, finalOpts, {
|
|
28
|
+
onChange: onChange
|
|
29
|
+
})));
|
|
30
|
+
};
|
|
31
|
+
beforeEach(() => {
|
|
32
|
+
onChange = jest.fn();
|
|
33
|
+
});
|
|
34
|
+
describe('onToggleChoice', () => {
|
|
35
|
+
it('calls handler when checkbox is clicked', () => {
|
|
36
|
+
const {
|
|
37
|
+
container
|
|
38
|
+
} = mkWrapper({
|
|
39
|
+
disabled: false
|
|
40
|
+
});
|
|
41
|
+
const input = container.querySelector('input[type="checkbox"]');
|
|
42
|
+
if (input) {
|
|
43
|
+
_react2.fireEvent.click(input);
|
|
44
|
+
expect(onChange).toHaveBeenCalled();
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdDIiLCJfY2hvaWNlSW5wdXQiLCJkZXNjcmliZSIsIm9uQ2hhbmdlIiwibWtXcmFwcGVyIiwib3B0cyIsImRlZmF1bHRPcHRzIiwiY2hlY2tlZCIsImRpc2FibGVkIiwiY2hvaWNlTW9kZSIsImxhYmVsIiwiZGlzcGxheUtleSIsImNvcnJlY3RuZXNzIiwidmFsdWUiLCJjbGFzc2VzIiwiZmluYWxPcHRzIiwicmVuZGVyIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJDaG9pY2VJbnB1dCIsIl9leHRlbmRzMiIsImJlZm9yZUVhY2giLCJqZXN0IiwiZm4iLCJpdCIsImNvbnRhaW5lciIsImlucHV0IiwicXVlcnlTZWxlY3RvciIsImZpcmVFdmVudCIsImNsaWNrIiwiZXhwZWN0IiwidG9IYXZlQmVlbkNhbGxlZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vY2hvaWNlLWlucHV0LXRlc3QuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyByZW5kZXIsIGZpcmVFdmVudCB9IGZyb20gJ0B0ZXN0aW5nLWxpYnJhcnkvcmVhY3QnO1xuaW1wb3J0IHsgQ2hvaWNlSW5wdXQgfSBmcm9tICcuLi9jaG9pY2UtaW5wdXQnO1xuXG5kZXNjcmliZSgnQ2hvaWNlSW5wdXQnLCAoKSA9PiB7XG4gIGxldCBvbkNoYW5nZTtcblxuICBjb25zdCBta1dyYXBwZXIgPSAob3B0cyA9IHt9KSA9PiB7XG4gICAgY29uc3QgZGVmYXVsdE9wdHMgPSB7XG4gICAgICBjaGVja2VkOiBmYWxzZSxcbiAgICAgIGRpc2FibGVkOiBmYWxzZSxcbiAgICAgIGNob2ljZU1vZGU6ICdjaGVja2JveCcsXG4gICAgICBsYWJlbDogJ2xhYmVsJyxcbiAgICAgIGRpc3BsYXlLZXk6ICcxJyxcbiAgICAgIGNvcnJlY3RuZXNzOiAnY29ycmVjdCcsXG4gICAgICB2YWx1ZTogJ3ZhbHVlJyxcbiAgICAgIGNsYXNzZXM6IHtcbiAgICAgICAgbGFiZWw6ICdsYWJlbCcsXG4gICAgICB9LFxuICAgIH07XG5cbiAgICBjb25zdCBmaW5hbE9wdHMgPSB7IC4uLmRlZmF1bHRPcHRzLCAuLi5vcHRzIH07XG5cbiAgICByZXR1cm4gcmVuZGVyKDxDaG9pY2VJbnB1dCB7Li4uZmluYWxPcHRzfSBvbkNoYW5nZT17b25DaGFuZ2V9IC8+KTtcbiAgfTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICBvbkNoYW5nZSA9IGplc3QuZm4oKTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ29uVG9nZ2xlQ2hvaWNlJywgKCkgPT4ge1xuICAgIGl0KCdjYWxscyBoYW5kbGVyIHdoZW4gY2hlY2tib3ggaXMgY2xpY2tlZCcsICgpID0+IHtcbiAgICAgIGNvbnN0IHsgY29udGFpbmVyIH0gPSBta1dyYXBwZXIoeyBkaXNhYmxlZDogZmFsc2UgfSk7XG4gICAgICBjb25zdCBpbnB1dCA9IGNvbnRhaW5lci5xdWVyeVNlbGVjdG9yKCdpbnB1dFt0eXBlPVwiY2hlY2tib3hcIl0nKTtcblxuICAgICAgaWYgKGlucHV0KSB7XG4gICAgICAgIGZpcmVFdmVudC5jbGljayhpbnB1dCk7XG4gICAgICAgIGV4cGVjdChvbkNoYW5nZSkudG9IYXZlQmVlbkNhbGxlZCgpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsWUFBQSxHQUFBRixPQUFBO0FBRUFHLFFBQVEsQ0FBQyxhQUFhLEVBQUUsTUFBTTtFQUM1QixJQUFJQyxRQUFRO0VBRVosTUFBTUMsU0FBUyxHQUFHQSxDQUFDQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEtBQUs7SUFDL0IsTUFBTUMsV0FBVyxHQUFHO01BQ2xCQyxPQUFPLEVBQUUsS0FBSztNQUNkQyxRQUFRLEVBQUUsS0FBSztNQUNmQyxVQUFVLEVBQUUsVUFBVTtNQUN0QkMsS0FBSyxFQUFFLE9BQU87TUFDZEMsVUFBVSxFQUFFLEdBQUc7TUFDZkMsV0FBVyxFQUFFLFNBQVM7TUFDdEJDLEtBQUssRUFBRSxPQUFPO01BQ2RDLE9BQU8sRUFBRTtRQUNQSixLQUFLLEVBQUU7TUFDVDtJQUNGLENBQUM7SUFFRCxNQUFNSyxTQUFTLEdBQUc7TUFBRSxHQUFHVCxXQUFXO01BQUUsR0FBR0Q7SUFBSyxDQUFDO0lBRTdDLE9BQU8sSUFBQVcsY0FBTSxlQUFDbkIsTUFBQSxDQUFBb0IsT0FBQSxDQUFBQyxhQUFBLENBQUNqQixZQUFBLENBQUFrQixXQUFXLE1BQUFDLFNBQUEsQ0FBQUgsT0FBQSxNQUFLRixTQUFTO01BQUVaLFFBQVEsRUFBRUE7SUFBUyxFQUFFLENBQUMsQ0FBQztFQUNuRSxDQUFDO0VBRURrQixVQUFVLENBQUMsTUFBTTtJQUNmbEIsUUFBUSxHQUFHbUIsSUFBSSxDQUFDQyxFQUFFLENBQUMsQ0FBQztFQUN0QixDQUFDLENBQUM7RUFFRnJCLFFBQVEsQ0FBQyxnQkFBZ0IsRUFBRSxNQUFNO0lBQy9Cc0IsRUFBRSxDQUFDLHdDQUF3QyxFQUFFLE1BQU07TUFDakQsTUFBTTtRQUFFQztNQUFVLENBQUMsR0FBR3JCLFNBQVMsQ0FBQztRQUFFSSxRQUFRLEVBQUU7TUFBTSxDQUFDLENBQUM7TUFDcEQsTUFBTWtCLEtBQUssR0FBR0QsU0FBUyxDQUFDRSxhQUFhLENBQUMsd0JBQXdCLENBQUM7TUFFL0QsSUFBSUQsS0FBSyxFQUFFO1FBQ1RFLGlCQUFTLENBQUNDLEtBQUssQ0FBQ0gsS0FBSyxDQUFDO1FBQ3RCSSxNQUFNLENBQUMzQixRQUFRLENBQUMsQ0FBQzRCLGdCQUFnQixDQUFDLENBQUM7TUFDckM7SUFDRixDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _piePlayerEvents = require("@pie-framework/pie-player-events");
|
|
7
|
+
var _main = _interopRequireDefault(require("../main"));
|
|
8
|
+
var _index = _interopRequireWildcard(require("../index"));
|
|
9
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
10
|
+
jest.useFakeTimers();
|
|
11
|
+
jest.mock('@pie-lib/math-rendering', () => ({
|
|
12
|
+
renderMath: jest.fn()
|
|
13
|
+
}));
|
|
14
|
+
jest.mock('lodash/debounce', () => jest.fn(fn => fn));
|
|
15
|
+
|
|
16
|
+
// Mock the render-ui PreviewLayout
|
|
17
|
+
jest.mock('@pie-lib/render-ui', () => ({
|
|
18
|
+
PreviewLayout: ({
|
|
19
|
+
children
|
|
20
|
+
}) => /*#__PURE__*/_react.default.createElement("div", {
|
|
21
|
+
"data-testid": "preview-layout"
|
|
22
|
+
}, children),
|
|
23
|
+
Collapsible: ({
|
|
24
|
+
children,
|
|
25
|
+
labels
|
|
26
|
+
}) => /*#__PURE__*/_react.default.createElement("div", {
|
|
27
|
+
"data-testid": "collapsible"
|
|
28
|
+
}, /*#__PURE__*/_react.default.createElement("button", null, labels?.hidden || 'Show'), children),
|
|
29
|
+
PreviewPrompt: ({
|
|
30
|
+
prompt
|
|
31
|
+
}) => /*#__PURE__*/_react.default.createElement("div", {
|
|
32
|
+
"data-testid": "preview-prompt"
|
|
33
|
+
}, prompt),
|
|
34
|
+
color: {
|
|
35
|
+
text: () => '#000',
|
|
36
|
+
background: () => '#fff',
|
|
37
|
+
primary: () => '#1976d2',
|
|
38
|
+
correct: () => '#4caf50',
|
|
39
|
+
incorrect: () => '#f44336',
|
|
40
|
+
disabled: () => '#9e9e9e'
|
|
41
|
+
}
|
|
42
|
+
}));
|
|
43
|
+
describe('isComplete', () => {
|
|
44
|
+
it.each`
|
|
45
|
+
session | expected
|
|
46
|
+
${{
|
|
47
|
+
value: [1, 2, 3]
|
|
48
|
+
}} | ${true}
|
|
49
|
+
${{
|
|
50
|
+
value: []
|
|
51
|
+
}} | ${false}
|
|
52
|
+
${{}} | ${false}
|
|
53
|
+
${null} | ${false}
|
|
54
|
+
${undefined} | ${false}
|
|
55
|
+
`('session = $session is complete => $expected', ({
|
|
56
|
+
session,
|
|
57
|
+
expected
|
|
58
|
+
}) => {
|
|
59
|
+
expect((0, _index.isComplete)(session)).toEqual(expected);
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
describe('multiple-choice', () => {
|
|
63
|
+
describe('rendering', () => {
|
|
64
|
+
const renderComponent = (modelOverrides = {}) => {
|
|
65
|
+
const defaultProps = {
|
|
66
|
+
model: {
|
|
67
|
+
choices: [],
|
|
68
|
+
prompt: 'Select an answer',
|
|
69
|
+
...modelOverrides
|
|
70
|
+
},
|
|
71
|
+
session: {},
|
|
72
|
+
classes: {}
|
|
73
|
+
};
|
|
74
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_main.default, defaultProps));
|
|
75
|
+
};
|
|
76
|
+
it('renders without crashing', () => {
|
|
77
|
+
const {
|
|
78
|
+
container
|
|
79
|
+
} = renderComponent();
|
|
80
|
+
expect(container).toBeInTheDocument();
|
|
81
|
+
});
|
|
82
|
+
it('renders the preview layout wrapper', () => {
|
|
83
|
+
renderComponent();
|
|
84
|
+
expect(_react2.screen.getByTestId('preview-layout')).toBeInTheDocument();
|
|
85
|
+
});
|
|
86
|
+
it('renders with rationale', () => {
|
|
87
|
+
renderComponent({
|
|
88
|
+
rationale: 'This is rationale'
|
|
89
|
+
});
|
|
90
|
+
expect(_react2.screen.getByText('This is rationale')).toBeInTheDocument();
|
|
91
|
+
});
|
|
92
|
+
it('renders with teacherInstructions', () => {
|
|
93
|
+
renderComponent({
|
|
94
|
+
teacherInstructions: 'These are teacher instructions'
|
|
95
|
+
});
|
|
96
|
+
expect(_react2.screen.getByText('These are teacher instructions')).toBeInTheDocument();
|
|
97
|
+
});
|
|
98
|
+
it('renders choices when provided', () => {
|
|
99
|
+
renderComponent({
|
|
100
|
+
choices: [{
|
|
101
|
+
value: 'a',
|
|
102
|
+
label: 'Option A'
|
|
103
|
+
}, {
|
|
104
|
+
value: 'b',
|
|
105
|
+
label: 'Option B'
|
|
106
|
+
}]
|
|
107
|
+
});
|
|
108
|
+
expect(_react2.screen.getByText('Option A')).toBeInTheDocument();
|
|
109
|
+
expect(_react2.screen.getByText('Option B')).toBeInTheDocument();
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
describe('events', () => {
|
|
113
|
+
describe('model', () => {
|
|
114
|
+
it('dispatches model set event', () => {
|
|
115
|
+
const el = new _index.default();
|
|
116
|
+
el.tagName = 'mc-el';
|
|
117
|
+
el.model = {};
|
|
118
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.ModelSetEvent('mc-el', false, true));
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
describe('onChange', () => {
|
|
122
|
+
it('dispatches session changed event - add answer (checkbox)', () => {
|
|
123
|
+
const el = new _index.default();
|
|
124
|
+
el.tagName = 'mc-el';
|
|
125
|
+
el.model = {
|
|
126
|
+
choiceMode: 'checkbox'
|
|
127
|
+
};
|
|
128
|
+
el.session = {
|
|
129
|
+
value: []
|
|
130
|
+
};
|
|
131
|
+
el._onChange({
|
|
132
|
+
value: 'a',
|
|
133
|
+
selected: true
|
|
134
|
+
});
|
|
135
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', true));
|
|
136
|
+
});
|
|
137
|
+
it('dispatches session changed event - remove answer (checkbox)', () => {
|
|
138
|
+
const el = new _index.default();
|
|
139
|
+
el.tagName = 'mc-el';
|
|
140
|
+
el.model = {
|
|
141
|
+
choiceMode: 'checkbox'
|
|
142
|
+
};
|
|
143
|
+
el.session = {
|
|
144
|
+
value: ['a']
|
|
145
|
+
};
|
|
146
|
+
el._onChange({
|
|
147
|
+
value: 'a',
|
|
148
|
+
selected: false
|
|
149
|
+
});
|
|
150
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', false));
|
|
151
|
+
});
|
|
152
|
+
it('dispatches session changed event - add/remove answer (checkbox)', () => {
|
|
153
|
+
const el = new _index.default();
|
|
154
|
+
el.tagName = 'mc-el';
|
|
155
|
+
el.model = {
|
|
156
|
+
choiceMode: 'checkbox'
|
|
157
|
+
};
|
|
158
|
+
el.session = {
|
|
159
|
+
value: ['1']
|
|
160
|
+
};
|
|
161
|
+
el._onChange({
|
|
162
|
+
id: '2',
|
|
163
|
+
selected: true
|
|
164
|
+
});
|
|
165
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', true));
|
|
166
|
+
el._onChange({
|
|
167
|
+
id: '1',
|
|
168
|
+
selected: false
|
|
169
|
+
});
|
|
170
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', true));
|
|
171
|
+
el._onChange({
|
|
172
|
+
id: '2',
|
|
173
|
+
selected: false
|
|
174
|
+
});
|
|
175
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', false));
|
|
176
|
+
});
|
|
177
|
+
it('dispatches session changed event - add/change answer (radio)', () => {
|
|
178
|
+
const el = new _index.default();
|
|
179
|
+
el.tagName = 'mc-el';
|
|
180
|
+
el.model = {
|
|
181
|
+
choiceMode: 'radio'
|
|
182
|
+
};
|
|
183
|
+
el.session = {
|
|
184
|
+
value: []
|
|
185
|
+
};
|
|
186
|
+
el._onChange({
|
|
187
|
+
value: 'a',
|
|
188
|
+
selected: true
|
|
189
|
+
});
|
|
190
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', true));
|
|
191
|
+
el._onChange({
|
|
192
|
+
value: 'b',
|
|
193
|
+
selected: true
|
|
194
|
+
});
|
|
195
|
+
expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('mc-el', true));
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
});
|
|
200
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_piePlayerEvents","_main","_index","_interopRequireWildcard","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","jest","useFakeTimers","mock","renderMath","fn","PreviewLayout","children","createElement","Collapsible","labels","hidden","PreviewPrompt","prompt","color","text","background","primary","correct","incorrect","disabled","describe","it","each","value","undefined","session","expected","expect","isComplete","toEqual","renderComponent","modelOverrides","defaultProps","model","choices","classes","render","container","toBeInTheDocument","screen","getByTestId","rationale","getByText","teacherInstructions","label","el","MultipleChoice","tagName","dispatchEvent","toBeCalledWith","ModelSetEvent","choiceMode","_onChange","selected","SessionChangedEvent","id"],"sources":["../../src/__tests__/index-test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport { ModelSetEvent, SessionChangedEvent } from '@pie-framework/pie-player-events';\nimport MultipleChoiceComponent from '../main';\nimport MultipleChoice from '../index';\nimport { isComplete } from '../index';\n\njest.useFakeTimers();\njest.mock('@pie-lib/math-rendering', () => ({ renderMath: jest.fn() }));\njest.mock('lodash/debounce', () => jest.fn((fn) => fn));\n\n// Mock the render-ui PreviewLayout\njest.mock('@pie-lib/render-ui', () => ({\n  PreviewLayout: ({ children }) => <div data-testid=\"preview-layout\">{children}</div>,\n  Collapsible: ({ children, labels }) => (\n    <div data-testid=\"collapsible\">\n      <button>{labels?.hidden || 'Show'}</button>\n      {children}\n    </div>\n  ),\n  PreviewPrompt: ({ prompt }) => <div data-testid=\"preview-prompt\">{prompt}</div>,\n  color: {\n    text: () => '#000',\n    background: () => '#fff',\n    primary: () => '#1976d2',\n    correct: () => '#4caf50',\n    incorrect: () => '#f44336',\n    disabled: () => '#9e9e9e',\n  },\n}));\n\ndescribe('isComplete', () => {\n  it.each`\n    session                 | expected\n    ${{ value: [1, 2, 3] }} | ${true}\n    ${{ value: [] }}        | ${false}\n    ${{}}                   | ${false}\n    ${null}                 | ${false}\n    ${undefined}            | ${false}\n  `('session = $session is complete => $expected', ({ session, expected }) => {\n    expect(isComplete(session)).toEqual(expected);\n  });\n});\n\ndescribe('multiple-choice', () => {\n  describe('rendering', () => {\n    const renderComponent = (modelOverrides = {}) => {\n      const defaultProps = {\n        model: {\n          choices: [],\n          prompt: 'Select an answer',\n          ...modelOverrides,\n        },\n        session: {},\n        classes: {},\n      };\n\n      return render(<MultipleChoiceComponent {...defaultProps} />);\n    };\n\n    it('renders without crashing', () => {\n      const { container } = renderComponent();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders the preview layout wrapper', () => {\n      renderComponent();\n      expect(screen.getByTestId('preview-layout')).toBeInTheDocument();\n    });\n\n    it('renders with rationale', () => {\n      renderComponent({ rationale: 'This is rationale' });\n      expect(screen.getByText('This is rationale')).toBeInTheDocument();\n    });\n\n    it('renders with teacherInstructions', () => {\n      renderComponent({ teacherInstructions: 'These are teacher instructions' });\n      expect(screen.getByText('These are teacher instructions')).toBeInTheDocument();\n    });\n\n    it('renders choices when provided', () => {\n      renderComponent({\n        choices: [\n          { value: 'a', label: 'Option A' },\n          { value: 'b', label: 'Option B' },\n        ],\n      });\n      expect(screen.getByText('Option A')).toBeInTheDocument();\n      expect(screen.getByText('Option B')).toBeInTheDocument();\n    });\n  });\n\n  describe('events', () => {\n    describe('model', () => {\n      it('dispatches model set event', () => {\n        const el = new MultipleChoice();\n        el.tagName = 'mc-el';\n        el.model = {};\n        expect(el.dispatchEvent).toBeCalledWith(new ModelSetEvent('mc-el', false, true));\n      });\n    });\n\n    describe('onChange', () => {\n      it('dispatches session changed event - add answer (checkbox)', () => {\n        const el = new MultipleChoice();\n        el.tagName = 'mc-el';\n        el.model = { choiceMode: 'checkbox' };\n        el.session = { value: [] };\n        el._onChange({ value: 'a', selected: true });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', true));\n      });\n\n      it('dispatches session changed event - remove answer (checkbox)', () => {\n        const el = new MultipleChoice();\n        el.tagName = 'mc-el';\n        el.model = { choiceMode: 'checkbox' };\n        el.session = { value: ['a'] };\n        el._onChange({ value: 'a', selected: false });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', false));\n      });\n\n      it('dispatches session changed event - add/remove answer (checkbox)', () => {\n        const el = new MultipleChoice();\n        el.tagName = 'mc-el';\n        el.model = { choiceMode: 'checkbox' };\n        el.session = { value: ['1'] };\n        el._onChange({ id: '2', selected: true });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', true));\n\n        el._onChange({ id: '1', selected: false });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', true));\n\n        el._onChange({ id: '2', selected: false });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', false));\n      });\n\n      it('dispatches session changed event - add/change answer (radio)', () => {\n        const el = new MultipleChoice();\n        el.tagName = 'mc-el';\n        el.model = { choiceMode: 'radio' };\n        el.session = { value: [] };\n        el._onChange({ value: 'a', selected: true });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', true));\n        el._onChange({ value: 'b', selected: true });\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('mc-el', true));\n      });\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _multipleChoice = _interopRequireDefault(require("../multiple-choice"));
|
|
5
|
+
describe('MultipleChoice', () => {
|
|
6
|
+
let instance;
|
|
7
|
+
beforeEach(() => {
|
|
8
|
+
instance = new _multipleChoice.default();
|
|
9
|
+
instance._model = {
|
|
10
|
+
choices: [{
|
|
11
|
+
value: '1'
|
|
12
|
+
}, {
|
|
13
|
+
value: '2'
|
|
14
|
+
}, {
|
|
15
|
+
value: '3'
|
|
16
|
+
}],
|
|
17
|
+
choiceMode: 'checkbox'
|
|
18
|
+
};
|
|
19
|
+
instance._session = {
|
|
20
|
+
value: []
|
|
21
|
+
};
|
|
22
|
+
instance._onChange = jest.fn();
|
|
23
|
+
});
|
|
24
|
+
describe('handleKeyDown', () => {
|
|
25
|
+
const simulateKeyDown = key => {
|
|
26
|
+
const event = new KeyboardEvent('keydown', {
|
|
27
|
+
key
|
|
28
|
+
});
|
|
29
|
+
instance.handleKeyDown(event);
|
|
30
|
+
};
|
|
31
|
+
it('selects a choice on valid numeric key (checkbox)', () => {
|
|
32
|
+
simulateKeyDown('1');
|
|
33
|
+
expect(instance._onChange).toHaveBeenCalledWith({
|
|
34
|
+
value: '1',
|
|
35
|
+
selected: true
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
it('toggles a choice on valid numeric key (checkbox)', () => {
|
|
39
|
+
instance._session.value = ['1'];
|
|
40
|
+
simulateKeyDown('1');
|
|
41
|
+
expect(instance._onChange).toHaveBeenCalledWith({
|
|
42
|
+
value: '1',
|
|
43
|
+
selected: false
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
it('selects a choice on valid alphabetic key (checkbox)', () => {
|
|
47
|
+
simulateKeyDown('a');
|
|
48
|
+
expect(instance._onChange).toHaveBeenCalledWith({
|
|
49
|
+
value: '1',
|
|
50
|
+
selected: true
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
it('does nothing on invalid key', () => {
|
|
54
|
+
simulateKeyDown('z');
|
|
55
|
+
expect(instance._onChange).not.toHaveBeenCalled();
|
|
56
|
+
});
|
|
57
|
+
it('selects a choice in radio mode', () => {
|
|
58
|
+
instance._model.choiceMode = 'radio';
|
|
59
|
+
simulateKeyDown('2');
|
|
60
|
+
expect(instance._onChange).toHaveBeenCalledWith({
|
|
61
|
+
value: '2',
|
|
62
|
+
selected: true
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
it('replaces the selected choice in radio mode', () => {
|
|
66
|
+
instance._model.choiceMode = 'radio';
|
|
67
|
+
instance._session.value = ['1'];
|
|
68
|
+
simulateKeyDown('3');
|
|
69
|
+
expect(instance._onChange).toHaveBeenCalledWith({
|
|
70
|
+
value: '3',
|
|
71
|
+
selected: true
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
it('does not toggle the same choice in radio mode', () => {
|
|
75
|
+
instance._model.choiceMode = 'radio';
|
|
76
|
+
instance._session.value = ['1'];
|
|
77
|
+
simulateKeyDown('1');
|
|
78
|
+
expect(instance._onChange).toHaveBeenCalledWith({
|
|
79
|
+
value: '1',
|
|
80
|
+
selected: true
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
it('does nothing if model is missing', () => {
|
|
84
|
+
instance._model = null;
|
|
85
|
+
simulateKeyDown('1');
|
|
86
|
+
expect(instance._onChange).not.toHaveBeenCalled();
|
|
87
|
+
});
|
|
88
|
+
it('does nothing if session is missing', () => {
|
|
89
|
+
instance._session = null;
|
|
90
|
+
simulateKeyDown('1');
|
|
91
|
+
expect(instance._onChange).not.toHaveBeenCalled();
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXVsdGlwbGVDaG9pY2UiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsImRlc2NyaWJlIiwiaW5zdGFuY2UiLCJiZWZvcmVFYWNoIiwiTXVsdGlwbGVDaG9pY2UiLCJfbW9kZWwiLCJjaG9pY2VzIiwidmFsdWUiLCJjaG9pY2VNb2RlIiwiX3Nlc3Npb24iLCJfb25DaGFuZ2UiLCJqZXN0IiwiZm4iLCJzaW11bGF0ZUtleURvd24iLCJrZXkiLCJldmVudCIsIktleWJvYXJkRXZlbnQiLCJoYW5kbGVLZXlEb3duIiwiaXQiLCJleHBlY3QiLCJ0b0hhdmVCZWVuQ2FsbGVkV2l0aCIsInNlbGVjdGVkIiwibm90IiwidG9IYXZlQmVlbkNhbGxlZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18va2V5LWV2ZW50cy10ZXN0LmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTXVsdGlwbGVDaG9pY2UgZnJvbSAnLi4vbXVsdGlwbGUtY2hvaWNlJztcblxuZGVzY3JpYmUoJ011bHRpcGxlQ2hvaWNlJywgKCkgPT4ge1xuICBsZXQgaW5zdGFuY2U7XG5cbiAgYmVmb3JlRWFjaCgoKSA9PiB7XG4gICAgaW5zdGFuY2UgPSBuZXcgTXVsdGlwbGVDaG9pY2UoKTtcbiAgICBpbnN0YW5jZS5fbW9kZWwgPSB7XG4gICAgICBjaG9pY2VzOiBbXG4gICAgICAgIHsgdmFsdWU6ICcxJyB9LFxuICAgICAgICB7IHZhbHVlOiAnMicgfSxcbiAgICAgICAgeyB2YWx1ZTogJzMnIH0sXG4gICAgICBdLFxuICAgICAgY2hvaWNlTW9kZTogJ2NoZWNrYm94JyxcbiAgICB9O1xuICAgIGluc3RhbmNlLl9zZXNzaW9uID0geyB2YWx1ZTogW10gfTtcbiAgICBpbnN0YW5jZS5fb25DaGFuZ2UgPSBqZXN0LmZuKCk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdoYW5kbGVLZXlEb3duJywgKCkgPT4ge1xuICAgIGNvbnN0IHNpbXVsYXRlS2V5RG93biA9IChrZXkpID0+IHtcbiAgICAgIGNvbnN0IGV2ZW50ID0gbmV3IEtleWJvYXJkRXZlbnQoJ2tleWRvd24nLCB7IGtleSB9KTtcbiAgICAgIGluc3RhbmNlLmhhbmRsZUtleURvd24oZXZlbnQpO1xuICAgIH07XG5cbiAgICBpdCgnc2VsZWN0cyBhIGNob2ljZSBvbiB2YWxpZCBudW1lcmljIGtleSAoY2hlY2tib3gpJywgKCkgPT4ge1xuICAgICAgc2ltdWxhdGVLZXlEb3duKCcxJyk7XG4gICAgICBleHBlY3QoaW5zdGFuY2UuX29uQ2hhbmdlKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCh7XG4gICAgICAgIHZhbHVlOiAnMScsXG4gICAgICAgIHNlbGVjdGVkOiB0cnVlLFxuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICBpdCgndG9nZ2xlcyBhIGNob2ljZSBvbiB2YWxpZCBudW1lcmljIGtleSAoY2hlY2tib3gpJywgKCkgPT4ge1xuICAgICAgaW5zdGFuY2UuX3Nlc3Npb24udmFsdWUgPSBbJzEnXTtcbiAgICAgIHNpbXVsYXRlS2V5RG93bignMScpO1xuICAgICAgZXhwZWN0KGluc3RhbmNlLl9vbkNoYW5nZSkudG9IYXZlQmVlbkNhbGxlZFdpdGgoe1xuICAgICAgICB2YWx1ZTogJzEnLFxuICAgICAgICBzZWxlY3RlZDogZmFsc2UsXG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIGl0KCdzZWxlY3RzIGEgY2hvaWNlIG9uIHZhbGlkIGFscGhhYmV0aWMga2V5IChjaGVja2JveCknLCAoKSA9PiB7XG4gICAgICBzaW11bGF0ZUtleURvd24oJ2EnKTtcbiAgICAgIGV4cGVjdChpbnN0YW5jZS5fb25DaGFuZ2UpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKHtcbiAgICAgICAgdmFsdWU6ICcxJyxcbiAgICAgICAgc2VsZWN0ZWQ6IHRydWUsXG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIGl0KCdkb2VzIG5vdGhpbmcgb24gaW52YWxpZCBrZXknLCAoKSA9PiB7XG4gICAgICBzaW11bGF0ZUtleURvd24oJ3onKTtcbiAgICAgIGV4cGVjdChpbnN0YW5jZS5fb25DaGFuZ2UpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2VsZWN0cyBhIGNob2ljZSBpbiByYWRpbyBtb2RlJywgKCkgPT4ge1xuICAgICAgaW5zdGFuY2UuX21vZGVsLmNob2ljZU1vZGUgPSAncmFkaW8nO1xuICAgICAgc2ltdWxhdGVLZXlEb3duKCcyJyk7XG4gICAgICBleHBlY3QoaW5zdGFuY2UuX29uQ2hhbmdlKS50b0hhdmVCZWVuQ2FsbGVkV2l0aCh7XG4gICAgICAgIHZhbHVlOiAnMicsXG4gICAgICAgIHNlbGVjdGVkOiB0cnVlLFxuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICBpdCgncmVwbGFjZXMgdGhlIHNlbGVjdGVkIGNob2ljZSBpbiByYWRpbyBtb2RlJywgKCkgPT4ge1xuICAgICAgaW5zdGFuY2UuX21vZGVsLmNob2ljZU1vZGUgPSAncmFkaW8nO1xuICAgICAgaW5zdGFuY2UuX3Nlc3Npb24udmFsdWUgPSBbJzEnXTtcbiAgICAgIHNpbXVsYXRlS2V5RG93bignMycpO1xuICAgICAgZXhwZWN0KGluc3RhbmNlLl9vbkNoYW5nZSkudG9IYXZlQmVlbkNhbGxlZFdpdGgoe1xuICAgICAgICB2YWx1ZTogJzMnLFxuICAgICAgICBzZWxlY3RlZDogdHJ1ZSxcbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgaXQoJ2RvZXMgbm90IHRvZ2dsZSB0aGUgc2FtZSBjaG9pY2UgaW4gcmFkaW8gbW9kZScsICgpID0+IHtcbiAgICAgIGluc3RhbmNlLl9tb2RlbC5jaG9pY2VNb2RlID0gJ3JhZGlvJztcbiAgICAgIGluc3RhbmNlLl9zZXNzaW9uLnZhbHVlID0gWycxJ107XG4gICAgICBzaW11bGF0ZUtleURvd24oJzEnKTtcbiAgICAgIGV4cGVjdChpbnN0YW5jZS5fb25DaGFuZ2UpLnRvSGF2ZUJlZW5DYWxsZWRXaXRoKHtcbiAgICAgICAgdmFsdWU6ICcxJyxcbiAgICAgICAgc2VsZWN0ZWQ6IHRydWUsXG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIGl0KCdkb2VzIG5vdGhpbmcgaWYgbW9kZWwgaXMgbWlzc2luZycsICgpID0+IHtcbiAgICAgIGluc3RhbmNlLl9tb2RlbCA9IG51bGw7XG4gICAgICBzaW11bGF0ZUtleURvd24oJzEnKTtcbiAgICAgIGV4cGVjdChpbnN0YW5jZS5fb25DaGFuZ2UpLm5vdC50b0hhdmVCZWVuQ2FsbGVkKCk7XG4gICAgfSk7XG5cbiAgICBpdCgnZG9lcyBub3RoaW5nIGlmIHNlc3Npb24gaXMgbWlzc2luZycsICgpID0+IHtcbiAgICAgIGluc3RhbmNlLl9zZXNzaW9uID0gbnVsbDtcbiAgICAgIHNpbXVsYXRlS2V5RG93bignMScpO1xuICAgICAgZXhwZWN0KGluc3RhbmNlLl9vbkNoYW5nZSkubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBQUEsZUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBRUFDLFFBQVEsQ0FBQyxnQkFBZ0IsRUFBRSxNQUFNO0VBQy9CLElBQUlDLFFBQVE7RUFFWkMsVUFBVSxDQUFDLE1BQU07SUFDZkQsUUFBUSxHQUFHLElBQUlFLHVCQUFjLENBQUMsQ0FBQztJQUMvQkYsUUFBUSxDQUFDRyxNQUFNLEdBQUc7TUFDaEJDLE9BQU8sRUFBRSxDQUNQO1FBQUVDLEtBQUssRUFBRTtNQUFJLENBQUMsRUFDZDtRQUFFQSxLQUFLLEVBQUU7TUFBSSxDQUFDLEVBQ2Q7UUFBRUEsS0FBSyxFQUFFO01BQUksQ0FBQyxDQUNmO01BQ0RDLFVBQVUsRUFBRTtJQUNkLENBQUM7SUFDRE4sUUFBUSxDQUFDTyxRQUFRLEdBQUc7TUFBRUYsS0FBSyxFQUFFO0lBQUcsQ0FBQztJQUNqQ0wsUUFBUSxDQUFDUSxTQUFTLEdBQUdDLElBQUksQ0FBQ0MsRUFBRSxDQUFDLENBQUM7RUFDaEMsQ0FBQyxDQUFDO0VBRUZYLFFBQVEsQ0FBQyxlQUFlLEVBQUUsTUFBTTtJQUM5QixN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
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _multipleChoice = require("../multiple-choice");
|
|
7
|
+
var _correctAnswerToggle = _interopRequireDefault(require("@pie-lib/correct-answer-toggle"));
|
|
8
|
+
// Mock the CorrectAnswerToggle component
|
|
9
|
+
jest.mock('@pie-lib/correct-answer-toggle', () => {
|
|
10
|
+
const MockToggle = props => /*#__PURE__*/_react.default.createElement("div", {
|
|
11
|
+
"data-testid": "correct-answer-toggle",
|
|
12
|
+
"data-show": props.show,
|
|
13
|
+
"data-toggled": props.toggled
|
|
14
|
+
}, "Mock Toggle");
|
|
15
|
+
MockToggle.displayName = 'CorrectAnswerToggle';
|
|
16
|
+
return MockToggle;
|
|
17
|
+
});
|
|
18
|
+
describe('Choice', () => {
|
|
19
|
+
let onChoiceChanged;
|
|
20
|
+
beforeEach(() => {
|
|
21
|
+
onChoiceChanged = jest.fn();
|
|
22
|
+
});
|
|
23
|
+
const renderChoice = (extras = {}) => {
|
|
24
|
+
const props = {
|
|
25
|
+
classes: {},
|
|
26
|
+
choice: {},
|
|
27
|
+
index: 0,
|
|
28
|
+
choicesLength: 1,
|
|
29
|
+
showCorrect: false,
|
|
30
|
+
isEvaluateMode: false,
|
|
31
|
+
choiceMode: 'radio',
|
|
32
|
+
disabled: true,
|
|
33
|
+
onChoiceChanged,
|
|
34
|
+
checked: true,
|
|
35
|
+
correctness: 'correct',
|
|
36
|
+
displayKey: '0',
|
|
37
|
+
choicesLayout: 'grid',
|
|
38
|
+
gridColumns: 2,
|
|
39
|
+
...extras
|
|
40
|
+
};
|
|
41
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_multipleChoice.Choice, props));
|
|
42
|
+
};
|
|
43
|
+
describe('logic', () => {
|
|
44
|
+
it('does not call onChoiceChanged if disabled is true', () => {
|
|
45
|
+
const {
|
|
46
|
+
container
|
|
47
|
+
} = renderChoice({
|
|
48
|
+
disabled: true
|
|
49
|
+
});
|
|
50
|
+
const input = container.querySelector('input');
|
|
51
|
+
if (input) {
|
|
52
|
+
input.click();
|
|
53
|
+
}
|
|
54
|
+
// When disabled, onChange should not be called
|
|
55
|
+
expect(onChoiceChanged).not.toHaveBeenCalled();
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
describe('CorespringChoice', () => {
|
|
60
|
+
const mkWrapper = (opts = {}) => {
|
|
61
|
+
const defaultProps = {
|
|
62
|
+
classes: {},
|
|
63
|
+
choices: [],
|
|
64
|
+
disabled: false,
|
|
65
|
+
keyMode: 'letters',
|
|
66
|
+
onChoiceChanged: jest.fn(),
|
|
67
|
+
mode: 'gather',
|
|
68
|
+
...opts
|
|
69
|
+
};
|
|
70
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_multipleChoice.MultipleChoice, defaultProps));
|
|
71
|
+
};
|
|
72
|
+
describe('Toggle', () => {
|
|
73
|
+
it('toggle is rendered', () => {
|
|
74
|
+
mkWrapper();
|
|
75
|
+
expect(_react2.screen.getByTestId('correct-answer-toggle')).toBeInTheDocument();
|
|
76
|
+
});
|
|
77
|
+
it('toggle show is set to false by default', () => {
|
|
78
|
+
mkWrapper();
|
|
79
|
+
const toggle = _react2.screen.getByTestId('correct-answer-toggle');
|
|
80
|
+
expect(toggle).toHaveAttribute('data-show', 'false');
|
|
81
|
+
});
|
|
82
|
+
it('shows toggle if mode is evaluate, feedback is enabled and responseCorrect is false', () => {
|
|
83
|
+
mkWrapper({
|
|
84
|
+
mode: 'evaluate',
|
|
85
|
+
responseCorrect: false,
|
|
86
|
+
feedbackEnabled: true
|
|
87
|
+
});
|
|
88
|
+
const toggle = _react2.screen.getByTestId('correct-answer-toggle');
|
|
89
|
+
expect(toggle).toHaveAttribute('data-show', 'true');
|
|
90
|
+
});
|
|
91
|
+
it('hides toggle if mode is evaluate and responseCorrect is true', () => {
|
|
92
|
+
mkWrapper({
|
|
93
|
+
mode: 'evaluate',
|
|
94
|
+
responseCorrect: true
|
|
95
|
+
});
|
|
96
|
+
const toggle = _react2.screen.getByTestId('correct-answer-toggle');
|
|
97
|
+
expect(toggle).toHaveAttribute('data-show', 'false');
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_multipleChoice","_correctAnswerToggle","jest","mock","MockToggle","props","default","createElement","show","toggled","displayName","describe","onChoiceChanged","beforeEach","fn","renderChoice","extras","classes","choice","index","choicesLength","showCorrect","isEvaluateMode","choiceMode","disabled","checked","correctness","displayKey","choicesLayout","gridColumns","render","Choice","it","container","input","querySelector","click","expect","not","toHaveBeenCalled","mkWrapper","opts","defaultProps","choices","keyMode","mode","MultipleChoice","screen","getByTestId","toBeInTheDocument","toggle","toHaveAttribute","responseCorrect","feedbackEnabled"],"sources":["../../src/__tests__/multiple-choice-test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport { MultipleChoice, Choice } from '../multiple-choice';\nimport CorrectAnswerToggle from '@pie-lib/correct-answer-toggle';\n\n// Mock the CorrectAnswerToggle component\njest.mock('@pie-lib/correct-answer-toggle', () => {\n  const MockToggle = (props) => (\n    <div data-testid=\"correct-answer-toggle\" data-show={props.show} data-toggled={props.toggled}>\n      Mock Toggle\n    </div>\n  );\n  MockToggle.displayName = 'CorrectAnswerToggle';\n  return MockToggle;\n});\n\ndescribe('Choice', () => {\n  let onChoiceChanged;\n\n  beforeEach(() => {\n    onChoiceChanged = jest.fn();\n  });\n\n  const renderChoice = (extras = {}) => {\n    const props = {\n      classes: {},\n      choice: {},\n      index: 0,\n      choicesLength: 1,\n      showCorrect: false,\n      isEvaluateMode: false,\n      choiceMode: 'radio',\n      disabled: true,\n      onChoiceChanged,\n      checked: true,\n      correctness: 'correct',\n      displayKey: '0',\n      choicesLayout: 'grid',\n      gridColumns: 2,\n      ...extras,\n    };\n    return render(<Choice {...props} />);\n  };\n\n  describe('logic', () => {\n    it('does not call onChoiceChanged if disabled is true', () => {\n      const { container } = renderChoice({ disabled: true });\n      const input = container.querySelector('input');\n      if (input) {\n        input.click();\n      }\n      // When disabled, onChange should not be called\n      expect(onChoiceChanged).not.toHaveBeenCalled();\n    });\n  });\n});\n\ndescribe('CorespringChoice', () => {\n  const mkWrapper = (opts = {}) => {\n    const defaultProps = {\n      classes: {},\n      choices: [],\n      disabled: false,\n      keyMode: 'letters',\n      onChoiceChanged: jest.fn(),\n      mode: 'gather',\n      ...opts,\n    };\n\n    return render(<MultipleChoice {...defaultProps} />);\n  };\n\n  describe('Toggle', () => {\n    it('toggle is rendered', () => {\n      mkWrapper();\n      expect(screen.getByTestId('correct-answer-toggle')).toBeInTheDocument();\n    });\n\n    it('toggle show is set to false by default', () => {\n      mkWrapper();\n      const toggle = screen.getByTestId('correct-answer-toggle');\n      expect(toggle).toHaveAttribute('data-show', 'false');\n    });\n\n    it('shows toggle if mode is evaluate, feedback is enabled and responseCorrect is false', () => {\n      mkWrapper({ mode: 'evaluate', responseCorrect: false, feedbackEnabled: true });\n      const toggle = screen.getByTestId('correct-answer-toggle');\n      expect(toggle).toHaveAttribute('data-show', 'true');\n    });\n\n    it('hides toggle if mode is evaluate and responseCorrect is true', () => {\n      mkWrapper({ mode: 'evaluate', responseCorrect: true });\n      const toggle = screen.getByTestId('correct-answer-toggle');\n      expect(toggle).toHaveAttribute('data-show', 'false');\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|