@rfkit/charts 1.2.29 → 1.3.2
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/components/AxisY/spectrum/useRanging/tools.d.ts +27 -11
- package/components/AxisY/tools.d.ts +2 -0
- package/components/Blaze/tools.d.ts +2 -1
- package/components/Cursor/tools.d.ts +1 -1
- package/components/Dashed/index.d.ts +1 -0
- package/components/DeltaMeasurement/Switch.d.ts +3 -0
- package/components/DeltaMeasurement/index.d.ts +3 -0
- package/components/DragSelectBox/index.d.ts +28 -0
- package/components/Dropdown/index.d.ts +1 -0
- package/components/EventBus/tools.d.ts +2 -2
- package/components/Markers/hooks/useMarkerEvents.d.ts +1 -0
- package/components/Markers/hooks/useMarkers.d.ts +20 -0
- package/components/Markers/tools.d.ts +17 -0
- package/components/Zoom/ZoomOffsetContainer/index.d.ts +1 -0
- package/config/constants.d.ts +12 -4
- package/config/setting.d.ts +9 -0
- package/hooks/data/index.d.ts +6 -0
- package/hooks/{useSegments.d.ts → data/useSegments.d.ts} +1 -1
- package/hooks/index.d.ts +12 -0
- package/hooks/publish/index.d.ts +6 -0
- package/hooks/{useMarkerPublish.d.ts → publish/useMarkerPublish.d.ts} +1 -1
- package/hooks/{usePublish.d.ts → publish/usePublish.d.ts} +2 -2
- package/hooks/{useSafePublish.d.ts → publish/useSafePublish.d.ts} +3 -3
- package/hooks/spectrum/index.d.ts +6 -0
- package/hooks/{useSpectrumChartType.d.ts → spectrum/useSpectrumChartType.d.ts} +1 -1
- package/hooks/{useSpectrumRule.d.ts → spectrum/useSpectrumRule.d.ts} +2 -2
- package/hooks/useChart/index.d.ts +14 -5
- package/hooks/useDragSelect.d.ts +32 -0
- package/hooks/useModuleSubscription.d.ts +66 -0
- package/hooks/useSeriesManager/index.d.ts +1 -1
- package/hooks/useSeriesManager/useFilteredSeries.d.ts +1 -1
- package/hooks/useSeriesManager/useSeriesManager.d.ts +0 -8
- package/index.d.ts +4 -2
- package/index.js +10955 -11501
- package/lib/Spectrum/Chart.d.ts +1 -1
- package/modules/Dial/render.d.ts +13 -8
- package/modules/Fluorescence/render.d.ts +13 -33
- package/modules/Gauge/render.d.ts +30 -9
- package/modules/Heatmap/render.d.ts +21 -21
- package/modules/IQEye/index.d.ts +6 -1
- package/modules/IQPlanisphere/index.d.ts +6 -1
- package/modules/IQStream/index.d.ts +5 -1
- package/modules/Occupancy/render.d.ts +14 -8
- package/modules/SpatialSpectrum/render.d.ts +13 -8
- package/modules/Spectrum/render.d.ts +3 -2
- package/modules/base/BaseRenderer.d.ts +83 -0
- package/modules/base/CircularRenderer.d.ts +59 -0
- package/modules/base/GradientRenderer.d.ts +42 -0
- package/modules/base/IQRenderer.d.ts +41 -0
- package/modules/base/index.d.ts +7 -0
- package/modules/tools.d.ts +2 -1
- package/package.json +1 -1
- package/store/reducer.d.ts +2 -0
- package/types/common.d.ts +14 -12
- package/types/publish.d.ts +4 -1
- package/types/store/axis.d.ts +29 -0
- package/types/store/frequency.d.ts +19 -0
- package/types/store/heatmap.d.ts +53 -0
- package/types/store/index.d.ts +95 -0
- package/types/store/marker.d.ts +39 -0
- package/types/store/series.d.ts +16 -0
- package/types/store/signal.d.ts +27 -0
- package/types/store/ui.d.ts +98 -0
- package/types/store.d.ts +13 -328
- package/utils/array.d.ts +40 -0
- package/utils/frequency.d.ts +72 -0
- package/utils/index.d.ts +12 -114
- package/utils/object.d.ts +11 -0
- package/utils/series/events.d.ts +1 -1
- package/utils/series/index.d.ts +1 -1
- package/utils/series/modes.d.ts +1 -1
- package/utils/subscription.d.ts +20 -2
- package/utils/theme.d.ts +18 -0
- package/utils/throttle.d.ts +52 -0
- package/utils/time.d.ts +27 -0
- package/engine/ColorInterpolator.d.ts +0 -49
- package/engine/dial.d.ts +0 -13
- package/engine/engine.d.ts +0 -10
- package/engine/fillImageData.d.ts +0 -34
- package/engine/fluorescence.d.ts +0 -37
- package/engine/gauge.d.ts +0 -16
- package/engine/heatmap.d.ts +0 -13
- package/engine/index.d.ts +0 -11
- package/engine/iq.d.ts +0 -12
- package/engine/iqEye.d.ts +0 -17
- package/engine/radar.d.ts +0 -11
- package/engine/series.d.ts +0 -12
- package/engine/tools.d.ts +0 -30
- package/engine/type.d.ts +0 -32
- package/engine/utils.d.ts +0 -2
- package/engine/webglEngine.d.ts +0 -23
- package/engine/webglExample.d.ts +0 -21
- package/engine/webglSeries.d.ts +0 -21
- package/hooks/useHeatmapHeight.d.ts +0 -7
- package/hooks/useRuleUpdate.d.ts +0 -4
- package/hooks/useZoomMinSimulateWave.d.ts +0 -7
- package/modules/IQEye/render.d.ts +0 -12
- package/modules/IQPlanisphere/render.d.ts +0 -12
- package/modules/IQStream/render.d.ts +0 -12
- /package/hooks/{useChannel.d.ts → data/useChannel.d.ts} +0 -0
- /package/hooks/{usePoints.d.ts → data/usePoints.d.ts} +0 -0
- /package/hooks/{uselevelStreamAnalyzer.d.ts → useLevelStreamAnalyzer.d.ts} +0 -0
package/lib/Spectrum/Chart.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type UseSpectrumChartTypeProps as SpectrumChartTypeProps } from '../../hooks/spectrum';
|
|
2
2
|
import { type OccupancyPortalProps } from '../../modules/OccupancyPortal';
|
|
3
3
|
import type { ParamsProps } from '../../types';
|
|
4
4
|
export interface Props extends SpectrumChartTypeProps, ParamsProps, OccupancyPortalProps {
|
package/modules/Dial/render.d.ts
CHANGED
|
@@ -1,9 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Dial 渲染器
|
|
3
|
+
*/
|
|
4
|
+
import { Dial } from '@rfkit/renderer';
|
|
5
|
+
import { CircularRenderer, type CircularRenderState } from '../base';
|
|
6
|
+
type DialRenderState = CircularRenderState<Dial>;
|
|
7
|
+
interface DialRenderProps {
|
|
8
|
+
id: string;
|
|
9
9
|
}
|
|
10
|
+
export default class DialRender extends CircularRenderer<Dial, DialRenderState> {
|
|
11
|
+
constructor(props: DialRenderProps);
|
|
12
|
+
protected init(): void;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
@@ -1,41 +1,21 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Fluorescence 渲染器
|
|
3
|
+
*/
|
|
4
|
+
import { Fluorescence as Chart } from '@rfkit/renderer';
|
|
5
|
+
import { GradientRenderer, type GradientRenderState } from '../base';
|
|
6
|
+
interface FluorescenceData {
|
|
7
|
+
fluorescenceData: Map<number, number>[];
|
|
8
|
+
fluorescenceMaxCount: number;
|
|
9
|
+
}
|
|
2
10
|
interface FluorescenceRenderProps {
|
|
3
11
|
id: string;
|
|
4
12
|
globalID: string;
|
|
5
13
|
}
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
9
|
-
export default class FluorescenceRender {
|
|
10
|
-
state: FluorescenceRenderState;
|
|
14
|
+
type FluorescenceRenderState = GradientRenderState<Chart>;
|
|
15
|
+
export default class FluorescenceRender extends GradientRenderer<Chart, FluorescenceRenderState, FluorescenceData> {
|
|
11
16
|
constructor(props: FluorescenceRenderProps);
|
|
12
|
-
init(): void;
|
|
13
|
-
/**
|
|
14
|
-
* 参数发生改变
|
|
15
|
-
*
|
|
16
|
-
* @param params 更新的参数
|
|
17
|
-
* @memberof WaterfallRender
|
|
18
|
-
*/
|
|
19
|
-
updateParams(params: Partial<FluorescenceRenderProps>): void;
|
|
20
|
-
/**
|
|
21
|
-
* 更新属性
|
|
22
|
-
*
|
|
23
|
-
* @param props
|
|
24
|
-
* @memberof FluorescenceRender
|
|
25
|
-
*/
|
|
17
|
+
protected init(): void;
|
|
26
18
|
updateProps(props: Record<string, unknown>): void;
|
|
27
|
-
|
|
28
|
-
* 更新数据
|
|
29
|
-
*
|
|
30
|
-
* @param {*} fluorescenceData
|
|
31
|
-
* @memberof FluorescenceRender
|
|
32
|
-
*/
|
|
33
|
-
updateSeries(data: {
|
|
34
|
-
fluorescenceData: Map<number, number>[];
|
|
35
|
-
fluorescenceMaxCount: number;
|
|
36
|
-
}): void;
|
|
37
|
-
reset(): void;
|
|
38
|
-
resize(): void;
|
|
39
|
-
clear(): void;
|
|
19
|
+
updateSeries(data: FluorescenceData): void;
|
|
40
20
|
}
|
|
41
21
|
export {};
|
|
@@ -1,10 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
clear(): void;
|
|
1
|
+
/**
|
|
2
|
+
* Gauge 渲染器
|
|
3
|
+
*/
|
|
4
|
+
import { Gauge } from '@rfkit/renderer';
|
|
5
|
+
import { BaseRenderer, type BaseRenderState } from '../base';
|
|
6
|
+
interface GaugeData {
|
|
7
|
+
value: number;
|
|
8
|
+
range?: [number, number];
|
|
10
9
|
}
|
|
10
|
+
interface GaugeRenderProps {
|
|
11
|
+
id: string;
|
|
12
|
+
[key: string]: unknown;
|
|
13
|
+
}
|
|
14
|
+
interface GaugeRenderState extends BaseRenderState<Gauge> {
|
|
15
|
+
props: GaugeRenderProps;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Gauge 渲染器
|
|
19
|
+
*
|
|
20
|
+
* 由于 Gauge 有额外的 props 透传和 updateProps 方法,
|
|
21
|
+
* 不完全继承 CircularRenderer,而是直接继承 BaseRenderer
|
|
22
|
+
*/
|
|
23
|
+
export default class GaugeRender extends BaseRenderer<Gauge, GaugeRenderState, GaugeData> {
|
|
24
|
+
private themeUnsubscribe;
|
|
25
|
+
constructor(props: GaugeRenderProps);
|
|
26
|
+
protected init(): void;
|
|
27
|
+
updateProps(p: Record<string, unknown>): void;
|
|
28
|
+
updateSeries(data: GaugeData): void;
|
|
29
|
+
destroy(): void;
|
|
30
|
+
}
|
|
31
|
+
export {};
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
updateSeries(
|
|
20
|
-
setRange(realRange?:
|
|
1
|
+
/**
|
|
2
|
+
* Heatmap 渲染器
|
|
3
|
+
*/
|
|
4
|
+
import { type IHeatmap } from '@rfkit/renderer';
|
|
5
|
+
import { GradientRenderer, type GradientRenderState } from '../base';
|
|
6
|
+
interface HeatmapRenderProps {
|
|
7
|
+
id: string;
|
|
8
|
+
globalID: string;
|
|
9
|
+
realRange?: [number, number];
|
|
10
|
+
heatmapDefaultData?: number[][];
|
|
11
|
+
}
|
|
12
|
+
interface HeatmapRenderState extends GradientRenderState<IHeatmap> {
|
|
13
|
+
realRange: [number, number];
|
|
14
|
+
heatmapDefaultData: number[][];
|
|
15
|
+
}
|
|
16
|
+
export default class Heatmap extends GradientRenderer<IHeatmap, HeatmapRenderState, number[][]> {
|
|
17
|
+
constructor(props: HeatmapRenderProps);
|
|
18
|
+
protected init(): void;
|
|
19
|
+
updateSeries(data: number[][]): void;
|
|
20
|
+
setRange(realRange?: [number, number]): void;
|
|
21
21
|
reset(): void;
|
|
22
22
|
resize(): void;
|
|
23
|
-
clear(): void;
|
|
24
23
|
}
|
|
24
|
+
export {};
|
package/modules/IQEye/index.d.ts
CHANGED
|
@@ -1 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
import { type IQChartType } from '../base';
|
|
2
|
+
interface IQEyeProps {
|
|
3
|
+
type?: IQChartType;
|
|
4
|
+
}
|
|
5
|
+
export default function IQEye({ type }: IQEyeProps): import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export {};
|
|
@@ -1 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
import { type IQChartType } from '../base';
|
|
2
|
+
interface IQPlanisphereProps {
|
|
3
|
+
type?: IQChartType;
|
|
4
|
+
}
|
|
5
|
+
export default function IQPlanisphere({ type }: IQPlanisphereProps): import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export {};
|
|
@@ -1,9 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
reset(): void;
|
|
7
|
-
resize(): void;
|
|
8
|
-
clear(): void;
|
|
1
|
+
import { type ISeries, OrientationType } from '@rfkit/renderer';
|
|
2
|
+
import { BaseRenderer, type BaseRenderState } from '../base/BaseRenderer';
|
|
3
|
+
interface OccupancyRenderProps {
|
|
4
|
+
id: string;
|
|
5
|
+
orientation?: OrientationType;
|
|
9
6
|
}
|
|
7
|
+
interface OccupancyRenderState extends BaseRenderState<ISeries> {
|
|
8
|
+
orientation: OrientationType;
|
|
9
|
+
}
|
|
10
|
+
export default class Occupancy extends BaseRenderer<ISeries, OccupancyRenderState, Float32Array> {
|
|
11
|
+
constructor(props: OccupancyRenderProps);
|
|
12
|
+
protected init(): void;
|
|
13
|
+
updateSeries(data: Float32Array): void;
|
|
14
|
+
}
|
|
15
|
+
export {};
|
|
@@ -1,9 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
/**
|
|
2
|
+
* SpatialSpectrum (Radar) 渲染器
|
|
3
|
+
*/
|
|
4
|
+
import { Radar } from '@rfkit/renderer';
|
|
5
|
+
import { CircularRenderer, type CircularRenderState } from '../base';
|
|
6
|
+
type SpatialSpectrumRenderState = CircularRenderState<Radar>;
|
|
7
|
+
interface SpatialSpectrumRenderProps {
|
|
8
|
+
id: string;
|
|
9
9
|
}
|
|
10
|
+
export default class SpatialSpectrumRender extends CircularRenderer<Radar, SpatialSpectrumRenderState> {
|
|
11
|
+
constructor(props: SpatialSpectrumRenderProps);
|
|
12
|
+
protected init(): void;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { type ISeries } from '@rfkit/renderer';
|
|
2
2
|
import type { SeriesConfig } from '../../types';
|
|
3
3
|
interface SpectrumState {
|
|
4
|
-
chart:
|
|
4
|
+
chart: ISeries | null;
|
|
5
5
|
autoranging: boolean;
|
|
6
6
|
prevAutoRangeTime: number;
|
|
7
7
|
id: string;
|
|
@@ -9,6 +9,7 @@ interface SpectrumState {
|
|
|
9
9
|
interval: number;
|
|
10
10
|
series: Record<string, SeriesConfig>;
|
|
11
11
|
globalID: string;
|
|
12
|
+
[key: string]: unknown;
|
|
12
13
|
}
|
|
13
14
|
export default class Spectrum {
|
|
14
15
|
state: SpectrumState;
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 渲染器抽象基类
|
|
3
|
+
*
|
|
4
|
+
* 提供统一的生命周期管理和资源清理机制
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* 渲染器接口
|
|
8
|
+
*/
|
|
9
|
+
export interface IRenderer<TData = unknown> {
|
|
10
|
+
updateSeries(data: TData): void;
|
|
11
|
+
reset(): void;
|
|
12
|
+
resize(): void;
|
|
13
|
+
clear(): void;
|
|
14
|
+
destroy(): void;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* 基础渲染状态
|
|
18
|
+
* 添加索引签名以兼容 RenderChartType.state
|
|
19
|
+
*/
|
|
20
|
+
export interface BaseRenderState<TChart = unknown> {
|
|
21
|
+
id: string;
|
|
22
|
+
chart: TChart | null;
|
|
23
|
+
[key: string]: unknown;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* 具有 resize/clear/draw 方法的图表接口
|
|
27
|
+
*/
|
|
28
|
+
interface ChartLike {
|
|
29
|
+
resize?: () => void;
|
|
30
|
+
clear?: () => void;
|
|
31
|
+
draw?: () => void;
|
|
32
|
+
updateProps?: (props: Record<string, unknown>) => void;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* 渲染器抽象基类
|
|
36
|
+
*
|
|
37
|
+
* @template TChart - 内部图表引擎类型
|
|
38
|
+
* @template TState - 渲染器状态类型
|
|
39
|
+
* @template TData - 数据类型
|
|
40
|
+
*/
|
|
41
|
+
export declare abstract class BaseRenderer<TChart extends ChartLike, TState extends BaseRenderState<TChart> = BaseRenderState<TChart>, TData = unknown> implements IRenderer<TData> {
|
|
42
|
+
/** 公开 state 以兼容 RenderChartType 接口 */
|
|
43
|
+
state: TState;
|
|
44
|
+
protected resizeTimer: ReturnType<typeof setTimeout> | null;
|
|
45
|
+
constructor(initialState: TState);
|
|
46
|
+
/**
|
|
47
|
+
* 初始化图表引擎(子类必须实现)
|
|
48
|
+
*/
|
|
49
|
+
protected abstract init(): void;
|
|
50
|
+
/**
|
|
51
|
+
* 更新数据(子类必须实现)
|
|
52
|
+
*/
|
|
53
|
+
abstract updateSeries(data: TData): void;
|
|
54
|
+
/**
|
|
55
|
+
* 重置(清空 + 调整大小)
|
|
56
|
+
*/
|
|
57
|
+
reset(): void;
|
|
58
|
+
/**
|
|
59
|
+
* 调整大小
|
|
60
|
+
*/
|
|
61
|
+
resize(): void;
|
|
62
|
+
/**
|
|
63
|
+
* 清空图表
|
|
64
|
+
*/
|
|
65
|
+
clear(): void;
|
|
66
|
+
/**
|
|
67
|
+
* 销毁资源
|
|
68
|
+
*/
|
|
69
|
+
destroy(): void;
|
|
70
|
+
/**
|
|
71
|
+
* dispose 别名,兼容 RenderChartType 接口
|
|
72
|
+
*/
|
|
73
|
+
dispose(): (() => void) | undefined;
|
|
74
|
+
/**
|
|
75
|
+
* 延迟调整大小(用于初始化后的首次 resize)
|
|
76
|
+
*/
|
|
77
|
+
protected scheduleResize(delay?: number): void;
|
|
78
|
+
/**
|
|
79
|
+
* 清理 resize 定时器
|
|
80
|
+
*/
|
|
81
|
+
protected clearResizeTimer(): void;
|
|
82
|
+
}
|
|
83
|
+
export {};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 圆形图表渲染器基类
|
|
3
|
+
*
|
|
4
|
+
* 提供主题订阅功能,适用于 Dial、Radar(SpatialSpectrum)、Gauge 等圆形图表
|
|
5
|
+
*/
|
|
6
|
+
import { BaseRenderer, type BaseRenderState } from './BaseRenderer';
|
|
7
|
+
/**
|
|
8
|
+
* 圆形图表数据项
|
|
9
|
+
*/
|
|
10
|
+
export interface CircularSeriesItem {
|
|
11
|
+
value: number;
|
|
12
|
+
color: string;
|
|
13
|
+
lineWidth?: number;
|
|
14
|
+
radio?: number;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* 圆形图表数据
|
|
18
|
+
*/
|
|
19
|
+
export interface CircularData {
|
|
20
|
+
series?: CircularSeriesItem[];
|
|
21
|
+
range?: number[];
|
|
22
|
+
yawAngle?: number;
|
|
23
|
+
isNorthFacing?: boolean;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* 具有 render/updateProps/draw 方法的圆形图表接口
|
|
27
|
+
*/
|
|
28
|
+
interface CircularChartLike {
|
|
29
|
+
resize?: () => void;
|
|
30
|
+
clear?: () => void;
|
|
31
|
+
draw?: () => void;
|
|
32
|
+
updateProps?: (props: Record<string, unknown>) => void;
|
|
33
|
+
render?: (data: CircularData) => void;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* 圆形渲染状态
|
|
37
|
+
*/
|
|
38
|
+
export interface CircularRenderState<TChart extends CircularChartLike> extends BaseRenderState<TChart> {
|
|
39
|
+
id: string;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* 圆形图表渲染器基类
|
|
43
|
+
*/
|
|
44
|
+
export declare abstract class CircularRenderer<TChart extends CircularChartLike, TState extends CircularRenderState<TChart> = CircularRenderState<TChart>> extends BaseRenderer<TChart, TState, CircularData> {
|
|
45
|
+
protected themeUnsubscribe: (() => void) | null;
|
|
46
|
+
/**
|
|
47
|
+
* 订阅主题变化
|
|
48
|
+
*/
|
|
49
|
+
protected subscribeToTheme(): void;
|
|
50
|
+
/**
|
|
51
|
+
* 更新数据
|
|
52
|
+
*/
|
|
53
|
+
updateSeries(data: CircularData): void;
|
|
54
|
+
/**
|
|
55
|
+
* 销毁资源
|
|
56
|
+
*/
|
|
57
|
+
destroy(): void;
|
|
58
|
+
}
|
|
59
|
+
export {};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 颜色梯度渲染器基类
|
|
3
|
+
*
|
|
4
|
+
* 提供颜色梯度管理功能,适用于 Heatmap、Fluorescence 等热力图类图表
|
|
5
|
+
*/
|
|
6
|
+
import { hexToRGBA } from '@rfkit/renderer';
|
|
7
|
+
import { BaseRenderer, type BaseRenderState } from './BaseRenderer';
|
|
8
|
+
/**
|
|
9
|
+
* 具有 updateProps/render 方法的梯度图表接口
|
|
10
|
+
*/
|
|
11
|
+
interface GradientChartLike {
|
|
12
|
+
resize?: () => void;
|
|
13
|
+
clear?: () => void;
|
|
14
|
+
updateProps?: (props: Record<string, unknown>) => void;
|
|
15
|
+
render?: (data: unknown) => void;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 梯度渲染状态
|
|
19
|
+
*/
|
|
20
|
+
export interface GradientRenderState<TChart extends GradientChartLike> extends BaseRenderState<TChart> {
|
|
21
|
+
globalID: string;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* 颜色梯度渲染器基类
|
|
25
|
+
*/
|
|
26
|
+
export declare abstract class GradientRenderer<TChart extends GradientChartLike, TState extends GradientRenderState<TChart> = GradientRenderState<TChart>, TData = unknown> extends BaseRenderer<TChart, TState, TData> {
|
|
27
|
+
/**
|
|
28
|
+
* 获取初始颜色配置
|
|
29
|
+
*/
|
|
30
|
+
protected getInitialColors(): ReturnType<typeof hexToRGBA>[];
|
|
31
|
+
/**
|
|
32
|
+
* 订阅颜色变化
|
|
33
|
+
*
|
|
34
|
+
* @param key - 订阅标识符
|
|
35
|
+
*/
|
|
36
|
+
protected subscribeToColor(key: string): void;
|
|
37
|
+
/**
|
|
38
|
+
* 参数发生改变时调用
|
|
39
|
+
*/
|
|
40
|
+
updateParams(params: Partial<TState>): void;
|
|
41
|
+
}
|
|
42
|
+
export {};
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* IQ 渲染器
|
|
3
|
+
*
|
|
4
|
+
* 合并 IQEye、IQStream、IQPlanisphere 三个渲染器
|
|
5
|
+
* 通过 type 参数区分不同的渲染模式
|
|
6
|
+
*/
|
|
7
|
+
import { IQ, IQEye } from '@rfkit/renderer';
|
|
8
|
+
import { BaseRenderer, type BaseRenderState } from './BaseRenderer';
|
|
9
|
+
/**
|
|
10
|
+
* IQ 图表类型
|
|
11
|
+
*/
|
|
12
|
+
export type IQChartType = 'iqEye' | 'iqLine' | 'iqPlanisphere' | 'iqStream';
|
|
13
|
+
/**
|
|
14
|
+
* IQ 渲染状态
|
|
15
|
+
*/
|
|
16
|
+
interface IQRenderState extends BaseRenderState<IQ | IQEye> {
|
|
17
|
+
type: IQChartType;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* IQ 渲染器属性
|
|
21
|
+
*/
|
|
22
|
+
interface IQRenderProps {
|
|
23
|
+
id: string;
|
|
24
|
+
type: IQChartType;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* IQ 渲染器
|
|
28
|
+
*/
|
|
29
|
+
export default class IQRenderer extends BaseRenderer<IQ | IQEye, IQRenderState, IQData> {
|
|
30
|
+
constructor(props: IQRenderProps);
|
|
31
|
+
protected init(): void;
|
|
32
|
+
updateSeries(data: IQData): void;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* IQ 数据类型
|
|
36
|
+
*/
|
|
37
|
+
export interface IQData {
|
|
38
|
+
IData: number[];
|
|
39
|
+
QData: number[];
|
|
40
|
+
}
|
|
41
|
+
export {};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 渲染器基类导出
|
|
3
|
+
*/
|
|
4
|
+
export { BaseRenderer, type BaseRenderState, type IRenderer } from './BaseRenderer';
|
|
5
|
+
export { type CircularData, CircularRenderer, type CircularRenderState, type CircularSeriesItem } from './CircularRenderer';
|
|
6
|
+
export { GradientRenderer, type GradientRenderState } from './GradientRenderer';
|
|
7
|
+
export { default as IQRenderer, type IQChartType, type IQData } from './IQRenderer';
|
package/modules/tools.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
import { type CSMCallback } from '../utils/subscription';
|
|
2
|
+
declare const _default: (globalID: string, name: string, func?: CSMCallback) => (...args: any[]) => void;
|
|
2
3
|
export default _default;
|
package/package.json
CHANGED
package/store/reducer.d.ts
CHANGED
|
@@ -30,6 +30,7 @@ export declare const defaultState: () => {
|
|
|
30
30
|
levelStream?: import("../types").LevelStreamProps;
|
|
31
31
|
timeRange?: number;
|
|
32
32
|
fluorescence: import("../types").FluorescenceProps;
|
|
33
|
+
deltaMeasurement: import("../types").DeltaMeasurementProps;
|
|
33
34
|
publish?: import("..").Publish;
|
|
34
35
|
};
|
|
35
36
|
export declare const reducer: (state: StoreState, action: DispatchAction) => {
|
|
@@ -62,5 +63,6 @@ export declare const reducer: (state: StoreState, action: DispatchAction) => {
|
|
|
62
63
|
levelStream?: import("../types").LevelStreamProps;
|
|
63
64
|
timeRange?: number;
|
|
64
65
|
fluorescence: import("../types").FluorescenceProps;
|
|
66
|
+
deltaMeasurement: import("../types").DeltaMeasurementProps;
|
|
65
67
|
publish?: import("..").Publish;
|
|
66
68
|
};
|
package/types/common.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { GraphicType, OrientationType } from '
|
|
1
|
+
import type { GraphicType, OrientationType } from '@rfkit/renderer';
|
|
2
2
|
import type { Publish, RecursiveObject, SetSeries } from './';
|
|
3
3
|
export type AxisYRange = [number, number];
|
|
4
4
|
export interface AxisXRange {
|
|
@@ -11,21 +11,23 @@ export interface TopRightBottomLeft {
|
|
|
11
11
|
right?: number;
|
|
12
12
|
bottom?: number;
|
|
13
13
|
}
|
|
14
|
-
export
|
|
15
|
-
resize(): unknown;
|
|
14
|
+
export interface RenderChartType {
|
|
16
15
|
state: {
|
|
16
|
+
id: string;
|
|
17
|
+
chart: unknown;
|
|
17
18
|
[key: string]: unknown;
|
|
18
19
|
};
|
|
19
|
-
updateProps(...arg: unknown[]): unknown;
|
|
20
|
-
updateSeries(...arg: unknown[]): unknown;
|
|
21
|
-
setDisabledClearRect(disabledClearRect: boolean): unknown;
|
|
22
20
|
reset(): unknown;
|
|
23
|
-
|
|
24
|
-
dispose(): () => void;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
21
|
+
resize(): unknown;
|
|
22
|
+
dispose(): (() => void) | undefined;
|
|
23
|
+
updateProps?(...arg: unknown[]): unknown;
|
|
24
|
+
updateSeries?(...arg: unknown[]): unknown;
|
|
25
|
+
setDisabledClearRect?(disabledClearRect: boolean): unknown;
|
|
26
|
+
useRangeAutoFocus?(): unknown;
|
|
27
|
+
setSeries?(s: SetSeries): unknown;
|
|
28
|
+
setRange?(range: AxisYRange): void;
|
|
29
|
+
updateParams?(params: RecursiveObject): void;
|
|
30
|
+
}
|
|
29
31
|
export interface SeriesConfig {
|
|
30
32
|
readonly name: string;
|
|
31
33
|
label?: string;
|
package/types/publish.d.ts
CHANGED
|
@@ -68,7 +68,10 @@ export interface PublishHeatmap {
|
|
|
68
68
|
}
|
|
69
69
|
export interface PublishFluorescence {
|
|
70
70
|
pstype: PSType.Fluorescence;
|
|
71
|
-
data:
|
|
71
|
+
data: {
|
|
72
|
+
fluorescenceData: Map<number, number>[];
|
|
73
|
+
fluorescenceMaxCount: number;
|
|
74
|
+
};
|
|
72
75
|
}
|
|
73
76
|
export interface PublishOccupancy {
|
|
74
77
|
pstype: PSType.Occupancy;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { AxisYRange, RecursiveObject } from '..';
|
|
2
|
+
export interface AxisYProps {
|
|
3
|
+
show?: boolean;
|
|
4
|
+
disabled?: boolean;
|
|
5
|
+
gradientRibbon?: boolean;
|
|
6
|
+
realRange?: number[];
|
|
7
|
+
range?: AxisYRange;
|
|
8
|
+
renderRange?: AxisYRange;
|
|
9
|
+
restrict?: number[];
|
|
10
|
+
autoranging?: boolean;
|
|
11
|
+
step?: number;
|
|
12
|
+
unit?: string;
|
|
13
|
+
unitList?: string[];
|
|
14
|
+
unitDisabled?: boolean;
|
|
15
|
+
type?: string;
|
|
16
|
+
hidden?: string[];
|
|
17
|
+
linkage?: boolean;
|
|
18
|
+
onChange?: (e: RecursiveObject) => void;
|
|
19
|
+
}
|
|
20
|
+
export interface AxisXProps {
|
|
21
|
+
show?: boolean;
|
|
22
|
+
range?: number[];
|
|
23
|
+
unit?: string;
|
|
24
|
+
unitKHz?: string;
|
|
25
|
+
ticks?: boolean;
|
|
26
|
+
children?: React.ReactNode;
|
|
27
|
+
onChange?: () => void;
|
|
28
|
+
frequencyFormat?: (x: number) => string;
|
|
29
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export interface FrequencyAllocationItem {
|
|
2
|
+
startFrequency?: number | string;
|
|
3
|
+
stopFrequency?: number | string;
|
|
4
|
+
centerFrequency?: number | string;
|
|
5
|
+
stepFrequency: number | string;
|
|
6
|
+
bandwidth?: number | string;
|
|
7
|
+
modulation: string;
|
|
8
|
+
title: string;
|
|
9
|
+
description: string;
|
|
10
|
+
demodulation?: string;
|
|
11
|
+
status?: string;
|
|
12
|
+
color?: string;
|
|
13
|
+
gradientColors?: [string, string];
|
|
14
|
+
}
|
|
15
|
+
export interface FrequencyAllocationProps {
|
|
16
|
+
show: boolean;
|
|
17
|
+
display: boolean;
|
|
18
|
+
data: FrequencyAllocationItem[];
|
|
19
|
+
}
|