blob: cc316a22c673b97d39346c3e52e0627cf5a8e91b [file] [log] [blame]
/*
* 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;
}
}