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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/configure/lib/__tests__/root.test.js +286 -0
  2. package/configure/lib/defaults.js +3 -5
  3. package/configure/lib/defaults.js.map +1 -1
  4. package/configure/lib/index.js +156 -193
  5. package/configure/lib/index.js.map +1 -1
  6. package/configure/lib/main.js +325 -445
  7. package/configure/lib/main.js.map +1 -1
  8. package/configure/lib/utils.js +9 -9
  9. package/configure/lib/utils.js.map +1 -1
  10. package/configure/package.json +10 -8
  11. package/controller/lib/__tests__/index.test.js +520 -0
  12. package/controller/lib/__tests__/utils.test.js +8 -0
  13. package/controller/lib/defaults.js +3 -4
  14. package/controller/lib/defaults.js.map +1 -1
  15. package/controller/lib/index.js +145 -240
  16. package/controller/lib/index.js.map +1 -1
  17. package/controller/lib/utils.js +5 -17
  18. package/controller/lib/utils.js.map +1 -1
  19. package/controller/package.json +2 -2
  20. package/docs/demo/pie.manifest.json +11 -0
  21. package/lib/__tests__/choice-input-test.js +49 -0
  22. package/lib/__tests__/index-test.js +200 -0
  23. package/lib/__tests__/key-events-test.js +95 -0
  24. package/lib/__tests__/multiple-choice-test.js +101 -0
  25. package/lib/__tests__/session-updater-test.js +70 -0
  26. package/lib/choice-input.js +312 -369
  27. package/lib/choice-input.js.map +1 -1
  28. package/lib/choice.js +164 -220
  29. package/lib/choice.js.map +1 -1
  30. package/lib/feedback-tick.js +75 -115
  31. package/lib/feedback-tick.js.map +1 -1
  32. package/lib/index.js +242 -342
  33. package/lib/index.js.map +1 -1
  34. package/lib/main.js +39 -86
  35. package/lib/main.js.map +1 -1
  36. package/lib/multiple-choice.js +305 -397
  37. package/lib/multiple-choice.js.map +1 -1
  38. package/lib/print.js +40 -78
  39. package/lib/print.js.map +1 -1
  40. package/lib/session-updater.js +5 -16
  41. package/lib/session-updater.js.map +1 -1
  42. package/package.json +13 -16
  43. package/module/configure.js +0 -1
  44. package/module/controller.js +0 -3472
  45. package/module/demo.js +0 -86
  46. package/module/element.js +0 -1
  47. package/module/index.html +0 -21
  48. package/module/manifest.json +0 -14
  49. package/module/print-demo.js +0 -124
  50. package/module/print.html +0 -18
  51. package/module/print.js +0 -1
@@ -1,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
- var isResponseCorrect = function isResponseCorrect(question, session) {
23
- var correctResponse = getCorrectResponse(question.choices);
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=utils.js.map
16
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfaXNFcXVhbCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZ2V0Q29ycmVjdFJlc3BvbnNlIiwiY2hvaWNlcyIsImZpbHRlciIsImMiLCJjb3JyZWN0IiwibWFwIiwidmFsdWUiLCJzb3J0IiwiZXhwb3J0cyIsImlzUmVzcG9uc2VDb3JyZWN0IiwicXVlc3Rpb24iLCJzZXNzaW9uIiwiY29ycmVjdFJlc3BvbnNlIiwiaXNFcXVhbCJdLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaXNFcXVhbCBmcm9tICdsb2Rhc2gvaXNFcXVhbCc7XG5cbmV4cG9ydCBjb25zdCBnZXRDb3JyZWN0UmVzcG9uc2UgPSAoY2hvaWNlcykgPT5cbiAgY2hvaWNlc1xuICAgIC5maWx0ZXIoKGMpID0+IGMuY29ycmVjdClcbiAgICAubWFwKChjKSA9PiBjLnZhbHVlKVxuICAgIC5zb3J0KCk7XG5cbmV4cG9ydCBjb25zdCBpc1Jlc3BvbnNlQ29ycmVjdCA9IChxdWVzdGlvbiwgc2Vzc2lvbikgPT4ge1xuICBsZXQgY29ycmVjdFJlc3BvbnNlID0gZ2V0Q29ycmVjdFJlc3BvbnNlKHF1ZXN0aW9uLmNob2ljZXMpO1xuICByZXR1cm4gc2Vzc2lvbiAmJiBpc0VxdWFsKChzZXNzaW9uLnZhbHVlIHx8IFtdKS5zb3J0KCksIGNvcnJlY3RSZXNwb25zZSk7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsUUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBRU8sTUFBTUMsa0JBQWtCLEdBQUlDLE9BQU8sSUFDeENBLE9BQU8sQ0FDSkMsTUFBTSxDQUFFQyxDQUFDLElBQUtBLENBQUMsQ0FBQ0MsT0FBTyxDQUFDLENBQ3hCQyxHQUFHLENBQUVGLENBQUMsSUFBS0EsQ0FBQyxDQUFDRyxLQUFLLENBQUMsQ0FDbkJDLElBQUksQ0FBQyxDQUFDO0FBQUNDLE9BQUEsQ0FBQVIsa0JBQUEsR0FBQUEsa0JBQUE7QUFFTCxNQUFNUyxpQkFBaUIsR0FBR0EsQ0FBQ0MsUUFBUSxFQUFFQyxPQUFPLEtBQUs7RUFDdEQsSUFBSUMsZUFBZSxHQUFHWixrQkFBa0IsQ0FBQ1UsUUFBUSxDQUFDVCxPQUFPLENBQUM7RUFDMUQsT0FBT1UsT0FBTyxJQUFJLElBQUFFLGdCQUFPLEVBQUMsQ0FBQ0YsT0FBTyxDQUFDTCxLQUFLLElBQUksRUFBRSxFQUFFQyxJQUFJLENBQUMsQ0FBQyxFQUFFSyxlQUFlLENBQUM7QUFDMUUsQ0FBQztBQUFDSixPQUFBLENBQUFDLGlCQUFBLEdBQUFBLGlCQUFBIiwiaWdub3JlTGlzdCI6W119
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/utils.js"],"names":["getCorrectResponse","choices","filter","c","correct","map","value","sort","isResponseCorrect","question","session","correctResponse"],"mappings":";;;;;;;;;AAAA;;AAEO,IAAMA,kBAAkB,GAAG,SAArBA,kBAAqB,CAACC,OAAD;AAAA,SAChCA,OAAO,CACJC,MADH,CACU,UAACC,CAAD;AAAA,WAAOA,CAAC,CAACC,OAAT;AAAA,GADV,EAEGC,GAFH,CAEO,UAACF,CAAD;AAAA,WAAOA,CAAC,CAACG,KAAT;AAAA,GAFP,EAGGC,IAHH,EADgC;AAAA,CAA3B;;;;AAMA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACC,QAAD,EAAWC,OAAX,EAAuB;AACtD,MAAIC,eAAe,GAAGX,kBAAkB,CAACS,QAAQ,CAACR,OAAV,CAAxC;AACA,SAAOS,OAAO,IAAI,yBAAQ,CAACA,OAAO,CAACJ,KAAR,IAAiB,EAAlB,EAAsBC,IAAtB,EAAR,EAAsCI,eAAtC,CAAlB;AACD,CAHM","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"],"file":"utils.js"}
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":[]}
@@ -1,14 +1,14 @@
1
1
  {
2
2
  "name": "@pie-element/multiple-choice-controller",
3
3
  "private": true,
4
- "version": "6.3.3",
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.2",
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,11 @@
1
+ {
2
+ "hash": "1801896442",
3
+ "info": [
4
+ {
5
+ "pie": "@pie-element/multiple-choice",
6
+ "version": {
7
+ "requested": "latest"
8
+ }
9
+ }
10
+ ]
11
+ }
@@ -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":";;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,eAAA,GAAAF,OAAA;AACA,IAAAG,oBAAA,GAAAJ,sBAAA,CAAAC,OAAA;AAEA;AACAI,IAAI,CAACC,IAAI,CAAC,gCAAgC,EAAE,MAAM;EAChD,MAAMC,UAAU,GAAIC,KAAK,iBACvBT,MAAA,CAAAU,OAAA,CAAAC,aAAA;IAAK,eAAY,uBAAuB;IAAC,aAAWF,KAAK,CAACG,IAAK;IAAC,gBAAcH,KAAK,CAACI;EAAQ,GAAC,aAExF,CACN;EACDL,UAAU,CAACM,WAAW,GAAG,qBAAqB;EAC9C,OAAON,UAAU;AACnB,CAAC,CAAC;AAEFO,QAAQ,CAAC,QAAQ,EAAE,MAAM;EACvB,IAAIC,eAAe;EAEnBC,UAAU,CAAC,MAAM;IACfD,eAAe,GAAGV,IAAI,CAACY,EAAE,CAAC,CAAC;EAC7B,CAAC,CAAC;EAEF,MAAMC,YAAY,GAAGA,CAACC,MAAM,GAAG,CAAC,CAAC,KAAK;IACpC,MAAMX,KAAK,GAAG;MACZY,OAAO,EAAE,CAAC,CAAC;MACXC,MAAM,EAAE,CAAC,CAAC;MACVC,KAAK,EAAE,CAAC;MACRC,aAAa,EAAE,CAAC;MAChBC,WAAW,EAAE,KAAK;MAClBC,cAAc,EAAE,KAAK;MACrBC,UAAU,EAAE,OAAO;MACnBC,QAAQ,EAAE,IAAI;MACdZ,eAAe;MACfa,OAAO,EAAE,IAAI;MACbC,WAAW,EAAE,SAAS;MACtBC,UAAU,EAAE,GAAG;MACfC,aAAa,EAAE,MAAM;MACrBC,WAAW,EAAE,CAAC;MACd,GAAGb;IACL,CAAC;IACD,OAAO,IAAAc,cAAM,eAAClC,MAAA,CAAAU,OAAA,CAAAC,aAAA,CAACP,eAAA,CAAA+B,MAAM,EAAK1B,KAAQ,CAAC,CAAC;EACtC,CAAC;EAEDM,QAAQ,CAAC,OAAO,EAAE,MAAM;IACtBqB,EAAE,CAAC,mDAAmD,EAAE,MAAM;MAC5D,MAAM;QAAEC;MAAU,CAAC,GAAGlB,YAAY,CAAC;QAAES,QAAQ,EAAE;MAAK,CAAC,CAAC;MACtD,MAAMU,KAAK,GAAGD,SAAS,CAACE,aAAa,CAAC,OAAO,CAAC;MAC9C,IAAID,KAAK,EAAE;QACTA,KAAK,CAACE,KAAK,CAAC,CAAC;MACf;MACA;MACAC,MAAM,CAACzB,eAAe,CAAC,CAAC0B,GAAG,CAACC,gBAAgB,CAAC,CAAC;IAChD,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AAEF5B,QAAQ,CAAC,kBAAkB,EAAE,MAAM;EACjC,MAAM6B,SAAS,GAAGA,CAACC,IAAI,GAAG,CAAC,CAAC,KAAK;IAC/B,MAAMC,YAAY,GAAG;MACnBzB,OAAO,EAAE,CAAC,CAAC;MACX0B,OAAO,EAAE,EAAE;MACXnB,QAAQ,EAAE,KAAK;MACfoB,OAAO,EAAE,SAAS;MAClBhC,eAAe,EAAEV,IAAI,CAACY,EAAE,CAAC,CAAC;MAC1B+B,IAAI,EAAE,QAAQ;MACd,GAAGJ;IACL,CAAC;IAED,OAAO,IAAAX,cAAM,eAAClC,MAAA,CAAAU,OAAA,CAAAC,aAAA,CAACP,eAAA,CAAA8C,cAAc,EAAKJ,YAAe,CAAC,CAAC;EACrD,CAAC;EAED/B,QAAQ,CAAC,QAAQ,EAAE,MAAM;IACvBqB,EAAE,CAAC,oBAAoB,EAAE,MAAM;MAC7BQ,SAAS,CAAC,CAAC;MACXH,MAAM,CAACU,cAAM,CAACC,WAAW,CAAC,uBAAuB,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IACzE,CAAC,CAAC;IAEFjB,EAAE,CAAC,wCAAwC,EAAE,MAAM;MACjDQ,SAAS,CAAC,CAAC;MACX,MAAMU,MAAM,GAAGH,cAAM,CAACC,WAAW,CAAC,uBAAuB,CAAC;MAC1DX,MAAM,CAACa,MAAM,CAAC,CAACC,eAAe,CAAC,WAAW,EAAE,OAAO,CAAC;IACtD,CAAC,CAAC;IAEFnB,EAAE,CAAC,oFAAoF,EAAE,MAAM;MAC7FQ,SAAS,CAAC;QAAEK,IAAI,EAAE,UAAU;QAAEO,eAAe,EAAE,KAAK;QAAEC,eAAe,EAAE;MAAK,CAAC,CAAC;MAC9E,MAAMH,MAAM,GAAGH,cAAM,CAACC,WAAW,CAAC,uBAAuB,CAAC;MAC1DX,MAAM,CAACa,MAAM,CAAC,CAACC,eAAe,CAAC,WAAW,EAAE,MAAM,CAAC;IACrD,CAAC,CAAC;IAEFnB,EAAE,CAAC,8DAA8D,EAAE,MAAM;MACvEQ,SAAS,CAAC;QAAEK,IAAI,EAAE,UAAU;QAAEO,eAAe,EAAE;MAAK,CAAC,CAAC;MACtD,MAAMF,MAAM,GAAGH,cAAM,CAACC,WAAW,CAAC,uBAAuB,CAAC;MAC1DX,MAAM,CAACa,MAAM,CAAC,CAACC,eAAe,CAAC,WAAW,EAAE,OAAO,CAAC;IACtD,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}