@pie-lib/charting 6.2.0-next.2 → 6.2.0-next.5
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 +26 -36
- package/LICENSE.md +5 -0
- package/lib/actions-button.js +1 -1
- package/lib/axes.js +1 -1
- package/lib/bars/bar.js +1 -1
- package/lib/bars/common/bars.js +1 -1
- package/lib/bars/common/correct-check-icon.js +1 -1
- package/lib/bars/histogram.js +1 -1
- package/lib/chart-setup.js +1 -1
- package/lib/chart-type.js +1 -1
- package/lib/chart-types.js +1 -1
- package/lib/chart.js +1 -1
- package/lib/common/correctness-indicators.js +1 -1
- package/lib/common/drag-handle.js +1 -1
- package/lib/common/drag-icon.js +1 -1
- package/lib/common/styles.js +1 -1
- package/lib/grid.js +1 -1
- package/lib/index.js +1 -1
- package/lib/key-legend.js +1 -1
- package/lib/line/common/drag-handle.js +1 -1
- package/lib/line/common/line.js +1 -1
- package/lib/line/line-cross.js +1 -1
- package/lib/line/line-dot.js +1 -1
- package/lib/mark-label.js +1 -1
- package/lib/plot/common/plot.js +1 -1
- package/lib/plot/dot.js +1 -1
- package/lib/plot/line.js +1 -1
- package/lib/tool-menu.js +1 -1
- package/lib/utils.js +1 -1
- package/package.json +3 -3
- package/lib/__tests__/actions-button.test.js +0 -332
- package/lib/__tests__/axes.test.js +0 -746
- package/lib/__tests__/chart-setup.test.js +0 -796
- package/lib/__tests__/chart-type.test.js +0 -25
- package/lib/__tests__/chart.test.js +0 -103
- package/lib/__tests__/grid.test.js +0 -39
- package/lib/__tests__/key-legend.test.js +0 -235
- package/lib/__tests__/mark-label.test.js +0 -46
- package/lib/__tests__/tool-menu.test.js +0 -627
- package/lib/__tests__/utils.js +0 -56
- package/lib/__tests__/utils.test.js +0 -186
- package/lib/bars/__tests__/bar.test.js +0 -53
- package/lib/bars/__tests__/histogram.test.js +0 -53
- package/lib/bars/__tests__/utils.js +0 -50
- package/lib/bars/common/__tests__/bars.test.js +0 -76
- package/lib/bars/common/__tests__/utils.js +0 -50
- package/lib/common/__tests__/correctness-indicators.test.js +0 -887
- package/lib/common/__tests__/drag-handle.test.js +0 -73
- package/lib/common/__tests__/utils.js +0 -50
- package/lib/line/__tests__/line-cross.test.js +0 -617
- package/lib/line/__tests__/line-dot.test.js +0 -47
- package/lib/line/__tests__/utils.js +0 -56
- package/lib/line/common/__tests__/drag-handle.test.js +0 -73
- package/lib/line/common/__tests__/line.test.js +0 -92
- package/lib/line/common/__tests__/utils.js +0 -50
- package/lib/plot/__tests__/dot.test.js +0 -513
- package/lib/plot/__tests__/line.test.js +0 -566
- package/lib/plot/__tests__/utils.js +0 -50
- package/lib/plot/common/__tests__/plot.test.js +0 -79
- package/lib/plot/common/__tests__/utils.js +0 -50
|
@@ -1,617 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
6
|
-
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
7
|
-
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _testUtils = require("@pie-lib/test-utils");
|
|
10
|
-
var _styles = require("@mui/material/styles");
|
|
11
|
-
var _lineCross = _interopRequireWildcard(require("../line-cross"));
|
|
12
|
-
var _utils = require("./utils");
|
|
13
|
-
var _excluded = ["data", "x", "y", "strokeWidth", "style"],
|
|
14
|
-
_excluded2 = ["children"],
|
|
15
|
-
_excluded3 = ["CustomDraggableComponent", "data", "graphProps"];
|
|
16
|
-
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
17
|
-
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
18
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
19
|
-
// Mock dependencies
|
|
20
|
-
jest.mock('@visx/shape', function () {
|
|
21
|
-
return {
|
|
22
|
-
LinePath: function LinePath(_ref) {
|
|
23
|
-
var data = _ref.data,
|
|
24
|
-
x = _ref.x,
|
|
25
|
-
y = _ref.y,
|
|
26
|
-
strokeWidth = _ref.strokeWidth,
|
|
27
|
-
style = _ref.style,
|
|
28
|
-
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
|
|
29
|
-
return /*#__PURE__*/_react["default"].createElement("path", (0, _extends2["default"])({
|
|
30
|
-
"data-testid": "line-path",
|
|
31
|
-
d: data.map(function (d, i) {
|
|
32
|
-
return "".concat(i === 0 ? 'M' : 'L').concat(x(d), ",").concat(y(d));
|
|
33
|
-
}).join(' '),
|
|
34
|
-
strokeWidth: strokeWidth
|
|
35
|
-
}, props));
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
});
|
|
39
|
-
jest.mock('@visx/group', function () {
|
|
40
|
-
return {
|
|
41
|
-
Group: function Group(_ref2) {
|
|
42
|
-
var children = _ref2.children,
|
|
43
|
-
props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded2);
|
|
44
|
-
return /*#__PURE__*/_react["default"].createElement("g", (0, _extends2["default"])({
|
|
45
|
-
"data-testid": "visx-group"
|
|
46
|
-
}, props), children);
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
});
|
|
50
|
-
jest.mock('@pie-lib/render-ui', function () {
|
|
51
|
-
return {
|
|
52
|
-
color: {
|
|
53
|
-
text: function text() {
|
|
54
|
-
return '#000000';
|
|
55
|
-
},
|
|
56
|
-
defaults: {
|
|
57
|
-
TEXT: '#000000',
|
|
58
|
-
BLACK: '#000000',
|
|
59
|
-
BORDER_GRAY: '#cccccc'
|
|
60
|
-
},
|
|
61
|
-
disabled: function disabled() {
|
|
62
|
-
return '#cccccc';
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
};
|
|
66
|
-
});
|
|
67
|
-
jest.mock('../../utils', function () {
|
|
68
|
-
return {
|
|
69
|
-
dataToXBand: jest.fn(function (scale, data, width, type) {
|
|
70
|
-
return {
|
|
71
|
-
bandwidth: function bandwidth() {
|
|
72
|
-
return 20;
|
|
73
|
-
}
|
|
74
|
-
};
|
|
75
|
-
})
|
|
76
|
-
};
|
|
77
|
-
});
|
|
78
|
-
jest.mock('../common/line', function () {
|
|
79
|
-
return function RawLine(_ref3) {
|
|
80
|
-
var CustomDraggableComponent = _ref3.CustomDraggableComponent,
|
|
81
|
-
data = _ref3.data,
|
|
82
|
-
graphProps = _ref3.graphProps,
|
|
83
|
-
props = (0, _objectWithoutProperties2["default"])(_ref3, _excluded3);
|
|
84
|
-
return /*#__PURE__*/_react["default"].createElement("svg", {
|
|
85
|
-
"data-testid": "raw-line"
|
|
86
|
-
}, data && data.length > 0 ? data.map(function (d, i) {
|
|
87
|
-
return /*#__PURE__*/_react["default"].createElement(CustomDraggableComponent, (0, _extends2["default"])({
|
|
88
|
-
key: i,
|
|
89
|
-
scale: graphProps.scale,
|
|
90
|
-
x: d.x || i,
|
|
91
|
-
y: d.y || i,
|
|
92
|
-
r: 8,
|
|
93
|
-
correctness: d.correctness,
|
|
94
|
-
interactive: d.interactive,
|
|
95
|
-
correctData: props.correctData,
|
|
96
|
-
label: d.label
|
|
97
|
-
}, props));
|
|
98
|
-
}) : /*#__PURE__*/_react["default"].createElement("text", null, "No data"));
|
|
99
|
-
};
|
|
100
|
-
});
|
|
101
|
-
jest.mock('../../common/correctness-indicators', function () {
|
|
102
|
-
return {
|
|
103
|
-
CorrectnessIndicator: function CorrectnessIndicator(_ref4) {
|
|
104
|
-
var scale = _ref4.scale,
|
|
105
|
-
x = _ref4.x,
|
|
106
|
-
y = _ref4.y,
|
|
107
|
-
correctness = _ref4.correctness,
|
|
108
|
-
interactive = _ref4.interactive;
|
|
109
|
-
return correctness && interactive ? /*#__PURE__*/_react["default"].createElement("g", {
|
|
110
|
-
"data-testid": "correctness-indicator"
|
|
111
|
-
}, /*#__PURE__*/_react["default"].createElement("circle", {
|
|
112
|
-
cx: scale.x(x),
|
|
113
|
-
cy: scale.y(y),
|
|
114
|
-
r: 5
|
|
115
|
-
})) : null;
|
|
116
|
-
},
|
|
117
|
-
SmallCorrectPointIndicator: function SmallCorrectPointIndicator(_ref5) {
|
|
118
|
-
var scale = _ref5.scale,
|
|
119
|
-
x = _ref5.x,
|
|
120
|
-
correctness = _ref5.correctness,
|
|
121
|
-
correctData = _ref5.correctData,
|
|
122
|
-
label = _ref5.label;
|
|
123
|
-
return correctness && correctness.value === 'incorrect' && correctData ? /*#__PURE__*/_react["default"].createElement("g", {
|
|
124
|
-
"data-testid": "small-correct-indicator"
|
|
125
|
-
}, /*#__PURE__*/_react["default"].createElement("circle", {
|
|
126
|
-
cx: scale.x(x),
|
|
127
|
-
cy: scale.y(0),
|
|
128
|
-
r: 3
|
|
129
|
-
})) : null;
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
});
|
|
133
|
-
var theme;
|
|
134
|
-
beforeAll(function () {
|
|
135
|
-
theme = (0, _styles.createTheme)();
|
|
136
|
-
});
|
|
137
|
-
describe('LineChart', function () {
|
|
138
|
-
var renderComponent = function renderComponent(extras) {
|
|
139
|
-
var defaults = {
|
|
140
|
-
classes: {},
|
|
141
|
-
className: 'className',
|
|
142
|
-
graphProps: (0, _utils.graphProps)(),
|
|
143
|
-
data: [],
|
|
144
|
-
xBand: function xBand() {
|
|
145
|
-
return {
|
|
146
|
-
bandwidth: function bandwidth() {}
|
|
147
|
-
};
|
|
148
|
-
}
|
|
149
|
-
};
|
|
150
|
-
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
151
|
-
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
152
|
-
theme: theme
|
|
153
|
-
}, /*#__PURE__*/_react["default"].createElement(_lineCross.LineCross, props)));
|
|
154
|
-
};
|
|
155
|
-
describe('rendering', function () {
|
|
156
|
-
it('renders line cross chart', function () {
|
|
157
|
-
var _renderComponent = renderComponent(),
|
|
158
|
-
container = _renderComponent.container;
|
|
159
|
-
expect(container.firstChild).toBeInTheDocument();
|
|
160
|
-
});
|
|
161
|
-
it('renders with data points', function () {
|
|
162
|
-
var data = [{
|
|
163
|
-
x: 1,
|
|
164
|
-
y: 2,
|
|
165
|
-
label: 'A'
|
|
166
|
-
}, {
|
|
167
|
-
x: 2,
|
|
168
|
-
y: 3,
|
|
169
|
-
label: 'B'
|
|
170
|
-
}];
|
|
171
|
-
var _renderComponent2 = renderComponent({
|
|
172
|
-
data: data
|
|
173
|
-
}),
|
|
174
|
-
getByTestId = _renderComponent2.getByTestId;
|
|
175
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
176
|
-
});
|
|
177
|
-
it('renders without data', function () {
|
|
178
|
-
var _renderComponent3 = renderComponent({
|
|
179
|
-
data: []
|
|
180
|
-
}),
|
|
181
|
-
getByTestId = _renderComponent3.getByTestId;
|
|
182
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
183
|
-
});
|
|
184
|
-
it('passes graphProps to RawLine', function () {
|
|
185
|
-
var customGraphProps = (0, _utils.graphProps)(0, 10, 0, 10);
|
|
186
|
-
var _renderComponent4 = renderComponent({
|
|
187
|
-
graphProps: customGraphProps
|
|
188
|
-
}),
|
|
189
|
-
getByTestId = _renderComponent4.getByTestId;
|
|
190
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
191
|
-
});
|
|
192
|
-
it('passes onChange to RawLine', function () {
|
|
193
|
-
var onChange = jest.fn();
|
|
194
|
-
var _renderComponent5 = renderComponent({
|
|
195
|
-
onChange: onChange
|
|
196
|
-
}),
|
|
197
|
-
getByTestId = _renderComponent5.getByTestId;
|
|
198
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
199
|
-
});
|
|
200
|
-
});
|
|
201
|
-
describe('xBand calculation', function () {
|
|
202
|
-
it('calculates xBand from data', function () {
|
|
203
|
-
var data = [{
|
|
204
|
-
x: 1,
|
|
205
|
-
y: 2
|
|
206
|
-
}];
|
|
207
|
-
var _renderComponent6 = renderComponent({
|
|
208
|
-
data: data
|
|
209
|
-
}),
|
|
210
|
-
getByTestId = _renderComponent6.getByTestId;
|
|
211
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
212
|
-
});
|
|
213
|
-
it('handles empty data for xBand', function () {
|
|
214
|
-
var _renderComponent7 = renderComponent({
|
|
215
|
-
data: []
|
|
216
|
-
}),
|
|
217
|
-
getByTestId = _renderComponent7.getByTestId;
|
|
218
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
219
|
-
});
|
|
220
|
-
});
|
|
221
|
-
describe('component', function () {
|
|
222
|
-
it('returns correct chart object', function () {
|
|
223
|
-
var chart = (0, _lineCross["default"])();
|
|
224
|
-
expect(chart).toEqual({
|
|
225
|
-
type: 'lineCross',
|
|
226
|
-
Component: _lineCross.LineCross,
|
|
227
|
-
name: 'Line Cross'
|
|
228
|
-
});
|
|
229
|
-
});
|
|
230
|
-
it('returns object with correct type', function () {
|
|
231
|
-
var chart = (0, _lineCross["default"])();
|
|
232
|
-
expect(chart.type).toBe('lineCross');
|
|
233
|
-
});
|
|
234
|
-
it('returns object with correct name', function () {
|
|
235
|
-
var chart = (0, _lineCross["default"])();
|
|
236
|
-
expect(chart.name).toBe('Line Cross');
|
|
237
|
-
});
|
|
238
|
-
it('returns object with LineCross component', function () {
|
|
239
|
-
var chart = (0, _lineCross["default"])();
|
|
240
|
-
expect(chart.Component).toBe(_lineCross.LineCross);
|
|
241
|
-
});
|
|
242
|
-
});
|
|
243
|
-
describe('edge cases', function () {
|
|
244
|
-
it('handles null data', function () {
|
|
245
|
-
var _renderComponent8 = renderComponent({
|
|
246
|
-
data: null
|
|
247
|
-
}),
|
|
248
|
-
getByTestId = _renderComponent8.getByTestId;
|
|
249
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
250
|
-
});
|
|
251
|
-
it('handles undefined graphProps', function () {
|
|
252
|
-
var _renderComponent9 = renderComponent({
|
|
253
|
-
graphProps: undefined
|
|
254
|
-
}),
|
|
255
|
-
container = _renderComponent9.container;
|
|
256
|
-
expect(container).toBeInTheDocument();
|
|
257
|
-
});
|
|
258
|
-
it('handles missing scale in graphProps', function () {
|
|
259
|
-
var _renderComponent0 = renderComponent({
|
|
260
|
-
graphProps: {
|
|
261
|
-
size: {
|
|
262
|
-
width: 400,
|
|
263
|
-
height: 400
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
}),
|
|
267
|
-
container = _renderComponent0.container;
|
|
268
|
-
expect(container).toBeInTheDocument();
|
|
269
|
-
});
|
|
270
|
-
it('handles missing size in graphProps', function () {
|
|
271
|
-
var _renderComponent1 = renderComponent({
|
|
272
|
-
graphProps: {
|
|
273
|
-
scale: (0, _utils.graphProps)().scale
|
|
274
|
-
}
|
|
275
|
-
}),
|
|
276
|
-
container = _renderComponent1.container;
|
|
277
|
-
expect(container).toBeInTheDocument();
|
|
278
|
-
});
|
|
279
|
-
it('renders with className', function () {
|
|
280
|
-
var _renderComponent10 = renderComponent({
|
|
281
|
-
className: 'custom-class'
|
|
282
|
-
}),
|
|
283
|
-
container = _renderComponent10.container;
|
|
284
|
-
expect(container).toBeInTheDocument();
|
|
285
|
-
});
|
|
286
|
-
});
|
|
287
|
-
describe('data with correctness', function () {
|
|
288
|
-
it('renders data with correct answers', function () {
|
|
289
|
-
var data = [{
|
|
290
|
-
x: 1,
|
|
291
|
-
y: 2,
|
|
292
|
-
label: 'A',
|
|
293
|
-
correctness: {
|
|
294
|
-
value: 'correct',
|
|
295
|
-
label: 'Correct!'
|
|
296
|
-
},
|
|
297
|
-
interactive: true
|
|
298
|
-
}];
|
|
299
|
-
var _renderComponent11 = renderComponent({
|
|
300
|
-
data: data
|
|
301
|
-
}),
|
|
302
|
-
getByTestId = _renderComponent11.getByTestId;
|
|
303
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
304
|
-
});
|
|
305
|
-
it('renders data with incorrect answers', function () {
|
|
306
|
-
var data = [{
|
|
307
|
-
x: 1,
|
|
308
|
-
y: 2,
|
|
309
|
-
label: 'A',
|
|
310
|
-
correctness: {
|
|
311
|
-
value: 'incorrect',
|
|
312
|
-
label: 'Wrong'
|
|
313
|
-
},
|
|
314
|
-
interactive: true
|
|
315
|
-
}];
|
|
316
|
-
var correctData = [{
|
|
317
|
-
label: 'A',
|
|
318
|
-
value: 3
|
|
319
|
-
}];
|
|
320
|
-
var _renderComponent12 = renderComponent({
|
|
321
|
-
data: data,
|
|
322
|
-
correctData: correctData
|
|
323
|
-
}),
|
|
324
|
-
getByTestId = _renderComponent12.getByTestId;
|
|
325
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
326
|
-
});
|
|
327
|
-
it('renders non-interactive data', function () {
|
|
328
|
-
var data = [{
|
|
329
|
-
x: 1,
|
|
330
|
-
y: 2,
|
|
331
|
-
label: 'A',
|
|
332
|
-
interactive: false
|
|
333
|
-
}];
|
|
334
|
-
var _renderComponent13 = renderComponent({
|
|
335
|
-
data: data
|
|
336
|
-
}),
|
|
337
|
-
getByTestId = _renderComponent13.getByTestId;
|
|
338
|
-
expect(getByTestId('raw-line')).toBeInTheDocument();
|
|
339
|
-
});
|
|
340
|
-
});
|
|
341
|
-
});
|
|
342
|
-
describe('DraggableComponent', function () {
|
|
343
|
-
// We need to test the DraggableComponent through LineCross since it's not exported
|
|
344
|
-
var renderLineCrossWithData = function renderLineCrossWithData() {
|
|
345
|
-
var dataExtras = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
346
|
-
var data = [_objectSpread({
|
|
347
|
-
x: 5,
|
|
348
|
-
y: 10,
|
|
349
|
-
label: 'A',
|
|
350
|
-
r: 8,
|
|
351
|
-
interactive: true
|
|
352
|
-
}, dataExtras)];
|
|
353
|
-
var props = {
|
|
354
|
-
graphProps: (0, _utils.graphProps)(),
|
|
355
|
-
data: data
|
|
356
|
-
};
|
|
357
|
-
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
358
|
-
theme: theme
|
|
359
|
-
}, /*#__PURE__*/_react["default"].createElement(_lineCross.LineCross, props)));
|
|
360
|
-
};
|
|
361
|
-
describe('rendering', function () {
|
|
362
|
-
it('renders cross lines', function () {
|
|
363
|
-
var _renderLineCrossWithD = renderLineCrossWithData(),
|
|
364
|
-
getAllByTestId = _renderLineCrossWithD.getAllByTestId;
|
|
365
|
-
var linePaths = getAllByTestId('line-path');
|
|
366
|
-
expect(linePaths.length).toBeGreaterThan(0);
|
|
367
|
-
});
|
|
368
|
-
it('renders visx group', function () {
|
|
369
|
-
var _renderLineCrossWithD2 = renderLineCrossWithData(),
|
|
370
|
-
getByTestId = _renderLineCrossWithD2.getByTestId;
|
|
371
|
-
expect(getByTestId('visx-group')).toBeInTheDocument();
|
|
372
|
-
});
|
|
373
|
-
it('renders transparent handle circle', function () {
|
|
374
|
-
var _renderLineCrossWithD3 = renderLineCrossWithData(),
|
|
375
|
-
container = _renderLineCrossWithD3.container;
|
|
376
|
-
var circles = container.querySelectorAll('circle');
|
|
377
|
-
expect(circles.length).toBeGreaterThan(0);
|
|
378
|
-
});
|
|
379
|
-
});
|
|
380
|
-
describe('hover interactions', function () {
|
|
381
|
-
it('renders interactive elements for hover', function () {
|
|
382
|
-
var _renderLineCrossWithD4 = renderLineCrossWithData(),
|
|
383
|
-
container = _renderLineCrossWithD4.container;
|
|
384
|
-
// The component should render, even if we can't test hover through the mock
|
|
385
|
-
expect(container).toBeInTheDocument();
|
|
386
|
-
});
|
|
387
|
-
it('component supports hover state changes', function () {
|
|
388
|
-
var _renderLineCrossWithD5 = renderLineCrossWithData(),
|
|
389
|
-
container = _renderLineCrossWithD5.container;
|
|
390
|
-
// Verify the component renders with interactive data
|
|
391
|
-
var svg = container.querySelector('svg');
|
|
392
|
-
expect(svg).toBeInTheDocument();
|
|
393
|
-
});
|
|
394
|
-
});
|
|
395
|
-
describe('correctness indicators', function () {
|
|
396
|
-
it('renders correctness indicator for correct answer', function () {
|
|
397
|
-
var _renderLineCrossWithD6 = renderLineCrossWithData({
|
|
398
|
-
correctness: {
|
|
399
|
-
value: 'correct',
|
|
400
|
-
label: 'Correct!'
|
|
401
|
-
}
|
|
402
|
-
}),
|
|
403
|
-
getByTestId = _renderLineCrossWithD6.getByTestId;
|
|
404
|
-
expect(getByTestId('correctness-indicator')).toBeInTheDocument();
|
|
405
|
-
});
|
|
406
|
-
it('does not render correctness indicator when not interactive', function () {
|
|
407
|
-
var _renderLineCrossWithD7 = renderLineCrossWithData({
|
|
408
|
-
correctness: {
|
|
409
|
-
value: 'correct',
|
|
410
|
-
label: 'Correct!'
|
|
411
|
-
},
|
|
412
|
-
interactive: false
|
|
413
|
-
}),
|
|
414
|
-
queryByTestId = _renderLineCrossWithD7.queryByTestId;
|
|
415
|
-
expect(queryByTestId('correctness-indicator')).not.toBeInTheDocument();
|
|
416
|
-
});
|
|
417
|
-
it('renders small correct indicator for incorrect answer', function () {
|
|
418
|
-
var data = [{
|
|
419
|
-
x: 5,
|
|
420
|
-
y: 10,
|
|
421
|
-
label: 'A',
|
|
422
|
-
correctness: {
|
|
423
|
-
value: 'incorrect',
|
|
424
|
-
label: 'Wrong'
|
|
425
|
-
},
|
|
426
|
-
interactive: true
|
|
427
|
-
}];
|
|
428
|
-
var correctData = [{
|
|
429
|
-
label: 'A',
|
|
430
|
-
value: 15
|
|
431
|
-
}];
|
|
432
|
-
var props = {
|
|
433
|
-
graphProps: (0, _utils.graphProps)(),
|
|
434
|
-
data: data,
|
|
435
|
-
correctData: correctData
|
|
436
|
-
};
|
|
437
|
-
var _render = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
438
|
-
theme: theme
|
|
439
|
-
}, /*#__PURE__*/_react["default"].createElement(_lineCross.LineCross, props))),
|
|
440
|
-
getByTestId = _render.getByTestId;
|
|
441
|
-
expect(getByTestId('small-correct-indicator')).toBeInTheDocument();
|
|
442
|
-
});
|
|
443
|
-
it('does not render small correct indicator for correct answer', function () {
|
|
444
|
-
var data = [{
|
|
445
|
-
x: 5,
|
|
446
|
-
y: 10,
|
|
447
|
-
label: 'A',
|
|
448
|
-
correctness: {
|
|
449
|
-
value: 'correct',
|
|
450
|
-
label: 'Correct!'
|
|
451
|
-
},
|
|
452
|
-
interactive: true
|
|
453
|
-
}];
|
|
454
|
-
var correctData = [{
|
|
455
|
-
label: 'A',
|
|
456
|
-
value: 15
|
|
457
|
-
}];
|
|
458
|
-
var props = {
|
|
459
|
-
graphProps: (0, _utils.graphProps)(),
|
|
460
|
-
data: data,
|
|
461
|
-
correctData: correctData
|
|
462
|
-
};
|
|
463
|
-
var _render2 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
464
|
-
theme: theme
|
|
465
|
-
}, /*#__PURE__*/_react["default"].createElement(_lineCross.LineCross, props))),
|
|
466
|
-
queryByTestId = _render2.queryByTestId;
|
|
467
|
-
expect(queryByTestId('small-correct-indicator')).not.toBeInTheDocument();
|
|
468
|
-
});
|
|
469
|
-
});
|
|
470
|
-
describe('cross lines positioning', function () {
|
|
471
|
-
it('renders two cross lines for each point', function () {
|
|
472
|
-
var _renderLineCrossWithD8 = renderLineCrossWithData(),
|
|
473
|
-
getAllByTestId = _renderLineCrossWithD8.getAllByTestId;
|
|
474
|
-
var linePaths = getAllByTestId('line-path');
|
|
475
|
-
expect(linePaths.length).toBe(2); // Two lines per cross
|
|
476
|
-
});
|
|
477
|
-
it('positions cross lines correctly with scale', function () {
|
|
478
|
-
var _renderLineCrossWithD9 = renderLineCrossWithData({
|
|
479
|
-
x: 3,
|
|
480
|
-
y: 7
|
|
481
|
-
}),
|
|
482
|
-
getAllByTestId = _renderLineCrossWithD9.getAllByTestId;
|
|
483
|
-
var linePaths = getAllByTestId('line-path');
|
|
484
|
-
expect(linePaths.length).toBe(2);
|
|
485
|
-
});
|
|
486
|
-
});
|
|
487
|
-
describe('edge cases', function () {
|
|
488
|
-
it('renders with zero coordinates', function () {
|
|
489
|
-
var _renderLineCrossWithD0 = renderLineCrossWithData({
|
|
490
|
-
x: 0,
|
|
491
|
-
y: 0
|
|
492
|
-
}),
|
|
493
|
-
container = _renderLineCrossWithD0.container;
|
|
494
|
-
expect(container).toBeInTheDocument();
|
|
495
|
-
});
|
|
496
|
-
it('renders with negative coordinates', function () {
|
|
497
|
-
var _renderLineCrossWithD1 = renderLineCrossWithData({
|
|
498
|
-
x: -5,
|
|
499
|
-
y: -10
|
|
500
|
-
}),
|
|
501
|
-
container = _renderLineCrossWithD1.container;
|
|
502
|
-
expect(container).toBeInTheDocument();
|
|
503
|
-
});
|
|
504
|
-
it('renders with large coordinates', function () {
|
|
505
|
-
var _renderLineCrossWithD10 = renderLineCrossWithData({
|
|
506
|
-
x: 1000,
|
|
507
|
-
y: 2000
|
|
508
|
-
}),
|
|
509
|
-
container = _renderLineCrossWithD10.container;
|
|
510
|
-
expect(container).toBeInTheDocument();
|
|
511
|
-
});
|
|
512
|
-
it('renders without correctness', function () {
|
|
513
|
-
var _renderLineCrossWithD11 = renderLineCrossWithData({
|
|
514
|
-
correctness: null
|
|
515
|
-
}),
|
|
516
|
-
container = _renderLineCrossWithD11.container;
|
|
517
|
-
expect(container).toBeInTheDocument();
|
|
518
|
-
});
|
|
519
|
-
it('renders without label', function () {
|
|
520
|
-
var _renderLineCrossWithD12 = renderLineCrossWithData({
|
|
521
|
-
label: undefined
|
|
522
|
-
}),
|
|
523
|
-
container = _renderLineCrossWithD12.container;
|
|
524
|
-
expect(container).toBeInTheDocument();
|
|
525
|
-
});
|
|
526
|
-
it('handles custom radius', function () {
|
|
527
|
-
var _renderLineCrossWithD13 = renderLineCrossWithData({
|
|
528
|
-
r: 12
|
|
529
|
-
}),
|
|
530
|
-
container = _renderLineCrossWithD13.container;
|
|
531
|
-
expect(container).toBeInTheDocument();
|
|
532
|
-
});
|
|
533
|
-
it('applies className', function () {
|
|
534
|
-
var _renderLineCrossWithD14 = renderLineCrossWithData({
|
|
535
|
-
className: 'custom-cross'
|
|
536
|
-
}),
|
|
537
|
-
getByTestId = _renderLineCrossWithD14.getByTestId;
|
|
538
|
-
var group = getByTestId('visx-group');
|
|
539
|
-
expect(group).toBeInTheDocument();
|
|
540
|
-
});
|
|
541
|
-
});
|
|
542
|
-
describe('hover rect sizing', function () {
|
|
543
|
-
it('component supports hover rect with proper sizing', function () {
|
|
544
|
-
var _renderLineCrossWithD15 = renderLineCrossWithData({
|
|
545
|
-
r: 10
|
|
546
|
-
}),
|
|
547
|
-
container = _renderLineCrossWithD15.container;
|
|
548
|
-
// Verify the component renders with custom radius
|
|
549
|
-
expect(container).toBeInTheDocument();
|
|
550
|
-
});
|
|
551
|
-
it('component supports hover rect centering', function () {
|
|
552
|
-
var _renderLineCrossWithD16 = renderLineCrossWithData({
|
|
553
|
-
x: 5,
|
|
554
|
-
y: 10,
|
|
555
|
-
r: 8
|
|
556
|
-
}),
|
|
557
|
-
container = _renderLineCrossWithD16.container;
|
|
558
|
-
// Verify the component renders at specified coordinates
|
|
559
|
-
expect(container).toBeInTheDocument();
|
|
560
|
-
});
|
|
561
|
-
});
|
|
562
|
-
describe('multiple data points', function () {
|
|
563
|
-
it('renders multiple crosses for multiple data points', function () {
|
|
564
|
-
var data = [{
|
|
565
|
-
x: 1,
|
|
566
|
-
y: 2,
|
|
567
|
-
label: 'A',
|
|
568
|
-
interactive: true
|
|
569
|
-
}, {
|
|
570
|
-
x: 3,
|
|
571
|
-
y: 4,
|
|
572
|
-
label: 'B',
|
|
573
|
-
interactive: true
|
|
574
|
-
}, {
|
|
575
|
-
x: 5,
|
|
576
|
-
y: 6,
|
|
577
|
-
label: 'C',
|
|
578
|
-
interactive: true
|
|
579
|
-
}];
|
|
580
|
-
var props = {
|
|
581
|
-
graphProps: (0, _utils.graphProps)(),
|
|
582
|
-
data: data
|
|
583
|
-
};
|
|
584
|
-
var _render3 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
585
|
-
theme: theme
|
|
586
|
-
}, /*#__PURE__*/_react["default"].createElement(_lineCross.LineCross, props))),
|
|
587
|
-
getAllByTestId = _render3.getAllByTestId;
|
|
588
|
-
var groups = getAllByTestId('visx-group');
|
|
589
|
-
expect(groups.length).toBe(3);
|
|
590
|
-
});
|
|
591
|
-
it('renders multiple data points with proper structure', function () {
|
|
592
|
-
var data = [{
|
|
593
|
-
x: 1,
|
|
594
|
-
y: 2,
|
|
595
|
-
label: 'A',
|
|
596
|
-
interactive: true
|
|
597
|
-
}, {
|
|
598
|
-
x: 3,
|
|
599
|
-
y: 4,
|
|
600
|
-
label: 'B',
|
|
601
|
-
interactive: true
|
|
602
|
-
}];
|
|
603
|
-
var props = {
|
|
604
|
-
graphProps: (0, _utils.graphProps)(),
|
|
605
|
-
data: data
|
|
606
|
-
};
|
|
607
|
-
var _render4 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
608
|
-
theme: theme
|
|
609
|
-
}, /*#__PURE__*/_react["default"].createElement(_lineCross.LineCross, props))),
|
|
610
|
-
container = _render4.container;
|
|
611
|
-
|
|
612
|
-
// Should render the component with multiple data points
|
|
613
|
-
expect(container).toBeInTheDocument();
|
|
614
|
-
});
|
|
615
|
-
});
|
|
616
|
-
});
|
|
617
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_testUtils","_styles","_lineCross","_interopRequireWildcard","_utils","_excluded","_excluded2","_excluded3","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","jest","mock","LinePath","_ref","data","x","y","strokeWidth","style","props","_objectWithoutProperties2","createElement","_extends2","d","map","concat","join","Group","_ref2","children","color","text","defaults","TEXT","BLACK","BORDER_GRAY","disabled","dataToXBand","fn","scale","width","type","bandwidth","RawLine","_ref3","CustomDraggableComponent","graphProps","key","correctness","interactive","correctData","label","CorrectnessIndicator","_ref4","cx","cy","SmallCorrectPointIndicator","_ref5","value","theme","beforeAll","createTheme","describe","renderComponent","extras","classes","className","xBand","render","ThemeProvider","LineCross","it","_renderComponent","container","expect","firstChild","toBeInTheDocument","_renderComponent2","getByTestId","_renderComponent3","customGraphProps","_renderComponent4","onChange","_renderComponent5","_renderComponent6","_renderComponent7","chart","Line","toEqual","Component","LineChart","name","toBe","_renderComponent8","_renderComponent9","undefined","_renderComponent0","size","height","_renderComponent1","_renderComponent10","_renderComponent11","_renderComponent12","_renderComponent13","renderLineCrossWithData","dataExtras","_renderLineCrossWithD","getAllByTestId","linePaths","toBeGreaterThan","_renderLineCrossWithD2","_renderLineCrossWithD3","circles","querySelectorAll","_renderLineCrossWithD4","_renderLineCrossWithD5","svg","querySelector","_renderLineCrossWithD6","_renderLineCrossWithD7","queryByTestId","not","_render","_render2","_renderLineCrossWithD8","_renderLineCrossWithD9","_renderLineCrossWithD0","_renderLineCrossWithD1","_renderLineCrossWithD10","_renderLineCrossWithD11","_renderLineCrossWithD12","_renderLineCrossWithD13","_renderLineCrossWithD14","group","_renderLineCrossWithD15","_renderLineCrossWithD16","_render3","groups","_render4"],"sources":["../../../src/line/__tests__/line-cross.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render } from '@pie-lib/test-utils';\nimport { createTheme, ThemeProvider } from '@mui/material/styles';\nimport Line, { LineCross as LineChart } from '../line-cross';\nimport { graphProps } from './utils';\n\n// Mock dependencies\njest.mock('@visx/shape', () => ({\n  LinePath: ({ data, x, y, strokeWidth, style, ...props }) => (\n    <path\n      data-testid=\"line-path\"\n      d={data.map((d, i) => `${i === 0 ? 'M' : 'L'}${x(d)},${y(d)}`).join(' ')}\n      strokeWidth={strokeWidth}\n      {...props}\n    />\n  ),\n}));\n\njest.mock('@visx/group', () => ({\n  Group: ({ children, ...props }) => (\n    <g data-testid=\"visx-group\" {...props}>\n      {children}\n    </g>\n  ),\n}));\n\njest.mock('@pie-lib/render-ui', () => ({\n  color: {\n    text: () => '#000000',\n    defaults: {\n      TEXT: '#000000',\n      BLACK: '#000000',\n      BORDER_GRAY: '#cccccc',\n    },\n    disabled: () => '#cccccc',\n  },\n}));\n\njest.mock('../../utils', () => ({\n  dataToXBand: jest.fn((scale, data, width, type) => {\n    return {\n      bandwidth: () => 20,\n    };\n  }),\n}));\n\njest.mock('../common/line', () => {\n  return function RawLine({ CustomDraggableComponent, data, graphProps, ...props }) {\n    return (\n      <svg data-testid=\"raw-line\">\n        {data && data.length > 0 ? (\n          data.map((d, i) => (\n            <CustomDraggableComponent\n              key={i}\n              scale={graphProps.scale}\n              x={d.x || i}\n              y={d.y || i}\n              r={8}\n              correctness={d.correctness}\n              interactive={d.interactive}\n              correctData={props.correctData}\n              label={d.label}\n              {...props}\n            />\n          ))\n        ) : (\n          <text>No data</text>\n        )}\n      </svg>\n    );\n  };\n});\n\njest.mock('../../common/correctness-indicators', () => ({\n  CorrectnessIndicator: ({ scale, x, y, correctness, interactive }) =>\n    correctness && interactive ? (\n      <g data-testid=\"correctness-indicator\">\n        <circle cx={scale.x(x)} cy={scale.y(y)} r={5} />\n      </g>\n    ) : null,\n  SmallCorrectPointIndicator: ({ scale, x, correctness, correctData, label }) =>\n    correctness && correctness.value === 'incorrect' && correctData ? (\n      <g data-testid=\"small-correct-indicator\">\n        <circle cx={scale.x(x)} cy={scale.y(0)} r={3} />\n      </g>\n    ) : null,\n}));\n\nlet theme;\n\nbeforeAll(() => {\n  theme = createTheme();\n});\n\ndescribe('LineChart', () => {\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      className: 'className',\n      graphProps: graphProps(),\n      data: [],\n      xBand: () => {\n        return {\n          bandwidth: () => {},\n        };\n      },\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <LineChart {...props} />\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders line cross chart', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders with data points', () => {\n      const data = [\n        { x: 1, y: 2, label: 'A' },\n        { x: 2, y: 3, label: 'B' },\n      ];\n      const { getByTestId } = renderComponent({ data });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('renders without data', () => {\n      const { getByTestId } = renderComponent({ data: [] });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('passes graphProps to RawLine', () => {\n      const customGraphProps = graphProps(0, 10, 0, 10);\n      const { getByTestId } = renderComponent({ graphProps: customGraphProps });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('passes onChange to RawLine', () => {\n      const onChange = jest.fn();\n      const { getByTestId } = renderComponent({ onChange });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n  });\n\n  describe('xBand calculation', () => {\n    it('calculates xBand from data', () => {\n      const data = [{ x: 1, y: 2 }];\n      const { getByTestId } = renderComponent({ data });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('handles empty data for xBand', () => {\n      const { getByTestId } = renderComponent({ data: [] });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n  });\n\n  describe('component', () => {\n    it('returns correct chart object', () => {\n      const chart = Line();\n\n      expect(chart).toEqual({\n        type: 'lineCross',\n        Component: LineChart,\n        name: 'Line Cross',\n      });\n    });\n\n    it('returns object with correct type', () => {\n      const chart = Line();\n      expect(chart.type).toBe('lineCross');\n    });\n\n    it('returns object with correct name', () => {\n      const chart = Line();\n      expect(chart.name).toBe('Line Cross');\n    });\n\n    it('returns object with LineCross component', () => {\n      const chart = Line();\n      expect(chart.Component).toBe(LineChart);\n    });\n  });\n\n  describe('edge cases', () => {\n    it('handles null data', () => {\n      const { getByTestId } = renderComponent({ data: null });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('handles undefined graphProps', () => {\n      const { container } = renderComponent({ graphProps: undefined });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles missing scale in graphProps', () => {\n      const { container } = renderComponent({\n        graphProps: { size: { width: 400, height: 400 } },\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles missing size in graphProps', () => {\n      const { container } = renderComponent({\n        graphProps: { scale: graphProps().scale },\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with className', () => {\n      const { container } = renderComponent({ className: 'custom-class' });\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('data with correctness', () => {\n    it('renders data with correct answers', () => {\n      const data = [\n        { x: 1, y: 2, label: 'A', correctness: { value: 'correct', label: 'Correct!' }, interactive: true },\n      ];\n      const { getByTestId } = renderComponent({ data });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('renders data with incorrect answers', () => {\n      const data = [{ x: 1, y: 2, label: 'A', correctness: { value: 'incorrect', label: 'Wrong' }, interactive: true }];\n      const correctData = [{ label: 'A', value: 3 }];\n      const { getByTestId } = renderComponent({ data, correctData });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n\n    it('renders non-interactive data', () => {\n      const data = [{ x: 1, y: 2, label: 'A', interactive: false }];\n      const { getByTestId } = renderComponent({ data });\n      expect(getByTestId('raw-line')).toBeInTheDocument();\n    });\n  });\n});\n\ndescribe('DraggableComponent', () => {\n  // We need to test the DraggableComponent through LineCross since it's not exported\n  const renderLineCrossWithData = (dataExtras = {}) => {\n    const data = [{ x: 5, y: 10, label: 'A', r: 8, interactive: true, ...dataExtras }];\n    const props = {\n      graphProps: graphProps(),\n      data,\n    };\n    return render(\n      <ThemeProvider theme={theme}>\n        <LineChart {...props} />\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders cross lines', () => {\n      const { getAllByTestId } = renderLineCrossWithData();\n      const linePaths = getAllByTestId('line-path');\n      expect(linePaths.length).toBeGreaterThan(0);\n    });\n\n    it('renders visx group', () => {\n      const { getByTestId } = renderLineCrossWithData();\n      expect(getByTestId('visx-group')).toBeInTheDocument();\n    });\n\n    it('renders transparent handle circle', () => {\n      const { container } = renderLineCrossWithData();\n      const circles = container.querySelectorAll('circle');\n      expect(circles.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe('hover interactions', () => {\n    it('renders interactive elements for hover', () => {\n      const { container } = renderLineCrossWithData();\n      // The component should render, even if we can't test hover through the mock\n      expect(container).toBeInTheDocument();\n    });\n\n    it('component supports hover state changes', () => {\n      const { container } = renderLineCrossWithData();\n      // Verify the component renders with interactive data\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n    });\n  });\n\n  describe('correctness indicators', () => {\n    it('renders correctness indicator for correct answer', () => {\n      const { getByTestId } = renderLineCrossWithData({\n        correctness: { value: 'correct', label: 'Correct!' },\n      });\n      expect(getByTestId('correctness-indicator')).toBeInTheDocument();\n    });\n\n    it('does not render correctness indicator when not interactive', () => {\n      const { queryByTestId } = renderLineCrossWithData({\n        correctness: { value: 'correct', label: 'Correct!' },\n        interactive: false,\n      });\n      expect(queryByTestId('correctness-indicator')).not.toBeInTheDocument();\n    });\n\n    it('renders small correct indicator for incorrect answer', () => {\n      const data = [\n        {\n          x: 5,\n          y: 10,\n          label: 'A',\n          correctness: { value: 'incorrect', label: 'Wrong' },\n          interactive: true,\n        },\n      ];\n      const correctData = [{ label: 'A', value: 15 }];\n      const props = {\n        graphProps: graphProps(),\n        data,\n        correctData,\n      };\n      const { getByTestId } = render(\n        <ThemeProvider theme={theme}>\n          <LineChart {...props} />\n        </ThemeProvider>,\n      );\n      expect(getByTestId('small-correct-indicator')).toBeInTheDocument();\n    });\n\n    it('does not render small correct indicator for correct answer', () => {\n      const data = [\n        {\n          x: 5,\n          y: 10,\n          label: 'A',\n          correctness: { value: 'correct', label: 'Correct!' },\n          interactive: true,\n        },\n      ];\n      const correctData = [{ label: 'A', value: 15 }];\n      const props = {\n        graphProps: graphProps(),\n        data,\n        correctData,\n      };\n      const { queryByTestId } = render(\n        <ThemeProvider theme={theme}>\n          <LineChart {...props} />\n        </ThemeProvider>,\n      );\n      expect(queryByTestId('small-correct-indicator')).not.toBeInTheDocument();\n    });\n  });\n\n  describe('cross lines positioning', () => {\n    it('renders two cross lines for each point', () => {\n      const { getAllByTestId } = renderLineCrossWithData();\n      const linePaths = getAllByTestId('line-path');\n      expect(linePaths.length).toBe(2); // Two lines per cross\n    });\n\n    it('positions cross lines correctly with scale', () => {\n      const { getAllByTestId } = renderLineCrossWithData({ x: 3, y: 7 });\n      const linePaths = getAllByTestId('line-path');\n      expect(linePaths.length).toBe(2);\n    });\n  });\n\n  describe('edge cases', () => {\n    it('renders with zero coordinates', () => {\n      const { container } = renderLineCrossWithData({ x: 0, y: 0 });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with negative coordinates', () => {\n      const { container } = renderLineCrossWithData({ x: -5, y: -10 });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with large coordinates', () => {\n      const { container } = renderLineCrossWithData({ x: 1000, y: 2000 });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders without correctness', () => {\n      const { container } = renderLineCrossWithData({ correctness: null });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders without label', () => {\n      const { container } = renderLineCrossWithData({ label: undefined });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles custom radius', () => {\n      const { container } = renderLineCrossWithData({ r: 12 });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('applies className', () => {\n      const { getByTestId } = renderLineCrossWithData({ className: 'custom-cross' });\n      const group = getByTestId('visx-group');\n      expect(group).toBeInTheDocument();\n    });\n  });\n\n  describe('hover rect sizing', () => {\n    it('component supports hover rect with proper sizing', () => {\n      const { container } = renderLineCrossWithData({ r: 10 });\n      // Verify the component renders with custom radius\n      expect(container).toBeInTheDocument();\n    });\n\n    it('component supports hover rect centering', () => {\n      const { container } = renderLineCrossWithData({ x: 5, y: 10, r: 8 });\n      // Verify the component renders at specified coordinates\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('multiple data points', () => {\n    it('renders multiple crosses for multiple data points', () => {\n      const data = [\n        { x: 1, y: 2, label: 'A', interactive: true },\n        { x: 3, y: 4, label: 'B', interactive: true },\n        { x: 5, y: 6, label: 'C', interactive: true },\n      ];\n      const props = {\n        graphProps: graphProps(),\n        data,\n      };\n      const { getAllByTestId } = render(\n        <ThemeProvider theme={theme}>\n          <LineChart {...props} />\n        </ThemeProvider>,\n      );\n      const groups = getAllByTestId('visx-group');\n      expect(groups.length).toBe(3);\n    });\n\n    it('renders multiple data points with proper structure', () => {\n      const data = [\n        { x: 1, y: 2, label: 'A', interactive: true },\n        { x: 3, y: 4, label: 'B', interactive: true },\n      ];\n      const props = {\n        graphProps: graphProps(),\n        data,\n      };\n      const { container } = render(\n        <ThemeProvider theme={theme}>\n          <LineChart {...props} />\n        </ThemeProvider>,\n      );\n\n      // Should render the component with multiple data points\n      expect(container).toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|