| /* |
| * Copyright 2017-present Open Networking Foundation |
| |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| import * as $ from 'jquery'; |
| import {IXosKeyboardShortcutService} from '../../core/services/keyboard-shortcut'; |
| import {IXosGraphStore} from './graph.store'; |
| import {IXosSidePanelService} from '../../core/side-panel/side-panel.service'; |
| |
| export interface IXosGraphConfig { |
| setupKeyboardShortcuts(): void; |
| toggleFullscreen(): void; |
| } |
| |
| export class XosGraphConfig { |
| |
| static $inject = [ |
| '$log', |
| '$cookies', |
| '$rootScope', |
| '$timeout', |
| 'XosSidePanel', |
| 'XosKeyboardShortcut', |
| 'XosGraphStore' |
| ]; |
| |
| private instanceEnabled = false; |
| private instanceBinding = { |
| key: 'i', |
| modifiers: ['shift'], |
| cb: () => { |
| // NOTE anytime the graph change the observable is updated, |
| // no need to manually retrigger here |
| this.XosGraphStore.toggleInstances(); |
| this.toggleNetworkShortcuts(); |
| }, |
| label: 'i', |
| description: 'Toggle Instances' |
| }; |
| |
| private networkEnabled = false; |
| private networkBinding = { |
| key: 'n', |
| modifiers: ['shift'], |
| cb: () => { |
| // NOTE anytime the graph change the observable is updated, |
| // no need to manually retrigger here |
| this.XosGraphStore.toggleNetwork(); |
| }, |
| label: 'n', |
| description: 'Toggle Networks' |
| }; |
| |
| constructor ( |
| private $log: ng.ILogService, |
| private $cookies: ng.cookies.ICookiesService, |
| private $rootScope: ng.IRootScopeService, |
| private $timeout: ng.ITimeoutService, |
| private XosSidePanel: IXosSidePanelService, |
| private XosKeyboardShortcut: IXosKeyboardShortcutService, |
| private XosGraphStore: IXosGraphStore |
| ) { |
| |
| } |
| |
| public setupKeyboardShortcuts() { |
| |
| this.$log.info(`[XosGraphConfig] Setting up keyboard shortcuts`); |
| |
| // Setup keyboard shortcuts |
| this.XosKeyboardShortcut.registerKeyBinding({ |
| key: 'h', |
| modifiers: ['shift'], |
| cb: () => { |
| this.XosSidePanel.toggleComponent('xosServiceGraphLegend'); |
| }, |
| label: 'h', |
| description: 'Toggle Graph Legend' |
| }); |
| |
| this.XosKeyboardShortcut.registerKeyBinding({ |
| key: 'f', |
| modifiers: ['shift'], |
| cb: () => { |
| this.toggleFullscreen(); |
| }, |
| label: 'f', |
| description: 'Toggle graph fullscreen' |
| }); |
| |
| this.XosKeyboardShortcut.registerKeyBinding({ |
| key: 's', |
| modifiers: ['shift'], |
| cb: () => { |
| this.XosGraphStore.toggleServiceInstances(); |
| this.toggleInstanceShortcuts(); |
| }, |
| label: 's', |
| description: 'Toggle ServiceInstances' |
| }); |
| |
| } |
| |
| public toggleFullscreen() { |
| $('.graph-container').toggleClass('fullscreen'); |
| this.$timeout(() => { |
| // NOTE wait for the CSS transition to complete before repositioning |
| this.$rootScope.$broadcast('xos.sg.update'); |
| }, 500); |
| } |
| |
| private toggleInstanceShortcuts(): void { |
| if (!this.instanceEnabled) { |
| this.XosKeyboardShortcut.registerKeyBinding(this.instanceBinding); |
| } |
| else { |
| this.XosKeyboardShortcut.removeKeyBinding(this.instanceBinding); |
| this.XosKeyboardShortcut.removeKeyBinding(this.networkBinding); |
| } |
| this.instanceEnabled = !this.instanceEnabled; |
| } |
| |
| private toggleNetworkShortcuts(): void { |
| if (!this.networkEnabled) { |
| this.XosKeyboardShortcut.registerKeyBinding(this.networkBinding); |
| } |
| else { |
| this.XosKeyboardShortcut.removeKeyBinding(this.networkBinding); |
| } |
| |
| this.networkEnabled = !this.networkEnabled; |
| } |
| } |