mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* NewPanelEdit: Added angular options to new panel editor and started looking and angular component state * Moved angular component state to redux * Close to working 100% * Think everything is working * AlertTab: Alert tab now gets angularComponent from redux * Fixed panel menu access to angular panel component * Added new tests * Fixed unit test * Fixed strict null errors * Fixed typescript issues * fixed issues
121 lines
3.2 KiB
TypeScript
121 lines
3.2 KiB
TypeScript
// Libraries
|
|
import React, { PureComponent } from 'react';
|
|
import { connect, MapStateToProps, MapDispatchToProps } from 'react-redux';
|
|
// Utils & Services
|
|
import { AngularComponent, getAngularLoader } from '@grafana/runtime';
|
|
// Types
|
|
import { PanelModel, DashboardModel } from '../state';
|
|
import { PanelPlugin, PanelPluginMeta } from '@grafana/data';
|
|
import { PanelCtrl } from 'app/plugins/sdk';
|
|
import { changePanelPlugin } from '../state/actions';
|
|
import { StoreState } from 'app/types';
|
|
|
|
interface OwnProps {
|
|
panel: PanelModel;
|
|
dashboard: DashboardModel;
|
|
plugin: PanelPlugin;
|
|
}
|
|
|
|
interface ConnectedProps {
|
|
angularPanelComponent: AngularComponent;
|
|
}
|
|
|
|
interface DispatchProps {
|
|
changePanelPlugin: typeof changePanelPlugin;
|
|
}
|
|
|
|
type Props = OwnProps & ConnectedProps & DispatchProps;
|
|
|
|
export class AngularPanelOptionsUnconnected extends PureComponent<Props> {
|
|
element?: HTMLElement;
|
|
angularOptions: AngularComponent;
|
|
|
|
constructor(props: Props) {
|
|
super(props);
|
|
}
|
|
|
|
componentDidMount() {
|
|
this.loadAngularOptions();
|
|
}
|
|
|
|
componentDidUpdate(prevProps: Props) {
|
|
if (this.props.plugin !== prevProps.plugin) {
|
|
this.cleanUpAngularOptions();
|
|
}
|
|
|
|
this.loadAngularOptions();
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
this.cleanUpAngularOptions();
|
|
}
|
|
|
|
cleanUpAngularOptions() {
|
|
if (this.angularOptions) {
|
|
this.angularOptions.destroy();
|
|
this.angularOptions = null;
|
|
}
|
|
}
|
|
|
|
loadAngularOptions() {
|
|
const { panel, angularPanelComponent, changePanelPlugin } = this.props;
|
|
|
|
if (!this.element || !angularPanelComponent || this.angularOptions) {
|
|
return;
|
|
}
|
|
|
|
const scope = angularPanelComponent.getScope();
|
|
|
|
// When full page reloading in edit mode the angular panel has on fully compiled & instantiated yet
|
|
if (!scope.$$childHead) {
|
|
setTimeout(() => {
|
|
this.forceUpdate();
|
|
});
|
|
return;
|
|
}
|
|
|
|
const panelCtrl: PanelCtrl = scope.$$childHead.ctrl;
|
|
panelCtrl.initEditMode();
|
|
panelCtrl.onPluginTypeChange = (plugin: PanelPluginMeta) => {
|
|
changePanelPlugin(panel, plugin.id);
|
|
};
|
|
|
|
let template = '';
|
|
for (let i = 0; i < panelCtrl.editorTabs.length; i++) {
|
|
template +=
|
|
`
|
|
<div class="panel-options-group" ng-cloak>` +
|
|
(i > 0
|
|
? `<div class="panel-options-group__header">
|
|
<span class="panel-options-group__title">{{ctrl.editorTabs[${i}].title}}
|
|
</span>
|
|
</div>`
|
|
: '') +
|
|
`<div class="panel-options-group__body">
|
|
<panel-editor-tab editor-tab="ctrl.editorTabs[${i}]" ctrl="ctrl"></panel-editor-tab>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
const loader = getAngularLoader();
|
|
const scopeProps = { ctrl: panelCtrl };
|
|
|
|
this.angularOptions = loader.load(this.element, scopeProps, template);
|
|
}
|
|
|
|
render() {
|
|
return <div ref={elem => (this.element = elem)} />;
|
|
}
|
|
}
|
|
|
|
const mapStateToProps: MapStateToProps<ConnectedProps, OwnProps, StoreState> = (state, props) => {
|
|
return {
|
|
angularPanelComponent: state.dashboard.panels[props.panel.id].angularComponent,
|
|
};
|
|
};
|
|
|
|
const mapDispatchToProps: MapDispatchToProps<DispatchProps, OwnProps> = { changePanelPlugin };
|
|
|
|
export const AngularPanelOptions = connect(mapStateToProps, mapDispatchToProps)(AngularPanelOptionsUnconnected);
|