@pie-lib/plot 2.9.0-beta.0 → 2.9.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.
package/lib/trig.js DELETED
@@ -1,196 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.toRadians = exports.toDegrees = exports.hypotenuse = exports.getOpposingSide = exports.edges = exports.diffEdge = exports.angle = exports.acuteYAngle = exports.acuteXAngle = void 0;
9
-
10
- var _utils = require("./utils");
11
-
12
- var _pointGeometry = _interopRequireDefault(require("@mapbox/point-geometry"));
13
-
14
- var _debug = _interopRequireDefault(require("debug"));
15
-
16
- var log = (0, _debug["default"])('pie-lib:plot:trig');
17
-
18
- var toDegrees = function toDegrees(radians) {
19
- return radians * (180 / Math.PI);
20
- };
21
-
22
- exports.toDegrees = toDegrees;
23
-
24
- var toRadians = function toRadians(degrees) {
25
- return degrees * (Math.PI / 180);
26
- };
27
- /**
28
- * return angle in radians between 2 points using counting degrees counter clockwise
29
- *
30
- * 0,0 + 1,1 = 45 in radians
31
- * 1,1 + 0,0 = 45?
32
- * @param {Point} a
33
- * @param {Point} b
34
- */
35
-
36
-
37
- exports.toRadians = toRadians;
38
-
39
- var angle = function angle(a, b) {
40
- var vd = b.y - a.y;
41
- var hd = b.x - a.x;
42
- log(a, b, 'vd: ', vd, 'hd: ', hd);
43
- var radians = Math.atan2(vd, hd);
44
- return radians < 0 ? radians + Math.PI * 2 : radians;
45
- };
46
-
47
- exports.angle = angle;
48
- var NINETY = Math.PI / 2;
49
- var ONE_EIGHTY = Math.PI;
50
- var TWO_SEVENTY = ONE_EIGHTY + NINETY;
51
-
52
- var acuteXAngle = function acuteXAngle(a) {
53
- log(toDegrees(a));
54
-
55
- if (a < NINETY) {
56
- return a;
57
- }
58
-
59
- if (a < ONE_EIGHTY) {
60
- return Math.abs(ONE_EIGHTY - a);
61
- }
62
-
63
- if (a < TWO_SEVENTY) {
64
- return Math.abs(ONE_EIGHTY - a);
65
- }
66
-
67
- return Math.abs(Math.PI * 2 - a);
68
- };
69
-
70
- exports.acuteXAngle = acuteXAngle;
71
-
72
- var acuteYAngle = function acuteYAngle(a) {
73
- return NINETY - acuteXAngle(a);
74
- };
75
-
76
- exports.acuteYAngle = acuteYAngle;
77
-
78
- var hypotenuse = function hypotenuse(a, alpha) {
79
- var out = Math.abs(a / Math.sin(alpha));
80
- return out;
81
- };
82
- /**
83
- * return 2 edge points for a,b within domain + range.
84
- * - one edge is from following a -> b to the bounds
85
- * - one edge is from following b -> a to the bounds
86
- * @param {{min: number, max: number}} domain
87
- * @param {{min: number, max: number}} range
88
- * @param {{x: number, y: number}} a
89
- * @param {{x: number, y: number}} b
90
- * @returns [{x: number, y: number}, {x: number, y: number}]
91
- */
92
-
93
-
94
- exports.hypotenuse = hypotenuse;
95
-
96
- var edges = function edges(domain, range) {
97
- return function (a, b) {
98
- // const xDest =
99
- var destX = a.x < b.x ? domain.max : domain.min;
100
- var destY = a.y < b.y ? range.max : range.min;
101
- var aToB = diffEdge((0, _utils.xy)(destX, destY), a, b);
102
- var dX = b.x < a.x ? domain.max : domain.min;
103
- var dY = b.y < a.y ? range.max : range.min;
104
- var bToA = diffEdge((0, _utils.xy)(dX, dY), b, a);
105
- return [aToB, bToA];
106
- };
107
- };
108
- /** get length of side A of a triangle from H and angle Alpha */
109
-
110
-
111
- exports.edges = edges;
112
-
113
- var getOpposingSide = function getOpposingSide(hyp, angle) {
114
- log('[getOpposingSide] hyp: ', hyp, 'angle:', angle);
115
- return Math.abs(hyp * Math.sin(angle));
116
- };
117
-
118
- exports.getOpposingSide = getOpposingSide;
119
-
120
- var getShortestSide = function getShortestSide(xh, yh) {
121
- if (Number.isFinite(xh) && Number.isFinite(yh)) {
122
- if (xh === 0 && yh > 0) {
123
- return 'y';
124
- }
125
-
126
- if (yh === 0 && xh > 0) {
127
- return 'x';
128
- }
129
-
130
- return xh < yh ? 'x' : 'y';
131
- }
132
-
133
- if (isNaN(xh) && !isNaN(yh)) {
134
- return 'y';
135
- }
136
-
137
- if (!isNaN(xh) && isNaN(yh)) {
138
- return 'x';
139
- }
140
-
141
- if (xh === Infinity) {
142
- return 'y';
143
- }
144
-
145
- if (yh === Infinity) {
146
- return 'x';
147
- } // eslint-disable-next-line no-console
148
-
149
-
150
- console.warn('hypotenuse - which is shorter? x:', xh, 'y:', yh);
151
- };
152
- /**
153
- * return the difference between bounds and a as a Point
154
- * @param {*} bounds
155
- */
156
-
157
-
158
- var diffEdge = function diffEdge(bounds, a, b) {
159
- var l = log.enabled ? log.bind(log, "diffEdge: [".concat(a.x, ",").concat(a.y, " -> ").concat(b.x, ",").concat(b.y, "]")) : function () {};
160
- var xRadians = angle(a, b);
161
- l('x angle', toDegrees(xRadians));
162
- var yRadians = Math.abs(xRadians - toRadians(90));
163
- l('y angle', toDegrees(yRadians));
164
- var xSide = Math.abs(a.x - bounds.x);
165
- /**
166
- * Draw 2 triangles:
167
- * 1 with a horizontal line from a to the graph x edge
168
- * 1 with a vertical line from a to the graph y edge
169
- * Calculate the hypotenuse for both, whichever is shorter
170
- * indicates that we should use that triangle to get the edge point.
171
- */
172
-
173
- var xH = hypotenuse(xSide, yRadians);
174
- var ySide = Math.abs(a.y - bounds.y);
175
- var yH = hypotenuse(ySide, xRadians);
176
- l('x: side', xSide, 'h:', xH);
177
- l('y: side', ySide, 'h:', yH);
178
- var side = getShortestSide(xH, yH);
179
-
180
- if (side !== 'x' && side !== 'y') {
181
- throw new Error('Cant decide which hypotenuse to use');
182
- }
183
-
184
- var point = side === 'x' ? new _pointGeometry["default"](xSide, getOpposingSide(xH, xRadians)) : new _pointGeometry["default"](getOpposingSide(yH, yRadians), ySide);
185
- l('point:', point);
186
- var multiplier = new _pointGeometry["default"](b.x < a.x ? -1 : 1, b.y < a.y ? -1 : 1);
187
- l('multiplier:', multiplier);
188
- var out = point.multByPoint(multiplier);
189
- l('out:', out);
190
- var normalized = out.add(new _pointGeometry["default"](a.x, a.y));
191
- l('normalized:', normalized);
192
- return normalized;
193
- };
194
-
195
- exports.diffEdge = diffEdge;
196
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/trig.js"],"names":["log","toDegrees","radians","Math","PI","toRadians","degrees","angle","a","b","vd","y","hd","x","atan2","NINETY","ONE_EIGHTY","TWO_SEVENTY","acuteXAngle","abs","acuteYAngle","hypotenuse","alpha","out","sin","edges","domain","range","destX","max","min","destY","aToB","diffEdge","dX","dY","bToA","getOpposingSide","hyp","getShortestSide","xh","yh","Number","isFinite","isNaN","Infinity","console","warn","bounds","l","enabled","bind","xRadians","yRadians","xSide","xH","ySide","yH","side","Error","point","Point","multiplier","multByPoint","normalized","add"],"mappings":"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","sourcesContent":["import { xy } from './utils';\nimport Point from '@mapbox/point-geometry';\nimport debug from 'debug';\nconst log = debug('pie-lib:plot:trig');\n\nexport const toDegrees = (radians) => radians * (180 / Math.PI);\nexport const toRadians = (degrees) => degrees * (Math.PI / 180);\n/**\n * return angle in radians between 2 points using counting degrees counter clockwise\n *\n * 0,0 + 1,1 = 45 in radians\n * 1,1 + 0,0 = 45?\n * @param {Point} a\n * @param {Point} b\n */\nexport const angle = (a, b) => {\n  const vd = b.y - a.y;\n  const hd = b.x - a.x;\n  log(a, b, 'vd: ', vd, 'hd: ', hd);\n  const radians = Math.atan2(vd, hd);\n  return radians < 0 ? radians + Math.PI * 2 : radians;\n};\n\nconst NINETY = Math.PI / 2;\nconst ONE_EIGHTY = Math.PI;\nconst TWO_SEVENTY = ONE_EIGHTY + NINETY;\n\nexport const acuteXAngle = (a) => {\n  log(toDegrees(a));\n\n  if (a < NINETY) {\n    return a;\n  }\n\n  if (a < ONE_EIGHTY) {\n    return Math.abs(ONE_EIGHTY - a);\n  }\n\n  if (a < TWO_SEVENTY) {\n    return Math.abs(ONE_EIGHTY - a);\n  }\n\n  return Math.abs(Math.PI * 2 - a);\n};\n\nexport const acuteYAngle = (a) => NINETY - acuteXAngle(a);\n\nexport const hypotenuse = (a, alpha) => {\n  const out = Math.abs(a / Math.sin(alpha));\n\n  return out;\n};\n\n/**\n * return 2 edge points for a,b within domain + range.\n * - one edge is from following a -> b to the bounds\n * - one edge is from following b -> a to the bounds\n * @param {{min: number, max: number}} domain\n * @param {{min: number, max: number}} range\n * @param {{x: number, y: number}} a\n * @param {{x: number, y: number}} b\n * @returns [{x: number, y: number}, {x: number, y: number}]\n */\nexport const edges = (domain, range) => (a, b) => {\n  // const xDest =\n  const destX = a.x < b.x ? domain.max : domain.min;\n  const destY = a.y < b.y ? range.max : range.min;\n  const aToB = diffEdge(xy(destX, destY), a, b);\n\n  const dX = b.x < a.x ? domain.max : domain.min;\n  const dY = b.y < a.y ? range.max : range.min;\n  const bToA = diffEdge(xy(dX, dY), b, a);\n  return [aToB, bToA];\n};\n\n/** get length of side A of a triangle from H and angle Alpha */\nexport const getOpposingSide = (hyp, angle) => {\n  log('[getOpposingSide] hyp: ', hyp, 'angle:', angle);\n  return Math.abs(hyp * Math.sin(angle));\n};\n\nconst getShortestSide = (xh, yh) => {\n  if (Number.isFinite(xh) && Number.isFinite(yh)) {\n    if (xh === 0 && yh > 0) {\n      return 'y';\n    }\n    if (yh === 0 && xh > 0) {\n      return 'x';\n    }\n    return xh < yh ? 'x' : 'y';\n  }\n  if (isNaN(xh) && !isNaN(yh)) {\n    return 'y';\n  }\n  if (!isNaN(xh) && isNaN(yh)) {\n    return 'x';\n  }\n  if (xh === Infinity) {\n    return 'y';\n  }\n  if (yh === Infinity) {\n    return 'x';\n  }\n\n  // eslint-disable-next-line no-console\n  console.warn('hypotenuse - which is shorter? x:', xh, 'y:', yh);\n};\n/**\n * return the difference between bounds and a as a Point\n * @param {*} bounds\n */\nexport const diffEdge = (bounds, a, b) => {\n  let l = log.enabled ? log.bind(log, `diffEdge: [${a.x},${a.y} -> ${b.x},${b.y}]`) : () => {};\n  const xRadians = angle(a, b);\n  l('x angle', toDegrees(xRadians));\n  const yRadians = Math.abs(xRadians - toRadians(90));\n  l('y angle', toDegrees(yRadians));\n  const xSide = Math.abs(a.x - bounds.x);\n\n  /**\n   * Draw 2 triangles:\n   * 1 with a horizontal line from a to the graph x edge\n   * 1 with a vertical line from a to the graph y edge\n   * Calculate the hypotenuse for both, whichever is shorter\n   * indicates that we should use that triangle to get the edge point.\n   */\n  const xH = hypotenuse(xSide, yRadians);\n\n  const ySide = Math.abs(a.y - bounds.y);\n  const yH = hypotenuse(ySide, xRadians);\n\n  l('x: side', xSide, 'h:', xH);\n  l('y: side', ySide, 'h:', yH);\n  const side = getShortestSide(xH, yH);\n\n  if (side !== 'x' && side !== 'y') {\n    throw new Error('Cant decide which hypotenuse to use');\n  }\n  const point =\n    side === 'x' ? new Point(xSide, getOpposingSide(xH, xRadians)) : new Point(getOpposingSide(yH, yRadians), ySide);\n\n  l('point:', point);\n  const multiplier = new Point(b.x < a.x ? -1 : 1, b.y < a.y ? -1 : 1);\n  l('multiplier:', multiplier);\n  const out = point.multByPoint(multiplier);\n  l('out:', out);\n  const normalized = out.add(new Point(a.x, a.y));\n  l('normalized:', normalized);\n  return normalized;\n};\n"]}
package/lib/types.js DELETED
@@ -1,68 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.SnapType = exports.SizeType = exports.ScaleType = exports.RangeType = exports.PointType = exports.GraphPropsType = exports.DomainType = exports.ChildrenType = exports.BaseDomainRangeType = void 0;
9
-
10
- var _propTypes = _interopRequireDefault(require("prop-types"));
11
-
12
- var BaseDomainRangeType = {
13
- min: _propTypes["default"].number.isRequired,
14
- max: _propTypes["default"].number.isRequired,
15
- step: _propTypes["default"].number
16
- };
17
- exports.BaseDomainRangeType = BaseDomainRangeType;
18
-
19
- var DomainType = _propTypes["default"].shape(BaseDomainRangeType);
20
-
21
- exports.DomainType = DomainType;
22
-
23
- var RangeType = _propTypes["default"].shape(BaseDomainRangeType);
24
-
25
- exports.RangeType = RangeType;
26
-
27
- var SizeType = _propTypes["default"].shape({
28
- width: _propTypes["default"].number.isRequired,
29
- height: _propTypes["default"].number.isRequired
30
- });
31
-
32
- exports.SizeType = SizeType;
33
-
34
- var PointType = _propTypes["default"].shape({
35
- x: _propTypes["default"].number.isRequired,
36
- y: _propTypes["default"].number.isRequired
37
- });
38
-
39
- exports.PointType = PointType;
40
-
41
- var ChildrenType = _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired;
42
-
43
- exports.ChildrenType = ChildrenType;
44
-
45
- var ScaleType = _propTypes["default"].shape({
46
- x: _propTypes["default"].func.isRequired,
47
- y: _propTypes["default"].func.isRequired
48
- });
49
-
50
- exports.ScaleType = ScaleType;
51
-
52
- var SnapType = _propTypes["default"].shape({
53
- x: _propTypes["default"].func.isRequired,
54
- y: _propTypes["default"].func.isRequired
55
- });
56
-
57
- exports.SnapType = SnapType;
58
-
59
- var GraphPropsType = _propTypes["default"].shape({
60
- scale: ScaleType.isRequired,
61
- snap: SnapType.isRequired,
62
- domain: DomainType.isRequired,
63
- range: RangeType.isRequired,
64
- size: SizeType.isRequired
65
- });
66
-
67
- exports.GraphPropsType = GraphPropsType;
68
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90eXBlcy5qcyJdLCJuYW1lcyI6WyJCYXNlRG9tYWluUmFuZ2VUeXBlIiwibWluIiwiUHJvcFR5cGVzIiwibnVtYmVyIiwiaXNSZXF1aXJlZCIsIm1heCIsInN0ZXAiLCJEb21haW5UeXBlIiwic2hhcGUiLCJSYW5nZVR5cGUiLCJTaXplVHlwZSIsIndpZHRoIiwiaGVpZ2h0IiwiUG9pbnRUeXBlIiwieCIsInkiLCJDaGlsZHJlblR5cGUiLCJvbmVPZlR5cGUiLCJhcnJheU9mIiwibm9kZSIsIlNjYWxlVHlwZSIsImZ1bmMiLCJTbmFwVHlwZSIsIkdyYXBoUHJvcHNUeXBlIiwic2NhbGUiLCJzbmFwIiwiZG9tYWluIiwicmFuZ2UiLCJzaXplIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFTyxJQUFNQSxtQkFBbUIsR0FBRztBQUNqQ0MsRUFBQUEsR0FBRyxFQUFFQyxzQkFBVUMsTUFBVixDQUFpQkMsVUFEVztBQUVqQ0MsRUFBQUEsR0FBRyxFQUFFSCxzQkFBVUMsTUFBVixDQUFpQkMsVUFGVztBQUdqQ0UsRUFBQUEsSUFBSSxFQUFFSixzQkFBVUM7QUFIaUIsQ0FBNUI7OztBQU1BLElBQU1JLFVBQVUsR0FBR0wsc0JBQVVNLEtBQVYsQ0FBZ0JSLG1CQUFoQixDQUFuQjs7OztBQUVBLElBQU1TLFNBQVMsR0FBR1Asc0JBQVVNLEtBQVYsQ0FBZ0JSLG1CQUFoQixDQUFsQjs7OztBQUVBLElBQU1VLFFBQVEsR0FBR1Isc0JBQVVNLEtBQVYsQ0FBZ0I7QUFDdENHLEVBQUFBLEtBQUssRUFBRVQsc0JBQVVDLE1BQVYsQ0FBaUJDLFVBRGM7QUFFdENRLEVBQUFBLE1BQU0sRUFBRVYsc0JBQVVDLE1BQVYsQ0FBaUJDO0FBRmEsQ0FBaEIsQ0FBakI7Ozs7QUFLQSxJQUFNUyxTQUFTLEdBQUdYLHNCQUFVTSxLQUFWLENBQWdCO0FBQ3ZDTSxFQUFBQSxDQUFDLEVBQUVaLHNCQUFVQyxNQUFWLENBQWlCQyxVQURtQjtBQUV2Q1csRUFBQUEsQ0FBQyxFQUFFYixzQkFBVUMsTUFBVixDQUFpQkM7QUFGbUIsQ0FBaEIsQ0FBbEI7Ozs7QUFLQSxJQUFNWSxZQUFZLEdBQUdkLHNCQUFVZSxTQUFWLENBQW9CLENBQUNmLHNCQUFVZ0IsT0FBVixDQUFrQmhCLHNCQUFVaUIsSUFBNUIsQ0FBRCxFQUFvQ2pCLHNCQUFVaUIsSUFBOUMsQ0FBcEIsRUFBeUVmLFVBQTlGOzs7O0FBRUEsSUFBTWdCLFNBQVMsR0FBR2xCLHNCQUFVTSxLQUFWLENBQWdCO0FBQ3ZDTSxFQUFBQSxDQUFDLEVBQUVaLHNCQUFVbUIsSUFBVixDQUFlakIsVUFEcUI7QUFFdkNXLEVBQUFBLENBQUMsRUFBRWIsc0JBQVVtQixJQUFWLENBQWVqQjtBQUZxQixDQUFoQixDQUFsQjs7OztBQUtBLElBQU1rQixRQUFRLEdBQUdwQixzQkFBVU0sS0FBVixDQUFnQjtBQUN0Q00sRUFBQUEsQ0FBQyxFQUFFWixzQkFBVW1CLElBQVYsQ0FBZWpCLFVBRG9CO0FBRXRDVyxFQUFBQSxDQUFDLEVBQUViLHNCQUFVbUIsSUFBVixDQUFlakI7QUFGb0IsQ0FBaEIsQ0FBakI7Ozs7QUFLQSxJQUFNbUIsY0FBYyxHQUFHckIsc0JBQVVNLEtBQVYsQ0FBZ0I7QUFDNUNnQixFQUFBQSxLQUFLLEVBQUVKLFNBQVMsQ0FBQ2hCLFVBRDJCO0FBRTVDcUIsRUFBQUEsSUFBSSxFQUFFSCxRQUFRLENBQUNsQixVQUY2QjtBQUc1Q3NCLEVBQUFBLE1BQU0sRUFBRW5CLFVBQVUsQ0FBQ0gsVUFIeUI7QUFJNUN1QixFQUFBQSxLQUFLLEVBQUVsQixTQUFTLENBQUNMLFVBSjJCO0FBSzVDd0IsRUFBQUEsSUFBSSxFQUFFbEIsUUFBUSxDQUFDTjtBQUw2QixDQUFoQixDQUF2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBCYXNlRG9tYWluUmFuZ2VUeXBlID0ge1xuICBtaW46IFByb3BUeXBlcy5udW1iZXIuaXNSZXF1aXJlZCxcbiAgbWF4OiBQcm9wVHlwZXMubnVtYmVyLmlzUmVxdWlyZWQsXG4gIHN0ZXA6IFByb3BUeXBlcy5udW1iZXIsXG59O1xuXG5leHBvcnQgY29uc3QgRG9tYWluVHlwZSA9IFByb3BUeXBlcy5zaGFwZShCYXNlRG9tYWluUmFuZ2VUeXBlKTtcblxuZXhwb3J0IGNvbnN0IFJhbmdlVHlwZSA9IFByb3BUeXBlcy5zaGFwZShCYXNlRG9tYWluUmFuZ2VUeXBlKTtcblxuZXhwb3J0IGNvbnN0IFNpemVUeXBlID0gUHJvcFR5cGVzLnNoYXBlKHtcbiAgd2lkdGg6IFByb3BUeXBlcy5udW1iZXIuaXNSZXF1aXJlZCxcbiAgaGVpZ2h0OiBQcm9wVHlwZXMubnVtYmVyLmlzUmVxdWlyZWQsXG59KTtcblxuZXhwb3J0IGNvbnN0IFBvaW50VHlwZSA9IFByb3BUeXBlcy5zaGFwZSh7XG4gIHg6IFByb3BUeXBlcy5udW1iZXIuaXNSZXF1aXJlZCxcbiAgeTogUHJvcFR5cGVzLm51bWJlci5pc1JlcXVpcmVkLFxufSk7XG5cbmV4cG9ydCBjb25zdCBDaGlsZHJlblR5cGUgPSBQcm9wVHlwZXMub25lT2ZUeXBlKFtQcm9wVHlwZXMuYXJyYXlPZihQcm9wVHlwZXMubm9kZSksIFByb3BUeXBlcy5ub2RlXSkuaXNSZXF1aXJlZDtcblxuZXhwb3J0IGNvbnN0IFNjYWxlVHlwZSA9IFByb3BUeXBlcy5zaGFwZSh7XG4gIHg6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIHk6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG59KTtcblxuZXhwb3J0IGNvbnN0IFNuYXBUeXBlID0gUHJvcFR5cGVzLnNoYXBlKHtcbiAgeDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgeTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbn0pO1xuXG5leHBvcnQgY29uc3QgR3JhcGhQcm9wc1R5cGUgPSBQcm9wVHlwZXMuc2hhcGUoe1xuICBzY2FsZTogU2NhbGVUeXBlLmlzUmVxdWlyZWQsXG4gIHNuYXA6IFNuYXBUeXBlLmlzUmVxdWlyZWQsXG4gIGRvbWFpbjogRG9tYWluVHlwZS5pc1JlcXVpcmVkLFxuICByYW5nZTogUmFuZ2VUeXBlLmlzUmVxdWlyZWQsXG4gIHNpemU6IFNpemVUeXBlLmlzUmVxdWlyZWQsXG59KTtcbiJdfQ==
package/lib/utils.js DELETED
@@ -1,232 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.buildSizeArray = exports.bounds = exports.bandKey = exports.amountToIncreaseWidth = void 0;
9
- exports.buildTickModel = buildTickModel;
10
- exports.getDelta = exports.findLongestWord = exports.extractTextFromHTML = void 0;
11
- exports.getInterval = getInterval;
12
- exports.polygonToArea = exports.point = exports.lineToArea = exports.isEmptyString = exports.isEmptyObject = exports.isDomainRangeEqual = void 0;
13
- exports.snapTo = snapTo;
14
- exports.xy = exports.tickCount = void 0;
15
-
16
- var _invariant = _interopRequireDefault(require("invariant"));
17
-
18
- var _range = _interopRequireDefault(require("lodash/range"));
19
-
20
- var _pointGeometry = _interopRequireDefault(require("@mapbox/point-geometry"));
21
-
22
- var _head = _interopRequireDefault(require("lodash/head"));
23
-
24
- var _tail = _interopRequireDefault(require("lodash/tail"));
25
-
26
- var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
27
-
28
- var xy = function xy(x, y) {
29
- return {
30
- x: x,
31
- y: y
32
- };
33
- };
34
-
35
- exports.xy = xy;
36
-
37
- var buildSizeArray = function buildSizeArray(size, padding) {
38
- padding = Number.isFinite(padding) ? Math.max(padding, 0) : 0;
39
- (0, _invariant["default"])(padding < size, 'padding must be less than size');
40
- var half = Math.round(padding * 0.5);
41
- return [half, size - half];
42
- };
43
-
44
- exports.buildSizeArray = buildSizeArray;
45
-
46
- var tickCount = function tickCount(min, max, step) {
47
- (0, _invariant["default"])(min < max, 'min must be less than max');
48
- var size = Math.abs(min - max);
49
- return Math.round(size / step);
50
- };
51
-
52
- exports.tickCount = tickCount;
53
-
54
- function getInterval(domain, ticks) {
55
- var min = domain.min,
56
- max = domain.max;
57
- var major = ticks.major,
58
- minor = ticks.minor;
59
-
60
- if (min >= max) {
61
- throw new Error("min is > max: ".concat(min, " > ").concat(max));
62
- }
63
-
64
- var distance = max - min;
65
- var minorTicks = minor > 0 ? minor + 1 : 1;
66
- var normalizedMajor = major - 1;
67
-
68
- if (isNaN(normalizedMajor)) {
69
- throw new Error('Tick Frequency must be 2 or higher');
70
- }
71
-
72
- if (normalizedMajor <= 0) {
73
- throw new Error('Tick Frequency must be 2 or higher');
74
- }
75
-
76
- var divider = normalizedMajor * minorTicks;
77
- var raw = distance / divider;
78
- return parseFloat(Number(raw).toFixed(4));
79
- }
80
-
81
- var mkRange = function mkRange(min, max, interval) {
82
- var raw = (0, _range["default"])(min, max, interval);
83
- /* Fix the last step due to rounding errors */
84
-
85
- raw.splice(raw.length, 1, max);
86
- return raw;
87
- };
88
-
89
- function snapTo(min, max, interval, value) {
90
- if (value >= max) {
91
- return max;
92
- }
93
-
94
- if (value <= min) {
95
- return min;
96
- }
97
-
98
- var rng = mkRange(min, max, interval);
99
- rng = rng.filter(function (v) {
100
- return Math.abs(value - v) <= interval;
101
- });
102
- return rng.length && rng.reduce(function (prev, curr) {
103
- var currentDistance = Math.abs(curr - value);
104
- var previousDistance = Math.abs(prev - value);
105
- return currentDistance <= previousDistance ? curr : prev;
106
- });
107
- }
108
-
109
- function buildTickModel(domain, ticks, interval, scaleFn) {
110
- var rng = mkRange(domain.min, domain.max, interval);
111
- return rng.map(function (r, index) {
112
- var isMajor = index % (ticks.minor + 1) === 0;
113
- return {
114
- value: r,
115
- major: isMajor,
116
- x: scaleFn(r)
117
- };
118
- });
119
- }
120
-
121
- var polygonToArea = function polygonToArea(points) {
122
- var h = (0, _head["default"])(points);
123
- var area = {
124
- left: h.x,
125
- top: h.y,
126
- bottom: h.y,
127
- right: h.x
128
- };
129
- return (0, _tail["default"])(points).reduce(function (a, p) {
130
- a.left = Math.min(a.left, p.x);
131
- a.top = Math.max(a.top, p.y);
132
- a.bottom = Math.min(a.bottom, p.y);
133
- a.right = Math.max(a.right, p.x);
134
- return a;
135
- }, area);
136
- };
137
-
138
- exports.polygonToArea = polygonToArea;
139
-
140
- var lineToArea = function lineToArea(from, to) {
141
- var left = Math.min(from.x, to.x);
142
- var top = Math.max(from.y, to.y);
143
- var bottom = Math.min(from.y, to.y);
144
- var right = Math.max(from.x, to.x);
145
- return {
146
- left: left,
147
- top: top,
148
- bottom: bottom,
149
- right: right
150
- };
151
- };
152
-
153
- exports.lineToArea = lineToArea;
154
-
155
- var bounds = function bounds(area, domain, range) {
156
- return {
157
- left: domain.min - area.left,
158
- right: Math.abs(area.right - domain.max),
159
- top: Math.abs(area.top - range.max),
160
- bottom: range.min - area.bottom
161
- };
162
- };
163
-
164
- exports.bounds = bounds;
165
-
166
- var point = function point(o) {
167
- return new _pointGeometry["default"](o.x, o.y);
168
- };
169
-
170
- exports.point = point;
171
-
172
- var getDelta = function getDelta(from, to) {
173
- return point(to).sub(point(from));
174
- };
175
-
176
- exports.getDelta = getDelta;
177
-
178
- var bandKey = function bandKey(d, index) {
179
- return "".concat(index, "-").concat(d.label || '-');
180
- };
181
-
182
- exports.bandKey = bandKey;
183
-
184
- var isDomainRangeEqual = function isDomainRangeEqual(graphProps, nextGraphProps) {
185
- return (0, _isEqual["default"])(graphProps.domain, nextGraphProps.domain) && (0, _isEqual["default"])(graphProps.range, nextGraphProps.range);
186
- }; // findLongestWord is also used in graphing
187
-
188
-
189
- exports.isDomainRangeEqual = isDomainRangeEqual;
190
-
191
- var findLongestWord = function findLongestWord(label) {
192
- var longestWord = (label || '').replace(/<[^>]+>/g, '').split(' ').sort(function (a, b) {
193
- return b.length - a.length;
194
- });
195
- return longestWord[0].length;
196
- }; // amountToIncreaseWidth is also used in graphing
197
-
198
-
199
- exports.findLongestWord = findLongestWord;
200
-
201
- var amountToIncreaseWidth = function amountToIncreaseWidth(longestWord) {
202
- if (!longestWord) {
203
- return 0;
204
- }
205
-
206
- return longestWord * 20;
207
- };
208
-
209
- exports.amountToIncreaseWidth = amountToIncreaseWidth;
210
-
211
- var extractTextFromHTML = function extractTextFromHTML(htmlString) {
212
- var _doc$body;
213
-
214
- var parser = new DOMParser();
215
- var doc = parser === null || parser === void 0 ? void 0 : parser.parseFromString(htmlString, 'text/html');
216
- return (doc === null || doc === void 0 ? void 0 : (_doc$body = doc.body) === null || _doc$body === void 0 ? void 0 : _doc$body.textContent) || '';
217
- };
218
-
219
- exports.extractTextFromHTML = extractTextFromHTML;
220
-
221
- var isEmptyObject = function isEmptyObject(obj) {
222
- return obj && Object.keys(obj).length === 0 && obj.constructor === Object;
223
- };
224
-
225
- exports.isEmptyObject = isEmptyObject;
226
-
227
- var isEmptyString = function isEmptyString(str) {
228
- return typeof str === 'string' && str.trim() === '';
229
- };
230
-
231
- exports.isEmptyString = isEmptyString;
232
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/utils.js"],"names":["xy","x","y","buildSizeArray","size","padding","Number","isFinite","Math","max","half","round","tickCount","min","step","abs","getInterval","domain","ticks","major","minor","Error","distance","minorTicks","normalizedMajor","isNaN","divider","raw","parseFloat","toFixed","mkRange","interval","splice","length","snapTo","value","rng","filter","v","reduce","prev","curr","currentDistance","previousDistance","buildTickModel","scaleFn","map","r","index","isMajor","polygonToArea","points","h","area","left","top","bottom","right","a","p","lineToArea","from","to","bounds","range","point","o","Point","getDelta","sub","bandKey","d","label","isDomainRangeEqual","graphProps","nextGraphProps","findLongestWord","longestWord","replace","split","sort","b","amountToIncreaseWidth","extractTextFromHTML","htmlString","parser","DOMParser","doc","parseFromString","body","textContent","isEmptyObject","obj","Object","keys","constructor","isEmptyString","str","trim"],"mappings":"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","sourcesContent":["import invariant from 'invariant';\nimport range from 'lodash/range';\nimport Point from '@mapbox/point-geometry';\nimport head from 'lodash/head';\nimport tail from 'lodash/tail';\nimport isEqual from 'lodash/isEqual';\n\nexport const xy = (x, y) => ({ x, y });\n\nexport const buildSizeArray = (size, padding) => {\n  padding = Number.isFinite(padding) ? Math.max(padding, 0) : 0;\n  invariant(padding < size, 'padding must be less than size');\n  const half = Math.round(padding * 0.5);\n  return [half, size - half];\n};\n\nexport const tickCount = (min, max, step) => {\n  invariant(min < max, 'min must be less than max');\n  const size = Math.abs(min - max);\n  return Math.round(size / step);\n};\n\nexport function getInterval(domain, ticks) {\n  const { min, max } = domain;\n  const { major, minor } = ticks;\n\n  if (min >= max) {\n    throw new Error(`min is > max: ${min} > ${max}`);\n  }\n\n  const distance = max - min;\n  const minorTicks = minor > 0 ? minor + 1 : 1;\n  const normalizedMajor = major - 1;\n\n  if (isNaN(normalizedMajor)) {\n    throw new Error('Tick Frequency must be 2 or higher');\n  }\n\n  if (normalizedMajor <= 0) {\n    throw new Error('Tick Frequency must be 2 or higher');\n  }\n\n  const divider = normalizedMajor * minorTicks;\n  const raw = distance / divider;\n  return parseFloat(Number(raw).toFixed(4));\n}\n\nconst mkRange = (min, max, interval) => {\n  const raw = range(min, max, interval);\n  /* Fix the last step due to rounding errors */\n  raw.splice(raw.length, 1, max);\n  return raw;\n};\n\nexport function snapTo(min, max, interval, value) {\n  if (value >= max) {\n    return max;\n  }\n\n  if (value <= min) {\n    return min;\n  }\n\n  let rng = mkRange(min, max, interval);\n\n  rng = rng.filter((v) => {\n    return Math.abs(value - v) <= interval;\n  });\n\n  return (\n    rng.length &&\n    rng.reduce((prev, curr) => {\n      const currentDistance = Math.abs(curr - value);\n      const previousDistance = Math.abs(prev - value);\n      return currentDistance <= previousDistance ? curr : prev;\n    })\n  );\n}\n\nexport function buildTickModel(domain, ticks, interval, scaleFn) {\n  const rng = mkRange(domain.min, domain.max, interval);\n\n  return rng.map((r, index) => {\n    const isMajor = index % (ticks.minor + 1) === 0;\n\n    return {\n      value: r,\n      major: isMajor,\n      x: scaleFn(r),\n    };\n  });\n}\n\nexport const polygonToArea = (points) => {\n  const h = head(points);\n  const area = {\n    left: h.x,\n    top: h.y,\n    bottom: h.y,\n    right: h.x,\n  };\n  return tail(points).reduce((a, p) => {\n    a.left = Math.min(a.left, p.x);\n    a.top = Math.max(a.top, p.y);\n    a.bottom = Math.min(a.bottom, p.y);\n    a.right = Math.max(a.right, p.x);\n    return a;\n  }, area);\n};\n\nexport const lineToArea = (from, to) => {\n  const left = Math.min(from.x, to.x);\n  const top = Math.max(from.y, to.y);\n  const bottom = Math.min(from.y, to.y);\n  const right = Math.max(from.x, to.x);\n  return { left, top, bottom, right };\n};\n\nexport const bounds = (area, domain, range) => {\n  return {\n    left: domain.min - area.left,\n    right: Math.abs(area.right - domain.max),\n    top: Math.abs(area.top - range.max),\n    bottom: range.min - area.bottom,\n  };\n};\n\nexport const point = (o) => new Point(o.x, o.y);\nexport const getDelta = (from, to) => {\n  return point(to).sub(point(from));\n};\n\nexport const bandKey = (d, index) => `${index}-${d.label || '-'}`;\n\nexport const isDomainRangeEqual = (graphProps, nextGraphProps) => {\n  return isEqual(graphProps.domain, nextGraphProps.domain) && isEqual(graphProps.range, nextGraphProps.range);\n};\n\n// findLongestWord is also used in graphing\nexport const findLongestWord = (label) => {\n  let longestWord = (label || '')\n    .replace(/<[^>]+>/g, '')\n    .split(' ')\n    .sort((a, b) => b.length - a.length);\n\n  return longestWord[0].length;\n};\n\n// amountToIncreaseWidth is also used in graphing\nexport const amountToIncreaseWidth = (longestWord) => {\n  if (!longestWord) {\n    return 0;\n  }\n\n  return longestWord * 20;\n};\n\nexport const extractTextFromHTML = (htmlString) => {\n  const parser = new DOMParser();\n  const doc = parser?.parseFromString(htmlString, 'text/html');\n  return doc?.body?.textContent || '';\n};\n\nexport const isEmptyObject = (obj) => {\n  return obj && Object.keys(obj).length === 0 && obj.constructor === Object;\n};\n\nexport const isEmptyString = (str) => {\n  return typeof str === 'string' && str.trim() === '';\n};\n"]}