@pie-lib/charting 5.15.7 → 5.17.0-beta.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 (132) hide show
  1. package/CHANGELOG.md +9 -1
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/lib/__tests__/axes.test.js +181 -0
  4. package/lib/__tests__/chart-setup.test.js +58 -0
  5. package/lib/__tests__/chart-type.test.js +42 -0
  6. package/lib/__tests__/chart.test.js +108 -0
  7. package/lib/__tests__/grid.test.js +48 -0
  8. package/lib/__tests__/mark-label.test.js +57 -0
  9. package/lib/__tests__/utils.js +56 -0
  10. package/lib/__tests__/utils.test.js +197 -0
  11. package/lib/axes.js +75 -30
  12. package/lib/bars/__tests__/bar.test.js +62 -0
  13. package/lib/bars/__tests__/histogram.test.js +64 -0
  14. package/lib/bars/__tests__/utils.js +56 -0
  15. package/lib/bars/bar.js +1 -1
  16. package/lib/bars/common/__tests__/bars.test.js +100 -0
  17. package/lib/bars/common/__tests__/utils.js +56 -0
  18. package/lib/bars/common/bars.js +36 -2
  19. package/lib/bars/histogram.js +1 -1
  20. package/lib/chart-setup.js +1 -1
  21. package/lib/chart-type.js +5 -5
  22. package/lib/chart-types.js +3 -3
  23. package/lib/chart.js +26 -11
  24. package/lib/common/__tests__/drag-handle.test.js +134 -0
  25. package/lib/common/__tests__/utils.js +56 -0
  26. package/lib/common/drag-handle.js +12 -6
  27. package/lib/common/drag-icon.js +8 -25
  28. package/lib/common/styles.js +1 -1
  29. package/lib/grid.js +1 -1
  30. package/lib/index.js +1 -1
  31. package/lib/line/__tests__/line-cross.test.js +64 -0
  32. package/lib/line/__tests__/line-dot.test.js +64 -0
  33. package/lib/line/__tests__/utils.js +56 -0
  34. package/lib/line/common/__tests__/drag-handle.test.js +134 -0
  35. package/lib/line/common/__tests__/line.test.js +128 -0
  36. package/lib/line/common/__tests__/utils.js +56 -0
  37. package/lib/line/common/drag-handle.js +10 -5
  38. package/lib/line/common/line.js +1 -1
  39. package/lib/line/line-cross.js +17 -6
  40. package/lib/line/line-dot.js +11 -3
  41. package/lib/mark-label.js +21 -12
  42. package/lib/plot/__tests__/dot.test.js +64 -0
  43. package/lib/plot/__tests__/line.test.js +64 -0
  44. package/lib/plot/__tests__/utils.js +56 -0
  45. package/lib/plot/common/__tests__/plot.test.js +103 -0
  46. package/lib/plot/common/__tests__/utils.js +56 -0
  47. package/lib/plot/common/plot.js +4 -2
  48. package/lib/plot/dot.js +2 -2
  49. package/lib/plot/line.js +2 -2
  50. package/lib/tool-menu.js +1 -5
  51. package/lib/utils.js +1 -1
  52. package/package.json +4 -4
  53. package/src/__tests__/__snapshots__/axes.test.jsx.snap +564 -0
  54. package/src/__tests__/__snapshots__/chart-type.test.jsx.snap +14 -0
  55. package/src/__tests__/__snapshots__/chart.test.jsx.snap +610 -0
  56. package/src/__tests__/__snapshots__/grid.test.jsx.snap +28 -0
  57. package/src/__tests__/__snapshots__/mark-label.test.jsx.snap +67 -0
  58. package/src/__tests__/axes.test.jsx +146 -0
  59. package/src/__tests__/chart-setup.test.jsx +47 -0
  60. package/src/__tests__/chart-type.test.jsx +29 -0
  61. package/src/__tests__/chart.test.jsx +87 -0
  62. package/src/__tests__/grid.test.jsx +25 -0
  63. package/src/__tests__/mark-label.test.jsx +31 -0
  64. package/src/__tests__/utils.js +30 -0
  65. package/src/__tests__/utils.test.js +100 -0
  66. package/src/axes.jsx +59 -23
  67. package/src/bars/__tests__/__snapshots__/bar.test.jsx.snap +43 -0
  68. package/src/bars/__tests__/__snapshots__/histogram.test.jsx.snap +45 -0
  69. package/src/bars/__tests__/bar.test.jsx +37 -0
  70. package/src/bars/__tests__/histogram.test.jsx +38 -0
  71. package/src/bars/__tests__/utils.js +30 -0
  72. package/src/bars/common/__tests__/__snapshots__/bars.test.jsx.snap +110 -0
  73. package/src/bars/common/__tests__/bars.test.jsx +69 -0
  74. package/src/bars/common/__tests__/utils.js +30 -0
  75. package/src/bars/common/bars.jsx +37 -1
  76. package/src/chart-type.js +7 -3
  77. package/src/chart-types.js +2 -2
  78. package/src/chart.jsx +15 -5
  79. package/src/common/__tests__/__snapshots__/drag-handle.test.jsx.snap +45 -0
  80. package/src/common/__tests__/drag-handle.test.jsx +88 -0
  81. package/src/common/__tests__/utils.js +30 -0
  82. package/src/common/drag-handle.jsx +18 -10
  83. package/src/common/drag-icon.jsx +6 -21
  84. package/src/line/__tests__/__snapshots__/line-cross.test.jsx.snap +45 -0
  85. package/src/line/__tests__/__snapshots__/line-dot.test.jsx.snap +45 -0
  86. package/src/line/__tests__/line-cross.test.jsx +38 -0
  87. package/src/line/__tests__/line-dot.test.jsx +38 -0
  88. package/src/line/__tests__/utils.js +30 -0
  89. package/src/line/common/__tests__/__snapshots__/drag-handle.test.jsx.snap +44 -0
  90. package/src/line/common/__tests__/__snapshots__/line.test.jsx.snap +141 -0
  91. package/src/line/common/__tests__/drag-handle.test.jsx +88 -0
  92. package/src/line/common/__tests__/line.test.jsx +82 -0
  93. package/src/line/common/__tests__/utils.js +30 -0
  94. package/src/line/common/drag-handle.jsx +9 -4
  95. package/src/line/line-cross.js +4 -1
  96. package/src/line/line-dot.js +17 -7
  97. package/src/mark-label.jsx +19 -7
  98. package/src/plot/__tests__/__snapshots__/dot.test.jsx.snap +45 -0
  99. package/src/plot/__tests__/__snapshots__/line.test.jsx.snap +45 -0
  100. package/src/plot/__tests__/dot.test.jsx +38 -0
  101. package/src/plot/__tests__/line.test.jsx +38 -0
  102. package/src/plot/__tests__/utils.js +30 -0
  103. package/src/plot/common/__tests__/__snapshots__/plot.test.jsx.snap +96 -0
  104. package/src/plot/common/__tests__/plot.test.jsx +70 -0
  105. package/src/plot/common/__tests__/utils.js +30 -0
  106. package/src/plot/common/plot.jsx +6 -1
  107. package/src/plot/dot.js +1 -1
  108. package/src/plot/line.js +1 -1
  109. package/src/tool-menu.jsx +0 -4
  110. package/lib/axes.js.map +0 -1
  111. package/lib/bars/bar.js.map +0 -1
  112. package/lib/bars/common/bars.js.map +0 -1
  113. package/lib/bars/histogram.js.map +0 -1
  114. package/lib/chart-setup.js.map +0 -1
  115. package/lib/chart-type.js.map +0 -1
  116. package/lib/chart-types.js.map +0 -1
  117. package/lib/chart.js.map +0 -1
  118. package/lib/common/drag-handle.js.map +0 -1
  119. package/lib/common/drag-icon.js.map +0 -1
  120. package/lib/common/styles.js.map +0 -1
  121. package/lib/grid.js.map +0 -1
  122. package/lib/index.js.map +0 -1
  123. package/lib/line/common/drag-handle.js.map +0 -1
  124. package/lib/line/common/line.js.map +0 -1
  125. package/lib/line/line-cross.js.map +0 -1
  126. package/lib/line/line-dot.js.map +0 -1
  127. package/lib/mark-label.js.map +0 -1
  128. package/lib/plot/common/plot.js.map +0 -1
  129. package/lib/plot/dot.js.map +0 -1
  130. package/lib/plot/line.js.map +0 -1
  131. package/lib/tool-menu.js.map +0 -1
  132. package/lib/utils.js.map +0 -1
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
8
+
9
+ var _enzyme = require("enzyme");
10
+
11
+ var _react = _interopRequireDefault(require("react"));
12
+
13
+ var _histogram = _interopRequireWildcard(require("../histogram"));
14
+
15
+ var _utils = require("./utils");
16
+
17
+ var _bar = require("../bar");
18
+
19
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
20
+
21
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
22
+
23
+ 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; }
24
+
25
+ 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; }
26
+
27
+ describe('HistogramChart', function () {
28
+ var wrapper = function wrapper(extras) {
29
+ var defaults = {
30
+ classes: {},
31
+ className: 'className',
32
+ graphProps: (0, _utils.graphProps)(),
33
+ xBand: function xBand() {
34
+ return {
35
+ bandwidth: function bandwidth() {}
36
+ };
37
+ }
38
+ };
39
+
40
+ var props = _objectSpread(_objectSpread({}, defaults), extras);
41
+
42
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_histogram.Histogram, props));
43
+ };
44
+
45
+ describe('snapshot', function () {
46
+ it('renders', function () {
47
+ return expect(wrapper()).toMatchSnapshot();
48
+ });
49
+ it('renders without graphProps', function () {
50
+ return expect(wrapper({
51
+ graphProps: undefined
52
+ })).toMatchSnapshot();
53
+ });
54
+ });
55
+ describe('component', function () {
56
+ var chart = (0, _histogram["default"])();
57
+ expect(chart).toEqual({
58
+ type: 'histogram',
59
+ Component: _histogram.Histogram,
60
+ name: 'Histogram'
61
+ });
62
+ });
63
+ });
64
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYXJzL19fdGVzdHNfXy9oaXN0b2dyYW0udGVzdC5qc3giXSwibmFtZXMiOlsiZGVzY3JpYmUiLCJ3cmFwcGVyIiwiZXh0cmFzIiwiZGVmYXVsdHMiLCJjbGFzc2VzIiwiY2xhc3NOYW1lIiwiZ3JhcGhQcm9wcyIsInhCYW5kIiwiYmFuZHdpZHRoIiwicHJvcHMiLCJpdCIsImV4cGVjdCIsInRvTWF0Y2hTbmFwc2hvdCIsInVuZGVmaW5lZCIsImNoYXJ0IiwidG9FcXVhbCIsInR5cGUiLCJDb21wb25lbnQiLCJIaXN0b2dyYW1DaGFydCIsIm5hbWUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7QUFFQUEsUUFBUSxDQUFDLGdCQUFELEVBQW1CLFlBQU07QUFDL0IsTUFBTUMsT0FBTyxHQUFHLFNBQVZBLE9BQVUsQ0FBQ0MsTUFBRCxFQUFZO0FBQzFCLFFBQU1DLFFBQVEsR0FBRztBQUNmQyxNQUFBQSxPQUFPLEVBQUUsRUFETTtBQUVmQyxNQUFBQSxTQUFTLEVBQUUsV0FGSTtBQUdmQyxNQUFBQSxVQUFVLEVBQUUsd0JBSEc7QUFJZkMsTUFBQUEsS0FBSyxFQUFFLGlCQUFNO0FBQ1gsZUFBTztBQUNMQyxVQUFBQSxTQUFTLEVBQUUscUJBQU0sQ0FBRTtBQURkLFNBQVA7QUFHRDtBQVJjLEtBQWpCOztBQVVBLFFBQU1DLEtBQUssbUNBQVFOLFFBQVIsR0FBcUJELE1BQXJCLENBQVg7O0FBQ0EsV0FBTyxtQ0FBUSxnQ0FBQyxvQkFBRCxFQUFvQk8sS0FBcEIsQ0FBUixDQUFQO0FBQ0QsR0FiRDs7QUFlQVQsRUFBQUEsUUFBUSxDQUFDLFVBQUQsRUFBYSxZQUFNO0FBQ3pCVSxJQUFBQSxFQUFFLENBQUMsU0FBRCxFQUFZO0FBQUEsYUFBTUMsTUFBTSxDQUFDVixPQUFPLEVBQVIsQ0FBTixDQUFrQlcsZUFBbEIsRUFBTjtBQUFBLEtBQVosQ0FBRjtBQUVBRixJQUFBQSxFQUFFLENBQUMsNEJBQUQsRUFBK0I7QUFBQSxhQUFNQyxNQUFNLENBQUNWLE9BQU8sQ0FBQztBQUFFSyxRQUFBQSxVQUFVLEVBQUVPO0FBQWQsT0FBRCxDQUFSLENBQU4sQ0FBMkNELGVBQTNDLEVBQU47QUFBQSxLQUEvQixDQUFGO0FBQ0QsR0FKTyxDQUFSO0FBTUFaLEVBQUFBLFFBQVEsQ0FBQyxXQUFELEVBQWMsWUFBTTtBQUMxQixRQUFNYyxLQUFLLEdBQUcsNEJBQWQ7QUFFQUgsSUFBQUEsTUFBTSxDQUFDRyxLQUFELENBQU4sQ0FBY0MsT0FBZCxDQUFzQjtBQUNwQkMsTUFBQUEsSUFBSSxFQUFFLFdBRGM7QUFFcEJDLE1BQUFBLFNBQVMsRUFBRUMsb0JBRlM7QUFHcEJDLE1BQUFBLElBQUksRUFBRTtBQUhjLEtBQXRCO0FBS0QsR0FSTyxDQUFSO0FBU0QsQ0EvQk8sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNoYWxsb3cgfSBmcm9tICdlbnp5bWUnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBIaXN0b2dyYW0sIHsgSGlzdG9ncmFtIGFzIEhpc3RvZ3JhbUNoYXJ0IH0gZnJvbSAnLi4vaGlzdG9ncmFtJztcbmltcG9ydCB7IGdyYXBoUHJvcHMgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IEJhciBhcyBCYXJDaGFydCB9IGZyb20gJy4uL2Jhcic7XG5cbmRlc2NyaWJlKCdIaXN0b2dyYW1DaGFydCcsICgpID0+IHtcbiAgY29uc3Qgd3JhcHBlciA9IChleHRyYXMpID0+IHtcbiAgICBjb25zdCBkZWZhdWx0cyA9IHtcbiAgICAgIGNsYXNzZXM6IHt9LFxuICAgICAgY2xhc3NOYW1lOiAnY2xhc3NOYW1lJyxcbiAgICAgIGdyYXBoUHJvcHM6IGdyYXBoUHJvcHMoKSxcbiAgICAgIHhCYW5kOiAoKSA9PiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgYmFuZHdpZHRoOiAoKSA9PiB7fSxcbiAgICAgICAgfTtcbiAgICAgIH0sXG4gICAgfTtcbiAgICBjb25zdCBwcm9wcyA9IHsgLi4uZGVmYXVsdHMsIC4uLmV4dHJhcyB9O1xuICAgIHJldHVybiBzaGFsbG93KDxIaXN0b2dyYW1DaGFydCB7Li4ucHJvcHN9IC8+KTtcbiAgfTtcblxuICBkZXNjcmliZSgnc25hcHNob3QnLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMnLCAoKSA9PiBleHBlY3Qod3JhcHBlcigpKS50b01hdGNoU25hcHNob3QoKSk7XG5cbiAgICBpdCgncmVuZGVycyB3aXRob3V0IGdyYXBoUHJvcHMnLCAoKSA9PiBleHBlY3Qod3JhcHBlcih7IGdyYXBoUHJvcHM6IHVuZGVmaW5lZCB9KSkudG9NYXRjaFNuYXBzaG90KCkpO1xuICB9KTtcblxuICBkZXNjcmliZSgnY29tcG9uZW50JywgKCkgPT4ge1xuICAgIGNvbnN0IGNoYXJ0ID0gSGlzdG9ncmFtKCk7XG5cbiAgICBleHBlY3QoY2hhcnQpLnRvRXF1YWwoe1xuICAgICAgdHlwZTogJ2hpc3RvZ3JhbScsXG4gICAgICBDb21wb25lbnQ6IEhpc3RvZ3JhbUNoYXJ0LFxuICAgICAgbmFtZTogJ0hpc3RvZ3JhbScsXG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.scaleMock = exports.graphProps = void 0;
7
+
8
+ var scaleMock = function scaleMock() {
9
+ var fn = jest.fn(function (n) {
10
+ return n;
11
+ });
12
+ fn.invert = jest.fn(function (n) {
13
+ return n;
14
+ });
15
+ return fn;
16
+ };
17
+
18
+ exports.scaleMock = scaleMock;
19
+
20
+ var graphProps = function graphProps() {
21
+ var dmin = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
22
+ var dmax = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
23
+ var rmin = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
24
+ var rmax = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
25
+ return {
26
+ scale: {
27
+ x: scaleMock(),
28
+ y: scaleMock()
29
+ },
30
+ snap: {
31
+ x: jest.fn(function (n) {
32
+ return n;
33
+ }),
34
+ y: jest.fn(function (n) {
35
+ return n;
36
+ })
37
+ },
38
+ domain: {
39
+ min: dmin,
40
+ max: dmax,
41
+ step: 1
42
+ },
43
+ range: {
44
+ min: rmin,
45
+ max: rmax,
46
+ step: 1
47
+ },
48
+ size: {
49
+ width: 400,
50
+ height: 400
51
+ }
52
+ };
53
+ };
54
+
55
+ exports.graphProps = graphProps;
56
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYXJzL19fdGVzdHNfXy91dGlscy5qcyJdLCJuYW1lcyI6WyJzY2FsZU1vY2siLCJmbiIsImplc3QiLCJuIiwiaW52ZXJ0IiwiZ3JhcGhQcm9wcyIsImRtaW4iLCJkbWF4Iiwicm1pbiIsInJtYXgiLCJzY2FsZSIsIngiLCJ5Iiwic25hcCIsImRvbWFpbiIsIm1pbiIsIm1heCIsInN0ZXAiLCJyYW5nZSIsInNpemUiLCJ3aWR0aCIsImhlaWdodCJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFPLElBQU1BLFNBQVMsR0FBRyxTQUFaQSxTQUFZLEdBQU07QUFDN0IsTUFBTUMsRUFBRSxHQUFHQyxJQUFJLENBQUNELEVBQUwsQ0FBUSxVQUFDRSxDQUFEO0FBQUEsV0FBT0EsQ0FBUDtBQUFBLEdBQVIsQ0FBWDtBQUNBRixFQUFBQSxFQUFFLENBQUNHLE1BQUgsR0FBWUYsSUFBSSxDQUFDRCxFQUFMLENBQVEsVUFBQ0UsQ0FBRDtBQUFBLFdBQU9BLENBQVA7QUFBQSxHQUFSLENBQVo7QUFDQSxTQUFPRixFQUFQO0FBQ0QsQ0FKTTs7OztBQU1BLElBQU1JLFVBQVUsR0FBRyxTQUFiQSxVQUFhO0FBQUEsTUFBQ0MsSUFBRCx1RUFBUSxDQUFSO0FBQUEsTUFBV0MsSUFBWCx1RUFBa0IsQ0FBbEI7QUFBQSxNQUFxQkMsSUFBckIsdUVBQTRCLENBQTVCO0FBQUEsTUFBK0JDLElBQS9CLHVFQUFzQyxDQUF0QztBQUFBLFNBQTZDO0FBQ3JFQyxJQUFBQSxLQUFLLEVBQUU7QUFDTEMsTUFBQUEsQ0FBQyxFQUFFWCxTQUFTLEVBRFA7QUFFTFksTUFBQUEsQ0FBQyxFQUFFWixTQUFTO0FBRlAsS0FEOEQ7QUFLckVhLElBQUFBLElBQUksRUFBRTtBQUNKRixNQUFBQSxDQUFDLEVBQUVULElBQUksQ0FBQ0QsRUFBTCxDQUFRLFVBQUNFLENBQUQ7QUFBQSxlQUFPQSxDQUFQO0FBQUEsT0FBUixDQURDO0FBRUpTLE1BQUFBLENBQUMsRUFBRVYsSUFBSSxDQUFDRCxFQUFMLENBQVEsVUFBQ0UsQ0FBRDtBQUFBLGVBQU9BLENBQVA7QUFBQSxPQUFSO0FBRkMsS0FMK0Q7QUFTckVXLElBQUFBLE1BQU0sRUFBRTtBQUNOQyxNQUFBQSxHQUFHLEVBQUVULElBREM7QUFFTlUsTUFBQUEsR0FBRyxFQUFFVCxJQUZDO0FBR05VLE1BQUFBLElBQUksRUFBRTtBQUhBLEtBVDZEO0FBY3JFQyxJQUFBQSxLQUFLLEVBQUU7QUFDTEgsTUFBQUEsR0FBRyxFQUFFUCxJQURBO0FBRUxRLE1BQUFBLEdBQUcsRUFBRVAsSUFGQTtBQUdMUSxNQUFBQSxJQUFJLEVBQUU7QUFIRCxLQWQ4RDtBQW1CckVFLElBQUFBLElBQUksRUFBRTtBQUNKQyxNQUFBQSxLQUFLLEVBQUUsR0FESDtBQUVKQyxNQUFBQSxNQUFNLEVBQUU7QUFGSjtBQW5CK0QsR0FBN0M7QUFBQSxDQUFuQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBzY2FsZU1vY2sgPSAoKSA9PiB7XG4gIGNvbnN0IGZuID0gamVzdC5mbigobikgPT4gbik7XG4gIGZuLmludmVydCA9IGplc3QuZm4oKG4pID0+IG4pO1xuICByZXR1cm4gZm47XG59O1xuXG5leHBvcnQgY29uc3QgZ3JhcGhQcm9wcyA9IChkbWluID0gMCwgZG1heCA9IDEsIHJtaW4gPSAwLCBybWF4ID0gMSkgPT4gKHtcbiAgc2NhbGU6IHtcbiAgICB4OiBzY2FsZU1vY2soKSxcbiAgICB5OiBzY2FsZU1vY2soKSxcbiAgfSxcbiAgc25hcDoge1xuICAgIHg6IGplc3QuZm4oKG4pID0+IG4pLFxuICAgIHk6IGplc3QuZm4oKG4pID0+IG4pLFxuICB9LFxuICBkb21haW46IHtcbiAgICBtaW46IGRtaW4sXG4gICAgbWF4OiBkbWF4LFxuICAgIHN0ZXA6IDEsXG4gIH0sXG4gIHJhbmdlOiB7XG4gICAgbWluOiBybWluLFxuICAgIG1heDogcm1heCxcbiAgICBzdGVwOiAxLFxuICB9LFxuICBzaXplOiB7XG4gICAgd2lkdGg6IDQwMCxcbiAgICBoZWlnaHQ6IDQwMCxcbiAgfSxcbn0pO1xuIl19
package/lib/bars/bar.js CHANGED
@@ -83,4 +83,4 @@ var _default = function _default() {
83
83
  };
84
84
 
85
85
  exports["default"] = _default;
86
- //# sourceMappingURL=bar.js.map
86
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iYXJzL2Jhci5qcyJdLCJuYW1lcyI6WyJCYXIiLCJwcm9wcyIsImRhdGEiLCJncmFwaFByb3BzIiwic2NhbGUiLCJzaXplIiwieEJhbmQiLCJ4Iiwid2lkdGgiLCJSZWFjdCIsIkNvbXBvbmVudCIsIlByb3BUeXBlcyIsImFycmF5Iiwib25DaGFuZ2UiLCJmdW5jIiwidHlwZXMiLCJHcmFwaFByb3BzVHlwZSIsImlzUmVxdWlyZWQiLCJ0eXBlIiwibmFtZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7O0lBRWFBLEc7Ozs7Ozs7Ozs7OztXQU9YLGtCQUFTO0FBQ1AsVUFBTUMsS0FBSyxHQUFHLEtBQUtBLEtBQW5CO0FBQ0EsVUFBUUMsSUFBUixHQUE2QkQsS0FBN0IsQ0FBUUMsSUFBUjtBQUFBLFVBQWNDLFVBQWQsR0FBNkJGLEtBQTdCLENBQWNFLFVBQWQ7O0FBQ0EsaUJBQWtDQSxVQUFVLElBQUksRUFBaEQ7QUFBQSw0QkFBUUMsS0FBUjtBQUFBLFVBQVFBLEtBQVIsMkJBQWdCLEVBQWhCO0FBQUEsMkJBQW9CQyxJQUFwQjtBQUFBLFVBQW9CQSxJQUFwQiwwQkFBMkIsRUFBM0I7O0FBQ0EsVUFBTUMsS0FBSyxHQUFHLHdCQUFZRixLQUFLLENBQUNHLENBQWxCLEVBQXFCTCxJQUFyQixFQUEyQkcsSUFBSSxDQUFDRyxLQUFoQyxFQUF1QyxLQUF2QyxDQUFkO0FBRUEsMEJBQU8sZ0NBQUMsZ0JBQUQsZ0NBQVVQLEtBQVY7QUFBaUIsUUFBQSxLQUFLLEVBQUVLO0FBQXhCLFNBQVA7QUFDRDs7O0VBZHNCRyxrQkFBTUMsUzs7O2lDQUFsQlYsRyxlQUNRO0FBQ2pCRSxFQUFBQSxJQUFJLEVBQUVTLHNCQUFVQyxLQURDO0FBRWpCQyxFQUFBQSxRQUFRLEVBQUVGLHNCQUFVRyxJQUZIO0FBR2pCWCxFQUFBQSxVQUFVLEVBQUVZLFlBQU1DLGNBQU4sQ0FBcUJDO0FBSGhCLEM7O2VBZ0JOO0FBQUEsU0FBTztBQUNwQkMsSUFBQUEsSUFBSSxFQUFFLEtBRGM7QUFFcEJSLElBQUFBLFNBQVMsRUFBRVYsR0FGUztBQUdwQm1CLElBQUFBLElBQUksRUFBRTtBQUhjLEdBQVA7QUFBQSxDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJ0BwaWUtbGliL3Bsb3QnO1xuaW1wb3J0IHsgZGF0YVRvWEJhbmQgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgQmFycyBmcm9tICcuL2NvbW1vbi9iYXJzJztcblxuZXhwb3J0IGNsYXNzIEJhciBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZGF0YTogUHJvcFR5cGVzLmFycmF5LFxuICAgIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgICBncmFwaFByb3BzOiB0eXBlcy5HcmFwaFByb3BzVHlwZS5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCBwcm9wcyA9IHRoaXMucHJvcHM7XG4gICAgY29uc3QgeyBkYXRhLCBncmFwaFByb3BzIH0gPSBwcm9wcztcbiAgICBjb25zdCB7IHNjYWxlID0ge30sIHNpemUgPSB7fSB9ID0gZ3JhcGhQcm9wcyB8fCB7fTtcbiAgICBjb25zdCB4QmFuZCA9IGRhdGFUb1hCYW5kKHNjYWxlLngsIGRhdGEsIHNpemUud2lkdGgsICdiYXInKTtcblxuICAgIHJldHVybiA8QmFycyB7Li4ucHJvcHN9IHhCYW5kPXt4QmFuZH0gLz47XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgKCkgPT4gKHtcbiAgdHlwZTogJ2JhcicsXG4gIENvbXBvbmVudDogQmFyLFxuICBuYW1lOiAnQmFyJyxcbn0pO1xuIl19
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
8
+
9
+ var _enzyme = require("enzyme");
10
+
11
+ var _react = _interopRequireDefault(require("react"));
12
+
13
+ var _bars = _interopRequireWildcard(require("../bars"));
14
+
15
+ var _utils = require("./utils");
16
+
17
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
18
+
19
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
20
+
21
+ 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; }
22
+
23
+ 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; }
24
+
25
+ describe('Bars', function () {
26
+ var xBand = function xBand() {};
27
+
28
+ xBand.bandwidth = function () {};
29
+
30
+ var onChange = jest.fn();
31
+
32
+ var wrapper = function wrapper(extras) {
33
+ var defaults = {
34
+ classes: {},
35
+ className: 'className',
36
+ graphProps: (0, _utils.graphProps)(),
37
+ xBand: xBand,
38
+ onChange: onChange,
39
+ data: [{
40
+ value: 0,
41
+ label: '0'
42
+ }]
43
+ };
44
+
45
+ var props = _objectSpread(_objectSpread({}, defaults), extras);
46
+
47
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_bars["default"], props));
48
+ };
49
+
50
+ describe('snapshot', function () {
51
+ it('renders', function () {
52
+ return expect(wrapper()).toMatchSnapshot();
53
+ });
54
+ });
55
+ });
56
+ describe('RawBar', function () {
57
+ var xBand = function xBand() {};
58
+
59
+ xBand.bandwidth = function () {};
60
+
61
+ var onChangeCategory = jest.fn();
62
+
63
+ var wrapper = function wrapper(extras) {
64
+ var defaults = {
65
+ classes: {},
66
+ className: 'className',
67
+ graphProps: (0, _utils.graphProps)(),
68
+ xBand: xBand,
69
+ onChangeCategory: onChangeCategory,
70
+ data: [],
71
+ label: 'label'
72
+ };
73
+
74
+ var props = _objectSpread(_objectSpread({}, defaults), extras);
75
+
76
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_bars.RawBar, props));
77
+ };
78
+
79
+ describe('snapshot', function () {
80
+ it('renders', function () {
81
+ return expect(wrapper()).toMatchSnapshot();
82
+ });
83
+ });
84
+ describe('logic', function () {
85
+ var w = wrapper();
86
+ it('dragStop', function () {
87
+ w.instance().dragStop();
88
+ expect(onChangeCategory).not.toHaveBeenCalled();
89
+ w.instance().setState({
90
+ dragValue: 2
91
+ });
92
+ w.instance().dragStop(0);
93
+ expect(onChangeCategory).toHaveBeenCalledWith({
94
+ label: 'label',
95
+ value: 2
96
+ });
97
+ });
98
+ });
99
+ });
100
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iYXJzL2NvbW1vbi9fX3Rlc3RzX18vYmFycy50ZXN0LmpzeCJdLCJuYW1lcyI6WyJkZXNjcmliZSIsInhCYW5kIiwiYmFuZHdpZHRoIiwib25DaGFuZ2UiLCJqZXN0IiwiZm4iLCJ3cmFwcGVyIiwiZXh0cmFzIiwiZGVmYXVsdHMiLCJjbGFzc2VzIiwiY2xhc3NOYW1lIiwiZ3JhcGhQcm9wcyIsImRhdGEiLCJ2YWx1ZSIsImxhYmVsIiwicHJvcHMiLCJpdCIsImV4cGVjdCIsInRvTWF0Y2hTbmFwc2hvdCIsIm9uQ2hhbmdlQ2F0ZWdvcnkiLCJ3IiwiaW5zdGFuY2UiLCJkcmFnU3RvcCIsIm5vdCIsInRvSGF2ZUJlZW5DYWxsZWQiLCJzZXRTdGF0ZSIsImRyYWdWYWx1ZSIsInRvSGF2ZUJlZW5DYWxsZWRXaXRoIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7Ozs7O0FBRUFBLFFBQVEsQ0FBQyxNQUFELEVBQVMsWUFBTTtBQUNyQixNQUFNQyxLQUFLLEdBQUcsU0FBUkEsS0FBUSxHQUFNLENBQUUsQ0FBdEI7O0FBQ0FBLEVBQUFBLEtBQUssQ0FBQ0MsU0FBTixHQUFrQixZQUFNLENBQUUsQ0FBMUI7O0FBQ0EsTUFBTUMsUUFBUSxHQUFHQyxJQUFJLENBQUNDLEVBQUwsRUFBakI7O0FBRUEsTUFBTUMsT0FBTyxHQUFHLFNBQVZBLE9BQVUsQ0FBQ0MsTUFBRCxFQUFZO0FBQzFCLFFBQU1DLFFBQVEsR0FBRztBQUNmQyxNQUFBQSxPQUFPLEVBQUUsRUFETTtBQUVmQyxNQUFBQSxTQUFTLEVBQUUsV0FGSTtBQUdmQyxNQUFBQSxVQUFVLEVBQUUsd0JBSEc7QUFJZlYsTUFBQUEsS0FBSyxFQUFMQSxLQUplO0FBS2ZFLE1BQUFBLFFBQVEsRUFBUkEsUUFMZTtBQU1mUyxNQUFBQSxJQUFJLEVBQUUsQ0FBQztBQUFFQyxRQUFBQSxLQUFLLEVBQUUsQ0FBVDtBQUFZQyxRQUFBQSxLQUFLLEVBQUU7QUFBbkIsT0FBRDtBQU5TLEtBQWpCOztBQVFBLFFBQU1DLEtBQUssbUNBQVFQLFFBQVIsR0FBcUJELE1BQXJCLENBQVg7O0FBQ0EsV0FBTyxtQ0FBUSxnQ0FBQyxnQkFBRCxFQUFVUSxLQUFWLENBQVIsQ0FBUDtBQUNELEdBWEQ7O0FBYUFmLEVBQUFBLFFBQVEsQ0FBQyxVQUFELEVBQWEsWUFBTTtBQUN6QmdCLElBQUFBLEVBQUUsQ0FBQyxTQUFELEVBQVk7QUFBQSxhQUFNQyxNQUFNLENBQUNYLE9BQU8sRUFBUixDQUFOLENBQWtCWSxlQUFsQixFQUFOO0FBQUEsS0FBWixDQUFGO0FBQ0QsR0FGTyxDQUFSO0FBR0QsQ0FyQk8sQ0FBUjtBQXVCQWxCLFFBQVEsQ0FBQyxRQUFELEVBQVcsWUFBTTtBQUN2QixNQUFNQyxLQUFLLEdBQUcsU0FBUkEsS0FBUSxHQUFNLENBQUUsQ0FBdEI7O0FBQ0FBLEVBQUFBLEtBQUssQ0FBQ0MsU0FBTixHQUFrQixZQUFNLENBQUUsQ0FBMUI7O0FBQ0EsTUFBTWlCLGdCQUFnQixHQUFHZixJQUFJLENBQUNDLEVBQUwsRUFBekI7O0FBRUEsTUFBTUMsT0FBTyxHQUFHLFNBQVZBLE9BQVUsQ0FBQ0MsTUFBRCxFQUFZO0FBQzFCLFFBQU1DLFFBQVEsR0FBRztBQUNmQyxNQUFBQSxPQUFPLEVBQUUsRUFETTtBQUVmQyxNQUFBQSxTQUFTLEVBQUUsV0FGSTtBQUdmQyxNQUFBQSxVQUFVLEVBQUUsd0JBSEc7QUFJZlYsTUFBQUEsS0FBSyxFQUFMQSxLQUplO0FBS2ZrQixNQUFBQSxnQkFBZ0IsRUFBaEJBLGdCQUxlO0FBTWZQLE1BQUFBLElBQUksRUFBRSxFQU5TO0FBT2ZFLE1BQUFBLEtBQUssRUFBRTtBQVBRLEtBQWpCOztBQVNBLFFBQU1DLEtBQUssbUNBQVFQLFFBQVIsR0FBcUJELE1BQXJCLENBQVg7O0FBQ0EsV0FBTyxtQ0FBUSxnQ0FBQyxZQUFELEVBQVlRLEtBQVosQ0FBUixDQUFQO0FBQ0QsR0FaRDs7QUFjQWYsRUFBQUEsUUFBUSxDQUFDLFVBQUQsRUFBYSxZQUFNO0FBQ3pCZ0IsSUFBQUEsRUFBRSxDQUFDLFNBQUQsRUFBWTtBQUFBLGFBQU1DLE1BQU0sQ0FBQ1gsT0FBTyxFQUFSLENBQU4sQ0FBa0JZLGVBQWxCLEVBQU47QUFBQSxLQUFaLENBQUY7QUFDRCxHQUZPLENBQVI7QUFJQWxCLEVBQUFBLFFBQVEsQ0FBQyxPQUFELEVBQVUsWUFBTTtBQUN0QixRQUFNb0IsQ0FBQyxHQUFHZCxPQUFPLEVBQWpCO0FBRUFVLElBQUFBLEVBQUUsQ0FBQyxVQUFELEVBQWEsWUFBTTtBQUNuQkksTUFBQUEsQ0FBQyxDQUFDQyxRQUFGLEdBQWFDLFFBQWI7QUFFQUwsTUFBQUEsTUFBTSxDQUFDRSxnQkFBRCxDQUFOLENBQXlCSSxHQUF6QixDQUE2QkMsZ0JBQTdCO0FBRUFKLE1BQUFBLENBQUMsQ0FBQ0MsUUFBRixHQUFhSSxRQUFiLENBQXNCO0FBQ3BCQyxRQUFBQSxTQUFTLEVBQUU7QUFEUyxPQUF0QjtBQUlBTixNQUFBQSxDQUFDLENBQUNDLFFBQUYsR0FBYUMsUUFBYixDQUFzQixDQUF0QjtBQUVBTCxNQUFBQSxNQUFNLENBQUNFLGdCQUFELENBQU4sQ0FBeUJRLG9CQUF6QixDQUE4QztBQUFFYixRQUFBQSxLQUFLLEVBQUUsT0FBVDtBQUFrQkQsUUFBQUEsS0FBSyxFQUFFO0FBQXpCLE9BQTlDO0FBQ0QsS0FaQyxDQUFGO0FBYUQsR0FoQk8sQ0FBUjtBQWlCRCxDQXhDTyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2hhbGxvdyB9IGZyb20gJ2VuenltZSc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IEJhcnMsIHsgUmF3QmFyIH0gZnJvbSAnLi4vYmFycyc7XG5pbXBvcnQgeyBncmFwaFByb3BzIH0gZnJvbSAnLi91dGlscyc7XG5cbmRlc2NyaWJlKCdCYXJzJywgKCkgPT4ge1xuICBjb25zdCB4QmFuZCA9ICgpID0+IHt9O1xuICB4QmFuZC5iYW5kd2lkdGggPSAoKSA9PiB7fTtcbiAgY29uc3Qgb25DaGFuZ2UgPSBqZXN0LmZuKCk7XG5cbiAgY29uc3Qgd3JhcHBlciA9IChleHRyYXMpID0+IHtcbiAgICBjb25zdCBkZWZhdWx0cyA9IHtcbiAgICAgIGNsYXNzZXM6IHt9LFxuICAgICAgY2xhc3NOYW1lOiAnY2xhc3NOYW1lJyxcbiAgICAgIGdyYXBoUHJvcHM6IGdyYXBoUHJvcHMoKSxcbiAgICAgIHhCYW5kLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICBkYXRhOiBbeyB2YWx1ZTogMCwgbGFiZWw6ICcwJyB9XSxcbiAgICB9O1xuICAgIGNvbnN0IHByb3BzID0geyAuLi5kZWZhdWx0cywgLi4uZXh0cmFzIH07XG4gICAgcmV0dXJuIHNoYWxsb3coPEJhcnMgey4uLnByb3BzfSAvPik7XG4gIH07XG5cbiAgZGVzY3JpYmUoJ3NuYXBzaG90JywgKCkgPT4ge1xuICAgIGl0KCdyZW5kZXJzJywgKCkgPT4gZXhwZWN0KHdyYXBwZXIoKSkudG9NYXRjaFNuYXBzaG90KCkpO1xuICB9KTtcbn0pO1xuXG5kZXNjcmliZSgnUmF3QmFyJywgKCkgPT4ge1xuICBjb25zdCB4QmFuZCA9ICgpID0+IHt9O1xuICB4QmFuZC5iYW5kd2lkdGggPSAoKSA9PiB7fTtcbiAgY29uc3Qgb25DaGFuZ2VDYXRlZ29yeSA9IGplc3QuZm4oKTtcblxuICBjb25zdCB3cmFwcGVyID0gKGV4dHJhcykgPT4ge1xuICAgIGNvbnN0IGRlZmF1bHRzID0ge1xuICAgICAgY2xhc3Nlczoge30sXG4gICAgICBjbGFzc05hbWU6ICdjbGFzc05hbWUnLFxuICAgICAgZ3JhcGhQcm9wczogZ3JhcGhQcm9wcygpLFxuICAgICAgeEJhbmQsXG4gICAgICBvbkNoYW5nZUNhdGVnb3J5LFxuICAgICAgZGF0YTogW10sXG4gICAgICBsYWJlbDogJ2xhYmVsJyxcbiAgICB9O1xuICAgIGNvbnN0IHByb3BzID0geyAuLi5kZWZhdWx0cywgLi4uZXh0cmFzIH07XG4gICAgcmV0dXJuIHNoYWxsb3coPFJhd0JhciB7Li4ucHJvcHN9IC8+KTtcbiAgfTtcblxuICBkZXNjcmliZSgnc25hcHNob3QnLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMnLCAoKSA9PiBleHBlY3Qod3JhcHBlcigpKS50b01hdGNoU25hcHNob3QoKSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdsb2dpYycsICgpID0+IHtcbiAgICBjb25zdCB3ID0gd3JhcHBlcigpO1xuXG4gICAgaXQoJ2RyYWdTdG9wJywgKCkgPT4ge1xuICAgICAgdy5pbnN0YW5jZSgpLmRyYWdTdG9wKCk7XG5cbiAgICAgIGV4cGVjdChvbkNoYW5nZUNhdGVnb3J5KS5ub3QudG9IYXZlQmVlbkNhbGxlZCgpO1xuXG4gICAgICB3Lmluc3RhbmNlKCkuc2V0U3RhdGUoe1xuICAgICAgICBkcmFnVmFsdWU6IDIsXG4gICAgICB9KTtcblxuICAgICAgdy5pbnN0YW5jZSgpLmRyYWdTdG9wKDApO1xuXG4gICAgICBleHBlY3Qob25DaGFuZ2VDYXRlZ29yeSkudG9IYXZlQmVlbkNhbGxlZFdpdGgoeyBsYWJlbDogJ2xhYmVsJywgdmFsdWU6IDIgfSk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.scaleMock = exports.graphProps = void 0;
7
+
8
+ var scaleMock = function scaleMock() {
9
+ var fn = jest.fn(function (n) {
10
+ return n;
11
+ });
12
+ fn.invert = jest.fn(function (n) {
13
+ return n;
14
+ });
15
+ return fn;
16
+ };
17
+
18
+ exports.scaleMock = scaleMock;
19
+
20
+ var graphProps = function graphProps() {
21
+ var dmin = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
22
+ var dmax = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
23
+ var rmin = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
24
+ var rmax = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
25
+ return {
26
+ scale: {
27
+ x: scaleMock(),
28
+ y: scaleMock()
29
+ },
30
+ snap: {
31
+ x: jest.fn(function (n) {
32
+ return n;
33
+ }),
34
+ y: jest.fn(function (n) {
35
+ return n;
36
+ })
37
+ },
38
+ domain: {
39
+ min: dmin,
40
+ max: dmax,
41
+ step: 1
42
+ },
43
+ range: {
44
+ min: rmin,
45
+ max: rmax,
46
+ step: 1
47
+ },
48
+ size: {
49
+ width: 400,
50
+ height: 400
51
+ }
52
+ };
53
+ };
54
+
55
+ exports.graphProps = graphProps;
56
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iYXJzL2NvbW1vbi9fX3Rlc3RzX18vdXRpbHMuanMiXSwibmFtZXMiOlsic2NhbGVNb2NrIiwiZm4iLCJqZXN0IiwibiIsImludmVydCIsImdyYXBoUHJvcHMiLCJkbWluIiwiZG1heCIsInJtaW4iLCJybWF4Iiwic2NhbGUiLCJ4IiwieSIsInNuYXAiLCJkb21haW4iLCJtaW4iLCJtYXgiLCJzdGVwIiwicmFuZ2UiLCJzaXplIiwid2lkdGgiLCJoZWlnaHQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBTyxJQUFNQSxTQUFTLEdBQUcsU0FBWkEsU0FBWSxHQUFNO0FBQzdCLE1BQU1DLEVBQUUsR0FBR0MsSUFBSSxDQUFDRCxFQUFMLENBQVEsVUFBQ0UsQ0FBRDtBQUFBLFdBQU9BLENBQVA7QUFBQSxHQUFSLENBQVg7QUFDQUYsRUFBQUEsRUFBRSxDQUFDRyxNQUFILEdBQVlGLElBQUksQ0FBQ0QsRUFBTCxDQUFRLFVBQUNFLENBQUQ7QUFBQSxXQUFPQSxDQUFQO0FBQUEsR0FBUixDQUFaO0FBQ0EsU0FBT0YsRUFBUDtBQUNELENBSk07Ozs7QUFNQSxJQUFNSSxVQUFVLEdBQUcsU0FBYkEsVUFBYTtBQUFBLE1BQUNDLElBQUQsdUVBQVEsQ0FBUjtBQUFBLE1BQVdDLElBQVgsdUVBQWtCLENBQWxCO0FBQUEsTUFBcUJDLElBQXJCLHVFQUE0QixDQUE1QjtBQUFBLE1BQStCQyxJQUEvQix1RUFBc0MsQ0FBdEM7QUFBQSxTQUE2QztBQUNyRUMsSUFBQUEsS0FBSyxFQUFFO0FBQ0xDLE1BQUFBLENBQUMsRUFBRVgsU0FBUyxFQURQO0FBRUxZLE1BQUFBLENBQUMsRUFBRVosU0FBUztBQUZQLEtBRDhEO0FBS3JFYSxJQUFBQSxJQUFJLEVBQUU7QUFDSkYsTUFBQUEsQ0FBQyxFQUFFVCxJQUFJLENBQUNELEVBQUwsQ0FBUSxVQUFDRSxDQUFEO0FBQUEsZUFBT0EsQ0FBUDtBQUFBLE9BQVIsQ0FEQztBQUVKUyxNQUFBQSxDQUFDLEVBQUVWLElBQUksQ0FBQ0QsRUFBTCxDQUFRLFVBQUNFLENBQUQ7QUFBQSxlQUFPQSxDQUFQO0FBQUEsT0FBUjtBQUZDLEtBTCtEO0FBU3JFVyxJQUFBQSxNQUFNLEVBQUU7QUFDTkMsTUFBQUEsR0FBRyxFQUFFVCxJQURDO0FBRU5VLE1BQUFBLEdBQUcsRUFBRVQsSUFGQztBQUdOVSxNQUFBQSxJQUFJLEVBQUU7QUFIQSxLQVQ2RDtBQWNyRUMsSUFBQUEsS0FBSyxFQUFFO0FBQ0xILE1BQUFBLEdBQUcsRUFBRVAsSUFEQTtBQUVMUSxNQUFBQSxHQUFHLEVBQUVQLElBRkE7QUFHTFEsTUFBQUEsSUFBSSxFQUFFO0FBSEQsS0FkOEQ7QUFtQnJFRSxJQUFBQSxJQUFJLEVBQUU7QUFDSkMsTUFBQUEsS0FBSyxFQUFFLEdBREg7QUFFSkMsTUFBQUEsTUFBTSxFQUFFO0FBRko7QUFuQitELEdBQTdDO0FBQUEsQ0FBbkIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3Qgc2NhbGVNb2NrID0gKCkgPT4ge1xuICBjb25zdCBmbiA9IGplc3QuZm4oKG4pID0+IG4pO1xuICBmbi5pbnZlcnQgPSBqZXN0LmZuKChuKSA9PiBuKTtcbiAgcmV0dXJuIGZuO1xufTtcblxuZXhwb3J0IGNvbnN0IGdyYXBoUHJvcHMgPSAoZG1pbiA9IDAsIGRtYXggPSAxLCBybWluID0gMCwgcm1heCA9IDEpID0+ICh7XG4gIHNjYWxlOiB7XG4gICAgeDogc2NhbGVNb2NrKCksXG4gICAgeTogc2NhbGVNb2NrKCksXG4gIH0sXG4gIHNuYXA6IHtcbiAgICB4OiBqZXN0LmZuKChuKSA9PiBuKSxcbiAgICB5OiBqZXN0LmZuKChuKSA9PiBuKSxcbiAgfSxcbiAgZG9tYWluOiB7XG4gICAgbWluOiBkbWluLFxuICAgIG1heDogZG1heCxcbiAgICBzdGVwOiAxLFxuICB9LFxuICByYW5nZToge1xuICAgIG1pbjogcm1pbixcbiAgICBtYXg6IHJtYXgsXG4gICAgc3RlcDogMSxcbiAgfSxcbiAgc2l6ZToge1xuICAgIHdpZHRoOiA0MDAsXG4gICAgaGVpZ2h0OiA0MDAsXG4gIH0sXG59KTtcbiJdfQ==
@@ -77,6 +77,23 @@ var RawBar = /*#__PURE__*/function (_React$Component) {
77
77
 
78
78
  (0, _classCallCheck2["default"])(this, RawBar);
79
79
  _this = _super.call(this, props);
80
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleMouseMove", function (e) {
81
+ // Update mouse position
82
+ _this.mouseX = e.clientX;
83
+ _this.mouseY = e.clientY; // Check if the mouse is inside the <g> element
84
+
85
+ var isMouseInside = _this.isMouseInsideSvgElement();
86
+
87
+ _this.setState({
88
+ isHovered: isMouseInside
89
+ });
90
+ });
91
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "isMouseInsideSvgElement", function () {
92
+ var gBoundingBox = _this.gRef.getBoundingClientRect(); // Check if the mouse position is within the bounding box
93
+
94
+
95
+ return _this.mouseX >= gBoundingBox.left && _this.mouseX <= gBoundingBox.right && _this.mouseY >= gBoundingBox.top && _this.mouseY <= gBoundingBox.bottom;
96
+ });
80
97
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleMouseEnter", function () {
81
98
  _this.setState({
82
99
  isHovered: true
@@ -117,10 +134,22 @@ var RawBar = /*#__PURE__*/function (_React$Component) {
117
134
  dragValue: undefined,
118
135
  isHovered: false
119
136
  };
137
+ _this.mouseX = 0;
138
+ _this.mouseY = 0;
120
139
  return _this;
121
140
  }
122
141
 
123
142
  (0, _createClass2["default"])(RawBar, [{
143
+ key: "componentDidMount",
144
+ value: function componentDidMount() {
145
+ window.addEventListener('mousemove', this.handleMouseMove);
146
+ }
147
+ }, {
148
+ key: "componentWillUnmount",
149
+ value: function componentWillUnmount() {
150
+ window.removeEventListener('mousemove', this.handleMouseMove);
151
+ }
152
+ }, {
124
153
  key: "render",
125
154
  value: function render() {
126
155
  var _this2 = this;
@@ -153,8 +182,13 @@ var RawBar = /*#__PURE__*/function (_React$Component) {
153
182
  log('label:', label, 'barX:', barX, 'v: ', v, 'barHeight:', barHeight, 'barWidth: ', barWidth);
154
183
  var Component = interactive ? _dragHandle["default"] : _dragHandle.DragHandle;
155
184
  return /*#__PURE__*/_react["default"].createElement("g", {
185
+ ref: function ref(_ref) {
186
+ return _this2.gRef = _ref;
187
+ },
156
188
  onMouseEnter: this.handleMouseEnter,
157
- onMouseLeave: this.handleMouseLeave
189
+ onMouseLeave: this.handleMouseLeave,
190
+ onTouchStart: this.handleMouseEnter,
191
+ onTouchEnd: this.handleMouseLeave
158
192
  }, /*#__PURE__*/_react["default"].createElement(_shape.Bar, {
159
193
  x: barX,
160
194
  y: scale.y(yy),
@@ -264,4 +298,4 @@ exports.Bars = Bars;
264
298
  });
265
299
  var _default = Bars;
266
300
  exports["default"] = _default;
267
- //# sourceMappingURL=bars.js.map
301
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/bars/common/bars.jsx"],"names":["log","histogramColors","hoverHistogramColors","calculateFillColor","isHovered","barColor","index","length","color","primaryDark","RawBar","props","e","mouseX","clientX","mouseY","clientY","isMouseInside","isMouseInsideSvgElement","setState","gBoundingBox","gRef","getBoundingClientRect","left","right","top","bottom","dragValue","label","onChangeCategory","state","undefined","value","setDragValue","existing","next","window","addEventListener","handleMouseMove","removeEventListener","graphProps","classes","xBand","interactive","correctness","defineChart","scale","range","fillColor","v","Number","isFinite","barWidth","bandwidth","barHeight","y","max","barX","rawY","yy","Component","DraggableHandle","DragHandle","ref","handleMouseEnter","handleMouseLeave","bar","fill","dragStop","React","PropTypes","string","func","number","object","isRequired","types","GraphPropsType","bool","shape","Bar","primaryLight","Bars","data","histogram","map","d","category","array"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { types } from '@pie-lib/plot';\nimport { Group } from '@vx/group';\nimport { color } from '@pie-lib/render-ui';\nimport { Bar as VxBar } from '@vx/shape';\nimport { withStyles } from '@material-ui/core/styles/index';\nimport debug from 'debug';\nimport { bandKey } from '../../utils';\nimport DraggableHandle, { DragHandle } from '../../common/drag-handle';\n\nconst log = debug('pie-lib:chart:bars');\nconst histogramColors = [\n  '#006699',\n  '#F59B00',\n  '#08916D',\n  '#529EE0',\n  '#52B7D8',\n  '#D9A6C2',\n  '#FFB03B',\n  '#54A77B',\n  '#E16032',\n  '#4FD2D2',\n  '#F0E442',\n  '#E287B2',\n];\nconst hoverHistogramColors = [\n  '#003754',\n  '#975616',\n  '#00503B',\n  '#225982',\n  '#1F687D',\n  '#825E6F',\n  '#996428',\n  '#255E44',\n  '#8A331F',\n  '#167A7A',\n  '#91862D',\n  '#894A65',\n];\n\nconst calculateFillColor = (isHovered, barColor, index, hoverHistogramColors) => {\n  if (isHovered && barColor) {\n    return hoverHistogramColors[index % hoverHistogramColors.length];\n  }\n  if (isHovered) {\n    return color.primaryDark();\n  }\n  return barColor || null;\n};\n\nexport class RawBar extends React.Component {\n  static propTypes = {\n    barColor: PropTypes.string,\n    onChangeCategory: PropTypes.func,\n    value: PropTypes.number,\n    classes: PropTypes.object,\n    label: PropTypes.string,\n    xBand: PropTypes.func,\n    index: PropTypes.number.isRequired,\n    graphProps: types.GraphPropsType.isRequired,\n    interactive: PropTypes.bool,\n    correctness: PropTypes.shape({\n      value: PropTypes.string,\n      label: PropTypes.string,\n    }),\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      dragValue: undefined,\n      isHovered: false,\n    };\n    this.mouseX = 0;\n    this.mouseY = 0;\n  }\n\n  componentDidMount() {\n    window.addEventListener('mousemove', this.handleMouseMove);\n  }\n\n  componentWillUnmount() {\n    window.removeEventListener('mousemove', this.handleMouseMove);\n  }\n\n  handleMouseMove = (e) => {\n    // Update mouse position\n    this.mouseX = e.clientX;\n    this.mouseY = e.clientY;\n    // Check if the mouse is inside the <g> element\n    const isMouseInside = this.isMouseInsideSvgElement();\n    this.setState({ isHovered: isMouseInside });\n  };\n\n  isMouseInsideSvgElement = () => {\n    const gBoundingBox = this.gRef.getBoundingClientRect();\n    // Check if the mouse position is within the bounding box\n    return (\n      this.mouseX >= gBoundingBox.left &&\n      this.mouseX <= gBoundingBox.right &&\n      this.mouseY >= gBoundingBox.top &&\n      this.mouseY <= gBoundingBox.bottom\n    );\n  };\n\n  handleMouseEnter = () => {\n    this.setState({ isHovered: true });\n  };\n\n  handleMouseLeave = () => {\n    this.setState({ isHovered: false });\n  };\n\n  setDragValue = (dragValue) => this.setState({ dragValue });\n\n  dragStop = () => {\n    const { label, onChangeCategory } = this.props;\n    const { dragValue } = this.state;\n    log('[dragStop]', dragValue);\n\n    if (dragValue !== undefined) {\n      onChangeCategory({ label, value: dragValue });\n    }\n\n    this.setDragValue(undefined);\n  };\n\n  dragValue = (existing, next) => {\n    log('[dragValue] next:', next);\n\n    this.setDragValue(next);\n  };\n\n  render() {\n    const {\n      graphProps,\n      value,\n      label,\n      classes,\n      xBand,\n      index,\n      interactive,\n      correctness,\n      barColor,\n      defineChart,\n    } = this.props;\n    const { scale, range } = graphProps;\n    const { dragValue, isHovered } = this.state;\n\n    const fillColor = calculateFillColor(isHovered, barColor, index, hoverHistogramColors);\n    const v = Number.isFinite(dragValue) ? dragValue : value;\n    const barWidth = xBand.bandwidth();\n    const barHeight = scale.y(range.max - v);\n    const barX = xBand(bandKey({ label }, index));\n    const rawY = range.max - v;\n    const yy = range.max - rawY;\n    log('label:', label, 'barX:', barX, 'v: ', v, 'barHeight:', barHeight, 'barWidth: ', barWidth);\n\n    const Component = interactive ? DraggableHandle : DragHandle;\n\n    return (\n      <g\n        ref={(ref) => (this.gRef = ref)}\n        onMouseEnter={this.handleMouseEnter}\n        onMouseLeave={this.handleMouseLeave}\n        onTouchStart={this.handleMouseEnter}\n        onTouchEnd={this.handleMouseLeave}\n      >\n        <VxBar\n          x={barX}\n          y={scale.y(yy)}\n          width={barWidth}\n          height={barHeight}\n          className={classes.bar}\n          style={{ fill: fillColor }}\n        />\n        <Component\n          x={barX}\n          y={v}\n          defineChart={defineChart}\n          interactive={interactive}\n          width={barWidth}\n          onDrag={(v) => this.dragValue(value, v)}\n          onDragStop={this.dragStop}\n          graphProps={graphProps}\n          correctness={correctness}\n          isHovered={isHovered}\n          color={fillColor}\n        />\n      </g>\n    );\n  }\n}\n\nconst Bar = withStyles(() => ({\n  bar: {\n    fill: color.primaryLight(),\n    '&:hover': {\n      fill: color.primaryDark(),\n    },\n  },\n}))(RawBar);\n\nexport class Bars extends React.Component {\n  static propTypes = {\n    data: PropTypes.array,\n    onChangeCategory: PropTypes.func,\n    defineChart: PropTypes.bool,\n    xBand: PropTypes.func,\n    graphProps: types.GraphPropsType.isRequired,\n    histogram: PropTypes.bool,\n  };\n\n  render() {\n    const { data, graphProps, xBand, onChangeCategory, defineChart, histogram } = this.props;\n\n    return (\n      <Group>\n        {(data || []).map((d, index) => (\n          <Bar\n            value={d.value}\n            interactive={defineChart || d.interactive}\n            defineChart={defineChart}\n            label={d.label}\n            xBand={xBand}\n            index={index}\n            key={`bar-${d.label}-${d.value}-${index}`}\n            onChangeCategory={(category) => onChangeCategory(index, category)}\n            graphProps={graphProps}\n            correctness={d.correctness}\n            barColor={\n              histogram &&\n              (histogramColors[index] ? histogramColors[index] : histogramColors[index % histogramColors.length])\n            }\n          />\n        ))}\n      </Group>\n    );\n  }\n}\n\nexport default Bars;\n"]}
@@ -84,4 +84,4 @@ var _default = function _default() {
84
84
  };
85
85
 
86
86
  exports["default"] = _default;
87
- //# sourceMappingURL=histogram.js.map
87
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iYXJzL2hpc3RvZ3JhbS5qcyJdLCJuYW1lcyI6WyJIaXN0b2dyYW0iLCJwcm9wcyIsImRhdGEiLCJncmFwaFByb3BzIiwic2NhbGUiLCJzaXplIiwieEJhbmQiLCJ4Iiwid2lkdGgiLCJSZWFjdCIsIkNvbXBvbmVudCIsIlByb3BUeXBlcyIsImFycmF5Iiwib25DaGFuZ2UiLCJmdW5jIiwidHlwZXMiLCJHcmFwaFByb3BzVHlwZSIsImlzUmVxdWlyZWQiLCJ0eXBlIiwibmFtZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7O0lBRWFBLFM7Ozs7Ozs7Ozs7OztXQU9YLGtCQUFTO0FBQ1AsVUFBTUMsS0FBSyxHQUFHLEtBQUtBLEtBQW5CO0FBQ0EsVUFBUUMsSUFBUixHQUE2QkQsS0FBN0IsQ0FBUUMsSUFBUjtBQUFBLFVBQWNDLFVBQWQsR0FBNkJGLEtBQTdCLENBQWNFLFVBQWQ7O0FBQ0EsaUJBQWtDQSxVQUFVLElBQUksRUFBaEQ7QUFBQSw0QkFBUUMsS0FBUjtBQUFBLFVBQVFBLEtBQVIsMkJBQWdCLEVBQWhCO0FBQUEsMkJBQW9CQyxJQUFwQjtBQUFBLFVBQW9CQSxJQUFwQiwwQkFBMkIsRUFBM0I7O0FBQ0EsVUFBTUMsS0FBSyxHQUFHLHdCQUFZRixLQUFLLENBQUNHLENBQWxCLEVBQXFCTCxJQUFyQixFQUEyQkcsSUFBSSxDQUFDRyxLQUFoQyxFQUF1QyxXQUF2QyxDQUFkO0FBRUEsMEJBQU8sZ0NBQUMsZ0JBQUQsZ0NBQVVQLEtBQVY7QUFBaUIsUUFBQSxLQUFLLEVBQUVLLEtBQXhCO0FBQStCLFFBQUEsU0FBUyxFQUFFO0FBQTFDLFNBQVA7QUFDRDs7O0VBZDRCRyxrQkFBTUMsUzs7O2lDQUF4QlYsUyxlQUNRO0FBQ2pCRSxFQUFBQSxJQUFJLEVBQUVTLHNCQUFVQyxLQURDO0FBRWpCQyxFQUFBQSxRQUFRLEVBQUVGLHNCQUFVRyxJQUZIO0FBR2pCWCxFQUFBQSxVQUFVLEVBQUVZLFlBQU1DLGNBQU4sQ0FBcUJDO0FBSGhCLEM7O2VBZ0JOO0FBQUEsU0FBTztBQUNwQkMsSUFBQUEsSUFBSSxFQUFFLFdBRGM7QUFFcEJSLElBQUFBLFNBQVMsRUFBRVYsU0FGUztBQUdwQm1CLElBQUFBLElBQUksRUFBRTtBQUhjLEdBQVA7QUFBQSxDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJ0BwaWUtbGliL3Bsb3QnO1xuaW1wb3J0IHsgZGF0YVRvWEJhbmQgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgQmFycyBmcm9tICcuL2NvbW1vbi9iYXJzJztcblxuZXhwb3J0IGNsYXNzIEhpc3RvZ3JhbSBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZGF0YTogUHJvcFR5cGVzLmFycmF5LFxuICAgIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgICBncmFwaFByb3BzOiB0eXBlcy5HcmFwaFByb3BzVHlwZS5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCBwcm9wcyA9IHRoaXMucHJvcHM7XG4gICAgY29uc3QgeyBkYXRhLCBncmFwaFByb3BzIH0gPSBwcm9wcztcbiAgICBjb25zdCB7IHNjYWxlID0ge30sIHNpemUgPSB7fSB9ID0gZ3JhcGhQcm9wcyB8fCB7fTtcbiAgICBjb25zdCB4QmFuZCA9IGRhdGFUb1hCYW5kKHNjYWxlLngsIGRhdGEsIHNpemUud2lkdGgsICdoaXN0b2dyYW0nKTtcblxuICAgIHJldHVybiA8QmFycyB7Li4ucHJvcHN9IHhCYW5kPXt4QmFuZH0gaGlzdG9ncmFtPXt0cnVlfSAvPjtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCAoKSA9PiAoe1xuICB0eXBlOiAnaGlzdG9ncmFtJyxcbiAgQ29tcG9uZW50OiBIaXN0b2dyYW0sXG4gIG5hbWU6ICdIaXN0b2dyYW0nLFxufSk7XG4iXX0=
@@ -455,4 +455,4 @@ var styles = function styles(theme) {
455
455
  var _default = (0, _styles.withStyles)(styles)(ConfigureChartPanel);
456
456
 
457
457
  exports["default"] = _default;
458
- //# sourceMappingURL=chart-setup.js.map
458
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/chart-setup.jsx"],"names":["resetValues","data","updateModel","range","onChange","model","forEach","d","d_value_scaled","Math","round","value","range_step_scaled","step","remainder_scaled","remainder","max","ConfigureChartPanel","props","classes","chartDimensions","gridValues","labelValues","studentNewCategoryDefaultLabel","availableChartTypes","chartTypeLabel","open","title","text","onClose","onConfirm","alertDialog","setAlertDialog","setOpen","rangeKey","setRangeKey","resetValue","setResetValue","correctAnswer","changeInteractiveEnabled","changeEditableEnabled","size","graph","showInConfigPanel","width","height","widthConstraints","min","heightConstraints","gridOptions","customValues","labelOptions","stepConfig","rowView","mediumTextField","e","v","onRangeChanged","labelStep","handleAlertDialog","openStatus","callback","prevState","setPropertiesToFalse","property","map","obj","hasOwnProperty","removeOutOfRangeValues","setCategoryDefaultLabel","studentCategoryDefaultLabel","label","rangeProps","chartType","includes","onSizeChanged","key","isOutOfRange","find","floor","outOfRange","JSON","stringify","isValidPlot","getPlotConfiguration","onChartTypeChange","wrapper","content","target","dimensions","columnView","textField","disabled","propTypes","PropTypes","object","domain","func","chartDimension","string","styles","theme","display","flexDirection","marginTop","spacing","unit","alignItems","justifyContent","margin","largeTextField","fontStyle","color"],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport { color } from '@pie-lib/render-ui';\nimport { withStyles } from '@material-ui/core/styles';\nimport Typography from '@material-ui/core/Typography';\nimport ChartType from './chart-type';\nimport { NumberTextFieldCustom } from '@pie-lib/config-ui';\nimport { AlertDialog } from '@pie-lib/config-ui';\n\nexport const resetValues = (data, updateModel, range, onChange, model) => {\n  (data || []).forEach((d) => {\n    const d_value_scaled = Math.round(d.value * 10);\n    const range_step_scaled = Math.round(range.step * 10);\n    const remainder_scaled = d_value_scaled % range_step_scaled;\n    const remainder = remainder_scaled / 10;\n\n    if (d.value > range.max || remainder !== 0) {\n      d.value = 0;\n    }\n  });\n\n  if (updateModel) {\n    onChange({ ...model, data });\n  }\n};\n\nconst ConfigureChartPanel = (props) => {\n  const {\n    classes,\n    model,\n    onChange,\n    chartDimensions,\n    gridValues = {},\n    labelValues = {},\n    studentNewCategoryDefaultLabel = {},\n    availableChartTypes = {},\n    chartTypeLabel,\n  } = props;\n  const [alertDialog, setAlertDialog] = useState({\n    open: false,\n    title: '',\n    text: '',\n    onClose: null,\n    onConfirm: null,\n  });\n  const [open, setOpen] = useState(false);\n  const [rangeKey, setRangeKey] = useState('');\n  const [resetValue, setResetValue] = useState(0);\n\n  const { range = {}, correctAnswer, changeInteractiveEnabled, changeEditableEnabled } = model;\n\n  const size = model.graph;\n  const { showInConfigPanel, width, height } = chartDimensions || {};\n\n  const widthConstraints = {\n    min: width?.min ? Math.max(50, width.min) : 50,\n    max: width?.max ? Math.min(700, width.max) : 700,\n    step: width?.step >= 1 ? Math.min(200, width.step) : 20,\n  };\n  const heightConstraints = {\n    min: height?.min ? Math.max(400, height.min) : 400,\n    max: height?.max ? Math.min(700, height.max) : 700,\n    step: height?.step >= 1 ? Math.min(200, height.step) : 20,\n  };\n\n  const gridOptions = gridValues && gridValues.range ? { customValues: gridValues.range } : { min: 0, max: 10000 };\n  const labelOptions = labelValues && labelValues.range ? { customValues: labelValues.range } : { min: 0, max: 10000 };\n\n  const stepConfig = (\n    <div className={classes.rowView}>\n      <NumberTextFieldCustom\n        className={classes.mediumTextField}\n        label=\"Grid Interval\"\n        value={range.step}\n        variant=\"outlined\"\n        onChange={(e, v) => onRangeChanged('step', v, e)}\n        {...gridOptions}\n      />\n      <NumberTextFieldCustom\n        className={classes.mediumTextField}\n        label={'Label Interval'}\n        value={range.labelStep}\n        variant={'outlined'}\n        onChange={(e, v) => onRangeChanged('labelStep', v, e)}\n        {...labelOptions}\n      />\n    </div>\n  );\n\n  const handleAlertDialog = (openStatus, callback) => {\n    setAlertDialog(\n      (prevState) => ({\n        ...prevState,\n        open: openStatus,\n      }),\n      () => {\n        if (callback) {\n          callback();\n        }\n      },\n    );\n\n    setOpen(openStatus);\n  };\n\n  const setPropertiesToFalse = (data, property) => {\n    return data.map((obj) => {\n      if (obj.hasOwnProperty(property)) {\n        obj[property] = property == 'interactive' ? true : false;\n      }\n      return obj;\n    });\n  };\n\n  const removeOutOfRangeValues = (updateModel) => {\n    const { correctAnswer, data } = model;\n\n    if (changeInteractiveEnabled === false) {\n      setPropertiesToFalse(data, 'interactive');\n    }\n\n    if (changeEditableEnabled === false) {\n      setPropertiesToFalse(data, 'editable');\n    }\n\n    resetValues(data, updateModel, range, onChange, model);\n    resetValues(correctAnswer.data, false, range, onChange, model);\n  };\n\n  const setCategoryDefaultLabel = () => {\n    const studentCategoryDefaultLabel = studentNewCategoryDefaultLabel?.label;\n\n    onChange({ ...model, studentCategoryDefaultLabel });\n  };\n\n  const rangeProps = (chartType) => {\n    return chartType.includes('Plot') ? { min: 3, max: 10 } : { min: 0.05, max: 10000 };\n  };\n\n  const onSizeChanged = (key, value) => {\n    const graph = { ...size, [key]: value };\n\n    onChange({ ...model, graph });\n  };\n\n  const isOutOfRange = (data, range) =>\n    (data || []).find((d) => d.value > range.max || d.value - range.step * Math.floor(d.value / range.step) !== 0);\n\n  const onRangeChanged = (key, value, e) => {\n    // use reset values to restore range to initial values\n    setResetValue(range[key]);\n    setRangeKey(key);\n\n    range[key] = value;\n\n    if (key === 'max' || key === 'step') {\n      // check if current chart values are invalid for given range step/max\n      const outOfRange = isOutOfRange(model.data, range) || isOutOfRange(model.correctAnswer.data, range);\n\n      if (outOfRange && JSON.stringify(e) !== '{}') {\n        setOpen(true);\n      } else {\n        onChange({ ...model, range });\n      }\n    } else {\n      onChange({ ...model, range });\n    }\n  };\n\n  useEffect(() => {\n    removeOutOfRangeValues(true);\n    setCategoryDefaultLabel();\n  }, []);\n\n  useEffect(() => {\n    if (open) {\n      setAlertDialog({\n        open: true,\n        title: 'Warning',\n        text: 'This change will remove values defined for one or more categories',\n        onConfirm: () => {\n          removeOutOfRangeValues();\n          handleAlertDialog(false, onChange({ ...model, range, correctAnswer }));\n        },\n        onClose: () => {\n          range[rangeKey] = resetValue;\n          handleAlertDialog(false);\n        },\n      });\n    }\n  }, [open]);\n\n  const isValidPlot = range.step === 1 && range.labelStep === 1 && 3 <= range.max && range.max <= 10;\n\n  const getPlotConfiguration = () => {\n    rangeProps.min = 3;\n    rangeProps.max = 10;\n\n    range.max = 10;\n    range.step = 1;\n    range.labelStep = 1;\n\n    onChange({ ...model, range });\n  };\n\n  const onChartTypeChange = (chartType) => {\n    if (chartType.includes('Plot')) {\n      // The selected chart type does not support the current chart configuration\n      if (!isValidPlot) {\n        setAlertDialog({\n          open: true,\n          title: 'Warning',\n          text: 'The selected chart type does not support the current chart configuration. Reset chart configuration?',\n          onConfirm: () => {\n            getPlotConfiguration();\n            removeOutOfRangeValues();\n            handleAlertDialog(false, onChange({ ...model, range, chartType }));\n          },\n          onClose: () => {\n            handleAlertDialog(false);\n          },\n        });\n\n        return;\n      }\n\n      rangeProps.min = 3;\n      rangeProps.max = 10;\n\n      onChange({ ...model, chartType });\n\n      return;\n    }\n\n    onChange({ ...model, chartType });\n  };\n\n  return (\n    <div className={classes.wrapper}>\n      <Typography variant={'subtitle1'}>Configure Chart</Typography>\n      <div className={classes.content}>\n        <div className={classes.rowView}>\n          <ChartType\n            value={model.chartType}\n            onChange={(e) => onChartTypeChange(e.target.value)}\n            availableChartTypes={availableChartTypes}\n            chartTypeLabel={chartTypeLabel}\n          />\n          <NumberTextFieldCustom\n            className={classes.mediumTextField}\n            label=\"Max Value\"\n            value={range.max}\n            min={rangeProps(model.chartType).min}\n            max={rangeProps(model.chartType).max}\n            variant=\"outlined\"\n            onChange={(e, v) => onRangeChanged('max', v, e)}\n          />\n        </div>\n        {!model.chartType.includes('Plot') && stepConfig}\n\n        {showInConfigPanel && (\n          <div className={classes.dimensions}>\n            <div>\n              <Typography>Dimensions(px)</Typography>\n            </div>\n\n            <div className={classes.columnView}>\n              <NumberTextFieldCustom\n                className={classes.textField}\n                label={'Width'}\n                value={size.width}\n                min={widthConstraints.min}\n                max={widthConstraints.max}\n                step={widthConstraints.step}\n                variant={'outlined'}\n                onChange={(e, v) => onSizeChanged('width', v)}\n              />\n              <Typography className={classes.disabled}>Min 50, Max 700</Typography>\n            </div>\n\n            <div className={classes.columnView}>\n              <NumberTextFieldCustom\n                className={classes.textField}\n                label={'Height'}\n                value={size.height}\n                min={heightConstraints.min}\n                max={heightConstraints.max}\n                step={heightConstraints.step}\n                variant={'outlined'}\n                onChange={(e, v) => onSizeChanged('height', v)}\n              />\n              <Typography className={classes.disabled}>Min 400, Max 700</Typography>\n            </div>\n          </div>\n        )}\n      </div>\n\n      <AlertDialog\n        open={alertDialog.open}\n        title={alertDialog.title}\n        text={alertDialog.text}\n        onClose={alertDialog.onClose}\n        onConfirm={alertDialog.onConfirm}\n      />\n    </div>\n  );\n};\n\nConfigureChartPanel.propTypes = {\n  classes: PropTypes.object,\n  chartDimensions: PropTypes.object,\n  domain: PropTypes.object,\n  gridValues: PropTypes.object,\n  labelValues: PropTypes.object,\n  model: PropTypes.object,\n  onChange: PropTypes.func,\n  range: PropTypes.object,\n  chartDimension: PropTypes.object,\n  size: PropTypes.object,\n  studentNewCategoryDefaultLabel: PropTypes.object,\n  availableChartTypes: PropTypes.object,\n  chartTypeLabel: PropTypes.string,\n};\n\nconst styles = (theme) => ({\n  wrapper: {\n    width: '450px',\n  },\n  content: {\n    display: 'flex',\n    flexDirection: 'column',\n    width: '100%',\n    marginTop: theme.spacing.unit * 3,\n  },\n  columnView: {\n    display: 'flex',\n    flexDirection: 'column',\n    alignItems: 'center',\n  },\n  rowView: {\n    display: 'flex',\n    justifyContent: 'space-around',\n    alignItems: 'center',\n  },\n  textField: {\n    width: '130px',\n    margin: `${theme.spacing.unit}px ${theme.spacing.unit / 2}px`,\n  },\n  mediumTextField: {\n    width: '160px',\n    margin: `${theme.spacing.unit}px ${theme.spacing.unit / 2}px`,\n  },\n  largeTextField: {\n    width: '230px',\n    margin: `${theme.spacing.unit}px ${theme.spacing.unit / 2}px`,\n  },\n  text: {\n    fontStyle: 'italic',\n    margin: `${theme.spacing.unit}px 0`,\n  },\n  dimensions: {\n    display: 'flex',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    margin: `${theme.spacing.unit * 3}px 0`,\n  },\n  disabled: {\n    color: color.disabled(),\n  },\n});\n\nexport default withStyles(styles)(ConfigureChartPanel);\n"]}
package/lib/chart-type.js CHANGED
@@ -42,15 +42,15 @@ var ChartType = (0, _styles.withStyles)(function () {
42
42
  variant: 'outlined',
43
43
  className: classes.chartType
44
44
  }, /*#__PURE__*/_react["default"].createElement(_InputLabel["default"], {
45
- htmlFor: "type-helper",
45
+ id: "type-helper-label",
46
46
  className: classes.chartTypeLabel
47
47
  }, chartTypeLabel), /*#__PURE__*/_react["default"].createElement(_Select["default"], {
48
+ labelId: "type-helper-label",
48
49
  value: value,
49
50
  onChange: onChange,
50
- labelWidth: 75,
51
51
  input: /*#__PURE__*/_react["default"].createElement(_OutlinedInput["default"], {
52
- name: "type",
53
- id: "type-helper"
52
+ labelWidth: 75,
53
+ name: "type"
54
54
  })
55
55
  }, (availableChartTypes === null || availableChartTypes === void 0 ? void 0 : availableChartTypes.histogram) && /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
56
56
  value: 'histogram'
@@ -68,4 +68,4 @@ var ChartType = (0, _styles.withStyles)(function () {
68
68
  });
69
69
  var _default = ChartType;
70
70
  exports["default"] = _default;
71
- //# sourceMappingURL=chart-type.js.map
71
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jaGFydC10eXBlLmpzIl0sIm5hbWVzIjpbIkNoYXJ0VHlwZSIsImNoYXJ0VHlwZSIsIndpZHRoIiwiY2hhcnRUeXBlTGFiZWwiLCJiYWNrZ3JvdW5kQ29sb3IiLCJvbkNoYW5nZSIsInZhbHVlIiwiY2xhc3NlcyIsImF2YWlsYWJsZUNoYXJ0VHlwZXMiLCJoaXN0b2dyYW0iLCJiYXIiLCJsaW5lRG90IiwibGluZUNyb3NzIiwiZG90UGxvdCIsImxpbmVQbG90Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQSxJQUFNQSxTQUFTLEdBQUcsd0JBQVc7QUFBQSxTQUFPO0FBQ2xDQyxJQUFBQSxTQUFTLEVBQUU7QUFDVEMsTUFBQUEsS0FBSyxFQUFFO0FBREUsS0FEdUI7QUFJbENDLElBQUFBLGNBQWMsRUFBRTtBQUNkQyxNQUFBQSxlQUFlLEVBQUU7QUFESDtBQUprQixHQUFQO0FBQUEsQ0FBWCxFQU9kO0FBQUEsTUFBR0MsUUFBSCxRQUFHQSxRQUFIO0FBQUEsTUFBYUMsS0FBYixRQUFhQSxLQUFiO0FBQUEsTUFBb0JDLE9BQXBCLFFBQW9CQSxPQUFwQjtBQUFBLE1BQTZCQyxtQkFBN0IsUUFBNkJBLG1CQUE3QjtBQUFBLE1BQWtETCxjQUFsRCxRQUFrREEsY0FBbEQ7QUFBQSxzQkFDRjtBQUFLLElBQUEsU0FBUyxFQUFFSSxPQUFPLENBQUNOO0FBQXhCLGtCQUNFLGdDQUFDLHVCQUFEO0FBQWEsSUFBQSxPQUFPLEVBQUUsVUFBdEI7QUFBa0MsSUFBQSxTQUFTLEVBQUVNLE9BQU8sQ0FBQ047QUFBckQsa0JBQ0UsZ0NBQUMsc0JBQUQ7QUFBWSxJQUFBLEVBQUUsRUFBQyxtQkFBZjtBQUFtQyxJQUFBLFNBQVMsRUFBRU0sT0FBTyxDQUFDSjtBQUF0RCxLQUNHQSxjQURILENBREYsZUFJRSxnQ0FBQyxrQkFBRDtBQUNFLElBQUEsT0FBTyxFQUFDLG1CQURWO0FBRUUsSUFBQSxLQUFLLEVBQUVHLEtBRlQ7QUFHRSxJQUFBLFFBQVEsRUFBRUQsUUFIWjtBQUlFLElBQUEsS0FBSyxlQUFFLGdDQUFDLHlCQUFEO0FBQWUsTUFBQSxVQUFVLEVBQUUsRUFBM0I7QUFBK0IsTUFBQSxJQUFJLEVBQUM7QUFBcEM7QUFKVCxLQU1HLENBQUFHLG1CQUFtQixTQUFuQixJQUFBQSxtQkFBbUIsV0FBbkIsWUFBQUEsbUJBQW1CLENBQUVDLFNBQXJCLGtCQUFrQyxnQ0FBQyxvQkFBRDtBQUFVLElBQUEsS0FBSyxFQUFFO0FBQWpCLEtBQStCRCxtQkFBbUIsQ0FBQ0MsU0FBbkQsQ0FOckMsRUFPRyxDQUFBRCxtQkFBbUIsU0FBbkIsSUFBQUEsbUJBQW1CLFdBQW5CLFlBQUFBLG1CQUFtQixDQUFFRSxHQUFyQixrQkFBNEIsZ0NBQUMsb0JBQUQ7QUFBVSxJQUFBLEtBQUssRUFBRTtBQUFqQixLQUF5QkYsbUJBQW1CLENBQUNFLEdBQTdDLENBUC9CLEVBUUcsQ0FBQUYsbUJBQW1CLFNBQW5CLElBQUFBLG1CQUFtQixXQUFuQixZQUFBQSxtQkFBbUIsQ0FBRUcsT0FBckIsa0JBQWdDLGdDQUFDLG9CQUFEO0FBQVUsSUFBQSxLQUFLLEVBQUU7QUFBakIsS0FBNkJILG1CQUFtQixDQUFDRyxPQUFqRCxDQVJuQyxFQVNHLENBQUFILG1CQUFtQixTQUFuQixJQUFBQSxtQkFBbUIsV0FBbkIsWUFBQUEsbUJBQW1CLENBQUVJLFNBQXJCLGtCQUFrQyxnQ0FBQyxvQkFBRDtBQUFVLElBQUEsS0FBSyxFQUFFO0FBQWpCLEtBQStCSixtQkFBbUIsQ0FBQ0ksU0FBbkQsQ0FUckMsRUFVRyxDQUFBSixtQkFBbUIsU0FBbkIsSUFBQUEsbUJBQW1CLFdBQW5CLFlBQUFBLG1CQUFtQixDQUFFSyxPQUFyQixrQkFBZ0MsZ0NBQUMsb0JBQUQ7QUFBVSxJQUFBLEtBQUssRUFBRTtBQUFqQixLQUE2QkwsbUJBQW1CLENBQUNLLE9BQWpELENBVm5DLEVBV0csQ0FBQUwsbUJBQW1CLFNBQW5CLElBQUFBLG1CQUFtQixXQUFuQixZQUFBQSxtQkFBbUIsQ0FBRU0sUUFBckIsa0JBQWlDLGdDQUFDLG9CQUFEO0FBQVUsSUFBQSxLQUFLLEVBQUU7QUFBakIsS0FBOEJOLG1CQUFtQixDQUFDTSxRQUFsRCxDQVhwQyxDQUpGLENBREYsQ0FERTtBQUFBLENBUGMsQ0FBbEI7ZUE4QmVkLFMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgd2l0aFN0eWxlcyB9IGZyb20gJ0BtYXRlcmlhbC11aS9jb3JlL3N0eWxlcyc7XG5pbXBvcnQgTWVudUl0ZW0gZnJvbSAnQG1hdGVyaWFsLXVpL2NvcmUvTWVudUl0ZW0nO1xuaW1wb3J0IEZvcm1Db250cm9sIGZyb20gJ0BtYXRlcmlhbC11aS9jb3JlL0Zvcm1Db250cm9sJztcbmltcG9ydCBJbnB1dExhYmVsIGZyb20gJ0BtYXRlcmlhbC11aS9jb3JlL0lucHV0TGFiZWwnO1xuaW1wb3J0IFNlbGVjdCBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9TZWxlY3QnO1xuaW1wb3J0IE91dGxpbmVkSW5wdXQgZnJvbSAnQG1hdGVyaWFsLXVpL2NvcmUvT3V0bGluZWRJbnB1dCc7XG5cbmNvbnN0IENoYXJ0VHlwZSA9IHdpdGhTdHlsZXMoKCkgPT4gKHtcbiAgY2hhcnRUeXBlOiB7XG4gICAgd2lkdGg6ICcxNjBweCcsXG4gIH0sXG4gIGNoYXJ0VHlwZUxhYmVsOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAndHJhbnNwYXJlbnQnLFxuICB9LFxufSkpKCh7IG9uQ2hhbmdlLCB2YWx1ZSwgY2xhc3NlcywgYXZhaWxhYmxlQ2hhcnRUeXBlcywgY2hhcnRUeXBlTGFiZWwgfSkgPT4gKFxuICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3Nlcy5jaGFydFR5cGV9PlxuICAgIDxGb3JtQ29udHJvbCB2YXJpYW50PXsnb3V0bGluZWQnfSBjbGFzc05hbWU9e2NsYXNzZXMuY2hhcnRUeXBlfT5cbiAgICAgIDxJbnB1dExhYmVsIGlkPVwidHlwZS1oZWxwZXItbGFiZWxcIiBjbGFzc05hbWU9e2NsYXNzZXMuY2hhcnRUeXBlTGFiZWx9PlxuICAgICAgICB7Y2hhcnRUeXBlTGFiZWx9XG4gICAgICA8L0lucHV0TGFiZWw+XG4gICAgICA8U2VsZWN0XG4gICAgICAgIGxhYmVsSWQ9XCJ0eXBlLWhlbHBlci1sYWJlbFwiXG4gICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICBpbnB1dD17PE91dGxpbmVkSW5wdXQgbGFiZWxXaWR0aD17NzV9IG5hbWU9XCJ0eXBlXCIgLz59XG4gICAgICA+XG4gICAgICAgIHthdmFpbGFibGVDaGFydFR5cGVzPy5oaXN0b2dyYW0gJiYgPE1lbnVJdGVtIHZhbHVlPXsnaGlzdG9ncmFtJ30+e2F2YWlsYWJsZUNoYXJ0VHlwZXMuaGlzdG9ncmFtfTwvTWVudUl0ZW0+fVxuICAgICAgICB7YXZhaWxhYmxlQ2hhcnRUeXBlcz8uYmFyICYmIDxNZW51SXRlbSB2YWx1ZT17J2Jhcid9PnthdmFpbGFibGVDaGFydFR5cGVzLmJhcn08L01lbnVJdGVtPn1cbiAgICAgICAge2F2YWlsYWJsZUNoYXJ0VHlwZXM/LmxpbmVEb3QgJiYgPE1lbnVJdGVtIHZhbHVlPXsnbGluZURvdCd9PnthdmFpbGFibGVDaGFydFR5cGVzLmxpbmVEb3R9PC9NZW51SXRlbT59XG4gICAgICAgIHthdmFpbGFibGVDaGFydFR5cGVzPy5saW5lQ3Jvc3MgJiYgPE1lbnVJdGVtIHZhbHVlPXsnbGluZUNyb3NzJ30+e2F2YWlsYWJsZUNoYXJ0VHlwZXMubGluZUNyb3NzfTwvTWVudUl0ZW0+fVxuICAgICAgICB7YXZhaWxhYmxlQ2hhcnRUeXBlcz8uZG90UGxvdCAmJiA8TWVudUl0ZW0gdmFsdWU9eydkb3RQbG90J30+e2F2YWlsYWJsZUNoYXJ0VHlwZXMuZG90UGxvdH08L01lbnVJdGVtPn1cbiAgICAgICAge2F2YWlsYWJsZUNoYXJ0VHlwZXM/LmxpbmVQbG90ICYmIDxNZW51SXRlbSB2YWx1ZT17J2xpbmVQbG90J30+e2F2YWlsYWJsZUNoYXJ0VHlwZXMubGluZVBsb3R9PC9NZW51SXRlbT59XG4gICAgICA8L1NlbGVjdD5cbiAgICA8L0Zvcm1Db250cm9sPlxuICA8L2Rpdj5cbikpO1xuXG5leHBvcnQgZGVmYXVsdCBDaGFydFR5cGU7XG4iXX0=
@@ -15,9 +15,9 @@ var _lineDot = _interopRequireDefault(require("./line/line-dot"));
15
15
 
16
16
  var _lineCross = _interopRequireDefault(require("./line/line-cross"));
17
17
 
18
- var _dot = _interopRequireDefault(require("./plot/dot"));
18
+ var _dot = _interopRequireDefault(require("@pie-lib/plot/dot"));
19
19
 
20
- var _line = _interopRequireDefault(require("./plot/line"));
20
+ var _line = _interopRequireDefault(require("@pie-lib/plot/line"));
21
21
 
22
22
  var _default = {
23
23
  Bar: _bar["default"],
@@ -28,4 +28,4 @@ var _default = {
28
28
  LineCross: _lineCross["default"]
29
29
  };
30
30
  exports["default"] = _default;
31
- //# sourceMappingURL=chart-types.js.map
31
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jaGFydC10eXBlcy5qcyJdLCJuYW1lcyI6WyJCYXIiLCJIaXN0b2dyYW0iLCJMaW5lRG90IiwiRG90UGxvdCIsIkxpbmVQbG90IiwiTGluZUNyb3NzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7ZUFFZTtBQUFFQSxFQUFBQSxHQUFHLEVBQUhBLGVBQUY7QUFBT0MsRUFBQUEsU0FBUyxFQUFUQSxxQkFBUDtBQUFrQkMsRUFBQUEsT0FBTyxFQUFQQSxtQkFBbEI7QUFBMkJDLEVBQUFBLE9BQU8sRUFBUEEsZUFBM0I7QUFBb0NDLEVBQUFBLFFBQVEsRUFBUkEsZ0JBQXBDO0FBQThDQyxFQUFBQSxTQUFTLEVBQVRBO0FBQTlDLEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmFyIGZyb20gJy4vYmFycy9iYXInO1xuaW1wb3J0IEhpc3RvZ3JhbSBmcm9tICcuL2JhcnMvaGlzdG9ncmFtJztcbmltcG9ydCBMaW5lRG90IGZyb20gJy4vbGluZS9saW5lLWRvdCc7XG5pbXBvcnQgTGluZUNyb3NzIGZyb20gJy4vbGluZS9saW5lLWNyb3NzJztcbmltcG9ydCBEb3RQbG90IGZyb20gJ0BwaWUtbGliL3Bsb3QvZG90JztcbmltcG9ydCBMaW5lUGxvdCBmcm9tICdAcGllLWxpYi9wbG90L2xpbmUnO1xuXG5leHBvcnQgZGVmYXVsdCB7IEJhciwgSGlzdG9ncmFtLCBMaW5lRG90LCBEb3RQbG90LCBMaW5lUGxvdCwgTGluZUNyb3NzIH07XG4iXX0=