@pie-lib/graphing-solution-set 3.1.0-next.2 → 3.1.0-next.25
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 +8 -0
- package/NEXT.CHANGELOG.json +16 -1
- package/lib/axis/arrow.js +82 -0
- package/lib/axis/arrow.js.map +1 -0
- package/lib/axis/axes.js +341 -0
- package/lib/axis/axes.js.map +1 -0
- package/lib/axis/index.js +28 -0
- package/lib/axis/index.js.map +1 -0
- package/lib/bg.js +120 -0
- package/lib/bg.js.map +1 -0
- package/lib/container/actions.js +19 -0
- package/lib/container/actions.js.map +1 -0
- package/lib/container/index.js +126 -0
- package/lib/container/index.js.map +1 -0
- package/lib/container/marks.js +24 -0
- package/lib/container/marks.js.map +1 -0
- package/lib/container/middleware.js +20 -0
- package/lib/container/middleware.js.map +1 -0
- package/lib/container/reducer.js +19 -0
- package/lib/container/reducer.js.map +1 -0
- package/lib/coordinates-label.js +88 -0
- package/lib/coordinates-label.js.map +1 -0
- package/lib/graph-with-controls.js +316 -0
- package/lib/graph-with-controls.js.map +1 -0
- package/lib/graph.js +372 -0
- package/lib/graph.js.map +1 -0
- package/lib/grid-setup.js +417 -0
- package/lib/grid-setup.js.map +1 -0
- package/lib/grid.js +153 -0
- package/lib/grid.js.map +1 -0
- package/lib/index.js +47 -0
- package/lib/index.js.map +1 -0
- package/lib/labels.js +212 -0
- package/lib/labels.js.map +1 -0
- package/lib/mark-label.js +175 -0
- package/lib/mark-label.js.map +1 -0
- package/lib/toggle-bar.js +265 -0
- package/lib/toggle-bar.js.map +1 -0
- package/lib/tool-menu.js +221 -0
- package/lib/tool-menu.js.map +1 -0
- package/lib/tools/index.js +25 -0
- package/lib/tools/index.js.map +1 -0
- package/lib/tools/line/component.js +105 -0
- package/lib/tools/line/component.js.map +1 -0
- package/lib/tools/line/index.js +12 -0
- package/lib/tools/line/index.js.map +1 -0
- package/lib/tools/polygon/component.js +378 -0
- package/lib/tools/polygon/component.js.map +1 -0
- package/lib/tools/polygon/index.js +101 -0
- package/lib/tools/polygon/index.js.map +1 -0
- package/lib/tools/polygon/line.js +130 -0
- package/lib/tools/polygon/line.js.map +1 -0
- package/lib/tools/polygon/polygon.js +150 -0
- package/lib/tools/polygon/polygon.js.map +1 -0
- package/lib/tools/shared/arrow-head.js +65 -0
- package/lib/tools/shared/arrow-head.js.map +1 -0
- package/lib/tools/shared/line/index.js +554 -0
- package/lib/tools/shared/line/index.js.map +1 -0
- package/lib/tools/shared/line/line-path.js +137 -0
- package/lib/tools/shared/line/line-path.js.map +1 -0
- package/lib/tools/shared/line/with-root-edge.js +132 -0
- package/lib/tools/shared/line/with-root-edge.js.map +1 -0
- package/lib/tools/shared/point/arrow-point.js +89 -0
- package/lib/tools/shared/point/arrow-point.js.map +1 -0
- package/lib/tools/shared/point/arrow.js +73 -0
- package/lib/tools/shared/point/arrow.js.map +1 -0
- package/lib/tools/shared/point/base-point.js +148 -0
- package/lib/tools/shared/point/base-point.js.map +1 -0
- package/lib/tools/shared/point/index.js +96 -0
- package/lib/tools/shared/point/index.js.map +1 -0
- package/lib/tools/shared/styles.js +27 -0
- package/lib/tools/shared/styles.js.map +1 -0
- package/lib/tools/shared/types.js +16 -0
- package/lib/tools/shared/types.js.map +1 -0
- package/lib/undo-redo.js +69 -0
- package/lib/undo-redo.js.map +1 -0
- package/lib/use-debounce.js +27 -0
- package/lib/use-debounce.js.map +1 -0
- package/lib/utils.js +253 -0
- package/lib/utils.js.map +1 -0
- package/package.json +14 -14
- package/src/__tests__/graph-with-controls.test.jsx +41 -0
- package/src/__tests__/toggle-bar.test.jsx +41 -0
- package/src/bg.jsx +5 -5
|
@@ -0,0 +1,417 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.symbol.js");
|
|
4
|
+
require("core-js/modules/es.array.filter.js");
|
|
5
|
+
require("core-js/modules/es.array.for-each.js");
|
|
6
|
+
require("core-js/modules/es.object.define-properties.js");
|
|
7
|
+
require("core-js/modules/es.object.define-property.js");
|
|
8
|
+
require("core-js/modules/es.object.get-own-property-descriptor.js");
|
|
9
|
+
require("core-js/modules/es.object.get-own-property-descriptors.js");
|
|
10
|
+
require("core-js/modules/es.object.keys.js");
|
|
11
|
+
require("core-js/modules/es.object.to-string.js");
|
|
12
|
+
require("core-js/modules/web.dom-collections.for-each.js");
|
|
13
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
14
|
+
Object.defineProperty(exports, "__esModule", {
|
|
15
|
+
value: true
|
|
16
|
+
});
|
|
17
|
+
exports["default"] = void 0;
|
|
18
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
19
|
+
require("core-js/modules/es.array.concat.js");
|
|
20
|
+
var _react = _interopRequireDefault(require("react"));
|
|
21
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
22
|
+
var _renderUi = require("@pie-lib/render-ui");
|
|
23
|
+
var _material = require("@mui/material");
|
|
24
|
+
var _ExpandMore = _interopRequireDefault(require("@mui/icons-material/ExpandMore"));
|
|
25
|
+
var _configUi = require("@pie-lib/config-ui");
|
|
26
|
+
var _editableHtmlTipTap = _interopRequireDefault(require("@pie-lib/editable-html-tip-tap"));
|
|
27
|
+
var _styles = require("@mui/material/styles");
|
|
28
|
+
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; }
|
|
29
|
+
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; }
|
|
30
|
+
var Wrapper = (0, _styles.styled)('div')(function () {
|
|
31
|
+
return {
|
|
32
|
+
width: '450px'
|
|
33
|
+
};
|
|
34
|
+
});
|
|
35
|
+
var Content = (0, _styles.styled)('div')(function () {
|
|
36
|
+
return {
|
|
37
|
+
display: 'flex',
|
|
38
|
+
flexDirection: 'column',
|
|
39
|
+
width: '100%'
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
var ColumnView = (0, _styles.styled)('div')(function () {
|
|
43
|
+
return {
|
|
44
|
+
display: 'flex',
|
|
45
|
+
flexDirection: 'column',
|
|
46
|
+
alignItems: 'center'
|
|
47
|
+
};
|
|
48
|
+
});
|
|
49
|
+
var RowView = (0, _styles.styled)('div')(function () {
|
|
50
|
+
return {
|
|
51
|
+
display: 'flex',
|
|
52
|
+
justifyContent: 'space-around',
|
|
53
|
+
alignItems: 'center'
|
|
54
|
+
};
|
|
55
|
+
});
|
|
56
|
+
var TextFieldSmall = (0, _styles.styled)('div')(function (_ref) {
|
|
57
|
+
var theme = _ref.theme;
|
|
58
|
+
return {
|
|
59
|
+
width: '130px',
|
|
60
|
+
margin: "".concat(theme.spacing(1), " ").concat(theme.spacing(0.5))
|
|
61
|
+
};
|
|
62
|
+
});
|
|
63
|
+
var TextFieldMedium = (0, _styles.styled)('div')(function (_ref2) {
|
|
64
|
+
var theme = _ref2.theme;
|
|
65
|
+
return {
|
|
66
|
+
width: '160px',
|
|
67
|
+
margin: "".concat(theme.spacing(1), " ").concat(theme.spacing(0.5)),
|
|
68
|
+
'& .MuiFormControl-root': {
|
|
69
|
+
width: '100%'
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
});
|
|
73
|
+
var TextFieldLarge = (0, _styles.styled)('div')(function (_ref3) {
|
|
74
|
+
var theme = _ref3.theme;
|
|
75
|
+
return {
|
|
76
|
+
width: '230px',
|
|
77
|
+
margin: "".concat(theme.spacing(1), " ").concat(theme.spacing(0.5)),
|
|
78
|
+
'& .MuiFormControl-root': {
|
|
79
|
+
width: '100%'
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
});
|
|
83
|
+
var ItalicText = (0, _styles.styled)(_material.Typography)(function (_ref4) {
|
|
84
|
+
var theme = _ref4.theme;
|
|
85
|
+
return {
|
|
86
|
+
fontStyle: 'italic',
|
|
87
|
+
margin: "".concat(theme.spacing(1), " 0")
|
|
88
|
+
};
|
|
89
|
+
});
|
|
90
|
+
var Dimensions = (0, _styles.styled)('div')(function () {
|
|
91
|
+
return {
|
|
92
|
+
display: 'flex',
|
|
93
|
+
justifyContent: 'space-between',
|
|
94
|
+
alignItems: 'center'
|
|
95
|
+
};
|
|
96
|
+
});
|
|
97
|
+
var DisabledText = (0, _styles.styled)(_material.Typography)(function () {
|
|
98
|
+
return {
|
|
99
|
+
color: _renderUi.color.disabled()
|
|
100
|
+
};
|
|
101
|
+
});
|
|
102
|
+
var AxisLabel = (0, _styles.styled)('div')(function (_ref5) {
|
|
103
|
+
var theme = _ref5.theme;
|
|
104
|
+
return {
|
|
105
|
+
paddingTop: theme.spacing(2)
|
|
106
|
+
};
|
|
107
|
+
});
|
|
108
|
+
var GridConfig = function GridConfig(props) {
|
|
109
|
+
var disabled = props.disabled,
|
|
110
|
+
displayedFields = props.displayedFields,
|
|
111
|
+
labelValue = props.labelValue,
|
|
112
|
+
labelValues = props.labelValues,
|
|
113
|
+
gridValue = props.gridValue,
|
|
114
|
+
gridValues = props.gridValues,
|
|
115
|
+
_onChange = props.onChange;
|
|
116
|
+
var _displayedFields$labe = displayedFields.labelStep,
|
|
117
|
+
labelStep = _displayedFields$labe === void 0 ? {} : _displayedFields$labe,
|
|
118
|
+
_displayedFields$step = displayedFields.step,
|
|
119
|
+
step = _displayedFields$step === void 0 ? {} : _displayedFields$step;
|
|
120
|
+
return /*#__PURE__*/_react["default"].createElement(ColumnView, null, step && step.enabled && /*#__PURE__*/_react["default"].createElement(TextFieldMedium, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
121
|
+
label: step.label || '',
|
|
122
|
+
value: gridValue,
|
|
123
|
+
customValues: gridValues,
|
|
124
|
+
variant: "outlined",
|
|
125
|
+
disabled: disabled,
|
|
126
|
+
onChange: function onChange(e, v) {
|
|
127
|
+
return _onChange('step', v);
|
|
128
|
+
}
|
|
129
|
+
})), labelStep && labelStep.enabled && /*#__PURE__*/_react["default"].createElement(TextFieldMedium, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
130
|
+
label: labelStep.label || '',
|
|
131
|
+
value: labelValue,
|
|
132
|
+
customValues: labelValues,
|
|
133
|
+
variant: "outlined",
|
|
134
|
+
disabled: disabled,
|
|
135
|
+
onChange: function onChange(e, v) {
|
|
136
|
+
return _onChange('labelStep', v);
|
|
137
|
+
}
|
|
138
|
+
})));
|
|
139
|
+
};
|
|
140
|
+
GridConfig.propTypes = {
|
|
141
|
+
disabled: _propTypes["default"].bool,
|
|
142
|
+
displayedFields: _propTypes["default"].object,
|
|
143
|
+
labelValue: _propTypes["default"].number,
|
|
144
|
+
labelValues: _propTypes["default"].array,
|
|
145
|
+
gridValue: _propTypes["default"].number,
|
|
146
|
+
gridValues: _propTypes["default"].array,
|
|
147
|
+
onChange: _propTypes["default"].func
|
|
148
|
+
};
|
|
149
|
+
var AxisConfig = function AxisConfig(props) {
|
|
150
|
+
var disabled = props.disabled,
|
|
151
|
+
displayedFields = props.displayedFields,
|
|
152
|
+
displayHeader = props.displayHeader,
|
|
153
|
+
label = props.label,
|
|
154
|
+
maxValue = props.maxValue,
|
|
155
|
+
minValue = props.minValue,
|
|
156
|
+
_onChange2 = props.onChange,
|
|
157
|
+
type = props.type;
|
|
158
|
+
var _displayedFields$axis = displayedFields.axisLabel,
|
|
159
|
+
axisLabel = _displayedFields$axis === void 0 ? {} : _displayedFields$axis,
|
|
160
|
+
_displayedFields$min = displayedFields.min,
|
|
161
|
+
min = _displayedFields$min === void 0 ? {} : _displayedFields$min,
|
|
162
|
+
_displayedFields$max = displayedFields.max,
|
|
163
|
+
max = _displayedFields$max === void 0 ? {} : _displayedFields$max;
|
|
164
|
+
var activePlugins = ['bold', 'italic', 'underline', 'strikethrough'];
|
|
165
|
+
return /*#__PURE__*/_react["default"].createElement(ColumnView, null, displayHeader && /*#__PURE__*/_react["default"].createElement(_material.Typography, {
|
|
166
|
+
variant: "subtitle2"
|
|
167
|
+
}, /*#__PURE__*/_react["default"].createElement("i", null, type === 'domain' ? 'x' : 'y'), "-axis"), min && min.enabled && /*#__PURE__*/_react["default"].createElement(TextFieldMedium, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
168
|
+
label: min.label || '',
|
|
169
|
+
value: minValue,
|
|
170
|
+
min: -10000,
|
|
171
|
+
max: maxValue - 0.05,
|
|
172
|
+
variant: "outlined",
|
|
173
|
+
disabled: disabled,
|
|
174
|
+
onChange: function onChange(e, v) {
|
|
175
|
+
return _onChange2('min', v);
|
|
176
|
+
}
|
|
177
|
+
})), max && max.enabled && /*#__PURE__*/_react["default"].createElement(TextFieldMedium, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
178
|
+
label: max.label || '',
|
|
179
|
+
value: maxValue,
|
|
180
|
+
min: minValue + 0.05,
|
|
181
|
+
max: 10000,
|
|
182
|
+
variant: "outlined",
|
|
183
|
+
disabled: disabled,
|
|
184
|
+
onChange: function onChange(e, v) {
|
|
185
|
+
return _onChange2('max', v);
|
|
186
|
+
}
|
|
187
|
+
})), axisLabel && axisLabel.enabled && /*#__PURE__*/_react["default"].createElement(TextFieldMedium, null, /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
|
|
188
|
+
label: axisLabel.label || ''
|
|
189
|
+
}, /*#__PURE__*/_react["default"].createElement(AxisLabel, null, /*#__PURE__*/_react["default"].createElement(_editableHtmlTipTap["default"], {
|
|
190
|
+
onChange: function onChange(value) {
|
|
191
|
+
return _onChange2('axisLabel', value);
|
|
192
|
+
},
|
|
193
|
+
markup: label || '',
|
|
194
|
+
charactersLimit: 5,
|
|
195
|
+
activePlugins: activePlugins
|
|
196
|
+
})))));
|
|
197
|
+
};
|
|
198
|
+
AxisConfig.propTypes = {
|
|
199
|
+
disabled: _propTypes["default"].bool,
|
|
200
|
+
displayedFields: _propTypes["default"].object,
|
|
201
|
+
displayHeader: _propTypes["default"].bool,
|
|
202
|
+
label: _propTypes["default"].string,
|
|
203
|
+
maxValue: _propTypes["default"].number,
|
|
204
|
+
minValue: _propTypes["default"].number,
|
|
205
|
+
type: _propTypes["default"].string,
|
|
206
|
+
onChange: _propTypes["default"].func
|
|
207
|
+
};
|
|
208
|
+
var GridSetup = function GridSetup(props) {
|
|
209
|
+
var domain = props.domain,
|
|
210
|
+
_props$displayedField = props.displayedFields,
|
|
211
|
+
displayedFields = _props$displayedField === void 0 ? {} : _props$displayedField,
|
|
212
|
+
_props$gridValues = props.gridValues,
|
|
213
|
+
gridValues = _props$gridValues === void 0 ? {} : _props$gridValues,
|
|
214
|
+
includeAxes = props.includeAxes,
|
|
215
|
+
_props$labelValues = props.labelValues,
|
|
216
|
+
labelValues = _props$labelValues === void 0 ? {} : _props$labelValues,
|
|
217
|
+
onChange = props.onChange,
|
|
218
|
+
onChangeView = props.onChangeView,
|
|
219
|
+
range = props.range,
|
|
220
|
+
size = props.size,
|
|
221
|
+
sizeConstraints = props.sizeConstraints,
|
|
222
|
+
standardGrid = props.standardGrid;
|
|
223
|
+
var gridProps = {
|
|
224
|
+
min: 2,
|
|
225
|
+
max: 41
|
|
226
|
+
};
|
|
227
|
+
var _ref6 = displayedFields || {},
|
|
228
|
+
_ref6$axisLabel = _ref6.axisLabel,
|
|
229
|
+
axisLabel = _ref6$axisLabel === void 0 ? {} : _ref6$axisLabel,
|
|
230
|
+
dimensionsEnabled = _ref6.dimensionsEnabled,
|
|
231
|
+
includeAxesEnabled = _ref6.includeAxesEnabled,
|
|
232
|
+
_ref6$labelStep = _ref6.labelStep,
|
|
233
|
+
labelStep = _ref6$labelStep === void 0 ? {} : _ref6$labelStep,
|
|
234
|
+
_ref6$min = _ref6.min,
|
|
235
|
+
min = _ref6$min === void 0 ? {} : _ref6$min,
|
|
236
|
+
_ref6$max = _ref6.max,
|
|
237
|
+
max = _ref6$max === void 0 ? {} : _ref6$max,
|
|
238
|
+
standardGridEnabled = _ref6.standardGridEnabled,
|
|
239
|
+
_ref6$step = _ref6.step,
|
|
240
|
+
step = _ref6$step === void 0 ? {} : _ref6$step;
|
|
241
|
+
var displayAxisType = min.enabled || max.enabled || axisLabel.enabled || step.enabled || labelStep.enabled;
|
|
242
|
+
var gridConfigFields = {
|
|
243
|
+
step: step,
|
|
244
|
+
labelStep: labelStep
|
|
245
|
+
};
|
|
246
|
+
var axisConfigFields = {
|
|
247
|
+
min: min,
|
|
248
|
+
max: max,
|
|
249
|
+
axisLabel: axisLabel
|
|
250
|
+
};
|
|
251
|
+
var onIncludeAxes = function onIncludeAxes(includeAxes) {
|
|
252
|
+
var noAxesConfig = function noAxesConfig(type) {
|
|
253
|
+
var axis = type === 'domain' ? domain : range;
|
|
254
|
+
return {
|
|
255
|
+
min: 1,
|
|
256
|
+
max: axis.max < gridProps.min || axis.max > gridProps.max ? 16 : axis.max,
|
|
257
|
+
step: 1,
|
|
258
|
+
labelStep: 0
|
|
259
|
+
};
|
|
260
|
+
};
|
|
261
|
+
var updatedRange = _objectSpread(_objectSpread({}, range), includeAxes ? {
|
|
262
|
+
labelStep: 1
|
|
263
|
+
} : noAxesConfig('range'));
|
|
264
|
+
var updatedDomain = _objectSpread(_objectSpread({}, domain), includeAxes ? {
|
|
265
|
+
labelStep: 1
|
|
266
|
+
} : noAxesConfig('domain'));
|
|
267
|
+
onChange({
|
|
268
|
+
includeAxes: includeAxes,
|
|
269
|
+
range: updatedRange,
|
|
270
|
+
domain: updatedDomain
|
|
271
|
+
});
|
|
272
|
+
};
|
|
273
|
+
var onStandardGridChanged = function onStandardGridChanged(value) {
|
|
274
|
+
onChange({
|
|
275
|
+
standardGrid: value,
|
|
276
|
+
range: _objectSpread(_objectSpread({}, domain), {}, {
|
|
277
|
+
axisLabel: range.axisLabel
|
|
278
|
+
}),
|
|
279
|
+
graph: _objectSpread(_objectSpread({}, size), {}, {
|
|
280
|
+
height: size.width
|
|
281
|
+
})
|
|
282
|
+
});
|
|
283
|
+
};
|
|
284
|
+
var onSizeChanged = function onSizeChanged(key, value) {
|
|
285
|
+
var graph = _objectSpread(_objectSpread({}, size), {}, (0, _defineProperty2["default"])({}, key, value));
|
|
286
|
+
if (standardGrid) graph.height = value;
|
|
287
|
+
onChange({
|
|
288
|
+
graph: graph
|
|
289
|
+
});
|
|
290
|
+
};
|
|
291
|
+
var onDomainChanged = function onDomainChanged(key, value) {
|
|
292
|
+
domain[key] = value;
|
|
293
|
+
if (standardGrid && key !== 'axisLabel') range[key] = value;
|
|
294
|
+
onChange({
|
|
295
|
+
domain: domain,
|
|
296
|
+
range: range
|
|
297
|
+
});
|
|
298
|
+
};
|
|
299
|
+
var onRangeChanged = function onRangeChanged(key, value) {
|
|
300
|
+
range[key] = value;
|
|
301
|
+
onChange({
|
|
302
|
+
range: range
|
|
303
|
+
});
|
|
304
|
+
};
|
|
305
|
+
var axesConfig = /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(RowView, null, /*#__PURE__*/_react["default"].createElement(AxisConfig, {
|
|
306
|
+
displayedFields: axisConfigFields,
|
|
307
|
+
displayHeader: displayAxisType,
|
|
308
|
+
type: "domain",
|
|
309
|
+
minValue: domain.min,
|
|
310
|
+
maxValue: domain.max,
|
|
311
|
+
label: domain.axisLabel,
|
|
312
|
+
includeAxes: includeAxes,
|
|
313
|
+
onChange: onDomainChanged
|
|
314
|
+
}), /*#__PURE__*/_react["default"].createElement(AxisConfig, {
|
|
315
|
+
displayedFields: axisConfigFields,
|
|
316
|
+
displayHeader: displayAxisType,
|
|
317
|
+
type: "range",
|
|
318
|
+
minValue: range.min,
|
|
319
|
+
maxValue: range.max,
|
|
320
|
+
label: range.axisLabel,
|
|
321
|
+
disabled: standardGrid,
|
|
322
|
+
includeAxes: includeAxes,
|
|
323
|
+
onChange: onRangeChanged
|
|
324
|
+
})), (min.enabled || max.enabled) && /*#__PURE__*/_react["default"].createElement(ItalicText, null, "If you want the axis to be visible, use a zero or negative Min Value, and a positive Max Value"), (step.enabled || labelStep.enabled) && /*#__PURE__*/_react["default"].createElement(RowView, null, /*#__PURE__*/_react["default"].createElement(GridConfig, {
|
|
325
|
+
displayedFields: gridConfigFields,
|
|
326
|
+
gridValue: domain.step,
|
|
327
|
+
labelValue: domain.labelStep,
|
|
328
|
+
gridValues: gridValues.domain || [],
|
|
329
|
+
labelValues: labelValues.domain || [],
|
|
330
|
+
onChange: onDomainChanged
|
|
331
|
+
}), /*#__PURE__*/_react["default"].createElement(GridConfig, {
|
|
332
|
+
disabled: standardGrid,
|
|
333
|
+
displayedFields: gridConfigFields,
|
|
334
|
+
gridValue: range.step,
|
|
335
|
+
labelValue: range.labelStep,
|
|
336
|
+
gridValues: gridValues.range || [],
|
|
337
|
+
labelValues: labelValues.range || [],
|
|
338
|
+
onChange: onRangeChanged
|
|
339
|
+
})), labelStep.enabled && /*#__PURE__*/_react["default"].createElement(ItalicText, null, "For unnumbered gridlines, enter a label interval of 0"));
|
|
340
|
+
var gridlinesConfig = max.enabled ? /*#__PURE__*/_react["default"].createElement(ColumnView, null, /*#__PURE__*/_react["default"].createElement(TextFieldLarge, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
341
|
+
label: "Number of Vertical Gridlines",
|
|
342
|
+
value: domain.max,
|
|
343
|
+
min: !includeAxes && gridProps.min,
|
|
344
|
+
max: !includeAxes && gridProps.max,
|
|
345
|
+
variant: "outlined",
|
|
346
|
+
onChange: function onChange(e, v) {
|
|
347
|
+
return onDomainChanged('max', v);
|
|
348
|
+
}
|
|
349
|
+
})), /*#__PURE__*/_react["default"].createElement(TextFieldLarge, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
350
|
+
label: "Number of Horizontal Gridlines",
|
|
351
|
+
value: range.max,
|
|
352
|
+
min: !includeAxes && gridProps.min,
|
|
353
|
+
max: !includeAxes && gridProps.max,
|
|
354
|
+
variant: "outlined",
|
|
355
|
+
disabled: standardGrid,
|
|
356
|
+
onChange: function onChange(e, v) {
|
|
357
|
+
return onRangeChanged('max', v);
|
|
358
|
+
}
|
|
359
|
+
}))) : null;
|
|
360
|
+
return /*#__PURE__*/_react["default"].createElement(Wrapper, null, /*#__PURE__*/_react["default"].createElement(_material.Accordion, {
|
|
361
|
+
onChange: onChangeView,
|
|
362
|
+
TransitionProps: {
|
|
363
|
+
timeout: {
|
|
364
|
+
enter: 225,
|
|
365
|
+
exit: 195
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
}, /*#__PURE__*/_react["default"].createElement(_material.AccordionSummary, {
|
|
369
|
+
expandIcon: /*#__PURE__*/_react["default"].createElement(_ExpandMore["default"], null)
|
|
370
|
+
}, /*#__PURE__*/_react["default"].createElement(_material.Typography, {
|
|
371
|
+
variant: "subtitle1"
|
|
372
|
+
}, "Customize Grid Setup")), /*#__PURE__*/_react["default"].createElement(_material.AccordionDetails, null, /*#__PURE__*/_react["default"].createElement(Content, null, includeAxesEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.Toggle, {
|
|
373
|
+
label: "Include axes and labels?",
|
|
374
|
+
toggle: onIncludeAxes,
|
|
375
|
+
checked: includeAxes
|
|
376
|
+
}), standardGridEnabled && /*#__PURE__*/_react["default"].createElement(_configUi.Toggle, {
|
|
377
|
+
label: "Constrain to standard coordinate grid?",
|
|
378
|
+
toggle: onStandardGridChanged,
|
|
379
|
+
checked: standardGrid
|
|
380
|
+
}), includeAxes ? axesConfig : gridlinesConfig, dimensionsEnabled && /*#__PURE__*/_react["default"].createElement(Dimensions, null, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_material.Typography, null, "Dimensions(px)"), /*#__PURE__*/_react["default"].createElement(DisabledText, null, "Min ", sizeConstraints.min, ", Max ", sizeConstraints.max)), /*#__PURE__*/_react["default"].createElement(TextFieldSmall, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
381
|
+
label: "Width",
|
|
382
|
+
value: size.width,
|
|
383
|
+
min: sizeConstraints.min,
|
|
384
|
+
max: sizeConstraints.max,
|
|
385
|
+
step: sizeConstraints.step,
|
|
386
|
+
variant: "outlined",
|
|
387
|
+
onChange: function onChange(e, v) {
|
|
388
|
+
return onSizeChanged('width', v);
|
|
389
|
+
}
|
|
390
|
+
})), /*#__PURE__*/_react["default"].createElement(TextFieldSmall, null, /*#__PURE__*/_react["default"].createElement(_configUi.NumberTextFieldCustom, {
|
|
391
|
+
label: "Height",
|
|
392
|
+
value: size.height,
|
|
393
|
+
min: sizeConstraints.min,
|
|
394
|
+
max: sizeConstraints.max,
|
|
395
|
+
step: sizeConstraints.step,
|
|
396
|
+
variant: "outlined",
|
|
397
|
+
disabled: standardGrid,
|
|
398
|
+
onChange: function onChange(e, v) {
|
|
399
|
+
return onSizeChanged('height', v);
|
|
400
|
+
}
|
|
401
|
+
})))))));
|
|
402
|
+
};
|
|
403
|
+
GridSetup.propTypes = {
|
|
404
|
+
domain: _propTypes["default"].object,
|
|
405
|
+
displayedFields: _propTypes["default"].object,
|
|
406
|
+
gridValues: _propTypes["default"].object,
|
|
407
|
+
includeAxes: _propTypes["default"].bool,
|
|
408
|
+
labelValues: _propTypes["default"].object,
|
|
409
|
+
onChange: _propTypes["default"].func,
|
|
410
|
+
onChangeView: _propTypes["default"].func,
|
|
411
|
+
range: _propTypes["default"].object,
|
|
412
|
+
size: _propTypes["default"].object,
|
|
413
|
+
sizeConstraints: _propTypes["default"].object,
|
|
414
|
+
standardGrid: _propTypes["default"].bool
|
|
415
|
+
};
|
|
416
|
+
var _default = exports["default"] = GridSetup;
|
|
417
|
+
//# sourceMappingURL=grid-setup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grid-setup.js","names":["_react","_interopRequireDefault","require","_propTypes","_renderUi","_material","_ExpandMore","_configUi","_editableHtmlTipTap","_styles","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","Wrapper","styled","width","Content","display","flexDirection","ColumnView","alignItems","RowView","justifyContent","TextFieldSmall","_ref","theme","margin","concat","spacing","TextFieldMedium","_ref2","TextFieldLarge","_ref3","ItalicText","Typography","_ref4","fontStyle","Dimensions","DisabledText","color","disabled","AxisLabel","_ref5","paddingTop","GridConfig","props","displayedFields","labelValue","labelValues","gridValue","gridValues","onChange","_displayedFields$labe","labelStep","_displayedFields$step","step","createElement","enabled","NumberTextFieldCustom","label","value","customValues","variant","v","propTypes","PropTypes","bool","object","number","array","func","AxisConfig","displayHeader","maxValue","minValue","type","_displayedFields$axis","axisLabel","_displayedFields$min","min","_displayedFields$max","max","activePlugins","InputContainer","markup","charactersLimit","string","GridSetup","domain","_props$displayedField","_props$gridValues","includeAxes","_props$labelValues","onChangeView","range","size","sizeConstraints","standardGrid","gridProps","_ref6","_ref6$axisLabel","dimensionsEnabled","includeAxesEnabled","_ref6$labelStep","_ref6$min","_ref6$max","standardGridEnabled","_ref6$step","displayAxisType","gridConfigFields","axisConfigFields","onIncludeAxes","noAxesConfig","axis","updatedRange","updatedDomain","onStandardGridChanged","graph","height","onSizeChanged","key","onDomainChanged","onRangeChanged","axesConfig","Fragment","gridlinesConfig","Accordion","TransitionProps","timeout","enter","exit","AccordionSummary","expandIcon","AccordionDetails","Toggle","toggle","checked","_default","exports"],"sources":["../src/grid-setup.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { color, InputContainer } from '@pie-lib/render-ui';\nimport { Accordion, AccordionSummary, AccordionDetails, Typography } from '@mui/material';\nimport ExpandMoreIcon from '@mui/icons-material/ExpandMore';\nimport { NumberTextFieldCustom, Toggle } from '@pie-lib/config-ui';\nimport EditableHTML from '@pie-lib/editable-html-tip-tap';\nimport { styled } from '@mui/material/styles';\n\nconst Wrapper = styled('div')(() => ({\n width: '450px',\n}));\n\nconst Content = styled('div')(() => ({\n display: 'flex',\n flexDirection: 'column',\n width: '100%',\n}));\n\nconst ColumnView = styled('div')(() => ({\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n}));\n\nconst RowView = styled('div')(() => ({\n display: 'flex',\n justifyContent: 'space-around',\n alignItems: 'center',\n}));\n\nconst TextFieldSmall = styled('div')(({ theme }) => ({\n width: '130px',\n margin: `${theme.spacing(1)} ${theme.spacing(0.5)}`,\n}));\n\nconst TextFieldMedium = styled('div')(({ theme }) => ({\n width: '160px',\n margin: `${theme.spacing(1)} ${theme.spacing(0.5)}`,\n '& .MuiFormControl-root': {\n width: '100%',\n },\n}));\n\nconst TextFieldLarge = styled('div')(({ theme }) => ({\n width: '230px',\n margin: `${theme.spacing(1)} ${theme.spacing(0.5)}`,\n '& .MuiFormControl-root': {\n width: '100%',\n },\n}));\n\nconst ItalicText = styled(Typography)(({ theme }) => ({\n fontStyle: 'italic',\n margin: `${theme.spacing(1)} 0`,\n}));\n\nconst Dimensions = styled('div')(() => ({\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n}));\n\nconst DisabledText = styled(Typography)(() => ({\n color: color.disabled(),\n}));\n\nconst AxisLabel = styled('div')(({ theme }) => ({\n paddingTop: theme.spacing(2),\n}));\n\nconst GridConfig = (props) => {\n const { disabled, displayedFields, labelValue, labelValues, gridValue, gridValues, onChange } = props;\n const { labelStep = {}, step = {} } = displayedFields;\n\n return (\n <ColumnView>\n {step && step.enabled && (\n <TextFieldMedium>\n <NumberTextFieldCustom\n label={step.label || ''}\n value={gridValue}\n customValues={gridValues}\n variant=\"outlined\"\n disabled={disabled}\n onChange={(e, v) => onChange('step', v)}\n />\n </TextFieldMedium>\n )}\n {labelStep && labelStep.enabled && (\n <TextFieldMedium>\n <NumberTextFieldCustom\n label={labelStep.label || ''}\n value={labelValue}\n customValues={labelValues}\n variant=\"outlined\"\n disabled={disabled}\n onChange={(e, v) => onChange('labelStep', v)}\n />\n </TextFieldMedium>\n )}\n </ColumnView>\n );\n};\n\nGridConfig.propTypes = {\n disabled: PropTypes.bool,\n displayedFields: PropTypes.object,\n labelValue: PropTypes.number,\n labelValues: PropTypes.array,\n gridValue: PropTypes.number,\n gridValues: PropTypes.array,\n onChange: PropTypes.func,\n};\n\nconst AxisConfig = (props) => {\n const { disabled, displayedFields, displayHeader, label, maxValue, minValue, onChange, type } = props;\n const { axisLabel = {}, min = {}, max = {} } = displayedFields;\n const activePlugins = ['bold', 'italic', 'underline', 'strikethrough'];\n\n return (\n <ColumnView>\n {displayHeader && (\n <Typography variant=\"subtitle2\">\n <i>{type === 'domain' ? 'x' : 'y'}</i>-axis\n </Typography>\n )}\n {min && min.enabled && (\n <TextFieldMedium>\n <NumberTextFieldCustom\n label={min.label || ''}\n value={minValue}\n min={-10000}\n max={maxValue - 0.05}\n variant=\"outlined\"\n disabled={disabled}\n onChange={(e, v) => onChange('min', v)}\n />\n </TextFieldMedium>\n )}\n {max && max.enabled && (\n <TextFieldMedium>\n <NumberTextFieldCustom\n label={max.label || ''}\n value={maxValue}\n min={minValue + 0.05}\n max={10000}\n variant=\"outlined\"\n disabled={disabled}\n onChange={(e, v) => onChange('max', v)}\n />\n </TextFieldMedium>\n )}\n {axisLabel && axisLabel.enabled && (\n <TextFieldMedium>\n <InputContainer label={axisLabel.label || ''}>\n <AxisLabel>\n <EditableHTML\n onChange={(value) => onChange('axisLabel', value)}\n markup={label || ''}\n charactersLimit={5}\n activePlugins={activePlugins}\n />\n </AxisLabel>\n </InputContainer>\n </TextFieldMedium>\n )}\n </ColumnView>\n );\n};\n\nAxisConfig.propTypes = {\n disabled: PropTypes.bool,\n displayedFields: PropTypes.object,\n displayHeader: PropTypes.bool,\n label: PropTypes.string,\n maxValue: PropTypes.number,\n minValue: PropTypes.number,\n type: PropTypes.string,\n onChange: PropTypes.func,\n};\n\nconst GridSetup = (props) => {\n const {\n domain,\n displayedFields = {},\n gridValues = {},\n includeAxes,\n labelValues = {},\n onChange,\n onChangeView,\n range,\n size,\n sizeConstraints,\n standardGrid,\n } = props;\n\n const gridProps = { min: 2, max: 41 };\n const {\n axisLabel = {},\n dimensionsEnabled,\n includeAxesEnabled,\n labelStep = {},\n min = {},\n max = {},\n standardGridEnabled,\n step = {},\n } = displayedFields || {};\n\n const displayAxisType = min.enabled || max.enabled || axisLabel.enabled || step.enabled || labelStep.enabled;\n const gridConfigFields = { step, labelStep };\n const axisConfigFields = { min, max, axisLabel };\n\n const onIncludeAxes = (includeAxes) => {\n const noAxesConfig = (type) => {\n const axis = type === 'domain' ? domain : range;\n return {\n min: 1,\n max: axis.max < gridProps.min || axis.max > gridProps.max ? 16 : axis.max,\n step: 1,\n labelStep: 0,\n };\n };\n\n const updatedRange = {\n ...range,\n ...(includeAxes ? { labelStep: 1 } : noAxesConfig('range')),\n };\n const updatedDomain = {\n ...domain,\n ...(includeAxes ? { labelStep: 1 } : noAxesConfig('domain')),\n };\n\n onChange({ includeAxes, range: updatedRange, domain: updatedDomain });\n };\n\n const onStandardGridChanged = (value) => {\n onChange({\n standardGrid: value,\n range: {\n ...domain,\n axisLabel: range.axisLabel,\n },\n graph: {\n ...size,\n height: size.width,\n },\n });\n };\n\n const onSizeChanged = (key, value) => {\n const graph = { ...size, [key]: value };\n if (standardGrid) graph.height = value;\n onChange({ graph });\n };\n\n const onDomainChanged = (key, value) => {\n domain[key] = value;\n if (standardGrid && key !== 'axisLabel') range[key] = value;\n onChange({ domain, range });\n };\n\n const onRangeChanged = (key, value) => {\n range[key] = value;\n onChange({ range });\n };\n\n const axesConfig = (\n <>\n <RowView>\n <AxisConfig\n displayedFields={axisConfigFields}\n displayHeader={displayAxisType}\n type=\"domain\"\n minValue={domain.min}\n maxValue={domain.max}\n label={domain.axisLabel}\n includeAxes={includeAxes}\n onChange={onDomainChanged}\n />\n <AxisConfig\n displayedFields={axisConfigFields}\n displayHeader={displayAxisType}\n type=\"range\"\n minValue={range.min}\n maxValue={range.max}\n label={range.axisLabel}\n disabled={standardGrid}\n includeAxes={includeAxes}\n onChange={onRangeChanged}\n />\n </RowView>\n {(min.enabled || max.enabled) && (\n <ItalicText>\n If you want the axis to be visible, use a zero or negative Min Value, and a positive Max Value\n </ItalicText>\n )}\n {(step.enabled || labelStep.enabled) && (\n <RowView>\n <GridConfig\n displayedFields={gridConfigFields}\n gridValue={domain.step}\n labelValue={domain.labelStep}\n gridValues={gridValues.domain || []}\n labelValues={labelValues.domain || []}\n onChange={onDomainChanged}\n />\n <GridConfig\n disabled={standardGrid}\n displayedFields={gridConfigFields}\n gridValue={range.step}\n labelValue={range.labelStep}\n gridValues={gridValues.range || []}\n labelValues={labelValues.range || []}\n onChange={onRangeChanged}\n />\n </RowView>\n )}\n {labelStep.enabled && <ItalicText>For unnumbered gridlines, enter a label interval of 0</ItalicText>}\n </>\n );\n\n const gridlinesConfig = max.enabled ? (\n <ColumnView>\n <TextFieldLarge>\n <NumberTextFieldCustom\n label=\"Number of Vertical Gridlines\"\n value={domain.max}\n min={!includeAxes && gridProps.min}\n max={!includeAxes && gridProps.max}\n variant=\"outlined\"\n onChange={(e, v) => onDomainChanged('max', v)}\n />\n </TextFieldLarge>\n <TextFieldLarge>\n <NumberTextFieldCustom\n label=\"Number of Horizontal Gridlines\"\n value={range.max}\n min={!includeAxes && gridProps.min}\n max={!includeAxes && gridProps.max}\n variant=\"outlined\"\n disabled={standardGrid}\n onChange={(e, v) => onRangeChanged('max', v)}\n />\n </TextFieldLarge>\n </ColumnView>\n ) : null;\n\n return (\n <Wrapper>\n <Accordion onChange={onChangeView} TransitionProps={{ timeout: { enter: 225, exit: 195 } }}>\n <AccordionSummary expandIcon={<ExpandMoreIcon />}>\n <Typography variant=\"subtitle1\">Customize Grid Setup</Typography>\n </AccordionSummary>\n <AccordionDetails>\n <Content>\n {includeAxesEnabled && (\n <Toggle label=\"Include axes and labels?\" toggle={onIncludeAxes} checked={includeAxes} />\n )}\n {standardGridEnabled && (\n <Toggle\n label=\"Constrain to standard coordinate grid?\"\n toggle={onStandardGridChanged}\n checked={standardGrid}\n />\n )}\n {includeAxes ? axesConfig : gridlinesConfig}\n {dimensionsEnabled && (\n <Dimensions>\n <div>\n <Typography>Dimensions(px)</Typography>\n <DisabledText>\n Min {sizeConstraints.min}, Max {sizeConstraints.max}\n </DisabledText>\n </div>\n <TextFieldSmall>\n <NumberTextFieldCustom\n label=\"Width\"\n value={size.width}\n min={sizeConstraints.min}\n max={sizeConstraints.max}\n step={sizeConstraints.step}\n variant=\"outlined\"\n onChange={(e, v) => onSizeChanged('width', v)}\n />\n </TextFieldSmall>\n <TextFieldSmall>\n <NumberTextFieldCustom\n label=\"Height\"\n value={size.height}\n min={sizeConstraints.min}\n max={sizeConstraints.max}\n step={sizeConstraints.step}\n variant=\"outlined\"\n disabled={standardGrid}\n onChange={(e, v) => onSizeChanged('height', v)}\n />\n </TextFieldSmall>\n </Dimensions>\n )}\n </Content>\n </AccordionDetails>\n </Accordion>\n </Wrapper>\n );\n};\n\nGridSetup.propTypes = {\n domain: PropTypes.object,\n displayedFields: PropTypes.object,\n gridValues: PropTypes.object,\n includeAxes: PropTypes.bool,\n labelValues: PropTypes.object,\n onChange: PropTypes.func,\n onChangeView: PropTypes.func,\n range: PropTypes.object,\n size: PropTypes.object,\n sizeConstraints: PropTypes.object,\n standardGrid: PropTypes.bool,\n};\n\nexport default GridSetup;\n"],"mappings":"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","ignoreList":[]}
|
package/lib/grid.js
ADDED
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.symbol.js");
|
|
4
|
+
require("core-js/modules/es.array.for-each.js");
|
|
5
|
+
require("core-js/modules/es.array.iterator.js");
|
|
6
|
+
require("core-js/modules/es.object.define-properties.js");
|
|
7
|
+
require("core-js/modules/es.object.define-property.js");
|
|
8
|
+
require("core-js/modules/es.object.get-own-property-descriptor.js");
|
|
9
|
+
require("core-js/modules/es.object.get-own-property-descriptors.js");
|
|
10
|
+
require("core-js/modules/es.object.keys.js");
|
|
11
|
+
require("core-js/modules/es.reflect.construct.js");
|
|
12
|
+
require("core-js/modules/es.string.iterator.js");
|
|
13
|
+
require("core-js/modules/es.weak-map.js");
|
|
14
|
+
require("core-js/modules/web.dom-collections.for-each.js");
|
|
15
|
+
require("core-js/modules/web.dom-collections.iterator.js");
|
|
16
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
17
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
18
|
+
Object.defineProperty(exports, "__esModule", {
|
|
19
|
+
value: true
|
|
20
|
+
});
|
|
21
|
+
exports["default"] = exports.Grid = void 0;
|
|
22
|
+
require("core-js/modules/es.array.concat.js");
|
|
23
|
+
require("core-js/modules/es.array.filter.js");
|
|
24
|
+
require("core-js/modules/es.array.includes.js");
|
|
25
|
+
require("core-js/modules/es.date.to-string.js");
|
|
26
|
+
require("core-js/modules/es.object.to-string.js");
|
|
27
|
+
require("core-js/modules/es.regexp.exec.js");
|
|
28
|
+
require("core-js/modules/es.regexp.to-string.js");
|
|
29
|
+
require("core-js/modules/es.string.includes.js");
|
|
30
|
+
require("core-js/modules/es.string.replace.js");
|
|
31
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
32
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
33
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
34
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
35
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
36
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
37
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
38
|
+
var _react = _interopRequireDefault(require("react"));
|
|
39
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
40
|
+
var vx = _interopRequireWildcard(require("@visx/grid"));
|
|
41
|
+
var _plot = require("@pie-lib/plot");
|
|
42
|
+
var _utils = require("./utils");
|
|
43
|
+
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); }
|
|
44
|
+
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; }
|
|
45
|
+
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; }
|
|
46
|
+
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)); }
|
|
47
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
48
|
+
var Grid = exports.Grid = /*#__PURE__*/function (_React$Component) {
|
|
49
|
+
function Grid() {
|
|
50
|
+
var _this;
|
|
51
|
+
(0, _classCallCheck2["default"])(this, Grid);
|
|
52
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
53
|
+
args[_key] = arguments[_key];
|
|
54
|
+
}
|
|
55
|
+
_this = _callSuper(this, Grid, [].concat(args));
|
|
56
|
+
(0, _defineProperty2["default"])(_this, "getAdditionalGridProps", function (rowTickValues, columnTickValues) {
|
|
57
|
+
var _this$props$graphProp = _this.props.graphProps,
|
|
58
|
+
scale = _this$props$graphProp.scale,
|
|
59
|
+
_this$props$graphProp2 = _this$props$graphProp.size,
|
|
60
|
+
width = _this$props$graphProp2.width,
|
|
61
|
+
height = _this$props$graphProp2.height,
|
|
62
|
+
domain = _this$props$graphProp.domain,
|
|
63
|
+
range = _this$props$graphProp.range;
|
|
64
|
+
var rowTickLabelValues = (0, _utils.getTickValues)(_objectSpread(_objectSpread({}, range), {}, {
|
|
65
|
+
step: range.labelStep
|
|
66
|
+
})).filter(function (value) {
|
|
67
|
+
return rowTickValues.includes(value);
|
|
68
|
+
});
|
|
69
|
+
var columnTickLabelValues = (0, _utils.getTickValues)(_objectSpread(_objectSpread({}, domain), {}, {
|
|
70
|
+
step: domain.labelStep
|
|
71
|
+
})).filter(function (value) {
|
|
72
|
+
return columnTickValues.includes(value);
|
|
73
|
+
});
|
|
74
|
+
var minValueLength = rowTickLabelValues.length && Math.min.apply(Math, (0, _toConsumableArray2["default"])(rowTickLabelValues)).toString().replace(/[.-]/g, '').length || 1;
|
|
75
|
+
var maxValueLength = rowTickLabelValues.length && Math.max.apply(Math, (0, _toConsumableArray2["default"])(rowTickLabelValues)).toString().replace(/[.-]/g, '').length || 1;
|
|
76
|
+
var rowLabelLength = Math.max(minValueLength, maxValueLength) * 9 + 22;
|
|
77
|
+
var horizontalDistanceToZero = scale.x(0);
|
|
78
|
+
var verticalDistanceToZero = scale.y(0);
|
|
79
|
+
var columnLabelLength = 28;
|
|
80
|
+
var rowStrokeDasharray = "".concat(horizontalDistanceToZero - rowLabelLength, " ").concat(rowLabelLength, " ").concat(width);
|
|
81
|
+
var columnStrokeDasharray = "".concat(verticalDistanceToZero, " ").concat(columnLabelLength, " ").concat(height);
|
|
82
|
+
var displayAdditionalGrid = domain.labelStep > 0 && range.labelStep > 0 && rowTickLabelValues && columnTickLabelValues && rowTickLabelValues.length > 1 && columnTickLabelValues.length > 1 && (rowTickLabelValues.length !== rowTickValues.length || columnTickLabelValues.length !== columnTickValues.length);
|
|
83
|
+
var filteredColumnValues = columnTickLabelValues.filter(function (value) {
|
|
84
|
+
return value >= 0 || horizontalDistanceToZero - scale.x(value) > rowLabelLength;
|
|
85
|
+
});
|
|
86
|
+
var filteredRowValues = rowTickLabelValues.filter(function (value) {
|
|
87
|
+
return value >= 0 || scale.y(value) - verticalDistanceToZero > columnLabelLength;
|
|
88
|
+
});
|
|
89
|
+
return {
|
|
90
|
+
rowTickLabelValues: filteredRowValues,
|
|
91
|
+
columnTickLabelValues: filteredColumnValues,
|
|
92
|
+
rowStrokeDasharray: rowStrokeDasharray,
|
|
93
|
+
columnStrokeDasharray: columnStrokeDasharray,
|
|
94
|
+
displayAdditionalGrid: displayAdditionalGrid
|
|
95
|
+
};
|
|
96
|
+
});
|
|
97
|
+
return _this;
|
|
98
|
+
}
|
|
99
|
+
(0, _inherits2["default"])(Grid, _React$Component);
|
|
100
|
+
return (0, _createClass2["default"])(Grid, [{
|
|
101
|
+
key: "render",
|
|
102
|
+
value: function render() {
|
|
103
|
+
var _this2 = this;
|
|
104
|
+
var graphProps = this.props.graphProps;
|
|
105
|
+
var scale = graphProps.scale,
|
|
106
|
+
_graphProps$size = graphProps.size,
|
|
107
|
+
height = _graphProps$size.height,
|
|
108
|
+
width = _graphProps$size.width,
|
|
109
|
+
domain = graphProps.domain,
|
|
110
|
+
range = graphProps.range;
|
|
111
|
+
var rowTickValues = (0, _utils.getTickValues)(range);
|
|
112
|
+
var columnTickValues = (0, _utils.getTickValues)(domain);
|
|
113
|
+
var _this$getAdditionalGr = this.getAdditionalGridProps(rowTickValues, columnTickValues),
|
|
114
|
+
rowTickLabelValues = _this$getAdditionalGr.rowTickLabelValues,
|
|
115
|
+
columnTickLabelValues = _this$getAdditionalGr.columnTickLabelValues,
|
|
116
|
+
rowStrokeDasharray = _this$getAdditionalGr.rowStrokeDasharray,
|
|
117
|
+
columnStrokeDasharray = _this$getAdditionalGr.columnStrokeDasharray,
|
|
118
|
+
displayAdditionalGrid = _this$getAdditionalGr.displayAdditionalGrid;
|
|
119
|
+
var additionalGridStroke = domain.labelStep * 2 === domain.step || range.labelStep * 2 === range.step ? '#9FA8DA' : '#7985CB';
|
|
120
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(vx.Grid, {
|
|
121
|
+
innerRef: function innerRef(r) {
|
|
122
|
+
return _this2.grid = r;
|
|
123
|
+
},
|
|
124
|
+
xScale: scale.x,
|
|
125
|
+
yScale: scale.y,
|
|
126
|
+
width: width,
|
|
127
|
+
height: height,
|
|
128
|
+
stroke: "#D3D3D3",
|
|
129
|
+
rowTickValues: rowTickValues,
|
|
130
|
+
columnTickValues: columnTickValues
|
|
131
|
+
}), displayAdditionalGrid && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(vx.GridRows, {
|
|
132
|
+
scale: scale.y,
|
|
133
|
+
width: width,
|
|
134
|
+
tickValues: rowTickLabelValues,
|
|
135
|
+
stroke: additionalGridStroke,
|
|
136
|
+
strokeDasharray: rowStrokeDasharray
|
|
137
|
+
}), /*#__PURE__*/_react["default"].createElement(vx.GridColumns, {
|
|
138
|
+
scale: scale.x,
|
|
139
|
+
height: height,
|
|
140
|
+
tickValues: columnTickLabelValues,
|
|
141
|
+
stroke: additionalGridStroke,
|
|
142
|
+
strokeDasharray: columnStrokeDasharray
|
|
143
|
+
})));
|
|
144
|
+
}
|
|
145
|
+
}]);
|
|
146
|
+
}(_react["default"].Component);
|
|
147
|
+
(0, _defineProperty2["default"])(Grid, "propTypes", {
|
|
148
|
+
disabled: _propTypes["default"].bool,
|
|
149
|
+
disabledAdditionalGrid: _propTypes["default"].bool,
|
|
150
|
+
graphProps: _plot.types.GraphPropsType.isRequired
|
|
151
|
+
});
|
|
152
|
+
var _default = exports["default"] = Grid;
|
|
153
|
+
//# sourceMappingURL=grid.js.map
|