blob: a8669db24900a41566a45822d406c658fe8ffd13 [file] [log] [blame]
/*
* Copyright 2014,2015 Open Networking Laboratory
*
* 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.
*/
/*
ONOS GUI -- Main Application Module
@author Simon Hunt
*/
(function () {
'use strict';
var moduleDependencies = [
// view modules...
// TODO: inject view dependencies server side
// {INJECTED-VIEW-MODULE-DEPENDENCIES}
// NOTE: 'ov' == 'Onos View'...
'ovSample',
'ovTopo',
'ovDevice',
// (end of view modules)
// core modules...
'ngRoute',
'onosUtil',
'onosSvg',
'onosMast'
];
var $log;
angular.module('onosApp', moduleDependencies)
// Create a resize directive, that we can apply to elements to
// respond to window resize events.
.directive('resize', ['$window', function ($window) {
return function (scope, element, attrs) {
var w = angular.element($window);
scope.$watch(function () {
return {
h: window.innerHeight,
w: window.innerWidth
};
}, function (newVal, oldVal) {
scope.windowHeight = newVal.h;
scope.windowWidth = newVal.w;
scope.resizeWithOffset = function (offH, offW) {
var oh = offH || 0,
ow = offW || 0;
scope.$eval(attrs.notifier);
return {
height: (newVal.h - oh) + 'px',
width: (newVal.w - ow) + 'px'
};
};
}, true);
w.bind('resize', function () {
scope.$apply();
});
};
}])
.controller('OnosCtrl', [
'$log', '$route', '$routeParams', '$location',
'KeyService', 'ThemeService', 'GlyphService',
function (_$log_, $route, $routeParams, $location, ks, ts, gs) {
var self = this;
$log = _$log_;
self.$route = $route;
self.$routeParams = $routeParams;
self.$location = $location;
self.version = '1.1.0';
// initialize services...
ts.init();
ks.installOn(d3.select('body'));
gs.init();
$log.log('OnosCtrl has been created');
$log.debug('route: ', self.$route);
$log.debug('routeParams: ', self.$routeParams);
$log.debug('location: ', self.$location);
}])
.config(['$routeProvider', function ($routeProvider) {
// TODO: figure out a way of handling contributed views...
$routeProvider
.when('/', {
controller: 'OvSampleCtrl',
controllerAs: 'ctrl',
templateUrl: 'view/sample/sample.html'
})
.when('/topo', {
controller: 'OvTopoCtrl',
controllerAs: 'ctrl',
templateUrl: 'view/topo/topo.html'
})
.when('/device', {
controller: 'OvDeviceCtrl',
controllerAs: 'ctrl',
templateUrl: 'view/device/device.html'
})
.otherwise({
redirectTo: '/'
})
}]);
}());