blob: 9b183ebc87e07db5695ae86762ee602b7f15f311 [file] [log] [blame]
Matteo Scandolo5461a7c2017-08-08 13:05:24 -07001
2/*
3 * Copyright 2017-present Open Networking Foundation
4
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8
9 * http://www.apache.org/licenses/LICENSE-2.0
10
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18
Matteo Scandolofc4b37b2017-02-02 12:18:47 -080019class DemoComponent {
20 static $inject = ['XosSidePanel', 'XosKeyboardShortcut'];
21
22 constructor(
23 private XosSidePanel: any,
24 private XosKeyboardShortcut: any
25 ) {
26 this.XosKeyboardShortcut.registerKeyBinding({
27 key: 'v',
28 description: 'Alert popup',
29 cb: () => {
30 alert('This binding is provided by the "xos-sample-gui-extension"');
31 },
32 }, 'view');
33 }
34
35 togglePanel() {
Max Chu438cdd72017-08-16 16:00:54 -070036 this.XosSidePanel.toggleComponent('xosAlert', {config: {type: 'info'}, show: true}, 'This content is being toggled by my sample UI extension!');
Matteo Scandolofc4b37b2017-02-02 12:18:47 -080037 }
38
39}
40
41export const xosDemoComponent: angular.IComponentOptions = {
42 template: require('./demo.html'),
43 controllerAs: 'vm',
44 controller: DemoComponent
45};