@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/lib/axes.js
CHANGED
|
@@ -1,92 +1,109 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = exports.TickComponent = exports.RawChartAxes = void 0;
|
|
9
|
-
|
|
10
8
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
11
|
-
|
|
12
9
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
13
|
-
|
|
14
10
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
15
|
-
|
|
16
|
-
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
17
|
-
|
|
18
|
-
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
19
|
-
|
|
20
11
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
21
|
-
|
|
22
12
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
23
|
-
|
|
13
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
24
14
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
25
|
-
|
|
26
15
|
var _react = _interopRequireDefault(require("react"));
|
|
27
|
-
|
|
28
16
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
29
|
-
|
|
30
|
-
var
|
|
31
|
-
|
|
32
|
-
var _axis = require("@vx/axis");
|
|
33
|
-
|
|
34
|
-
var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
|
|
35
|
-
|
|
17
|
+
var _styles = require("@mui/material/styles");
|
|
18
|
+
var _axis = require("@visx/axis");
|
|
19
|
+
var _Checkbox = _interopRequireDefault(require("@mui/material/Checkbox"));
|
|
36
20
|
var _plot = require("@pie-lib/plot");
|
|
37
|
-
|
|
38
21
|
var _renderUi = require("@pie-lib/render-ui");
|
|
39
|
-
|
|
40
22
|
var _configUi = require("@pie-lib/config-ui");
|
|
41
|
-
|
|
42
23
|
var _mathRendering = require("@pie-lib/math-rendering");
|
|
43
|
-
|
|
44
24
|
var _correctnessIndicators = require("./common/correctness-indicators");
|
|
45
|
-
|
|
46
25
|
var _utils = require("./utils");
|
|
47
|
-
|
|
48
26
|
var _markLabel = _interopRequireDefault(require("./mark-label"));
|
|
49
|
-
|
|
50
|
-
function
|
|
51
|
-
|
|
52
|
-
function
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
27
|
+
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; }
|
|
28
|
+
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; }
|
|
29
|
+
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
|
|
30
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
31
|
+
var StyledErrorText = (0, _styles.styled)('text')(function (_ref) {
|
|
32
|
+
var theme = _ref.theme;
|
|
33
|
+
return {
|
|
34
|
+
fontSize: theme.typography.fontSize - 2,
|
|
35
|
+
fill: theme.palette.error.main
|
|
36
|
+
};
|
|
37
|
+
});
|
|
38
|
+
var StyledCheckbox = (0, _styles.styled)(_Checkbox["default"])(function () {
|
|
39
|
+
return {
|
|
40
|
+
color: "".concat(_renderUi.color.tertiary(), " !important")
|
|
41
|
+
};
|
|
42
|
+
});
|
|
43
|
+
var StyledAxesGroup = (0, _styles.styled)('g')(function (_ref2) {
|
|
44
|
+
var _theme$typography$bod;
|
|
45
|
+
var theme = _ref2.theme;
|
|
46
|
+
return {
|
|
47
|
+
'& .vx-axis-line': {
|
|
48
|
+
stroke: _renderUi.color.visualElementsColors.AXIS_LINE_COLOR,
|
|
49
|
+
strokeWidth: 2
|
|
50
|
+
},
|
|
51
|
+
'& .vx-axis-tick': {
|
|
52
|
+
fill: _renderUi.color.visualElementsColors.AXIS_TICK_COLOR,
|
|
53
|
+
'& line': {
|
|
54
|
+
stroke: _renderUi.color.visualElementsColors.AXIS_TICK_COLOR,
|
|
55
|
+
strokeWidth: 2
|
|
56
|
+
},
|
|
57
|
+
fontFamily: (_theme$typography$bod = theme.typography.body1) === null || _theme$typography$bod === void 0 ? void 0 : _theme$typography$bod.fontFamily,
|
|
58
|
+
fontSize: theme.typography.fontSize,
|
|
59
|
+
textAnchor: 'middle'
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
});
|
|
63
|
+
var correctnessIconStyles = function correctnessIconStyles(theme) {
|
|
64
|
+
return {
|
|
65
|
+
borderRadius: theme.spacing(2),
|
|
66
|
+
color: _renderUi.color.defaults.WHITE,
|
|
67
|
+
fontSize: '16px',
|
|
68
|
+
width: '16px',
|
|
69
|
+
height: '16px',
|
|
70
|
+
padding: '2px',
|
|
71
|
+
border: "1px solid ".concat(_renderUi.color.defaults.WHITE),
|
|
72
|
+
boxSizing: 'unset' // to override the default border-box in IBX
|
|
73
|
+
};
|
|
74
|
+
};
|
|
75
|
+
var incorrectIconStyles = {
|
|
76
|
+
backgroundColor: _renderUi.color.incorrectWithIcon()
|
|
77
|
+
};
|
|
78
|
+
var correctIconStyles = {
|
|
79
|
+
backgroundColor: _renderUi.color.correct()
|
|
80
|
+
};
|
|
81
|
+
var TickComponent = exports.TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
63
82
|
function TickComponent(props) {
|
|
64
83
|
var _this;
|
|
65
|
-
|
|
66
84
|
(0, _classCallCheck2["default"])(this, TickComponent);
|
|
67
|
-
_this =
|
|
68
|
-
(0, _defineProperty2["default"])(
|
|
85
|
+
_this = _callSuper(this, TickComponent, [props]);
|
|
86
|
+
(0, _defineProperty2["default"])(_this, "handleAlertDialog", function (open, callback) {
|
|
69
87
|
return _this.setState({
|
|
70
88
|
dialog: {
|
|
71
89
|
open: open
|
|
72
90
|
}
|
|
73
91
|
}, callback);
|
|
74
92
|
});
|
|
75
|
-
(0, _defineProperty2["default"])(
|
|
93
|
+
(0, _defineProperty2["default"])(_this, "changeCategory", function (index, newLabel) {
|
|
76
94
|
var _this$props = _this.props,
|
|
77
|
-
|
|
78
|
-
|
|
95
|
+
categories = _this$props.categories,
|
|
96
|
+
onChangeCategory = _this$props.onChangeCategory;
|
|
79
97
|
var category = categories[index];
|
|
80
98
|
onChangeCategory(index, _objectSpread(_objectSpread({}, category), {}, {
|
|
81
99
|
label: newLabel
|
|
82
100
|
}));
|
|
83
101
|
});
|
|
84
|
-
(0, _defineProperty2["default"])(
|
|
102
|
+
(0, _defineProperty2["default"])(_this, "changeInteractive", function (index, value) {
|
|
85
103
|
var _this$props2 = _this.props,
|
|
86
|
-
|
|
87
|
-
|
|
104
|
+
categories = _this$props2.categories,
|
|
105
|
+
onChangeCategory = _this$props2.onChangeCategory;
|
|
88
106
|
var category = categories[index];
|
|
89
|
-
|
|
90
107
|
if (!value) {
|
|
91
108
|
_this.setState({
|
|
92
109
|
dialog: {
|
|
@@ -109,12 +126,11 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
109
126
|
}));
|
|
110
127
|
}
|
|
111
128
|
});
|
|
112
|
-
(0, _defineProperty2["default"])(
|
|
129
|
+
(0, _defineProperty2["default"])(_this, "changeEditable", function (index, value) {
|
|
113
130
|
var _this$props3 = _this.props,
|
|
114
|
-
|
|
115
|
-
|
|
131
|
+
categories = _this$props3.categories,
|
|
132
|
+
onChangeCategory = _this$props3.onChangeCategory;
|
|
116
133
|
var category = categories[index];
|
|
117
|
-
|
|
118
134
|
if (!value) {
|
|
119
135
|
_this.setState({
|
|
120
136
|
dialog: {
|
|
@@ -137,26 +153,21 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
137
153
|
}));
|
|
138
154
|
}
|
|
139
155
|
});
|
|
140
|
-
(0, _defineProperty2["default"])(
|
|
156
|
+
(0, _defineProperty2["default"])(_this, "splitText", function (text, maxChar) {
|
|
141
157
|
var chunks = [];
|
|
142
|
-
|
|
143
158
|
while ((text || '').length > 0) {
|
|
144
159
|
var indexToSplit = void 0;
|
|
145
|
-
|
|
146
160
|
if (text.length > maxChar) {
|
|
147
161
|
indexToSplit = text.lastIndexOf(' ', maxChar);
|
|
148
|
-
|
|
149
162
|
if (indexToSplit === -1) {
|
|
150
163
|
indexToSplit = maxChar;
|
|
151
164
|
}
|
|
152
165
|
} else {
|
|
153
166
|
indexToSplit = text.length;
|
|
154
167
|
}
|
|
155
|
-
|
|
156
168
|
chunks.push(text.substring(0, indexToSplit));
|
|
157
169
|
text = text.substring(indexToSplit).trim();
|
|
158
170
|
}
|
|
159
|
-
|
|
160
171
|
return chunks;
|
|
161
172
|
});
|
|
162
173
|
_this.state = {
|
|
@@ -166,8 +177,8 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
166
177
|
};
|
|
167
178
|
return _this;
|
|
168
179
|
}
|
|
169
|
-
|
|
170
|
-
(0, _createClass2["default"])(TickComponent, [{
|
|
180
|
+
(0, _inherits2["default"])(TickComponent, _React$Component);
|
|
181
|
+
return (0, _createClass2["default"])(TickComponent, [{
|
|
171
182
|
key: "componentDidUpdate",
|
|
172
183
|
value: function componentDidUpdate(prevProps) {
|
|
173
184
|
if (this.props.autoFocus && !prevProps.autoFocus) {
|
|
@@ -178,47 +189,46 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
178
189
|
key: "render",
|
|
179
190
|
value: function render() {
|
|
180
191
|
var _this2 = this;
|
|
181
|
-
|
|
182
192
|
var _this$props4 = this.props,
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
showCorrectness = _this$props4.showCorrectness;
|
|
202
|
-
|
|
193
|
+
categories = _this$props4.categories,
|
|
194
|
+
xBand = _this$props4.xBand,
|
|
195
|
+
bandWidth = _this$props4.bandWidth,
|
|
196
|
+
barWidth = _this$props4.barWidth,
|
|
197
|
+
rotate = _this$props4.rotate,
|
|
198
|
+
top = _this$props4.top,
|
|
199
|
+
graphProps = _this$props4.graphProps,
|
|
200
|
+
defineChart = _this$props4.defineChart,
|
|
201
|
+
chartingOptions = _this$props4.chartingOptions,
|
|
202
|
+
x = _this$props4.x,
|
|
203
|
+
y = _this$props4.y,
|
|
204
|
+
formattedValue = _this$props4.formattedValue,
|
|
205
|
+
changeInteractiveEnabled = _this$props4.changeInteractiveEnabled,
|
|
206
|
+
changeEditableEnabled = _this$props4.changeEditableEnabled,
|
|
207
|
+
error = _this$props4.error,
|
|
208
|
+
autoFocus = _this$props4.autoFocus,
|
|
209
|
+
hiddenLabelRef = _this$props4.hiddenLabelRef,
|
|
210
|
+
showCorrectness = _this$props4.showCorrectness;
|
|
203
211
|
if (!formattedValue) {
|
|
204
212
|
return null;
|
|
205
213
|
}
|
|
206
214
|
|
|
215
|
+
// Create classes object for TickCorrectnessIndicator compatibility
|
|
216
|
+
var classes = {
|
|
217
|
+
correctnessIcon: correctnessIconStyles,
|
|
218
|
+
incorrectIcon: incorrectIconStyles,
|
|
219
|
+
correctIcon: correctIconStyles
|
|
220
|
+
};
|
|
207
221
|
var dialog = this.state.dialog;
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
changeInteractive = _ref.changeInteractive;
|
|
212
|
-
|
|
222
|
+
var _ref3 = chartingOptions || {},
|
|
223
|
+
changeEditable = _ref3.changeEditable,
|
|
224
|
+
changeInteractive = _ref3.changeInteractive;
|
|
213
225
|
var index = parseInt(formattedValue.split('-')[0], 10);
|
|
214
226
|
var category = categories[index];
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
correctness = _ref2.correctness;
|
|
221
|
-
|
|
227
|
+
var _ref4 = category || {},
|
|
228
|
+
editable = _ref4.editable,
|
|
229
|
+
interactive = _ref4.interactive,
|
|
230
|
+
label = _ref4.label,
|
|
231
|
+
correctness = _ref4.correctness;
|
|
222
232
|
var barX = xBand((0, _utils.bandKey)({
|
|
223
233
|
label: label
|
|
224
234
|
}, index));
|
|
@@ -226,6 +236,8 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
226
236
|
var lengthA = a && a.label ? a.label.length : 0;
|
|
227
237
|
var lengthB = b && b.label ? b.label.length : 0;
|
|
228
238
|
return lengthA > lengthB ? a : b;
|
|
239
|
+
}, {
|
|
240
|
+
label: ''
|
|
229
241
|
});
|
|
230
242
|
var distinctMessages = error ? (0, _toConsumableArray2["default"])(new Set(Object.values(error))).join(' ') : '';
|
|
231
243
|
return /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("foreignObject", {
|
|
@@ -265,8 +277,7 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
265
277
|
interactive: interactive,
|
|
266
278
|
classes: classes
|
|
267
279
|
})
|
|
268
|
-
})), error && index === 0 && /*#__PURE__*/_react["default"].createElement(
|
|
269
|
-
className: classes.error,
|
|
280
|
+
})), error && index === 0 && /*#__PURE__*/_react["default"].createElement(StyledErrorText, {
|
|
270
281
|
y: y + 23,
|
|
271
282
|
height: 6,
|
|
272
283
|
textAnchor: "start"
|
|
@@ -318,8 +329,7 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
318
329
|
pointerEvents: 'visible',
|
|
319
330
|
overflow: 'visible'
|
|
320
331
|
}
|
|
321
|
-
}, /*#__PURE__*/_react["default"].createElement(
|
|
322
|
-
className: classes.customColor,
|
|
332
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledCheckbox, {
|
|
323
333
|
style: {
|
|
324
334
|
position: 'fixed'
|
|
325
335
|
},
|
|
@@ -336,8 +346,7 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
336
346
|
pointerEvents: 'visible',
|
|
337
347
|
overflow: 'visible'
|
|
338
348
|
}
|
|
339
|
-
}, /*#__PURE__*/_react["default"].createElement(
|
|
340
|
-
className: classes.customColor,
|
|
349
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledCheckbox, {
|
|
341
350
|
style: {
|
|
342
351
|
position: 'fixed'
|
|
343
352
|
},
|
|
@@ -363,10 +372,7 @@ var TickComponent = /*#__PURE__*/function (_React$Component) {
|
|
|
363
372
|
})));
|
|
364
373
|
}
|
|
365
374
|
}]);
|
|
366
|
-
return TickComponent;
|
|
367
375
|
}(_react["default"].Component);
|
|
368
|
-
|
|
369
|
-
exports.TickComponent = TickComponent;
|
|
370
376
|
(0, _defineProperty2["default"])(TickComponent, "propTypes", {
|
|
371
377
|
defineChart: _propTypes["default"].bool,
|
|
372
378
|
error: _propTypes["default"].any
|
|
@@ -384,7 +390,6 @@ TickComponent.propTypes = {
|
|
|
384
390
|
formattedValue: _propTypes["default"].string,
|
|
385
391
|
onChangeCategory: _propTypes["default"].func,
|
|
386
392
|
onChange: _propTypes["default"].func,
|
|
387
|
-
classes: _propTypes["default"].object,
|
|
388
393
|
error: _propTypes["default"].object,
|
|
389
394
|
defineChart: _propTypes["default"].bool,
|
|
390
395
|
chartingOptions: _propTypes["default"].object,
|
|
@@ -392,47 +397,41 @@ TickComponent.propTypes = {
|
|
|
392
397
|
changeEditableEnabled: _propTypes["default"].bool,
|
|
393
398
|
autoFocus: _propTypes["default"].bool,
|
|
394
399
|
onAutoFocusUsed: _propTypes["default"].func,
|
|
395
|
-
showCorrectness: _propTypes["default"].bool
|
|
400
|
+
showCorrectness: _propTypes["default"].bool,
|
|
401
|
+
hiddenLabelRef: _propTypes["default"].oneOfType([_propTypes["default"].func, _propTypes["default"].shape({
|
|
402
|
+
current: _propTypes["default"].instanceOf(Element)
|
|
403
|
+
})])
|
|
396
404
|
};
|
|
397
|
-
|
|
398
|
-
var RawChartAxes = /*#__PURE__*/function (_React$Component2) {
|
|
399
|
-
(0, _inherits2["default"])(RawChartAxes, _React$Component2);
|
|
400
|
-
|
|
401
|
-
var _super2 = _createSuper(RawChartAxes);
|
|
402
|
-
|
|
405
|
+
var RawChartAxes = exports.RawChartAxes = /*#__PURE__*/function (_React$Component2) {
|
|
403
406
|
function RawChartAxes() {
|
|
404
407
|
var _this3;
|
|
405
|
-
|
|
406
408
|
(0, _classCallCheck2["default"])(this, RawChartAxes);
|
|
407
|
-
|
|
408
409
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
409
410
|
args[_key] = arguments[_key];
|
|
410
411
|
}
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this3), "state", {
|
|
412
|
+
_this3 = _callSuper(this, RawChartAxes, [].concat(args));
|
|
413
|
+
(0, _defineProperty2["default"])(_this3, "state", {
|
|
414
414
|
height: 0,
|
|
415
415
|
width: 0
|
|
416
416
|
});
|
|
417
417
|
return _this3;
|
|
418
418
|
}
|
|
419
|
-
|
|
420
|
-
(0, _createClass2["default"])(RawChartAxes, [{
|
|
419
|
+
(0, _inherits2["default"])(RawChartAxes, _React$Component2);
|
|
420
|
+
return (0, _createClass2["default"])(RawChartAxes, [{
|
|
421
421
|
key: "componentDidMount",
|
|
422
422
|
value: function componentDidMount() {
|
|
423
423
|
if (this.hiddenLabelRef) {
|
|
424
424
|
var boundingClientRect = this.hiddenLabelRef.getBoundingClientRect();
|
|
425
|
-
var hiddenEl = this.hiddenLabelRef
|
|
425
|
+
var hiddenEl = this.hiddenLabelRef;
|
|
426
426
|
|
|
427
|
+
// same logic used in dropdown.jsx for hidden labels width calculation
|
|
427
428
|
if (hiddenEl) {
|
|
428
429
|
var containsLatex = hiddenEl.querySelector('[data-latex], [data-raw]');
|
|
429
430
|
var hasMathJax = hiddenEl.querySelector('mjx-container');
|
|
430
431
|
var mathHandled = hiddenEl.querySelector('[data-math-handled="true"]');
|
|
431
|
-
|
|
432
432
|
if (containsLatex && (!mathHandled || !hasMathJax)) {
|
|
433
433
|
(0, _mathRendering.renderMath)(this.hiddenLabelRef);
|
|
434
434
|
}
|
|
435
|
-
|
|
436
435
|
this.setState({
|
|
437
436
|
height: Math.floor(boundingClientRect.height),
|
|
438
437
|
width: Math.floor(boundingClientRect.width)
|
|
@@ -442,10 +441,9 @@ var RawChartAxes = /*#__PURE__*/function (_React$Component2) {
|
|
|
442
441
|
}
|
|
443
442
|
}, {
|
|
444
443
|
key: "componentDidUpdate",
|
|
445
|
-
value: function componentDidUpdate(
|
|
444
|
+
value: function componentDidUpdate() {
|
|
446
445
|
if (this.hiddenLabelRef) {
|
|
447
446
|
var width = Math.floor(this.hiddenLabelRef.getBoundingClientRect().width);
|
|
448
|
-
|
|
449
447
|
if (width !== this.state.width) {
|
|
450
448
|
this.setState({
|
|
451
449
|
width: width
|
|
@@ -457,69 +455,59 @@ var RawChartAxes = /*#__PURE__*/function (_React$Component2) {
|
|
|
457
455
|
key: "render",
|
|
458
456
|
value: function render() {
|
|
459
457
|
var _this4 = this;
|
|
460
|
-
|
|
461
458
|
var _this$props5 = this.props,
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
range = _ref3$range === void 0 ? {} : _ref3$range,
|
|
489
|
-
_ref3$domain = _ref3.domain,
|
|
490
|
-
domain = _ref3$domain === void 0 ? {} : _ref3$domain,
|
|
491
|
-
_ref3$size = _ref3.size,
|
|
492
|
-
size = _ref3$size === void 0 ? {} : _ref3$size;
|
|
493
|
-
|
|
459
|
+
graphProps = _this$props5.graphProps,
|
|
460
|
+
xBand = _this$props5.xBand,
|
|
461
|
+
leftAxis = _this$props5.leftAxis,
|
|
462
|
+
onChange = _this$props5.onChange,
|
|
463
|
+
onChangeCategory = _this$props5.onChangeCategory,
|
|
464
|
+
_this$props5$categori = _this$props5.categories,
|
|
465
|
+
categories = _this$props5$categori === void 0 ? [] : _this$props5$categori,
|
|
466
|
+
top = _this$props5.top,
|
|
467
|
+
defineChart = _this$props5.defineChart,
|
|
468
|
+
chartingOptions = _this$props5.chartingOptions,
|
|
469
|
+
changeInteractiveEnabled = _this$props5.changeInteractiveEnabled,
|
|
470
|
+
changeEditableEnabled = _this$props5.changeEditableEnabled,
|
|
471
|
+
theme = _this$props5.theme,
|
|
472
|
+
autoFocus = _this$props5.autoFocus,
|
|
473
|
+
onAutoFocusUsed = _this$props5.onAutoFocusUsed,
|
|
474
|
+
error = _this$props5.error,
|
|
475
|
+
showCorrectness = _this$props5.showCorrectness;
|
|
476
|
+
var _ref5 = graphProps || {},
|
|
477
|
+
_ref5$scale = _ref5.scale,
|
|
478
|
+
scale = _ref5$scale === void 0 ? {} : _ref5$scale,
|
|
479
|
+
_ref5$range = _ref5.range,
|
|
480
|
+
range = _ref5$range === void 0 ? {} : _ref5$range,
|
|
481
|
+
_ref5$domain = _ref5.domain,
|
|
482
|
+
domain = _ref5$domain === void 0 ? {} : _ref5$domain,
|
|
483
|
+
_ref5$size = _ref5.size,
|
|
484
|
+
size = _ref5$size === void 0 ? {} : _ref5$size;
|
|
494
485
|
var _this$state = this.state,
|
|
495
|
-
|
|
496
|
-
|
|
486
|
+
height = _this$state.height,
|
|
487
|
+
width = _this$state.width;
|
|
497
488
|
var bottomScale = xBand && typeof xBand.rangeRound === 'function' && xBand.rangeRound([0, size.width]);
|
|
498
|
-
var bandWidth = xBand && typeof xBand.bandwidth === 'function' && xBand.bandwidth();
|
|
499
|
-
|
|
489
|
+
var bandWidth = xBand && typeof xBand.bandwidth === 'function' && xBand.bandwidth();
|
|
490
|
+
// for chartType "line", bandWidth will be 0, so we have to calculate it
|
|
500
491
|
var barWidth = bandWidth || scale.x && scale.x(domain.max) / categories.length;
|
|
501
492
|
var rowTickValues = (0, _utils.getTickValues)(_objectSpread(_objectSpread({}, range), {}, {
|
|
502
493
|
step: range.labelStep
|
|
503
494
|
}));
|
|
504
|
-
var fontSize = theme && theme.typography ? theme.typography.fontSize : 14;
|
|
505
|
-
|
|
506
|
-
var rotateBecauseOfHeight = (0, _utils.getRotateAngle)(fontSize, height);
|
|
507
|
-
|
|
495
|
+
var fontSize = theme && theme.typography ? theme.typography.fontSize : 14;
|
|
496
|
+
// this mostly applies for labels that are not editable
|
|
497
|
+
var rotateBecauseOfHeight = (0, _utils.getRotateAngle)(fontSize, height);
|
|
498
|
+
// this applies for labels that are editable
|
|
508
499
|
var rotateBecauseOfWidth = width > barWidth ? 25 : 0;
|
|
509
|
-
|
|
510
500
|
var getTickLabelProps = function getTickLabelProps(value) {
|
|
511
501
|
return {
|
|
512
502
|
dy: 4,
|
|
513
503
|
dx: -10 - (value.toLocaleString().length || 1) * 5
|
|
514
504
|
};
|
|
515
505
|
};
|
|
516
|
-
|
|
517
506
|
var getTickComponent = function getTickComponent(props) {
|
|
518
507
|
var properties = {
|
|
519
508
|
hiddenLabelRef: function hiddenLabelRef(ref) {
|
|
520
509
|
_this4.hiddenLabelRef = ref;
|
|
521
510
|
},
|
|
522
|
-
classes: classes,
|
|
523
511
|
categories: categories,
|
|
524
512
|
xBand: xBand,
|
|
525
513
|
bandWidth: bandWidth,
|
|
@@ -543,21 +531,15 @@ var RawChartAxes = /*#__PURE__*/function (_React$Component2) {
|
|
|
543
531
|
};
|
|
544
532
|
return /*#__PURE__*/_react["default"].createElement(TickComponent, properties);
|
|
545
533
|
};
|
|
546
|
-
|
|
547
|
-
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, leftAxis && /*#__PURE__*/_react["default"].createElement(_axis.AxisLeft, {
|
|
534
|
+
return /*#__PURE__*/_react["default"].createElement(StyledAxesGroup, null, leftAxis && /*#__PURE__*/_react["default"].createElement(_axis.AxisLeft, {
|
|
548
535
|
scale: scale.y,
|
|
549
|
-
className: axis,
|
|
550
|
-
axisLineClassName: axisLine,
|
|
551
536
|
tickLength: 10,
|
|
552
|
-
tickClassName: tick,
|
|
553
537
|
tickFormat: function tickFormat(value) {
|
|
554
538
|
return value;
|
|
555
539
|
},
|
|
556
540
|
tickValues: rowTickValues,
|
|
557
541
|
tickLabelProps: getTickLabelProps
|
|
558
542
|
}), /*#__PURE__*/_react["default"].createElement(_axis.AxisBottom, {
|
|
559
|
-
axisLineClassName: axisLine,
|
|
560
|
-
tickClassName: tick,
|
|
561
543
|
scale: bottomScale,
|
|
562
544
|
labelProps: {
|
|
563
545
|
y: 60 + top
|
|
@@ -577,13 +559,9 @@ var RawChartAxes = /*#__PURE__*/function (_React$Component2) {
|
|
|
577
559
|
}));
|
|
578
560
|
}
|
|
579
561
|
}]);
|
|
580
|
-
return RawChartAxes;
|
|
581
562
|
}(_react["default"].Component);
|
|
582
|
-
|
|
583
|
-
exports.RawChartAxes = RawChartAxes;
|
|
584
563
|
(0, _defineProperty2["default"])(RawChartAxes, "propTypes", {
|
|
585
564
|
bottomScale: _propTypes["default"].func,
|
|
586
|
-
classes: _propTypes["default"].object.isRequired,
|
|
587
565
|
categories: _propTypes["default"].array,
|
|
588
566
|
defineChart: _propTypes["default"].bool,
|
|
589
567
|
error: _propTypes["default"].any,
|
|
@@ -599,64 +577,10 @@ exports.RawChartAxes = RawChartAxes;
|
|
|
599
577
|
changeEditableEnabled: _propTypes["default"].bool,
|
|
600
578
|
autoFocus: _propTypes["default"].bool,
|
|
601
579
|
onAutoFocusUsed: _propTypes["default"].func,
|
|
602
|
-
showCorrectness: _propTypes["default"].bool
|
|
580
|
+
showCorrectness: _propTypes["default"].bool,
|
|
581
|
+
hiddenLabelRef: _propTypes["default"].oneOfType([_propTypes["default"].func, _propTypes["default"].shape({
|
|
582
|
+
current: _propTypes["default"].instanceOf(Element)
|
|
583
|
+
})])
|
|
603
584
|
});
|
|
604
|
-
var
|
|
605
|
-
return {
|
|
606
|
-
axis: {
|
|
607
|
-
stroke: _renderUi.color.primaryDark(),
|
|
608
|
-
strokeWidth: 2
|
|
609
|
-
},
|
|
610
|
-
axisLine: {
|
|
611
|
-
stroke: _renderUi.color.visualElementsColors.AXIS_LINE_COLOR,
|
|
612
|
-
strokeWidth: 2
|
|
613
|
-
},
|
|
614
|
-
tick: {
|
|
615
|
-
'& > line': {
|
|
616
|
-
stroke: _renderUi.color.primaryDark(),
|
|
617
|
-
strokeWidth: 2
|
|
618
|
-
},
|
|
619
|
-
fontFamily: theme.typography.body1.fontFamily,
|
|
620
|
-
fontSize: theme.typography.fontSize,
|
|
621
|
-
textAnchor: 'middle'
|
|
622
|
-
},
|
|
623
|
-
dottedLine: {
|
|
624
|
-
stroke: _renderUi.color.primaryLight(),
|
|
625
|
-
opacity: 0.2
|
|
626
|
-
},
|
|
627
|
-
error: {
|
|
628
|
-
fontSize: theme.typography.fontSize - 2,
|
|
629
|
-
fill: theme.palette.error.main
|
|
630
|
-
},
|
|
631
|
-
customColor: {
|
|
632
|
-
color: "".concat(_renderUi.color.tertiary(), " !important")
|
|
633
|
-
},
|
|
634
|
-
correctnessIcon: {
|
|
635
|
-
borderRadius: theme.spacing.unit * 2,
|
|
636
|
-
color: _renderUi.color.defaults.WHITE,
|
|
637
|
-
fontSize: '16px',
|
|
638
|
-
width: '16px',
|
|
639
|
-
height: '16px',
|
|
640
|
-
padding: '2px',
|
|
641
|
-
border: "1px solid ".concat(_renderUi.color.defaults.WHITE),
|
|
642
|
-
boxSizing: 'unset' // to override the default border-box in IBX
|
|
643
|
-
|
|
644
|
-
},
|
|
645
|
-
incorrectIcon: {
|
|
646
|
-
backgroundColor: _renderUi.color.incorrectWithIcon()
|
|
647
|
-
},
|
|
648
|
-
correctIcon: {
|
|
649
|
-
backgroundColor: _renderUi.color.correct()
|
|
650
|
-
},
|
|
651
|
-
tickContainer: {
|
|
652
|
-
display: 'flex',
|
|
653
|
-
flexDirection: 'column',
|
|
654
|
-
alignItems: 'center'
|
|
655
|
-
}
|
|
656
|
-
};
|
|
657
|
-
}, {
|
|
658
|
-
withTheme: true
|
|
659
|
-
})(RawChartAxes);
|
|
660
|
-
var _default = ChartAxes;
|
|
661
|
-
exports["default"] = _default;
|
|
662
|
-
//# sourceMappingURL=axes.js.map
|
|
585
|
+
var _default = exports["default"] = RawChartAxes;
|
|
586
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_styles","_axis","_Checkbox","_plot","_renderUi","_configUi","_mathRendering","_correctnessIndicators","_utils","_markLabel","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","StyledErrorText","styled","_ref","theme","fontSize","typography","fill","palette","error","main","StyledCheckbox","Checkbox","color","concat","tertiary","StyledAxesGroup","_ref2","_theme$typography$bod","stroke","visualElementsColors","AXIS_LINE_COLOR","strokeWidth","AXIS_TICK_COLOR","fontFamily","body1","textAnchor","correctnessIconStyles","borderRadius","spacing","defaults","WHITE","width","height","padding","border","boxSizing","incorrectIconStyles","backgroundColor","incorrectWithIcon","correctIconStyles","correct","TickComponent","exports","_React$Component","props","_this","_classCallCheck2","open","callback","setState","dialog","index","newLabel","_this$props","categories","onChangeCategory","category","label","value","_this$props2","title","text","onConfirm","handleAlertDialog","interactive","onClose","_this$props3","editable","maxChar","chunks","indexToSplit","lastIndexOf","substring","trim","state","_inherits2","_createClass2","key","componentDidUpdate","prevProps","autoFocus","onAutoFocusUsed","render","_this2","_this$props4","xBand","bandWidth","barWidth","rotate","top","graphProps","defineChart","chartingOptions","x","y","formattedValue","changeInteractiveEnabled","changeEditableEnabled","hiddenLabelRef","showCorrectness","classes","correctnessIcon","incorrectIcon","correctIcon","_ref3","changeEditable","changeInteractive","parseInt","split","_ref4","correctness","barX","bandKey","longestCategory","reduce","a","b","lengthA","lengthB","distinctMessages","_toConsumableArray2","Set","values","join","createElement","style","pointerEvents","overflow","isHiddenLabel","inputRef","disabled","mark","input","onChange","changeCategory","limitCharacters","correctnessIndicator","TickCorrectnessIndicator","position","wordBreak","maxWidth","display","splitText","authoringLabel","map","word","dy","checked","target","AlertDialog","React","Component","PropTypes","bool","any","propTypes","array","func","number","object","string","oneOfType","shape","current","instanceOf","Element","RawChartAxes","_React$Component2","_this3","_len","args","Array","_key","componentDidMount","boundingClientRect","getBoundingClientRect","hiddenEl","containsLatex","querySelector","hasMathJax","mathHandled","renderMath","Math","floor","_this4","_this$props5","leftAxis","_this$props5$categori","_ref5","_ref5$scale","scale","_ref5$range","range","_ref5$domain","domain","_ref5$size","size","_this$state","bottomScale","rangeRound","bandwidth","max","rowTickValues","getTickValues","step","labelStep","rotateBecauseOfHeight","getRotateAngle","rotateBecauseOfWidth","getTickLabelProps","dx","toLocaleString","getTickComponent","properties","ref","AxisLeft","tickLength","tickFormat","tickValues","tickLabelProps","AxisBottom","labelProps","min","textLabelProps","count","tickComponent","types","GraphPropsType","isRequired","_default"],"sources":["../src/axes.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\nimport { AxisLeft, AxisBottom } from '@visx/axis';\nimport Checkbox from '@mui/material/Checkbox';\n\nimport { types } from '@pie-lib/plot';\nimport { color } from '@pie-lib/render-ui';\nimport { AlertDialog } from '@pie-lib/config-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\n\nimport { TickCorrectnessIndicator } from './common/correctness-indicators';\nimport { bandKey, getTickValues, getRotateAngle } from './utils';\nimport MarkLabel from './mark-label';\n\nconst StyledErrorText = styled('text')(({ theme }) => ({\n  fontSize: theme.typography.fontSize - 2,\n  fill: theme.palette.error.main,\n}));\n\nconst StyledCheckbox = styled(Checkbox)(() => ({\n  color: `${color.tertiary()} !important`,\n}));\n\nconst StyledAxesGroup = styled('g')(({ theme }) => ({\n  '& .vx-axis-line': {\n    stroke: color.visualElementsColors.AXIS_LINE_COLOR,\n    strokeWidth: 2,\n  },\n  '& .vx-axis-tick': {\n    fill: color.visualElementsColors.AXIS_TICK_COLOR,\n    '& line': {\n      stroke: color.visualElementsColors.AXIS_TICK_COLOR,\n      strokeWidth: 2,\n    },\n    fontFamily: theme.typography.body1?.fontFamily,\n    fontSize: theme.typography.fontSize,\n    textAnchor: 'middle',\n  },\n}));\n\nconst correctnessIconStyles = (theme) => ({\n  borderRadius: theme.spacing(2),\n  color: color.defaults.WHITE,\n  fontSize: '16px',\n  width: '16px',\n  height: '16px',\n  padding: '2px',\n  border: `1px solid ${color.defaults.WHITE}`,\n  boxSizing: 'unset', // to override the default border-box in IBX\n});\n\nconst incorrectIconStyles = {\n  backgroundColor: color.incorrectWithIcon(),\n};\n\nconst correctIconStyles = {\n  backgroundColor: color.correct(),\n};\n\nexport class TickComponent extends React.Component {\n  static propTypes = {\n    defineChart: PropTypes.bool,\n    error: PropTypes.any,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      dialog: {\n        open: false,\n      },\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.autoFocus && !prevProps.autoFocus) {\n      this.props.onAutoFocusUsed();\n    }\n  }\n\n  handleAlertDialog = (open, callback) =>\n    this.setState(\n      {\n        dialog: { open },\n      },\n      callback,\n    );\n\n  changeCategory = (index, newLabel) => {\n    const { categories, onChangeCategory } = this.props;\n    const category = categories[index];\n\n    onChangeCategory(index, { ...category, label: newLabel });\n  };\n\n  changeInteractive = (index, value) => {\n    const { categories, onChangeCategory } = this.props;\n    const category = categories[index];\n\n    if (!value) {\n      this.setState({\n        dialog: {\n          open: true,\n          title: 'Warning',\n          text: 'This will remove the correct answer value that has been defined for this category.',\n          onConfirm: () =>\n            this.handleAlertDialog(false, onChangeCategory(index, { ...category, interactive: !category.interactive })),\n          onClose: () => this.handleAlertDialog(false),\n        },\n      });\n    } else {\n      onChangeCategory(index, { ...category, interactive: !category.interactive });\n    }\n  };\n\n  changeEditable = (index, value) => {\n    const { categories, onChangeCategory } = this.props;\n    const category = categories[index];\n\n    if (!value) {\n      this.setState({\n        dialog: {\n          open: true,\n          title: 'Warning',\n          text: 'This will remove the correct answer category name that has been defined for this category.',\n          onConfirm: () =>\n            this.handleAlertDialog(\n              false,\n              onChangeCategory(index, { ...category, editable: !category.editable || false }),\n            ),\n          onClose: () => this.handleAlertDialog(false),\n        },\n      });\n    } else {\n      onChangeCategory(index, { ...category, editable: !category.editable || false });\n    }\n  };\n\n  splitText = (text, maxChar) => {\n    let chunks = [];\n    while ((text || '').length > 0) {\n      let indexToSplit;\n      if (text.length > maxChar) {\n        indexToSplit = text.lastIndexOf(' ', maxChar);\n        if (indexToSplit === -1) {\n          indexToSplit = maxChar;\n        }\n      } else {\n        indexToSplit = text.length;\n      }\n      chunks.push(text.substring(0, indexToSplit));\n      text = text.substring(indexToSplit).trim();\n    }\n    return chunks;\n  };\n\n  render() {\n    const {\n      categories,\n      xBand,\n      bandWidth,\n      barWidth,\n      rotate,\n      top,\n      graphProps,\n      defineChart,\n      chartingOptions,\n      x,\n      y,\n      formattedValue,\n      changeInteractiveEnabled,\n      changeEditableEnabled,\n      error,\n      autoFocus,\n      hiddenLabelRef,\n      showCorrectness,\n    } = this.props;\n\n    if (!formattedValue) {\n      return null;\n    }\n\n    // Create classes object for TickCorrectnessIndicator compatibility\n    const classes = {\n      correctnessIcon: correctnessIconStyles,\n      incorrectIcon: incorrectIconStyles,\n      correctIcon: correctIconStyles,\n    };\n\n    const { dialog } = this.state;\n    const { changeEditable, changeInteractive } = chartingOptions || {};\n    const index = parseInt(formattedValue.split('-')[0], 10);\n    const category = categories[index];\n    const { editable, interactive, label, correctness } = category || {};\n    const barX = xBand(bandKey({ label }, index));\n    const longestCategory = (categories || []).reduce((a, b) => {\n      const lengthA = a && a.label ? a.label.length : 0;\n      const lengthB = b && b.label ? b.label.length : 0;\n\n      return lengthA > lengthB ? a : b;\n    }, { label: '' });\n    const distinctMessages = error ? [...new Set(Object.values(error))].join(' ') : '';\n\n    return (\n      <g>\n        <foreignObject\n          x={bandWidth ? barX : x - barWidth / 2}\n          y={18}\n          width={barWidth}\n          height={4}\n          style={{ pointerEvents: 'none', overflow: 'visible' }}\n        >\n          {index === 0 && (\n            <MarkLabel\n              isHiddenLabel={true}\n              inputRef={hiddenLabelRef}\n              disabled={true}\n              mark={longestCategory}\n              graphProps={graphProps}\n              barWidth={barWidth}\n            />\n          )}\n\n          <MarkLabel\n            autoFocus={defineChart && autoFocus}\n            inputRef={(r) => (this.input = r)}\n            disabled={!defineChart && !editable}\n            mark={category}\n            graphProps={graphProps}\n            onChange={(newLabel) => this.changeCategory(index, newLabel)}\n            barWidth={barWidth}\n            rotate={rotate}\n            correctness={correctness}\n            error={error && error[index]}\n            limitCharacters\n            correctnessIndicator={\n              showCorrectness &&\n              correctness && (\n                <TickCorrectnessIndicator correctness={correctness} interactive={interactive} classes={classes} />\n              )\n            }\n          />\n        </foreignObject>\n\n        {error && index === 0 && (\n          <StyledErrorText y={y + 23} height={6} textAnchor=\"start\">\n            {distinctMessages}\n          </StyledErrorText>\n        )}\n\n        {defineChart && index === 0 && (\n          <svg\n            x={-55}\n            style={{\n              overflow: 'visible',\n            }}\n          >\n            {changeInteractiveEnabled && (\n              <text\n                y={y + 90 + top}\n                width={barWidth}\n                height={4}\n                style={{\n                  position: 'absolute',\n                  pointerEvents: 'none',\n                  wordBreak: 'break-word',\n                  maxWidth: barWidth,\n                  display: 'inline-block',\n                }}\n              >\n                {this.splitText(changeInteractive?.authoringLabel, 20).map((word, index) => (\n                  <tspan key={index} x=\"0\" dy={`${index > 0 ? '1.2em' : '.6em'}`}>\n                    {word}\n                  </tspan>\n                ))}\n              </text>\n            )}\n\n            {changeEditableEnabled && (\n              <text\n                y={y + 145 + top}\n                width={barWidth}\n                height={4}\n                style={{\n                  position: 'absolute',\n                  pointerEvents: 'none',\n                  wordBreak: 'break-word',\n                  maxWidth: barWidth,\n                  display: 'inline-block',\n                }}\n              >\n                {this.splitText(changeEditable?.authoringLabel, 20).map((word, index) => (\n                  <tspan key={index} x=\"0\" dy={`${index > 0 ? '1.2em' : '.6em'}`}>\n                    {word}\n                  </tspan>\n                ))}\n              </text>\n            )}\n          </svg>\n        )}\n\n        {defineChart && changeInteractiveEnabled && (\n          <foreignObject\n            x={x - 24}\n            y={y + 80 + top}\n            width={barWidth}\n            height={4}\n            style={{ pointerEvents: 'visible', overflow: 'visible' }}\n          >\n            <StyledCheckbox\n              style={{ position: 'fixed' }}\n              checked={interactive}\n              onChange={(e) => this.changeInteractive(index, e.target.checked)}\n            />\n          </foreignObject>\n        )}\n\n        {defineChart && changeEditableEnabled && (\n          <foreignObject\n            x={x - 24}\n            y={y + 130 + top}\n            width={barWidth}\n            height={4}\n            style={{ pointerEvents: 'visible', overflow: 'visible' }}\n          >\n            <StyledCheckbox\n              style={{ position: 'fixed' }}\n              checked={editable}\n              onChange={(e) => this.changeEditable(index, e.target.checked)}\n            />\n          </foreignObject>\n        )}\n\n        <foreignObject\n          x={x - 24}\n          y={y + 100 + top}\n          width={barWidth}\n          height={4}\n          style={{ pointerEvents: 'visible', overflow: 'visible' }}\n        >\n          <AlertDialog\n            open={dialog.open}\n            title={dialog.title}\n            text={dialog.text}\n            onClose={dialog.onClose}\n            onConfirm={dialog.onConfirm}\n          />\n        </foreignObject>\n      </g>\n    );\n  }\n}\n\nTickComponent.propTypes = {\n  categories: PropTypes.array,\n  xBand: PropTypes.func,\n  bandWidth: PropTypes.number,\n  barWidth: PropTypes.number,\n  rotate: PropTypes.number,\n  top: PropTypes.number,\n  x: PropTypes.number,\n  y: PropTypes.number,\n  graphProps: PropTypes.object,\n  formattedValue: PropTypes.string,\n  onChangeCategory: PropTypes.func,\n  onChange: PropTypes.func,\n  error: PropTypes.object,\n  defineChart: PropTypes.bool,\n  chartingOptions: PropTypes.object,\n  changeInteractiveEnabled: PropTypes.bool,\n  changeEditableEnabled: PropTypes.bool,\n  autoFocus: PropTypes.bool,\n  onAutoFocusUsed: PropTypes.func,\n  showCorrectness: PropTypes.bool,\n  hiddenLabelRef: PropTypes.oneOfType([PropTypes.func, PropTypes.shape({ current: PropTypes.instanceOf(Element) })]),\n};\n\nexport class RawChartAxes extends React.Component {\n  static propTypes = {\n    bottomScale: PropTypes.func,\n    categories: PropTypes.array,\n    defineChart: PropTypes.bool,\n    error: PropTypes.any,\n    graphProps: types.GraphPropsType.isRequired,\n    xBand: PropTypes.func,\n    leftAxis: PropTypes.bool,\n    onChange: PropTypes.func,\n    onChangeCategory: PropTypes.func,\n    top: PropTypes.number,\n    theme: PropTypes.object,\n    chartingOptions: PropTypes.object,\n    changeInteractiveEnabled: PropTypes.bool,\n    changeEditableEnabled: PropTypes.bool,\n    autoFocus: PropTypes.bool,\n    onAutoFocusUsed: PropTypes.func,\n    showCorrectness: PropTypes.bool,\n    hiddenLabelRef: PropTypes.oneOfType([PropTypes.func, PropTypes.shape({ current: PropTypes.instanceOf(Element) })]),\n  };\n\n  state = { height: 0, width: 0 };\n\n  componentDidMount() {\n    if (this.hiddenLabelRef) {\n      const boundingClientRect = this.hiddenLabelRef.getBoundingClientRect();\n      const hiddenEl = this.hiddenLabelRef;\n\n      // same logic used in dropdown.jsx for hidden labels width calculation\n      if (hiddenEl) {\n        const containsLatex = hiddenEl.querySelector('[data-latex], [data-raw]');\n        const hasMathJax = hiddenEl.querySelector('mjx-container');\n        const mathHandled = hiddenEl.querySelector('[data-math-handled=\"true\"]');\n\n        if (containsLatex && (!mathHandled || !hasMathJax)) {\n          renderMath(this.hiddenLabelRef);\n        }\n\n        this.setState({\n          height: Math.floor(boundingClientRect.height),\n          width: Math.floor(boundingClientRect.width),\n        });\n      }\n    }\n  }\n\n  componentDidUpdate() {\n    if (this.hiddenLabelRef) {\n      const width = Math.floor(this.hiddenLabelRef.getBoundingClientRect().width);\n\n      if (width !== this.state.width) {\n        this.setState({ width });\n      }\n    }\n  }\n\n  render() {\n    const {\n      graphProps,\n      xBand,\n      leftAxis,\n      onChange,\n      onChangeCategory,\n      categories = [],\n      top,\n      defineChart,\n      chartingOptions,\n      changeInteractiveEnabled,\n      changeEditableEnabled,\n      theme,\n      autoFocus,\n      onAutoFocusUsed,\n      error,\n      showCorrectness,\n    } = this.props;\n\n    const { scale = {}, range = {}, domain = {}, size = {} } = graphProps || {};\n    const { height, width } = this.state;\n\n    const bottomScale = xBand && typeof xBand.rangeRound === 'function' && xBand.rangeRound([0, size.width]);\n\n    const bandWidth = xBand && typeof xBand.bandwidth === 'function' && xBand.bandwidth();\n    // for chartType \"line\", bandWidth will be 0, so we have to calculate it\n    const barWidth = bandWidth || (scale.x && scale.x(domain.max) / categories.length);\n\n    const rowTickValues = getTickValues({ ...range, step: range.labelStep });\n    const fontSize = theme && theme.typography ? theme.typography.fontSize : 14;\n    // this mostly applies for labels that are not editable\n    const rotateBecauseOfHeight = getRotateAngle(fontSize, height);\n    // this applies for labels that are editable\n    const rotateBecauseOfWidth = width > barWidth ? 25 : 0;\n\n    const getTickLabelProps = (value) => ({\n      dy: 4,\n      dx: -10 - (value.toLocaleString().length || 1) * 5,\n    });\n\n    const getTickComponent = (props) => {\n      const properties = {\n        hiddenLabelRef: (ref) => {\n          this.hiddenLabelRef = ref;\n        },\n        categories,\n        xBand,\n        bandWidth,\n        barWidth,\n        rotate: rotateBecauseOfHeight || rotateBecauseOfWidth,\n        top,\n        defineChart,\n        chartingOptions,\n        autoFocus,\n        onAutoFocusUsed,\n        error,\n        onChangeCategory,\n        changeInteractiveEnabled,\n        changeEditableEnabled,\n        onChange,\n        graphProps,\n        x: props.x,\n        y: props.y,\n        formattedValue: props.formattedValue,\n        showCorrectness,\n      };\n\n      return <TickComponent {...properties} />;\n    };\n\n    return (\n      <StyledAxesGroup>\n        {leftAxis && (\n          <AxisLeft\n            scale={scale.y}\n            tickLength={10}\n            tickFormat={(value) => value}\n            tickValues={rowTickValues}\n            tickLabelProps={getTickLabelProps}\n          />\n        )}\n        <AxisBottom\n          scale={bottomScale}\n          labelProps={{ y: 60 + top }}\n          top={scale.y && scale.y(range.min)}\n          textLabelProps={() => ({ textAnchor: 'middle' })}\n          tickFormat={(count) => count}\n          tickComponent={getTickComponent}\n          autoFocus={autoFocus}\n          onAutoFocusUsed={onAutoFocusUsed}\n        />\n      </StyledAxesGroup>\n    );\n  }\n}\n\nexport default RawChartAxes;\n"],"mappings":"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","ignoreList":[]}
|