PanelEditor.tsx 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. import React from 'react';
  2. import { PanelModel } from '../panel_model';
  3. import { DashboardModel } from '../dashboard_model';
  4. import { store } from 'app/stores/store';
  5. import { observer } from 'mobx-react';
  6. import { QueriesTab } from './QueriesTab';
  7. import classNames from 'classnames';
  8. interface PanelEditorProps {
  9. panel: PanelModel;
  10. dashboard: DashboardModel;
  11. }
  12. interface PanelEditorTab {
  13. id: string;
  14. text: string;
  15. icon: string;
  16. }
  17. @observer
  18. export class PanelEditor extends React.Component<PanelEditorProps, any> {
  19. constructor(props) {
  20. super(props);
  21. }
  22. renderQueriesTab() {
  23. return <QueriesTab panel={this.props.panel} dashboard={this.props.dashboard} />;
  24. }
  25. renderVizTab() {
  26. return <h2>Visualizations</h2>;
  27. }
  28. onChangeTab = (tab: PanelEditorTab) => {
  29. store.view.updateQuery({ tab: tab.id }, false);
  30. };
  31. render() {
  32. const activeTab: string = store.view.query.get('tab') || 'queries';
  33. const tabs: PanelEditorTab[] = [
  34. { id: 'queries', text: 'Queries', icon: 'fa fa-database' },
  35. { id: 'viz', text: 'Visualization', icon: 'fa fa-line-chart' },
  36. ];
  37. return (
  38. <div className="tabbed-view tabbed-view--panel-edit-new">
  39. <div className="tabbed-view-header">
  40. <ul className="gf-tabs">
  41. {tabs.map(tab => {
  42. return <TabItem tab={tab} activeTab={activeTab} onClick={this.onChangeTab} key={tab.id} />;
  43. })}
  44. </ul>
  45. <button className="tabbed-view-close-btn" ng-click="ctrl.exitFullscreen();">
  46. <i className="fa fa-remove" />
  47. </button>
  48. </div>
  49. <div className="tabbed-view-body">
  50. {activeTab === 'queries' && this.renderQueriesTab()}
  51. {activeTab === 'viz' && this.renderVizTab()}
  52. </div>
  53. </div>
  54. );
  55. }
  56. }
  57. interface TabItemParams {
  58. tab: PanelEditorTab;
  59. activeTab: string;
  60. onClick: (tab: PanelEditorTab) => void;
  61. }
  62. function TabItem({ tab, activeTab, onClick }: TabItemParams) {
  63. const tabClasses = classNames({
  64. 'gf-tabs-link': true,
  65. active: activeTab === tab.id,
  66. });
  67. return (
  68. <li className="gf-tabs-item" key={tab.id}>
  69. <a className={tabClasses} onClick={() => onClick(tab)}>
  70. <i className={tab.icon} />
  71. {tab.text}
  72. </a>
  73. </li>
  74. );
  75. }