@pie-lib/charting 5.17.0-beta.0 → 5.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (102) hide show
  1. package/CHANGELOG.json +1 -581
  2. package/CHANGELOG.md +141 -43
  3. package/lib/actions-button.js +174 -0
  4. package/lib/actions-button.js.map +1 -0
  5. package/lib/axes.js +52 -81
  6. package/lib/axes.js.map +1 -0
  7. package/lib/bars/bar.js +1 -1
  8. package/lib/bars/bar.js.map +1 -0
  9. package/lib/bars/common/bars.js +11 -13
  10. package/lib/bars/common/bars.js.map +1 -0
  11. package/lib/bars/histogram.js +1 -1
  12. package/lib/bars/histogram.js.map +1 -0
  13. package/lib/chart-setup.js +3 -3
  14. package/lib/chart-setup.js.map +1 -0
  15. package/lib/chart-type.js +1 -1
  16. package/lib/chart-type.js.map +1 -0
  17. package/lib/chart-types.js +1 -1
  18. package/lib/chart-types.js.map +1 -0
  19. package/lib/chart.js +67 -58
  20. package/lib/chart.js.map +1 -0
  21. package/lib/common/drag-handle.js +4 -4
  22. package/lib/common/drag-handle.js.map +1 -0
  23. package/lib/common/drag-icon.js +1 -1
  24. package/lib/common/drag-icon.js.map +1 -0
  25. package/lib/common/styles.js +5 -5
  26. package/lib/common/styles.js.map +1 -0
  27. package/lib/grid.js +50 -13
  28. package/lib/grid.js.map +1 -0
  29. package/lib/index.js +9 -1
  30. package/lib/index.js.map +1 -0
  31. package/lib/key-legend.js +111 -0
  32. package/lib/key-legend.js.map +1 -0
  33. package/lib/line/common/drag-handle.js +5 -11
  34. package/lib/line/common/drag-handle.js.map +1 -0
  35. package/lib/line/common/line.js +4 -8
  36. package/lib/line/common/line.js.map +1 -0
  37. package/lib/line/line-cross.js +40 -5
  38. package/lib/line/line-cross.js.map +1 -0
  39. package/lib/line/line-dot.js +32 -7
  40. package/lib/line/line-dot.js.map +1 -0
  41. package/lib/mark-label.js +11 -6
  42. package/lib/mark-label.js.map +1 -0
  43. package/lib/plot/common/plot.js +10 -9
  44. package/lib/plot/common/plot.js.map +1 -0
  45. package/lib/plot/dot.js +1 -1
  46. package/lib/plot/dot.js.map +1 -0
  47. package/lib/plot/line.js +1 -1
  48. package/lib/plot/line.js.map +1 -0
  49. package/lib/shared/index.js +136 -0
  50. package/lib/tool-menu.js +10 -10
  51. package/lib/tool-menu.js.map +1 -0
  52. package/lib/utils.js +1 -1
  53. package/lib/utils.js.map +1 -0
  54. package/package.json +5 -5
  55. package/src/__tests__/__snapshots__/axes.test.jsx.snap +1 -0
  56. package/src/__tests__/__snapshots__/chart.test.jsx.snap +0 -18
  57. package/src/__tests__/__snapshots__/grid.test.jsx.snap +61 -17
  58. package/src/__tests__/axes.test.jsx +0 -5
  59. package/src/__tests__/chart.test.jsx +8 -0
  60. package/src/actions-button.jsx +109 -0
  61. package/src/axes.jsx +5 -31
  62. package/src/bars/common/bars.jsx +8 -10
  63. package/src/chart-setup.jsx +1 -1
  64. package/src/chart.jsx +31 -26
  65. package/src/common/drag-handle.jsx +3 -3
  66. package/src/common/styles.js +1 -1
  67. package/src/grid.jsx +38 -13
  68. package/src/index.js +2 -1
  69. package/src/key-legend.jsx +75 -0
  70. package/src/line/common/drag-handle.jsx +3 -9
  71. package/src/line/common/line.jsx +2 -6
  72. package/src/line/line-cross.js +29 -2
  73. package/src/line/line-dot.js +36 -19
  74. package/src/mark-label.jsx +7 -2
  75. package/src/plot/common/plot.jsx +8 -5
  76. package/src/tool-menu.jsx +1 -1
  77. package/lib/__tests__/axes.test.js +0 -181
  78. package/lib/__tests__/chart-setup.test.js +0 -58
  79. package/lib/__tests__/chart-type.test.js +0 -42
  80. package/lib/__tests__/chart.test.js +0 -108
  81. package/lib/__tests__/grid.test.js +0 -48
  82. package/lib/__tests__/mark-label.test.js +0 -57
  83. package/lib/__tests__/utils.js +0 -56
  84. package/lib/__tests__/utils.test.js +0 -197
  85. package/lib/bars/__tests__/bar.test.js +0 -62
  86. package/lib/bars/__tests__/histogram.test.js +0 -64
  87. package/lib/bars/__tests__/utils.js +0 -56
  88. package/lib/bars/common/__tests__/bars.test.js +0 -100
  89. package/lib/bars/common/__tests__/utils.js +0 -56
  90. package/lib/common/__tests__/drag-handle.test.js +0 -134
  91. package/lib/common/__tests__/utils.js +0 -56
  92. package/lib/line/__tests__/line-cross.test.js +0 -64
  93. package/lib/line/__tests__/line-dot.test.js +0 -64
  94. package/lib/line/__tests__/utils.js +0 -56
  95. package/lib/line/common/__tests__/drag-handle.test.js +0 -134
  96. package/lib/line/common/__tests__/line.test.js +0 -128
  97. package/lib/line/common/__tests__/utils.js +0 -56
  98. package/lib/plot/__tests__/dot.test.js +0 -64
  99. package/lib/plot/__tests__/line.test.js +0 -64
  100. package/lib/plot/__tests__/utils.js +0 -56
  101. package/lib/plot/common/__tests__/plot.test.js +0 -103
  102. package/lib/plot/common/__tests__/utils.js +0 -56
package/lib/tool-menu.js CHANGED
@@ -25,7 +25,7 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
25
25
 
26
26
  var _classnames = _interopRequireDefault(require("classnames"));
27
27
 
28
- var _renderUi = require("@pie-lib/render-ui");
28
+ var _index = require("./shared/index");
29
29
 
30
30
  var _styles = require("@material-ui/core/styles");
31
31
 
@@ -42,27 +42,27 @@ var translator = _translator["default"].translator;
42
42
  var buttonStyles = function buttonStyles(theme) {
43
43
  return {
44
44
  root: {
45
- color: _renderUi.color.text(),
46
- border: "1px solid ".concat(_renderUi.color.secondary()),
45
+ color: _index.color.text(),
46
+ border: "1px solid ".concat(_index.color.secondary()),
47
47
  fontSize: theme.typography.fontSize
48
48
  },
49
49
  selected: {
50
- backgroundColor: _renderUi.color.background(),
50
+ backgroundColor: _index.color.background(),
51
51
  '& span': {
52
- color: _renderUi.color.primaryDark()
52
+ color: _index.color.primaryDark()
53
53
  }
54
54
  },
55
55
  notSelected: {
56
56
  '& span': {
57
- color: _renderUi.color.primary()
57
+ color: _index.color.primary()
58
58
  },
59
- backgroundColor: _renderUi.color.background()
59
+ backgroundColor: _index.color.background()
60
60
  },
61
61
  disabled: {
62
62
  '& span': {
63
- color: _renderUi.color.primary()
63
+ color: _index.color.primary()
64
64
  },
65
- backgroundColor: _renderUi.color.disabled()
65
+ backgroundColor: _index.color.disabled()
66
66
  }
67
67
  };
68
68
  };
@@ -139,4 +139,4 @@ exports.ToolMenu = ToolMenu;
139
139
  (0, _defineProperty2["default"])(ToolMenu, "defaultProps", {});
140
140
  var _default = ToolMenu;
141
141
  exports["default"] = _default;
142
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90b29sLW1lbnUuanN4Il0sIm5hbWVzIjpbInRyYW5zbGF0b3IiLCJUcmFuc2xhdG9yIiwiYnV0dG9uU3R5bGVzIiwidGhlbWUiLCJyb290IiwiY29sb3IiLCJ0ZXh0IiwiYm9yZGVyIiwic2Vjb25kYXJ5IiwiZm9udFNpemUiLCJ0eXBvZ3JhcGh5Iiwic2VsZWN0ZWQiLCJiYWNrZ3JvdW5kQ29sb3IiLCJiYWNrZ3JvdW5kIiwicHJpbWFyeURhcmsiLCJub3RTZWxlY3RlZCIsInByaW1hcnkiLCJkaXNhYmxlZCIsIk1pbmlCdXR0b24iLCJwcm9wcyIsImNsYXNzZXMiLCJjbGFzc05hbWUiLCJ2YWx1ZSIsIm9uQ2xpY2siLCJwcm9wVHlwZXMiLCJQcm9wVHlwZXMiLCJib29sIiwic3RyaW5nIiwiZGlzYWJsZWRDbGFzc05hbWUiLCJmdW5jIiwiVG9vbE1lbnUiLCJhZGRDYXRlZ29yeSIsImxhbmd1YWdlIiwidCIsImxuZyIsIlJlYWN0IiwiQ29tcG9uZW50Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFFQTs7QUFDQTs7Ozs7O0FBRUEsSUFBUUEsVUFBUixHQUF1QkMsc0JBQXZCLENBQVFELFVBQVI7O0FBRUEsSUFBTUUsWUFBWSxHQUFHLFNBQWZBLFlBQWUsQ0FBQ0MsS0FBRDtBQUFBLFNBQVk7QUFDL0JDLElBQUFBLElBQUksRUFBRTtBQUNKQyxNQUFBQSxLQUFLLEVBQUVBLGdCQUFNQyxJQUFOLEVBREg7QUFFSkMsTUFBQUEsTUFBTSxzQkFBZUYsZ0JBQU1HLFNBQU4sRUFBZixDQUZGO0FBR0pDLE1BQUFBLFFBQVEsRUFBRU4sS0FBSyxDQUFDTyxVQUFOLENBQWlCRDtBQUh2QixLQUR5QjtBQU0vQkUsSUFBQUEsUUFBUSxFQUFFO0FBQ1JDLE1BQUFBLGVBQWUsRUFBRVAsZ0JBQU1RLFVBQU4sRUFEVDtBQUVSLGdCQUFVO0FBQ1JSLFFBQUFBLEtBQUssRUFBRUEsZ0JB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RU4sc0JBQVVJLElBRk47QUFHakJaLEVBQUFBLFFBQVEsRUFBRVEsc0JBQVVDLElBSEg7QUFJakJNLEVBQUFBLFFBQVEsRUFBRVAsc0JBQVVFO0FBSkgsQztpQ0FEUkcsUSxrQkFRVyxFO2VBZVRBLFEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBjbGFzc05hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IHsgY29sb3IgfSBmcm9tICdAcGllLWxpYi9yZW5kZXItdWknO1xuXG5pbXBvcnQgeyB3aXRoU3R5bGVzIH0gZnJvbSAnQG1hdGVyaWFsLXVpL2NvcmUvc3R5bGVzJztcbmltcG9ydCBjbiBmcm9tICdjbGFzc25hbWVzJztcbmltcG9ydCBCdXR0b24gZnJvbSAnQG1hdGVyaWFsLXVpL2NvcmUvQnV0dG9uJztcbmltcG9ydCBUcmFuc2xhdG9yIGZyb20gJ0BwaWUtbGliL3RyYW5zbGF0b3InO1xuXG5jb25zdCB7IHRyYW5zbGF0b3IgfSA9IFRyYW5zbGF0b3I7XG5cbmNvbnN0IGJ1dHRvblN0eWxlcyA9ICh0aGVtZSkgPT4gKHtcbiAgcm9vdDoge1xuICAgIGNvbG9yOiBjb2xvci50ZXh0KCksXG4gICAgYm9yZGVyOiBgMXB4IHNvbGlkICR7Y29sb3Iuc2Vjb25kYXJ5KCl9YCxcbiAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZSxcbiAgfSxcbiAgc2VsZWN0ZWQ6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IGNvbG9yLmJhY2tncm91bmQoKSxcbiAgICAnJiBzcGFuJzoge1xuICAgICAgY29sb3I6IGNvbG9yLnByaW1hcnlEYXJrKCksXG4gICAgfSxcbiAgfSxcbiAgbm90U2VsZWN0ZWQ6IHtcbiAgICAnJiBzcGFuJzoge1xuICAgICAgY29sb3I6IGNvbG9yLnByaW1hcnkoKSxcbiAgICB9LFxuICAgIGJhY2tncm91bmRDb2xvcjogY29sb3IuYmFja2dyb3VuZCgpLFxuICB9LFxuICBkaXNhYmxlZDoge1xuICAgICcmIHNwYW4nOiB7XG4gICAgICBjb2xvcjogY29sb3IucHJpbWFyeSgpLFxuICAgIH0sXG4gICAgYmFja2dyb3VuZENvbG9yOiBjb2xvci5kaXNhYmxlZCgpLFxuICB9LFxufSk7XG5cbmV4cG9ydCBjb25zdCBNaW5pQnV0dG9uID0gd2l0aFN0eWxlcyhidXR0b25TdHlsZXMpKChwcm9wcykgPT4ge1xuICBjb25zdCB7IGRpc2FibGVkLCBjbGFzc2VzLCBjbGFzc05hbWUsIHNlbGVjdGVkLCB2YWx1ZSwgb25DbGljayB9ID0gcHJvcHM7XG4gIHJldHVybiAoXG4gICAgPEJ1dHRvblxuICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIGNvbG9yPXtzZWxlY3RlZCA/ICdzZWNvbmRhcnknIDogJ2RlZmF1bHQnfVxuICAgICAgY2xhc3NOYW1lPXtjbihjbGFzc2VzLnJvb3QsIHNlbGVjdGVkICYmIGNsYXNzZXMuc2VsZWN0ZWQsIGNsYXNzTmFtZSl9XG4gICAgICBjbGFzc2VzPXt7IGRpc2FibGVkOiBjbihkaXNhYmxlZCAmJiBjbGFzc2VzLmRpc2FibGVkKSB9fVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAga2V5PXt2YWx1ZX1cbiAgICAgIHZhcmlhbnQ9XCJvdXRsaW5lZFwiXG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHt2YWx1ZX1cbiAgICA8L0J1dHRvbj5cbiAgKTtcbn0pO1xuTWluaUJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIGRpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgY2xhc3NOYW1lOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBkaXNhYmxlZENsYXNzTmFtZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgc2VsZWN0ZWQ6IFByb3BUeXBlcy5ib29sLFxuICB2YWx1ZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgb25DbGljazogUHJvcFR5cGVzLmZ1bmMsXG59O1xuXG5leHBvcnQgY2xhc3MgVG9vbE1lbnUgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNsYXNzTmFtZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBhZGRDYXRlZ29yeTogUHJvcFR5cGVzLmZ1bmMsXG4gICAgZGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIGxhbmd1YWdlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7fTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjbGFzc05hbWUsIGRpc2FibGVkLCBhZGRDYXRlZ29yeSwgbGFuZ3VhZ2UgfSA9IHRoaXMucHJvcHM7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBjbGFzc05hbWU9e2NsYXNzTmFtZXMoY2xhc3NOYW1lKX0+XG4gICAgICAgIHshZGlzYWJsZWQgJiYgKFxuICAgICAgICAgIDxNaW5pQnV0dG9uIHZhbHVlPXt0cmFuc2xhdG9yLnQoJ2NoYXJ0aW5nLmFkZENhdGVnb3J5JywgeyBsbmc6IGxhbmd1YWdlIH0pfSBvbkNsaWNrPXthZGRDYXRlZ29yeX0gLz5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgVG9vbE1lbnU7XG4iXX0=
142
+ //# sourceMappingURL=tool-menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tool-menu.jsx"],"names":["translator","Translator","buttonStyles","theme","root","color","text","border","secondary","fontSize","typography","selected","backgroundColor","background","primaryDark","notSelected","primary","disabled","MiniButton","props","classes","className","value","onClick","propTypes","PropTypes","bool","string","disabledClassName","func","ToolMenu","addCategory","language","t","lng","React","Component"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { color } from '../../render-ui/src/index';\n\nimport { withStyles } from '@material-ui/core/styles';\nimport cn from 'classnames';\nimport Button from '@material-ui/core/Button';\nimport Translator from '@pie-lib/translator';\n\nconst { translator } = Translator;\n\nconst buttonStyles = (theme) => ({\n root: {\n color: color.text(),\n border: `1px solid ${color.secondary()}`,\n fontSize: theme.typography.fontSize,\n },\n selected: {\n backgroundColor: color.background(),\n '& span': {\n color: color.primaryDark(),\n },\n },\n notSelected: {\n '& span': {\n color: color.primary(),\n },\n backgroundColor: color.background(),\n },\n disabled: {\n '& span': {\n color: color.primary(),\n },\n backgroundColor: color.disabled(),\n },\n});\n\nexport const MiniButton = withStyles(buttonStyles)((props) => {\n const { disabled, classes, className, selected, value, onClick } = props;\n return (\n <Button\n size=\"small\"\n disabled={disabled}\n color={selected ? 'secondary' : 'default'}\n className={cn(classes.root, selected && classes.selected, className)}\n classes={{ disabled: cn(disabled && classes.disabled) }}\n value={value}\n key={value}\n variant=\"outlined\"\n onClick={onClick}\n >\n {value}\n </Button>\n );\n});\nMiniButton.propTypes = {\n disabled: PropTypes.bool,\n className: PropTypes.string,\n disabledClassName: PropTypes.string,\n selected: PropTypes.bool,\n value: PropTypes.string,\n onClick: PropTypes.func,\n};\n\nexport class ToolMenu extends React.Component {\n static propTypes = {\n className: PropTypes.string,\n addCategory: PropTypes.func,\n disabled: PropTypes.bool,\n language: PropTypes.string,\n };\n\n static defaultProps = {};\n\n render() {\n const { className, disabled, addCategory, language } = this.props;\n\n return (\n <div className={classNames(className)}>\n {!disabled && (\n <MiniButton value={translator.t('charting.addCategory', { lng: language })} onClick={addCategory} />\n )}\n </div>\n );\n }\n}\n\nexport default ToolMenu;\n"],"file":"tool-menu.js"}
package/lib/utils.js CHANGED
@@ -241,4 +241,4 @@ var getAdjustedX = function getAdjustedX(width, scaleValue) {
241
241
  };
242
242
 
243
243
  exports.getAdjustedX = getAdjustedX;
244
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/utils.js"],"names":["tickCount","utils","bounds","point","bandKey","d","index","label","dataToXBand","scaleX","data","width","type","rangeRound","domain","map","padding","range","getTickValues","prop","tickValues","tickVal","min","max","push","Math","round","step","getDomainAndRangeByChartType","chartType","labelStep","isNaN","intMin","intMax","getGridLinesAndAxisByChartType","verticalLines","undefined","horizontalLines","leftAxis","getRotateAngle","fontSize","height","getTopPadding","barWidth","getScale","scale","deltay","pow","getAdjustedX","scaleValue","innerWidthOriginal","effectiveInnerWidth"],"mappings":"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","sourcesContent":["import { scaleBand, scalePoint } from '@vx/scale';\nimport { utils } from '@pie-lib/plot';\n\nexport const tickCount = utils.tickCount;\nexport const bounds = utils.bounds;\nexport const point = utils.point;\n\nexport const bandKey = (d, index) => `${index}-${d.label || '-'}`;\n\nexport const dataToXBand = (scaleX, data, width, type) => {\n  switch (type) {\n    case 'bar':\n    case 'dotPlot':\n    case 'linePlot':\n      return scaleBand({\n        rangeRound: [0, width],\n        domain: data && data.map(bandKey),\n        padding: 0.2,\n      });\n\n    case 'histogram':\n      return scaleBand({\n        rangeRound: [0, width],\n        domain: data && data.map(bandKey),\n        padding: 0,\n      });\n\n    case 'lineCross':\n    case 'lineDot':\n      return scalePoint({\n        domain: data && data.map(bandKey),\n        rangeRound: [0, width],\n      });\n\n    default:\n      return scaleBand({\n        range: [0, width],\n        domain: data && data.map(bandKey),\n        padding: 0,\n      });\n  }\n};\n\nexport const getTickValues = (prop = {}) => {\n  const tickValues = [];\n  let tickVal = prop.min;\n\n  while (tickVal <= prop.max) {\n    tickValues.push(tickVal);\n    tickVal = Math.round((tickVal + prop.step) * 10000) / 10000;\n  }\n\n  return tickValues;\n};\n\nexport const getDomainAndRangeByChartType = (domain, range, chartType) => {\n  let { step, labelStep, min, max } = range || {};\n\n  if (!min) {\n    min = 0;\n  }\n\n  if (!max || max < 0) {\n    max = range.min + 1;\n  }\n\n  if (!step) {\n    step = labelStep || 1;\n  }\n  if (!labelStep || (isNaN(labelStep) && step)) {\n    labelStep = step || 1;\n  }\n\n  range.max = max;\n\n  switch (chartType) {\n    // if chart is dot plot or line plot, we should ignore step and make sure that min & max are integer values\n    case 'dotPlot':\n    case 'linePlot': {\n      const intMin = Math.round(min);\n      const intMax = Math.round(max);\n\n      return {\n        domain: {\n          ...domain,\n          step: 1,\n          labelStep: 1,\n          min: 0,\n          max: 1,\n        },\n        range: {\n          ...range,\n          min: intMin,\n          max: intMin === intMax ? intMin + 1 : intMax,\n          labelStep,\n          step: 1,\n        },\n      };\n    }\n\n    default:\n      return {\n        domain: {\n          ...domain,\n          step: 1,\n          labelStep: 1,\n          min: 0,\n          max: 1,\n        },\n        range: {\n          ...range,\n          labelStep,\n          step,\n        },\n      };\n  }\n};\n\nexport const getGridLinesAndAxisByChartType = (range, chartType) => {\n  switch (chartType) {\n    case 'lineDot':\n    case 'lineCross':\n      return {\n        verticalLines: undefined,\n        horizontalLines: getTickValues(range),\n        leftAxis: true,\n      };\n\n    case 'dotPlot':\n    case 'linePlot':\n      return {\n        verticalLines: [],\n        horizontalLines: [],\n        leftAxis: false,\n      };\n\n    default:\n      return {\n        verticalLines: [],\n        horizontalLines: getTickValues(range),\n        leftAxis: true,\n      };\n  }\n};\n\nexport const getRotateAngle = (fontSize, height) => {\n  if (height >= fontSize * 2) {\n    return 25;\n  }\n\n  return 0;\n};\n\nexport const getTopPadding = (barWidth) => {\n  if (barWidth < 30) {\n    return 50;\n  }\n\n  if (barWidth < 40) {\n    return 30;\n  }\n\n  if (barWidth < 60) {\n    return 15;\n  }\n\n  return 0;\n};\n\n// This function calculates the transformation scale for SVG and the icon's vertical distance from its category\nexport const getScale = (width) => {\n  let scale, deltay;\n\n  if (width > 91) {\n    scale = 1.3;\n    deltay = -55;\n  } else if (width > 45) {\n    scale = 1.1;\n    deltay = -45;\n  } else if (width > 40) {\n    scale = 0.5 + (width - 34) * 0.02;\n    deltay = -25;\n  } else if (width > 30) {\n    scale = 0.5 + (width - 34) * 0.02;\n    deltay = -20;\n  } else {\n    scale = 0.5 * Math.pow(0.98, 34 - width); // 0.98 is the reduction factor. Adjust to control scaling.\n    deltay = -15;\n  }\n\n  return { scale, deltay };\n};\n\nexport const getAdjustedX = (width, scaleValue) => {\n  const innerWidthOriginal = 57;\n  const effectiveInnerWidth = innerWidthOriginal * scaleValue;\n  return (width - effectiveInnerWidth) / 2;\n};\n"]}
244
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils.js"],"names":["tickCount","utils","bounds","point","bandKey","d","index","label","dataToXBand","scaleX","data","width","type","rangeRound","domain","map","padding","range","getTickValues","prop","tickValues","tickVal","min","max","push","Math","round","step","getDomainAndRangeByChartType","chartType","labelStep","isNaN","intMin","intMax","getGridLinesAndAxisByChartType","verticalLines","undefined","horizontalLines","leftAxis","getRotateAngle","fontSize","height","getTopPadding","barWidth","getScale","scale","deltay","pow","getAdjustedX","scaleValue","innerWidthOriginal","effectiveInnerWidth"],"mappings":"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","sourcesContent":["import { scaleBand, scalePoint } from '@vx/scale';\nimport { utils } from '@pie-lib/plot';\n\nexport const tickCount = utils.tickCount;\nexport const bounds = utils.bounds;\nexport const point = utils.point;\n\nexport const bandKey = (d, index) => `${index}-${d.label || '-'}`;\n\nexport const dataToXBand = (scaleX, data, width, type) => {\n switch (type) {\n case 'bar':\n case 'dotPlot':\n case 'linePlot':\n return scaleBand({\n rangeRound: [0, width],\n domain: data && data.map(bandKey),\n padding: 0.2,\n });\n\n case 'histogram':\n return scaleBand({\n rangeRound: [0, width],\n domain: data && data.map(bandKey),\n padding: 0,\n });\n\n case 'lineCross':\n case 'lineDot':\n return scalePoint({\n domain: data && data.map(bandKey),\n rangeRound: [0, width],\n });\n\n default:\n return scaleBand({\n range: [0, width],\n domain: data && data.map(bandKey),\n padding: 0,\n });\n }\n};\n\nexport const getTickValues = (prop = {}) => {\n const tickValues = [];\n let tickVal = prop.min;\n\n while (tickVal <= prop.max) {\n tickValues.push(tickVal);\n tickVal = Math.round((tickVal + prop.step) * 10000) / 10000;\n }\n\n return tickValues;\n};\n\nexport const getDomainAndRangeByChartType = (domain, range, chartType) => {\n let { step, labelStep, min, max } = range || {};\n\n if (!min) {\n min = 0;\n }\n\n if (!max || max < 0) {\n max = range.min + 1;\n }\n\n if (!step) {\n step = labelStep || 1;\n }\n if (!labelStep || (isNaN(labelStep) && step)) {\n labelStep = step || 1;\n }\n\n range.max = max;\n\n switch (chartType) {\n // if chart is dot plot or line plot, we should ignore step and make sure that min & max are integer values\n case 'dotPlot':\n case 'linePlot': {\n const intMin = Math.round(min);\n const intMax = Math.round(max);\n\n return {\n domain: {\n ...domain,\n step: 1,\n labelStep: 1,\n min: 0,\n max: 1,\n },\n range: {\n ...range,\n min: intMin,\n max: intMin === intMax ? intMin + 1 : intMax,\n labelStep,\n step: 1,\n },\n };\n }\n\n default:\n return {\n domain: {\n ...domain,\n step: 1,\n labelStep: 1,\n min: 0,\n max: 1,\n },\n range: {\n ...range,\n labelStep,\n step,\n },\n };\n }\n};\n\nexport const getGridLinesAndAxisByChartType = (range, chartType) => {\n switch (chartType) {\n case 'lineDot':\n case 'lineCross':\n return {\n verticalLines: undefined,\n horizontalLines: getTickValues(range),\n leftAxis: true,\n };\n\n case 'dotPlot':\n case 'linePlot':\n return {\n verticalLines: [],\n horizontalLines: [],\n leftAxis: false,\n };\n\n default:\n return {\n verticalLines: [],\n horizontalLines: getTickValues(range),\n leftAxis: true,\n };\n }\n};\n\nexport const getRotateAngle = (fontSize, height) => {\n if (height >= fontSize * 2) {\n return 25;\n }\n\n return 0;\n};\n\nexport const getTopPadding = (barWidth) => {\n if (barWidth < 30) {\n return 50;\n }\n\n if (barWidth < 40) {\n return 30;\n }\n\n if (barWidth < 60) {\n return 15;\n }\n\n return 0;\n};\n\n// This function calculates the transformation scale for SVG and the icon's vertical distance from its category\nexport const getScale = (width) => {\n let scale, deltay;\n\n if (width > 91) {\n scale = 1.3;\n deltay = -55;\n } else if (width > 45) {\n scale = 1.1;\n deltay = -45;\n } else if (width > 40) {\n scale = 0.5 + (width - 34) * 0.02;\n deltay = -25;\n } else if (width > 30) {\n scale = 0.5 + (width - 34) * 0.02;\n deltay = -20;\n } else {\n scale = 0.5 * Math.pow(0.98, 34 - width); // 0.98 is the reduction factor. Adjust to control scaling.\n deltay = -15;\n }\n\n return { scale, deltay };\n};\n\nexport const getAdjustedX = (width, scaleValue) => {\n const innerWidthOriginal = 57;\n const effectiveInnerWidth = innerWidthOriginal * scaleValue;\n return (width - effectiveInnerWidth) / 2;\n};\n"],"file":"utils.js"}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "publishConfig": {
4
4
  "access": "public"
5
5
  },
6
- "version": "5.17.0-beta.0",
6
+ "version": "5.18.0",
7
7
  "description": "charting",
8
8
  "keywords": [
9
9
  "react",
@@ -19,8 +19,8 @@
19
19
  "dependencies": {
20
20
  "@mapbox/point-geometry": "^0.1.0",
21
21
  "@material-ui/core": "^3.8.3",
22
- "@pie-lib/plot": "^2.9.0-beta.0",
23
- "@pie-lib/translator": "^2.5.0-beta.0",
22
+ "@pie-lib/plot": "beta",
23
+ "@pie-lib/translator": "beta",
24
24
  "@vx/axis": "^0.0.183",
25
25
  "@vx/event": "^0.0.182",
26
26
  "@vx/grid": "^0.0.183",
@@ -39,10 +39,10 @@
39
39
  "react-input-autosize": "^2.2.1",
40
40
  "react-redux": "^6.0.0",
41
41
  "redux": "^4.0.1",
42
- "redux-undo": "beta"
42
+ "redux-undo": "latest"
43
43
  },
44
44
  "peerDependencies": {
45
45
  "react": "^16.8.1"
46
46
  },
47
- "gitHead": "3818c24530f62b5bb9be7a2c6aa5428f13a17e0a"
47
+ "gitHead": "ecb1ca31aa1c24d23af00d5ad04ce73ed8871057"
48
48
  }
@@ -536,6 +536,7 @@ exports[`TickComponent snapshot1 renders 1`] = `
536
536
  }
537
537
  }
538
538
  inputRef={[Function]}
539
+ limitCharacters={true}
539
540
  mark={
540
541
  Object {
541
542
  "label": "test",
@@ -4,12 +4,6 @@ exports[`ChartAxes snapshot renders 1`] = `
4
4
  <div
5
5
  className="className"
6
6
  >
7
- <div>
8
- <ToolMenu
9
- addCategory={[Function]}
10
- disabled={true}
11
- />
12
- </div>
13
7
  <WithStyles(Root)
14
8
  defineChart={false}
15
9
  disabledLabels={true}
@@ -205,12 +199,6 @@ exports[`ChartAxes snapshot renders if size is not defined 1`] = `
205
199
  <div
206
200
  className="className"
207
201
  >
208
- <div>
209
- <ToolMenu
210
- addCategory={[Function]}
211
- disabled={true}
212
- />
213
- </div>
214
202
  <WithStyles(Root)
215
203
  defineChart={false}
216
204
  disabledLabels={true}
@@ -410,12 +398,6 @@ exports[`ChartAxes snapshot renders without chartType property 1`] = `
410
398
  <div
411
399
  className="className"
412
400
  >
413
- <div>
414
- <ToolMenu
415
- addCategory={[Function]}
416
- disabled={true}
417
- />
418
- </div>
419
401
  <WithStyles(Root)
420
402
  defineChart={false}
421
403
  disabledLabels={true}
@@ -1,28 +1,72 @@
1
1
  // Jest Snapshot v1, https://goo.gl/fbAQLP
2
2
 
3
3
  exports[`Grid snapshot renders 1`] = `
4
- <r
4
+ <g
5
5
  className="className"
6
- height={400}
7
- width={400}
8
- xOffset={NaN}
9
- xScale={
10
- Object {
11
- "bandwidth": [Function],
6
+ >
7
+ <q
8
+ lineStyle={
9
+ Object {
10
+ "stroke": "var(--pie-faded-primary, #DCDAFB)",
11
+ "strokeWidth": 1,
12
+ }
12
13
  }
13
- }
14
- yScale={[MockFunction]}
15
- />
14
+ scale={[MockFunction]}
15
+ tickValues={Array []}
16
+ width={400}
17
+ />
18
+ <q
19
+ lineStyle={
20
+ Object {
21
+ "stroke": "#8E88EA",
22
+ "strokeWidth": 1,
23
+ }
24
+ }
25
+ scale={[MockFunction]}
26
+ tickValues={Array []}
27
+ width={400}
28
+ />
29
+ <V
30
+ height={400}
31
+ offset={NaN}
32
+ scale={
33
+ Object {
34
+ "bandwidth": [Function],
35
+ }
36
+ }
37
+ />
38
+ </g>
16
39
  `;
17
40
 
18
41
  exports[`Grid snapshot renders if graphProps is not defined 1`] = `
19
- <r
42
+ <g
20
43
  className="className"
21
- xOffset={NaN}
22
- xScale={
23
- Object {
24
- "bandwidth": [Function],
44
+ >
45
+ <q
46
+ lineStyle={
47
+ Object {
48
+ "stroke": "var(--pie-faded-primary, #DCDAFB)",
49
+ "strokeWidth": 1,
50
+ }
51
+ }
52
+ tickValues={Array []}
53
+ />
54
+ <q
55
+ lineStyle={
56
+ Object {
57
+ "stroke": "#8E88EA",
58
+ "strokeWidth": 1,
59
+ }
60
+ }
61
+ tickValues={Array []}
62
+ />
63
+ <V
64
+ offset={NaN}
65
+ scale={
66
+ Object {
67
+ "bandwidth": [Function],
68
+ }
25
69
  }
26
- }
27
- />
70
+ />
71
+ </g>
28
72
  `;
@@ -137,10 +137,5 @@ describe('TickComponent', () => {
137
137
  w.instance().changeCategory(0, 'new label');
138
138
  expect(onChangeCategory).toHaveBeenCalledWith(0, { value: 1, label: 'new label' });
139
139
  });
140
-
141
- it('calls onChange', () => {
142
- w.instance().deleteCategory(0);
143
- expect(onChange).toHaveBeenCalledWith([]);
144
- });
145
140
  });
146
141
  });
@@ -83,5 +83,13 @@ describe('ChartAxes', () => {
83
83
 
84
84
  expect(chart.type).toEqual('bar');
85
85
  });
86
+
87
+ it('deleteCategory', () => {
88
+ const w = wrapper();
89
+
90
+ w.instance().deleteCategory(0);
91
+
92
+ expect(onDataChange).toHaveBeenCalled();
93
+ });
86
94
  });
87
95
  });
@@ -0,0 +1,109 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { withStyles } from '@material-ui/core/styles';
4
+ import Button from '@material-ui/core/Button';
5
+ import Popover from '@material-ui/core/Popover';
6
+ import Paper from '@material-ui/core/Paper';
7
+
8
+ import { color } from '../../render-ui/src/index';
9
+ import Translator from '@pie-lib/translator';
10
+
11
+ const { translator } = Translator;
12
+
13
+ export class ActionsButton extends React.Component {
14
+ constructor(props) {
15
+ super(props);
16
+ this.state = {
17
+ actionsAnchorEl: null,
18
+ };
19
+ }
20
+
21
+ static propTypes = {
22
+ classes: PropTypes.object.isRequired,
23
+ categories: PropTypes.array,
24
+ addCategory: PropTypes.func.isRequired,
25
+ deleteCategory: PropTypes.func.isRequired,
26
+ language: PropTypes.string.isRequired,
27
+ };
28
+
29
+ handleActionsClick = (event) => {
30
+ this.setState({ actionsAnchorEl: event.currentTarget });
31
+ };
32
+
33
+ handleActionsClose = () => {
34
+ this.setState({ actionsAnchorEl: null });
35
+ };
36
+
37
+ handleAddCategory = () => {
38
+ const { addCategory } = this.props;
39
+ addCategory();
40
+ this.handleActionsClose();
41
+ };
42
+
43
+ handleDeleteCategory = (index) => {
44
+ const { deleteCategory } = this.props;
45
+ deleteCategory(index);
46
+ this.handleActionsClose();
47
+ };
48
+
49
+ render() {
50
+ const { classes, categories, language } = this.props;
51
+
52
+ return (
53
+ <div className={classes.actions}>
54
+ <div role="button" tabIndex={0} className={classes.trigger} onClick={this.handleActionsClick}>
55
+ Actions
56
+ </div>
57
+ <Popover
58
+ open={Boolean(this.state.actionsAnchorEl)}
59
+ anchorEl={this.state.actionsAnchorEl}
60
+ onClose={this.handleActionsClose}
61
+ anchorOrigin={{ vertical: 'bottom', horizontal: 'left' }}
62
+ transformOrigin={{ vertical: 'top', horizontal: 'left' }}
63
+ >
64
+ <Paper className={classes.actionsPaper}>
65
+ <Button onClick={() => this.handleAddCategory()}>
66
+ + {translator.t('charting.add', { lng: language })}
67
+ </Button>
68
+ {categories.length > 0 &&
69
+ categories.map(
70
+ (category, index) =>
71
+ category.deletable &&
72
+ !category.correctness && (
73
+ <Button key={index} onClick={() => this.handleDeleteCategory(index)}>
74
+ {`${translator.t('charting.delete', { lng: language })} <${category.label ||
75
+ translator.t('charting.newLabel', { lng: language })}>`}
76
+ </Button>
77
+ ),
78
+ )}
79
+ </Paper>
80
+ </Popover>
81
+ </div>
82
+ );
83
+ }
84
+ }
85
+
86
+ const styles = (theme) => ({
87
+ actions: {
88
+ alignSelf: 'flex-end',
89
+ },
90
+ trigger: {
91
+ cursor: 'pointer',
92
+ fontSize: theme.typography.fontSize,
93
+ color: color.tertiary(),
94
+ },
95
+ actionsPaper: {
96
+ padding: theme.spacing.unit,
97
+ display: 'flex',
98
+ flexDirection: 'column',
99
+ gap: theme.spacing.unit,
100
+ '& button': {
101
+ textTransform: 'none',
102
+ fontSize: theme.typography.fontSize,
103
+ color: color.text(),
104
+ justifyContent: 'flex-start',
105
+ },
106
+ },
107
+ });
108
+
109
+ export default withStyles(styles)(ActionsButton);
package/src/axes.jsx CHANGED
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { withStyles } from '@material-ui/core/styles';
4
4
  import { types } from '@pie-lib/plot';
5
- import { color } from '@pie-lib/render-ui';
5
+ import { color } from '../../render-ui/src/index';
6
6
  import { AlertDialog } from '@pie-lib/config-ui';
7
7
  import { AxisLeft, AxisBottom } from '@vx/axis';
8
8
  import { bandKey, getTickValues, getRotateAngle } from './utils';
@@ -45,14 +45,6 @@ export class TickComponent extends React.Component {
45
45
  onChangeCategory(index, { ...category, label: newLabel });
46
46
  };
47
47
 
48
- deleteCategory = (index) => {
49
- const { categories, onChange } = this.props;
50
-
51
- if (index >= 0 && categories[index]) {
52
- onChange([...categories.slice(0, index), ...categories.slice(index + 1)]);
53
- }
54
- };
55
-
56
48
  changeInteractive = (index, value) => {
57
49
  const { categories, onChangeCategory } = this.props;
58
50
  const category = categories[index];
@@ -144,7 +136,7 @@ export class TickComponent extends React.Component {
144
136
  const { changeEditable, changeInteractive } = chartingOptions || {};
145
137
  const index = parseInt(formattedValue.split('-')[0], 10);
146
138
  const category = categories[index];
147
- const { deletable, editable, interactive, label, correctness } = category || {};
139
+ const { editable, interactive, label, correctness } = category || {};
148
140
  const barX = xBand(bandKey({ label }, index));
149
141
  const longestCategory = (categories || []).reduce((a, b) => {
150
142
  const lengthA = a && a.label ? a.label.length : 0;
@@ -185,6 +177,7 @@ export class TickComponent extends React.Component {
185
177
  rotate={rotate}
186
178
  correctness={correctness}
187
179
  error={error && error[index]}
180
+ limitCharacters
188
181
  />
189
182
  </foreignObject>
190
183
 
@@ -194,24 +187,6 @@ export class TickComponent extends React.Component {
194
187
  </text>
195
188
  )}
196
189
 
197
- {deletable && !correctness && (
198
- <line x1={x} y1={0} x2={x} y2={y + 4 + top} className={classes.dottedLine} strokeDasharray="4 2" />
199
- )}
200
-
201
- {deletable && !correctness && (
202
- <svg
203
- xmlns="http://www.w3.org/2000/svg"
204
- x={x - 8}
205
- y={y + 60 + top}
206
- width={16}
207
- height={16}
208
- viewBox="0 0 512 512"
209
- onClick={() => this.deleteCategory(index)}
210
- >
211
- <path d="M128 405.429C128 428.846 147.198 448 170.667 448h170.667C364.802 448 384 428.846 384 405.429V160H128v245.429zM416 96h-80l-26.785-32H202.786L176 96H96v32h320V96z" />
212
- </svg>
213
- )}
214
-
215
190
  {defineChart && index === 0 && (
216
191
  <svg
217
192
  x={-55}
@@ -493,7 +468,7 @@ const ChartAxes = withStyles(
493
468
  strokeWidth: 2,
494
469
  },
495
470
  axisLine: {
496
- stroke: color.primaryDark(),
471
+ stroke: color.visualElementsColors.AXIS_LINE_COLOR,
497
472
  strokeWidth: 2,
498
473
  },
499
474
  tick: {
@@ -501,7 +476,6 @@ const ChartAxes = withStyles(
501
476
  stroke: color.primaryDark(),
502
477
  strokeWidth: 2,
503
478
  },
504
- fill: color.primaryDark(),
505
479
  fontFamily: theme.typography.body1.fontFamily,
506
480
  fontSize: theme.typography.fontSize,
507
481
  textAnchor: 'middle',
@@ -515,7 +489,7 @@ const ChartAxes = withStyles(
515
489
  fill: theme.palette.error.main,
516
490
  },
517
491
  customColor: {
518
- color: `${color.tertiary()} !important`
492
+ color: `${color.tertiary()} !important`,
519
493
  },
520
494
  }),
521
495
  { withTheme: true },
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { types } from '@pie-lib/plot';
4
4
  import { Group } from '@vx/group';
5
- import { color } from '@pie-lib/render-ui';
5
+ import { color } from '../../../render-ui/src/index';
6
6
  import { Bar as VxBar } from '@vx/shape';
7
7
  import { withStyles } from '@material-ui/core/styles/index';
8
8
  import debug from 'debug';
@@ -39,12 +39,12 @@ const hoverHistogramColors = [
39
39
  '#894A65',
40
40
  ];
41
41
 
42
- const calculateFillColor = (isHovered, barColor, index, hoverHistogramColors) => {
43
- if (isHovered && barColor) {
42
+ const calculateFillColor = (isHovered, barColor, index, hoverHistogramColors, allowRolloverEvent) => {
43
+ if (isHovered && barColor && allowRolloverEvent) {
44
44
  return hoverHistogramColors[index % hoverHistogramColors.length];
45
45
  }
46
- if (isHovered) {
47
- return color.primaryDark();
46
+ if (isHovered && allowRolloverEvent) {
47
+ return color.visualElementsColors.ROLLOVER_FILL_BAR_COLOR;
48
48
  }
49
49
  return barColor || null;
50
50
  };
@@ -148,7 +148,8 @@ export class RawBar extends React.Component {
148
148
  const { scale, range } = graphProps;
149
149
  const { dragValue, isHovered } = this.state;
150
150
 
151
- const fillColor = calculateFillColor(isHovered, barColor, index, hoverHistogramColors);
151
+ const allowRolloverEvent = interactive && !correctness;
152
+ const fillColor = calculateFillColor(isHovered, barColor, index, hoverHistogramColors, allowRolloverEvent);
152
153
  const v = Number.isFinite(dragValue) ? dragValue : value;
153
154
  const barWidth = xBand.bandwidth();
154
155
  const barHeight = scale.y(range.max - v);
@@ -195,10 +196,7 @@ export class RawBar extends React.Component {
195
196
 
196
197
  const Bar = withStyles(() => ({
197
198
  bar: {
198
- fill: color.primaryLight(),
199
- '&:hover': {
200
- fill: color.primaryDark(),
201
- },
199
+ fill: color.defaults.TERTIARY,
202
200
  },
203
201
  }))(RawBar);
204
202
 
@@ -1,6 +1,6 @@
1
1
  import React, { useState, useEffect } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- import { color } from '@pie-lib/render-ui';
3
+ import { color } from '../../render-ui/src/index';
4
4
  import { withStyles } from '@material-ui/core/styles';
5
5
  import Typography from '@material-ui/core/Typography';
6
6
  import ChartType from './chart-type';