@gpa-gemstone/react-graph 1.0.73 → 1.0.75

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/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;