@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.
- package/CHANGELOG.md +0 -11
- package/configure/CHANGELOG.md +0 -11
- package/configure/lib/__tests__/main.test.js +100 -0
- package/configure/lib/__tests__/utils.js +39 -0
- package/configure/lib/defaults.js +3 -6
- package/configure/lib/defaults.js.map +1 -1
- package/configure/lib/design/__tests__/builder.test.js +34 -0
- package/configure/lib/design/__tests__/buttons.test.js +36 -0
- package/configure/lib/design/__tests__/header.test.js +37 -0
- package/configure/lib/design/__tests__/index.test.js +125 -0
- package/configure/lib/design/__tests__/input-header.test.js +41 -0
- package/configure/lib/design/builder.js +16 -34
- package/configure/lib/design/builder.js.map +1 -1
- package/configure/lib/design/buttons.js +42 -96
- package/configure/lib/design/buttons.js.map +1 -1
- package/configure/lib/design/categories/RowLabel.js +34 -47
- package/configure/lib/design/categories/RowLabel.js.map +1 -1
- package/configure/lib/design/categories/__tests__/alternateResponses.test.js +93 -0
- package/configure/lib/design/categories/__tests__/category.test.js +65 -0
- package/configure/lib/design/categories/__tests__/choice-preview.test.js +52 -0
- package/configure/lib/design/categories/__tests__/droppable-placeholder.test.js +63 -0
- package/configure/lib/design/categories/__tests__/index.test.js +91 -0
- package/configure/lib/design/categories/alternateResponses.js +97 -252
- package/configure/lib/design/categories/alternateResponses.js.map +1 -1
- package/configure/lib/design/categories/category.js +136 -209
- package/configure/lib/design/categories/category.js.map +1 -1
- package/configure/lib/design/categories/choice-preview.js +62 -127
- package/configure/lib/design/categories/choice-preview.js.map +1 -1
- package/configure/lib/design/categories/droppable-placeholder.js +74 -166
- package/configure/lib/design/categories/droppable-placeholder.js.map +1 -1
- package/configure/lib/design/categories/index.js +196 -385
- package/configure/lib/design/categories/index.js.map +1 -1
- package/configure/lib/design/choices/__tests__/choice.test.js +62 -0
- package/configure/lib/design/choices/__tests__/config.test.js +66 -0
- package/configure/lib/design/choices/__tests__/index.test.js +70 -0
- package/configure/lib/design/choices/choice.js +156 -265
- package/configure/lib/design/choices/choice.js.map +1 -1
- package/configure/lib/design/choices/config.js +43 -99
- package/configure/lib/design/choices/config.js.map +1 -1
- package/configure/lib/design/choices/index.js +149 -237
- package/configure/lib/design/choices/index.js.map +1 -1
- package/configure/lib/design/header.js +58 -112
- package/configure/lib/design/header.js.map +1 -1
- package/configure/lib/design/index.js +633 -478
- package/configure/lib/design/index.js.map +1 -1
- package/configure/lib/design/input-header.js +95 -151
- package/configure/lib/design/input-header.js.map +1 -1
- package/configure/lib/design/utils.js +5 -16
- package/configure/lib/design/utils.js.map +1 -1
- package/configure/lib/index.js +121 -184
- package/configure/lib/index.js.map +1 -1
- package/configure/lib/main.js +31 -75
- package/configure/lib/main.js.map +1 -1
- package/configure/lib/utils.js +23 -33
- package/configure/lib/utils.js.map +1 -1
- package/configure/package.json +15 -15
- package/controller/CHANGELOG.md +0 -11
- package/controller/lib/__tests__/index.test.js +526 -0
- package/controller/lib/defaults.js +3 -6
- package/controller/lib/defaults.js.map +1 -1
- package/controller/lib/index.js +238 -319
- package/controller/lib/index.js.map +1 -1
- package/controller/lib/utils.js +29 -66
- package/controller/lib/utils.js.map +1 -1
- package/controller/package.json +5 -5
- package/docs/demo/.pie/.configure/package.json +10 -0
- package/docs/demo/.pie/.configure/yarn.lock +2181 -0
- package/docs/demo/.pie/.controllers/package.json +10 -0
- package/docs/demo/.pie/.controllers/yarn.lock +110 -0
- package/docs/demo/.pie/info.entry.js +89 -0
- package/docs/demo/.pie/info.webpack.config.js +119 -0
- package/docs/demo/.pie/package.json +10 -0
- package/docs/demo/.pie/yarn.lock +2190 -0
- package/docs/demo/pie.manifest.json +11 -0
- package/lib/__tests__/index.test.js +197 -0
- package/lib/categorize/__tests__/categories.test.js +138 -0
- package/lib/categorize/__tests__/category.test.js +137 -0
- package/lib/categorize/__tests__/choice.test.js +88 -0
- package/lib/categorize/__tests__/choices.test.js +118 -0
- package/lib/categorize/__tests__/droppable-placeholder.test.js +96 -0
- package/lib/categorize/__tests__/grid-content.test.js +48 -0
- package/lib/categorize/__tests__/index.test.js +152 -0
- package/lib/categorize/categories.js +107 -165
- package/lib/categorize/categories.js.map +1 -1
- package/lib/categorize/category.js +74 -124
- package/lib/categorize/category.js.map +1 -1
- package/lib/categorize/choice.js +119 -246
- package/lib/categorize/choice.js.map +1 -1
- package/lib/categorize/choices.js +67 -132
- package/lib/categorize/choices.js.map +1 -1
- package/lib/categorize/droppable-placeholder.js +47 -104
- package/lib/categorize/droppable-placeholder.js.map +1 -1
- package/lib/categorize/grid-content.js +40 -88
- package/lib/categorize/grid-content.js.map +1 -1
- package/lib/categorize/index.js +342 -318
- package/lib/categorize/index.js.map +1 -1
- package/lib/index.js +286 -307
- package/lib/index.js.map +1 -1
- package/package.json +16 -14
- package/esm/configure.js +0 -34401
- package/esm/configure.js.map +0 -1
- package/esm/controller.js +0 -1468
- package/esm/controller.js.map +0 -1
- package/esm/element.js +0 -13134
- package/esm/element.js.map +0 -1
- package/esm/package.json +0 -3
|
@@ -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":"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","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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
|