@pie-lib/plot 2.7.4-next.0 → 2.9.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.
@@ -0,0 +1,151 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
6
+
7
+ var _enzyme = require("enzyme");
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _root = require("../root");
12
+
13
+ var _d3Selection = require("d3-selection");
14
+
15
+ 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; }
16
+
17
+ 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; }
18
+
19
+ var scaleMock = function scaleMock() {
20
+ var fn = jest.fn(function (n) {
21
+ return n;
22
+ });
23
+ fn.invert = jest.fn(function (n) {
24
+ return n;
25
+ });
26
+ return fn;
27
+ };
28
+
29
+ var graphProps = function graphProps() {
30
+ return {
31
+ scale: {
32
+ x: scaleMock(),
33
+ y: scaleMock()
34
+ },
35
+ snap: {
36
+ x: jest.fn(function (n) {
37
+ return n;
38
+ }),
39
+ y: jest.fn(function (n) {
40
+ return n;
41
+ })
42
+ },
43
+ domain: {
44
+ min: 0,
45
+ max: 1,
46
+ step: 1
47
+ },
48
+ range: {
49
+ min: 0,
50
+ max: 1,
51
+ step: 1
52
+ },
53
+ size: {
54
+ width: 400,
55
+ height: 400
56
+ }
57
+ };
58
+ };
59
+
60
+ var wrapper = function wrapper(props) {
61
+ props = _objectSpread({
62
+ classes: {},
63
+ graphProps: graphProps()
64
+ }, props);
65
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_root.Root, props, "hi"), {
66
+ disableLifecycleMethods: true
67
+ });
68
+ };
69
+
70
+ jest.mock('d3-selection', function () {
71
+ return {
72
+ select: jest.fn(),
73
+ mouse: jest.fn()
74
+ };
75
+ });
76
+ describe('root', function () {
77
+ describe('snapshot', function () {
78
+ it('matches', function () {
79
+ var w = wrapper();
80
+ expect(w).toMatchSnapshot();
81
+ });
82
+ });
83
+ describe('logic', function () {
84
+ describe('mousemove', function () {
85
+ describe('mount/unmount', function () {
86
+ it('adds mousemove listener on compenentDidMount', function () {
87
+ var w = wrapper();
88
+ var g = {
89
+ on: jest.fn()
90
+ };
91
+
92
+ _d3Selection.select.mockReturnValue(g);
93
+
94
+ w.instance().componentDidMount();
95
+ expect(g.on).toHaveBeenCalledWith('mousemove', expect.any(Function));
96
+ });
97
+ it('unsets mousemove listener on componentWillUnmount', function () {
98
+ var w = wrapper();
99
+ var g = {
100
+ on: jest.fn()
101
+ };
102
+
103
+ _d3Selection.select.mockReturnValue(g);
104
+
105
+ w.instance().componentWillUnmount();
106
+ expect(g.on).toHaveBeenCalledWith('mousemove', null);
107
+ });
108
+ });
109
+ describe('mouseMove function', function () {
110
+ var onMouseMove, w, gp;
111
+ beforeEach(function () {
112
+ onMouseMove = jest.fn();
113
+ gp = graphProps();
114
+ w = wrapper({
115
+ onMouseMove: onMouseMove,
116
+ graphProps: gp
117
+ });
118
+
119
+ _d3Selection.mouse.mockReturnValue([0, 0]);
120
+
121
+ var g = {
122
+ _groups: [[[0, 0]]]
123
+ };
124
+ w.instance().mouseMove(g);
125
+ });
126
+ it('calls mouse', function () {
127
+ expect(_d3Selection.mouse).toHaveBeenCalledWith([0, 0]);
128
+ });
129
+ it('calls, scale.x.invert', function () {
130
+ expect(gp.scale.x.invert).toHaveBeenCalledWith(0);
131
+ });
132
+ it('calls, scale.y.invert', function () {
133
+ expect(gp.scale.y.invert).toHaveBeenCalledWith(0);
134
+ });
135
+ it('calls, snap.x', function () {
136
+ expect(gp.snap.x).toHaveBeenCalledWith(0);
137
+ });
138
+ it('calls, snap.y', function () {
139
+ expect(gp.snap.y).toHaveBeenCalledWith(0);
140
+ });
141
+ it('calls handler', function () {
142
+ expect(onMouseMove).toHaveBeenCalledWith({
143
+ x: 0,
144
+ y: 0
145
+ });
146
+ });
147
+ });
148
+ });
149
+ });
150
+ });
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/root.test.jsx"],"names":["scaleMock","fn","jest","n","invert","graphProps","scale","x","y","snap","domain","min","max","step","range","size","width","height","wrapper","props","classes","disableLifecycleMethods","mock","select","mouse","describe","it","w","expect","toMatchSnapshot","g","on","mockReturnValue","instance","componentDidMount","toHaveBeenCalledWith","any","Function","componentWillUnmount","onMouseMove","gp","beforeEach","_groups","mouseMove"],"mappings":";;;;;;AAAA;;AACA;;AACA;;AACA;;;;;;AAEA,IAAMA,SAAS,GAAG,SAAZA,SAAY,GAAM;AACtB,MAAMC,EAAE,GAAGC,IAAI,CAACD,EAAL,CAAQ,UAACE,CAAD;AAAA,WAAOA,CAAP;AAAA,GAAR,CAAX;AACAF,EAAAA,EAAE,CAACG,MAAH,GAAYF,IAAI,CAACD,EAAL,CAAQ,UAACE,CAAD;AAAA,WAAOA,CAAP;AAAA,GAAR,CAAZ;AACA,SAAOF,EAAP;AACD,CAJD;;AAMA,IAAMI,UAAU,GAAG,SAAbA,UAAa;AAAA,SAAO;AACxBC,IAAAA,KAAK,EAAE;AACLC,MAAAA,CAAC,EAAEP,SAAS,EADP;AAELQ,MAAAA,CAAC,EAAER,SAAS;AAFP,KADiB;AAKxBS,IAAAA,IAAI,EAAE;AACJF,MAAAA,CAAC,EAAEL,IAAI,CAACD,EAAL,CAAQ,UAACE,CAAD;AAAA,eAAOA,CAAP;AAAA,OAAR,CADC;AAEJK,MAAAA,CAAC,EAAEN,IAAI,CAACD,EAAL,CAAQ,UAACE,CAAD;AAAA,eAAOA,CAAP;AAAA,OAAR;AAFC,KALkB;AASxBO,IAAAA,MAAM,EAAE;AACNC,MAAAA,GAAG,EAAE,CADC;AAENC,MAAAA,GAAG,EAAE,CAFC;AAGNC,MAAAA,IAAI,EAAE;AAHA,KATgB;AAcxBC,IAAAA,KAAK,EAAE;AACLH,MAAAA,GAAG,EAAE,CADA;AAELC,MAAAA,GAAG,EAAE,CAFA;AAGLC,MAAAA,IAAI,EAAE;AAHD,KAdiB;AAmBxBE,IAAAA,IAAI,EAAE;AACJC,MAAAA,KAAK,EAAE,GADH;AAEJC,MAAAA,MAAM,EAAE;AAFJ;AAnBkB,GAAP;AAAA,CAAnB;;AAyBA,IAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,KAAD,EAAW;AACzBA,EAAAA,KAAK;AACHC,IAAAA,OAAO,EAAE,EADN;AAEHf,IAAAA,UAAU,EAAEA,UAAU;AAFnB,KAGAc,KAHA,CAAL;AAMA,SAAO,mCAAQ,gCAAC,UAAD,EAAUA,KAAV,OAAR,EAAoC;AAAEE,IAAAA,uBAAuB,EAAE;AAA3B,GAApC,CAAP;AACD,CARD;;AAUAnB,IAAI,CAACoB,IAAL,CAAU,cAAV,EAA0B;AAAA,SAAO;AAC/BC,IAAAA,MAAM,EAAErB,IAAI,CAACD,EAAL,EADuB;AAE/BuB,IAAAA,KAAK,EAAEtB,IAAI,CAACD,EAAL;AAFwB,GAAP;AAAA,CAA1B;AAKAwB,QAAQ,CAAC,MAAD,EAAS,YAAM;AACrBA,EAAAA,QAAQ,CAAC,UAAD,EAAa,YAAM;AACzBC,IAAAA,EAAE,CAAC,SAAD,EAAY,YAAM;AAClB,UAAMC,CAAC,GAAGT,OAAO,EAAjB;AACAU,MAAAA,MAAM,CAACD,CAAD,CAAN,CAAUE,eAAV;AACD,KAHC,CAAF;AAID,GALO,CAAR;AAOAJ,EAAAA,QAAQ,CAAC,OAAD,EAAU,YAAM;AACtBA,IAAAA,QAAQ,CAAC,WAAD,EAAc,YAAM;AAC1BA,MAAAA,QAAQ,CAAC,eAAD,EAAkB,YAAM;AAC9BC,QAAAA,EAAE,CAAC,8CAAD,EAAiD,YAAM;AACvD,cAAMC,CAAC,GAAGT,OAAO,EAAjB;AACA,cAAMY,CAAC,GAAG;AACRC,YAAAA,EAAE,EAAE7B,IAAI,CAACD,EAAL;AADI,WAAV;;AAGAsB,8BAAOS,eAAP,CAAuBF,CAAvB;;AACAH,UAAAA,CAAC,CAACM,QAAF,GAAaC,iBAAb;AACAN,UAAAA,MAAM,CAACE,CAAC,CAACC,EAAH,CAAN,CAAaI,oBAAb,CAAkC,WAAlC,EAA+CP,MAAM,CAACQ,GAAP,CAAWC,QAAX,CAA/C;AACD,SARC,CAAF;AASAX,QAAAA,EAAE,CAAC,mDAAD,EAAsD,YAAM;AAC5D,cAAMC,CAAC,GAAGT,OAAO,EAAjB;AACA,cAAMY,CAAC,GAAG;AACRC,YAAAA,EAAE,EAAE7B,IAAI,CAACD,EAAL;AADI,WAAV;;AAGAsB,8BAAOS,eAAP,CAAuBF,CAAvB;;AACAH,UAAAA,CAAC,CAACM,QAAF,GAAaK,oBAAb;AACAV,UAAAA,MAAM,CAACE,CAAC,CAACC,EAAH,CAAN,CAAaI,oBAAb,CAAkC,WAAlC,EAA+C,IAA/C;AACD,SARC,CAAF;AASD,OAnBO,CAAR;AAqBAV,MAAAA,QAAQ,CAAC,oBAAD,EAAuB,YAAM;AACnC,YAAIc,WAAJ,EAAiBZ,CAAjB,EAAoBa,EAApB;AACAC,QAAAA,UAAU,CAAC,YAAM;AACfF,UAAAA,WAAW,GAAGrC,IAAI,CAACD,EAAL,EAAd;AACAuC,UAAAA,EAAE,GAAGnC,UAAU,EAAf;AACAsB,UAAAA,CAAC,GAAGT,OAAO,CAAC;AACVqB,YAAAA,WAAW,EAAXA,WADU;AAEVlC,YAAAA,UAAU,EAAEmC;AAFF,WAAD,CAAX;;AAIAhB,6BAAMQ,eAAN,CAAsB,CAAC,CAAD,EAAI,CAAJ,CAAtB;;AACA,cAAMF,CAAC,GAAG;AAAEY,YAAAA,OAAO,EAAE,CAAC,CAAC,CAAC,CAAD,EAAI,CAAJ,CAAD,CAAD;AAAX,WAAV;AACAf,UAAAA,CAAC,CAACM,QAAF,GAAaU,SAAb,CAAuBb,CAAvB;AACD,SAVS,CAAV;AAWAJ,QAAAA,EAAE,CAAC,aAAD,EAAgB,YAAM;AACtBE,UAAAA,MAAM,CAACJ,kBAAD,CAAN,CAAcW,oBAAd,CAAmC,CAAC,CAAD,EAAI,CAAJ,CAAnC;AACD,SAFC,CAAF;AAGAT,QAAAA,EAAE,CAAC,uBAAD,EAA0B,YAAM;AAChCE,UAAAA,MAAM,CAACY,EAAE,CAAClC,KAAH,CAASC,CAAT,CAAWH,MAAZ,CAAN,CAA0B+B,oBAA1B,CAA+C,CAA/C;AACD,SAFC,CAAF;AAGAT,QAAAA,EAAE,CAAC,uBAAD,EAA0B,YAAM;AAChCE,UAAAA,MAAM,CAACY,EAAE,CAAClC,KAAH,CAASE,CAAT,CAAWJ,MAAZ,CAAN,CAA0B+B,oBAA1B,CAA+C,CAA/C;AACD,SAFC,CAAF;AAGAT,QAAAA,EAAE,CAAC,eAAD,EAAkB,YAAM;AACxBE,UAAAA,MAAM,CAACY,EAAE,CAAC/B,IAAH,CAAQF,CAAT,CAAN,CAAkB4B,oBAAlB,CAAuC,CAAvC;AACD,SAFC,CAAF;AAGAT,QAAAA,EAAE,CAAC,eAAD,EAAkB,YAAM;AACxBE,UAAAA,MAAM,CAACY,EAAE,CAAC/B,IAAH,CAAQD,CAAT,CAAN,CAAkB2B,oBAAlB,CAAuC,CAAvC;AACD,SAFC,CAAF;AAIAT,QAAAA,EAAE,CAAC,eAAD,EAAkB,YAAM;AACxBE,UAAAA,MAAM,CAACW,WAAD,CAAN,CAAoBJ,oBAApB,CAAyC;AAAE5B,YAAAA,CAAC,EAAE,CAAL;AAAQC,YAAAA,CAAC,EAAE;AAAX,WAAzC;AACD,SAFC,CAAF;AAGD,OAhCO,CAAR;AAiCD,KAvDO,CAAR;AAwDD,GAzDO,CAAR;AA0DD,CAlEO,CAAR","sourcesContent":["import { shallow } from 'enzyme';\nimport React from 'react';\nimport { Root } from '../root';\nimport { select, mouse } from 'd3-selection';\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\nconst wrapper = (props) => {\n  props = {\n    classes: {},\n    graphProps: graphProps(),\n    ...props,\n  };\n\n  return shallow(<Root {...props}>hi</Root>, { disableLifecycleMethods: true });\n};\n\njest.mock('d3-selection', () => ({\n  select: jest.fn(),\n  mouse: jest.fn(),\n}));\n\ndescribe('root', () => {\n  describe('snapshot', () => {\n    it('matches', () => {\n      const w = wrapper();\n      expect(w).toMatchSnapshot();\n    });\n  });\n\n  describe('logic', () => {\n    describe('mousemove', () => {\n      describe('mount/unmount', () => {\n        it('adds mousemove listener on compenentDidMount', () => {\n          const w = wrapper();\n          const g = {\n            on: jest.fn(),\n          };\n          select.mockReturnValue(g);\n          w.instance().componentDidMount();\n          expect(g.on).toHaveBeenCalledWith('mousemove', expect.any(Function));\n        });\n        it('unsets mousemove listener on componentWillUnmount', () => {\n          const w = wrapper();\n          const g = {\n            on: jest.fn(),\n          };\n          select.mockReturnValue(g);\n          w.instance().componentWillUnmount();\n          expect(g.on).toHaveBeenCalledWith('mousemove', null);\n        });\n      });\n\n      describe('mouseMove function', () => {\n        let onMouseMove, w, gp;\n        beforeEach(() => {\n          onMouseMove = jest.fn();\n          gp = graphProps();\n          w = wrapper({\n            onMouseMove,\n            graphProps: gp,\n          });\n          mouse.mockReturnValue([0, 0]);\n          const g = { _groups: [[[0, 0]]] };\n          w.instance().mouseMove(g);\n        });\n        it('calls mouse', () => {\n          expect(mouse).toHaveBeenCalledWith([0, 0]);\n        });\n        it('calls, scale.x.invert', () => {\n          expect(gp.scale.x.invert).toHaveBeenCalledWith(0);\n        });\n        it('calls, scale.y.invert', () => {\n          expect(gp.scale.y.invert).toHaveBeenCalledWith(0);\n        });\n        it('calls, snap.x', () => {\n          expect(gp.snap.x).toHaveBeenCalledWith(0);\n        });\n        it('calls, snap.y', () => {\n          expect(gp.snap.y).toHaveBeenCalledWith(0);\n        });\n\n        it('calls handler', () => {\n          expect(onMouseMove).toHaveBeenCalledWith({ x: 0, y: 0 });\n        });\n      });\n    });\n  });\n});\n"]}
@@ -0,0 +1,183 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
6
+
7
+ var _trig = require("../trig");
8
+
9
+ var _utils = require("../utils");
10
+
11
+ var _debug = _interopRequireDefault(require("debug"));
12
+
13
+ var _templateObject, _templateObject2, _templateObject3;
14
+
15
+ var log = (0, _debug["default"])('pie-lib:plot:trig:test');
16
+
17
+ var vs = function vs(v) {
18
+ if (!v) {
19
+ return '';
20
+ }
21
+
22
+ if (Number.isFinite(v.x) && Number.isFinite(v.y)) {
23
+ return "[".concat(v.x, ",").concat(v.y, "]");
24
+ }
25
+
26
+ return JSON.stringify(v);
27
+ };
28
+
29
+ var p = function p(strings) {
30
+ for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
31
+ values[_key - 1] = arguments[_key];
32
+ }
33
+
34
+ return strings.reduce(function (acc, s, index) {
35
+ return "".concat(acc).concat(s).concat(vs(values[index]));
36
+ }, '');
37
+ };
38
+
39
+ describe('trig', function () {
40
+ describe('angle', function () {
41
+ var assertAngle = function assertAngle(a, b, expected) {
42
+ it(p(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["", ", ", " => ", ""])), a, b, (0, _trig.toDegrees)(expected)), function () {
43
+ var result = (0, _trig.angle)(a, b);
44
+ expect(result).toBeCloseTo(expected);
45
+ });
46
+ };
47
+
48
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _trig.toRadians)(45));
49
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(0, 1), (0, _trig.toRadians)(90));
50
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _trig.toRadians)(135));
51
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 0), (0, _trig.toRadians)(180));
52
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, -1), (0, _trig.toRadians)(225));
53
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(0, -1), (0, _trig.toRadians)(270));
54
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(1, -1), (0, _trig.toRadians)(315));
55
+ assertAngle((0, _utils.xy)(1, 1), (0, _utils.xy)(0, 0), (0, _trig.toRadians)(225));
56
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _trig.toRadians)(45));
57
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 1), (0, _trig.toRadians)(26.565));
58
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(3, 1), (0, _trig.toRadians)(18.434));
59
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(4, 1), (0, _trig.toRadians)(14.036));
60
+ assertAngle((0, _utils.xy)(0, 0), (0, _utils.xy)(5, 1), (0, _trig.toRadians)(11.309));
61
+ });
62
+ describe('acuteXAngle', 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.acuteXAngle)(input);
66
+ log("result: ".concat((0, _trig.toDegrees)(result)));
67
+ expect(result).toBeCloseTo(expected);
68
+ });
69
+ };
70
+
71
+ assertAcute((0, _trig.toRadians)(45), (0, _trig.toRadians)(45));
72
+ assertAcute((0, _trig.toRadians)(100), (0, _trig.toRadians)(80));
73
+ assertAcute((0, _trig.toRadians)(190), (0, _trig.toRadians)(10));
74
+ assertAcute((0, _trig.toRadians)(350), (0, _trig.toRadians)(10));
75
+ });
76
+ describe('acuteYAngle', function () {
77
+ var assertAcute = function assertAcute(input, expected) {
78
+ it("".concat((0, _trig.toDegrees)(input), " => ").concat((0, _trig.toDegrees)(expected)), function () {
79
+ var result = (0, _trig.acuteYAngle)(input);
80
+ log("result: ".concat((0, _trig.toDegrees)(result)));
81
+ expect(result).toBeCloseTo(expected);
82
+ });
83
+ };
84
+
85
+ assertAcute((0, _trig.toRadians)(45), (0, _trig.toRadians)(45));
86
+ assertAcute((0, _trig.toRadians)(100), (0, _trig.toRadians)(10));
87
+ assertAcute((0, _trig.toRadians)(190), (0, _trig.toRadians)(80));
88
+ assertAcute((0, _trig.toRadians)(350), (0, _trig.toRadians)(80));
89
+ });
90
+ describe('edges', function () {
91
+ var assertEdges = function assertEdges(domain, range) {
92
+ return function (from, to, expected) {
93
+ it(p(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["", ", ", " + ", " -> ", " => ", "", ""])), domain, range, from, to, expected[0], expected[1]), function () {
94
+ var result = (0, _trig.edges)(domain, range)(from, to);
95
+ expect(result[0].x).toBeCloseTo(expected[0].x);
96
+ expect(result[0].y).toBeCloseTo(expected[0].y);
97
+ expect(result[1].x).toBeCloseTo(expected[1].x);
98
+ expect(result[1].y).toBeCloseTo(expected[1].y);
99
+ });
100
+ };
101
+ };
102
+
103
+ var one = assertEdges({
104
+ min: -4,
105
+ max: 4
106
+ }, {
107
+ min: -4,
108
+ max: 4
109
+ });
110
+ one((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), [(0, _utils.xy)(4, 4), (0, _utils.xy)(-4, -4)]);
111
+ one((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 1), [(0, _utils.xy)(4, 2), (0, _utils.xy)(-4, -2)]);
112
+ one((0, _utils.xy)(1, 1), (0, _utils.xy)(2, 2), [(0, _utils.xy)(4, 4), (0, _utils.xy)(-4, -4)]);
113
+ one((0, _utils.xy)(1, 0), (0, _utils.xy)(2, 0), [(0, _utils.xy)(4, 0), (0, _utils.xy)(-4, 0)]);
114
+ one((0, _utils.xy)(1, 0), (0, _utils.xy)(-2, 0), [(0, _utils.xy)(-4, 0), (0, _utils.xy)(4, 0)]);
115
+ /**
116
+ * 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}
117
+ */
118
+
119
+ var lineIssue = assertEdges({
120
+ min: -5,
121
+ max: 5
122
+ }, {
123
+ min: -5,
124
+ max: 5
125
+ });
126
+ lineIssue((0, _utils.xy)(-5, -0), (0, _utils.xy)(-5, 2), [(0, _utils.xy)(-5, 5), (0, _utils.xy)(-5, -5)]);
127
+ });
128
+ describe('diffEdge', function () {
129
+ var assertDiffEdge = function assertDiffEdge(bounds, from, to, expected) {
130
+ it(p(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["<", "> ", " -> ", " => ", ""])), bounds, from, to, expected), function () {
131
+ var result = (0, _trig.diffEdge)(bounds, from, to);
132
+ expect(result.x).toBeCloseTo(expected.x);
133
+ expect(result.y).toBeCloseTo(expected.y);
134
+ });
135
+ };
136
+
137
+ var twoTwo = assertDiffEdge.bind(null, (0, _utils.xy)(2, 2));
138
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _utils.xy)(2, 2));
139
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 2), (0, _utils.xy)(1, 2));
140
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 2), (0, _utils.xy)(2, 2));
141
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 2), (0, _utils.xy)(2, 2));
142
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _utils.xy)(-2, 2));
143
+ twoTwo((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-2, -2));
144
+ var fourFour = assertDiffEdge.bind(null, (0, _utils.xy)(4, 4));
145
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 1), (0, _utils.xy)(4, 4));
146
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(1, 2), (0, _utils.xy)(2, 4));
147
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(2, 1), (0, _utils.xy)(4, 2));
148
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _utils.xy)(-4, 4));
149
+ fourFour((0, _utils.xy)(0, 0), (0, _utils.xy)(-1, 1), (0, _utils.xy)(-4, 4));
150
+ assertDiffEdge((0, _utils.xy)(-4, -4), (0, _utils.xy)(0, 0), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-4, -4));
151
+ assertDiffEdge((0, _utils.xy)(4, 4), (0, _utils.xy)(1, 1), (0, _utils.xy)(2, 2), (0, _utils.xy)(4, 4));
152
+ assertDiffEdge((0, _utils.xy)(4, 4), (0, _utils.xy)(2, 2), (0, _utils.xy)(3, 3), (0, _utils.xy)(4, 4));
153
+ assertDiffEdge((0, _utils.xy)(-4, -4), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-2, -2), (0, _utils.xy)(-4, -4));
154
+ assertDiffEdge((0, _utils.xy)(-4, 4), (0, _utils.xy)(-1, -1), (0, _utils.xy)(-2, 0), (0, _utils.xy)(-4, 2));
155
+ var lineIssue = assertDiffEdge.bind(null, (0, _utils.xy)(-5, -5));
156
+ lineIssue((0, _utils.xy)(-5, 2), (0, _utils.xy)(-5, 0), (0, _utils.xy)(-5, -5)); //Top Right
157
+
158
+ assertDiffEdge((0, _utils.xy)(5, 5), (0, _utils.xy)(0, 5), (0, _utils.xy)(2, 5), (0, _utils.xy)(5, 5));
159
+ assertDiffEdge((0, _utils.xy)(5, 5), (0, _utils.xy)(5, 0), (0, _utils.xy)(5, 1), (0, _utils.xy)(5, 5)); // //Bottom Right
160
+
161
+ assertDiffEdge((0, _utils.xy)(5, -5), (0, _utils.xy)(5, 0), (0, _utils.xy)(5, -0.1), (0, _utils.xy)(5, -5));
162
+ assertDiffEdge((0, _utils.xy)(5, -5), (0, _utils.xy)(0, -5), (0, _utils.xy)(1, -5), (0, _utils.xy)(5, -5)); //Top Left
163
+
164
+ assertDiffEdge((0, _utils.xy)(-5, 5), (0, _utils.xy)(-5, 0), (0, _utils.xy)(-5, 0.1), (0, _utils.xy)(-5, 5));
165
+ assertDiffEdge((0, _utils.xy)(-5, 5), (0, _utils.xy)(0, 5), (0, _utils.xy)(-1, 5), (0, _utils.xy)(-5, 5)); //Bottom Left
166
+
167
+ assertDiffEdge((0, _utils.xy)(-5, -5), (0, _utils.xy)(-5, 0), (0, _utils.xy)(-5, -0.1), (0, _utils.xy)(-5, -5));
168
+ assertDiffEdge((0, _utils.xy)(-5, -5), (0, _utils.xy)(0, -5), (0, _utils.xy)(-1, -5), (0, _utils.xy)(-5, -5));
169
+ });
170
+ describe('getOpposingSide', function () {
171
+ var assertOpposingSide = function assertOpposingSide(hyp, angle, expected) {
172
+ it("".concat(hyp, ", ").concat(angle, " = ").concat(expected), function () {
173
+ var radians = (0, _trig.toRadians)(angle);
174
+ var result = (0, _trig.getOpposingSide)(hyp, radians);
175
+ expect(result).toBeCloseTo(expected);
176
+ });
177
+ };
178
+
179
+ assertOpposingSide(1, 45, 0.707);
180
+ assertOpposingSide(1.25, 45, 0.88);
181
+ });
182
+ });
183
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/trig.test.js"],"names":["log","vs","v","Number","isFinite","x","y","JSON","stringify","p","strings","values","reduce","acc","s","index","describe","assertAngle","a","b","expected","it","result","expect","toBeCloseTo","assertAcute","input","assertEdges","domain","range","from","to","one","min","max","lineIssue","assertDiffEdge","bounds","twoTwo","bind","fourFour","assertOpposingSide","hyp","angle","radians"],"mappings":"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","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"]}