@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.
Files changed (84) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/NEXT.CHANGELOG.json +16 -1
  3. package/lib/axis/arrow.js +82 -0
  4. package/lib/axis/arrow.js.map +1 -0
  5. package/lib/axis/axes.js +341 -0
  6. package/lib/axis/axes.js.map +1 -0
  7. package/lib/axis/index.js +28 -0
  8. package/lib/axis/index.js.map +1 -0
  9. package/lib/bg.js +120 -0
  10. package/lib/bg.js.map +1 -0
  11. package/lib/container/actions.js +19 -0
  12. package/lib/container/actions.js.map +1 -0
  13. package/lib/container/index.js +126 -0
  14. package/lib/container/index.js.map +1 -0
  15. package/lib/container/marks.js +24 -0
  16. package/lib/container/marks.js.map +1 -0
  17. package/lib/container/middleware.js +20 -0
  18. package/lib/container/middleware.js.map +1 -0
  19. package/lib/container/reducer.js +19 -0
  20. package/lib/container/reducer.js.map +1 -0
  21. package/lib/coordinates-label.js +88 -0
  22. package/lib/coordinates-label.js.map +1 -0
  23. package/lib/graph-with-controls.js +316 -0
  24. package/lib/graph-with-controls.js.map +1 -0
  25. package/lib/graph.js +372 -0
  26. package/lib/graph.js.map +1 -0
  27. package/lib/grid-setup.js +417 -0
  28. package/lib/grid-setup.js.map +1 -0
  29. package/lib/grid.js +153 -0
  30. package/lib/grid.js.map +1 -0
  31. package/lib/index.js +47 -0
  32. package/lib/index.js.map +1 -0
  33. package/lib/labels.js +212 -0
  34. package/lib/labels.js.map +1 -0
  35. package/lib/mark-label.js +175 -0
  36. package/lib/mark-label.js.map +1 -0
  37. package/lib/toggle-bar.js +265 -0
  38. package/lib/toggle-bar.js.map +1 -0
  39. package/lib/tool-menu.js +221 -0
  40. package/lib/tool-menu.js.map +1 -0
  41. package/lib/tools/index.js +25 -0
  42. package/lib/tools/index.js.map +1 -0
  43. package/lib/tools/line/component.js +105 -0
  44. package/lib/tools/line/component.js.map +1 -0
  45. package/lib/tools/line/index.js +12 -0
  46. package/lib/tools/line/index.js.map +1 -0
  47. package/lib/tools/polygon/component.js +378 -0
  48. package/lib/tools/polygon/component.js.map +1 -0
  49. package/lib/tools/polygon/index.js +101 -0
  50. package/lib/tools/polygon/index.js.map +1 -0
  51. package/lib/tools/polygon/line.js +130 -0
  52. package/lib/tools/polygon/line.js.map +1 -0
  53. package/lib/tools/polygon/polygon.js +150 -0
  54. package/lib/tools/polygon/polygon.js.map +1 -0
  55. package/lib/tools/shared/arrow-head.js +65 -0
  56. package/lib/tools/shared/arrow-head.js.map +1 -0
  57. package/lib/tools/shared/line/index.js +554 -0
  58. package/lib/tools/shared/line/index.js.map +1 -0
  59. package/lib/tools/shared/line/line-path.js +137 -0
  60. package/lib/tools/shared/line/line-path.js.map +1 -0
  61. package/lib/tools/shared/line/with-root-edge.js +132 -0
  62. package/lib/tools/shared/line/with-root-edge.js.map +1 -0
  63. package/lib/tools/shared/point/arrow-point.js +89 -0
  64. package/lib/tools/shared/point/arrow-point.js.map +1 -0
  65. package/lib/tools/shared/point/arrow.js +73 -0
  66. package/lib/tools/shared/point/arrow.js.map +1 -0
  67. package/lib/tools/shared/point/base-point.js +148 -0
  68. package/lib/tools/shared/point/base-point.js.map +1 -0
  69. package/lib/tools/shared/point/index.js +96 -0
  70. package/lib/tools/shared/point/index.js.map +1 -0
  71. package/lib/tools/shared/styles.js +27 -0
  72. package/lib/tools/shared/styles.js.map +1 -0
  73. package/lib/tools/shared/types.js +16 -0
  74. package/lib/tools/shared/types.js.map +1 -0
  75. package/lib/undo-redo.js +69 -0
  76. package/lib/undo-redo.js.map +1 -0
  77. package/lib/use-debounce.js +27 -0
  78. package/lib/use-debounce.js.map +1 -0
  79. package/lib/utils.js +253 -0
  80. package/lib/utils.js.map +1 -0
  81. package/package.json +14 -14
  82. package/src/__tests__/graph-with-controls.test.jsx +41 -0
  83. package/src/__tests__/toggle-bar.test.jsx +41 -0
  84. 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