@pie-lib/charting 5.36.3-next.2 → 5.36.4-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -96
- package/lib/__tests__/axes.test.js +129 -0
- package/lib/__tests__/chart-setup.test.js +57 -0
- package/lib/__tests__/chart-type.test.js +25 -0
- package/lib/__tests__/chart.test.js +103 -0
- package/lib/__tests__/grid.test.js +39 -0
- package/lib/__tests__/mark-label.test.js +46 -0
- package/lib/__tests__/utils.js +56 -0
- package/lib/__tests__/utils.test.js +186 -0
- package/lib/actions-button.js +61 -91
- package/lib/actions-button.js.map +1 -1
- package/lib/axes.js +163 -239
- package/lib/axes.js.map +1 -1
- package/lib/bars/__tests__/bar.test.js +53 -0
- package/lib/bars/__tests__/histogram.test.js +53 -0
- package/lib/bars/__tests__/utils.js +50 -0
- package/lib/bars/bar.js +14 -42
- package/lib/bars/bar.js.map +1 -1
- package/lib/bars/common/__tests__/bars.test.js +76 -0
- package/lib/bars/common/__tests__/utils.js +50 -0
- package/lib/bars/common/bars.js +62 -138
- package/lib/bars/common/bars.js.map +1 -1
- package/lib/bars/common/correct-check-icon.js +6 -7
- package/lib/bars/common/correct-check-icon.js.map +1 -1
- package/lib/bars/histogram.js +14 -42
- package/lib/bars/histogram.js.map +1 -1
- package/lib/chart-setup.js +120 -196
- package/lib/chart-setup.js.map +1 -1
- package/lib/chart-type.js +53 -44
- package/lib/chart-type.js.map +1 -1
- package/lib/chart-types.js +2 -11
- package/lib/chart-types.js.map +1 -1
- package/lib/chart.js +74 -152
- package/lib/chart.js.map +1 -1
- package/lib/common/__tests__/drag-handle.test.js +74 -0
- package/lib/common/__tests__/utils.js +50 -0
- package/lib/common/correctness-indicators.js +110 -53
- package/lib/common/correctness-indicators.js.map +1 -1
- package/lib/common/drag-handle.js +66 -109
- package/lib/common/drag-handle.js.map +1 -1
- package/lib/common/drag-icon.js +13 -13
- package/lib/common/drag-icon.js.map +1 -1
- package/lib/common/styles.js +7 -25
- package/lib/common/styles.js.map +1 -1
- package/lib/grid.js +44 -84
- package/lib/grid.js.map +1 -1
- package/lib/index.js +1 -7
- package/lib/index.js.map +1 -1
- package/lib/key-legend.js +64 -88
- package/lib/key-legend.js.map +1 -1
- package/lib/line/__tests__/line-cross.test.js +47 -0
- package/lib/line/__tests__/line-dot.test.js +47 -0
- package/lib/line/__tests__/utils.js +56 -0
- package/lib/line/common/__tests__/drag-handle.test.js +74 -0
- package/lib/line/common/__tests__/line.test.js +92 -0
- package/lib/line/common/__tests__/utils.js +50 -0
- package/lib/line/common/drag-handle.js +73 -101
- package/lib/line/common/drag-handle.js.map +1 -1
- package/lib/line/common/line.js +51 -97
- package/lib/line/common/line.js.map +1 -1
- package/lib/line/line-cross.js +80 -90
- package/lib/line/line-cross.js.map +1 -1
- package/lib/line/line-dot.js +59 -77
- package/lib/line/line-dot.js.map +1 -1
- package/lib/mark-label.js +85 -120
- package/lib/mark-label.js.map +1 -1
- package/lib/plot/__tests__/dot.test.js +53 -0
- package/lib/plot/__tests__/line.test.js +53 -0
- package/lib/plot/__tests__/utils.js +50 -0
- package/lib/plot/common/__tests__/plot.test.js +79 -0
- package/lib/plot/common/__tests__/utils.js +50 -0
- package/lib/plot/common/plot.js +91 -149
- package/lib/plot/common/plot.js.map +1 -1
- package/lib/plot/dot.js +33 -59
- package/lib/plot/dot.js.map +1 -1
- package/lib/plot/line.js +40 -65
- package/lib/plot/line.js.map +1 -1
- package/lib/tool-menu.js +48 -84
- package/lib/tool-menu.js.map +1 -1
- package/lib/utils.js +32 -87
- package/lib/utils.js.map +1 -1
- package/package.json +22 -24
- package/src/__tests__/axes.test.jsx +85 -100
- package/src/__tests__/chart-type.test.jsx +5 -11
- package/src/__tests__/chart.test.jsx +41 -50
- package/src/__tests__/grid.test.jsx +23 -11
- package/src/__tests__/mark-label.test.jsx +13 -11
- package/src/__tests__/utils.js +8 -2
- package/src/actions-button.jsx +44 -39
- package/src/axes.jsx +67 -81
- package/src/bars/__tests__/bar.test.jsx +19 -11
- package/src/bars/__tests__/histogram.test.jsx +19 -12
- package/src/bars/common/__tests__/bars.test.jsx +23 -24
- package/src/bars/common/bars.jsx +42 -69
- package/src/bars/common/correct-check-icon.jsx +5 -0
- package/src/chart-setup.jsx +75 -88
- package/src/chart-type.js +45 -22
- package/src/chart.jsx +19 -34
- package/src/common/__tests__/drag-handle.test.jsx +16 -45
- package/src/common/correctness-indicators.jsx +91 -13
- package/src/common/drag-handle.jsx +44 -64
- package/src/common/drag-icon.jsx +9 -2
- package/src/common/styles.js +1 -1
- package/src/grid.jsx +10 -14
- package/src/key-legend.jsx +62 -60
- package/src/line/__tests__/line-cross.test.jsx +16 -13
- package/src/line/__tests__/line-dot.test.jsx +16 -13
- package/src/line/__tests__/utils.js +8 -2
- package/src/line/common/__tests__/drag-handle.test.jsx +20 -45
- package/src/line/common/__tests__/line.test.jsx +27 -30
- package/src/line/common/drag-handle.jsx +61 -55
- package/src/line/common/line.jsx +21 -11
- package/src/line/line-cross.js +39 -14
- package/src/line/line-dot.js +27 -32
- package/src/mark-label.jsx +51 -47
- package/src/plot/__tests__/dot.test.jsx +19 -12
- package/src/plot/__tests__/line.test.jsx +19 -12
- package/src/plot/common/__tests__/plot.test.jsx +23 -24
- package/src/plot/common/plot.jsx +29 -24
- package/src/plot/dot.js +11 -4
- package/src/plot/line.js +16 -8
- package/src/tool-menu.jsx +26 -30
- package/src/utils.js +13 -9
- package/esm/index.css +0 -847
- package/esm/index.js +0 -231130
- package/esm/index.js.map +0 -1
- package/esm/package.json +0 -3
- package/src/__tests__/__snapshots__/axes.test.jsx.snap +0 -569
- package/src/__tests__/__snapshots__/chart-type.test.jsx.snap +0 -14
- package/src/__tests__/__snapshots__/chart.test.jsx.snap +0 -595
- package/src/__tests__/__snapshots__/grid.test.jsx.snap +0 -72
- package/src/__tests__/__snapshots__/mark-label.test.jsx.snap +0 -73
- package/src/bars/__tests__/__snapshots__/bar.test.jsx.snap +0 -43
- package/src/bars/__tests__/__snapshots__/histogram.test.jsx.snap +0 -45
- package/src/bars/common/__tests__/__snapshots__/bars.test.jsx.snap +0 -110
- package/src/common/__tests__/__snapshots__/drag-handle.test.jsx.snap +0 -48
- package/src/line/__tests__/__snapshots__/line-cross.test.jsx.snap +0 -45
- package/src/line/__tests__/__snapshots__/line-dot.test.jsx.snap +0 -45
- package/src/line/common/__tests__/__snapshots__/drag-handle.test.jsx.snap +0 -49
- package/src/line/common/__tests__/__snapshots__/line.test.jsx.snap +0 -143
- package/src/plot/__tests__/__snapshots__/dot.test.jsx.snap +0 -45
- package/src/plot/__tests__/__snapshots__/line.test.jsx.snap +0 -45
- package/src/plot/common/__tests__/__snapshots__/plot.test.jsx.snap +0 -97
package/CHANGELOG.md
CHANGED
|
@@ -7,182 +7,103 @@ See [Conventional Commits](https://conventionalcommits.org) for commit guideline
|
|
|
7
7
|
|
|
8
8
|
**Note:** Version bump only for package @pie-lib/charting
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
10
|
## [5.36.1](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.32.7...@pie-lib/charting@5.36.1) (2025-10-22)
|
|
15
11
|
|
|
16
12
|
**Note:** Version bump only for package @pie-lib/charting
|
|
17
13
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
14
|
# [5.36.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.35.0...@pie-lib/charting@5.36.0) (2025-10-16)
|
|
23
15
|
|
|
24
16
|
**Note:** Version bump only for package @pie-lib/charting
|
|
25
17
|
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
18
|
# [5.35.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.31.0...@pie-lib/charting@5.35.0) (2025-10-16)
|
|
31
19
|
|
|
32
|
-
|
|
33
20
|
### Features
|
|
34
21
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
22
|
+
- PD-5128 only needed files ([64d375b](https://github.com/pie-framework/pie-lib/commit/64d375b1731179ae46f735c2c4da21215101bd95))
|
|
23
|
+
- PD-5217 only needed file ([b21b343](https://github.com/pie-framework/pie-lib/commit/b21b34348569c73253eff72eea43c6c3235b25df))
|
|
41
24
|
|
|
42
25
|
# [5.34.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.31.0...@pie-lib/charting@5.34.0) (2025-10-16)
|
|
43
26
|
|
|
44
|
-
|
|
45
27
|
### Features
|
|
46
28
|
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
29
|
+
- PD-5128 only needed files ([64d375b](https://github.com/pie-framework/pie-lib/commit/64d375b1731179ae46f735c2c4da21215101bd95))
|
|
30
|
+
- PD-5217 only needed file ([b21b343](https://github.com/pie-framework/pie-lib/commit/b21b34348569c73253eff72eea43c6c3235b25df))
|
|
53
31
|
|
|
54
32
|
# [5.33.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.31.0...@pie-lib/charting@5.33.0) (2025-10-16)
|
|
55
33
|
|
|
56
|
-
|
|
57
34
|
### Features
|
|
58
35
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
36
|
+
- PD-5128 only needed files ([64d375b](https://github.com/pie-framework/pie-lib/commit/64d375b1731179ae46f735c2c4da21215101bd95))
|
|
37
|
+
- PD-5217 only needed file ([b21b343](https://github.com/pie-framework/pie-lib/commit/b21b34348569c73253eff72eea43c6c3235b25df))
|
|
65
38
|
|
|
66
39
|
## [5.32.7](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.32.6...@pie-lib/charting@5.32.7) (2025-10-14)
|
|
67
40
|
|
|
68
41
|
**Note:** Version bump only for package @pie-lib/charting
|
|
69
42
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
43
|
## [5.32.6](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.32.0...@pie-lib/charting@5.32.6) (2025-10-09)
|
|
75
44
|
|
|
76
45
|
**Note:** Version bump only for package @pie-lib/charting
|
|
77
46
|
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
47
|
# [5.32.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.31.0...@pie-lib/charting@5.32.0) (2025-10-09)
|
|
83
48
|
|
|
84
|
-
|
|
85
49
|
### Features
|
|
86
50
|
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
51
|
+
- PD-5128 only needed files ([64d375b](https://github.com/pie-framework/pie-lib/commit/64d375b1731179ae46f735c2c4da21215101bd95))
|
|
52
|
+
- PD-5217 only needed file ([b21b343](https://github.com/pie-framework/pie-lib/commit/b21b34348569c73253eff72eea43c6c3235b25df))
|
|
93
53
|
|
|
94
54
|
# [5.31.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.15.6...@pie-lib/charting@5.31.0) (2025-09-25)
|
|
95
55
|
|
|
96
|
-
|
|
97
56
|
### Bug Fixes
|
|
98
57
|
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
58
|
+
- **charting:** make the “answer key correct” indicators smaller for plot PD-5198 ([ce6bb35](https://github.com/pie-framework/pie-lib/commit/ce6bb35099c832f017e1bc213403ccb094792442))
|
|
59
|
+
- fixed pie-lib/icons import [PD-5126](<[dcb506c](https://github.com/pie-framework/pie-lib/commit/dcb506c914a177f6d88bf73247a023bfe71dac1f)>)
|
|
102
60
|
|
|
103
61
|
### Features
|
|
104
62
|
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
63
|
+
- split pie-toolbox into multiple packages [PD-5126](<[7d55a25](https://github.com/pie-framework/pie-lib/commit/7d55a2552d084cd3d0d5c00dc77411b2ced2f5e2)>)
|
|
110
64
|
|
|
111
65
|
# [5.30.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.29.0...@pie-lib/charting@5.30.0) (2025-09-18)
|
|
112
66
|
|
|
113
67
|
**Note:** Version bump only for package @pie-lib/charting
|
|
114
68
|
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
69
|
# [5.29.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.28.0...@pie-lib/charting@5.29.0) (2025-09-18)
|
|
120
70
|
|
|
121
71
|
**Note:** Version bump only for package @pie-lib/charting
|
|
122
72
|
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
73
|
# [5.28.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.15.6...@pie-lib/charting@5.28.0) (2025-09-18)
|
|
128
74
|
|
|
129
|
-
|
|
130
75
|
### Bug Fixes
|
|
131
76
|
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
77
|
+
- **charting:** make the “answer key correct” indicators smaller for plot PD-5198 ([ce6bb35](https://github.com/pie-framework/pie-lib/commit/ce6bb35099c832f017e1bc213403ccb094792442))
|
|
78
|
+
- fixed pie-lib/icons import [PD-5126](<[dcb506c](https://github.com/pie-framework/pie-lib/commit/dcb506c914a177f6d88bf73247a023bfe71dac1f)>)
|
|
135
79
|
|
|
136
80
|
### Features
|
|
137
81
|
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
82
|
+
- split pie-toolbox into multiple packages [PD-5126](<[7d55a25](https://github.com/pie-framework/pie-lib/commit/7d55a2552d084cd3d0d5c00dc77411b2ced2f5e2)>)
|
|
143
83
|
|
|
144
84
|
# [5.27.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.26.0...@pie-lib/charting@5.27.0) (2025-09-17)
|
|
145
85
|
|
|
146
86
|
**Note:** Version bump only for package @pie-lib/charting
|
|
147
87
|
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
88
|
# [5.26.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.25.0...@pie-lib/charting@5.26.0) (2025-09-17)
|
|
153
89
|
|
|
154
90
|
**Note:** Version bump only for package @pie-lib/charting
|
|
155
91
|
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
92
|
# [5.25.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.24.1...@pie-lib/charting@5.25.0) (2025-09-17)
|
|
161
93
|
|
|
162
|
-
|
|
163
94
|
### Bug Fixes
|
|
164
95
|
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
96
|
+
- **charting:** make the “answer key correct” indicators smaller for plot PD-5198 ([ce6bb35](https://github.com/pie-framework/pie-lib/commit/ce6bb35099c832f017e1bc213403ccb094792442))
|
|
170
97
|
|
|
171
98
|
## [5.24.1](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.15.6...@pie-lib/charting@5.24.1) (2025-08-11)
|
|
172
99
|
|
|
173
|
-
|
|
174
100
|
### Bug Fixes
|
|
175
101
|
|
|
176
|
-
|
|
177
|
-
|
|
102
|
+
- fixed pie-lib/icons import [PD-5126](<[dcb506c](https://github.com/pie-framework/pie-lib/commit/dcb506c914a177f6d88bf73247a023bfe71dac1f)>)
|
|
178
103
|
|
|
179
104
|
### Features
|
|
180
105
|
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
106
|
+
- split pie-toolbox into multiple packages [PD-5126](<[7d55a25](https://github.com/pie-framework/pie-lib/commit/7d55a2552d084cd3d0d5c00dc77411b2ced2f5e2)>)
|
|
186
107
|
|
|
187
108
|
# [5.24.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/charting@5.15.6...@pie-lib/charting@5.24.0) (2025-08-07)
|
|
188
109
|
|
|
@@ -0,0 +1,129 @@
|
|
|
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 _react = _interopRequireDefault(require("react"));
|
|
7
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
8
|
+
var _styles = require("@mui/material/styles");
|
|
9
|
+
var _axes = _interopRequireWildcard(require("../axes"));
|
|
10
|
+
var _utils = require("./utils");
|
|
11
|
+
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); }
|
|
12
|
+
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; }
|
|
13
|
+
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; }
|
|
14
|
+
var theme = (0, _styles.createTheme)();
|
|
15
|
+
describe('ChartAxes', function () {
|
|
16
|
+
var renderComponent = function renderComponent(extras) {
|
|
17
|
+
var defaults = {
|
|
18
|
+
classes: {},
|
|
19
|
+
className: 'className',
|
|
20
|
+
graphProps: (0, _utils.graphProps)(),
|
|
21
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
22
|
+
categories: []
|
|
23
|
+
};
|
|
24
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
25
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
26
|
+
theme: theme
|
|
27
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes["default"], props))));
|
|
28
|
+
};
|
|
29
|
+
describe('rendering', function () {
|
|
30
|
+
it('renders axes container', function () {
|
|
31
|
+
var _renderComponent = renderComponent(),
|
|
32
|
+
container = _renderComponent.container;
|
|
33
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
34
|
+
});
|
|
35
|
+
it('renders SVG with axes group', function () {
|
|
36
|
+
var _renderComponent2 = renderComponent(),
|
|
37
|
+
container = _renderComponent2.container;
|
|
38
|
+
var svg = container.querySelector('svg');
|
|
39
|
+
expect(svg).toBeInTheDocument();
|
|
40
|
+
// Component renders StyledAxesGroup which is a <g> element
|
|
41
|
+
var axesGroup = container.querySelector('g');
|
|
42
|
+
expect(axesGroup).toBeInTheDocument();
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
describe('RawChartAxes', function () {
|
|
47
|
+
var renderComponent = function renderComponent(extras) {
|
|
48
|
+
var defaults = {
|
|
49
|
+
classes: {},
|
|
50
|
+
className: 'className',
|
|
51
|
+
graphProps: (0, _utils.graphProps)(),
|
|
52
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
53
|
+
categories: []
|
|
54
|
+
};
|
|
55
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
56
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
57
|
+
theme: theme
|
|
58
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes.RawChartAxes, props))));
|
|
59
|
+
};
|
|
60
|
+
describe('rendering', function () {
|
|
61
|
+
it('renders raw axes container', function () {
|
|
62
|
+
var _renderComponent3 = renderComponent(),
|
|
63
|
+
container = _renderComponent3.container;
|
|
64
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
65
|
+
});
|
|
66
|
+
it('renders SVG with axes group', function () {
|
|
67
|
+
var _renderComponent4 = renderComponent(),
|
|
68
|
+
container = _renderComponent4.container;
|
|
69
|
+
var svg = container.querySelector('svg');
|
|
70
|
+
expect(svg).toBeInTheDocument();
|
|
71
|
+
// Component renders StyledAxesGroup which is a <g> element
|
|
72
|
+
var axesGroup = container.querySelector('g');
|
|
73
|
+
expect(axesGroup).toBeInTheDocument();
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
describe('TickComponent', function () {
|
|
78
|
+
var renderComponent = function renderComponent(extras) {
|
|
79
|
+
var defaults = {
|
|
80
|
+
graphProps: (0, _utils.graphProps)(),
|
|
81
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
82
|
+
categories: [{
|
|
83
|
+
value: 1,
|
|
84
|
+
label: 'test',
|
|
85
|
+
editable: false,
|
|
86
|
+
interactive: false
|
|
87
|
+
}],
|
|
88
|
+
formattedValue: '0-test',
|
|
89
|
+
bandWidth: 100,
|
|
90
|
+
barWidth: 100,
|
|
91
|
+
x: 50,
|
|
92
|
+
y: 50
|
|
93
|
+
};
|
|
94
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
95
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
96
|
+
theme: theme
|
|
97
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes.TickComponent, props))));
|
|
98
|
+
};
|
|
99
|
+
describe('rendering', function () {
|
|
100
|
+
it('renders tick component', function () {
|
|
101
|
+
var _renderComponent5 = renderComponent(),
|
|
102
|
+
container = _renderComponent5.container;
|
|
103
|
+
var svg = container.querySelector('svg');
|
|
104
|
+
expect(svg).toBeInTheDocument();
|
|
105
|
+
// TickComponent renders a <g> element
|
|
106
|
+
expect(container.querySelector('g')).toBeInTheDocument();
|
|
107
|
+
});
|
|
108
|
+
it('renders with categories', function () {
|
|
109
|
+
var _renderComponent6 = renderComponent({
|
|
110
|
+
formattedValue: '0-test',
|
|
111
|
+
categories: [{
|
|
112
|
+
value: 1,
|
|
113
|
+
label: 'test',
|
|
114
|
+
editable: false,
|
|
115
|
+
interactive: false
|
|
116
|
+
}]
|
|
117
|
+
}),
|
|
118
|
+
container = _renderComponent6.container;
|
|
119
|
+
var svg = container.querySelector('svg');
|
|
120
|
+
expect(svg).toBeInTheDocument();
|
|
121
|
+
expect(container.querySelector('g')).toBeInTheDocument();
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
// Note: splitText and changeCategory are internal implementation details.
|
|
126
|
+
// In RTL philosophy, we test user-visible behavior rather than implementation.
|
|
127
|
+
// These methods would be tested indirectly through their effects on the rendered output.
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_testUtils","_styles","_axes","_interopRequireWildcard","_utils","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","theme","createTheme","describe","renderComponent","extras","defaults","classes","className","graphProps","xBand","createBandScale","categories","props","render","createElement","ThemeProvider","it","_renderComponent","container","expect","firstChild","toBeInTheDocument","_renderComponent2","svg","querySelector","axesGroup","RawChartAxes","_renderComponent3","_renderComponent4","value","label","editable","interactive","formattedValue","bandWidth","barWidth","x","y","TickComponent","_renderComponent5","_renderComponent6"],"sources":["../../src/__tests__/axes.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render } from '@pie-lib/test-utils';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport ChartAxes, { TickComponent, RawChartAxes } from '../axes';\nimport { graphProps, createBandScale } from './utils';\n\nconst theme = createTheme();\n\ndescribe('ChartAxes', () => {\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      className: 'className',\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n      categories: [],\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <svg>\n          <ChartAxes {...props} />\n        </svg>\n      </ThemeProvider>\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders axes container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders SVG with axes group', () => {\n      const { container} = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      // Component renders StyledAxesGroup which is a <g> element\n      const axesGroup = container.querySelector('g');\n      expect(axesGroup).toBeInTheDocument();\n    });\n  });\n});\n\ndescribe('RawChartAxes', () => {\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      className: 'className',\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n      categories: [],\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <svg>\n          <RawChartAxes {...props} />\n        </svg>\n      </ThemeProvider>\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders raw axes container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders SVG with axes group', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      // Component renders StyledAxesGroup which is a <g> element\n      const axesGroup = container.querySelector('g');\n      expect(axesGroup).toBeInTheDocument();\n    });\n  });\n});\n\ndescribe('TickComponent', () => {\n  const renderComponent = (extras) => {\n    const defaults = {\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n      categories: [{ value: 1, label: 'test', editable: false, interactive: false }],\n      formattedValue: '0-test',\n      bandWidth: 100,\n      barWidth: 100,\n      x: 50,\n      y: 50,\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <svg>\n          <TickComponent {...props} />\n        </svg>\n      </ThemeProvider>\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders tick component', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      // TickComponent renders a <g> element\n      expect(container.querySelector('g')).toBeInTheDocument();\n    });\n\n    it('renders with categories', () => {\n      const { container } = renderComponent({\n        formattedValue: '0-test',\n        categories: [{ value: 1, label: 'test', editable: false, interactive: false }],\n      });\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      expect(container.querySelector('g')).toBeInTheDocument();\n    });\n  });\n\n  // Note: splitText and changeCategory are internal implementation details.\n  // In RTL philosophy, we test user-visible behavior rather than implementation.\n  // These methods would be tested indirectly through their effects on the rendered output.\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _chartSetup = require("../chart-setup");
|
|
4
|
+
describe('resetValues', function () {
|
|
5
|
+
var data;
|
|
6
|
+
var range;
|
|
7
|
+
var model;
|
|
8
|
+
var onChange;
|
|
9
|
+
beforeEach(function () {
|
|
10
|
+
range = {
|
|
11
|
+
min: 0,
|
|
12
|
+
max: 10,
|
|
13
|
+
step: 1
|
|
14
|
+
};
|
|
15
|
+
data = [{
|
|
16
|
+
value: 2
|
|
17
|
+
}, {
|
|
18
|
+
value: 11
|
|
19
|
+
}, {
|
|
20
|
+
value: 5.5
|
|
21
|
+
}, {
|
|
22
|
+
value: 2.0000000001
|
|
23
|
+
},
|
|
24
|
+
// A float close to an integer
|
|
25
|
+
{
|
|
26
|
+
value: 2.9999999999
|
|
27
|
+
} // Another float close to an integer
|
|
28
|
+
];
|
|
29
|
+
model = {
|
|
30
|
+
someField: 'someValue',
|
|
31
|
+
data: data
|
|
32
|
+
};
|
|
33
|
+
onChange = jest.fn();
|
|
34
|
+
});
|
|
35
|
+
it('should reset values greater than range.max to zero', function () {
|
|
36
|
+
(0, _chartSetup.resetValues)(data, true, range, onChange, model);
|
|
37
|
+
expect(data[1].value).toBe(0);
|
|
38
|
+
});
|
|
39
|
+
it('should reset values that are not multiples of range.step to zero', function () {
|
|
40
|
+
(0, _chartSetup.resetValues)(data, true, range, onChange, model);
|
|
41
|
+
expect(data[2].value).toBe(0);
|
|
42
|
+
});
|
|
43
|
+
it('should not reset values that are within range and multiples of range.step', function () {
|
|
44
|
+
(0, _chartSetup.resetValues)(data, true, range, onChange, model);
|
|
45
|
+
expect(data[0].value).toBe(2);
|
|
46
|
+
});
|
|
47
|
+
it('should not reset floating point values that are close to multiples of range.step', function () {
|
|
48
|
+
(0, _chartSetup.resetValues)(data, true, range, onChange, model);
|
|
49
|
+
expect(data[3].value).toBe(2.0000000001); // remains unchanged
|
|
50
|
+
expect(data[4].value).toBe(2.9999999999); // remains unchanged
|
|
51
|
+
});
|
|
52
|
+
it('should not call onChange when updateModel is false', function () {
|
|
53
|
+
(0, _chartSetup.resetValues)(data, false, range, onChange, model);
|
|
54
|
+
expect(onChange).not.toHaveBeenCalled();
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY2hhcnRTZXR1cCIsInJlcXVpcmUiLCJkZXNjcmliZSIsImRhdGEiLCJyYW5nZSIsIm1vZGVsIiwib25DaGFuZ2UiLCJiZWZvcmVFYWNoIiwibWluIiwibWF4Iiwic3RlcCIsInZhbHVlIiwic29tZUZpZWxkIiwiamVzdCIsImZuIiwiaXQiLCJyZXNldFZhbHVlcyIsImV4cGVjdCIsInRvQmUiLCJub3QiLCJ0b0hhdmVCZWVuQ2FsbGVkIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL19fdGVzdHNfXy9jaGFydC1zZXR1cC50ZXN0LmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByZXNldFZhbHVlcyB9IGZyb20gJy4uL2NoYXJ0LXNldHVwJztcblxuZGVzY3JpYmUoJ3Jlc2V0VmFsdWVzJywgKCkgPT4ge1xuICBsZXQgZGF0YTtcbiAgbGV0IHJhbmdlO1xuICBsZXQgbW9kZWw7XG4gIGxldCBvbkNoYW5nZTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICByYW5nZSA9IHsgbWluOiAwLCBtYXg6IDEwLCBzdGVwOiAxIH07XG4gICAgZGF0YSA9IFtcbiAgICAgIHsgdmFsdWU6IDIgfSxcbiAgICAgIHsgdmFsdWU6IDExIH0sXG4gICAgICB7IHZhbHVlOiA1LjUgfSxcbiAgICAgIHsgdmFsdWU6IDIuMDAwMDAwMDAwMSB9LCAvLyBBIGZsb2F0IGNsb3NlIHRvIGFuIGludGVnZXJcbiAgICAgIHsgdmFsdWU6IDIuOTk5OTk5OTk5OSB9LCAvLyBBbm90aGVyIGZsb2F0IGNsb3NlIHRvIGFuIGludGVnZXJcbiAgICBdO1xuICAgIG1vZGVsID0geyBzb21lRmllbGQ6ICdzb21lVmFsdWUnLCBkYXRhIH07XG4gICAgb25DaGFuZ2UgPSBqZXN0LmZuKCk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgcmVzZXQgdmFsdWVzIGdyZWF0ZXIgdGhhbiByYW5nZS5tYXggdG8gemVybycsICgpID0+IHtcbiAgICByZXNldFZhbHVlcyhkYXRhLCB0cnVlLCByYW5nZSwgb25DaGFuZ2UsIG1vZGVsKTtcbiAgICBleHBlY3QoZGF0YVsxXS52YWx1ZSkudG9CZSgwKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCByZXNldCB2YWx1ZXMgdGhhdCBhcmUgbm90IG11bHRpcGxlcyBvZiByYW5nZS5zdGVwIHRvIHplcm8nLCAoKSA9PiB7XG4gICAgcmVzZXRWYWx1ZXMoZGF0YSwgdHJ1ZSwgcmFuZ2UsIG9uQ2hhbmdlLCBtb2RlbCk7XG4gICAgZXhwZWN0KGRhdGFbMl0udmFsdWUpLnRvQmUoMCk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgbm90IHJlc2V0IHZhbHVlcyB0aGF0IGFyZSB3aXRoaW4gcmFuZ2UgYW5kIG11bHRpcGxlcyBvZiByYW5nZS5zdGVwJywgKCkgPT4ge1xuICAgIHJlc2V0VmFsdWVzKGRhdGEsIHRydWUsIHJhbmdlLCBvbkNoYW5nZSwgbW9kZWwpO1xuICAgIGV4cGVjdChkYXRhWzBdLnZhbHVlKS50b0JlKDIpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIG5vdCByZXNldCBmbG9hdGluZyBwb2ludCB2YWx1ZXMgdGhhdCBhcmUgY2xvc2UgdG8gbXVsdGlwbGVzIG9mIHJhbmdlLnN0ZXAnLCAoKSA9PiB7XG4gICAgcmVzZXRWYWx1ZXMoZGF0YSwgdHJ1ZSwgcmFuZ2UsIG9uQ2hhbmdlLCBtb2RlbCk7XG4gICAgZXhwZWN0KGRhdGFbM10udmFsdWUpLnRvQmUoMi4wMDAwMDAwMDAxKTsgLy8gcmVtYWlucyB1bmNoYW5nZWRcbiAgICBleHBlY3QoZGF0YVs0XS52YWx1ZSkudG9CZSgyLjk5OTk5OTk5OTkpOyAvLyByZW1haW5zIHVuY2hhbmdlZFxuICB9KTtcblxuICBpdCgnc2hvdWxkIG5vdCBjYWxsIG9uQ2hhbmdlIHdoZW4gdXBkYXRlTW9kZWwgaXMgZmFsc2UnLCAoKSA9PiB7XG4gICAgcmVzZXRWYWx1ZXMoZGF0YSwgZmFsc2UsIHJhbmdlLCBvbkNoYW5nZSwgbW9kZWwpO1xuICAgIGV4cGVjdChvbkNoYW5nZSkubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxXQUFBLEdBQUFDLE9BQUE7QUFFQUMsUUFBUSxDQUFDLGFBQWEsRUFBRSxZQUFNO0VBQzVCLElBQUlDLElBQUk7RUFDUixJQUFJQyxLQUFLO0VBQ1QsSUFBSUMsS0FBSztFQUNULElBQUlDLFFBQVE7RUFFWkMsVUFBVSxDQUFDLFlBQU07SUFDZkgsS0FBSyxHQUFHO01BQUVJLEdBQUcsRUFBRSxDQUFDO01BQUVDLEdBQUcsRUFBRSxFQUFFO01BQUVDLElBQUksRUFBRTtJQUFFLENBQUM7SUFDcENQLElBQUksR0FBRyxDQUNMO01BQUVRLEtBQUssRUFBRTtJQUFFLENBQUMsRUFDWjtNQUFFQSxLQUFLLEVBQUU7SUFBRyxDQUFDLEVBQ2I7TUFBRUEsS0FBSyxFQUFFO0lBQUksQ0FBQyxFQUNkO01BQUVBLEtBQUssRUFBRTtJQUFhLENBQUM7SUFBRTtJQUN6QjtNQUFFQSxLQUFLLEVBQUU7SUFBYSxDQUFDLENBQUU7SUFBQSxDQUMxQjtJQUNETixLQUFLLEdBQUc7TUFBRU8sU0FBUyxFQUFFLFdBQVc7TUFBRVQsSUFBSSxFQUFKQTtJQUFLLENBQUM7SUFDeENHLFFBQVEsR0FBR08sSUFBSSxDQUFDQyxFQUFFLENBQUMsQ0FBQztFQUN0QixDQUFDLENBQUM7RUFFRkMsRUFBRSxDQUFDLG9EQUFvRCxFQUFFLFlBQU07SUFDN0QsSUFBQUMsdUJBQVcsRUFBQ2IsSUFBSSxFQUFFLElBQUksRUFBRUMsS0FBSyxFQUFFRSxRQUFRLEVBQUVELEtBQUssQ0FBQztJQUMvQ1ksTUFBTSxDQUFDZCxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUNRLEtBQUssQ0FBQyxDQUFDTyxJQUFJLENBQUMsQ0FBQyxDQUFDO0VBQy9CLENBQUMsQ0FBQztFQUVGSCxFQUFFLENBQUMsa0VBQWtFLEVBQUUsWUFBTTtJQUMzRSxJQUFBQyx1QkFBVyxFQUFDYixJQUFJLEVBQUUsSUFBSSxFQUFFQyxLQUFLLEVBQUVFLFFBQVEsRUFBRUQsS0FBSyxDQUFDO0lBQy9DWSxNQUFNLENBQUNkLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQ1EsS0FBSyxDQUFDLENBQUNPLElBQUksQ0FBQyxDQUFDLENBQUM7RUFDL0IsQ0FBQyxDQUFDO0VBRUZILEVBQUUsQ0FBQywyRUFBMkUsRUFBRSxZQUFNO0lBQ3BGLElBQUFDLHVCQUFXLEVBQUNiLElBQUksRUFBRSxJQUFJLEVBQUVDLEtBQUssRUFBRUUsUUFBUSxFQUFFRCxLQUFLLENBQUM7SUFDL0NZLE1BQU0sQ0FBQ2QsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDUSxLQUFLLENBQUMsQ0FBQ08sSUFBSSxDQUFDLENBQUMsQ0FBQztFQUMvQixDQUFDLENBQUM7RUFFRkgsRUFBRSxDQUFDLGtGQUFrRixFQUFFLFlBQU07SUFDM0YsSUFBQUMsdUJBQVcsRUFBQ2IsSUFBSSxFQUFFLElBQUksRUFBRUMsS0FBSyxFQUFFRSxRQUFRLEVBQUVELEtBQUssQ0FBQztJQUMvQ1ksTUFBTSxDQUFDZCxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUNRLEtBQUssQ0FBQyxDQUFDTyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQztJQUMxQ0QsTUFBTSxDQUFDZCxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUNRLEtBQUssQ0FBQyxDQUFDTyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQztFQUM1QyxDQUFDLENBQUM7RUFFRkgsRUFBRSxDQUFDLG9EQUFvRCxFQUFFLFlBQU07SUFDN0QsSUFBQUMsdUJBQVcsRUFBQ2IsSUFBSSxFQUFFLEtBQUssRUFBRUMsS0FBSyxFQUFFRSxRQUFRLEVBQUVELEtBQUssQ0FBQztJQUNoRFksTUFBTSxDQUFDWCxRQUFRLENBQUMsQ0FBQ2EsR0FBRyxDQUFDQyxnQkFBZ0IsQ0FBQyxDQUFDO0VBQ3pDLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
6
|
+
var _chartType = _interopRequireDefault(require("../chart-type"));
|
|
7
|
+
describe('ChartType', function () {
|
|
8
|
+
var props;
|
|
9
|
+
var onChange = jest.fn();
|
|
10
|
+
beforeEach(function () {
|
|
11
|
+
props = {
|
|
12
|
+
classes: {},
|
|
13
|
+
value: 'bar',
|
|
14
|
+
onChange: onChange
|
|
15
|
+
};
|
|
16
|
+
});
|
|
17
|
+
describe('rendering', function () {
|
|
18
|
+
it('renders chart type selector', function () {
|
|
19
|
+
var _render = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_chartType["default"], props)),
|
|
20
|
+
container = _render.container;
|
|
21
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl90ZXN0VXRpbHMiLCJfY2hhcnRUeXBlIiwiZGVzY3JpYmUiLCJwcm9wcyIsIm9uQ2hhbmdlIiwiamVzdCIsImZuIiwiYmVmb3JlRWFjaCIsImNsYXNzZXMiLCJ2YWx1ZSIsIml0IiwiX3JlbmRlciIsInJlbmRlciIsImNyZWF0ZUVsZW1lbnQiLCJjb250YWluZXIiLCJleHBlY3QiLCJmaXJzdENoaWxkIiwidG9CZUluVGhlRG9jdW1lbnQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvX190ZXN0c19fL2NoYXJ0LXR5cGUudGVzdC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHJlbmRlciB9IGZyb20gJ0BwaWUtbGliL3Rlc3QtdXRpbHMnO1xuaW1wb3J0IENoYXJ0VHlwZSBmcm9tICcuLi9jaGFydC10eXBlJztcblxuZGVzY3JpYmUoJ0NoYXJ0VHlwZScsICgpID0+IHtcbiAgbGV0IHByb3BzO1xuICBjb25zdCBvbkNoYW5nZSA9IGplc3QuZm4oKTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICBwcm9wcyA9IHtcbiAgICAgIGNsYXNzZXM6IHt9LFxuICAgICAgdmFsdWU6ICdiYXInLFxuICAgICAgb25DaGFuZ2UsXG4gICAgfTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3JlbmRlcmluZycsICgpID0+IHtcbiAgICBpdCgncmVuZGVycyBjaGFydCB0eXBlIHNlbGVjdG9yJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlcig8Q2hhcnRUeXBlIHsuLi5wcm9wc30gLz4pO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lci5maXJzdENoaWxkKS50b0JlSW5UaGVEb2N1bWVudCgpO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOzs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxVQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxVQUFBLEdBQUFILHNCQUFBLENBQUFDLE9BQUE7QUFFQUcsUUFBUSxDQUFDLFdBQVcsRUFBRSxZQUFNO0VBQzFCLElBQUlDLEtBQUs7RUFDVCxJQUFNQyxRQUFRLEdBQUdDLElBQUksQ0FBQ0MsRUFBRSxDQUFDLENBQUM7RUFFMUJDLFVBQVUsQ0FBQyxZQUFNO0lBQ2ZKLEtBQUssR0FBRztNQUNOSyxPQUFPLEVBQUUsQ0FBQyxDQUFDO01BQ1hDLEtBQUssRUFBRSxLQUFLO01BQ1pMLFFBQVEsRUFBUkE7SUFDRixDQUFDO0VBQ0gsQ0FBQyxDQUFDO0VBRUZGLFFBQVEsQ0FBQyxXQUFXLEVBQUUsWUFBTTtJQUMxQlEsRUFBRSxDQUFDLDZCQUE2QixFQUFFLFlBQU07TUFDdEMsSUFBQUMsT0FBQSxHQUFzQixJQUFBQyxpQkFBTSxlQUFDZixNQUFBLFlBQUFnQixhQUFBLENBQUNaLFVBQUEsV0FBUyxFQUFLRSxLQUFRLENBQUMsQ0FBQztRQUE5Q1csU0FBUyxHQUFBSCxPQUFBLENBQVRHLFNBQVM7TUFDakJDLE1BQU0sQ0FBQ0QsU0FBUyxDQUFDRSxVQUFVLENBQUMsQ0FBQ0MsaUJBQWlCLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
7
|
+
var _chart = require("../chart");
|
|
8
|
+
var _utils = require("./utils");
|
|
9
|
+
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; }
|
|
10
|
+
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; }
|
|
11
|
+
describe('ChartAxes', function () {
|
|
12
|
+
var onDataChange = jest.fn();
|
|
13
|
+
var renderComponent = function renderComponent(extras) {
|
|
14
|
+
var defaults = {
|
|
15
|
+
classes: {},
|
|
16
|
+
onDataChange: onDataChange,
|
|
17
|
+
className: 'className',
|
|
18
|
+
graphProps: (0, _utils.graphProps)(),
|
|
19
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 100]),
|
|
20
|
+
charts: [{
|
|
21
|
+
type: 'bar',
|
|
22
|
+
Component: function Component() {
|
|
23
|
+
return /*#__PURE__*/_react["default"].createElement("div", null);
|
|
24
|
+
}
|
|
25
|
+
}],
|
|
26
|
+
chartType: 'bar',
|
|
27
|
+
domain: {},
|
|
28
|
+
range: {
|
|
29
|
+
min: 0,
|
|
30
|
+
max: 10
|
|
31
|
+
},
|
|
32
|
+
size: {
|
|
33
|
+
width: 100,
|
|
34
|
+
height: 100
|
|
35
|
+
},
|
|
36
|
+
data: []
|
|
37
|
+
};
|
|
38
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
39
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_chart.Chart, props));
|
|
40
|
+
};
|
|
41
|
+
describe('rendering', function () {
|
|
42
|
+
it('renders chart container', function () {
|
|
43
|
+
var _renderComponent = renderComponent(),
|
|
44
|
+
container = _renderComponent.container;
|
|
45
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
46
|
+
expect(container.querySelector('svg')).toBeInTheDocument();
|
|
47
|
+
});
|
|
48
|
+
it('renders chart with default size', function () {
|
|
49
|
+
var _renderComponent2 = renderComponent(),
|
|
50
|
+
container = _renderComponent2.container;
|
|
51
|
+
var svg = container.querySelector('svg');
|
|
52
|
+
expect(svg).toBeInTheDocument();
|
|
53
|
+
expect(svg).toHaveAttribute('width', '240');
|
|
54
|
+
expect(svg).toHaveAttribute('height', '240');
|
|
55
|
+
});
|
|
56
|
+
it('renders chart when size is not defined', function () {
|
|
57
|
+
var _renderComponent3 = renderComponent({
|
|
58
|
+
size: undefined
|
|
59
|
+
}),
|
|
60
|
+
container = _renderComponent3.container;
|
|
61
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
62
|
+
var svg = container.querySelector('svg');
|
|
63
|
+
expect(svg).toBeInTheDocument();
|
|
64
|
+
});
|
|
65
|
+
it('renders chart without chartType property', function () {
|
|
66
|
+
var _renderComponent4 = renderComponent({
|
|
67
|
+
chartType: null
|
|
68
|
+
}),
|
|
69
|
+
container = _renderComponent4.container;
|
|
70
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
71
|
+
expect(container.querySelector('svg')).toBeInTheDocument();
|
|
72
|
+
});
|
|
73
|
+
it('renders chart without chartType and charts properties', function () {
|
|
74
|
+
var _renderComponent5 = renderComponent({
|
|
75
|
+
chartType: null,
|
|
76
|
+
charts: null
|
|
77
|
+
}),
|
|
78
|
+
container = _renderComponent5.container;
|
|
79
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
80
|
+
});
|
|
81
|
+
it('renders chart without chartType property and empty charts property', function () {
|
|
82
|
+
var _renderComponent6 = renderComponent({
|
|
83
|
+
chartType: null,
|
|
84
|
+
charts: []
|
|
85
|
+
}),
|
|
86
|
+
container = _renderComponent6.container;
|
|
87
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
88
|
+
});
|
|
89
|
+
it('renders chart with chartType property and empty charts property', function () {
|
|
90
|
+
var _renderComponent7 = renderComponent({
|
|
91
|
+
charts: []
|
|
92
|
+
}),
|
|
93
|
+
container = _renderComponent7.container;
|
|
94
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
95
|
+
expect(container.querySelector('svg')).toBeInTheDocument();
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
// Note: changeData, getChart, and deleteCategory are internal implementation details.
|
|
100
|
+
// In RTL philosophy, we test user-visible behavior rather than implementation.
|
|
101
|
+
// These methods would be tested indirectly through user interactions that trigger them.
|
|
102
|
+
});
|
|
103
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_testUtils","_chart","_utils","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","describe","onDataChange","jest","fn","renderComponent","extras","defaults","classes","className","graphProps","xBand","createBandScale","charts","type","Component","createElement","chartType","domain","range","min","max","size","width","height","data","props","render","Chart","it","_renderComponent","container","expect","firstChild","toBeInTheDocument","querySelector","_renderComponent2","svg","toHaveAttribute","_renderComponent3","undefined","_renderComponent4","_renderComponent5","_renderComponent6","_renderComponent7"],"sources":["../../src/__tests__/chart.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render } from '@pie-lib/test-utils';\nimport { Chart } from '../chart';\nimport { graphProps, createBandScale } from './utils';\n\ndescribe('ChartAxes', () => {\n  let onDataChange = jest.fn();\n\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      onDataChange,\n      className: 'className',\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 100]),\n      charts: [\n        {\n          type: 'bar',\n          Component: () => <div />,\n        },\n      ],\n      chartType: 'bar',\n      domain: {},\n      range: {\n        min: 0,\n        max: 10,\n      },\n      size: {\n        width: 100,\n        height: 100,\n      },\n      data: [],\n    };\n    const props = { ...defaults, ...extras };\n    return render(<Chart {...props} />);\n  };\n\n  describe('rendering', () => {\n    it('renders chart container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n      expect(container.querySelector('svg')).toBeInTheDocument();\n    });\n\n    it('renders chart with default size', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      expect(svg).toHaveAttribute('width', '240');\n      expect(svg).toHaveAttribute('height', '240');\n    });\n\n    it('renders chart when size is not defined', () => {\n      const { container } = renderComponent({ size: undefined });\n      expect(container.firstChild).toBeInTheDocument();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n    });\n\n    it('renders chart without chartType property', () => {\n      const { container } = renderComponent({ chartType: null });\n      expect(container.firstChild).toBeInTheDocument();\n      expect(container.querySelector('svg')).toBeInTheDocument();\n    });\n\n    it('renders chart without chartType and charts properties', () => {\n      const { container } = renderComponent({ chartType: null, charts: null });\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders chart without chartType property and empty charts property', () => {\n      const { container } = renderComponent({ chartType: null, charts: [] });\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders chart with chartType property and empty charts property', () => {\n      const { container } = renderComponent({ charts: [] });\n      expect(container.firstChild).toBeInTheDocument();\n      expect(container.querySelector('svg')).toBeInTheDocument();\n    });\n  });\n\n  // Note: changeData, getChart, and deleteCategory are internal implementation details.\n  // In RTL philosophy, we test user-visible behavior rather than implementation.\n  // These methods would be tested indirectly through user interactions that trigger them.\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
7
|
+
var _grid = require("../grid");
|
|
8
|
+
var _utils = require("./utils");
|
|
9
|
+
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; }
|
|
10
|
+
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; }
|
|
11
|
+
describe('Grid', function () {
|
|
12
|
+
var renderComponent = function renderComponent(extras) {
|
|
13
|
+
var defaults = {
|
|
14
|
+
classes: {},
|
|
15
|
+
className: 'className',
|
|
16
|
+
graphProps: (0, _utils.graphProps)(),
|
|
17
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400])
|
|
18
|
+
};
|
|
19
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
20
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_grid.Grid, props)));
|
|
21
|
+
};
|
|
22
|
+
describe('rendering', function () {
|
|
23
|
+
it('renders grid container', function () {
|
|
24
|
+
var _renderComponent = renderComponent(),
|
|
25
|
+
container = _renderComponent.container;
|
|
26
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
27
|
+
});
|
|
28
|
+
it('renders grid with SVG group', function () {
|
|
29
|
+
var _renderComponent2 = renderComponent(),
|
|
30
|
+
container = _renderComponent2.container;
|
|
31
|
+
var svg = container.querySelector('svg');
|
|
32
|
+
expect(svg).toBeInTheDocument();
|
|
33
|
+
// Grid renders a <g> element (StyledGridGroup)
|
|
34
|
+
var gridGroup = container.querySelector('g');
|
|
35
|
+
expect(gridGroup).toBeInTheDocument();
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl90ZXN0VXRpbHMiLCJfZ3JpZCIsIl91dGlscyIsIm93bktleXMiLCJlIiwiciIsInQiLCJPYmplY3QiLCJrZXlzIiwiZ2V0T3duUHJvcGVydHlTeW1ib2xzIiwibyIsImZpbHRlciIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImVudW1lcmFibGUiLCJwdXNoIiwiYXBwbHkiLCJfb2JqZWN0U3ByZWFkIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwiZm9yRWFjaCIsIl9kZWZpbmVQcm9wZXJ0eTIiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzIiwiZGVmaW5lUHJvcGVydGllcyIsImRlZmluZVByb3BlcnR5IiwiZGVzY3JpYmUiLCJyZW5kZXJDb21wb25lbnQiLCJleHRyYXMiLCJkZWZhdWx0cyIsImNsYXNzZXMiLCJjbGFzc05hbWUiLCJncmFwaFByb3BzIiwieEJhbmQiLCJjcmVhdGVCYW5kU2NhbGUiLCJwcm9wcyIsInJlbmRlciIsImNyZWF0ZUVsZW1lbnQiLCJHcmlkIiwiaXQiLCJfcmVuZGVyQ29tcG9uZW50IiwiY29udGFpbmVyIiwiZXhwZWN0IiwiZmlyc3RDaGlsZCIsInRvQmVJblRoZURvY3VtZW50IiwiX3JlbmRlckNvbXBvbmVudDIiLCJzdmciLCJxdWVyeVNlbGVjdG9yIiwiZ3JpZEdyb3VwIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL19fdGVzdHNfXy9ncmlkLnRlc3QuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyByZW5kZXIgfSBmcm9tICdAcGllLWxpYi90ZXN0LXV0aWxzJztcbmltcG9ydCB7IEdyaWQgfSBmcm9tICcuLi9ncmlkJztcbmltcG9ydCB7IGdyYXBoUHJvcHMsIGNyZWF0ZUJhbmRTY2FsZSB9IGZyb20gJy4vdXRpbHMnO1xuXG5kZXNjcmliZSgnR3JpZCcsICgpID0+IHtcbiAgY29uc3QgcmVuZGVyQ29tcG9uZW50ID0gKGV4dHJhcykgPT4ge1xuICAgIGNvbnN0IGRlZmF1bHRzID0ge1xuICAgICAgY2xhc3Nlczoge30sXG4gICAgICBjbGFzc05hbWU6ICdjbGFzc05hbWUnLFxuICAgICAgZ3JhcGhQcm9wczogZ3JhcGhQcm9wcygpLFxuICAgICAgeEJhbmQ6IGNyZWF0ZUJhbmRTY2FsZShbJ2EnLCAnYicsICdjJ10sIFswLCA0MDBdKSxcbiAgICB9O1xuICAgIGNvbnN0IHByb3BzID0geyAuLi5kZWZhdWx0cywgLi4uZXh0cmFzIH07XG4gICAgcmV0dXJuIHJlbmRlcihcbiAgICAgIDxzdmc+XG4gICAgICAgIDxHcmlkIHsuLi5wcm9wc30gLz5cbiAgICAgIDwvc3ZnPlxuICAgICk7XG4gIH07XG5cbiAgZGVzY3JpYmUoJ3JlbmRlcmluZycsICgpID0+IHtcbiAgICBpdCgncmVuZGVycyBncmlkIGNvbnRhaW5lcicsICgpID0+IHtcbiAgICAgIGNvbnN0IHsgY29udGFpbmVyIH0gPSByZW5kZXJDb21wb25lbnQoKTtcbiAgICAgIGV4cGVjdChjb250YWluZXIuZmlyc3RDaGlsZCkudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIGdyaWQgd2l0aCBTVkcgZ3JvdXAnLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyQ29tcG9uZW50KCk7XG4gICAgICBjb25zdCBzdmcgPSBjb250YWluZXIucXVlcnlTZWxlY3Rvcignc3ZnJyk7XG4gICAgICBleHBlY3Qoc3ZnKS50b0JlSW5UaGVEb2N1bWVudCgpO1xuICAgICAgLy8gR3JpZCByZW5kZXJzIGEgPGc+IGVsZW1lbnQgKFN0eWxlZEdyaWRHcm91cClcbiAgICAgIGNvbnN0IGdyaWRHcm91cCA9IGNvbnRhaW5lci5xdWVyeVNlbGVjdG9yKCdnJyk7XG4gICAgICBleHBlY3QoZ3JpZEdyb3VwKS50b0JlSW5UaGVEb2N1bWVudCgpO1xuICAgIH0pO1xuICB9KTtc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
|