@pie-element/categorize 11.3.4-next.3 → 12.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/CHANGELOG.md +0 -11
  2. package/configure/CHANGELOG.md +0 -11
  3. package/configure/lib/__tests__/main.test.js +100 -0
  4. package/configure/lib/__tests__/utils.js +39 -0
  5. package/configure/lib/defaults.js +3 -6
  6. package/configure/lib/defaults.js.map +1 -1
  7. package/configure/lib/design/__tests__/builder.test.js +34 -0
  8. package/configure/lib/design/__tests__/buttons.test.js +36 -0
  9. package/configure/lib/design/__tests__/header.test.js +37 -0
  10. package/configure/lib/design/__tests__/index.test.js +125 -0
  11. package/configure/lib/design/__tests__/input-header.test.js +41 -0
  12. package/configure/lib/design/builder.js +16 -34
  13. package/configure/lib/design/builder.js.map +1 -1
  14. package/configure/lib/design/buttons.js +42 -96
  15. package/configure/lib/design/buttons.js.map +1 -1
  16. package/configure/lib/design/categories/RowLabel.js +34 -47
  17. package/configure/lib/design/categories/RowLabel.js.map +1 -1
  18. package/configure/lib/design/categories/__tests__/alternateResponses.test.js +93 -0
  19. package/configure/lib/design/categories/__tests__/category.test.js +65 -0
  20. package/configure/lib/design/categories/__tests__/choice-preview.test.js +52 -0
  21. package/configure/lib/design/categories/__tests__/droppable-placeholder.test.js +63 -0
  22. package/configure/lib/design/categories/__tests__/index.test.js +91 -0
  23. package/configure/lib/design/categories/alternateResponses.js +97 -252
  24. package/configure/lib/design/categories/alternateResponses.js.map +1 -1
  25. package/configure/lib/design/categories/category.js +136 -209
  26. package/configure/lib/design/categories/category.js.map +1 -1
  27. package/configure/lib/design/categories/choice-preview.js +62 -127
  28. package/configure/lib/design/categories/choice-preview.js.map +1 -1
  29. package/configure/lib/design/categories/droppable-placeholder.js +74 -166
  30. package/configure/lib/design/categories/droppable-placeholder.js.map +1 -1
  31. package/configure/lib/design/categories/index.js +196 -385
  32. package/configure/lib/design/categories/index.js.map +1 -1
  33. package/configure/lib/design/choices/__tests__/choice.test.js +62 -0
  34. package/configure/lib/design/choices/__tests__/config.test.js +66 -0
  35. package/configure/lib/design/choices/__tests__/index.test.js +70 -0
  36. package/configure/lib/design/choices/choice.js +156 -265
  37. package/configure/lib/design/choices/choice.js.map +1 -1
  38. package/configure/lib/design/choices/config.js +43 -99
  39. package/configure/lib/design/choices/config.js.map +1 -1
  40. package/configure/lib/design/choices/index.js +149 -237
  41. package/configure/lib/design/choices/index.js.map +1 -1
  42. package/configure/lib/design/header.js +58 -112
  43. package/configure/lib/design/header.js.map +1 -1
  44. package/configure/lib/design/index.js +633 -478
  45. package/configure/lib/design/index.js.map +1 -1
  46. package/configure/lib/design/input-header.js +95 -151
  47. package/configure/lib/design/input-header.js.map +1 -1
  48. package/configure/lib/design/utils.js +5 -16
  49. package/configure/lib/design/utils.js.map +1 -1
  50. package/configure/lib/index.js +121 -184
  51. package/configure/lib/index.js.map +1 -1
  52. package/configure/lib/main.js +31 -75
  53. package/configure/lib/main.js.map +1 -1
  54. package/configure/lib/utils.js +23 -33
  55. package/configure/lib/utils.js.map +1 -1
  56. package/configure/package.json +15 -15
  57. package/controller/CHANGELOG.md +0 -11
  58. package/controller/lib/__tests__/index.test.js +526 -0
  59. package/controller/lib/defaults.js +3 -6
  60. package/controller/lib/defaults.js.map +1 -1
  61. package/controller/lib/index.js +238 -319
  62. package/controller/lib/index.js.map +1 -1
  63. package/controller/lib/utils.js +29 -66
  64. package/controller/lib/utils.js.map +1 -1
  65. package/controller/package.json +5 -5
  66. package/docs/demo/.pie/.configure/package.json +10 -0
  67. package/docs/demo/.pie/.configure/yarn.lock +2181 -0
  68. package/docs/demo/.pie/.controllers/package.json +10 -0
  69. package/docs/demo/.pie/.controllers/yarn.lock +110 -0
  70. package/docs/demo/.pie/info.entry.js +89 -0
  71. package/docs/demo/.pie/info.webpack.config.js +119 -0
  72. package/docs/demo/.pie/package.json +10 -0
  73. package/docs/demo/.pie/yarn.lock +2190 -0
  74. package/docs/demo/pie.manifest.json +11 -0
  75. package/lib/__tests__/index.test.js +197 -0
  76. package/lib/categorize/__tests__/categories.test.js +138 -0
  77. package/lib/categorize/__tests__/category.test.js +137 -0
  78. package/lib/categorize/__tests__/choice.test.js +88 -0
  79. package/lib/categorize/__tests__/choices.test.js +118 -0
  80. package/lib/categorize/__tests__/droppable-placeholder.test.js +96 -0
  81. package/lib/categorize/__tests__/grid-content.test.js +48 -0
  82. package/lib/categorize/__tests__/index.test.js +152 -0
  83. package/lib/categorize/categories.js +107 -165
  84. package/lib/categorize/categories.js.map +1 -1
  85. package/lib/categorize/category.js +74 -124
  86. package/lib/categorize/category.js.map +1 -1
  87. package/lib/categorize/choice.js +119 -246
  88. package/lib/categorize/choice.js.map +1 -1
  89. package/lib/categorize/choices.js +67 -132
  90. package/lib/categorize/choices.js.map +1 -1
  91. package/lib/categorize/droppable-placeholder.js +47 -104
  92. package/lib/categorize/droppable-placeholder.js.map +1 -1
  93. package/lib/categorize/grid-content.js +40 -88
  94. package/lib/categorize/grid-content.js.map +1 -1
  95. package/lib/categorize/index.js +342 -318
  96. package/lib/categorize/index.js.map +1 -1
  97. package/lib/index.js +286 -307
  98. package/lib/index.js.map +1 -1
  99. package/package.json +16 -14
  100. package/esm/configure.js +0 -34401
  101. package/esm/configure.js.map +0 -1
  102. package/esm/controller.js +0 -1468
  103. package/esm/controller.js.map +0 -1
  104. package/esm/element.js +0 -13134
  105. package/esm/element.js.map +0 -1
  106. package/esm/package.json +0 -3
@@ -0,0 +1,11 @@
1
+ {
2
+ "hash": "-1338235779",
3
+ "info": [
4
+ {
5
+ "pie": "@pie-element/categorize",
6
+ "version": {
7
+ "requested": "latest"
8
+ }
9
+ }
10
+ ]
11
+ }
@@ -0,0 +1,197 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _index = _interopRequireDefault(require("../index"));
6
+ var _react2 = require("@testing-library/react");
7
+ var _styles = require("@mui/material/styles");
8
+ var _piePlayerEvents = require("@pie-framework/pie-player-events");
9
+ var _index2 = require("../categorize/index");
10
+ jest.mock('@pie-lib/math-rendering', () => ({
11
+ renderMath: jest.fn()
12
+ }));
13
+ const mockRender = jest.fn();
14
+ const mockUnmount = jest.fn();
15
+ jest.mock('react-dom/client', () => ({
16
+ createRoot: jest.fn(() => ({
17
+ render: mockRender,
18
+ unmount: mockUnmount
19
+ }))
20
+ }));
21
+ const theme = (0, _styles.createTheme)();
22
+ describe('categorize', () => {
23
+ describe('renders', () => {
24
+ const renderCategorize = props => {
25
+ const defaultProps = {
26
+ model: {
27
+ categories: [],
28
+ choices: [],
29
+ correctResponse: [],
30
+ ...props
31
+ },
32
+ session: {},
33
+ classes: {},
34
+ onAnswersChange: jest.fn(),
35
+ onShowCorrectToggle: jest.fn()
36
+ };
37
+ return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
38
+ theme: theme
39
+ }, /*#__PURE__*/_react.default.createElement(_index2.Categorize, defaultProps)));
40
+ };
41
+ it('renders without crashing', () => {
42
+ const {
43
+ container
44
+ } = renderCategorize();
45
+ expect(container).toBeInTheDocument();
46
+ });
47
+ it('renders with rationale', () => {
48
+ const {
49
+ container
50
+ } = renderCategorize({
51
+ rationale: 'This is rationale'
52
+ });
53
+ expect(container).toBeInTheDocument();
54
+ });
55
+ it('renders with teacherInstructions', () => {
56
+ const {
57
+ container
58
+ } = renderCategorize({
59
+ teacherInstructions: 'These are teacher instructions'
60
+ });
61
+ expect(container).toBeInTheDocument();
62
+ });
63
+ });
64
+ describe('events', () => {
65
+ let el;
66
+ beforeEach(() => {
67
+ // Register custom element if not already registered
68
+ if (!customElements.get('categorize-el')) {
69
+ customElements.define('categorize-el', _index.default);
70
+ }
71
+
72
+ // Create element via createElement to properly initialize it
73
+ el = document.createElement('categorize-el');
74
+
75
+ // Mock dispatchEvent
76
+ el.dispatchEvent = jest.fn();
77
+ });
78
+ describe('model', () => {
79
+ it('dispatches model set event', () => {
80
+ el.model = {};
81
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.ModelSetEvent('categorize-el', false, true));
82
+ });
83
+ });
84
+ describe('changeAnswers', () => {
85
+ it('dispatches session changed event - add answer', () => {
86
+ el.model = {
87
+ responseAreasToBeFilled: 2,
88
+ hasUnplacedChoices: true
89
+ };
90
+ el.session = {
91
+ answers: []
92
+ };
93
+ el.changeAnswers([{
94
+ category: 'id-fruits',
95
+ choices: ['apple']
96
+ }]);
97
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', false));
98
+ el.changeAnswers([{
99
+ category: 'id-fruits',
100
+ choices: ['apple']
101
+ }, {
102
+ category: 'id-vegetables',
103
+ choices: ['carrot']
104
+ }]);
105
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', true));
106
+ });
107
+ it('dispatches session changed event - remove answer', () => {
108
+ el.model = {
109
+ responseAreasToBeFilled: 1
110
+ };
111
+ el.session = {
112
+ answers: [{
113
+ category: 'id-fruits',
114
+ choices: ['apple']
115
+ }]
116
+ };
117
+ el.changeAnswers([{
118
+ category: 'id-fruits',
119
+ choices: []
120
+ }]);
121
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', false));
122
+ });
123
+ it('dispatches session changed event - add/remove answer', () => {
124
+ el.model = {
125
+ responseAreasToBeFilled: 2,
126
+ hasUnplacedChoices: true
127
+ };
128
+ el.session = {
129
+ answers: [{
130
+ category: 'id-fruits',
131
+ choices: ['apple']
132
+ }, {
133
+ category: 'id-vegetables',
134
+ choices: ['carrot', 'onion']
135
+ }]
136
+ };
137
+ el.changeAnswers([{
138
+ category: 'id-fruits',
139
+ choices: ['apple']
140
+ }, {
141
+ category: 'id-vegetables',
142
+ choices: ['carrot']
143
+ }]);
144
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', true));
145
+ el.changeAnswers([{
146
+ category: 'id-fruits',
147
+ choices: ['apple']
148
+ }, {
149
+ category: 'id-vegetables',
150
+ choices: []
151
+ }]);
152
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', false));
153
+ el.changeAnswers([{
154
+ category: 'id-fruits',
155
+ choices: []
156
+ }, {
157
+ category: 'id-vegetables',
158
+ choices: []
159
+ }]);
160
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', false));
161
+ });
162
+ it('dispatches session changed event - add/remove answer - no unplaced choices', () => {
163
+ el.model = {
164
+ responseAreasToBeFilled: 2,
165
+ hasUnplacedChoices: false,
166
+ possibleResponses: [['apple', 'carrot', 'onion']]
167
+ };
168
+ el.session = {
169
+ answers: [{
170
+ category: 'id-fruits',
171
+ choices: ['apple']
172
+ }, {
173
+ category: 'id-vegetables',
174
+ choices: []
175
+ }]
176
+ };
177
+ el.changeAnswers([{
178
+ category: 'id-fruits',
179
+ choices: ['apple']
180
+ }, {
181
+ category: 'id-vegetables',
182
+ choices: ['carrot']
183
+ }]);
184
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', false));
185
+ el.changeAnswers([{
186
+ category: 'id-fruits',
187
+ choices: ['apple']
188
+ }, {
189
+ category: 'id-vegetables',
190
+ choices: ['carrot', 'onion']
191
+ }]);
192
+ expect(el.dispatchEvent).toBeCalledWith(new _piePlayerEvents.SessionChangedEvent('categorize-el', true));
193
+ });
194
+ });
195
+ });
196
+ });
197
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_index","_react2","_styles","_piePlayerEvents","_index2","jest","mock","renderMath","fn","mockRender","mockUnmount","createRoot","render","unmount","theme","createTheme","describe","renderCategorize","props","defaultProps","model","categories","choices","correctResponse","session","classes","onAnswersChange","onShowCorrectToggle","default","createElement","ThemeProvider","Categorize","it","container","expect","toBeInTheDocument","rationale","teacherInstructions","el","beforeEach","customElements","get","define","document","dispatchEvent","toBeCalledWith","ModelSetEvent","responseAreasToBeFilled","hasUnplacedChoices","answers","changeAnswers","category","SessionChangedEvent","possibleResponses"],"sources":["../../src/__tests__/index.test.js"],"sourcesContent":["import React from 'react';\nimport Categorize from '../index';\nimport { render } from '@testing-library/react';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport { ModelSetEvent, SessionChangedEvent } from '@pie-framework/pie-player-events';\nimport { Categorize as UnStyledCategorize } from '../categorize/index';\n\njest.mock('@pie-lib/math-rendering', () => ({ renderMath: jest.fn() }));\nconst mockRender = jest.fn();\nconst mockUnmount = jest.fn();\njest.mock('react-dom/client', () => ({\n  createRoot: jest.fn(() => ({\n    render: mockRender,\n    unmount: mockUnmount,\n  })),\n}));\n\nconst theme = createTheme();\n\ndescribe('categorize', () => {\n  describe('renders', () => {\n    const renderCategorize = (props) => {\n      const defaultProps = {\n        model: {\n          categories: [],\n          choices: [],\n          correctResponse: [],\n          ...props,\n        },\n        session: {},\n        classes: {},\n        onAnswersChange: jest.fn(),\n        onShowCorrectToggle: jest.fn(),\n      };\n      return render(\n        <ThemeProvider theme={theme}>\n          <UnStyledCategorize {...defaultProps} />\n        </ThemeProvider>\n      );\n    };\n\n    it('renders without crashing', () => {\n      const { container } = renderCategorize();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with rationale', () => {\n      const { container} = renderCategorize({ rationale: 'This is rationale' });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with teacherInstructions', () => {\n      const { container } = renderCategorize({ teacherInstructions: 'These are teacher instructions' });\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('events', () => {\n    let el;\n\n    beforeEach(() => {\n      // Register custom element if not already registered\n      if (!customElements.get('categorize-el')) {\n        customElements.define('categorize-el', Categorize);\n      }\n\n      // Create element via createElement to properly initialize it\n      el = document.createElement('categorize-el');\n\n      // Mock dispatchEvent\n      el.dispatchEvent = jest.fn();\n    });\n\n    describe('model', () => {\n      it('dispatches model set event', () => {\n        el.model = {};\n        expect(el.dispatchEvent).toBeCalledWith(new ModelSetEvent('categorize-el', false, true));\n      });\n    });\n\n    describe('changeAnswers', () => {\n      it('dispatches session changed event - add answer', () => {\n        el.model = {\n          responseAreasToBeFilled: 2,\n          hasUnplacedChoices: true,\n        };\n        el.session = { answers: [] };\n        el.changeAnswers([{ category: 'id-fruits', choices: ['apple'] }]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', false));\n        el.changeAnswers([\n          { category: 'id-fruits', choices: ['apple'] },\n          { category: 'id-vegetables', choices: ['carrot'] },\n        ]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', true));\n      });\n\n      it('dispatches session changed event - remove answer', () => {\n        el.model = {\n          responseAreasToBeFilled: 1,\n        };\n        el.session = { answers: [{ category: 'id-fruits', choices: ['apple'] }] };\n        el.changeAnswers([{ category: 'id-fruits', choices: [] }]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', false));\n      });\n\n      it('dispatches session changed event - add/remove answer', () => {\n        el.model = {\n          responseAreasToBeFilled: 2,\n          hasUnplacedChoices: true,\n        };\n        el.session = {\n          answers: [\n            { category: 'id-fruits', choices: ['apple'] },\n            { category: 'id-vegetables', choices: ['carrot', 'onion'] },\n          ],\n        };\n        el.changeAnswers([\n          { category: 'id-fruits', choices: ['apple'] },\n          { category: 'id-vegetables', choices: ['carrot'] },\n        ]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', true));\n\n        el.changeAnswers([\n          { category: 'id-fruits', choices: ['apple'] },\n          { category: 'id-vegetables', choices: [] },\n        ]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', false));\n\n        el.changeAnswers([\n          { category: 'id-fruits', choices: [] },\n          { category: 'id-vegetables', choices: [] },\n        ]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', false));\n      });\n\n      it('dispatches session changed event - add/remove answer - no unplaced choices', () => {\n        el.model = {\n          responseAreasToBeFilled: 2,\n          hasUnplacedChoices: false,\n          possibleResponses: [['apple', 'carrot', 'onion']],\n        };\n        el.session = {\n          answers: [\n            { category: 'id-fruits', choices: ['apple'] },\n            { category: 'id-vegetables', choices: [] },\n          ],\n        };\n\n        el.changeAnswers([\n          { category: 'id-fruits', choices: ['apple'] },\n          { category: 'id-vegetables', choices: ['carrot'] },\n        ]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', false));\n\n        el.changeAnswers([\n          { category: 'id-fruits', choices: ['apple'] },\n          { category: 'id-vegetables', choices: ['carrot', 'onion'] },\n        ]);\n        expect(el.dispatchEvent).toBeCalledWith(new SessionChangedEvent('categorize-el', true));\n      });\n    });\n  });\n});\n"],"mappings":";;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AACA,IAAAI,gBAAA,GAAAJ,OAAA;AACA,IAAAK,OAAA,GAAAL,OAAA;AAEAM,IAAI,CAACC,IAAI,CAAC,yBAAyB,EAAE,OAAO;EAAEC,UAAU,EAAEF,IAAI,CAACG,EAAE,CAAC;AAAE,CAAC,CAAC,CAAC;AACvE,MAAMC,UAAU,GAAGJ,IAAI,CAACG,EAAE,CAAC,CAAC;AAC5B,MAAME,WAAW,GAAGL,IAAI,CAACG,EAAE,CAAC,CAAC;AAC7BH,IAAI,CAACC,IAAI,CAAC,kBAAkB,EAAE,OAAO;EACnCK,UAAU,EAAEN,IAAI,CAACG,EAAE,CAAC,OAAO;IACzBI,MAAM,EAAEH,UAAU;IAClBI,OAAO,EAAEH;EACX,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,MAAMI,KAAK,GAAG,IAAAC,mBAAW,EAAC,CAAC;AAE3BC,QAAQ,CAAC,YAAY,EAAE,MAAM;EAC3BA,QAAQ,CAAC,SAAS,EAAE,MAAM;IACxB,MAAMC,gBAAgB,GAAIC,KAAK,IAAK;MAClC,MAAMC,YAAY,GAAG;QACnBC,KAAK,EAAE;UACLC,UAAU,EAAE,EAAE;UACdC,OAAO,EAAE,EAAE;UACXC,eAAe,EAAE,EAAE;UACnB,GAAGL;QACL,CAAC;QACDM,OAAO,EAAE,CAAC,CAAC;QACXC,OAAO,EAAE,CAAC,CAAC;QACXC,eAAe,EAAErB,IAAI,CAACG,EAAE,CAAC,CAAC;QAC1BmB,mBAAmB,EAAEtB,IAAI,CAACG,EAAE,CAAC;MAC/B,CAAC;MACD,OAAO,IAAAI,cAAM,eACXf,MAAA,CAAA+B,OAAA,CAAAC,aAAA,CAAC3B,OAAA,CAAA4B,aAAa;QAAChB,KAAK,EAAEA;MAAM,gBAC1BjB,MAAA,CAAA+B,OAAA,CAAAC,aAAA,CAACzB,OAAA,CAAA2B,UAAkB,EAAKZ,YAAe,CAC1B,CACjB,CAAC;IACH,CAAC;IAEDa,EAAE,CAAC,0BAA0B,EAAE,MAAM;MACnC,MAAM;QAAEC;MAAU,CAAC,GAAGhB,gBAAgB,CAAC,CAAC;MACxCiB,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFH,EAAE,CAAC,wBAAwB,EAAE,MAAM;MACjC,MAAM;QAAEC;MAAS,CAAC,GAAGhB,gBAAgB,CAAC;QAAEmB,SAAS,EAAE;MAAoB,CAAC,CAAC;MACzEF,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFH,EAAE,CAAC,kCAAkC,EAAE,MAAM;MAC3C,MAAM;QAAEC;MAAU,CAAC,GAAGhB,gBAAgB,CAAC;QAAEoB,mBAAmB,EAAE;MAAiC,CAAC,CAAC;MACjGH,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnB,QAAQ,CAAC,QAAQ,EAAE,MAAM;IACvB,IAAIsB,EAAE;IAENC,UAAU,CAAC,MAAM;MACf;MACA,IAAI,CAACC,cAAc,CAACC,GAAG,CAAC,eAAe,CAAC,EAAE;QACxCD,cAAc,CAACE,MAAM,CAAC,eAAe,EAAEX,cAAU,CAAC;MACpD;;MAEA;MACAO,EAAE,GAAGK,QAAQ,CAACd,aAAa,CAAC,eAAe,CAAC;;MAE5C;MACAS,EAAE,CAACM,aAAa,GAAGvC,IAAI,CAACG,EAAE,CAAC,CAAC;IAC9B,CAAC,CAAC;IAEFQ,QAAQ,CAAC,OAAO,EAAE,MAAM;MACtBgB,EAAE,CAAC,4BAA4B,EAAE,MAAM;QACrCM,EAAE,CAAClB,KAAK,GAAG,CAAC,CAAC;QACbc,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIC,8BAAa,CAAC,eAAe,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;MAC1F,CAAC,CAAC;IACJ,CAAC,CAAC;IAEF9B,QAAQ,CAAC,eAAe,EAAE,MAAM;MAC9BgB,EAAE,CAAC,+CAA+C,EAAE,MAAM;QACxDM,EAAE,CAAClB,KAAK,GAAG;UACT2B,uBAAuB,EAAE,CAAC;UAC1BC,kBAAkB,EAAE;QACtB,CAAC;QACDV,EAAE,CAACd,OAAO,GAAG;UAAEyB,OAAO,EAAE;QAAG,CAAC;QAC5BX,EAAE,CAACY,aAAa,CAAC,CAAC;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE,CAAC,OAAO;QAAE,CAAC,CAAC,CAAC;QACjEY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;QACxFd,EAAE,CAACY,aAAa,CAAC,CACf;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE,CAAC,OAAO;QAAE,CAAC,EAC7C;UAAE6B,QAAQ,EAAE,eAAe;UAAE7B,OAAO,EAAE,CAAC,QAAQ;QAAE,CAAC,CACnD,CAAC;QACFY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;MACzF,CAAC,CAAC;MAEFpB,EAAE,CAAC,kDAAkD,EAAE,MAAM;QAC3DM,EAAE,CAAClB,KAAK,GAAG;UACT2B,uBAAuB,EAAE;QAC3B,CAAC;QACDT,EAAE,CAACd,OAAO,GAAG;UAAEyB,OAAO,EAAE,CAAC;YAAEE,QAAQ,EAAE,WAAW;YAAE7B,OAAO,EAAE,CAAC,OAAO;UAAE,CAAC;QAAE,CAAC;QACzEgB,EAAE,CAACY,aAAa,CAAC,CAAC;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE;QAAG,CAAC,CAAC,CAAC;QAC1DY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;MAC1F,CAAC,CAAC;MAEFpB,EAAE,CAAC,sDAAsD,EAAE,MAAM;QAC/DM,EAAE,CAAClB,KAAK,GAAG;UACT2B,uBAAuB,EAAE,CAAC;UAC1BC,kBAAkB,EAAE;QACtB,CAAC;QACDV,EAAE,CAACd,OAAO,GAAG;UACXyB,OAAO,EAAE,CACP;YAAEE,QAAQ,EAAE,WAAW;YAAE7B,OAAO,EAAE,CAAC,OAAO;UAAE,CAAC,EAC7C;YAAE6B,QAAQ,EAAE,eAAe;YAAE7B,OAAO,EAAE,CAAC,QAAQ,EAAE,OAAO;UAAE,CAAC;QAE/D,CAAC;QACDgB,EAAE,CAACY,aAAa,CAAC,CACf;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE,CAAC,OAAO;QAAE,CAAC,EAC7C;UAAE6B,QAAQ,EAAE,eAAe;UAAE7B,OAAO,EAAE,CAAC,QAAQ;QAAE,CAAC,CACnD,CAAC;QACFY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAEvFd,EAAE,CAACY,aAAa,CAAC,CACf;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE,CAAC,OAAO;QAAE,CAAC,EAC7C;UAAE6B,QAAQ,EAAE,eAAe;UAAE7B,OAAO,EAAE;QAAG,CAAC,CAC3C,CAAC;QACFY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;QAExFd,EAAE,CAACY,aAAa,CAAC,CACf;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE;QAAG,CAAC,EACtC;UAAE6B,QAAQ,EAAE,eAAe;UAAE7B,OAAO,EAAE;QAAG,CAAC,CAC3C,CAAC;QACFY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;MAC1F,CAAC,CAAC;MAEFpB,EAAE,CAAC,4EAA4E,EAAE,MAAM;QACrFM,EAAE,CAAClB,KAAK,GAAG;UACT2B,uBAAuB,EAAE,CAAC;UAC1BC,kBAAkB,EAAE,KAAK;UACzBK,iBAAiB,EAAE,CAAC,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC;QAClD,CAAC;QACDf,EAAE,CAACd,OAAO,GAAG;UACXyB,OAAO,EAAE,CACP;YAAEE,QAAQ,EAAE,WAAW;YAAE7B,OAAO,EAAE,CAAC,OAAO;UAAE,CAAC,EAC7C;YAAE6B,QAAQ,EAAE,eAAe;YAAE7B,OAAO,EAAE;UAAG,CAAC;QAE9C,CAAC;QAEDgB,EAAE,CAACY,aAAa,CAAC,CACf;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE,CAAC,OAAO;QAAE,CAAC,EAC7C;UAAE6B,QAAQ,EAAE,eAAe;UAAE7B,OAAO,EAAE,CAAC,QAAQ;QAAE,CAAC,CACnD,CAAC;QACFY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;QAExFd,EAAE,CAACY,aAAa,CAAC,CACf;UAAEC,QAAQ,EAAE,WAAW;UAAE7B,OAAO,EAAE,CAAC,OAAO;QAAE,CAAC,EAC7C;UAAE6B,QAAQ,EAAE,eAAe;UAAE7B,OAAO,EAAE,CAAC,QAAQ,EAAE,OAAO;QAAE,CAAC,CAC5D,CAAC;QACFY,MAAM,CAACI,EAAE,CAACM,aAAa,CAAC,CAACC,cAAc,CAAC,IAAIO,oCAAmB,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;MACzF,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1,138 @@
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 _styles = require("@mui/material/styles");
7
+ var _categories = require("../categories");
8
+ jest.mock('../category', () => ({
9
+ __esModule: true,
10
+ default: ({
11
+ id,
12
+ label
13
+ }) => /*#__PURE__*/_react.default.createElement("div", {
14
+ "data-testid": `category-${id}`
15
+ }, label),
16
+ CategoryType: {}
17
+ }));
18
+ jest.mock('../grid-content', () => ({
19
+ __esModule: true,
20
+ default: ({
21
+ children,
22
+ columns
23
+ }) => /*#__PURE__*/_react.default.createElement("div", {
24
+ "data-testid": "grid-content",
25
+ "data-columns": columns
26
+ }, children)
27
+ }));
28
+ const theme = (0, _styles.createTheme)();
29
+ describe('Categories', () => {
30
+ const renderCategories = extras => {
31
+ const defaults = {
32
+ classes: {},
33
+ categories: [{
34
+ choices: [],
35
+ id: '1',
36
+ label: 'Category One'
37
+ }],
38
+ onDropChoice: jest.fn(),
39
+ onRemoveChoice: jest.fn(),
40
+ id: '1',
41
+ label: 'Category Label',
42
+ grid: {
43
+ columns: 1,
44
+ rows: 1
45
+ }
46
+ };
47
+ const props = {
48
+ ...defaults,
49
+ ...extras
50
+ };
51
+ return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
52
+ theme: theme
53
+ }, /*#__PURE__*/_react.default.createElement(_categories.Categories, props)));
54
+ };
55
+ describe('rendering', () => {
56
+ it('renders without crashing', () => {
57
+ const {
58
+ container
59
+ } = renderCategories();
60
+ expect(container).toBeInTheDocument();
61
+ });
62
+ it('renders when disabled', () => {
63
+ const {
64
+ container
65
+ } = renderCategories({
66
+ disabled: true
67
+ });
68
+ expect(container).toBeInTheDocument();
69
+ });
70
+ it('renders the grid content wrapper', () => {
71
+ renderCategories();
72
+ expect(_react2.screen.getByTestId('grid-content')).toBeInTheDocument();
73
+ });
74
+ });
75
+ describe('category labels', () => {
76
+ it('displays category labels', () => {
77
+ renderCategories({
78
+ categories: [{
79
+ id: '1',
80
+ label: 'First Category',
81
+ choices: []
82
+ }, {
83
+ id: '2',
84
+ label: 'Second Category',
85
+ choices: []
86
+ }]
87
+ });
88
+ // Multiple elements may contain the same text (label + category mock)
89
+ expect(_react2.screen.getAllByText('First Category').length).toBeGreaterThan(0);
90
+ expect(_react2.screen.getAllByText('Second Category').length).toBeGreaterThan(0);
91
+ });
92
+ });
93
+ describe('categories per row', () => {
94
+ it('respects categoriesPerRow setting', () => {
95
+ renderCategories({
96
+ categories: [{
97
+ id: '1',
98
+ label: 'Cat 1',
99
+ choices: []
100
+ }, {
101
+ id: '2',
102
+ label: 'Cat 2',
103
+ choices: []
104
+ }],
105
+ model: {
106
+ categoriesPerRow: 2
107
+ }
108
+ });
109
+ const grid = _react2.screen.getByTestId('grid-content');
110
+ expect(grid).toHaveAttribute('data-columns', '2');
111
+ });
112
+ });
113
+ describe('row labels', () => {
114
+ it('renders row labels when provided', () => {
115
+ renderCategories({
116
+ categories: [{
117
+ id: '1',
118
+ label: 'Category',
119
+ choices: []
120
+ }],
121
+ rowLabels: ['Row 1 Label']
122
+ });
123
+ expect(_react2.screen.getByText('Row 1 Label')).toBeInTheDocument();
124
+ });
125
+ it('does not render row labels when empty', () => {
126
+ renderCategories({
127
+ categories: [{
128
+ id: '1',
129
+ label: 'Category',
130
+ choices: []
131
+ }],
132
+ rowLabels: []
133
+ });
134
+ expect(_react2.screen.queryByText('Row 1 Label')).not.toBeInTheDocument();
135
+ });
136
+ });
137
+ });
138
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_styles","_categories","jest","mock","__esModule","default","id","label","createElement","CategoryType","children","columns","theme","createTheme","describe","renderCategories","extras","defaults","classes","categories","choices","onDropChoice","fn","onRemoveChoice","grid","rows","props","render","ThemeProvider","Categories","it","container","expect","toBeInTheDocument","disabled","screen","getByTestId","getAllByText","length","toBeGreaterThan","model","categoriesPerRow","toHaveAttribute","rowLabels","getByText","queryByText","not"],"sources":["../../../src/categorize/__tests__/categories.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport { Categories } from '../categories';\n\njest.mock('../category', () => ({\n  __esModule: true,\n  default: ({ id, label }) => <div data-testid={`category-${id}`}>{label}</div>,\n  CategoryType: {},\n}));\n\njest.mock('../grid-content', () => ({\n  __esModule: true,\n  default: ({ children, columns }) => (\n    <div data-testid=\"grid-content\" data-columns={columns}>\n      {children}\n    </div>\n  ),\n}));\n\nconst theme = createTheme();\n\ndescribe('Categories', () => {\n  const renderCategories = (extras) => {\n    const defaults = {\n      classes: {},\n      categories: [{ choices: [], id: '1', label: 'Category One' }],\n      onDropChoice: jest.fn(),\n      onRemoveChoice: jest.fn(),\n      id: '1',\n      label: 'Category Label',\n      grid: { columns: 1, rows: 1 },\n    };\n\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <Categories {...props} />\n      </ThemeProvider>\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders without crashing', () => {\n      const { container } = renderCategories();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders when disabled', () => {\n      const { container } = renderCategories({ disabled: true });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders the grid content wrapper', () => {\n      renderCategories();\n      expect(screen.getByTestId('grid-content')).toBeInTheDocument();\n    });\n  });\n\n  describe('category labels', () => {\n    it('displays category labels', () => {\n      renderCategories({\n        categories: [\n          { id: '1', label: 'First Category', choices: [] },\n          { id: '2', label: 'Second Category', choices: [] },\n        ],\n      });\n      // Multiple elements may contain the same text (label + category mock)\n      expect(screen.getAllByText('First Category').length).toBeGreaterThan(0);\n      expect(screen.getAllByText('Second Category').length).toBeGreaterThan(0);\n    });\n  });\n\n  describe('categories per row', () => {\n    it('respects categoriesPerRow setting', () => {\n      renderCategories({\n        categories: [\n          { id: '1', label: 'Cat 1', choices: [] },\n          { id: '2', label: 'Cat 2', choices: [] },\n        ],\n        model: { categoriesPerRow: 2 },\n      });\n      const grid = screen.getByTestId('grid-content');\n      expect(grid).toHaveAttribute('data-columns', '2');\n    });\n  });\n\n  describe('row labels', () => {\n    it('renders row labels when provided', () => {\n      renderCategories({\n        categories: [{ id: '1', label: 'Category', choices: [] }],\n        rowLabels: ['Row 1 Label'],\n      });\n      expect(screen.getByText('Row 1 Label')).toBeInTheDocument();\n    });\n\n    it('does not render row labels when empty', () => {\n      renderCategories({\n        categories: [{ id: '1', label: 'Category', choices: [] }],\n        rowLabels: [],\n      });\n      expect(screen.queryByText('Row 1 Label')).not.toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,137 @@
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 _styles = require("@mui/material/styles");
7
+ var _category = require("../category");
8
+ jest.mock('../droppable-placeholder', () => ({
9
+ __esModule: true,
10
+ default: ({
11
+ children,
12
+ id,
13
+ correct
14
+ }) => /*#__PURE__*/_react.default.createElement("div", {
15
+ "data-testid": `placeholder-${id}`,
16
+ "data-correct": correct !== undefined ? String(correct) : undefined
17
+ }, children)
18
+ }));
19
+ jest.mock('../choice', () => ({
20
+ __esModule: true,
21
+ default: ({
22
+ id,
23
+ label,
24
+ categoryId
25
+ }) => /*#__PURE__*/_react.default.createElement("div", {
26
+ "data-testid": `choice-${id}`,
27
+ "data-category": categoryId
28
+ }, label)
29
+ }));
30
+ const theme = (0, _styles.createTheme)();
31
+ describe('Category', () => {
32
+ const renderCategory = extras => {
33
+ const defaults = {
34
+ classes: {
35
+ label: 'label',
36
+ incorrect: 'incorrect',
37
+ placeholder: 'placeholder',
38
+ category: 'category'
39
+ },
40
+ choices: [],
41
+ id: 'category-1',
42
+ label: 'Category Label',
43
+ grid: {
44
+ columns: 1,
45
+ rows: 1
46
+ }
47
+ };
48
+ const props = {
49
+ ...defaults,
50
+ ...extras
51
+ };
52
+ return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
53
+ theme: theme
54
+ }, /*#__PURE__*/_react.default.createElement(_category.Category, props)));
55
+ };
56
+ describe('rendering', () => {
57
+ it('renders without crashing', () => {
58
+ const {
59
+ container
60
+ } = renderCategory();
61
+ expect(container).toBeInTheDocument();
62
+ });
63
+ it('renders the placeholder with correct id', () => {
64
+ renderCategory({
65
+ id: 'test-category'
66
+ });
67
+ expect(_react2.screen.getByTestId('placeholder-test-category')).toBeInTheDocument();
68
+ });
69
+ it('renders when disabled', () => {
70
+ const {
71
+ container
72
+ } = renderCategory({
73
+ disabled: true
74
+ });
75
+ expect(container).toBeInTheDocument();
76
+ });
77
+ });
78
+ describe('choices rendering', () => {
79
+ it('renders choices within the category', () => {
80
+ renderCategory({
81
+ id: 'cat-1',
82
+ choices: [{
83
+ id: 'choice-1',
84
+ label: 'First Choice'
85
+ }, {
86
+ id: 'choice-2',
87
+ label: 'Second Choice'
88
+ }]
89
+ });
90
+ expect(_react2.screen.getByTestId('choice-choice-1')).toBeInTheDocument();
91
+ expect(_react2.screen.getByTestId('choice-choice-2')).toBeInTheDocument();
92
+ expect(_react2.screen.getByText('First Choice')).toBeInTheDocument();
93
+ expect(_react2.screen.getByText('Second Choice')).toBeInTheDocument();
94
+ });
95
+ it('renders empty category when no choices', () => {
96
+ renderCategory({
97
+ choices: []
98
+ });
99
+ expect(_react2.screen.queryByTestId(/^choice-/)).not.toBeInTheDocument();
100
+ });
101
+ });
102
+ describe('correctness state', () => {
103
+ // Note: StyledPlaceHolder uses shouldForwardProp to prevent 'correct' from being
104
+ // forwarded to the underlying component - it's only used for styling.
105
+ // We test that rendering doesn't crash with different correctness values.
106
+ it('renders correctly when correct=false (incorrect answer)', () => {
107
+ const {
108
+ container
109
+ } = renderCategory({
110
+ id: 'cat-1',
111
+ correct: false
112
+ });
113
+ expect(container).toBeInTheDocument();
114
+ expect(_react2.screen.getByTestId('placeholder-cat-1')).toBeInTheDocument();
115
+ });
116
+ it('renders correctly when correct=true (correct answer)', () => {
117
+ const {
118
+ container
119
+ } = renderCategory({
120
+ id: 'cat-1',
121
+ correct: true
122
+ });
123
+ expect(container).toBeInTheDocument();
124
+ expect(_react2.screen.getByTestId('placeholder-cat-1')).toBeInTheDocument();
125
+ });
126
+ it('renders correctly when correct is undefined', () => {
127
+ const {
128
+ container
129
+ } = renderCategory({
130
+ id: 'cat-1'
131
+ });
132
+ expect(container).toBeInTheDocument();
133
+ expect(_react2.screen.getByTestId('placeholder-cat-1')).toBeInTheDocument();
134
+ });
135
+ });
136
+ });
137
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_styles","_category","jest","mock","__esModule","default","children","id","correct","createElement","undefined","String","label","categoryId","theme","createTheme","describe","renderCategory","extras","defaults","classes","incorrect","placeholder","category","choices","grid","columns","rows","props","render","ThemeProvider","Category","it","container","expect","toBeInTheDocument","screen","getByTestId","disabled","getByText","queryByTestId","not"],"sources":["../../../src/categorize/__tests__/category.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport { Category } from '../category';\n\njest.mock('../droppable-placeholder', () => ({\n  __esModule: true,\n  default: ({ children, id, correct }) => (\n    <div \n      data-testid={`placeholder-${id}`} \n      data-correct={correct !== undefined ? String(correct) : undefined}\n    >\n      {children}\n    </div>\n  ),\n}));\njest.mock('../choice', () => ({\n  __esModule: true,\n  default: ({ id, label, categoryId }) => (\n    <div data-testid={`choice-${id}`} data-category={categoryId}>\n      {label}\n    </div>\n  ),\n}));\n\nconst theme = createTheme();\n\ndescribe('Category', () => {\n  const renderCategory = (extras) => {\n    const defaults = {\n      classes: {\n        label: 'label',\n        incorrect: 'incorrect',\n        placeholder: 'placeholder',\n        category: 'category',\n      },\n      choices: [],\n      id: 'category-1',\n      label: 'Category Label',\n      grid: { columns: 1, rows: 1 },\n    };\n\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <Category {...props} />\n      </ThemeProvider>\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders without crashing', () => {\n      const { container } = renderCategory();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders the placeholder with correct id', () => {\n      renderCategory({ id: 'test-category' });\n      expect(screen.getByTestId('placeholder-test-category')).toBeInTheDocument();\n    });\n\n    it('renders when disabled', () => {\n      const { container } = renderCategory({ disabled: true });\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('choices rendering', () => {\n    it('renders choices within the category', () => {\n      renderCategory({\n        id: 'cat-1',\n        choices: [\n          { id: 'choice-1', label: 'First Choice' },\n          { id: 'choice-2', label: 'Second Choice' },\n        ],\n      });\n      expect(screen.getByTestId('choice-choice-1')).toBeInTheDocument();\n      expect(screen.getByTestId('choice-choice-2')).toBeInTheDocument();\n      expect(screen.getByText('First Choice')).toBeInTheDocument();\n      expect(screen.getByText('Second Choice')).toBeInTheDocument();\n    });\n\n    it('renders empty category when no choices', () => {\n      renderCategory({ choices: [] });\n      expect(screen.queryByTestId(/^choice-/)).not.toBeInTheDocument();\n    });\n  });\n\n  describe('correctness state', () => {\n    // Note: StyledPlaceHolder uses shouldForwardProp to prevent 'correct' from being\n    // forwarded to the underlying component - it's only used for styling.\n    // We test that rendering doesn't crash with different correctness values.\n    it('renders correctly when correct=false (incorrect answer)', () => {\n      const { container } = renderCategory({ id: 'cat-1', correct: false });\n      expect(container).toBeInTheDocument();\n      expect(screen.getByTestId('placeholder-cat-1')).toBeInTheDocument();\n    });\n\n    it('renders correctly when correct=true (correct answer)', () => {\n      const { container } = renderCategory({ id: 'cat-1', correct: true });\n      expect(container).toBeInTheDocument();\n      expect(screen.getByTestId('placeholder-cat-1')).toBeInTheDocument();\n    });\n\n    it('renders correctly when correct is undefined', () => {\n      const { container } = renderCategory({ id: 'cat-1' });\n      expect(container).toBeInTheDocument();\n      expect(screen.getByTestId('placeholder-cat-1')).toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,88 @@
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 _styles = require("@mui/material/styles");
7
+ var _choice = require("../choice");
8
+ jest.mock('@pie-lib/render-ui', () => ({
9
+ HtmlAndMath: props => /*#__PURE__*/_react.default.createElement("div", null, props.text),
10
+ color: {
11
+ text: () => '#000',
12
+ background: () => '#fff',
13
+ white: () => '#fff',
14
+ correct: () => '#00ff00',
15
+ incorrect: () => '#ff0000'
16
+ }
17
+ }));
18
+ const theme = (0, _styles.createTheme)();
19
+ describe('Layout', () => {
20
+ const renderLayout = extras => {
21
+ const defaults = {
22
+ classes: {},
23
+ content: 'Choice Content'
24
+ };
25
+ const props = {
26
+ ...defaults,
27
+ ...extras
28
+ };
29
+ return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
30
+ theme: theme
31
+ }, /*#__PURE__*/_react.default.createElement(_choice.Layout, props)));
32
+ };
33
+ describe('rendering', () => {
34
+ it('renders without crashing', () => {
35
+ const {
36
+ container
37
+ } = renderLayout();
38
+ expect(container).toBeInTheDocument();
39
+ });
40
+ it('renders the choice content', () => {
41
+ renderLayout({
42
+ content: 'Test Choice Text'
43
+ });
44
+ expect(_react2.screen.getByText('Test Choice Text')).toBeInTheDocument();
45
+ });
46
+ it('renders HTML content', () => {
47
+ renderLayout({
48
+ content: '<strong>Bold Text</strong>'
49
+ });
50
+ expect(_react2.screen.getByText('Bold Text')).toBeInTheDocument();
51
+ });
52
+ });
53
+ describe('states', () => {
54
+ it('renders when disabled', () => {
55
+ const {
56
+ container
57
+ } = renderLayout({
58
+ disabled: true
59
+ });
60
+ expect(container).toBeInTheDocument();
61
+ });
62
+ it('renders when correct', () => {
63
+ const {
64
+ container
65
+ } = renderLayout({
66
+ correct: true
67
+ });
68
+ expect(container).toBeInTheDocument();
69
+ });
70
+ it('renders when incorrect', () => {
71
+ const {
72
+ container
73
+ } = renderLayout({
74
+ correct: false
75
+ });
76
+ expect(container).toBeInTheDocument();
77
+ });
78
+ it('renders when dragging', () => {
79
+ const {
80
+ container
81
+ } = renderLayout({
82
+ isDragging: true
83
+ });
84
+ expect(container).toBeInTheDocument();
85
+ });
86
+ });
87
+ });
88
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdDIiLCJfc3R5bGVzIiwiX2Nob2ljZSIsImplc3QiLCJtb2NrIiwiSHRtbEFuZE1hdGgiLCJwcm9wcyIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50IiwidGV4dCIsImNvbG9yIiwiYmFja2dyb3VuZCIsIndoaXRlIiwiY29ycmVjdCIsImluY29ycmVjdCIsInRoZW1lIiwiY3JlYXRlVGhlbWUiLCJkZXNjcmliZSIsInJlbmRlckxheW91dCIsImV4dHJhcyIsImRlZmF1bHRzIiwiY2xhc3NlcyIsImNvbnRlbnQiLCJyZW5kZXIiLCJUaGVtZVByb3ZpZGVyIiwiTGF5b3V0IiwiaXQiLCJjb250YWluZXIiLCJleHBlY3QiLCJ0b0JlSW5UaGVEb2N1bWVudCIsInNjcmVlbiIsImdldEJ5VGV4dCIsImRpc2FibGVkIiwiaXNEcmFnZ2luZyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYXRlZ29yaXplL19fdGVzdHNfXy9jaG9pY2UudGVzdC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHJlbmRlciwgc2NyZWVuIH0gZnJvbSAnQHRlc3RpbmctbGlicmFyeS9yZWFjdCc7XG5pbXBvcnQgeyBUaGVtZVByb3ZpZGVyLCBjcmVhdGVUaGVtZSB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwvc3R5bGVzJztcbmltcG9ydCB7IExheW91dCB9IGZyb20gJy4uL2Nob2ljZSc7XG5cbmplc3QubW9jaygnQHBpZS1saWIvcmVuZGVyLXVpJywgKCkgPT4gKHtcbiAgSHRtbEFuZE1hdGg6IChwcm9wcykgPT4gPGRpdj57cHJvcHMudGV4dH08L2Rpdj4sXG4gIGNvbG9yOiB7XG4gICAgdGV4dDogKCkgPT4gJyMwMDAnLFxuICAgIGJhY2tncm91bmQ6ICgpID0+ICcjZmZmJyxcbiAgICB3aGl0ZTogKCkgPT4gJyNmZmYnLFxuICAgIGNvcnJlY3Q6ICgpID0+ICcjMDBmZjAwJyxcbiAgICBpbmNvcnJlY3Q6ICgpID0+ICcjZmYwMDAwJyxcbiAgfSxcbn0pKTtcblxuY29uc3QgdGhlbWUgPSBjcmVhdGVUaGVtZSgpO1xuXG5kZXNjcmliZSgnTGF5b3V0JywgKCkgPT4ge1xuICBjb25zdCByZW5kZXJMYXlvdXQgPSAoZXh0cmFzKSA9PiB7XG4gICAgY29uc3QgZGVmYXVsdHMgPSB7XG4gICAgICBjbGFzc2VzOiB7fSxcbiAgICAgIGNvbnRlbnQ6ICdDaG9pY2UgQ29udGVudCcsXG4gICAgfTtcbiAgICBjb25zdCBwcm9wcyA9IHsgLi4uZGVmYXVsdHMsIC4uLmV4dHJhcyB9O1xuICAgIHJldHVybiByZW5kZXIoXG4gICAgICA8VGhlbWVQcm92aWRlciB0aGVtZT17dGhlbWV9PlxuICAgICAgICA8TGF5b3V0IHsuLi5wcm9wc30gLz5cbiAgICAgIDwvVGhlbWVQcm92aWRlcj5cbiAgICApO1xuICB9O1xuXG4gIGRlc2NyaWJlKCdyZW5kZXJpbmcnLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMgd2l0aG91dCBjcmFzaGluZycsICgpID0+IHtcbiAgICAgIGNvbnN0IHsgY29udGFpbmVyIH0gPSByZW5kZXJMYXlvdXQoKTtcbiAgICAgIGV4cGVjdChjb250YWluZXIpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG5cbiAgICBpdCgncmVuZGVycyB0aGUgY2hvaWNlIGNvbnRlbnQnLCAoKSA9PiB7XG4gICAgICByZW5kZXJMYXlvdXQoeyBjb250ZW50OiAnVGVzdCBDaG9pY2UgVGV4dCcgfSk7XG4gICAgICBleHBlY3Qoc2NyZWVuLmdldEJ5VGV4dCgnVGVzdCBDaG9pY2UgVGV4dCcpKS50b0JlSW5UaGVEb2N1bWVudCgpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3JlbmRlcnMgSFRNTCBjb250ZW50JywgKCkgPT4ge1xuICAgICAgcmVuZGVyTGF5b3V0KHsgY29udGVudDogJzxzdHJvbmc+Qm9sZCBUZXh0PC9zdHJvbmc+JyB9KTtcbiAgICAgIGV4cGVjdChzY3JlZW4uZ2V0QnlUZXh0KCdCb2xkIFRleHQnKSkudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3N0YXRlcycsICgpID0+IHtcbiAgICBpdCgncmVuZGVycyB3aGVuIGRpc2FibGVkJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlckxheW91dCh7IGRpc2FibGVkOiB0cnVlIH0pO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lcikudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIHdoZW4gY29ycmVjdCcsICgpID0+IHtcbiAgICAgIGNvbnN0IHsgY29udGFpbmVyIH0gPSByZW5kZXJMYXlvdXQoeyBjb3JyZWN0OiB0cnVlIH0pO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lcikudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIHdoZW4gaW5jb3JyZWN0JywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlckxheW91dCh7IGNvcnJlY3Q6IGZhbHNlIH0pO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lcikudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIHdoZW4gZHJhZ2dpbmcnLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyTGF5b3V0KHsgaXNEcmFnZ2luZzogdHJ1ZSB9KTtcbiAgICAgIGV4cGVjdChjb250YWluZXIpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG5cbiJdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsT0FBQSxHQUFBRixPQUFBO0FBQ0EsSUFBQUcsT0FBQSxHQUFB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