mirror of
https://github.com/grafana/grafana.git
synced 2025-08-01 17:33:30 +08:00

* update eslint, tsconfig + esbuild to handle new jsx transform * remove thing that breaks the new jsx transform * remove react imports * adjust grafana-icons build * is this the correct syntax? * try this * well this was much easier than expected... * change grafana-plugin-configs webpack config * fixes * fix lockfile * fix 2 more violations * use path.resolve instead of require.resolve * remove react import * fix react imports * more fixes * remove React import * remove import React from docs * remove another react import
31 lines
944 B
TypeScript
31 lines
944 B
TypeScript
import { Component } from 'react';
|
|
|
|
import { PanelProps } from '@grafana/data';
|
|
|
|
import { CursorView } from './CursorView';
|
|
import { EventBusLoggerPanel } from './EventBusLogger';
|
|
import { RenderInfoViewer } from './RenderInfoViewer';
|
|
import { StateView } from './StateView';
|
|
import { Options, DebugMode } from './panelcfg.gen';
|
|
|
|
type Props = PanelProps<Options>;
|
|
|
|
export class DebugPanel extends Component<Props> {
|
|
render() {
|
|
const { options } = this.props;
|
|
|
|
switch (options.mode) {
|
|
case DebugMode.Events:
|
|
return <EventBusLoggerPanel eventBus={this.props.eventBus} />;
|
|
case DebugMode.Cursor:
|
|
return <CursorView eventBus={this.props.eventBus} />;
|
|
case DebugMode.State:
|
|
return <StateView {...this.props} />;
|
|
case DebugMode.ThrowError:
|
|
throw new Error('I failed you and for that i am deeply sorry');
|
|
default:
|
|
return <RenderInfoViewer {...this.props} />;
|
|
}
|
|
}
|
|
}
|