mirror of
https://github.com/reduxjs/redux-devtools.git
synced 2025-02-07 15:10:45 +03:00
* Update packages * Fix after update * Update some types * Remove attr * Finish d3tooltip * Update style option * Updates * Zoom * Update * Update * Update * Fix * Update * Update * Update * Update * Update * Fixes * Update id type * Fix enter + update selections * Use this * Fix stringifying * Remove InputOptions * Use data.value * Updates * Remove UMD builds * Fix exit * No need to re-assign * Simplify d3tooltip API * Update redux-devtools-chart-monitor * Update redux-devtools-app * Update * Update * Remove @types/prop-types * Update prop types * Update d3tooltip docs * Update d3-state-visualizer docs * Update chart-monitor docs * Create weak-kings-brake.md * Create spicy-olives-compete.md * Create friendly-coats-trade.md * Create slimy-elephants-flash.md * Fix empty arrays
56 lines
1.7 KiB
TypeScript
56 lines
1.7 KiB
TypeScript
import React, { Component, createRef } from 'react';
|
|
import { tree } from 'd3-state-visualizer';
|
|
import type { Options } from 'd3-state-visualizer';
|
|
import { Action, Dispatch } from 'redux';
|
|
import { LiftedAction, LiftedState } from '@redux-devtools/core';
|
|
import * as themes from 'redux-devtools-themes';
|
|
import { ChartMonitorState } from './reducers';
|
|
|
|
const wrapperStyle = {
|
|
width: '100%',
|
|
height: '100%',
|
|
};
|
|
|
|
export interface Props<S, A extends Action<unknown>>
|
|
extends LiftedState<S, A, ChartMonitorState>,
|
|
Options {
|
|
dispatch: Dispatch<LiftedAction<S, A, ChartMonitorState>>;
|
|
preserveScrollTop: boolean;
|
|
select: (state: S) => unknown;
|
|
theme: keyof typeof themes | themes.Base16Theme;
|
|
invertTheme: boolean;
|
|
|
|
state: S | null;
|
|
defaultIsVisible?: boolean;
|
|
}
|
|
|
|
class Chart<S, A extends Action<unknown>> extends Component<Props<S, A>> {
|
|
divRef = createRef<HTMLDivElement>();
|
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
renderChart?: (state?: {} | null | undefined) => void;
|
|
|
|
componentDidMount() {
|
|
const { select, state, defaultIsVisible } = this.props;
|
|
this.renderChart = tree(this.divRef.current!, this.props);
|
|
if (defaultIsVisible) {
|
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
this.renderChart(select(state!) as {} | null | undefined);
|
|
}
|
|
}
|
|
|
|
UNSAFE_componentWillReceiveProps(nextProps: Props<S, A>) {
|
|
const { state, select, monitorState } = nextProps;
|
|
|
|
if (monitorState.isVisible !== false) {
|
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
this.renderChart!(select(state!) as {} | null | undefined);
|
|
}
|
|
}
|
|
|
|
render() {
|
|
return <div style={wrapperStyle} ref={this.divRef} />;
|
|
}
|
|
}
|
|
|
|
export default Chart;
|