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

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 +40 -0
  2. package/lib/axes.js +643 -0
  3. package/lib/axes.js.map +1 -0
  4. package/lib/bars/bar.js +86 -0
  5. package/lib/bars/bar.js.map +1 -0
  6. package/lib/bars/common/bars.js +301 -0
  7. package/lib/bars/common/bars.js.map +1 -0
  8. package/lib/bars/histogram.js +87 -0
  9. package/lib/bars/histogram.js.map +1 -0
  10. package/lib/chart-setup.js +458 -0
  11. package/lib/chart-setup.js.map +1 -0
  12. package/lib/chart-type.js +71 -0
  13. package/lib/chart-type.js.map +1 -0
  14. package/lib/chart-types.js +31 -0
  15. package/lib/chart-types.js.map +1 -0
  16. package/lib/chart.js +438 -0
  17. package/lib/chart.js.map +1 -0
  18. package/lib/common/drag-handle.js +175 -0
  19. package/lib/common/drag-handle.js.map +1 -0
  20. package/lib/common/drag-icon.js +52 -0
  21. package/lib/common/drag-icon.js.map +1 -0
  22. package/lib/common/styles.js +40 -0
  23. package/lib/common/styles.js.map +1 -0
  24. package/lib/grid.js +104 -0
  25. package/lib/grid.js.map +1 -0
  26. package/lib/index.js +40 -0
  27. package/lib/index.js.map +1 -0
  28. package/lib/line/common/drag-handle.js +157 -0
  29. package/lib/line/common/drag-handle.js.map +1 -0
  30. package/lib/line/common/line.js +261 -0
  31. package/lib/line/common/line.js.map +1 -0
  32. package/lib/line/line-cross.js +168 -0
  33. package/lib/line/line-cross.js.map +1 -0
  34. package/lib/line/line-dot.js +131 -0
  35. package/lib/line/line-dot.js.map +1 -0
  36. package/lib/mark-label.js +255 -0
  37. package/lib/mark-label.js.map +1 -0
  38. package/lib/plot/common/plot.js +280 -0
  39. package/lib/plot/common/plot.js.map +1 -0
  40. package/lib/plot/dot.js +123 -0
  41. package/lib/plot/dot.js.map +1 -0
  42. package/lib/plot/line.js +152 -0
  43. package/lib/plot/line.js.map +1 -0
  44. package/lib/tool-menu.js +142 -0
  45. package/lib/tool-menu.js.map +1 -0
  46. package/lib/utils.js +244 -0
  47. package/lib/utils.js.map +1 -0
  48. package/package.json +2 -29
package/lib/chart.js ADDED
@@ -0,0 +1,438 @@
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
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,175 @@
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