| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- import coreModule from 'app/core/core_module';
- import { getColorModes } from './time_region_manager';
- export class TimeRegionFormCtrl {
- panelCtrl: any;
- panel: any;
- disabled: boolean;
- colorModes: any;
- /** @ngInject */
- constructor($scope) {
- this.panel = this.panelCtrl.panel;
- const unbindDestroy = $scope.$on('$destroy', () => {
- this.panelCtrl.editingTimeRegions = false;
- this.panelCtrl.render();
- unbindDestroy();
- });
- this.colorModes = getColorModes();
- this.panelCtrl.editingTimeRegions = true;
- }
- render() {
- this.panelCtrl.render();
- }
- addTimeRegion() {
- this.panel.timeRegions.push({
- op: 'time',
- fromDayOfWeek: undefined,
- from: undefined,
- toDayOfWeek: undefined,
- to: undefined,
- colorMode: 'background6',
- fill: true,
- line: false,
- // Default colors for new
- fillColor: 'rgba(234, 112, 112, 0.12)',
- lineColor: 'rgba(237, 46, 24, 0.60)',
- });
- this.panelCtrl.render();
- }
- removeTimeRegion(index) {
- this.panel.timeRegions.splice(index, 1);
- this.panelCtrl.render();
- }
- onFillColorChange(index) {
- return newColor => {
- this.panel.timeRegions[index].fillColor = newColor;
- this.render();
- };
- }
- onLineColorChange(index) {
- return newColor => {
- this.panel.timeRegions[index].lineColor = newColor;
- this.render();
- };
- }
- }
- coreModule.directive('graphTimeRegionForm', () => {
- return {
- restrict: 'E',
- templateUrl: 'public/app/plugins/panel/graph/time_regions_form.html',
- controller: TimeRegionFormCtrl,
- bindToController: true,
- controllerAs: 'ctrl',
- scope: {
- panelCtrl: '=',
- },
- };
- });
|