@pie-lib/graphing 3.2.0-next.0 → 3.2.0-next.2
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/lib/__tests__/bg.test.js +282 -0
- package/lib/__tests__/coordinates-label.test.js +276 -0
- package/lib/__tests__/graph-with-controls.test.js +275 -0
- package/lib/__tests__/graph.test.js +927 -0
- package/lib/__tests__/grid-setup.test.js +729 -0
- package/lib/__tests__/grid.test.js +29 -0
- package/lib/__tests__/key-legend.test.js +321 -0
- package/lib/__tests__/label-svg-icon.test.js +373 -0
- package/lib/__tests__/labels.test.js +61 -0
- package/lib/__tests__/mark-label.test.js +133 -0
- package/lib/__tests__/toggle-bar.test.js +197 -0
- package/lib/__tests__/tool-menu.test.js +151 -0
- package/lib/__tests__/undo-redo.test.js +31 -0
- package/lib/__tests__/use-debounce.test.js +24 -0
- package/lib/__tests__/utils.js +70 -0
- package/lib/__tests__/utils.test.js +123 -0
- package/lib/axis/__tests__/arrow.test.js +60 -0
- package/lib/axis/__tests__/axes.test.js +195 -0
- package/lib/axis/arrow.js +1 -1
- package/lib/axis/axes.js +1 -1
- package/lib/axis/index.js +1 -1
- package/lib/bg.js +1 -1
- package/lib/container/__tests__/actions.test.js +108 -0
- package/lib/container/__tests__/index.test.js +503 -0
- package/lib/container/__tests__/marks.test.js +259 -0
- package/lib/container/__tests__/middleware.test.js +244 -0
- package/lib/container/__tests__/reducer.test.js +450 -0
- package/lib/container/actions.js +1 -1
- package/lib/container/index.js +1 -1
- package/lib/container/marks.js +1 -1
- package/lib/container/middleware.js +1 -1
- package/lib/container/reducer.js +1 -1
- package/lib/coordinates-label.js +1 -1
- package/lib/graph-with-controls.js +1 -1
- package/lib/graph.js +1 -1
- package/lib/grid-setup.js +1 -1
- package/lib/grid.js +1 -1
- package/lib/index.js +1 -1
- package/lib/key-legend.js +1 -1
- package/lib/label-svg-icon.js +1 -1
- package/lib/labels.js +1 -1
- package/lib/mark-label.js +1 -1
- package/lib/toggle-bar.js +1 -1
- package/lib/tool-menu.js +1 -1
- package/lib/tools/absolute/__tests__/component.test.js +65 -0
- package/lib/tools/absolute/component.js +1 -1
- package/lib/tools/absolute/index.js +1 -1
- package/lib/tools/circle/__tests__/bg-circle.test.js +33 -0
- package/lib/tools/circle/__tests__/component.test.js +615 -0
- package/lib/tools/circle/__tests__/index.test.js +576 -0
- package/lib/tools/circle/bg-circle.js +1 -1
- package/lib/tools/circle/component.js +1 -1
- package/lib/tools/circle/index.js +1 -1
- package/lib/tools/exponential/__tests__/component.test.js +64 -0
- package/lib/tools/exponential/__tests__/index.test.js +828 -0
- package/lib/tools/exponential/component.js +1 -1
- package/lib/tools/exponential/index.js +1 -1
- package/lib/tools/index.js +1 -1
- package/lib/tools/line/__tests__/component.test.js +45 -0
- package/lib/tools/line/component.js +1 -1
- package/lib/tools/line/index.js +1 -1
- package/lib/tools/parabola/__tests__/component.test.js +64 -0
- package/lib/tools/parabola/__tests__/index.test.js +564 -0
- package/lib/tools/parabola/component.js +1 -1
- package/lib/tools/parabola/index.js +1 -1
- package/lib/tools/point/__tests__/component.test.js +434 -0
- package/lib/tools/point/__tests__/index.test.js +262 -0
- package/lib/tools/point/component.js +1 -1
- package/lib/tools/point/index.js +1 -1
- package/lib/tools/polygon/__tests__/component.test.js +485 -0
- package/lib/tools/polygon/__tests__/index.test.js +303 -0
- package/lib/tools/polygon/__tests__/line.test.js +50 -0
- package/lib/tools/polygon/__tests__/polygon.test.js +85 -0
- package/lib/tools/polygon/component.js +1 -1
- package/lib/tools/polygon/index.js +1 -1
- package/lib/tools/polygon/line.js +1 -1
- package/lib/tools/polygon/polygon.js +1 -1
- package/lib/tools/ray/__tests__/component.test.js +35 -0
- package/lib/tools/ray/component.js +1 -1
- package/lib/tools/ray/index.js +1 -1
- package/lib/tools/segment/__tests__/component.test.js +35 -0
- package/lib/tools/segment/component.js +1 -1
- package/lib/tools/segment/index.js +1 -1
- package/lib/tools/shared/__tests__/arrow-head.test.js +45 -0
- package/lib/tools/shared/arrow-head.js +1 -1
- package/lib/tools/shared/icons/CorrectSVG.js +1 -1
- package/lib/tools/shared/icons/IncorrectSVG.js +1 -1
- package/lib/tools/shared/icons/MissingSVG.js +1 -1
- package/lib/tools/shared/line/__tests__/index.test.js +124 -0
- package/lib/tools/shared/line/__tests__/line-path.test.js +62 -0
- package/lib/tools/shared/line/__tests__/with-root-edge.test.js +90 -0
- package/lib/tools/shared/line/index.js +1 -1
- package/lib/tools/shared/line/line-path.js +1 -1
- package/lib/tools/shared/line/with-root-edge.js +1 -1
- package/lib/tools/shared/point/__tests__/arrow-point.test.js +127 -0
- package/lib/tools/shared/point/__tests__/base-point.test.js +122 -0
- package/lib/tools/shared/point/arrow-point.js +1 -1
- package/lib/tools/shared/point/arrow.js +1 -1
- package/lib/tools/shared/point/base-point.js +1 -1
- package/lib/tools/shared/point/index.js +1 -1
- package/lib/tools/shared/styles.js +1 -1
- package/lib/tools/shared/types.js +1 -1
- package/lib/tools/sine/__tests__/component.test.js +72 -0
- package/lib/tools/sine/component.js +1 -1
- package/lib/tools/sine/index.js +1 -1
- package/lib/tools/vector/__tests__/component.test.js +32 -0
- package/lib/tools/vector/component.js +1 -1
- package/lib/tools/vector/index.js +1 -1
- package/lib/undo-redo.js +1 -1
- package/lib/use-debounce.js +1 -1
- package/lib/utils.js +1 -1
- package/package.json +9 -12
- package/LICENSE.md +0 -5
|
@@ -0,0 +1,729 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
9
|
+
var _gridSetup = _interopRequireDefault(require("../grid-setup"));
|
|
10
|
+
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; }
|
|
11
|
+
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; }
|
|
12
|
+
var mockOnChange = jest.fn();
|
|
13
|
+
var mockOnChangeView = jest.fn();
|
|
14
|
+
var defaultProps = {
|
|
15
|
+
domain: {
|
|
16
|
+
min: -5,
|
|
17
|
+
max: 5,
|
|
18
|
+
step: 1,
|
|
19
|
+
labelStep: 1,
|
|
20
|
+
axisLabel: 'x'
|
|
21
|
+
},
|
|
22
|
+
range: {
|
|
23
|
+
min: -5,
|
|
24
|
+
max: 5,
|
|
25
|
+
step: 1,
|
|
26
|
+
labelStep: 1,
|
|
27
|
+
axisLabel: 'y'
|
|
28
|
+
},
|
|
29
|
+
size: {
|
|
30
|
+
width: 480,
|
|
31
|
+
height: 480
|
|
32
|
+
},
|
|
33
|
+
sizeConstraints: {
|
|
34
|
+
min: 300,
|
|
35
|
+
max: 900,
|
|
36
|
+
step: 10
|
|
37
|
+
},
|
|
38
|
+
includeAxes: true,
|
|
39
|
+
standardGrid: false,
|
|
40
|
+
displayedFields: {
|
|
41
|
+
axisLabel: {
|
|
42
|
+
enabled: true,
|
|
43
|
+
label: 'Axis Label'
|
|
44
|
+
},
|
|
45
|
+
min: {
|
|
46
|
+
enabled: true,
|
|
47
|
+
label: 'Min'
|
|
48
|
+
},
|
|
49
|
+
max: {
|
|
50
|
+
enabled: true,
|
|
51
|
+
label: 'Max'
|
|
52
|
+
},
|
|
53
|
+
step: {
|
|
54
|
+
enabled: true,
|
|
55
|
+
label: 'Interval'
|
|
56
|
+
},
|
|
57
|
+
labelStep: {
|
|
58
|
+
enabled: true,
|
|
59
|
+
label: 'Label Interval'
|
|
60
|
+
},
|
|
61
|
+
dimensionsEnabled: true,
|
|
62
|
+
includeAxesEnabled: true,
|
|
63
|
+
standardGridEnabled: true
|
|
64
|
+
},
|
|
65
|
+
gridValues: {
|
|
66
|
+
domain: [1, 2, 5, 10],
|
|
67
|
+
range: [1, 2, 5, 10]
|
|
68
|
+
},
|
|
69
|
+
labelValues: {
|
|
70
|
+
domain: [0, 1, 2],
|
|
71
|
+
range: [0, 1, 2]
|
|
72
|
+
},
|
|
73
|
+
onChange: mockOnChange,
|
|
74
|
+
onChangeView: mockOnChangeView
|
|
75
|
+
};
|
|
76
|
+
describe('GridSetup', function () {
|
|
77
|
+
beforeEach(function () {
|
|
78
|
+
jest.clearAllMocks();
|
|
79
|
+
});
|
|
80
|
+
describe('rendering', function () {
|
|
81
|
+
it('renders without crashing', function () {
|
|
82
|
+
var _render = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
83
|
+
container = _render.container;
|
|
84
|
+
expect(container).toBeTruthy();
|
|
85
|
+
});
|
|
86
|
+
it('renders accordion with title', function () {
|
|
87
|
+
var _render2 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
88
|
+
getByText = _render2.getByText;
|
|
89
|
+
expect(getByText('Customize Grid Setup')).toBeTruthy();
|
|
90
|
+
});
|
|
91
|
+
it('renders Include axes toggle when enabled', function () {
|
|
92
|
+
var _render3 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
93
|
+
getByText = _render3.getByText;
|
|
94
|
+
expect(getByText('Include axes and labels?')).toBeTruthy();
|
|
95
|
+
});
|
|
96
|
+
it('does not render Include axes toggle when disabled', function () {
|
|
97
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
98
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
99
|
+
includeAxesEnabled: false
|
|
100
|
+
})
|
|
101
|
+
});
|
|
102
|
+
var _render4 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
103
|
+
queryByText = _render4.queryByText;
|
|
104
|
+
expect(queryByText('Include axes and labels?')).toBeFalsy();
|
|
105
|
+
});
|
|
106
|
+
it('renders standard grid toggle when enabled', function () {
|
|
107
|
+
var _render5 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
108
|
+
getByText = _render5.getByText;
|
|
109
|
+
expect(getByText('Constrain to standard coordinate grid?')).toBeTruthy();
|
|
110
|
+
});
|
|
111
|
+
it('does not render standard grid toggle when disabled', function () {
|
|
112
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
113
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
114
|
+
standardGridEnabled: false
|
|
115
|
+
})
|
|
116
|
+
});
|
|
117
|
+
var _render6 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
118
|
+
queryByText = _render6.queryByText;
|
|
119
|
+
expect(queryByText('Constrain to standard coordinate grid?')).toBeFalsy();
|
|
120
|
+
});
|
|
121
|
+
it('renders dimensions section when enabled', function () {
|
|
122
|
+
var _render7 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
123
|
+
getByText = _render7.getByText;
|
|
124
|
+
expect(getByText('Dimensions(px)')).toBeTruthy();
|
|
125
|
+
expect(getByText(/Min 300, Max 900/)).toBeTruthy();
|
|
126
|
+
});
|
|
127
|
+
it('does not render dimensions section when disabled', function () {
|
|
128
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
129
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
130
|
+
dimensionsEnabled: false
|
|
131
|
+
})
|
|
132
|
+
});
|
|
133
|
+
var _render8 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
134
|
+
queryByText = _render8.queryByText;
|
|
135
|
+
expect(queryByText('Dimensions(px)')).toBeFalsy();
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
describe('axes configuration', function () {
|
|
139
|
+
it('renders axis headers when includeAxes is true', function () {
|
|
140
|
+
var _render9 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
141
|
+
container = _render9.container;
|
|
142
|
+
var xAxisHeader = container.querySelector('i');
|
|
143
|
+
expect(xAxisHeader === null || xAxisHeader === void 0 ? void 0 : xAxisHeader.textContent).toBe('x');
|
|
144
|
+
});
|
|
145
|
+
it('renders min/max fields when enabled', function () {
|
|
146
|
+
var _render0 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
147
|
+
getAllByLabelText = _render0.getAllByLabelText;
|
|
148
|
+
var minFields = getAllByLabelText('Min');
|
|
149
|
+
var maxFields = getAllByLabelText('Max');
|
|
150
|
+
expect(minFields.length).toBe(2); // domain and range
|
|
151
|
+
expect(maxFields.length).toBe(2); // domain and range
|
|
152
|
+
});
|
|
153
|
+
it('does not render min/max fields when disabled', function () {
|
|
154
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
155
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
156
|
+
min: {
|
|
157
|
+
enabled: false
|
|
158
|
+
},
|
|
159
|
+
max: {
|
|
160
|
+
enabled: false
|
|
161
|
+
}
|
|
162
|
+
})
|
|
163
|
+
});
|
|
164
|
+
var _render1 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
165
|
+
queryByLabelText = _render1.queryByLabelText;
|
|
166
|
+
expect(queryByLabelText('Min')).toBeFalsy();
|
|
167
|
+
expect(queryByLabelText('Max')).toBeFalsy();
|
|
168
|
+
});
|
|
169
|
+
it('renders axis label fields when enabled', function () {
|
|
170
|
+
var _render10 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
171
|
+
getAllByText = _render10.getAllByText;
|
|
172
|
+
var axisLabelFields = getAllByText('Axis Label');
|
|
173
|
+
expect(axisLabelFields.length).toBe(2); // domain and range
|
|
174
|
+
});
|
|
175
|
+
it('does not render axis label fields when disabled', function () {
|
|
176
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
177
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
178
|
+
axisLabel: {
|
|
179
|
+
enabled: false
|
|
180
|
+
}
|
|
181
|
+
})
|
|
182
|
+
});
|
|
183
|
+
var _render11 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
184
|
+
queryByText = _render11.queryByText;
|
|
185
|
+
expect(queryByText('Axis Label')).toBeFalsy();
|
|
186
|
+
});
|
|
187
|
+
it('renders step and labelStep fields when enabled', function () {
|
|
188
|
+
var _render12 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
189
|
+
getAllByLabelText = _render12.getAllByLabelText;
|
|
190
|
+
var intervalFields = getAllByLabelText('Interval');
|
|
191
|
+
var labelIntervalFields = getAllByLabelText('Label Interval');
|
|
192
|
+
expect(intervalFields.length).toBe(2); // domain and range
|
|
193
|
+
expect(labelIntervalFields.length).toBe(2); // domain and range
|
|
194
|
+
});
|
|
195
|
+
it('does not render step fields when disabled', function () {
|
|
196
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
197
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
198
|
+
step: {
|
|
199
|
+
enabled: false
|
|
200
|
+
}
|
|
201
|
+
})
|
|
202
|
+
});
|
|
203
|
+
var _render13 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
204
|
+
queryByLabelText = _render13.queryByLabelText;
|
|
205
|
+
expect(queryByLabelText('Interval')).toBeFalsy();
|
|
206
|
+
});
|
|
207
|
+
it('does not render labelStep fields when disabled', function () {
|
|
208
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
209
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
210
|
+
labelStep: {
|
|
211
|
+
enabled: false
|
|
212
|
+
}
|
|
213
|
+
})
|
|
214
|
+
});
|
|
215
|
+
var _render14 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
216
|
+
queryByLabelText = _render14.queryByLabelText;
|
|
217
|
+
expect(queryByLabelText('Label Interval')).toBeFalsy();
|
|
218
|
+
});
|
|
219
|
+
it('displays axis visibility hint when min/max enabled', function () {
|
|
220
|
+
var _render15 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
221
|
+
getByText = _render15.getByText;
|
|
222
|
+
expect(getByText('If you want the axis to be visible, use a zero or negative Min Value, and a positive Max Value')).toBeTruthy();
|
|
223
|
+
});
|
|
224
|
+
it('displays unnumbered gridlines hint when labelStep enabled', function () {
|
|
225
|
+
var _render16 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
226
|
+
getByText = _render16.getByText;
|
|
227
|
+
expect(getByText('For unnumbered gridlines, enter a label interval of 0')).toBeTruthy();
|
|
228
|
+
});
|
|
229
|
+
});
|
|
230
|
+
describe('gridlines configuration', function () {
|
|
231
|
+
it('renders gridlines config when includeAxes is false', function () {
|
|
232
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
233
|
+
includeAxes: false
|
|
234
|
+
});
|
|
235
|
+
var _render17 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
236
|
+
getByLabelText = _render17.getByLabelText;
|
|
237
|
+
expect(getByLabelText('Number of Vertical Gridlines')).toBeTruthy();
|
|
238
|
+
expect(getByLabelText('Number of Horizontal Gridlines')).toBeTruthy();
|
|
239
|
+
});
|
|
240
|
+
it('does not render axes config when includeAxes is false', function () {
|
|
241
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
242
|
+
includeAxes: false
|
|
243
|
+
});
|
|
244
|
+
var _render18 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
245
|
+
queryByText = _render18.queryByText;
|
|
246
|
+
expect(queryByText('Axis Label')).toBeFalsy();
|
|
247
|
+
});
|
|
248
|
+
it('does not render gridlines config when max is disabled', function () {
|
|
249
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
250
|
+
includeAxes: false,
|
|
251
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
252
|
+
max: {
|
|
253
|
+
enabled: false
|
|
254
|
+
}
|
|
255
|
+
})
|
|
256
|
+
});
|
|
257
|
+
var _render19 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
258
|
+
queryByLabelText = _render19.queryByLabelText;
|
|
259
|
+
expect(queryByLabelText('Number of Vertical Gridlines')).toBeFalsy();
|
|
260
|
+
expect(queryByLabelText('Number of Horizontal Gridlines')).toBeFalsy();
|
|
261
|
+
});
|
|
262
|
+
});
|
|
263
|
+
describe('user interactions', function () {
|
|
264
|
+
it('calls onChange when includeAxes toggle is clicked', function () {
|
|
265
|
+
var _render20 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
266
|
+
container = _render20.container;
|
|
267
|
+
var toggleInput = container.querySelector('input[type="checkbox"]');
|
|
268
|
+
_testUtils.fireEvent.click(toggleInput);
|
|
269
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
270
|
+
includeAxes: false
|
|
271
|
+
}));
|
|
272
|
+
});
|
|
273
|
+
it('calls onChange with proper config when includeAxes is disabled', function () {
|
|
274
|
+
var _render21 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
275
|
+
container = _render21.container;
|
|
276
|
+
var toggleInput = container.querySelector('input[type="checkbox"]');
|
|
277
|
+
_testUtils.fireEvent.click(toggleInput);
|
|
278
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
279
|
+
includeAxes: false,
|
|
280
|
+
domain: expect.objectContaining({
|
|
281
|
+
min: 1,
|
|
282
|
+
max: 5,
|
|
283
|
+
step: 1,
|
|
284
|
+
labelStep: 0
|
|
285
|
+
}),
|
|
286
|
+
range: expect.objectContaining({
|
|
287
|
+
min: 1,
|
|
288
|
+
max: 5,
|
|
289
|
+
step: 1,
|
|
290
|
+
labelStep: 0
|
|
291
|
+
})
|
|
292
|
+
}));
|
|
293
|
+
});
|
|
294
|
+
it('calls onChange with proper config when includeAxes is enabled', function () {
|
|
295
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
296
|
+
includeAxes: false
|
|
297
|
+
});
|
|
298
|
+
var _render22 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
299
|
+
container = _render22.container;
|
|
300
|
+
var toggleInputs = container.querySelectorAll('input[type="checkbox"]');
|
|
301
|
+
var includeAxesToggle = toggleInputs[0]; // First toggle is includeAxes
|
|
302
|
+
|
|
303
|
+
_testUtils.fireEvent.click(includeAxesToggle);
|
|
304
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
305
|
+
includeAxes: true,
|
|
306
|
+
domain: expect.objectContaining({
|
|
307
|
+
labelStep: 1
|
|
308
|
+
}),
|
|
309
|
+
range: expect.objectContaining({
|
|
310
|
+
labelStep: 1
|
|
311
|
+
})
|
|
312
|
+
}));
|
|
313
|
+
});
|
|
314
|
+
it('calls onChange when standardGrid toggle is clicked', function () {
|
|
315
|
+
var _render23 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
316
|
+
container = _render23.container;
|
|
317
|
+
var toggleInputs = container.querySelectorAll('input[type="checkbox"]');
|
|
318
|
+
var standardGridToggle = toggleInputs[1]; // Second toggle is standardGrid
|
|
319
|
+
|
|
320
|
+
_testUtils.fireEvent.click(standardGridToggle);
|
|
321
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
322
|
+
standardGrid: true,
|
|
323
|
+
graph: expect.objectContaining({
|
|
324
|
+
width: 480,
|
|
325
|
+
height: 480
|
|
326
|
+
})
|
|
327
|
+
}));
|
|
328
|
+
});
|
|
329
|
+
it('calls onChange when width is changed', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
330
|
+
var _render24, getAllByLabelText, widthInput;
|
|
331
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
332
|
+
while (1) switch (_context.prev = _context.next) {
|
|
333
|
+
case 0:
|
|
334
|
+
_render24 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)), getAllByLabelText = _render24.getAllByLabelText;
|
|
335
|
+
widthInput = getAllByLabelText('Width')[0];
|
|
336
|
+
_testUtils.fireEvent.change(widthInput, {
|
|
337
|
+
target: {
|
|
338
|
+
value: '500'
|
|
339
|
+
}
|
|
340
|
+
});
|
|
341
|
+
_testUtils.fireEvent.blur(widthInput);
|
|
342
|
+
_context.next = 1;
|
|
343
|
+
return (0, _testUtils.waitFor)(function () {
|
|
344
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
345
|
+
graph: expect.objectContaining({
|
|
346
|
+
width: 500
|
|
347
|
+
})
|
|
348
|
+
}));
|
|
349
|
+
});
|
|
350
|
+
case 1:
|
|
351
|
+
case "end":
|
|
352
|
+
return _context.stop();
|
|
353
|
+
}
|
|
354
|
+
}, _callee);
|
|
355
|
+
})));
|
|
356
|
+
it('calls onChange when height is changed', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
357
|
+
var _render25, getAllByLabelText, heightInput;
|
|
358
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
359
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
360
|
+
case 0:
|
|
361
|
+
_render25 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)), getAllByLabelText = _render25.getAllByLabelText;
|
|
362
|
+
heightInput = getAllByLabelText('Height')[0];
|
|
363
|
+
_testUtils.fireEvent.change(heightInput, {
|
|
364
|
+
target: {
|
|
365
|
+
value: '520'
|
|
366
|
+
}
|
|
367
|
+
});
|
|
368
|
+
_testUtils.fireEvent.blur(heightInput);
|
|
369
|
+
_context2.next = 1;
|
|
370
|
+
return (0, _testUtils.waitFor)(function () {
|
|
371
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
372
|
+
graph: expect.objectContaining({
|
|
373
|
+
height: 520
|
|
374
|
+
})
|
|
375
|
+
}));
|
|
376
|
+
});
|
|
377
|
+
case 1:
|
|
378
|
+
case "end":
|
|
379
|
+
return _context2.stop();
|
|
380
|
+
}
|
|
381
|
+
}, _callee2);
|
|
382
|
+
})));
|
|
383
|
+
it('updates both width and height when standardGrid is true', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
384
|
+
var props, _render26, getAllByLabelText, widthInput;
|
|
385
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
386
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
387
|
+
case 0:
|
|
388
|
+
props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
389
|
+
standardGrid: true
|
|
390
|
+
});
|
|
391
|
+
_render26 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)), getAllByLabelText = _render26.getAllByLabelText;
|
|
392
|
+
widthInput = getAllByLabelText('Width')[0];
|
|
393
|
+
_testUtils.fireEvent.change(widthInput, {
|
|
394
|
+
target: {
|
|
395
|
+
value: '600'
|
|
396
|
+
}
|
|
397
|
+
});
|
|
398
|
+
_testUtils.fireEvent.blur(widthInput);
|
|
399
|
+
_context3.next = 1;
|
|
400
|
+
return (0, _testUtils.waitFor)(function () {
|
|
401
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
402
|
+
graph: expect.objectContaining({
|
|
403
|
+
width: 600,
|
|
404
|
+
height: 600
|
|
405
|
+
})
|
|
406
|
+
}));
|
|
407
|
+
});
|
|
408
|
+
case 1:
|
|
409
|
+
case "end":
|
|
410
|
+
return _context3.stop();
|
|
411
|
+
}
|
|
412
|
+
}, _callee3);
|
|
413
|
+
})));
|
|
414
|
+
it('calls onChange when domain min is changed', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4() {
|
|
415
|
+
var _render27, getAllByLabelText, minInputs, domainMinInput;
|
|
416
|
+
return _regenerator["default"].wrap(function (_context4) {
|
|
417
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
418
|
+
case 0:
|
|
419
|
+
_render27 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)), getAllByLabelText = _render27.getAllByLabelText;
|
|
420
|
+
minInputs = getAllByLabelText('Min');
|
|
421
|
+
domainMinInput = minInputs[0];
|
|
422
|
+
_testUtils.fireEvent.change(domainMinInput, {
|
|
423
|
+
target: {
|
|
424
|
+
value: '-10'
|
|
425
|
+
}
|
|
426
|
+
});
|
|
427
|
+
_testUtils.fireEvent.blur(domainMinInput);
|
|
428
|
+
_context4.next = 1;
|
|
429
|
+
return (0, _testUtils.waitFor)(function () {
|
|
430
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
431
|
+
domain: expect.objectContaining({
|
|
432
|
+
min: -10
|
|
433
|
+
})
|
|
434
|
+
}));
|
|
435
|
+
});
|
|
436
|
+
case 1:
|
|
437
|
+
case "end":
|
|
438
|
+
return _context4.stop();
|
|
439
|
+
}
|
|
440
|
+
}, _callee4);
|
|
441
|
+
})));
|
|
442
|
+
it('calls onChange when domain max is changed', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee5() {
|
|
443
|
+
var _render28, getAllByLabelText, maxInputs, domainMaxInput;
|
|
444
|
+
return _regenerator["default"].wrap(function (_context5) {
|
|
445
|
+
while (1) switch (_context5.prev = _context5.next) {
|
|
446
|
+
case 0:
|
|
447
|
+
_render28 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)), getAllByLabelText = _render28.getAllByLabelText;
|
|
448
|
+
maxInputs = getAllByLabelText('Max');
|
|
449
|
+
domainMaxInput = maxInputs[0];
|
|
450
|
+
_testUtils.fireEvent.change(domainMaxInput, {
|
|
451
|
+
target: {
|
|
452
|
+
value: '10'
|
|
453
|
+
}
|
|
454
|
+
});
|
|
455
|
+
_testUtils.fireEvent.blur(domainMaxInput);
|
|
456
|
+
_context5.next = 1;
|
|
457
|
+
return (0, _testUtils.waitFor)(function () {
|
|
458
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
459
|
+
domain: expect.objectContaining({
|
|
460
|
+
max: 10
|
|
461
|
+
})
|
|
462
|
+
}));
|
|
463
|
+
});
|
|
464
|
+
case 1:
|
|
465
|
+
case "end":
|
|
466
|
+
return _context5.stop();
|
|
467
|
+
}
|
|
468
|
+
}, _callee5);
|
|
469
|
+
})));
|
|
470
|
+
it('calls onChange when range min is changed', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee6() {
|
|
471
|
+
var _render29, getAllByLabelText, minInputs, rangeMinInput;
|
|
472
|
+
return _regenerator["default"].wrap(function (_context6) {
|
|
473
|
+
while (1) switch (_context6.prev = _context6.next) {
|
|
474
|
+
case 0:
|
|
475
|
+
_render29 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)), getAllByLabelText = _render29.getAllByLabelText;
|
|
476
|
+
minInputs = getAllByLabelText('Min');
|
|
477
|
+
rangeMinInput = minInputs[1];
|
|
478
|
+
_testUtils.fireEvent.change(rangeMinInput, {
|
|
479
|
+
target: {
|
|
480
|
+
value: '-8'
|
|
481
|
+
}
|
|
482
|
+
});
|
|
483
|
+
_testUtils.fireEvent.blur(rangeMinInput);
|
|
484
|
+
_context6.next = 1;
|
|
485
|
+
return (0, _testUtils.waitFor)(function () {
|
|
486
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
487
|
+
range: expect.objectContaining({
|
|
488
|
+
min: -8
|
|
489
|
+
})
|
|
490
|
+
}));
|
|
491
|
+
});
|
|
492
|
+
case 1:
|
|
493
|
+
case "end":
|
|
494
|
+
return _context6.stop();
|
|
495
|
+
}
|
|
496
|
+
}, _callee6);
|
|
497
|
+
})));
|
|
498
|
+
it('calls onChange when range max is changed', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee7() {
|
|
499
|
+
var _render30, getAllByLabelText, maxInputs, rangeMaxInput;
|
|
500
|
+
return _regenerator["default"].wrap(function (_context7) {
|
|
501
|
+
while (1) switch (_context7.prev = _context7.next) {
|
|
502
|
+
case 0:
|
|
503
|
+
_render30 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)), getAllByLabelText = _render30.getAllByLabelText;
|
|
504
|
+
maxInputs = getAllByLabelText('Max');
|
|
505
|
+
rangeMaxInput = maxInputs[1];
|
|
506
|
+
_testUtils.fireEvent.change(rangeMaxInput, {
|
|
507
|
+
target: {
|
|
508
|
+
value: '12'
|
|
509
|
+
}
|
|
510
|
+
});
|
|
511
|
+
_testUtils.fireEvent.blur(rangeMaxInput);
|
|
512
|
+
_context7.next = 1;
|
|
513
|
+
return (0, _testUtils.waitFor)(function () {
|
|
514
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
515
|
+
range: expect.objectContaining({
|
|
516
|
+
max: 12
|
|
517
|
+
})
|
|
518
|
+
}));
|
|
519
|
+
});
|
|
520
|
+
case 1:
|
|
521
|
+
case "end":
|
|
522
|
+
return _context7.stop();
|
|
523
|
+
}
|
|
524
|
+
}, _callee7);
|
|
525
|
+
})));
|
|
526
|
+
it('updates both domain and range when standardGrid is true and domain changes', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee8() {
|
|
527
|
+
var props, _render31, getAllByLabelText, minInputs, domainMinInput;
|
|
528
|
+
return _regenerator["default"].wrap(function (_context8) {
|
|
529
|
+
while (1) switch (_context8.prev = _context8.next) {
|
|
530
|
+
case 0:
|
|
531
|
+
props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
532
|
+
standardGrid: true
|
|
533
|
+
});
|
|
534
|
+
_render31 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)), getAllByLabelText = _render31.getAllByLabelText;
|
|
535
|
+
minInputs = getAllByLabelText('Min');
|
|
536
|
+
domainMinInput = minInputs[0];
|
|
537
|
+
_testUtils.fireEvent.change(domainMinInput, {
|
|
538
|
+
target: {
|
|
539
|
+
value: '-15'
|
|
540
|
+
}
|
|
541
|
+
});
|
|
542
|
+
_testUtils.fireEvent.blur(domainMinInput);
|
|
543
|
+
_context8.next = 1;
|
|
544
|
+
return (0, _testUtils.waitFor)(function () {
|
|
545
|
+
expect(mockOnChange).toHaveBeenCalledWith(expect.objectContaining({
|
|
546
|
+
domain: expect.objectContaining({
|
|
547
|
+
min: -15
|
|
548
|
+
}),
|
|
549
|
+
range: expect.objectContaining({
|
|
550
|
+
min: -15
|
|
551
|
+
})
|
|
552
|
+
}));
|
|
553
|
+
});
|
|
554
|
+
case 1:
|
|
555
|
+
case "end":
|
|
556
|
+
return _context8.stop();
|
|
557
|
+
}
|
|
558
|
+
}, _callee8);
|
|
559
|
+
})));
|
|
560
|
+
it('does not update range when domain axisLabel changes with standardGrid', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee9() {
|
|
561
|
+
var props, _render32, container, axisLabelInputs;
|
|
562
|
+
return _regenerator["default"].wrap(function (_context9) {
|
|
563
|
+
while (1) switch (_context9.prev = _context9.next) {
|
|
564
|
+
case 0:
|
|
565
|
+
props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
566
|
+
standardGrid: true
|
|
567
|
+
});
|
|
568
|
+
_render32 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)), container = _render32.container; // EditableHTML change is harder to trigger, but we can test the handler directly
|
|
569
|
+
// by verifying the range doesn't get the axisLabel value from domain
|
|
570
|
+
axisLabelInputs = container.querySelectorAll('[contenteditable="true"]');
|
|
571
|
+
if (!(axisLabelInputs.length > 0)) {
|
|
572
|
+
_context9.next = 1;
|
|
573
|
+
break;
|
|
574
|
+
}
|
|
575
|
+
_testUtils.fireEvent.input(axisLabelInputs[0], {
|
|
576
|
+
target: {
|
|
577
|
+
innerHTML: 'X-Axis'
|
|
578
|
+
}
|
|
579
|
+
});
|
|
580
|
+
_context9.next = 1;
|
|
581
|
+
return (0, _testUtils.waitFor)(function () {
|
|
582
|
+
if (mockOnChange.mock.calls.length > 0) {
|
|
583
|
+
var _lastCall$range;
|
|
584
|
+
var lastCall = mockOnChange.mock.calls[mockOnChange.mock.calls.length - 1][0];
|
|
585
|
+
// range.axisLabel should not be 'X-Axis', it should keep its original value
|
|
586
|
+
expect((_lastCall$range = lastCall.range) === null || _lastCall$range === void 0 ? void 0 : _lastCall$range.axisLabel).not.toBe('X-Axis');
|
|
587
|
+
}
|
|
588
|
+
});
|
|
589
|
+
case 1:
|
|
590
|
+
case "end":
|
|
591
|
+
return _context9.stop();
|
|
592
|
+
}
|
|
593
|
+
}, _callee9);
|
|
594
|
+
})));
|
|
595
|
+
it('calls onChangeView when accordion is toggled', function () {
|
|
596
|
+
var _render33 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
597
|
+
container = _render33.container;
|
|
598
|
+
var accordionSummary = container.querySelector('[aria-expanded]');
|
|
599
|
+
_testUtils.fireEvent.click(accordionSummary);
|
|
600
|
+
expect(mockOnChangeView).toHaveBeenCalled();
|
|
601
|
+
});
|
|
602
|
+
});
|
|
603
|
+
describe('disabled states', function () {
|
|
604
|
+
it('disables range fields when standardGrid is true', function () {
|
|
605
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
606
|
+
standardGrid: true
|
|
607
|
+
});
|
|
608
|
+
var _render34 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
609
|
+
getAllByLabelText = _render34.getAllByLabelText;
|
|
610
|
+
var minInputs = getAllByLabelText('Min');
|
|
611
|
+
var rangeMinInput = minInputs[1];
|
|
612
|
+
expect(rangeMinInput).toBeDisabled();
|
|
613
|
+
});
|
|
614
|
+
it('disables height field when standardGrid is true', function () {
|
|
615
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
616
|
+
standardGrid: true
|
|
617
|
+
});
|
|
618
|
+
var _render35 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
619
|
+
getAllByLabelText = _render35.getAllByLabelText;
|
|
620
|
+
var heightInput = getAllByLabelText('Height')[0];
|
|
621
|
+
expect(heightInput).toBeDisabled();
|
|
622
|
+
});
|
|
623
|
+
it('disables horizontal gridlines field when standardGrid is true and includeAxes is false', function () {
|
|
624
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
625
|
+
includeAxes: false,
|
|
626
|
+
standardGrid: true
|
|
627
|
+
});
|
|
628
|
+
var _render36 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
629
|
+
getByLabelText = _render36.getByLabelText;
|
|
630
|
+
var horizontalGridlinesInput = getByLabelText('Number of Horizontal Gridlines');
|
|
631
|
+
expect(horizontalGridlinesInput).toBeDisabled();
|
|
632
|
+
});
|
|
633
|
+
});
|
|
634
|
+
describe('GridConfig component', function () {
|
|
635
|
+
it('renders step field when enabled', function () {
|
|
636
|
+
var _render37 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
637
|
+
getAllByLabelText = _render37.getAllByLabelText;
|
|
638
|
+
var intervalFields = getAllByLabelText('Interval');
|
|
639
|
+
expect(intervalFields.length).toBeGreaterThan(0);
|
|
640
|
+
});
|
|
641
|
+
it('renders labelStep field when enabled', function () {
|
|
642
|
+
var _render38 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
643
|
+
getAllByLabelText = _render38.getAllByLabelText;
|
|
644
|
+
var labelIntervalFields = getAllByLabelText('Label Interval');
|
|
645
|
+
expect(labelIntervalFields.length).toBeGreaterThan(0);
|
|
646
|
+
});
|
|
647
|
+
it('does not render when both step and labelStep are disabled', function () {
|
|
648
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
649
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
650
|
+
step: {
|
|
651
|
+
enabled: false
|
|
652
|
+
},
|
|
653
|
+
labelStep: {
|
|
654
|
+
enabled: false
|
|
655
|
+
}
|
|
656
|
+
})
|
|
657
|
+
});
|
|
658
|
+
var _render39 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
659
|
+
queryByLabelText = _render39.queryByLabelText;
|
|
660
|
+
expect(queryByLabelText('Interval')).toBeFalsy();
|
|
661
|
+
expect(queryByLabelText('Label Interval')).toBeFalsy();
|
|
662
|
+
});
|
|
663
|
+
});
|
|
664
|
+
describe('AxisConfig component', function () {
|
|
665
|
+
it('renders x-axis header', function () {
|
|
666
|
+
var _render40 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
667
|
+
container = _render40.container;
|
|
668
|
+
var headers = container.querySelectorAll('i');
|
|
669
|
+
var xAxisHeader = Array.from(headers).find(function (h) {
|
|
670
|
+
return h.textContent === 'x';
|
|
671
|
+
});
|
|
672
|
+
expect(xAxisHeader).toBeTruthy();
|
|
673
|
+
});
|
|
674
|
+
it('renders y-axis header', function () {
|
|
675
|
+
var _render41 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
676
|
+
container = _render41.container;
|
|
677
|
+
var headers = container.querySelectorAll('i');
|
|
678
|
+
var yAxisHeader = Array.from(headers).find(function (h) {
|
|
679
|
+
return h.textContent === 'y';
|
|
680
|
+
});
|
|
681
|
+
expect(yAxisHeader).toBeTruthy();
|
|
682
|
+
});
|
|
683
|
+
it('does not render headers when all fields are disabled', function () {
|
|
684
|
+
var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
685
|
+
displayedFields: _objectSpread(_objectSpread({}, defaultProps.displayedFields), {}, {
|
|
686
|
+
min: {
|
|
687
|
+
enabled: false
|
|
688
|
+
},
|
|
689
|
+
max: {
|
|
690
|
+
enabled: false
|
|
691
|
+
},
|
|
692
|
+
axisLabel: {
|
|
693
|
+
enabled: false
|
|
694
|
+
},
|
|
695
|
+
step: {
|
|
696
|
+
enabled: false
|
|
697
|
+
},
|
|
698
|
+
labelStep: {
|
|
699
|
+
enabled: false
|
|
700
|
+
}
|
|
701
|
+
})
|
|
702
|
+
});
|
|
703
|
+
var _render42 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], props)),
|
|
704
|
+
container = _render42.container;
|
|
705
|
+
var headers = container.querySelectorAll('i');
|
|
706
|
+
var axisHeaders = Array.from(headers).filter(function (h) {
|
|
707
|
+
return h.textContent === 'x' || h.textContent === 'y';
|
|
708
|
+
});
|
|
709
|
+
expect(axisHeaders.length).toBe(0);
|
|
710
|
+
});
|
|
711
|
+
});
|
|
712
|
+
describe('Accordion behavior', function () {
|
|
713
|
+
it('renders with correct transition props', function () {
|
|
714
|
+
var _render43 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
715
|
+
container = _render43.container;
|
|
716
|
+
var accordion = container.querySelector('.MuiAccordion-root');
|
|
717
|
+
expect(accordion).toBeTruthy();
|
|
718
|
+
});
|
|
719
|
+
it('expands and collapses accordion', function () {
|
|
720
|
+
var _render44 = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_gridSetup["default"], defaultProps)),
|
|
721
|
+
container = _render44.container;
|
|
722
|
+
var accordionSummary = container.querySelector('[aria-expanded]');
|
|
723
|
+
expect(accordionSummary.getAttribute('aria-expanded')).toBe('false');
|
|
724
|
+
_testUtils.fireEvent.click(accordionSummary);
|
|
725
|
+
expect(mockOnChangeView).toHaveBeenCalled();
|
|
726
|
+
});
|
|
727
|
+
});
|
|
728
|
+
});
|
|
729
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_testUtils","_gridSetup","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","mockOnChange","jest","fn","mockOnChangeView","defaultProps","domain","min","max","step","labelStep","axisLabel","range","size","width","height","sizeConstraints","includeAxes","standardGrid","displayedFields","enabled","label","dimensionsEnabled","includeAxesEnabled","standardGridEnabled","gridValues","labelValues","onChange","onChangeView","describe","beforeEach","clearAllMocks","it","_render","render","createElement","container","expect","toBeTruthy","_render2","getByText","_render3","props","_render4","queryByText","toBeFalsy","_render5","_render6","_render7","_render8","_render9","xAxisHeader","querySelector","textContent","toBe","_render0","getAllByLabelText","minFields","maxFields","_render1","queryByLabelText","_render10","getAllByText","axisLabelFields","_render11","_render12","intervalFields","labelIntervalFields","_render13","_render14","_render15","_render16","_render17","getByLabelText","_render18","_render19","_render20","toggleInput","fireEvent","click","toHaveBeenCalledWith","objectContaining","_render21","_render22","toggleInputs","querySelectorAll","includeAxesToggle","_render23","standardGridToggle","graph","_asyncToGenerator2","_regenerator","mark","_callee","_render24","widthInput","wrap","_context","prev","next","change","target","value","blur","waitFor","stop","_callee2","_render25","heightInput","_context2","_callee3","_render26","_context3","_callee4","_render27","minInputs","domainMinInput","_context4","_callee5","_render28","maxInputs","domainMaxInput","_context5","_callee6","_render29","rangeMinInput","_context6","_callee7","_render30","rangeMaxInput","_context7","_callee8","_render31","_context8","_callee9","_render32","axisLabelInputs","_context9","input","innerHTML","mock","calls","_lastCall$range","lastCall","not","_render33","accordionSummary","toHaveBeenCalled","_render34","toBeDisabled","_render35","_render36","horizontalGridlinesInput","_render37","toBeGreaterThan","_render38","_render39","_render40","headers","Array","from","find","h","_render41","yAxisHeader","_render42","axisHeaders","_render43","accordion","_render44","getAttribute"],"sources":["../../src/__tests__/grid-setup.test.jsx"],"sourcesContent":["import React from 'react';\nimport { fireEvent, render, waitFor } from '@pie-lib/test-utils';\nimport GridSetup from '../grid-setup';\n\nconst mockOnChange = jest.fn();\nconst mockOnChangeView = jest.fn();\n\nconst defaultProps = {\n  domain: {\n    min: -5,\n    max: 5,\n    step: 1,\n    labelStep: 1,\n    axisLabel: 'x',\n  },\n  range: {\n    min: -5,\n    max: 5,\n    step: 1,\n    labelStep: 1,\n    axisLabel: 'y',\n  },\n  size: {\n    width: 480,\n    height: 480,\n  },\n  sizeConstraints: {\n    min: 300,\n    max: 900,\n    step: 10,\n  },\n  includeAxes: true,\n  standardGrid: false,\n  displayedFields: {\n    axisLabel: { enabled: true, label: 'Axis Label' },\n    min: { enabled: true, label: 'Min' },\n    max: { enabled: true, label: 'Max' },\n    step: { enabled: true, label: 'Interval' },\n    labelStep: { enabled: true, label: 'Label Interval' },\n    dimensionsEnabled: true,\n    includeAxesEnabled: true,\n    standardGridEnabled: true,\n  },\n  gridValues: {\n    domain: [1, 2, 5, 10],\n    range: [1, 2, 5, 10],\n  },\n  labelValues: {\n    domain: [0, 1, 2],\n    range: [0, 1, 2],\n  },\n  onChange: mockOnChange,\n  onChangeView: mockOnChangeView,\n};\n\ndescribe('GridSetup', () => {\n  beforeEach(() => {\n    jest.clearAllMocks();\n  });\n\n  describe('rendering', () => {\n    it('renders without crashing', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      expect(container).toBeTruthy();\n    });\n\n    it('renders accordion with title', () => {\n      const { getByText } = render(<GridSetup {...defaultProps} />);\n      expect(getByText('Customize Grid Setup')).toBeTruthy();\n    });\n\n    it('renders Include axes toggle when enabled', () => {\n      const { getByText } = render(<GridSetup {...defaultProps} />);\n      expect(getByText('Include axes and labels?')).toBeTruthy();\n    });\n\n    it('does not render Include axes toggle when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          includeAxesEnabled: false,\n        },\n      };\n      const { queryByText } = render(<GridSetup {...props} />);\n      expect(queryByText('Include axes and labels?')).toBeFalsy();\n    });\n\n    it('renders standard grid toggle when enabled', () => {\n      const { getByText } = render(<GridSetup {...defaultProps} />);\n      expect(getByText('Constrain to standard coordinate grid?')).toBeTruthy();\n    });\n\n    it('does not render standard grid toggle when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          standardGridEnabled: false,\n        },\n      };\n      const { queryByText } = render(<GridSetup {...props} />);\n      expect(queryByText('Constrain to standard coordinate grid?')).toBeFalsy();\n    });\n\n    it('renders dimensions section when enabled', () => {\n      const { getByText } = render(<GridSetup {...defaultProps} />);\n      expect(getByText('Dimensions(px)')).toBeTruthy();\n      expect(getByText(/Min 300, Max 900/)).toBeTruthy();\n    });\n\n    it('does not render dimensions section when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          dimensionsEnabled: false,\n        },\n      };\n      const { queryByText } = render(<GridSetup {...props} />);\n      expect(queryByText('Dimensions(px)')).toBeFalsy();\n    });\n  });\n\n  describe('axes configuration', () => {\n    it('renders axis headers when includeAxes is true', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const xAxisHeader = container.querySelector('i');\n      expect(xAxisHeader?.textContent).toBe('x');\n    });\n\n    it('renders min/max fields when enabled', () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const minFields = getAllByLabelText('Min');\n      const maxFields = getAllByLabelText('Max');\n      expect(minFields.length).toBe(2); // domain and range\n      expect(maxFields.length).toBe(2); // domain and range\n    });\n\n    it('does not render min/max fields when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          min: { enabled: false },\n          max: { enabled: false },\n        },\n      };\n      const { queryByLabelText } = render(<GridSetup {...props} />);\n      expect(queryByLabelText('Min')).toBeFalsy();\n      expect(queryByLabelText('Max')).toBeFalsy();\n    });\n\n    it('renders axis label fields when enabled', () => {\n      const { getAllByText } = render(<GridSetup {...defaultProps} />);\n      const axisLabelFields = getAllByText('Axis Label');\n      expect(axisLabelFields.length).toBe(2); // domain and range\n    });\n\n    it('does not render axis label fields when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          axisLabel: { enabled: false },\n        },\n      };\n      const { queryByText } = render(<GridSetup {...props} />);\n      expect(queryByText('Axis Label')).toBeFalsy();\n    });\n\n    it('renders step and labelStep fields when enabled', () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const intervalFields = getAllByLabelText('Interval');\n      const labelIntervalFields = getAllByLabelText('Label Interval');\n      expect(intervalFields.length).toBe(2); // domain and range\n      expect(labelIntervalFields.length).toBe(2); // domain and range\n    });\n\n    it('does not render step fields when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          step: { enabled: false },\n        },\n      };\n      const { queryByLabelText } = render(<GridSetup {...props} />);\n      expect(queryByLabelText('Interval')).toBeFalsy();\n    });\n\n    it('does not render labelStep fields when disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          labelStep: { enabled: false },\n        },\n      };\n      const { queryByLabelText } = render(<GridSetup {...props} />);\n      expect(queryByLabelText('Label Interval')).toBeFalsy();\n    });\n\n    it('displays axis visibility hint when min/max enabled', () => {\n      const { getByText } = render(<GridSetup {...defaultProps} />);\n      expect(\n        getByText('If you want the axis to be visible, use a zero or negative Min Value, and a positive Max Value'),\n      ).toBeTruthy();\n    });\n\n    it('displays unnumbered gridlines hint when labelStep enabled', () => {\n      const { getByText } = render(<GridSetup {...defaultProps} />);\n      expect(getByText('For unnumbered gridlines, enter a label interval of 0')).toBeTruthy();\n    });\n  });\n\n  describe('gridlines configuration', () => {\n    it('renders gridlines config when includeAxes is false', () => {\n      const props = {\n        ...defaultProps,\n        includeAxes: false,\n      };\n      const { getByLabelText } = render(<GridSetup {...props} />);\n      expect(getByLabelText('Number of Vertical Gridlines')).toBeTruthy();\n      expect(getByLabelText('Number of Horizontal Gridlines')).toBeTruthy();\n    });\n\n    it('does not render axes config when includeAxes is false', () => {\n      const props = {\n        ...defaultProps,\n        includeAxes: false,\n      };\n      const { queryByText } = render(<GridSetup {...props} />);\n      expect(queryByText('Axis Label')).toBeFalsy();\n    });\n\n    it('does not render gridlines config when max is disabled', () => {\n      const props = {\n        ...defaultProps,\n        includeAxes: false,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          max: { enabled: false },\n        },\n      };\n      const { queryByLabelText } = render(<GridSetup {...props} />);\n      expect(queryByLabelText('Number of Vertical Gridlines')).toBeFalsy();\n      expect(queryByLabelText('Number of Horizontal Gridlines')).toBeFalsy();\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange when includeAxes toggle is clicked', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const toggleInput = container.querySelector('input[type=\"checkbox\"]');\n\n      fireEvent.click(toggleInput);\n\n      expect(mockOnChange).toHaveBeenCalledWith(\n        expect.objectContaining({\n          includeAxes: false,\n        }),\n      );\n    });\n\n    it('calls onChange with proper config when includeAxes is disabled', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const toggleInput = container.querySelector('input[type=\"checkbox\"]');\n\n      fireEvent.click(toggleInput);\n\n      expect(mockOnChange).toHaveBeenCalledWith(\n        expect.objectContaining({\n          includeAxes: false,\n          domain: expect.objectContaining({\n            min: 1,\n            max: 5,\n            step: 1,\n            labelStep: 0,\n          }),\n          range: expect.objectContaining({\n            min: 1,\n            max: 5,\n            step: 1,\n            labelStep: 0,\n          }),\n        }),\n      );\n    });\n\n    it('calls onChange with proper config when includeAxes is enabled', () => {\n      const props = {\n        ...defaultProps,\n        includeAxes: false,\n      };\n      const { container } = render(<GridSetup {...props} />);\n      const toggleInputs = container.querySelectorAll('input[type=\"checkbox\"]');\n      const includeAxesToggle = toggleInputs[0]; // First toggle is includeAxes\n\n      fireEvent.click(includeAxesToggle);\n\n      expect(mockOnChange).toHaveBeenCalledWith(\n        expect.objectContaining({\n          includeAxes: true,\n          domain: expect.objectContaining({\n            labelStep: 1,\n          }),\n          range: expect.objectContaining({\n            labelStep: 1,\n          }),\n        }),\n      );\n    });\n\n    it('calls onChange when standardGrid toggle is clicked', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const toggleInputs = container.querySelectorAll('input[type=\"checkbox\"]');\n      const standardGridToggle = toggleInputs[1]; // Second toggle is standardGrid\n\n      fireEvent.click(standardGridToggle);\n\n      expect(mockOnChange).toHaveBeenCalledWith(\n        expect.objectContaining({\n          standardGrid: true,\n          graph: expect.objectContaining({\n            width: 480,\n            height: 480,\n          }),\n        }),\n      );\n    });\n\n    it('calls onChange when width is changed', async () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const widthInput = getAllByLabelText('Width')[0];\n\n      fireEvent.change(widthInput, { target: { value: '500' } });\n      fireEvent.blur(widthInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            graph: expect.objectContaining({\n              width: 500,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('calls onChange when height is changed', async () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const heightInput = getAllByLabelText('Height')[0];\n\n      fireEvent.change(heightInput, { target: { value: '520' } });\n      fireEvent.blur(heightInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            graph: expect.objectContaining({\n              height: 520,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('updates both width and height when standardGrid is true', async () => {\n      const props = {\n        ...defaultProps,\n        standardGrid: true,\n      };\n      const { getAllByLabelText } = render(<GridSetup {...props} />);\n      const widthInput = getAllByLabelText('Width')[0];\n\n      fireEvent.change(widthInput, { target: { value: '600' } });\n      fireEvent.blur(widthInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            graph: expect.objectContaining({\n              width: 600,\n              height: 600,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('calls onChange when domain min is changed', async () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const minInputs = getAllByLabelText('Min');\n      const domainMinInput = minInputs[0];\n\n      fireEvent.change(domainMinInput, { target: { value: '-10' } });\n      fireEvent.blur(domainMinInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            domain: expect.objectContaining({\n              min: -10,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('calls onChange when domain max is changed', async () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const maxInputs = getAllByLabelText('Max');\n      const domainMaxInput = maxInputs[0];\n\n      fireEvent.change(domainMaxInput, { target: { value: '10' } });\n      fireEvent.blur(domainMaxInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            domain: expect.objectContaining({\n              max: 10,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('calls onChange when range min is changed', async () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const minInputs = getAllByLabelText('Min');\n      const rangeMinInput = minInputs[1];\n\n      fireEvent.change(rangeMinInput, { target: { value: '-8' } });\n      fireEvent.blur(rangeMinInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            range: expect.objectContaining({\n              min: -8,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('calls onChange when range max is changed', async () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const maxInputs = getAllByLabelText('Max');\n      const rangeMaxInput = maxInputs[1];\n\n      fireEvent.change(rangeMaxInput, { target: { value: '12' } });\n      fireEvent.blur(rangeMaxInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            range: expect.objectContaining({\n              max: 12,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('updates both domain and range when standardGrid is true and domain changes', async () => {\n      const props = {\n        ...defaultProps,\n        standardGrid: true,\n      };\n      const { getAllByLabelText } = render(<GridSetup {...props} />);\n      const minInputs = getAllByLabelText('Min');\n      const domainMinInput = minInputs[0];\n\n      fireEvent.change(domainMinInput, { target: { value: '-15' } });\n      fireEvent.blur(domainMinInput);\n\n      await waitFor(() => {\n        expect(mockOnChange).toHaveBeenCalledWith(\n          expect.objectContaining({\n            domain: expect.objectContaining({\n              min: -15,\n            }),\n            range: expect.objectContaining({\n              min: -15,\n            }),\n          }),\n        );\n      });\n    });\n\n    it('does not update range when domain axisLabel changes with standardGrid', async () => {\n      const props = {\n        ...defaultProps,\n        standardGrid: true,\n      };\n      const { container } = render(<GridSetup {...props} />);\n\n      // EditableHTML change is harder to trigger, but we can test the handler directly\n      // by verifying the range doesn't get the axisLabel value from domain\n      const axisLabelInputs = container.querySelectorAll('[contenteditable=\"true\"]');\n\n      if (axisLabelInputs.length > 0) {\n        fireEvent.input(axisLabelInputs[0], { target: { innerHTML: 'X-Axis' } });\n\n        await waitFor(() => {\n          if (mockOnChange.mock.calls.length > 0) {\n            const lastCall = mockOnChange.mock.calls[mockOnChange.mock.calls.length - 1][0];\n            // range.axisLabel should not be 'X-Axis', it should keep its original value\n            expect(lastCall.range?.axisLabel).not.toBe('X-Axis');\n          }\n        });\n      }\n    });\n\n    it('calls onChangeView when accordion is toggled', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const accordionSummary = container.querySelector('[aria-expanded]');\n\n      fireEvent.click(accordionSummary);\n\n      expect(mockOnChangeView).toHaveBeenCalled();\n    });\n  });\n\n  describe('disabled states', () => {\n    it('disables range fields when standardGrid is true', () => {\n      const props = {\n        ...defaultProps,\n        standardGrid: true,\n      };\n      const { getAllByLabelText } = render(<GridSetup {...props} />);\n      const minInputs = getAllByLabelText('Min');\n      const rangeMinInput = minInputs[1];\n\n      expect(rangeMinInput).toBeDisabled();\n    });\n\n    it('disables height field when standardGrid is true', () => {\n      const props = {\n        ...defaultProps,\n        standardGrid: true,\n      };\n      const { getAllByLabelText } = render(<GridSetup {...props} />);\n      const heightInput = getAllByLabelText('Height')[0];\n\n      expect(heightInput).toBeDisabled();\n    });\n\n    it('disables horizontal gridlines field when standardGrid is true and includeAxes is false', () => {\n      const props = {\n        ...defaultProps,\n        includeAxes: false,\n        standardGrid: true,\n      };\n      const { getByLabelText } = render(<GridSetup {...props} />);\n      const horizontalGridlinesInput = getByLabelText('Number of Horizontal Gridlines');\n\n      expect(horizontalGridlinesInput).toBeDisabled();\n    });\n  });\n\n  describe('GridConfig component', () => {\n    it('renders step field when enabled', () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const intervalFields = getAllByLabelText('Interval');\n      expect(intervalFields.length).toBeGreaterThan(0);\n    });\n\n    it('renders labelStep field when enabled', () => {\n      const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);\n      const labelIntervalFields = getAllByLabelText('Label Interval');\n      expect(labelIntervalFields.length).toBeGreaterThan(0);\n    });\n\n    it('does not render when both step and labelStep are disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          step: { enabled: false },\n          labelStep: { enabled: false },\n        },\n      };\n      const { queryByLabelText } = render(<GridSetup {...props} />);\n      expect(queryByLabelText('Interval')).toBeFalsy();\n      expect(queryByLabelText('Label Interval')).toBeFalsy();\n    });\n  });\n\n  describe('AxisConfig component', () => {\n    it('renders x-axis header', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const headers = container.querySelectorAll('i');\n      const xAxisHeader = Array.from(headers).find((h) => h.textContent === 'x');\n      expect(xAxisHeader).toBeTruthy();\n    });\n\n    it('renders y-axis header', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const headers = container.querySelectorAll('i');\n      const yAxisHeader = Array.from(headers).find((h) => h.textContent === 'y');\n      expect(yAxisHeader).toBeTruthy();\n    });\n\n    it('does not render headers when all fields are disabled', () => {\n      const props = {\n        ...defaultProps,\n        displayedFields: {\n          ...defaultProps.displayedFields,\n          min: { enabled: false },\n          max: { enabled: false },\n          axisLabel: { enabled: false },\n          step: { enabled: false },\n          labelStep: { enabled: false },\n        },\n      };\n      const { container } = render(<GridSetup {...props} />);\n      const headers = container.querySelectorAll('i');\n      const axisHeaders = Array.from(headers).filter((h) => h.textContent === 'x' || h.textContent === 'y');\n      expect(axisHeaders.length).toBe(0);\n    });\n  });\n\n  describe('Accordion behavior', () => {\n    it('renders with correct transition props', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const accordion = container.querySelector('.MuiAccordion-root');\n      expect(accordion).toBeTruthy();\n    });\n\n    it('expands and collapses accordion', () => {\n      const { container } = render(<GridSetup {...defaultProps} />);\n      const accordionSummary = container.querySelector('[aria-expanded]');\n\n      expect(accordionSummary.getAttribute('aria-expanded')).toBe('false');\n\n      fireEvent.click(accordionSummary);\n\n      expect(mockOnChangeView).toHaveBeenCalled();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|