2019-02-03 17:55:58 +08:00
|
|
|
// Libaries
|
|
|
|
|
import React, { PureComponent } from 'react';
|
|
|
|
|
|
|
|
|
|
// Utils & Services
|
|
|
|
|
import { AngularComponent, getAngularLoader } from 'app/core/services/AngularLoader';
|
|
|
|
|
|
|
|
|
|
// Types
|
|
|
|
|
import { DashboardModel } from '../../state/DashboardModel';
|
|
|
|
|
|
|
|
|
|
export interface Props {
|
|
|
|
|
dashboard: DashboardModel | null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export class DashboardSettings extends PureComponent<Props> {
|
|
|
|
|
element: HTMLElement;
|
|
|
|
|
angularCmp: AngularComponent;
|
|
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
|
const loader = getAngularLoader();
|
|
|
|
|
|
|
|
|
|
const template = '<dashboard-settings dashboard="dashboard" class="dashboard-settings" />';
|
|
|
|
|
const scopeProps = { dashboard: this.props.dashboard };
|
|
|
|
|
|
|
|
|
|
this.angularCmp = loader.load(this.element, scopeProps, template);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
|
if (this.angularCmp) {
|
|
|
|
|
this.angularCmp.destroy();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
render() {
|
2019-02-13 18:14:53 +08:00
|
|
|
return <div className="panel-height-helper" ref={element => (this.element = element)} />;
|
2019-02-03 17:55:58 +08:00
|
|
|
}
|
|
|
|
|
}
|