Commit 3e14f8a0 by Torkel Ödegaard

feat(): panel refactoring

parent a950ff97
///<reference path="../../headers/common.d.ts" />
import config from 'app/core/config';
import {PanelCtrl} from './panel_ctrl';
function metricsEditorTab() {
return {templateUrl: 'public/app/partials/metrics.html'};
}
class MetricsPanelCtrl extends PanelCtrl {
constructor($scope) {
super($scope);
}
initEditorTabs() {
super.initEditorTabs();
this.editorTabs.push({title: 'Metrics', directiveFn: metricsEditorTab});
}
}
export {MetricsPanelCtrl};
...@@ -2,75 +2,10 @@ ...@@ -2,75 +2,10 @@
import config from 'app/core/config'; import config from 'app/core/config';
function generalOptionsTabEditorTab() { import {PanelCtrl} from './panel_ctrl';
return {templateUrl: 'public/app/partials/panelgeneral.html'}; import {MetricsPanelCtrl} from './metrics_panel_ctrl';
}
export class PanelCtrl {
panel: any;
row: any;
dashboard: any;
editorTabIndex: number;
name: string;
icon: string;
editorTabs: any;
$scope: any;
constructor($scope) {
var plugin = config.panels[this.panel.type];
this.$scope = $scope;
this.name = plugin.name;
this.icon = plugin.info.icon;
this.editorTabIndex = 0;
this.publishAppEvent('panel-instantiated', {scope: $scope});
}
publishAppEvent(evtName, evt) {
this.$scope.$root.appEvent(evtName, evt);
}
changeView(fullscreen, edit) {
this.publishAppEvent('panel-change-view', {
fullscreen: fullscreen, edit: edit, panelId: this.panel.id
});
}
viewPanel() {
this.changeView(true, false);
}
editPanel() {
if (!this.editorTabs) {
this.initEditorTabs();
}
this.changeView(true, true);
}
exitFullscreen() {
this.changeView(false, false);
}
initEditorTabs() {
this.editorTabs = [];
this.editorTabs.push({title: 'General', directiveFn: generalOptionsTabEditorTab});
this.editorTabs = this.editorTabs.concat(this.getEditorTabs());
}
getEditorTabs() { return [];}
getMenu() {
let menu = [];
menu.push({text: 'View', click: 'ctrl.viewPanel(); dismiss();'});
menu.push({text: 'Edit', click: 'ctrl.editPanel(); dismiss();', role: 'Editor'});
menu.push({text: 'Duplicate', click: 'ctrl.duplicate()', role: 'Editor' });
menu.push({text: 'Share', click: 'ctrl.share(); dismiss();'});
return menu;
}
}
export class PanelDirective { class PanelDirective {
template: string; template: string;
templateUrl: string; templateUrl: string;
bindToController: boolean; bindToController: boolean;
...@@ -99,3 +34,8 @@ export class PanelDirective { ...@@ -99,3 +34,8 @@ export class PanelDirective {
} }
} }
export {
PanelCtrl,
MetricsPanelCtrl,
PanelDirective,
}
///<reference path="../../headers/common.d.ts" />
import config from 'app/core/config';
function generalOptionsTabEditorTab() {
return {templateUrl: 'public/app/partials/panelgeneral.html'};
}
export class PanelCtrl {
panel: any;
row: any;
dashboard: any;
editorTabIndex: number;
name: string;
icon: string;
editorTabs: any;
$scope: any;
isMetricsPanel: boolean;
constructor($scope) {
var plugin = config.panels[this.panel.type];
this.$scope = $scope;
this.name = plugin.name;
this.icon = plugin.info.icon;
this.editorTabIndex = 0;
this.publishAppEvent('panel-instantiated', {scope: $scope});
}
publishAppEvent(evtName, evt) {
this.$scope.$root.appEvent(evtName, evt);
}
changeView(fullscreen, edit) {
this.publishAppEvent('panel-change-view', {
fullscreen: fullscreen, edit: edit, panelId: this.panel.id
});
}
viewPanel() {
this.changeView(true, false);
}
editPanel() {
if (!this.editorTabs) {
this.initEditorTabs();
}
this.changeView(true, true);
}
exitFullscreen() {
this.changeView(false, false);
}
initEditorTabs() {
this.editorTabs = [];
this.editorTabs.push({title: 'General', directiveFn: generalOptionsTabEditorTab});
}
getMenu() {
let menu = [];
menu.push({text: 'View', click: 'ctrl.viewPanel(); dismiss();'});
menu.push({text: 'Edit', click: 'ctrl.editPanel(); dismiss();', role: 'Editor'});
menu.push({text: 'Duplicate', click: 'ctrl.duplicate()', role: 'Editor' });
menu.push({text: 'Share', click: 'ctrl.share(); dismiss();'});
return menu;
}
}
///<reference path="../../../headers/common.d.ts" /> ///<reference path="../../../headers/common.d.ts" />
import {PanelDirective, PanelCtrl} from '../../../features/panel/panel'; import {PanelDirective, MetricsPanelCtrl} from '../../../features/panel/panel';
function optionsTab() { function optionsTab() {
return { return {template: '<h2>options!</h2>' };
template: '<h2>options!</h2>'
};
} }
export class TestPanelCtrl extends PanelCtrl { export class TestPanelCtrl extends MetricsPanelCtrl {
constructor($scope) { constructor($scope) {
super($scope); super($scope);
} }
getEditorTabs() { initEditorTabs() {
return [{title: 'Options', directiveFn: optionsTab}]; super.initEditorTabs();
this.editorTabs.push({title: 'Options', directiveFn: optionsTab});
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment