@pie-lib/charting 5.16.0-beta.1 → 5.16.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/package.json +6 -6
  3. package/lib/axes.js +0 -643
  4. package/lib/axes.js.map +0 -1
  5. package/lib/bars/bar.js +0 -86
  6. package/lib/bars/bar.js.map +0 -1
  7. package/lib/bars/common/bars.js +0 -301
  8. package/lib/bars/common/bars.js.map +0 -1
  9. package/lib/bars/histogram.js +0 -87
  10. package/lib/bars/histogram.js.map +0 -1
  11. package/lib/chart-setup.js +0 -458
  12. package/lib/chart-setup.js.map +0 -1
  13. package/lib/chart-type.js +0 -71
  14. package/lib/chart-type.js.map +0 -1
  15. package/lib/chart-types.js +0 -31
  16. package/lib/chart-types.js.map +0 -1
  17. package/lib/chart.js +0 -438
  18. package/lib/chart.js.map +0 -1
  19. package/lib/common/drag-handle.js +0 -175
  20. package/lib/common/drag-handle.js.map +0 -1
  21. package/lib/common/drag-icon.js +0 -52
  22. package/lib/common/drag-icon.js.map +0 -1
  23. package/lib/common/styles.js +0 -40
  24. package/lib/common/styles.js.map +0 -1
  25. package/lib/grid.js +0 -104
  26. package/lib/grid.js.map +0 -1
  27. package/lib/index.js +0 -40
  28. package/lib/index.js.map +0 -1
  29. package/lib/line/common/drag-handle.js +0 -157
  30. package/lib/line/common/drag-handle.js.map +0 -1
  31. package/lib/line/common/line.js +0 -261
  32. package/lib/line/common/line.js.map +0 -1
  33. package/lib/line/line-cross.js +0 -168
  34. package/lib/line/line-cross.js.map +0 -1
  35. package/lib/line/line-dot.js +0 -131
  36. package/lib/line/line-dot.js.map +0 -1
  37. package/lib/mark-label.js +0 -255
  38. package/lib/mark-label.js.map +0 -1
  39. package/lib/plot/common/plot.js +0 -280
  40. package/lib/plot/common/plot.js.map +0 -1
  41. package/lib/plot/dot.js +0 -123
  42. package/lib/plot/dot.js.map +0 -1
  43. package/lib/plot/line.js +0 -152
  44. package/lib/plot/line.js.map +0 -1
  45. package/lib/tool-menu.js +0 -142
  46. package/lib/tool-menu.js.map +0 -1
  47. package/lib/utils.js +0 -244
  48. package/lib/utils.js.map +0 -1
package/lib/chart.js DELETED
@@ -1,438 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = exports.Chart = void 0;
9
-
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
-
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
15
-
16
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
17
-
18
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
19
-
20
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
21
-
22
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
23
-
24
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
25
-
26
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
27
-
28
- var _react = _interopRequireDefault(require("react"));
29
-
30
- var _propTypes = _interopRequireDefault(require("prop-types"));
31
-
32
- var _styles = require("@material-ui/core/styles");
33
-
34
- var _classnames = _interopRequireDefault(require("classnames"));
35
-
36
- var _plot = require("@pie-lib/plot");
37
-
38
- var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
39
-
40
- var _grid = _interopRequireDefault(require("./grid"));
41
-
42
- var _axes = _interopRequireDefault(require("./axes"));
43
-
44
- var _debug = _interopRequireDefault(require("debug"));
45
-
46
- var _renderUi = require("@pie-lib/render-ui");
47
-
48
- var _utils = require("./utils");
49
-
50
- var _toolMenu = _interopRequireDefault(require("./tool-menu"));
51
-
52
- var _chartTypes = _interopRequireDefault(require("./chart-types"));
53
-
54
- var _configUi = require("@pie-lib/config-ui");
55
-
56
- var _translator = _interopRequireDefault(require("@pie-lib/translator"));
57
-
58
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
59
-
60
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
61
-
62
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
63
-
64
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
65
-
66
- var translator = _translator["default"].translator;
67
- var log = (0, _debug["default"])('pie-lib:charts:chart');
68
-
69
- var Chart = /*#__PURE__*/function (_React$Component) {
70
- (0, _inherits2["default"])(Chart, _React$Component);
71
-
72
- var _super = _createSuper(Chart);
73
-
74
- function Chart(props) {
75
- var _this;
76
-
77
- (0, _classCallCheck2["default"])(this, Chart);
78
- _this = _super.call(this, props);
79
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
80
- charts: [_chartTypes["default"].Bar(), _chartTypes["default"].Histogram(), _chartTypes["default"].LineDot(), _chartTypes["default"].LineCross(), _chartTypes["default"].DotPlot(), _chartTypes["default"].LinePlot()],
81
- autoFocus: false
82
- });
83
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleAlertDialog", function (open, callback) {
84
- return _this.setState({
85
- dialog: {
86
- open: open
87
- }
88
- }, callback);
89
- });
90
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getChart", function () {
91
- var charts = _this.props.charts || _this.state.charts;
92
- var chartType = _this.props.chartType;
93
- var ChartComponent = null;
94
- var chart = null;
95
-
96
- if (chartType) {
97
- chart = charts && charts.find(function (chart) {
98
- return chart.type === chartType;
99
- });
100
- ChartComponent = chart && chart.Component;
101
- } else {
102
- chart = charts && charts[0];
103
- ChartComponent = chart && chart.Component;
104
- chartType = chart && chart.type;
105
- }
106
-
107
- return {
108
- type: chartType,
109
- ChartComponent: ChartComponent
110
- };
111
- });
112
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeData", function (data) {
113
- var onDataChange = _this.props.onDataChange;
114
- onDataChange(data);
115
- });
116
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeCategory", function (index, newCategory) {
117
- var integerIndex = parseInt(index, 10);
118
-
119
- if (integerIndex >= 0) {
120
- var _this$props = _this.props,
121
- data = _this$props.data,
122
- onDataChange = _this$props.onDataChange;
123
- data[integerIndex] = _objectSpread(_objectSpread({}, data[integerIndex]), newCategory);
124
- onDataChange(data);
125
- }
126
- });
127
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "addCategory", function () {
128
- var _this$props2 = _this.props,
129
- onDataChange = _this$props2.onDataChange,
130
- data = _this$props2.data,
131
- categoryDefaultLabel = _this$props2.categoryDefaultLabel,
132
- defineChart = _this$props2.defineChart,
133
- categoryDefaults = _this$props2.categoryDefaults,
134
- language = _this$props2.language;
135
-
136
- if ((data || []).length > 19) {
137
- _this.setState({
138
- dialog: {
139
- open: true,
140
- title: translator.t('common:warning', {
141
- lng: language
142
- }),
143
- text: translator.t('charting.reachedLimit_other', {
144
- count: 20,
145
- lng: language
146
- }),
147
- onConfirm: function onConfirm() {
148
- return _this.handleAlertDialog(false);
149
- }
150
- }
151
- });
152
- } else {
153
- _this.setState({
154
- autoFocus: true
155
- });
156
-
157
- onDataChange([].concat((0, _toConsumableArray2["default"])(data), [{
158
- inDefineChart: defineChart,
159
- label: categoryDefaultLabel || translator.t('charting.newLabel', {
160
- lng: language
161
- }),
162
- value: 0,
163
- deletable: true,
164
- editable: categoryDefaults ? categoryDefaults === null || categoryDefaults === void 0 ? void 0 : categoryDefaults.editable : true,
165
- interactive: categoryDefaults ? categoryDefaults === null || categoryDefaults === void 0 ? void 0 : categoryDefaults.interactive : true
166
- }]));
167
- }
168
- });
169
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getFilteredCategories", function () {
170
- var _this$props3 = _this.props,
171
- data = _this$props3.data,
172
- defineChart = _this$props3.defineChart;
173
- return data ? data.map(function (d) {
174
- return _objectSpread(_objectSpread({}, d), {}, {
175
- deletable: defineChart || d.deletable
176
- });
177
- }) : [];
178
- });
179
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "resetAutoFocus", function () {
180
- _this.setState({
181
- autoFocus: false
182
- });
183
- });
184
- _this.state = {
185
- dialog: {
186
- open: false
187
- }
188
- };
189
- _this.maskUid = _this.generateMaskId();
190
- return _this;
191
- }
192
-
193
- (0, _createClass2["default"])(Chart, [{
194
- key: "generateMaskId",
195
- value: function generateMaskId() {
196
- return 'chart-' + (Math.random() * 10000).toFixed();
197
- }
198
- }, {
199
- key: "render",
200
- value: function render() {
201
- var _this2 = this;
202
-
203
- var _this$props4 = this.props,
204
- classes = _this$props4.classes,
205
- className = _this$props4.className,
206
- _this$props4$domain = _this$props4.domain,
207
- domain = _this$props4$domain === void 0 ? {} : _this$props4$domain,
208
- _this$props4$range = _this$props4.range,
209
- range = _this$props4$range === void 0 ? {} : _this$props4$range,
210
- chartingOptions = _this$props4.chartingOptions,
211
- size = _this$props4.size,
212
- title = _this$props4.title,
213
- onChangeTitle = _this$props4.onChangeTitle,
214
- onChangeLabels = _this$props4.onChangeLabels,
215
- labelsPlaceholders = _this$props4.labelsPlaceholders,
216
- titlePlaceholder = _this$props4.titlePlaceholder,
217
- addCategoryEnabled = _this$props4.addCategoryEnabled,
218
- changeInteractiveEnabled = _this$props4.changeInteractiveEnabled,
219
- changeEditableEnabled = _this$props4.changeEditableEnabled,
220
- showPixelGuides = _this$props4.showPixelGuides,
221
- error = _this$props4.error,
222
- _this$props4$mathMlOp = _this$props4.mathMlOptions,
223
- mathMlOptions = _this$props4$mathMlOp === void 0 ? {} : _this$props4$mathMlOp,
224
- language = _this$props4.language,
225
- labelsCharactersLimit = _this$props4.labelsCharactersLimit;
226
- var chartType = this.props.chartType;
227
- var dialog = this.state.dialog;
228
- var defineChart = this.props.defineChart || false;
229
-
230
- var _ref = size || {},
231
- width = _ref.width,
232
- height = _ref.height;
233
-
234
- var labels = {
235
- left: (range === null || range === void 0 ? void 0 : range.label) || '',
236
- bottom: (domain === null || domain === void 0 ? void 0 : domain.label) || ''
237
- };
238
-
239
- var _this$getChart = this.getChart(),
240
- ChartComponent = _this$getChart.ChartComponent;
241
-
242
- var categories = this.getFilteredCategories();
243
- var correctValues = (0, _utils.getDomainAndRangeByChartType)(domain, range, chartType);
244
-
245
- var _getGridLinesAndAxisB = (0, _utils.getGridLinesAndAxisByChartType)(correctValues.range, chartType),
246
- verticalLines = _getGridLinesAndAxisB.verticalLines,
247
- horizontalLines = _getGridLinesAndAxisB.horizontalLines,
248
- leftAxis = _getGridLinesAndAxisB.leftAxis;
249
-
250
- var common = {
251
- graphProps: (0, _plot.createGraphProps)(correctValues.domain, correctValues.range, size, function () {
252
- return _this2.rootNode;
253
- })
254
- };
255
- log('[render] common:', common);
256
- var maskSize = {
257
- x: -10,
258
- y: -75,
259
- width: width + 20,
260
- height: height + 80
261
- };
262
- var scale = common.graphProps.scale;
263
- var xBand = (0, _utils.dataToXBand)(scale.x, categories, width, chartType);
264
-
265
- if (!ChartComponent) {
266
- return null;
267
- }
268
-
269
- var bandWidth = xBand.bandwidth(); // for chartType "line", bandWidth will be 0, so we have to calculate it
270
-
271
- var barWidth = bandWidth || scale.x(correctValues.domain.max) / categories.length;
272
- var increaseHeight = defineChart ? 160 : 60; // if there are many categories, we have to rotate their names in order to fit
273
- // and we have to add extra value on top of some items
274
-
275
- var top = (0, _utils.getTopPadding)(barWidth);
276
- var rootCommon = (0, _cloneDeep["default"])(common);
277
- rootCommon.graphProps.size.height += top + increaseHeight;
278
- return /*#__PURE__*/_react["default"].createElement("div", {
279
- className: (0, _classnames["default"])(classes.chart, classes.chartBox, className)
280
- }, /*#__PURE__*/_react["default"].createElement("div", {
281
- className: classes.controls
282
- }, /*#__PURE__*/_react["default"].createElement(_toolMenu["default"], {
283
- className: classes.toolMenu,
284
- disabled: !addCategoryEnabled,
285
- addCategory: function addCategory() {
286
- return _this2.addCategory();
287
- },
288
- language: language
289
- })), /*#__PURE__*/_react["default"].createElement(_plot.Root, (0, _extends2["default"])({
290
- title: title,
291
- onChangeTitle: onChangeTitle,
292
- disabledTitle: !defineChart,
293
- showTitle: true,
294
- showLabels: true,
295
- labels: labels,
296
- onChangeLabels: onChangeLabels,
297
- labelsPlaceholders: labelsPlaceholders,
298
- titlePlaceholder: titlePlaceholder,
299
- defineChart: defineChart,
300
- disabledLabels: !defineChart,
301
- isChart: true,
302
- showPixelGuides: showPixelGuides,
303
- rootRef: function rootRef(r) {
304
- return _this2.rootNode = r;
305
- },
306
- mathMlOptions: mathMlOptions,
307
- labelsCharactersLimit: labelsCharactersLimit
308
- }, rootCommon), /*#__PURE__*/_react["default"].createElement(_grid["default"], (0, _extends2["default"])({}, common, {
309
- xBand: xBand,
310
- rowTickValues: horizontalLines,
311
- columnTickValues: verticalLines
312
- })), /*#__PURE__*/_react["default"].createElement(_axes["default"], (0, _extends2["default"])({
313
- autoFocus: this.state.autoFocus,
314
- onAutoFocusUsed: this.resetAutoFocus
315
- }, common, {
316
- defineChart: defineChart,
317
- categories: categories,
318
- xBand: xBand,
319
- leftAxis: leftAxis,
320
- onChange: this.changeData,
321
- onChangeCategory: this.changeCategory,
322
- chartingOptions: chartingOptions,
323
- changeInteractiveEnabled: changeInteractiveEnabled,
324
- changeEditableEnabled: changeEditableEnabled,
325
- top: top,
326
- error: error
327
- })), /*#__PURE__*/_react["default"].createElement("mask", {
328
- id: "".concat(this.maskUid)
329
- }, /*#__PURE__*/_react["default"].createElement("rect", (0, _extends2["default"])({}, maskSize, {
330
- fill: "white"
331
- }))), /*#__PURE__*/_react["default"].createElement("g", {
332
- id: "marks",
333
- mask: "url('#".concat(this.maskUid, "')")
334
- }, /*#__PURE__*/_react["default"].createElement(ChartComponent, (0, _extends2["default"])({}, common, {
335
- data: categories,
336
- height: rootCommon.graphProps.size.height,
337
- defineChart: defineChart,
338
- onChange: this.changeData,
339
- onChangeCategory: this.changeCategory
340
- })))), /*#__PURE__*/_react["default"].createElement(_configUi.AlertDialog, {
341
- open: dialog.open,
342
- title: dialog.title,
343
- text: dialog.text,
344
- onClose: dialog.onClose,
345
- onConfirm: dialog.onConfirm
346
- }));
347
- }
348
- }]);
349
- return Chart;
350
- }(_react["default"].Component);
351
-
352
- exports.Chart = Chart;
353
- (0, _defineProperty2["default"])(Chart, "propTypes", {
354
- classes: _propTypes["default"].object.isRequired,
355
- className: _propTypes["default"].string,
356
- chartType: _propTypes["default"].string.isRequired,
357
- size: _propTypes["default"].shape({
358
- width: _propTypes["default"].number,
359
- height: _propTypes["default"].number
360
- }),
361
- domain: _propTypes["default"].shape({
362
- label: _propTypes["default"].string,
363
- min: _propTypes["default"].number,
364
- max: _propTypes["default"].number,
365
- axisLabel: _propTypes["default"].string
366
- }),
367
- data: _propTypes["default"].arrayOf(_propTypes["default"].shape({
368
- label: _propTypes["default"].string,
369
- value: _propTypes["default"].number
370
- })),
371
- range: _propTypes["default"].shape({
372
- label: _propTypes["default"].string,
373
- min: _propTypes["default"].number,
374
- max: _propTypes["default"].number,
375
- step: _propTypes["default"].number,
376
- labelStep: _propTypes["default"].number,
377
- axisLabel: _propTypes["default"].string
378
- }),
379
- charts: _propTypes["default"].array,
380
- labelsPlaceholders: _propTypes["default"].object,
381
- title: _propTypes["default"].string,
382
- titlePlaceholder: _propTypes["default"].string,
383
- onDataChange: _propTypes["default"].func,
384
- onChangeLabels: _propTypes["default"].func,
385
- onChangeTitle: _propTypes["default"].func,
386
- error: _propTypes["default"].any,
387
- addCategoryEnabled: _propTypes["default"].bool,
388
- showPixelGuides: _propTypes["default"].bool,
389
- categoryDefaultLabel: _propTypes["default"].string,
390
- categoryDefaults: _propTypes["default"].object,
391
- defineChart: _propTypes["default"].bool,
392
- theme: _propTypes["default"].object,
393
- chartingOptions: _propTypes["default"].object,
394
- changeInteractiveEnabled: _propTypes["default"].bool,
395
- changeEditableEnabled: _propTypes["default"].bool,
396
- language: _propTypes["default"].string,
397
- mathMlOptions: _propTypes["default"].object,
398
- labelsCharactersLimit: _propTypes["default"].number
399
- });
400
- (0, _defineProperty2["default"])(Chart, "defaultProps", {
401
- size: {
402
- width: 480,
403
- height: 480
404
- }
405
- });
406
-
407
- var styles = function styles(theme) {
408
- return {
409
- graphBox: {
410
- transform: 'translate(60px, 35px)'
411
- },
412
- controls: {
413
- display: 'flex',
414
- justifyContent: 'space-between',
415
- padding: theme.spacing.unit,
416
- backgroundColor: _renderUi.color.primaryLight(),
417
- '& button': {
418
- fontSize: theme.typography.fontSize
419
- }
420
- },
421
- svg: {
422
- overflow: 'visible'
423
- },
424
- toolMenu: {
425
- minHeight: '36px'
426
- },
427
- chartBox: {
428
- width: 'min-content'
429
- }
430
- };
431
- };
432
-
433
- var _default = (0, _styles.withStyles)(styles, {
434
- withTheme: true
435
- })(Chart);
436
-
437
- exports["default"] = _default;
438
- //# sourceMappingURL=chart.js.map
package/lib/chart.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/chart.jsx"],"names":["translator","Translator","log","Chart","props","charts","chartTypes","Bar","Histogram","LineDot","LineCross","DotPlot","LinePlot","autoFocus","open","callback","setState","dialog","state","chartType","ChartComponent","chart","find","type","Component","data","onDataChange","index","newCategory","integerIndex","parseInt","categoryDefaultLabel","defineChart","categoryDefaults","language","length","title","t","lng","text","count","onConfirm","handleAlertDialog","inDefineChart","label","value","deletable","editable","interactive","map","d","maskUid","generateMaskId","Math","random","toFixed","classes","className","domain","range","chartingOptions","size","onChangeTitle","onChangeLabels","labelsPlaceholders","titlePlaceholder","addCategoryEnabled","changeInteractiveEnabled","changeEditableEnabled","showPixelGuides","error","mathMlOptions","labelsCharactersLimit","width","height","labels","left","bottom","getChart","categories","getFilteredCategories","correctValues","verticalLines","horizontalLines","leftAxis","common","graphProps","rootNode","maskSize","x","y","scale","xBand","bandWidth","bandwidth","barWidth","max","increaseHeight","top","rootCommon","chartBox","controls","toolMenu","addCategory","r","resetAutoFocus","changeData","changeCategory","onClose","React","PropTypes","object","isRequired","string","shape","number","min","axisLabel","arrayOf","step","labelStep","array","func","any","bool","theme","styles","graphBox","transform","display","justifyContent","padding","spacing","unit","backgroundColor","color","primaryLight","fontSize","typography","svg","overflow","minHeight","withTheme"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport { Root, createGraphProps } from '@pie-lib/plot';\nimport cloneDeep from 'lodash/cloneDeep';\nimport ChartGrid from './grid';\nimport ChartAxes from './axes';\nimport debug from 'debug';\nimport { color } from '@pie-lib/render-ui';\nimport { dataToXBand, getDomainAndRangeByChartType, getGridLinesAndAxisByChartType, getTopPadding } from './utils';\nimport ToolMenu from './tool-menu';\nimport chartTypes from './chart-types';\nimport { AlertDialog } from '@pie-lib/config-ui';\nimport Translator from '@pie-lib/translator';\n\nconst { translator } = Translator;\n\nconst log = debug('pie-lib:charts:chart');\n\nexport class Chart extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n dialog: {\n open: false,\n },\n };\n this.maskUid = this.generateMaskId();\n }\n\n static propTypes = {\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n chartType: PropTypes.string.isRequired,\n size: PropTypes.shape({\n width: PropTypes.number,\n height: PropTypes.number,\n }),\n domain: PropTypes.shape({\n label: PropTypes.string,\n min: PropTypes.number,\n max: PropTypes.number,\n axisLabel: PropTypes.string,\n }),\n data: PropTypes.arrayOf(PropTypes.shape({ label: PropTypes.string, value: PropTypes.number })),\n range: PropTypes.shape({\n label: PropTypes.string,\n min: PropTypes.number,\n max: PropTypes.number,\n step: PropTypes.number,\n labelStep: PropTypes.number,\n axisLabel: PropTypes.string,\n }),\n charts: PropTypes.array,\n labelsPlaceholders: PropTypes.object,\n title: PropTypes.string,\n titlePlaceholder: PropTypes.string,\n onDataChange: PropTypes.func,\n onChangeLabels: PropTypes.func,\n onChangeTitle: PropTypes.func,\n error: PropTypes.any,\n addCategoryEnabled: PropTypes.bool,\n showPixelGuides: PropTypes.bool,\n categoryDefaultLabel: PropTypes.string,\n categoryDefaults: PropTypes.object,\n defineChart: PropTypes.bool,\n theme: PropTypes.object,\n chartingOptions: PropTypes.object,\n changeInteractiveEnabled: PropTypes.bool,\n changeEditableEnabled: PropTypes.bool,\n language: PropTypes.string,\n mathMlOptions: PropTypes.object,\n labelsCharactersLimit: PropTypes.number,\n };\n\n static defaultProps = {\n size: {\n width: 480,\n height: 480,\n },\n };\n\n state = {\n charts: [\n chartTypes.Bar(),\n chartTypes.Histogram(),\n chartTypes.LineDot(),\n chartTypes.LineCross(),\n chartTypes.DotPlot(),\n chartTypes.LinePlot(),\n ],\n autoFocus: false,\n };\n\n generateMaskId() {\n return 'chart-' + (Math.random() * 10000).toFixed();\n }\n\n handleAlertDialog = (open, callback) =>\n this.setState(\n {\n dialog: { open },\n },\n callback,\n );\n\n getChart = () => {\n const charts = this.props.charts || this.state.charts;\n let { chartType } = this.props;\n let ChartComponent = null;\n let chart = null;\n\n if (chartType) {\n chart = charts && charts.find((chart) => chart.type === chartType);\n ChartComponent = chart && chart.Component;\n } else {\n chart = charts && charts[0];\n ChartComponent = chart && chart.Component;\n chartType = chart && chart.type;\n }\n\n return {\n type: chartType,\n ChartComponent,\n };\n };\n\n changeData = (data) => {\n const { onDataChange } = this.props;\n\n onDataChange(data);\n };\n\n changeCategory = (index, newCategory) => {\n const integerIndex = parseInt(index, 10);\n\n if (integerIndex >= 0) {\n const { data, onDataChange } = this.props;\n data[integerIndex] = {\n ...data[integerIndex],\n ...newCategory,\n };\n\n onDataChange(data);\n }\n };\n\n addCategory = () => {\n const { onDataChange, data, categoryDefaultLabel, defineChart, categoryDefaults, language } = this.props;\n\n if ((data || []).length > 19) {\n this.setState({\n dialog: {\n open: true,\n title: translator.t('common:warning', { lng: language }),\n text: translator.t('charting.reachedLimit_other', { count: 20, lng: language }),\n onConfirm: () => this.handleAlertDialog(false),\n },\n });\n } else {\n this.setState({ autoFocus: true });\n onDataChange([\n ...data,\n {\n inDefineChart: defineChart,\n label: categoryDefaultLabel || translator.t('charting.newLabel', { lng: language }),\n value: 0,\n deletable: true,\n editable: categoryDefaults ? categoryDefaults?.editable : true,\n interactive: categoryDefaults ? categoryDefaults?.interactive : true,\n },\n ]);\n }\n };\n\n getFilteredCategories = () => {\n const { data, defineChart } = this.props;\n\n return data\n ? data.map((d) => ({\n ...d,\n deletable: defineChart || d.deletable,\n }))\n : [];\n };\n\n resetAutoFocus = () => {\n this.setState({ autoFocus: false });\n };\n\n render() {\n const {\n classes,\n className,\n domain = {},\n range = {},\n chartingOptions,\n size,\n title,\n onChangeTitle,\n onChangeLabels,\n labelsPlaceholders,\n titlePlaceholder,\n addCategoryEnabled,\n changeInteractiveEnabled,\n changeEditableEnabled,\n showPixelGuides,\n error,\n mathMlOptions = {},\n language,\n labelsCharactersLimit,\n } = this.props;\n let { chartType } = this.props;\n\n const { dialog } = this.state;\n const defineChart = this.props.defineChart || false;\n\n const { width, height } = size || {};\n const labels = { left: range?.label || '', bottom: domain?.label || '' };\n\n const { ChartComponent } = this.getChart();\n const categories = this.getFilteredCategories();\n\n const correctValues = getDomainAndRangeByChartType(domain, range, chartType);\n\n const { verticalLines, horizontalLines, leftAxis } = getGridLinesAndAxisByChartType(correctValues.range, chartType);\n const common = {\n graphProps: createGraphProps(correctValues.domain, correctValues.range, size, () => this.rootNode),\n };\n\n log('[render] common:', common);\n\n const maskSize = { x: -10, y: -75, width: width + 20, height: height + 80 };\n const { scale } = common.graphProps;\n const xBand = dataToXBand(scale.x, categories, width, chartType);\n\n if (!ChartComponent) {\n return null;\n }\n\n const bandWidth = xBand.bandwidth();\n // for chartType \"line\", bandWidth will be 0, so we have to calculate it\n const barWidth = bandWidth || scale.x(correctValues.domain.max) / categories.length;\n const increaseHeight = defineChart ? 160 : 60;\n\n // if there are many categories, we have to rotate their names in order to fit\n // and we have to add extra value on top of some items\n const top = getTopPadding(barWidth);\n const rootCommon = cloneDeep(common);\n rootCommon.graphProps.size.height += top + increaseHeight;\n\n return (\n <div className={classNames(classes.chart, classes.chartBox, className)}>\n <div className={classes.controls}>\n <ToolMenu\n className={classes.toolMenu}\n disabled={!addCategoryEnabled}\n addCategory={() => this.addCategory()}\n language={language}\n />\n </div>\n\n <Root\n title={title}\n onChangeTitle={onChangeTitle}\n disabledTitle={!defineChart}\n showTitle={true}\n showLabels={true}\n labels={labels}\n onChangeLabels={onChangeLabels}\n labelsPlaceholders={labelsPlaceholders}\n titlePlaceholder={titlePlaceholder}\n defineChart={defineChart}\n disabledLabels={!defineChart}\n isChart={true}\n showPixelGuides={showPixelGuides}\n rootRef={(r) => (this.rootNode = r)}\n mathMlOptions={mathMlOptions}\n labelsCharactersLimit={labelsCharactersLimit}\n {...rootCommon}\n >\n <ChartGrid {...common} xBand={xBand} rowTickValues={horizontalLines} columnTickValues={verticalLines} />\n <ChartAxes\n autoFocus={this.state.autoFocus}\n onAutoFocusUsed={this.resetAutoFocus}\n {...common}\n defineChart={defineChart}\n categories={categories}\n xBand={xBand}\n leftAxis={leftAxis}\n onChange={this.changeData}\n onChangeCategory={this.changeCategory}\n chartingOptions={chartingOptions}\n changeInteractiveEnabled={changeInteractiveEnabled}\n changeEditableEnabled={changeEditableEnabled}\n top={top}\n error={error}\n />\n <mask id={`${this.maskUid}`}>\n <rect {...maskSize} fill=\"white\" />\n </mask>\n <g id=\"marks\" mask={`url('#${this.maskUid}')`}>\n <ChartComponent\n {...common}\n data={categories}\n height={rootCommon.graphProps.size.height}\n defineChart={defineChart}\n onChange={this.changeData}\n onChangeCategory={this.changeCategory}\n />\n </g>\n </Root>\n <AlertDialog\n open={dialog.open}\n title={dialog.title}\n text={dialog.text}\n onClose={dialog.onClose}\n onConfirm={dialog.onConfirm}\n />\n </div>\n );\n }\n}\n\nconst styles = (theme) => ({\n graphBox: {\n transform: 'translate(60px, 35px)',\n },\n controls: {\n display: 'flex',\n justifyContent: 'space-between',\n padding: theme.spacing.unit,\n backgroundColor: color.primaryLight(),\n '& button': {\n fontSize: theme.typography.fontSize,\n },\n },\n svg: {\n overflow: 'visible',\n },\n toolMenu: {\n minHeight: '36px',\n },\n chartBox: {\n width: 'min-content',\n },\n});\n\nexport default withStyles(styles, { withTheme: true })(Chart);\n"],"file":"chart.js"}
@@ -1,175 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = exports.DragHandle = exports.D = void 0;
9
-
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
-
12
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
-
14
- var _react = _interopRequireDefault(require("react"));
15
-
16
- var _propTypes = _interopRequireDefault(require("prop-types"));
17
-
18
- var _classnames = _interopRequireDefault(require("classnames"));
19
-
20
- var _styles = require("@material-ui/core/styles");
21
-
22
- var _plot = require("@pie-lib/plot");
23
-
24
- var _renderUi = require("@pie-lib/render-ui");
25
-
26
- var _styles2 = require("./styles");
27
-
28
- var _utils = require("../utils");
29
-
30
- var _dragIcon = _interopRequireDefault(require("./drag-icon"));
31
-
32
- var _excluded = ["x", "y", "width", "graphProps", "classes", "className", "interactive", "defineChart", "isHovered", "correctness", "color"];
33
-
34
- var RawDragHandle = function RawDragHandle(_ref) {
35
- var _getScale;
36
-
37
- var x = _ref.x,
38
- y = _ref.y,
39
- width = _ref.width,
40
- graphProps = _ref.graphProps,
41
- classes = _ref.classes,
42
- className = _ref.className,
43
- interactive = _ref.interactive,
44
- defineChart = _ref.defineChart,
45
- isHovered = _ref.isHovered,
46
- correctness = _ref.correctness,
47
- color = _ref.color,
48
- rest = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
49
- var scale = graphProps.scale;
50
- var scaleValue = (_getScale = (0, _utils.getScale)(width)) === null || _getScale === void 0 ? void 0 : _getScale.scale;
51
- return /*#__PURE__*/_react["default"].createElement("svg", {
52
- x: x,
53
- y: scale.y(y) - 10,
54
- width: width,
55
- overflow: "visible",
56
- className: classes.svgOverflowVisible
57
- }, isHovered && !correctness && interactive && /*#__PURE__*/_react["default"].createElement(_dragIcon["default"], {
58
- width: width,
59
- scaleValue: scaleValue,
60
- color: color,
61
- classes: classes
62
- }), interactive && !correctness && /*#__PURE__*/_react["default"].createElement("ellipse", (0, _extends2["default"])({
63
- cx: width / 2,
64
- cy: 10,
65
- rx: width / 2 // the drag icon has a 22px fixed r value, so the ry value is 3 times that in order to cover all the area
66
- ,
67
- ry: 66,
68
- className: (0, _classnames["default"])(classes.transparentHandle, className)
69
- }, rest)), /*#__PURE__*/_react["default"].createElement("defs", null, /*#__PURE__*/_react["default"].createElement("filter", {
70
- id: "bottomShadow",
71
- x: "0",
72
- y: "0",
73
- width: "140%",
74
- height: "140%"
75
- }, /*#__PURE__*/_react["default"].createElement("feGaussianBlur", {
76
- "in": "SourceAlpha",
77
- stdDeviation: "3"
78
- }), /*#__PURE__*/_react["default"].createElement("feOffset", {
79
- dx: "0",
80
- dy: "5",
81
- result: "offsetblur"
82
- }), /*#__PURE__*/_react["default"].createElement("feFlood", {
83
- floodColor: "#00000033"
84
- }), /*#__PURE__*/_react["default"].createElement("feComposite", {
85
- in2: "offsetblur",
86
- operator: "in"
87
- }), /*#__PURE__*/_react["default"].createElement("feMerge", null, /*#__PURE__*/_react["default"].createElement("feMergeNode", null), /*#__PURE__*/_react["default"].createElement("feMergeNode", {
88
- "in": "SourceGraphic"
89
- })))), correctness && /*#__PURE__*/_react["default"].createElement("rect", (0, _extends2["default"])({
90
- y: 10,
91
- width: width,
92
- filter: "url(#bottomShadow)",
93
- className: (0, _classnames["default"])(classes.handle, 'handle', className, !interactive && 'non-interactive', interactive && correctness && correctness.value)
94
- }, rest)));
95
- };
96
-
97
- RawDragHandle.propTypes = {
98
- x: _propTypes["default"].number.isRequired,
99
- y: _propTypes["default"].number.isRequired,
100
- width: _propTypes["default"].number,
101
- graphProps: _plot.types.GraphPropsType.isRequired,
102
- classes: _propTypes["default"].object.isRequired,
103
- className: _propTypes["default"].string,
104
- interactive: _propTypes["default"].bool,
105
- isHovered: _propTypes["default"].bool,
106
- correctness: _propTypes["default"].shape({
107
- value: _propTypes["default"].string,
108
- label: _propTypes["default"].string
109
- }),
110
- color: _propTypes["default"].string
111
- };
112
- var DragHandle = (0, _styles.withStyles)(function () {
113
- return {
114
- handle: {
115
- height: '10px',
116
- fill: 'transparent',
117
- transition: 'fill 200ms linear, height 200ms linear',
118
- '&.correct': (0, _styles2.correct)('fill'),
119
- '&.incorrect': (0, _styles2.incorrect)('fill'),
120
- '&.non-interactive': (0, _styles2.disabled)('fill')
121
- },
122
- transparentHandle: {
123
- fill: 'transparent',
124
- clipPath: 'polygon(50% 0%, 100% 0%, 100% 50%, 0% 50%, 0% 0%)'
125
- },
126
- handleContainer: {
127
- height: 30,
128
- '&:hover': {
129
- '& .handle': {
130
- fill: _renderUi.color.secondaryDark(),
131
- height: '16px'
132
- }
133
- },
134
- '&.non-interactive': (0, _styles2.disabled)('fill'),
135
- '&.incorrect': (0, _styles2.incorrect)('fill'),
136
- '&.correct': (0, _styles2.correct)('fill')
137
- },
138
- svgOverflowVisible: {
139
- overflow: 'visible !important'
140
- }
141
- };
142
- })(RawDragHandle);
143
- exports.DragHandle = DragHandle;
144
- var D = (0, _plot.gridDraggable)({
145
- axis: 'y',
146
- fromDelta: function fromDelta(props, delta) {
147
- //TODO: should be in grid-draggable, if axis is y delta.x should always be 0.
148
- delta.x = 0;
149
-
150
- var newPoint = _plot.utils.point(props).add(_plot.utils.point(delta));
151
-
152
- return newPoint.y;
153
- },
154
- bounds: function bounds(props, _ref2) {
155
- var domain = _ref2.domain,
156
- range = _ref2.range;
157
- var area = {
158
- left: 0,
159
- top: props.y,
160
- bottom: props.y,
161
- right: 0
162
- };
163
- return _plot.utils.bounds(area, domain, range);
164
- },
165
- anchorPoint: function anchorPoint(props) {
166
- return {
167
- x: props.x,
168
- y: props.y
169
- };
170
- }
171
- })(DragHandle);
172
- exports.D = D;
173
- var _default = D;
174
- exports["default"] = _default;
175
- //# sourceMappingURL=drag-handle.js.map