@pie-lib/plot 2.27.3-next.2 → 2.27.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.
@@ -0,0 +1,265 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
5
+ var _react = require("@testing-library/react");
6
+ var _react2 = _interopRequireDefault(require("react"));
7
+ var _root = require("../root");
8
+ var _d3Selection = require("d3-selection");
9
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
10
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
11
+ jest.mock('d3-selection', function () {
12
+ return {
13
+ select: jest.fn(),
14
+ mouse: jest.fn()
15
+ };
16
+ });
17
+ var scaleMock = function scaleMock() {
18
+ var fn = jest.fn(function (n) {
19
+ return n;
20
+ });
21
+ fn.invert = jest.fn(function (n) {
22
+ return n;
23
+ });
24
+ return fn;
25
+ };
26
+ var graphProps = function graphProps() {
27
+ return {
28
+ scale: {
29
+ x: scaleMock(),
30
+ y: scaleMock()
31
+ },
32
+ snap: {
33
+ x: jest.fn(function (n) {
34
+ return n;
35
+ }),
36
+ y: jest.fn(function (n) {
37
+ return n;
38
+ })
39
+ },
40
+ domain: {
41
+ min: 0,
42
+ max: 1,
43
+ step: 1
44
+ },
45
+ range: {
46
+ min: 0,
47
+ max: 1,
48
+ step: 1
49
+ },
50
+ size: {
51
+ width: 400,
52
+ height: 400
53
+ }
54
+ };
55
+ };
56
+ describe('root', function () {
57
+ var mockOn;
58
+ var defaultProps;
59
+ beforeEach(function () {
60
+ mockOn = jest.fn();
61
+ _d3Selection.select.mockReturnValue({
62
+ on: mockOn
63
+ });
64
+ _d3Selection.mouse.mockReturnValue([0, 0]);
65
+ defaultProps = {
66
+ classes: {},
67
+ graphProps: graphProps()
68
+ };
69
+ });
70
+ afterEach(function () {
71
+ (0, _react.cleanup)();
72
+ jest.clearAllMocks();
73
+ });
74
+ it('renders with children', function () {
75
+ var _render = (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, defaultProps, "hi")),
76
+ container = _render.container,
77
+ getByText = _render.getByText;
78
+ expect(container.firstChild).toBeInTheDocument();
79
+ expect(getByText('hi')).toBeInTheDocument();
80
+ });
81
+ describe('logic', function () {
82
+ describe('mousemove', function () {
83
+ describe('mount/unmount', function () {
84
+ it('adds mousemove listener on componentDidMount', function () {
85
+ (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, defaultProps, "hi"));
86
+
87
+ // Verify that select was called with the g element
88
+ expect(_d3Selection.select).toHaveBeenCalled();
89
+
90
+ // Verify that on() was called with 'mousemove' and a function
91
+ expect(mockOn).toHaveBeenCalledWith('mousemove', expect.any(Function));
92
+ });
93
+ it('removes mousemove listener on componentWillUnmount', function () {
94
+ var _render2 = (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, defaultProps, "hi")),
95
+ unmount = _render2.unmount;
96
+
97
+ // Clear previous calls to isolate unmount behavior
98
+ mockOn.mockClear();
99
+ _d3Selection.select.mockClear();
100
+ unmount();
101
+
102
+ // Verify that select was called during unmount
103
+ expect(_d3Selection.select).toHaveBeenCalled();
104
+
105
+ // Verify that on() was called with 'mousemove' and null to remove the listener
106
+ expect(mockOn).toHaveBeenCalledWith('mousemove', null);
107
+ });
108
+ });
109
+ describe('mouseMove function', function () {
110
+ it('calls mouse with correct arguments', function () {
111
+ var onMouseMove = jest.fn();
112
+ var gp = graphProps();
113
+ var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
114
+ onMouseMove: onMouseMove,
115
+ graphProps: gp
116
+ });
117
+ var mockNode = document.createElement('div');
118
+ var mockSelection = {
119
+ _groups: [[mockNode]],
120
+ node: function node() {
121
+ return mockNode;
122
+ }
123
+ };
124
+
125
+ // Mock select to return our mockSelection
126
+ _d3Selection.select.mockReturnValue(_objectSpread(_objectSpread({}, mockSelection), {}, {
127
+ on: function on(event, handler) {
128
+ mockOn(event, handler);
129
+ // When 'mousemove' is registered, immediately test it
130
+ if (event === 'mousemove' && handler) {
131
+ _d3Selection.mouse.mockReturnValue([10, 20]);
132
+ // Handler is bound with mockSelection as first arg, so call with no args
133
+ handler();
134
+ }
135
+ }
136
+ }));
137
+ (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, props, "hi"));
138
+
139
+ // Verify mouse was called with the correct node
140
+ expect(_d3Selection.mouse).toHaveBeenCalledWith(mockNode);
141
+ });
142
+ it('calls scale.x.invert and scale.y.invert', function () {
143
+ var onMouseMove = jest.fn();
144
+ var gp = graphProps();
145
+ var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
146
+ onMouseMove: onMouseMove,
147
+ graphProps: gp
148
+ });
149
+ var mockNode = document.createElement('div');
150
+ var mockSelection = {
151
+ _groups: [[mockNode]],
152
+ node: function node() {
153
+ return mockNode;
154
+ }
155
+ };
156
+ _d3Selection.select.mockReturnValue(_objectSpread(_objectSpread({}, mockSelection), {}, {
157
+ on: function on(event, handler) {
158
+ mockOn(event, handler);
159
+ if (event === 'mousemove' && handler) {
160
+ _d3Selection.mouse.mockReturnValue([15, 25]);
161
+ handler();
162
+ }
163
+ }
164
+ }));
165
+ (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, props, "hi"));
166
+ expect(gp.scale.x.invert).toHaveBeenCalledWith(15);
167
+ expect(gp.scale.y.invert).toHaveBeenCalledWith(25);
168
+ });
169
+ it('calls snap.x and snap.y with inverted coordinates', function () {
170
+ var onMouseMove = jest.fn();
171
+ var gp = graphProps();
172
+ gp.scale.x.invert = jest.fn().mockReturnValue(5);
173
+ gp.scale.y.invert = jest.fn().mockReturnValue(10);
174
+ var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
175
+ onMouseMove: onMouseMove,
176
+ graphProps: gp
177
+ });
178
+ var mockNode = document.createElement('div');
179
+ var mockSelection = {
180
+ _groups: [[mockNode]],
181
+ node: function node() {
182
+ return mockNode;
183
+ }
184
+ };
185
+ _d3Selection.select.mockReturnValue(_objectSpread(_objectSpread({}, mockSelection), {}, {
186
+ on: function on(event, handler) {
187
+ mockOn(event, handler);
188
+ if (event === 'mousemove' && handler) {
189
+ _d3Selection.mouse.mockReturnValue([15, 25]);
190
+ handler();
191
+ }
192
+ }
193
+ }));
194
+ (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, props, "hi"));
195
+ expect(gp.snap.x).toHaveBeenCalledWith(5);
196
+ expect(gp.snap.y).toHaveBeenCalledWith(10);
197
+ });
198
+ it('calls onMouseMove handler with snapped coordinates', function () {
199
+ var onMouseMove = jest.fn();
200
+ var gp = graphProps();
201
+ gp.scale.x.invert = jest.fn().mockReturnValue(7);
202
+ gp.scale.y.invert = jest.fn().mockReturnValue(14);
203
+ gp.snap.x = jest.fn().mockReturnValue(10);
204
+ gp.snap.y = jest.fn().mockReturnValue(15);
205
+ var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
206
+ onMouseMove: onMouseMove,
207
+ graphProps: gp
208
+ });
209
+ var mockNode = document.createElement('div');
210
+ var mockSelection = {
211
+ _groups: [[mockNode]],
212
+ node: function node() {
213
+ return mockNode;
214
+ }
215
+ };
216
+ _d3Selection.select.mockReturnValue(_objectSpread(_objectSpread({}, mockSelection), {}, {
217
+ on: function on(event, handler) {
218
+ mockOn(event, handler);
219
+ if (event === 'mousemove' && handler) {
220
+ _d3Selection.mouse.mockReturnValue([100, 200]);
221
+ handler();
222
+ }
223
+ }
224
+ }));
225
+ (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, props, "hi"));
226
+ expect(onMouseMove).toHaveBeenCalledWith({
227
+ x: 10,
228
+ y: 15
229
+ });
230
+ });
231
+ it('does not call onMouseMove when handler is not provided', function () {
232
+ var gp = graphProps();
233
+ var props = _objectSpread(_objectSpread({}, defaultProps), {}, {
234
+ graphProps: gp
235
+ });
236
+ var mockNode = document.createElement('div');
237
+ var mockSelection = {
238
+ _groups: [[mockNode]],
239
+ node: function node() {
240
+ return mockNode;
241
+ }
242
+ };
243
+ _d3Selection.select.mockReturnValue(_objectSpread(_objectSpread({}, mockSelection), {}, {
244
+ on: function on(event, handler) {
245
+ mockOn(event, handler);
246
+ if (event === 'mousemove' && handler) {
247
+ _d3Selection.mouse.mockReturnValue([100, 200]);
248
+ // Should not throw error when onMouseMove is not provided
249
+ expect(function () {
250
+ return handler();
251
+ }).not.toThrow();
252
+ }
253
+ }
254
+ }));
255
+ (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_root.Root, props, "hi"));
256
+
257
+ // Verify scale methods were not called (early return in mouseMove)
258
+ expect(gp.scale.x.invert).not.toHaveBeenCalled();
259
+ expect(gp.scale.y.invert).not.toHaveBeenCalled();
260
+ });
261
+ });
262
+ });
263
+ });
264
+ });
265
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_react2","_interopRequireDefault","_root","_d3Selection","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","jest","mock","select","fn","mouse","scaleMock","n","invert","graphProps","scale","x","y","snap","domain","min","max","step","range","size","width","height","describe","mockOn","defaultProps","beforeEach","mockReturnValue","on","classes","afterEach","cleanup","clearAllMocks","it","_render","render","createElement","Root","container","getByText","expect","firstChild","toBeInTheDocument","toHaveBeenCalled","toHaveBeenCalledWith","any","Function","_render2","unmount","mockClear","onMouseMove","gp","props","mockNode","document","mockSelection","_groups","node","event","handler","not","toThrow"],"sources":["../../src/__tests__/root.test.jsx"],"sourcesContent":["import { render, cleanup } from '@testing-library/react';\nimport React from 'react';\nimport { Root } from '../root';\nimport { select, mouse } from 'd3-selection';\n\njest.mock('d3-selection', () => ({\n  select: jest.fn(),\n  mouse: jest.fn(),\n}));\n\nconst scaleMock = () => {\n  const fn = jest.fn((n) => n);\n  fn.invert = jest.fn((n) => n);\n  return fn;\n};\n\nconst graphProps = () => ({\n  scale: {\n    x: scaleMock(),\n    y: scaleMock(),\n  },\n  snap: {\n    x: jest.fn((n) => n),\n    y: jest.fn((n) => n),\n  },\n  domain: {\n    min: 0,\n    max: 1,\n    step: 1,\n  },\n  range: {\n    min: 0,\n    max: 1,\n    step: 1,\n  },\n  size: {\n    width: 400,\n    height: 400,\n  },\n});\n\ndescribe('root', () => {\n  let mockOn;\n  let defaultProps;\n\n  beforeEach(() => {\n    mockOn = jest.fn();\n    select.mockReturnValue({\n      on: mockOn,\n    });\n    mouse.mockReturnValue([0, 0]);\n\n    defaultProps = {\n      classes: {},\n      graphProps: graphProps(),\n    };\n  });\n\n  afterEach(() => {\n    cleanup();\n    jest.clearAllMocks();\n  });\n\n  it('renders with children', () => {\n    const { container, getByText } = render(\n      <Root {...defaultProps}>hi</Root>\n    );\n    expect(container.firstChild).toBeInTheDocument();\n    expect(getByText('hi')).toBeInTheDocument();\n  });\n\n  describe('logic', () => {\n    describe('mousemove', () => {\n      describe('mount/unmount', () => {\n        it('adds mousemove listener on componentDidMount', () => {\n          render(<Root {...defaultProps}>hi</Root>);\n\n          // Verify that select was called with the g element\n          expect(select).toHaveBeenCalled();\n\n          // Verify that on() was called with 'mousemove' and a function\n          expect(mockOn).toHaveBeenCalledWith('mousemove', expect.any(Function));\n        });\n\n        it('removes mousemove listener on componentWillUnmount', () => {\n          const { unmount } = render(<Root {...defaultProps}>hi</Root>);\n\n          // Clear previous calls to isolate unmount behavior\n          mockOn.mockClear();\n          select.mockClear();\n\n          unmount();\n\n          // Verify that select was called during unmount\n          expect(select).toHaveBeenCalled();\n\n          // Verify that on() was called with 'mousemove' and null to remove the listener\n          expect(mockOn).toHaveBeenCalledWith('mousemove', null);\n        });\n      });\n\n      describe('mouseMove function', () => {\n        it('calls mouse with correct arguments', () => {\n          const onMouseMove = jest.fn();\n          const gp = graphProps();\n          const props = {\n            ...defaultProps,\n            onMouseMove,\n            graphProps: gp,\n          };\n\n          const mockNode = document.createElement('div');\n          const mockSelection = {\n            _groups: [[mockNode]],\n            node: () => mockNode,\n          };\n\n          // Mock select to return our mockSelection\n          select.mockReturnValue({\n            ...mockSelection,\n            on: (event, handler) => {\n              mockOn(event, handler);\n              // When 'mousemove' is registered, immediately test it\n              if (event === 'mousemove' && handler) {\n                mouse.mockReturnValue([10, 20]);\n                // Handler is bound with mockSelection as first arg, so call with no args\n                handler();\n              }\n            },\n          });\n\n          render(<Root {...props}>hi</Root>);\n\n          // Verify mouse was called with the correct node\n          expect(mouse).toHaveBeenCalledWith(mockNode);\n        });\n\n        it('calls scale.x.invert and scale.y.invert', () => {\n          const onMouseMove = jest.fn();\n          const gp = graphProps();\n          const props = {\n            ...defaultProps,\n            onMouseMove,\n            graphProps: gp,\n          };\n\n          const mockNode = document.createElement('div');\n          const mockSelection = {\n            _groups: [[mockNode]],\n            node: () => mockNode,\n          };\n\n          select.mockReturnValue({\n            ...mockSelection,\n            on: (event, handler) => {\n              mockOn(event, handler);\n              if (event === 'mousemove' && handler) {\n                mouse.mockReturnValue([15, 25]);\n                handler();\n              }\n            },\n          });\n\n          render(<Root {...props}>hi</Root>);\n\n          expect(gp.scale.x.invert).toHaveBeenCalledWith(15);\n          expect(gp.scale.y.invert).toHaveBeenCalledWith(25);\n        });\n\n        it('calls snap.x and snap.y with inverted coordinates', () => {\n          const onMouseMove = jest.fn();\n          const gp = graphProps();\n          gp.scale.x.invert = jest.fn().mockReturnValue(5);\n          gp.scale.y.invert = jest.fn().mockReturnValue(10);\n          const props = {\n            ...defaultProps,\n            onMouseMove,\n            graphProps: gp,\n          };\n\n          const mockNode = document.createElement('div');\n          const mockSelection = {\n            _groups: [[mockNode]],\n            node: () => mockNode,\n          };\n\n          select.mockReturnValue({\n            ...mockSelection,\n            on: (event, handler) => {\n              mockOn(event, handler);\n              if (event === 'mousemove' && handler) {\n                mouse.mockReturnValue([15, 25]);\n                handler();\n              }\n            },\n          });\n\n          render(<Root {...props}>hi</Root>);\n\n          expect(gp.snap.x).toHaveBeenCalledWith(5);\n          expect(gp.snap.y).toHaveBeenCalledWith(10);\n        });\n\n        it('calls onMouseMove handler with snapped coordinates', () => {\n          const onMouseMove = jest.fn();\n          const gp = graphProps();\n          gp.scale.x.invert = jest.fn().mockReturnValue(7);\n          gp.scale.y.invert = jest.fn().mockReturnValue(14);\n          gp.snap.x = jest.fn().mockReturnValue(10);\n          gp.snap.y = jest.fn().mockReturnValue(15);\n\n          const props = {\n            ...defaultProps,\n            onMouseMove,\n            graphProps: gp,\n          };\n\n          const mockNode = document.createElement('div');\n          const mockSelection = {\n            _groups: [[mockNode]],\n            node: () => mockNode,\n          };\n\n          select.mockReturnValue({\n            ...mockSelection,\n            on: (event, handler) => {\n              mockOn(event, handler);\n              if (event === 'mousemove' && handler) {\n                mouse.mockReturnValue([100, 200]);\n                handler();\n              }\n            },\n          });\n\n          render(<Root {...props}>hi</Root>);\n\n          expect(onMouseMove).toHaveBeenCalledWith({ x: 10, y: 15 });\n        });\n\n        it('does not call onMouseMove when handler is not provided', () => {\n          const gp = graphProps();\n          const props = {\n            ...defaultProps,\n            graphProps: gp,\n          };\n\n          const mockNode = document.createElement('div');\n          const mockSelection = {\n            _groups: [[mockNode]],\n            node: () => mockNode,\n          };\n\n          select.mockReturnValue({\n            ...mockSelection,\n            on: (event, handler) => {\n              mockOn(event, handler);\n              if (event === 'mousemove' && handler) {\n                mouse.mockReturnValue([100, 200]);\n                // Should not throw error when onMouseMove is not provided\n                expect(() => handler()).not.toThrow();\n              }\n            },\n          });\n\n          render(<Root {...props}>hi</Root>);\n\n          // Verify scale methods were not called (early return in mouseMove)\n          expect(gp.scale.x.invert).not.toHaveBeenCalled();\n          expect(gp.scale.y.invert).not.toHaveBeenCalled();\n        });\n      });\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
5
+ var _trig = require("../trig");
6
+ var _utils = require("../utils");
7
+ var _debug = _interopRequireDefault(require("debug"));
8
+ var _templateObject, _templateObject2, _templateObject3;
9
+ var log = (0, _debug["default"])('pie-lib:plot:trig:test');
10
+ var vs = function vs(v) {
11
+ if (!v) {
12
+ return '';
13
+ }
14
+ if (Number.isFinite(v.x) && Number.isFinite(v.y)) {
15
+ return "[".concat(v.x, ",").concat(v.y, "]");
16
+ }
17
+ return JSON.stringify(v);
18
+ };
19
+ var p = function p(strings) {
20
+ for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
21
+ values[_key - 1] = arguments[_key];
22
+ }
23
+ return strings.reduce(function (acc, s, index) {
24
+ return "".concat(acc).concat(s).concat(vs(values[index]));
25
+ }, '');
26
+ };
27
+ describe('trig', function () {
28
+ describe('angle', function () {
29
+ var assertAngle = function assertAngle(a, b, expected) {
30
+ it(p(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["", ", ", " => ", ""])), a, b, (0, _trig.toDegrees)(expected)), function () {
31
+ var result = (0, _trig.angle)(a, b);
32
+ expect(result).toBeCloseTo(expected);
33
+ });
34
+ };
35
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _trig.toRadians)(45));
36
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(0, 1), (0, _trig.toRadians)(90));
37
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _trig.toRadians)(135));
38
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 0), (0, _trig.toRadians)(180));
39
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, -1), (0, _trig.toRadians)(225));
40
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(0, -1), (0, _trig.toRadians)(270));
41
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(1, -1), (0, _trig.toRadians)(315));
42
+ assertAngle((0, _utils.xy)(1, 1), (0, _utils.xy)(0, 0), (0, _trig.toRadians)(225));
43
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _trig.toRadians)(45));
44
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 1), (0, _trig.toRadians)(26.565));
45
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(3, 1), (0, _trig.toRadians)(18.434));
46
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(4, 1), (0, _trig.toRadians)(14.036));
47
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(5, 1), (0, _trig.toRadians)(11.309));
48
+ });
49
+ describe('acuteXAngle', function () {
50
+ var assertAcute = function assertAcute(input, expected) {
51
+ it("".concat((0, _trig.toDegrees)(input), " => ").concat((0, _trig.toDegrees)(expected)), function () {
52
+ var result = (0, _trig.acuteXAngle)(input);
53
+ log("result: ".concat((0, _trig.toDegrees)(result)));
54
+ expect(result).toBeCloseTo(expected);
55
+ });
56
+ };
57
+ assertAcute((0, _trig.toRadians)(45), (0, _trig.toRadians)(45));
58
+ assertAcute((0, _trig.toRadians)(100), (0, _trig.toRadians)(80));
59
+ assertAcute((0, _trig.toRadians)(190), (0, _trig.toRadians)(10));
60
+ assertAcute((0, _trig.toRadians)(350), (0, _trig.toRadians)(10));
61
+ });
62
+ describe('acuteYAngle', function () {
63
+ var assertAcute = function assertAcute(input, expected) {
64
+ it("".concat((0, _trig.toDegrees)(input), " => ").concat((0, _trig.toDegrees)(expected)), function () {
65
+ var result = (0, _trig.acuteYAngle)(input);
66
+ log("result: ".concat((0, _trig.toDegrees)(result)));
67
+ expect(result).toBeCloseTo(expected);
68
+ });
69
+ };
70
+ assertAcute((0, _trig.toRadians)(45), (0, _trig.toRadians)(45));
71
+ assertAcute((0, _trig.toRadians)(100), (0, _trig.toRadians)(10));
72
+ assertAcute((0, _trig.toRadians)(190), (0, _trig.toRadians)(80));
73
+ assertAcute((0, _trig.toRadians)(350), (0, _trig.toRadians)(80));
74
+ });
75
+ describe('edges', function () {
76
+ var assertEdges = function assertEdges(domain, range) {
77
+ return function (from, to, expected) {
78
+ it(p(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["", ", ", " + ", " -> ", " => ", "", ""])), domain, range, from, to, expected[0], expected[1]), function () {
79
+ var result = (0, _trig.edges)(domain, range)(from, to);
80
+ expect(result[0].x).toBeCloseTo(expected[0].x);
81
+ expect(result[0].y).toBeCloseTo(expected[0].y);
82
+ expect(result[1].x).toBeCloseTo(expected[1].x);
83
+ expect(result[1].y).toBeCloseTo(expected[1].y);
84
+ });
85
+ };
86
+ };
87
+ var one = assertEdges({
88
+ min: -4,
89
+ max: 4
90
+ }, {
91
+ min: -4,
92
+ max: 4
93
+ });
94
+ one((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), [(0, _utils.xy)(4, 4), (0, _utils.xy)(-4, -4)]);
95
+ one((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 1), [(0, _utils.xy)(4, 2), (0, _utils.xy)(-4, -2)]);
96
+ one((0, _utils.xy)(1, 1), (0, _utils.xy)(2, 2), [(0, _utils.xy)(4, 4), (0, _utils.xy)(-4, -4)]);
97
+ one((0, _utils.xy)(1, 0), (0, _utils.xy)(2, 0), [(0, _utils.xy)(4, 0), (0, _utils.xy)(-4, 0)]);
98
+ one((0, _utils.xy)(1, 0), (0, _utils.xy)(-2, 0), [(0, _utils.xy)(-4, 0), (0, _utils.xy)(4, 0)]);
99
+
100
+ /**
101
+ * domain {min: -5, max: 5, padding: 0, step: 1, labelStep: 1}labelStep: 1max: 5min: -5padding: 0step: 1__proto__: Object range: {min: -5, max: 5, padding: 0, step: 1, labelStep: 1} a: {x: -5, y: 0} b: {x: -5, y: 2} edges: Point {x: -5, y: 5} Point {x: -5, y: 2}
102
+ */
103
+ var lineIssue = assertEdges({
104
+ min: -5,
105
+ max: 5
106
+ }, {
107
+ min: -5,
108
+ max: 5
109
+ });
110
+ lineIssue((0, _utils.xy)(-5, -0), (0, _utils.xy)(-5, 2), [(0, _utils.xy)(-5, 5), (0, _utils.xy)(-5, -5)]);
111
+ });
112
+ describe('diffEdge', function () {
113
+ var assertDiffEdge = function assertDiffEdge(bounds, from, to, expected) {
114
+ it(p(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["<", "> ", " -> ", " => ", ""])), bounds, from, to, expected), function () {
115
+ var result = (0, _trig.diffEdge)(bounds, from, to);
116
+ expect(result.x).toBeCloseTo(expected.x);
117
+ expect(result.y).toBeCloseTo(expected.y);
118
+ });
119
+ };
120
+ var twoTwo = assertDiffEdge.bind(null, (0, _utils.xy)(2, 2));
121
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _utils.xy)(2, 2));
122
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 2), (0, _utils.xy)(1, 2));
123
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 2), (0, _utils.xy)(2, 2));
124
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 2), (0, _utils.xy)(2, 2));
125
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _utils.xy)(-2, 2));
126
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-2, -2));
127
+ var fourFour = assertDiffEdge.bind(null, (0, _utils.xy)(4, 4));
128
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _utils.xy)(4, 4));
129
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 2), (0, _utils.xy)(2, 4));
130
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 1), (0, _utils.xy)(4, 2));
131
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _utils.xy)(-4, 4));
132
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _utils.xy)(-4, 4));
133
+ assertDiffEdge((0, _utils.xy)(-4, -4), (0, _utils.xy)(0, 0), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-4, -4));
134
+ assertDiffEdge((0, _utils.xy)(4, 4), (0, _utils.xy)(1, 1), (0, _utils.xy)(2, 2), (0, _utils.xy)(4, 4));
135
+ assertDiffEdge((0, _utils.xy)(4, 4), (0, _utils.xy)(2, 2), (0, _utils.xy)(3, 3), (0, _utils.xy)(4, 4));
136
+ assertDiffEdge((0, _utils.xy)(-4, -4), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-2, -2), (0, _utils.xy)(-4, -4));
137
+ assertDiffEdge((0, _utils.xy)(-4, 4), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-2, 0), (0, _utils.xy)(-4, 2));
138
+ var lineIssue = assertDiffEdge.bind(null, (0, _utils.xy)(-5, -5));
139
+ lineIssue((0, _utils.xy)(-5, 2), (0, _utils.xy)(-5, 0), (0, _utils.xy)(-5, -5));
140
+ //Top Right
141
+ assertDiffEdge((0, _utils.xy)(5, 5), (0, _utils.xy)(0, 5), (0, _utils.xy)(2, 5), (0, _utils.xy)(5, 5));
142
+ assertDiffEdge((0, _utils.xy)(5, 5), (0, _utils.xy)(5, 0), (0, _utils.xy)(5, 1), (0, _utils.xy)(5, 5));
143
+
144
+ // //Bottom Right
145
+ assertDiffEdge((0, _utils.xy)(5, -5), (0, _utils.xy)(5, 0), (0, _utils.xy)(5, -0.1), (0, _utils.xy)(5, -5));
146
+ assertDiffEdge((0, _utils.xy)(5, -5), (0, _utils.xy)(0, -5), (0, _utils.xy)(1, -5), (0, _utils.xy)(5, -5));
147
+
148
+ //Top Left
149
+ assertDiffEdge((0, _utils.xy)(-5, 5), (0, _utils.xy)(-5, 0), (0, _utils.xy)(-5, 0.1), (0, _utils.xy)(-5, 5));
150
+ assertDiffEdge((0, _utils.xy)(-5, 5), (0, _utils.xy)(0, 5), (0, _utils.xy)(-1, 5), (0, _utils.xy)(-5, 5));
151
+
152
+ //Bottom Left
153
+ assertDiffEdge((0, _utils.xy)(-5, -5), (0, _utils.xy)(-5, 0), (0, _utils.xy)(-5, -0.1), (0, _utils.xy)(-5, -5));
154
+ assertDiffEdge((0, _utils.xy)(-5, -5), (0, _utils.xy)(0, -5), (0, _utils.xy)(-1, -5), (0, _utils.xy)(-5, -5));
155
+ });
156
+ describe('getOpposingSide', function () {
157
+ var assertOpposingSide = function assertOpposingSide(hyp, angle, expected) {
158
+ it("".concat(hyp, ", ").concat(angle, " = ").concat(expected), function () {
159
+ var radians = (0, _trig.toRadians)(angle);
160
+ var result = (0, _trig.getOpposingSide)(hyp, radians);
161
+ expect(result).toBeCloseTo(expected);
162
+ });
163
+ };
164
+ assertOpposingSide(1, 45, 0.707);
165
+ assertOpposingSide(1.25, 45, 0.88);
166
+ });
167
+ });
168
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_trig","require","_utils","_debug","_interopRequireDefault","_templateObject","_templateObject2","_templateObject3","log","debug","vs","v","Number","isFinite","x","y","concat","JSON","stringify","p","strings","_len","arguments","length","values","Array","_key","reduce","acc","s","index","describe","assertAngle","a","b","expected","it","_taggedTemplateLiteral2","toDegrees","result","angle","expect","toBeCloseTo","xy","toRadians","assertAcute","input","acuteXAngle","acuteYAngle","assertEdges","domain","range","from","to","edges","one","min","max","lineIssue","assertDiffEdge","bounds","diffEdge","twoTwo","bind","fourFour","assertOpposingSide","hyp","radians","getOpposingSide"],"sources":["../../src/__tests__/trig.test.js"],"sourcesContent":["import {\n  angle,\n  edge,\n  edges,\n  maxEdge,\n  minEdge,\n  toRadians,\n  toDegrees,\n  acuteXAngle,\n  acuteYAngle,\n  diffEdge,\n} from '../trig';\nimport { xy } from '../utils';\nimport debug from 'debug';\nimport { getOpposingSide } from '../trig';\nconst log = debug('pie-lib:plot:trig:test');\n\nconst vs = (v) => {\n  if (!v) {\n    return '';\n  }\n\n  if (Number.isFinite(v.x) && Number.isFinite(v.y)) {\n    return `[${v.x},${v.y}]`;\n  }\n  return JSON.stringify(v);\n};\nconst p = (strings, ...values) => {\n  return strings.reduce((acc, s, index) => {\n    return `${acc}${s}${vs(values[index])}`;\n  }, '');\n};\ndescribe('trig', () => {\n  describe('angle', () => {\n    const assertAngle = (a, b, expected) => {\n      it(p`${a}, ${b} => ${toDegrees(expected)}`, () => {\n        const result = angle(a, b);\n        expect(result).toBeCloseTo(expected);\n      });\n    };\n\n    assertAngle(xy(0, 0), xy(1, 1), toRadians(45));\n    assertAngle(xy(0, 0), xy(0, 1), toRadians(90));\n    assertAngle(xy(0, 0), xy(-1, 1), toRadians(135));\n    assertAngle(xy(0, 0), xy(-1, 0), toRadians(180));\n    assertAngle(xy(0, 0), xy(-1, -1), toRadians(225));\n    assertAngle(xy(0, 0), xy(0, -1), toRadians(270));\n    assertAngle(xy(0, 0), xy(1, -1), toRadians(315));\n    assertAngle(xy(1, 1), xy(0, 0), toRadians(225));\n    assertAngle(xy(0, 0), xy(1, 1), toRadians(45));\n    assertAngle(xy(0, 0), xy(2, 1), toRadians(26.565));\n    assertAngle(xy(0, 0), xy(3, 1), toRadians(18.434));\n    assertAngle(xy(0, 0), xy(4, 1), toRadians(14.036));\n    assertAngle(xy(0, 0), xy(5, 1), toRadians(11.309));\n  });\n\n  describe('acuteXAngle', () => {\n    const assertAcute = (input, expected) => {\n      it(`${toDegrees(input)} => ${toDegrees(expected)}`, () => {\n        const result = acuteXAngle(input);\n        log(`result: ${toDegrees(result)}`);\n        expect(result).toBeCloseTo(expected);\n      });\n    };\n\n    assertAcute(toRadians(45), toRadians(45));\n    assertAcute(toRadians(100), toRadians(80));\n    assertAcute(toRadians(190), toRadians(10));\n    assertAcute(toRadians(350), toRadians(10));\n  });\n\n  describe('acuteYAngle', () => {\n    const assertAcute = (input, expected) => {\n      it(`${toDegrees(input)} => ${toDegrees(expected)}`, () => {\n        const result = acuteYAngle(input);\n        log(`result: ${toDegrees(result)}`);\n        expect(result).toBeCloseTo(expected);\n      });\n    };\n\n    assertAcute(toRadians(45), toRadians(45));\n    assertAcute(toRadians(100), toRadians(10));\n    assertAcute(toRadians(190), toRadians(80));\n    assertAcute(toRadians(350), toRadians(80));\n  });\n\n  describe('edges', () => {\n    const assertEdges = (domain, range) => (from, to, expected) => {\n      it(p`${domain}, ${range} + ${from} -> ${to} => ${expected[0]}${expected[1]}`, () => {\n        const result = edges(domain, range)(from, to);\n        expect(result[0].x).toBeCloseTo(expected[0].x);\n        expect(result[0].y).toBeCloseTo(expected[0].y);\n        expect(result[1].x).toBeCloseTo(expected[1].x);\n        expect(result[1].y).toBeCloseTo(expected[1].y);\n      });\n    };\n\n    const one = assertEdges({ min: -4, max: 4 }, { min: -4, max: 4 });\n    one(xy(0, 0), xy(1, 1), [xy(4, 4), xy(-4, -4)]);\n    one(xy(0, 0), xy(2, 1), [xy(4, 2), xy(-4, -2)]);\n    one(xy(1, 1), xy(2, 2), [xy(4, 4), xy(-4, -4)]);\n    one(xy(1, 0), xy(2, 0), [xy(4, 0), xy(-4, 0)]);\n    one(xy(1, 0), xy(-2, 0), [xy(-4, 0), xy(4, 0)]);\n\n    /**\n     * domain {min: -5, max: 5, padding: 0, step: 1, labelStep: 1}labelStep: 1max: 5min: -5padding: 0step: 1__proto__: Object range:  {min: -5, max: 5, padding: 0, step: 1, labelStep: 1} a: {x: -5, y: 0} b: {x: -5, y: 2} edges: Point {x: -5, y: 5} Point {x: -5, y: 2}\n     */\n    const lineIssue = assertEdges({ min: -5, max: 5 }, { min: -5, max: 5 });\n    lineIssue(xy(-5, -0), xy(-5, 2), [xy(-5, 5), xy(-5, -5)]);\n  });\n\n  describe('diffEdge', () => {\n    const assertDiffEdge = (bounds, from, to, expected) => {\n      it(p`<${bounds}> ${from} -> ${to} => ${expected}`, () => {\n        const result = diffEdge(bounds, from, to);\n        expect(result.x).toBeCloseTo(expected.x);\n        expect(result.y).toBeCloseTo(expected.y);\n      });\n    };\n\n    const twoTwo = assertDiffEdge.bind(null, xy(2, 2));\n    twoTwo(xy(0, 0), xy(1, 1), xy(2, 2));\n    twoTwo(xy(0, 0), xy(1, 2), xy(1, 2));\n    twoTwo(xy(0, 0), xy(2, 2), xy(2, 2));\n    twoTwo(xy(0, 0), xy(2, 2), xy(2, 2));\n    twoTwo(xy(0, 0), xy(-1, 1), xy(-2, 2));\n    twoTwo(xy(0, 0), xy(-1, -1), xy(-2, -2));\n    const fourFour = assertDiffEdge.bind(null, xy(4, 4));\n\n    fourFour(xy(0, 0), xy(1, 1), xy(4, 4));\n    fourFour(xy(0, 0), xy(1, 2), xy(2, 4));\n    fourFour(xy(0, 0), xy(2, 1), xy(4, 2));\n    fourFour(xy(0, 0), xy(-1, 1), xy(-4, 4));\n    fourFour(xy(0, 0), xy(-1, 1), xy(-4, 4));\n\n    assertDiffEdge(xy(-4, -4), xy(0, 0), xy(-1, -1), xy(-4, -4));\n    assertDiffEdge(xy(4, 4), xy(1, 1), xy(2, 2), xy(4, 4));\n    assertDiffEdge(xy(4, 4), xy(2, 2), xy(3, 3), xy(4, 4));\n    assertDiffEdge(xy(-4, -4), xy(-1, -1), xy(-2, -2), xy(-4, -4));\n    assertDiffEdge(xy(-4, 4), xy(-1, -1), xy(-2, 0), xy(-4, 2));\n\n    const lineIssue = assertDiffEdge.bind(null, xy(-5, -5));\n\n    lineIssue(xy(-5, 2), xy(-5, 0), xy(-5, -5));\n    //Top Right\n    assertDiffEdge(xy(5, 5), xy(0, 5), xy(2, 5), xy(5, 5));\n    assertDiffEdge(xy(5, 5), xy(5, 0), xy(5, 1), xy(5, 5));\n\n    // //Bottom Right\n    assertDiffEdge(xy(5, -5), xy(5, 0), xy(5, -0.1), xy(5, -5));\n    assertDiffEdge(xy(5, -5), xy(0, -5), xy(1, -5), xy(5, -5));\n\n    //Top Left\n    assertDiffEdge(xy(-5, 5), xy(-5, 0), xy(-5, 0.1), xy(-5, 5));\n    assertDiffEdge(xy(-5, 5), xy(0, 5), xy(-1, 5), xy(-5, 5));\n\n    //Bottom Left\n    assertDiffEdge(xy(-5, -5), xy(-5, 0), xy(-5, -0.1), xy(-5, -5));\n    assertDiffEdge(xy(-5, -5), xy(0, -5), xy(-1, -5), xy(-5, -5));\n  });\n\n  describe('getOpposingSide', () => {\n    const assertOpposingSide = (hyp, angle, expected) => {\n      it(`${hyp}, ${angle} = ${expected}`, () => {\n        const radians = toRadians(angle);\n        const result = getOpposingSide(hyp, radians);\n        expect(result).toBeCloseTo(expected);\n      });\n    };\n\n    assertOpposingSide(1, 45, 0.707);\n    assertOpposingSide(1.25, 45, 0.88);\n  });\n});\n"],"mappings":"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","ignoreList":[]}