@pie-lib/graphing 2.34.3-next.2 → 2.34.4-next.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 (252) hide show
  1. package/CHANGELOG.md +6 -76
  2. package/lib/__tests__/graph-with-controls.test.js +226 -0
  3. package/lib/__tests__/graph.test.js +187 -0
  4. package/lib/__tests__/grid.test.js +29 -0
  5. package/lib/__tests__/labels.test.js +61 -0
  6. package/lib/__tests__/mark-label.test.js +133 -0
  7. package/lib/__tests__/toggle-bar.test.js +150 -0
  8. package/lib/__tests__/tool-menu.test.js +101 -0
  9. package/lib/__tests__/undo-redo.test.js +31 -0
  10. package/lib/__tests__/use-debounce.test.js +24 -0
  11. package/lib/__tests__/utils.js +70 -0
  12. package/lib/__tests__/utils.test.js +123 -0
  13. package/lib/axis/__tests__/arrow.test.js +60 -0
  14. package/lib/axis/__tests__/axes.test.js +195 -0
  15. package/lib/axis/arrow.js +20 -56
  16. package/lib/axis/arrow.js.map +1 -1
  17. package/lib/axis/axes.js +107 -195
  18. package/lib/axis/axes.js.map +1 -1
  19. package/lib/axis/index.js +2 -7
  20. package/lib/axis/index.js.map +1 -1
  21. package/lib/bg.js +22 -50
  22. package/lib/bg.js.map +1 -1
  23. package/lib/container/actions.js +3 -9
  24. package/lib/container/actions.js.map +1 -1
  25. package/lib/container/index.js +15 -60
  26. package/lib/container/index.js.map +1 -1
  27. package/lib/container/marks.js +2 -7
  28. package/lib/container/marks.js.map +1 -1
  29. package/lib/container/middleware.js +3 -9
  30. package/lib/container/middleware.js.map +1 -1
  31. package/lib/container/reducer.js +2 -9
  32. package/lib/container/reducer.js.map +1 -1
  33. package/lib/coordinates-label.js +25 -55
  34. package/lib/coordinates-label.js.map +1 -1
  35. package/lib/graph-with-controls.js +121 -185
  36. package/lib/graph-with-controls.js.map +1 -1
  37. package/lib/graph.js +60 -117
  38. package/lib/graph.js.map +1 -1
  39. package/lib/grid-setup.js +169 -225
  40. package/lib/grid-setup.js.map +1 -1
  41. package/lib/grid.js +30 -75
  42. package/lib/grid.js.map +1 -1
  43. package/lib/index.js +2 -14
  44. package/lib/index.js.map +1 -1
  45. package/lib/key-legend.js +41 -86
  46. package/lib/key-legend.js.map +1 -1
  47. package/lib/label-svg-icon.js +2 -8
  48. package/lib/label-svg-icon.js.map +1 -1
  49. package/lib/labels.js +66 -122
  50. package/lib/labels.js.map +1 -1
  51. package/lib/mark-label.js +121 -164
  52. package/lib/mark-label.js.map +1 -1
  53. package/lib/toggle-bar.js +156 -244
  54. package/lib/toggle-bar.js.map +1 -1
  55. package/lib/tool-menu.js +17 -51
  56. package/lib/tool-menu.js.map +1 -1
  57. package/lib/tools/absolute/__tests__/component.test.js +67 -0
  58. package/lib/tools/absolute/component.js +5 -11
  59. package/lib/tools/absolute/component.js.map +1 -1
  60. package/lib/tools/absolute/index.js +4 -17
  61. package/lib/tools/absolute/index.js.map +1 -1
  62. package/lib/tools/circle/__tests__/bg-circle.test.js +33 -0
  63. package/lib/tools/circle/__tests__/component.test.js +68 -0
  64. package/lib/tools/circle/bg-circle.js +43 -93
  65. package/lib/tools/circle/bg-circle.js.map +1 -1
  66. package/lib/tools/circle/component.js +79 -166
  67. package/lib/tools/circle/component.js.map +1 -1
  68. package/lib/tools/circle/index.js +4 -14
  69. package/lib/tools/circle/index.js.map +1 -1
  70. package/lib/tools/exponential/__tests__/component.test.js +66 -0
  71. package/lib/tools/exponential/component.js +5 -11
  72. package/lib/tools/exponential/component.js.map +1 -1
  73. package/lib/tools/exponential/index.js +4 -19
  74. package/lib/tools/exponential/index.js.map +1 -1
  75. package/lib/tools/index.js +4 -17
  76. package/lib/tools/index.js.map +1 -1
  77. package/lib/tools/line/__tests__/component.test.js +45 -0
  78. package/lib/tools/line/component.js +28 -49
  79. package/lib/tools/line/component.js.map +1 -1
  80. package/lib/tools/line/index.js +2 -7
  81. package/lib/tools/line/index.js.map +1 -1
  82. package/lib/tools/parabola/__tests__/component.test.js +66 -0
  83. package/lib/tools/parabola/component.js +5 -11
  84. package/lib/tools/parabola/component.js.map +1 -1
  85. package/lib/tools/parabola/index.js +4 -17
  86. package/lib/tools/parabola/index.js.map +1 -1
  87. package/lib/tools/point/__tests__/component.test.js +50 -0
  88. package/lib/tools/point/component.js +25 -72
  89. package/lib/tools/point/component.js.map +1 -1
  90. package/lib/tools/point/index.js +4 -12
  91. package/lib/tools/point/index.js.map +1 -1
  92. package/lib/tools/polygon/__tests__/component.test.js +85 -0
  93. package/lib/tools/polygon/__tests__/index.test.js +92 -0
  94. package/lib/tools/polygon/__tests__/line.test.js +29 -0
  95. package/lib/tools/polygon/__tests__/polygon.test.js +59 -0
  96. package/lib/tools/polygon/component.js +84 -185
  97. package/lib/tools/polygon/component.js.map +1 -1
  98. package/lib/tools/polygon/index.js +7 -24
  99. package/lib/tools/polygon/index.js.map +1 -1
  100. package/lib/tools/polygon/line.js +49 -92
  101. package/lib/tools/polygon/line.js.map +1 -1
  102. package/lib/tools/polygon/polygon.js +66 -99
  103. package/lib/tools/polygon/polygon.js.map +1 -1
  104. package/lib/tools/ray/__tests__/component.test.js +35 -0
  105. package/lib/tools/ray/component.js +42 -61
  106. package/lib/tools/ray/component.js.map +1 -1
  107. package/lib/tools/ray/index.js +2 -7
  108. package/lib/tools/ray/index.js.map +1 -1
  109. package/lib/tools/segment/__tests__/component.test.js +35 -0
  110. package/lib/tools/segment/component.js +26 -44
  111. package/lib/tools/segment/component.js.map +1 -1
  112. package/lib/tools/segment/index.js +2 -7
  113. package/lib/tools/segment/index.js.map +1 -1
  114. package/lib/tools/shared/__tests__/arrow-head.test.js +45 -0
  115. package/lib/tools/shared/arrow-head.js +70 -29
  116. package/lib/tools/shared/arrow-head.js.map +1 -1
  117. package/lib/tools/shared/icons/CorrectSVG.js +13 -9
  118. package/lib/tools/shared/icons/CorrectSVG.js.map +1 -1
  119. package/lib/tools/shared/icons/IncorrectSVG.js +13 -9
  120. package/lib/tools/shared/icons/IncorrectSVG.js.map +1 -1
  121. package/lib/tools/shared/icons/MissingSVG.js +13 -9
  122. package/lib/tools/shared/icons/MissingSVG.js.map +1 -1
  123. package/lib/tools/shared/line/__tests__/index.test.js +124 -0
  124. package/lib/tools/shared/line/__tests__/line-path.test.js +62 -0
  125. package/lib/tools/shared/line/__tests__/with-root-edge.test.js +91 -0
  126. package/lib/tools/shared/line/index.js +141 -194
  127. package/lib/tools/shared/line/index.js.map +1 -1
  128. package/lib/tools/shared/line/line-path.js +71 -102
  129. package/lib/tools/shared/line/line-path.js.map +1 -1
  130. package/lib/tools/shared/line/with-root-edge.js +23 -57
  131. package/lib/tools/shared/line/with-root-edge.js.map +1 -1
  132. package/lib/tools/shared/point/__tests__/arrow-point.test.js +127 -0
  133. package/lib/tools/shared/point/__tests__/base-point.test.js +122 -0
  134. package/lib/tools/shared/point/arrow-point.js +22 -63
  135. package/lib/tools/shared/point/arrow-point.js.map +1 -1
  136. package/lib/tools/shared/point/arrow.js +24 -53
  137. package/lib/tools/shared/point/arrow.js.map +1 -1
  138. package/lib/tools/shared/point/base-point.js +55 -73
  139. package/lib/tools/shared/point/base-point.js.map +1 -1
  140. package/lib/tools/shared/point/index.js +23 -58
  141. package/lib/tools/shared/point/index.js.map +1 -1
  142. package/lib/tools/shared/styles.js +11 -39
  143. package/lib/tools/shared/styles.js.map +1 -1
  144. package/lib/tools/shared/types.js +3 -10
  145. package/lib/tools/shared/types.js.map +1 -1
  146. package/lib/tools/sine/__tests__/component.test.js +72 -0
  147. package/lib/tools/sine/component.js +9 -20
  148. package/lib/tools/sine/component.js.map +1 -1
  149. package/lib/tools/sine/index.js +4 -17
  150. package/lib/tools/sine/index.js.map +1 -1
  151. package/lib/tools/vector/__tests__/component.test.js +32 -0
  152. package/lib/tools/vector/component.js +25 -45
  153. package/lib/tools/vector/component.js.map +1 -1
  154. package/lib/tools/vector/index.js +2 -7
  155. package/lib/tools/vector/index.js.map +1 -1
  156. package/lib/undo-redo.js +30 -70
  157. package/lib/undo-redo.js.map +1 -1
  158. package/lib/use-debounce.js +5 -12
  159. package/lib/use-debounce.js.map +1 -1
  160. package/lib/utils.js +52 -129
  161. package/lib/utils.js.map +1 -1
  162. package/package.json +25 -29
  163. package/src/__tests__/graph-with-controls.test.jsx +28 -11
  164. package/src/__tests__/graph.test.jsx +104 -168
  165. package/src/__tests__/grid.test.jsx +8 -6
  166. package/src/__tests__/labels.test.jsx +25 -8
  167. package/src/__tests__/mark-label.test.jsx +12 -17
  168. package/src/__tests__/toggle-bar.test.jsx +92 -17
  169. package/src/__tests__/tool-menu.test.jsx +61 -12
  170. package/src/__tests__/undo-redo.test.jsx +7 -8
  171. package/src/__tests__/utils.js +3 -0
  172. package/src/axis/__tests__/arrow.test.jsx +16 -17
  173. package/src/axis/__tests__/axes.test.jsx +118 -122
  174. package/src/axis/arrow.jsx +7 -12
  175. package/src/axis/axes.jsx +45 -55
  176. package/src/coordinates-label.jsx +14 -18
  177. package/src/graph-with-controls.jsx +52 -59
  178. package/src/grid-setup.jsx +210 -206
  179. package/src/grid.jsx +2 -4
  180. package/src/key-legend.jsx +52 -56
  181. package/src/labels.jsx +23 -30
  182. package/src/mark-label.jsx +92 -81
  183. package/src/toggle-bar.jsx +135 -164
  184. package/src/tool-menu.jsx +1 -1
  185. package/src/tools/circle/__tests__/bg-circle.test.jsx +7 -9
  186. package/src/tools/circle/__tests__/component.test.jsx +17 -189
  187. package/src/tools/circle/bg-circle.jsx +20 -28
  188. package/src/tools/circle/component.jsx +28 -63
  189. package/src/tools/line/__tests__/component.test.jsx +7 -7
  190. package/src/tools/line/component.jsx +22 -15
  191. package/src/tools/point/__tests__/component.test.jsx +18 -43
  192. package/src/tools/point/component.jsx +1 -1
  193. package/src/tools/polygon/__tests__/component.test.jsx +18 -162
  194. package/src/tools/polygon/__tests__/line.test.jsx +7 -10
  195. package/src/tools/polygon/__tests__/polygon.test.jsx +7 -8
  196. package/src/tools/polygon/component.jsx +3 -4
  197. package/src/tools/polygon/line.jsx +30 -33
  198. package/src/tools/polygon/polygon.jsx +52 -45
  199. package/src/tools/ray/__tests__/component.test.jsx +7 -8
  200. package/src/tools/ray/component.jsx +38 -25
  201. package/src/tools/segment/__tests__/component.test.jsx +7 -8
  202. package/src/tools/segment/component.jsx +19 -18
  203. package/src/tools/shared/__tests__/arrow-head.test.jsx +14 -17
  204. package/src/tools/shared/arrow-head.jsx +60 -7
  205. package/src/tools/shared/icons/CorrectSVG.jsx +10 -0
  206. package/src/tools/shared/icons/IncorrectSVG.jsx +10 -0
  207. package/src/tools/shared/icons/MissingSVG.jsx +10 -0
  208. package/src/tools/shared/line/__tests__/index.test.jsx +19 -165
  209. package/src/tools/shared/line/__tests__/line-path.test.jsx +8 -8
  210. package/src/tools/shared/line/__tests__/with-root-edge.test.jsx +22 -22
  211. package/src/tools/shared/line/index.jsx +52 -7
  212. package/src/tools/shared/line/line-path.jsx +55 -59
  213. package/src/tools/shared/line/with-root-edge.jsx +1 -1
  214. package/src/tools/shared/point/__tests__/arrow-point.test.jsx +15 -11
  215. package/src/tools/shared/point/__tests__/base-point.test.jsx +14 -11
  216. package/src/tools/shared/point/arrow-point.jsx +10 -24
  217. package/src/tools/shared/point/arrow.jsx +5 -11
  218. package/src/tools/shared/point/base-point.jsx +42 -19
  219. package/src/tools/shared/point/index.jsx +27 -44
  220. package/src/tools/vector/__tests__/component.test.jsx +7 -8
  221. package/src/tools/vector/component.jsx +11 -16
  222. package/src/undo-redo.jsx +19 -21
  223. package/esm/index.css +0 -847
  224. package/esm/index.js +0 -239949
  225. package/esm/index.js.map +0 -1
  226. package/esm/package.json +0 -3
  227. package/src/__tests__/__snapshots__/graph-with-controls.test.jsx.snap +0 -237
  228. package/src/__tests__/__snapshots__/graph.test.jsx.snap +0 -211
  229. package/src/__tests__/__snapshots__/grid.test.jsx.snap +0 -54
  230. package/src/__tests__/__snapshots__/labels.test.jsx.snap +0 -30
  231. package/src/__tests__/__snapshots__/mark-label.test.jsx.snap +0 -45
  232. package/src/__tests__/__snapshots__/toggle-bar.test.jsx.snap +0 -7
  233. package/src/__tests__/__snapshots__/tool-menu.test.jsx.snap +0 -13
  234. package/src/__tests__/__snapshots__/undo-redo.test.jsx.snap +0 -14
  235. package/src/axis/__tests__/__snapshots__/arrow.test.jsx.snap +0 -33
  236. package/src/axis/__tests__/__snapshots__/axes.test.jsx.snap +0 -122
  237. package/src/tools/circle/__tests__/__snapshots__/bg-circle.test.jsx.snap +0 -46
  238. package/src/tools/circle/__tests__/__snapshots__/component.test.jsx.snap +0 -293
  239. package/src/tools/line/__tests__/__snapshots__/component.test.jsx.snap +0 -20
  240. package/src/tools/point/__tests__/__snapshots__/component.test.jsx.snap +0 -40
  241. package/src/tools/polygon/__tests__/__snapshots__/component.test.jsx.snap +0 -415
  242. package/src/tools/polygon/__tests__/__snapshots__/line.test.jsx.snap +0 -45
  243. package/src/tools/polygon/__tests__/__snapshots__/polygon.test.jsx.snap +0 -52
  244. package/src/tools/ray/__tests__/__snapshots__/component.test.jsx.snap +0 -23
  245. package/src/tools/segment/__tests__/__snapshots__/component.test.jsx.snap +0 -14
  246. package/src/tools/shared/__tests__/__snapshots__/arrow-head.test.jsx.snap +0 -27
  247. package/src/tools/shared/line/__tests__/__snapshots__/index.test.jsx.snap +0 -360
  248. package/src/tools/shared/line/__tests__/__snapshots__/line-path.test.jsx.snap +0 -58
  249. package/src/tools/shared/line/__tests__/__snapshots__/with-root-edge.test.jsx.snap +0 -63
  250. package/src/tools/shared/point/__tests__/__snapshots__/arrow-point.test.jsx.snap +0 -56
  251. package/src/tools/shared/point/__tests__/__snapshots__/base-point.test.jsx.snap +0 -44
  252. package/src/tools/vector/__tests__/__snapshots__/component.test.jsx.snap +0 -12
@@ -1,25 +1,24 @@
1
- import { shallow } from 'enzyme';
1
+ import { render } from '@pie-lib/test-utils';
2
2
  import React from 'react';
3
3
  import UndoRedo from '../undo-redo';
4
4
 
5
5
  describe('UndoRedo', () => {
6
- let w;
7
6
  let onUndo = jest.fn();
8
7
  let onRedo = jest.fn();
9
8
  let onReset = jest.fn();
10
- const wrapper = (extras) => {
9
+ const renderComponent = (extras) => {
11
10
  const defaults = {
12
11
  onUndo,
13
12
  onRedo,
14
13
  onReset,
15
14
  };
16
15
  const props = { ...defaults, ...extras };
17
- return shallow(<UndoRedo {...props} />);
16
+ return render(<UndoRedo {...props} />);
18
17
  };
19
- describe('snapshot', () => {
20
- it('renders', () => {
21
- w = wrapper();
22
- expect(w).toMatchSnapshot();
18
+ describe('rendering', () => {
19
+ it('renders without crashing', () => {
20
+ const { container } = renderComponent();
21
+ expect(container.firstChild).toBeInTheDocument();
23
22
  });
24
23
  });
25
24
  });
@@ -1,6 +1,9 @@
1
1
  export const scaleMock = () => {
2
2
  const fn = jest.fn((n) => n);
3
3
  fn.invert = jest.fn((n) => n);
4
+ fn.domain = jest.fn(() => fn);
5
+ fn.range = jest.fn(() => fn);
6
+ fn.copy = jest.fn(() => scaleMock());
4
7
  return fn;
5
8
  };
6
9
 
@@ -1,11 +1,10 @@
1
- import { shallow } from 'enzyme';
1
+ import { render } from '@pie-lib/test-utils';
2
2
  import React from 'react';
3
3
  import { Arrow } from '../arrow';
4
4
 
5
5
  describe('Arrow', () => {
6
- let w;
7
6
  let onChange = jest.fn();
8
- const wrapper = (extras) => {
7
+ const renderComponent = (extras) => {
9
8
  const defaults = {
10
9
  classes: {},
11
10
  className: 'className',
@@ -16,24 +15,24 @@ describe('Arrow', () => {
16
15
  },
17
16
  };
18
17
  const props = { ...defaults, ...extras };
19
- return shallow(<Arrow {...props} />);
18
+ return render(<Arrow {...props} />);
20
19
  };
21
- describe('snapshot', () => {
22
- it('up', () => {
23
- w = wrapper({ direction: 'up' });
24
- expect(w).toMatchSnapshot();
20
+ describe('rendering', () => {
21
+ it('renders with direction up', () => {
22
+ const { container } = renderComponent({ direction: 'up' });
23
+ expect(container.firstChild).toBeInTheDocument();
25
24
  });
26
- it('down', () => {
27
- w = wrapper({ direction: 'down' });
28
- expect(w).toMatchSnapshot();
25
+ it('renders with direction down', () => {
26
+ const { container } = renderComponent({ direction: 'down' });
27
+ expect(container.firstChild).toBeInTheDocument();
29
28
  });
30
- it('left', () => {
31
- w = wrapper({ direction: 'left' });
32
- expect(w).toMatchSnapshot();
29
+ it('renders with direction left', () => {
30
+ const { container } = renderComponent({ direction: 'left' });
31
+ expect(container.firstChild).toBeInTheDocument();
33
32
  });
34
- it('right', () => {
35
- w = wrapper({ direction: 'right' });
36
- expect(w).toMatchSnapshot();
33
+ it('renders with direction right', () => {
34
+ const { container } = renderComponent({ direction: 'right' });
35
+ expect(container.firstChild).toBeInTheDocument();
37
36
  });
38
37
  });
39
38
  });
@@ -1,13 +1,12 @@
1
- import { shallow } from 'enzyme';
1
+ import { render } from '@pie-lib/test-utils';
2
2
  import React from 'react';
3
3
  import { graphProps } from '../../__tests__/utils';
4
4
 
5
5
  import Axes, { RawXAxis, RawYAxis, firstNegativeValue, sharedValues } from '../axes';
6
6
 
7
7
  describe('RawXAxis', () => {
8
- let w;
9
8
  let onChange = jest.fn();
10
- const wrapper = (extras) => {
9
+ const renderComponent = (extras) => {
11
10
  const defaults = {
12
11
  classes: {},
13
12
  className: 'className',
@@ -19,22 +18,25 @@ describe('RawXAxis', () => {
19
18
  up: true,
20
19
  down: true,
21
20
  },
21
+ columnTicksValues: [-1, 0, 1],
22
+ skipValues: [],
23
+ distanceFromOriginToFirstNegativeY: 0,
24
+ dy: 0,
22
25
  };
23
26
  const props = { ...defaults, ...extras };
24
- return shallow(<RawXAxis {...props} />);
27
+ return render(<RawXAxis {...props} />);
25
28
  };
26
- describe('snapshot', () => {
27
- it('renders', () => {
28
- w = wrapper();
29
- expect(w).toMatchSnapshot();
29
+ describe('rendering', () => {
30
+ it('renders without crashing', () => {
31
+ const { container } = renderComponent();
32
+ expect(container.firstChild).toBeInTheDocument();
30
33
  });
31
34
  });
32
35
  });
33
36
 
34
37
  describe('RawYAxis', () => {
35
- let w;
36
38
  let onChange = jest.fn();
37
- const wrapper = (extras) => {
39
+ const renderComponent = (extras) => {
38
40
  const defaults = {
39
41
  classes: {},
40
42
  className: 'className',
@@ -46,14 +48,16 @@ describe('RawYAxis', () => {
46
48
  up: true,
47
49
  down: true,
48
50
  },
51
+ rowTickValues: [-1, 0, 1],
52
+ skipValues: [],
49
53
  };
50
54
  const props = { ...defaults, ...extras };
51
- return shallow(<RawYAxis {...props} />);
55
+ return render(<RawYAxis {...props} />);
52
56
  };
53
- describe('snapshot', () => {
54
- it('renders', () => {
55
- w = wrapper();
56
- expect(w).toMatchSnapshot();
57
+ describe('rendering', () => {
58
+ it('renders without crashing', () => {
59
+ const { container } = renderComponent();
60
+ expect(container.firstChild).toBeInTheDocument();
57
61
  });
58
62
  });
59
63
  });
@@ -61,11 +65,13 @@ describe('RawYAxis', () => {
61
65
  const customScaleMock = (distance) => {
62
66
  const fn = jest.fn((n) => n * distance);
63
67
  fn.invert = jest.fn((n) => n * distance);
68
+ fn.domain = jest.fn(() => fn);
69
+ fn.range = jest.fn(() => fn);
70
+ fn.copy = jest.fn(() => customScaleMock(distance));
64
71
  return fn;
65
72
  };
66
73
 
67
- describe.only('Axes', () => {
68
- let w;
74
+ describe('Axes', () => {
69
75
  let onChange = jest.fn();
70
76
 
71
77
  const customGraphProps = {
@@ -88,7 +94,7 @@ describe.only('Axes', () => {
88
94
  },
89
95
  };
90
96
 
91
- const wrapper = (extras) => {
97
+ const renderComponent = (extras) => {
92
98
  const defaults = {
93
99
  classes: {},
94
100
  className: 'className',
@@ -97,124 +103,114 @@ describe.only('Axes', () => {
97
103
  };
98
104
 
99
105
  const props = { ...defaults, ...extras };
100
- return shallow(<Axes {...props} />);
106
+ return render(<Axes {...props} />);
101
107
  };
102
- describe('xValues', () => {
103
- it('renders', () => {
104
- w = wrapper();
105
- const result = w.instance().xValues();
106
- expect(result).toEqual({
107
- columnTicksValues: expect.arrayContaining([-2, -1, 0, 1, 2]),
108
- distanceFromOriginToFirstNegativeX: 150,
109
- firstNegativeX: -1,
110
- });
108
+ describe('rendering', () => {
109
+ it('renders without crashing', () => {
110
+ const { container } = renderComponent();
111
+ expect(container.firstChild).toBeInTheDocument();
111
112
  });
112
113
  });
113
- describe('yValues', () => {
114
- it('renders', () => {
115
- w = wrapper();
116
- const result = w.instance().yValues();
117
- expect(result).toEqual({
118
- rowTickValues: expect.arrayContaining([-2, -1, 0, 1, 2]),
119
- distanceFromOriginToFirstNegativeY: 200,
120
- firstNegativeY: -1,
121
- });
122
- });
123
- });
124
- });
125
-
126
- describe('firstNegativeValue should return undefiend for undefined interval', () => {
127
- const interval = undefined;
128
- const result = firstNegativeValue(interval);
129
- expect(result).toEqual(undefined);
130
- });
131
-
132
- describe('firstNegativeValue should return undefiend for empty interval', () => {
133
- const interval = [];
134
- const result = firstNegativeValue(interval);
135
- expect(result).toEqual(undefined);
136
114
  });
137
115
 
138
- describe('firstNegativeValue should return undefined if there is no negative in interval array', () => {
139
- const interval = [1, 5, 7, 4, 5];
140
- const result = firstNegativeValue(interval);
141
- expect(result).toEqual(undefined);
142
- });
143
-
144
- describe('firstNegativeValue should return first negative number from interval', () => {
145
- const interval = [1, 5, 7, -2, 4, 5, -1];
146
- const result = firstNegativeValue(interval);
147
- expect(result).toEqual(-2);
148
- });
149
-
150
- describe('skipValue should be empty array if firstNegativeValue for one of the axes is undefined', () => {
151
- // x
152
- const intervalX = [1, 2, 3, 4, 5, 6];
153
- const firstNegativeX = firstNegativeValue(intervalX);
154
- const distanceFromOriginToFirstNegativeX = -22;
155
-
156
- // y
157
- const intervalY = [-1, -2, 1, 2, 3, 4, 5, 6];
158
- const firstNegativeY = firstNegativeValue(intervalY);
159
- const distanceFromOriginToFirstNegativeY = -22;
116
+ describe('firstNegativeValue', () => {
117
+ it('should return undefined for undefined interval', () => {
118
+ const interval = undefined;
119
+ const result = firstNegativeValue(interval);
120
+ expect(result).toEqual(undefined);
121
+ });
160
122
 
161
- const deltaAllowance = 5;
123
+ it('should return undefined for empty interval', () => {
124
+ const interval = [];
125
+ const result = firstNegativeValue(interval);
126
+ expect(result).toEqual(undefined);
127
+ });
162
128
 
163
- const result = sharedValues(
164
- firstNegativeX,
165
- firstNegativeY,
166
- distanceFromOriginToFirstNegativeX,
167
- distanceFromOriginToFirstNegativeY,
168
- deltaAllowance,
169
- );
129
+ it('should return undefined if there is no negative in interval array', () => {
130
+ const interval = [1, 5, 7, 4, 5];
131
+ const result = firstNegativeValue(interval);
132
+ expect(result).toEqual(undefined);
133
+ });
170
134
 
171
- expect(result).toEqual([]);
135
+ it('should return first negative number from interval', () => {
136
+ const interval = [1, 5, 7, -2, 4, 5, -1];
137
+ const result = firstNegativeValue(interval);
138
+ expect(result).toEqual(-2);
139
+ });
172
140
  });
173
141
 
174
- describe('skipValue should be empty array if firstNegativeX and firstNegativeY are equal but they do not overlap', () => {
175
- // x
176
- const intervalX = [-1, -2, 1, 2, 3, 4, 5, 6];
177
- const firstNegativeX = firstNegativeValue(intervalX);
178
- const distanceFromOriginToFirstNegativeX = -7;
179
-
180
- // y
181
- const intervalY = [-1, -2, 1, 2, 3, 4, 5, 6];
182
- const firstNegativeY = firstNegativeValue(intervalY);
183
- const distanceFromOriginToFirstNegativeY = -22;
184
-
185
- const deltaAllowance = 5;
186
-
187
- const result = sharedValues(
188
- firstNegativeX,
189
- firstNegativeY,
190
- distanceFromOriginToFirstNegativeX,
191
- distanceFromOriginToFirstNegativeY,
192
- deltaAllowance,
193
- );
142
+ describe('sharedValues', () => {
143
+ it('should be empty array if firstNegativeValue for one of the axes is undefined', () => {
144
+ // x
145
+ const intervalX = [1, 2, 3, 4, 5, 6];
146
+ const firstNegativeX = firstNegativeValue(intervalX);
147
+ const distanceFromOriginToFirstNegativeX = -22;
148
+
149
+ // y
150
+ const intervalY = [-1, -2, 1, 2, 3, 4, 5, 6];
151
+ const firstNegativeY = firstNegativeValue(intervalY);
152
+ const distanceFromOriginToFirstNegativeY = -22;
153
+
154
+ const deltaAllowance = 5;
155
+
156
+ const result = sharedValues(
157
+ firstNegativeX,
158
+ firstNegativeY,
159
+ distanceFromOriginToFirstNegativeX,
160
+ distanceFromOriginToFirstNegativeY,
161
+ deltaAllowance,
162
+ );
163
+
164
+ expect(result).toEqual([]);
165
+ });
194
166
 
195
- expect(result).toEqual([]);
196
- });
167
+ it('should be empty array if firstNegativeX and firstNegativeY are equal but they do not overlap', () => {
168
+ // x
169
+ const intervalX = [-1, -2, 1, 2, 3, 4, 5, 6];
170
+ const firstNegativeX = firstNegativeValue(intervalX);
171
+ const distanceFromOriginToFirstNegativeX = -7;
197
172
 
198
- describe('skipValue should be -1 if firstNegativeX and firstNegativeY are equal and they overlap', () => {
199
- // x
200
- const intervalX = [-1, -2, 1, 2, 3, 4, 5, 6];
201
- const firstNegativeX = firstNegativeValue(intervalX);
202
- const distanceFromOriginToFirstNegativeX = -20;
173
+ // y
174
+ const intervalY = [-1, -2, 1, 2, 3, 4, 5, 6];
175
+ const firstNegativeY = firstNegativeValue(intervalY);
176
+ const distanceFromOriginToFirstNegativeY = -22;
203
177
 
204
- // y
205
- const intervalY = [-1, -2, 1, 2, 3, 4, 5, 6];
206
- const firstNegativeY = firstNegativeValue(intervalY);
207
- const distanceFromOriginToFirstNegativeY = -22;
178
+ const deltaAllowance = 5;
208
179
 
209
- const deltaAllowance = 5;
180
+ const result = sharedValues(
181
+ firstNegativeX,
182
+ firstNegativeY,
183
+ distanceFromOriginToFirstNegativeX,
184
+ distanceFromOriginToFirstNegativeY,
185
+ deltaAllowance,
186
+ );
210
187
 
211
- const result = sharedValues(
212
- firstNegativeX,
213
- firstNegativeY,
214
- distanceFromOriginToFirstNegativeX,
215
- distanceFromOriginToFirstNegativeY,
216
- deltaAllowance,
217
- );
188
+ expect(result).toEqual([]);
189
+ });
218
190
 
219
- expect(result).toEqual([-1]);
191
+ it('should be -1 if firstNegativeX and firstNegativeY are equal and they overlap', () => {
192
+ // x
193
+ const intervalX = [-1, -2, 1, 2, 3, 4, 5, 6];
194
+ const firstNegativeX = firstNegativeValue(intervalX);
195
+ const distanceFromOriginToFirstNegativeX = -20;
196
+
197
+ // y
198
+ const intervalY = [-1, -2, 1, 2, 3, 4, 5, 6];
199
+ const firstNegativeY = firstNegativeValue(intervalY);
200
+ const distanceFromOriginToFirstNegativeY = -22;
201
+
202
+ const deltaAllowance = 5;
203
+ const dy = -20; // dy needs to be within the range for the condition to pass
204
+
205
+ const result = sharedValues(
206
+ firstNegativeX,
207
+ firstNegativeY,
208
+ distanceFromOriginToFirstNegativeX,
209
+ distanceFromOriginToFirstNegativeY,
210
+ deltaAllowance,
211
+ dy,
212
+ );
213
+
214
+ expect(result).toEqual([-1]);
215
+ });
220
216
  });
@@ -1,20 +1,16 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
 
4
- import classNames from 'classnames';
5
- import { withStyles } from '@material-ui/core/styles';
4
+ import { styled } from '@mui/material/styles';
6
5
  import { types } from '@pie-lib/plot';
7
6
 
8
- const style = (theme) => ({
9
- root: {
10
- fill: `var(--arrow-color, ${theme.palette.common.black})`,
11
- },
12
- });
7
+ const StyledPath = styled('path')(({ theme }) => ({
8
+ fill: `var(--arrow-color, ${theme.palette.common.black})`,
9
+ }));
13
10
 
14
11
  export class Arrow extends React.Component {
15
12
  render() {
16
- const { x, y, classes, className, scale } = this.props;
17
- const names = classNames(classes.root, className);
13
+ const { x, y, className, scale } = this.props;
18
14
  let direction = this.props.direction || 'left';
19
15
 
20
16
  const xv = scale.x(x);
@@ -40,7 +36,7 @@ export class Arrow extends React.Component {
40
36
  transform = getTransform(xv, yv + 15, 270);
41
37
  }
42
38
 
43
- return <path d="m 0,0 8,-5 0,10 -8,-5" transform={transform} className={names} />;
39
+ return <StyledPath d="m 0,0 8,-5 0,10 -8,-5" transform={transform} className={className} />;
44
40
  }
45
41
  }
46
42
 
@@ -48,7 +44,6 @@ Arrow.propTypes = {
48
44
  y: PropTypes.number,
49
45
  x: PropTypes.number,
50
46
  direction: PropTypes.oneOf(['left', 'right', 'up', 'down']),
51
- classes: PropTypes.object.isRequired,
52
47
  className: PropTypes.string,
53
48
  scale: types.ScaleType.isRequired,
54
49
  };
@@ -59,4 +54,4 @@ Arrow.defaultProps = {
59
54
  direction: 'left',
60
55
  };
61
56
 
62
- export default withStyles(style)(Arrow);
57
+ export default Arrow;