@gpa-gemstone/react-graph 1.0.74 → 1.0.76
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/GraphContext.d.ts +8 -0
- package/lib/GraphContext.js +3 -1
- package/lib/HeatLegend.js +6 -18
- package/lib/HeatMapChart.js +4 -4
- package/lib/InteractiveButtons.d.ts +2 -0
- package/lib/InteractiveButtons.js +24 -12
- package/lib/Legend.d.ts +6 -1
- package/lib/Legend.js +116 -60
- package/lib/LegendContext.d.ts +3 -5
- package/lib/LegendContext.js +3 -5
- package/lib/Line.js +10 -4
- package/lib/LineLegend.d.ts +1 -1
- package/lib/LineLegend.js +13 -51
- package/lib/LineWithThreshold.js +9 -3
- package/lib/Pill.d.ts +73 -0
- package/lib/Pill.js +165 -0
- package/lib/Plot.d.ts +11 -0
- package/lib/Plot.js +84 -65
- package/lib/index.d.ts +2 -2
- package/lib/index.js +3 -3
- package/package.json +3 -3
- package/lib/Oval.d.ts +0 -64
- package/lib/Oval.js +0 -132
package/lib/Pill.d.ts
ADDED
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { IActionFunctions, AxisIdentifier } from './GraphContext';
|
|
2
|
+
export interface IProps {
|
|
3
|
+
/**
|
|
4
|
+
* Data for the pill and circles:
|
|
5
|
+
* [x1, x2]
|
|
6
|
+
* - x1: The x-coordinate of the left edge of the pill.
|
|
7
|
+
* - x2: The x-coordinate of the right edge of the pill.
|
|
8
|
+
*/
|
|
9
|
+
XData: [number, number];
|
|
10
|
+
/**
|
|
11
|
+
* Data for the pill and circles:
|
|
12
|
+
* [y1, y2]
|
|
13
|
+
* - y1: The y-coordinate of the bottom edge of the pill.
|
|
14
|
+
* - y2: The y-coordinate of the top edge of the pill.
|
|
15
|
+
*/
|
|
16
|
+
YData: [number, number];
|
|
17
|
+
/**
|
|
18
|
+
* Radius of the pill in pixels.
|
|
19
|
+
*/
|
|
20
|
+
RadiusPX: number;
|
|
21
|
+
/**
|
|
22
|
+
* Fill color of the pill.
|
|
23
|
+
* @type {string}
|
|
24
|
+
*/
|
|
25
|
+
Color: string;
|
|
26
|
+
/**
|
|
27
|
+
* Color of text in pill.
|
|
28
|
+
* @type {string}
|
|
29
|
+
*/
|
|
30
|
+
TextColor?: string;
|
|
31
|
+
/**
|
|
32
|
+
* Stroke color of the pill and circles.
|
|
33
|
+
* @optional
|
|
34
|
+
* @type {string}
|
|
35
|
+
*/
|
|
36
|
+
BorderColor?: string;
|
|
37
|
+
/**
|
|
38
|
+
* Stroke thickness of the pill and circles.
|
|
39
|
+
* @optional
|
|
40
|
+
* @type {number}
|
|
41
|
+
*/
|
|
42
|
+
BorderThickness?: number;
|
|
43
|
+
/**
|
|
44
|
+
* Optional text to display inside the pill.
|
|
45
|
+
* @optional
|
|
46
|
+
* @type {string}
|
|
47
|
+
*/
|
|
48
|
+
Text?: string;
|
|
49
|
+
/**
|
|
50
|
+
* Where to place text in the pill
|
|
51
|
+
*/
|
|
52
|
+
TextPlacement?: 'center' | 'left' | 'right';
|
|
53
|
+
/**
|
|
54
|
+
* Opacity of the pill and circles.
|
|
55
|
+
* @optional
|
|
56
|
+
* @type {number}
|
|
57
|
+
*/
|
|
58
|
+
Opacity?: number;
|
|
59
|
+
/**
|
|
60
|
+
* Axis identifier used for vertical positioning.
|
|
61
|
+
* @optional
|
|
62
|
+
* @type {AxisIdentifier}
|
|
63
|
+
*/
|
|
64
|
+
Axis?: AxisIdentifier;
|
|
65
|
+
/**
|
|
66
|
+
* Callback function to handle click events on the pill. Provides action functions to update domains.
|
|
67
|
+
* @optional
|
|
68
|
+
* @type {(actions: IActionFunctions) => void}
|
|
69
|
+
*/
|
|
70
|
+
OnClick?: (x: number, y: number, actions: IActionFunctions) => void;
|
|
71
|
+
}
|
|
72
|
+
declare const Pill: (props: IProps) => JSX.Element | null;
|
|
73
|
+
export default Pill;
|
package/lib/Pill.js
ADDED
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ******************************************************************************************************
|
|
3
|
+
// Pill.tsx - Gbtc
|
|
4
|
+
//
|
|
5
|
+
// Copyright © 2024, Grid Protection Alliance. All Rights Reserved.
|
|
6
|
+
//
|
|
7
|
+
// Licensed to the Grid Protection Alliance (GPA) under one or more contributor license agreements. See
|
|
8
|
+
// the NOTICE file distributed with this work for additional information regarding copyright ownership.
|
|
9
|
+
// The GPA licenses this file to you under the MIT License (MIT), the "License"; you may not use this
|
|
10
|
+
// file except in compliance with the License. You may obtain a copy of the License at:
|
|
11
|
+
//
|
|
12
|
+
// http://opensource.org/licenses/MIT
|
|
13
|
+
//
|
|
14
|
+
// Unless agreed to in writing, the subject software distributed under the License is distributed on an
|
|
15
|
+
// "AS-IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. Refer to the
|
|
16
|
+
// License for the specific language governing permissions and limitations.
|
|
17
|
+
//
|
|
18
|
+
// Code Modification History:
|
|
19
|
+
// ----------------------------------------------------------------------------------------------------
|
|
20
|
+
// 09/03/2024 - Preston Crawford
|
|
21
|
+
// Generated original version of source code.
|
|
22
|
+
//
|
|
23
|
+
// ******************************************************************************************************
|
|
24
|
+
var __read = (this && this.__read) || function (o, n) {
|
|
25
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
26
|
+
if (!m) return o;
|
|
27
|
+
var i = m.call(o), r, ar = [], e;
|
|
28
|
+
try {
|
|
29
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
30
|
+
}
|
|
31
|
+
catch (error) { e = { error: error }; }
|
|
32
|
+
finally {
|
|
33
|
+
try {
|
|
34
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
35
|
+
}
|
|
36
|
+
finally { if (e) throw e.error; }
|
|
37
|
+
}
|
|
38
|
+
return ar;
|
|
39
|
+
};
|
|
40
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
41
|
+
var helper_functions_1 = require("@gpa-gemstone/helper-functions");
|
|
42
|
+
var React = require("react");
|
|
43
|
+
var GraphContext_1 = require("./GraphContext");
|
|
44
|
+
var Pill = function (props) {
|
|
45
|
+
var _a;
|
|
46
|
+
var context = React.useContext(GraphContext_1.GraphContext);
|
|
47
|
+
var _b = __read(React.useState(""), 2), guid = _b[0], setGuid = _b[1];
|
|
48
|
+
var _c = __read(React.useState(1), 2), textSize = _c[0], setTextSize = _c[1];
|
|
49
|
+
var pxHeight = React.useMemo(function () {
|
|
50
|
+
var axis = GraphContext_1.AxisMap.get(props.Axis);
|
|
51
|
+
var y0px = context.YTransformation(props.YData[0], axis);
|
|
52
|
+
var y1px = context.YTransformation(props.YData[1], axis);
|
|
53
|
+
return Math.abs(y1px - y0px);
|
|
54
|
+
}, [context.XTransformation, props.YData, props.Axis]);
|
|
55
|
+
var pxWidth = React.useMemo(function () {
|
|
56
|
+
return Math.abs(context.XTransformation(props.XData[1]) - context.XTransformation(props.XData[0]));
|
|
57
|
+
}, [context.XTransformation, props.XData]);
|
|
58
|
+
var radius = React.useMemo(function () {
|
|
59
|
+
return Math.min(pxHeight / 2, pxWidth / 2, props.RadiusPX);
|
|
60
|
+
}, [pxHeight, pxWidth, props.RadiusPX]);
|
|
61
|
+
var getMax = React.useCallback(function (tDomain) {
|
|
62
|
+
var _a = __read(tDomain, 2), t0 = _a[0], t1 = _a[1];
|
|
63
|
+
var _b = __read(props.XData, 2), x1 = _b[0], x2 = _b[1];
|
|
64
|
+
if (t1 >= x1 && t0 <= x2)
|
|
65
|
+
return Math.max(props.YData[0], props.YData[1]);
|
|
66
|
+
return undefined;
|
|
67
|
+
}, [props.XData, props.YData]);
|
|
68
|
+
var getMin = React.useCallback(function (tDomain) {
|
|
69
|
+
var _a = __read(tDomain, 2), t0 = _a[0], t1 = _a[1];
|
|
70
|
+
var _b = __read(props.XData, 2), x1 = _b[0], x2 = _b[1];
|
|
71
|
+
if (t1 >= x1 && t0 <= x2)
|
|
72
|
+
return Math.min(props.YData[0], props.YData[1]);
|
|
73
|
+
return undefined;
|
|
74
|
+
}, [props.XData, props.YData]);
|
|
75
|
+
// Update data series information in the graph context based on circle properties
|
|
76
|
+
React.useEffect(function () {
|
|
77
|
+
if (guid === "")
|
|
78
|
+
return;
|
|
79
|
+
context.UpdateData(guid, {
|
|
80
|
+
axis: props.Axis,
|
|
81
|
+
legend: undefined,
|
|
82
|
+
getMax: getMax,
|
|
83
|
+
getMin: getMin,
|
|
84
|
+
});
|
|
85
|
+
}, [props.Axis, props.XData, props.YData]);
|
|
86
|
+
// Add a new data series on component mount / removing on unmount
|
|
87
|
+
React.useEffect(function () {
|
|
88
|
+
var id = context.AddData({
|
|
89
|
+
axis: props.Axis,
|
|
90
|
+
legend: undefined,
|
|
91
|
+
getMax: getMax,
|
|
92
|
+
getMin: getMin
|
|
93
|
+
});
|
|
94
|
+
setGuid(id);
|
|
95
|
+
return function () {
|
|
96
|
+
context.RemoveData(id);
|
|
97
|
+
};
|
|
98
|
+
}, []);
|
|
99
|
+
// Adjust text size within the pill to ensure it fits
|
|
100
|
+
React.useEffect(function () {
|
|
101
|
+
if (props.Text === undefined)
|
|
102
|
+
return;
|
|
103
|
+
var fontFamily = "Segoe UI";
|
|
104
|
+
var fontSizeUnit = "em";
|
|
105
|
+
var minSize = 0.05;
|
|
106
|
+
var maxSize = 5;
|
|
107
|
+
var bestSize = minSize;
|
|
108
|
+
var calculateTextSize = function (size) {
|
|
109
|
+
var dX = (0, helper_functions_1.GetTextWidth)(fontFamily, size + fontSizeUnit, props.Text);
|
|
110
|
+
var dY = (0, helper_functions_1.GetTextHeight)(fontFamily, size + fontSizeUnit, props.Text);
|
|
111
|
+
return { dX: dX, dY: dY };
|
|
112
|
+
};
|
|
113
|
+
while (maxSize - minSize > 0.01) {
|
|
114
|
+
var midSize = (maxSize + minSize) / 2;
|
|
115
|
+
var _a = calculateTextSize(midSize), dX = _a.dX, dY = _a.dY;
|
|
116
|
+
if (dX <= pxWidth && dY <= pxHeight) {
|
|
117
|
+
bestSize = midSize;
|
|
118
|
+
minSize = midSize; // Try larger
|
|
119
|
+
}
|
|
120
|
+
else
|
|
121
|
+
maxSize = midSize; // Try smaller
|
|
122
|
+
}
|
|
123
|
+
setTextSize(bestSize);
|
|
124
|
+
}, [props.Text, pxHeight, pxWidth]);
|
|
125
|
+
// Set up a click handler if provided in props
|
|
126
|
+
React.useEffect(function () {
|
|
127
|
+
if (guid === "" || props.OnClick === undefined)
|
|
128
|
+
return;
|
|
129
|
+
context.UpdateSelect(guid, { onClick: onClick });
|
|
130
|
+
}, [props.OnClick, context.UpdateFlag]);
|
|
131
|
+
// Handle click events on the pill
|
|
132
|
+
var onClick = React.useCallback(function (xClick, yClick) {
|
|
133
|
+
if (props.OnClick === undefined)
|
|
134
|
+
return;
|
|
135
|
+
// Calculate positions and determine if the click was within the pill bounds
|
|
136
|
+
var _a = __read(props.XData, 2), x1 = _a[0], x2 = _a[1];
|
|
137
|
+
var _b = __read(props.YData, 2), y1 = _b[0], y2 = _b[1];
|
|
138
|
+
var isWithinHorizontalBounds = xClick >= x1 && xClick <= x2;
|
|
139
|
+
var isWithinVerticalBounds = yClick >= y1 && yClick <= y2;
|
|
140
|
+
if (isWithinHorizontalBounds && isWithinVerticalBounds)
|
|
141
|
+
props.OnClick(xClick, yClick, { setYDomain: context.SetYDomain, setTDomain: context.SetXDomain });
|
|
142
|
+
}, [props.OnClick, props.Axis, props.XData, props.YData, context.XTransformation, context.YTransformation, context.SetXDomain, context.SetYDomain]);
|
|
143
|
+
var textXPosition = React.useMemo(function () {
|
|
144
|
+
var xLeft = context.XTransformation(props.XData[0]);
|
|
145
|
+
var xRight = context.XTransformation(props.XData[1]);
|
|
146
|
+
var xCenter = (xLeft + xRight) / 2;
|
|
147
|
+
if (props.TextPlacement == null || props.TextPlacement === 'center')
|
|
148
|
+
return xCenter;
|
|
149
|
+
if (props.TextPlacement === 'left')
|
|
150
|
+
return xLeft;
|
|
151
|
+
if (props.TextPlacement === 'right')
|
|
152
|
+
return xRight;
|
|
153
|
+
return xCenter;
|
|
154
|
+
}, [context.XTransformation, props.XData, props.TextPlacement]);
|
|
155
|
+
// Render null if coordinates are not valid, otherwise render the pill / text
|
|
156
|
+
if (!isFinite(context.XTransformation((props.XData[0], props.XData[1]) / 2)) || !isFinite(context.YTransformation(props.YData[0], GraphContext_1.AxisMap.get(props.Axis))) || !isFinite(context.YTransformation(props.YData[1], GraphContext_1.AxisMap.get(props.Axis))))
|
|
157
|
+
return null;
|
|
158
|
+
return (React.createElement("g", null,
|
|
159
|
+
React.createElement("rect", { x: context.XTransformation(props.XData[0]), width: pxWidth, y: context.YTransformation(props.YData[1], GraphContext_1.AxisMap.get(props.Axis)), height: pxHeight, rx: radius, ry: radius, fill: props.Color, opacity: props.Opacity, stroke: props.BorderColor, strokeWidth: props.BorderThickness, onClick: function (e) { return onClick(e.clientX, e.clientY); } }),
|
|
160
|
+
props.Text !== undefined ?
|
|
161
|
+
React.createElement("g", { clipPath: "url(#oval-clip-".concat(guid, ")") },
|
|
162
|
+
React.createElement("text", { fill: (_a = props.TextColor) !== null && _a !== void 0 ? _a : 'currentColor', style: { fontSize: textSize + 'em', textAnchor: 'middle', dominantBaseline: 'middle' }, y: (context.YTransformation(props.YData[0], GraphContext_1.AxisMap.get(props.Axis)) + context.YTransformation(props.YData[1], GraphContext_1.AxisMap.get(props.Axis))) / 2, x: textXPosition }, props.Text)) : null));
|
|
163
|
+
};
|
|
164
|
+
exports.default = Pill;
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Pill.js","sourceRoot":"","sources":["../src/Pill.tsx"],"names":[],"mappings":"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"}
|
package/lib/Plot.d.ts
CHANGED
|
@@ -11,7 +11,18 @@ export interface IProps {
|
|
|
11
11
|
width: number;
|
|
12
12
|
showGrid?: boolean;
|
|
13
13
|
XAxisType?: 'time' | 'log' | 'value';
|
|
14
|
+
/**
|
|
15
|
+
* Flag to enable all zooming features.
|
|
16
|
+
*/
|
|
14
17
|
zoom?: boolean;
|
|
18
|
+
/**
|
|
19
|
+
* Flag to enable zooming on the y-axis.
|
|
20
|
+
*/
|
|
21
|
+
yZoom?: boolean;
|
|
22
|
+
/**
|
|
23
|
+
* Flag to enable zooming on the x-axis.
|
|
24
|
+
*/
|
|
25
|
+
xZoom?: boolean;
|
|
15
26
|
pan?: boolean;
|
|
16
27
|
Tmin?: number;
|
|
17
28
|
Tmax?: number;
|