Merge branch 'master' of github.com:titilambert/adagios-frontend
Conflicts: app/index.html app/navbar/navbar.js app/sidebar/sidebar.js app/topbar/topbar.css app/topbar/topbar.html
This commit is contained in:
commit
951d35e945
5
.gitignore
vendored
5
.gitignore
vendored
@ -1,4 +1,8 @@
|
|||||||
|
# Logs
|
||||||
logs/*
|
logs/*
|
||||||
|
*.log
|
||||||
|
*.orig
|
||||||
|
|
||||||
!.gitkeep
|
!.gitkeep
|
||||||
node_modules/
|
node_modules/
|
||||||
bower_components/
|
bower_components/
|
||||||
@ -8,3 +12,4 @@ tmp
|
|||||||
*.swp
|
*.swp
|
||||||
app/assets/css
|
app/assets/css
|
||||||
.sass-cache/
|
.sass-cache/
|
||||||
|
out/
|
||||||
|
47
Gruntfile.js
47
Gruntfile.js
@ -1,8 +1,12 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
module.exports = function (grunt) {
|
module.exports = function (grunt) {
|
||||||
grunt.initConfig({
|
|
||||||
|
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-sass');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||||
|
grunt.loadNpmTasks('grunt-jslint');
|
||||||
|
|
||||||
|
grunt.initConfig({
|
||||||
|
|
||||||
pkg: grunt.file.readJSON('package.json'),
|
pkg: grunt.file.readJSON('package.json'),
|
||||||
|
|
||||||
@ -12,7 +16,6 @@ module.exports = function(grunt) {
|
|||||||
css: ['<%= project.assets %>/sass/app.scss']
|
css: ['<%= project.assets %>/sass/app.scss']
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
sass: {
|
sass: {
|
||||||
dev: {
|
dev: {
|
||||||
options: {
|
options: {
|
||||||
@ -33,12 +36,42 @@ module.exports = function(grunt) {
|
|||||||
],
|
],
|
||||||
tasks: ['sass:dev']
|
tasks: ['sass:dev']
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
jslint: { // configure the task
|
||||||
|
|
||||||
|
client: {
|
||||||
|
src: [
|
||||||
|
'karma.conf.js',
|
||||||
|
'Gruntfile.js',
|
||||||
|
'app/app.js',
|
||||||
|
'app/**/*.js'
|
||||||
|
],
|
||||||
|
exclude: [
|
||||||
|
'app/bower_components/**/*.js',
|
||||||
|
'app/assets/**/*'
|
||||||
|
],
|
||||||
|
directives: {
|
||||||
|
node: true,
|
||||||
|
unparam: true, // TEMPORARY: Ignore unused params
|
||||||
|
nomen: true,
|
||||||
|
predef: [ // Global variables
|
||||||
|
'angular', 'inject', 'JustGage',
|
||||||
|
'describe', 'beforeEach', 'it', 'expect'
|
||||||
|
]
|
||||||
|
},
|
||||||
|
options: {
|
||||||
|
edition: 'latest', // specify an edition of jslint or use 'dir/mycustom-jslint.js' for own path
|
||||||
|
junit: 'out/client-junit.xml', // write the output to a JUnit XML
|
||||||
|
log: 'out/client-lint.log',
|
||||||
|
jslintXml: 'out/client-jslint.xml',
|
||||||
|
errorsOnly: true, // only display errors
|
||||||
|
failOnError: false, // defaults to true
|
||||||
|
checkstyle: 'out/client-checkstyle.xml' // write a checkstyle-XML
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
grunt.loadNpmTasks('grunt-contrib-sass');
|
grunt.registerTask('default', [ 'watch', 'jslint' ]);
|
||||||
grunt.loadNpmTasks('grunt-contrib-watch');
|
|
||||||
grunt.registerTask('default', [
|
|
||||||
'watch'
|
|
||||||
]);
|
|
||||||
};
|
};
|
||||||
|
10
app/app.js
10
app/app.js
@ -1,13 +1,13 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
// Declare app level module which depends on views, and components
|
|
||||||
angular.module('adagios', [
|
angular.module('adagios', [
|
||||||
'ngRoute',
|
'ngRoute',
|
||||||
'adagios.sidebar',
|
'adagios.sidebar',
|
||||||
'adagios.navbar',
|
'adagios.topbar',
|
||||||
'adagios.tactical'
|
'adagios.tactical',
|
||||||
]).
|
'adagios.table'
|
||||||
|
])
|
||||||
|
|
||||||
config(['$routeProvider', function($routeProvider) {
|
.config(['$routeProvider', function ($routeProvider) {
|
||||||
$routeProvider.otherwise({redirectTo: '/'});
|
$routeProvider.otherwise({redirectTo: '/'});
|
||||||
}]);
|
}]);
|
||||||
|
13
app/components/live/get_services.js
Normal file
13
app/components/live/get_services.js
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.live')
|
||||||
|
|
||||||
|
.factory('GetServices', ['$http', function ($http, columns) {
|
||||||
|
|
||||||
|
return function (columns) {
|
||||||
|
return $http.get('/rest/status/json/services/?fields=' + columns)
|
||||||
|
.error(function (data, status, headers, config) {
|
||||||
|
console.error('GetServices : GET Request failed');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}]);
|
3
app/components/live/live.js
Normal file
3
app/components/live/live.js
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.live', []);
|
@ -1,10 +1,9 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.live')
|
||||||
|
|
||||||
angular.module('adagios.live', [])
|
|
||||||
.factory('GetProblems', ['$http', function ($http) {
|
.factory('GetProblems', ['$http', function ($http) {
|
||||||
// $http.get("/getproblems")
|
|
||||||
var problem_number = 44;
|
var problem_number = 44;
|
||||||
// factory function body that constructs shinyNewServiceInstance
|
|
||||||
return problem_number;
|
return problem_number;
|
||||||
}]);
|
}]);
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
angular.module("ngJustGage", [])
|
angular.module("ngJustGage", [])
|
||||||
.directive('justGage', ['$timeout', function ($timeout) {
|
.directive('justGage', ['$timeout', function ($timeout) {
|
||||||
return {
|
return {
|
||||||
@ -14,19 +16,25 @@ angular.module("ngJustGage", [])
|
|||||||
template: '<div id="{{id}}-justgage" class="{{class}}"></div>',
|
template: '<div id="{{id}}-justgage" class="{{class}}"></div>',
|
||||||
link: function (scope, element, attrs) {
|
link: function (scope, element, attrs) {
|
||||||
$timeout(function () {
|
$timeout(function () {
|
||||||
var options = {
|
var options, key, graph;
|
||||||
|
|
||||||
|
options = {
|
||||||
id: scope.id + '-justgage',
|
id: scope.id + '-justgage',
|
||||||
min: scope.min,
|
min: scope.min,
|
||||||
max: scope.max,
|
max: scope.max,
|
||||||
title: scope.title,
|
title: scope.title,
|
||||||
value: scope.value
|
value: scope.value
|
||||||
}
|
};
|
||||||
|
|
||||||
if (scope.options) {
|
if (scope.options) {
|
||||||
for (var key in scope.options) {
|
for (key in scope.options) {
|
||||||
|
if (scope.options.hasOwnProperty(key)) {
|
||||||
options[key] = scope.options[key];
|
options[key] = scope.options[key];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var graph = new JustGage(options);
|
}
|
||||||
|
|
||||||
|
graph = new JustGage(options);
|
||||||
|
|
||||||
scope.$watch('max', function (updatedMax) {
|
scope.$watch('max', function (updatedMax) {
|
||||||
if (updatedMax !== undefined) {
|
if (updatedMax !== undefined) {
|
||||||
@ -39,6 +47,7 @@ angular.module("ngJustGage", [])
|
|||||||
graph.refresh(updatedValue);
|
graph.refresh(updatedValue);
|
||||||
}
|
}
|
||||||
}, true);
|
}, true);
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -19,13 +19,15 @@
|
|||||||
<!-- Application -->
|
<!-- Application -->
|
||||||
<script src="app.js"></script>
|
<script src="app.js"></script>
|
||||||
<!-- COMPONENTS -->
|
<!-- COMPONENTS -->
|
||||||
|
<script src="components/live/live.js"></script>
|
||||||
<script src="components/live/notifications.js"></script>
|
<script src="components/live/notifications.js"></script>
|
||||||
|
<script src="components/live/get_services.js"></script>
|
||||||
<script src="components/ng-justgage/ng-justgage.js"></script>
|
<script src="components/ng-justgage/ng-justgage.js"></script>
|
||||||
<!-- MODULES -->
|
<!-- MODULES -->
|
||||||
<!-- Sidebar -->
|
<!-- Sidebar -->
|
||||||
<script src="sidebar/sidebar.js"></script>
|
<script src="sidebar/sidebar.js"></script>
|
||||||
<!-- Navbar -->
|
<!-- Topbar -->
|
||||||
<script src="navbar/navbar.js"></script>
|
<script src="topbar/topbar.js"></script>
|
||||||
<!-- Tactical -->
|
<!-- Tactical -->
|
||||||
<script src="tactical/tactical.js"></script>
|
<script src="tactical/tactical.js"></script>
|
||||||
<!-- Status Overview -->
|
<!-- Status Overview -->
|
||||||
@ -34,6 +36,13 @@
|
|||||||
<script src="tactical/current_health/current_health.js"></script>
|
<script src="tactical/current_health/current_health.js"></script>
|
||||||
<!-- TopAlertProducers -->
|
<!-- TopAlertProducers -->
|
||||||
<script src="tactical/top_alert_producers/top_alert_producers.js"></script>
|
<script src="tactical/top_alert_producers/top_alert_producers.js"></script>
|
||||||
|
<script src="table/table.js"></script>
|
||||||
|
<script src="table/entry/entry.js"></script>
|
||||||
|
<script src="table/entry/column_duration/duration_column.js"></script>
|
||||||
|
<script src="table/entry/column_host/host_column.js"></script>
|
||||||
|
<script src="table/entry/column_last_check/last_check_column.js"></script>
|
||||||
|
<script src="table/entry/column_service_check/service_check_column.js"></script>
|
||||||
|
|
||||||
<script src="bower_components/html5-boilerplate/js/vendor/modernizr-2.6.2.min.js"></script>
|
<script src="bower_components/html5-boilerplate/js/vendor/modernizr-2.6.2.min.js"></script>
|
||||||
</head>
|
</head>
|
||||||
<body class="layout color-scheme--dark">
|
<body class="layout color-scheme--dark">
|
||||||
@ -47,9 +56,7 @@
|
|||||||
|
|
||||||
<div class="layout__main">
|
<div class="layout__main">
|
||||||
<div class="layout__row navbar-wrapper">
|
<div class="layout__row navbar-wrapper">
|
||||||
<navbar></navbar>
|
<topbar></topbar>
|
||||||
</div>
|
|
||||||
|
|
||||||
<main ng-view id="page" class="main layout__row" role="main"></main>
|
<main ng-view id="page" class="main layout__row" role="main"></main>
|
||||||
<footer class="footer layout__row" role="contentinfo">...</footer>
|
<footer class="footer layout__row" role="contentinfo">...</footer>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,18 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
angular.module('adagios.navbar', ['adagios.live'])
|
|
||||||
|
|
||||||
.controller('NavBarCtrl', ['$scope', '$http', 'GetProblems',
|
|
||||||
function($scope, $http, GetProblems) {
|
|
||||||
$scope.notifications = GetProblems;
|
|
||||||
|
|
||||||
}])
|
|
||||||
|
|
||||||
.directive('navbar', function() {
|
|
||||||
return {
|
|
||||||
restrict: 'E',
|
|
||||||
templateUrl: "navbar/navbar.html"
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
angular.module('adagios.sidebar', [])
|
angular.module('adagios.sidebar', [])
|
||||||
|
|
||||||
.controller('SideBarCtrl', ['$scope', '$http',
|
.controller('SideBarCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
function($scope, $http) {
|
return;
|
||||||
|
|
||||||
}])
|
}])
|
||||||
|
|
||||||
|
41
app/sidebar/sidebar_test.js
Normal file
41
app/sidebar/sidebar_test.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
146
app/table/entry/column_duration/duration_column.css
Normal file
146
app/table/entry/column_duration/duration_column.css
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
.nav-side-menu {
|
||||||
|
overflow: auto;
|
||||||
|
font-family: verdana;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 200;
|
||||||
|
background-color: #2e353d;
|
||||||
|
position: fixed;
|
||||||
|
top: 0px;
|
||||||
|
width: 300px;
|
||||||
|
height: 100%;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu .brand {
|
||||||
|
background-color: #23282e;
|
||||||
|
line-height: 50px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul,
|
||||||
|
.nav-side-menu li {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0px;
|
||||||
|
margin: 0px;
|
||||||
|
line-height: 35px;
|
||||||
|
cursor: pointer;
|
||||||
|
/*
|
||||||
|
.collapsed{
|
||||||
|
.arrow:before{
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f053";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left:10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
.nav-side-menu ul :not(collapsed) .arrow:before,
|
||||||
|
.nav-side-menu li :not(collapsed) .arrow:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f078";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .active,
|
||||||
|
.nav-side-menu li .active {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active,
|
||||||
|
.nav-side-menu li .sub-menu li.active {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active a,
|
||||||
|
.nav-side-menu li .sub-menu li.active a {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li,
|
||||||
|
.nav-side-menu li .sub-menu li {
|
||||||
|
background-color: #181c20;
|
||||||
|
border: none;
|
||||||
|
line-height: 28px;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:hover,
|
||||||
|
.nav-side-menu li .sub-menu li:hover {
|
||||||
|
background-color: #020203;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:before,
|
||||||
|
.nav-side-menu li .sub-menu li:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f105";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.nav-side-menu li {
|
||||||
|
padding-left: 0px;
|
||||||
|
border-left: 3px solid #2e353d;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a i {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
}
|
||||||
|
.nav-side-menu li:hover {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
-webkit-transition: all 1s ease;
|
||||||
|
-moz-transition: all 1s ease;
|
||||||
|
-o-transition: all 1s ease;
|
||||||
|
-ms-transition: all 1s ease;
|
||||||
|
transition: all 1s ease;
|
||||||
|
}
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.nav-side-menu {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 10px;
|
||||||
|
top: 10px;
|
||||||
|
z-index: 10 !important;
|
||||||
|
padding: 3px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #000;
|
||||||
|
width: 40px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.brand {
|
||||||
|
text-align: left !important;
|
||||||
|
font-size: 22px;
|
||||||
|
padding-left: 20px;
|
||||||
|
line-height: 50px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (min-width: 767px) {
|
||||||
|
.nav-side-menu .menu-list .menu-content {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
59
app/table/entry/column_duration/duration_column.html
Normal file
59
app/table/entry/column_duration/duration_column.html
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
<div nv-app="adagios.sidebar" class="nav-side-menu" ng-controller="SideBarCtrl">
|
||||||
|
<div class="brand">ADAGIOS</div>
|
||||||
|
<i class="fa fa-bars fa-2x toggle-btn" data-toggle="collapse" data-target="#menu-content"></i>
|
||||||
|
|
||||||
|
<div class="menu-list">
|
||||||
|
|
||||||
|
<ul id="menu-content" class="menu-content out">
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#shortcut" class="collapsed menu-title">
|
||||||
|
<a href="#"> Shortcut <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="shortcut">
|
||||||
|
<li><a href="#/tactical">Dashboard</a></li>
|
||||||
|
<li><a href="#/hosts">Hosts</a></li>
|
||||||
|
<li><a href="#">Services</a></li>
|
||||||
|
<li><a href="#">Networks parents</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#reports" class="collapsed menu-title">
|
||||||
|
<a href="#"> Reports <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="reports">
|
||||||
|
<li><a href="#">State History</a></li>
|
||||||
|
<li><a href="#">Log</a></li>
|
||||||
|
<li><a href="#">Comments</a></li>
|
||||||
|
<li><a href="#">Downtimes</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#groups" class="collapsed menu-title">
|
||||||
|
<a href="#"> Groups <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="groups">
|
||||||
|
<li><a href="#">Hostgroups</a></li>
|
||||||
|
<li><a href="#">Servicegroups</a></li>
|
||||||
|
<li><a href="#">Contactgroups</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#other" class="collapsed menu-title">
|
||||||
|
<a href="#"> Other <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="other">
|
||||||
|
<li><a href="#">Grafana</a></li>
|
||||||
|
<li><a href="#">Nagvis</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<li>
|
||||||
|
<a href="#">
|
||||||
|
<i class="fa fa-user fa-lg"></i> Profile
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
14
app/table/entry/column_duration/duration_column.js
Normal file
14
app/table/entry/column_duration/duration_column.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.table.entry.column_duration', [])
|
||||||
|
|
||||||
|
.controller('SideBarCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
|
return;
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('sidebar', function () {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "sidebar/sidebar.html"
|
||||||
|
};
|
||||||
|
});
|
41
app/table/entry/column_duration/duration_column_test.js
Normal file
41
app/table/entry/column_duration/duration_column_test.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
146
app/table/entry/column_host/host_column.css
Normal file
146
app/table/entry/column_host/host_column.css
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
.nav-side-menu {
|
||||||
|
overflow: auto;
|
||||||
|
font-family: verdana;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 200;
|
||||||
|
background-color: #2e353d;
|
||||||
|
position: fixed;
|
||||||
|
top: 0px;
|
||||||
|
width: 300px;
|
||||||
|
height: 100%;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu .brand {
|
||||||
|
background-color: #23282e;
|
||||||
|
line-height: 50px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul,
|
||||||
|
.nav-side-menu li {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0px;
|
||||||
|
margin: 0px;
|
||||||
|
line-height: 35px;
|
||||||
|
cursor: pointer;
|
||||||
|
/*
|
||||||
|
.collapsed{
|
||||||
|
.arrow:before{
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f053";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left:10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
.nav-side-menu ul :not(collapsed) .arrow:before,
|
||||||
|
.nav-side-menu li :not(collapsed) .arrow:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f078";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .active,
|
||||||
|
.nav-side-menu li .active {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active,
|
||||||
|
.nav-side-menu li .sub-menu li.active {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active a,
|
||||||
|
.nav-side-menu li .sub-menu li.active a {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li,
|
||||||
|
.nav-side-menu li .sub-menu li {
|
||||||
|
background-color: #181c20;
|
||||||
|
border: none;
|
||||||
|
line-height: 28px;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:hover,
|
||||||
|
.nav-side-menu li .sub-menu li:hover {
|
||||||
|
background-color: #020203;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:before,
|
||||||
|
.nav-side-menu li .sub-menu li:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f105";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.nav-side-menu li {
|
||||||
|
padding-left: 0px;
|
||||||
|
border-left: 3px solid #2e353d;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a i {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
}
|
||||||
|
.nav-side-menu li:hover {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
-webkit-transition: all 1s ease;
|
||||||
|
-moz-transition: all 1s ease;
|
||||||
|
-o-transition: all 1s ease;
|
||||||
|
-ms-transition: all 1s ease;
|
||||||
|
transition: all 1s ease;
|
||||||
|
}
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.nav-side-menu {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 10px;
|
||||||
|
top: 10px;
|
||||||
|
z-index: 10 !important;
|
||||||
|
padding: 3px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #000;
|
||||||
|
width: 40px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.brand {
|
||||||
|
text-align: left !important;
|
||||||
|
font-size: 22px;
|
||||||
|
padding-left: 20px;
|
||||||
|
line-height: 50px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (min-width: 767px) {
|
||||||
|
.nav-side-menu .menu-list .menu-content {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
59
app/table/entry/column_host/host_column.html
Normal file
59
app/table/entry/column_host/host_column.html
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
<div nv-app="adagios.sidebar" class="nav-side-menu" ng-controller="SideBarCtrl">
|
||||||
|
<div class="brand">ADAGIOS</div>
|
||||||
|
<i class="fa fa-bars fa-2x toggle-btn" data-toggle="collapse" data-target="#menu-content"></i>
|
||||||
|
|
||||||
|
<div class="menu-list">
|
||||||
|
|
||||||
|
<ul id="menu-content" class="menu-content out">
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#shortcut" class="collapsed menu-title">
|
||||||
|
<a href="#"> Shortcut <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="shortcut">
|
||||||
|
<li><a href="#/tactical">Dashboard</a></li>
|
||||||
|
<li><a href="#/hosts">Hosts</a></li>
|
||||||
|
<li><a href="#">Services</a></li>
|
||||||
|
<li><a href="#">Networks parents</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#reports" class="collapsed menu-title">
|
||||||
|
<a href="#"> Reports <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="reports">
|
||||||
|
<li><a href="#">State History</a></li>
|
||||||
|
<li><a href="#">Log</a></li>
|
||||||
|
<li><a href="#">Comments</a></li>
|
||||||
|
<li><a href="#">Downtimes</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#groups" class="collapsed menu-title">
|
||||||
|
<a href="#"> Groups <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="groups">
|
||||||
|
<li><a href="#">Hostgroups</a></li>
|
||||||
|
<li><a href="#">Servicegroups</a></li>
|
||||||
|
<li><a href="#">Contactgroups</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#other" class="collapsed menu-title">
|
||||||
|
<a href="#"> Other <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="other">
|
||||||
|
<li><a href="#">Grafana</a></li>
|
||||||
|
<li><a href="#">Nagvis</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<li>
|
||||||
|
<a href="#">
|
||||||
|
<i class="fa fa-user fa-lg"></i> Profile
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
14
app/table/entry/column_host/host_column.js
Normal file
14
app/table/entry/column_host/host_column.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.table.entry.column_host', [])
|
||||||
|
|
||||||
|
.controller('SideBarCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
|
return;
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('sidebar', function () {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "sidebar/sidebar.html"
|
||||||
|
};
|
||||||
|
});
|
41
app/table/entry/column_host/host_column_test.js
Normal file
41
app/table/entry/column_host/host_column_test.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
146
app/table/entry/column_last_check/last_check_column.css
Normal file
146
app/table/entry/column_last_check/last_check_column.css
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
.nav-side-menu {
|
||||||
|
overflow: auto;
|
||||||
|
font-family: verdana;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 200;
|
||||||
|
background-color: #2e353d;
|
||||||
|
position: fixed;
|
||||||
|
top: 0px;
|
||||||
|
width: 300px;
|
||||||
|
height: 100%;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu .brand {
|
||||||
|
background-color: #23282e;
|
||||||
|
line-height: 50px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul,
|
||||||
|
.nav-side-menu li {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0px;
|
||||||
|
margin: 0px;
|
||||||
|
line-height: 35px;
|
||||||
|
cursor: pointer;
|
||||||
|
/*
|
||||||
|
.collapsed{
|
||||||
|
.arrow:before{
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f053";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left:10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
.nav-side-menu ul :not(collapsed) .arrow:before,
|
||||||
|
.nav-side-menu li :not(collapsed) .arrow:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f078";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .active,
|
||||||
|
.nav-side-menu li .active {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active,
|
||||||
|
.nav-side-menu li .sub-menu li.active {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active a,
|
||||||
|
.nav-side-menu li .sub-menu li.active a {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li,
|
||||||
|
.nav-side-menu li .sub-menu li {
|
||||||
|
background-color: #181c20;
|
||||||
|
border: none;
|
||||||
|
line-height: 28px;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:hover,
|
||||||
|
.nav-side-menu li .sub-menu li:hover {
|
||||||
|
background-color: #020203;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:before,
|
||||||
|
.nav-side-menu li .sub-menu li:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f105";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.nav-side-menu li {
|
||||||
|
padding-left: 0px;
|
||||||
|
border-left: 3px solid #2e353d;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a i {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
}
|
||||||
|
.nav-side-menu li:hover {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
-webkit-transition: all 1s ease;
|
||||||
|
-moz-transition: all 1s ease;
|
||||||
|
-o-transition: all 1s ease;
|
||||||
|
-ms-transition: all 1s ease;
|
||||||
|
transition: all 1s ease;
|
||||||
|
}
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.nav-side-menu {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 10px;
|
||||||
|
top: 10px;
|
||||||
|
z-index: 10 !important;
|
||||||
|
padding: 3px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #000;
|
||||||
|
width: 40px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.brand {
|
||||||
|
text-align: left !important;
|
||||||
|
font-size: 22px;
|
||||||
|
padding-left: 20px;
|
||||||
|
line-height: 50px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (min-width: 767px) {
|
||||||
|
.nav-side-menu .menu-list .menu-content {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
59
app/table/entry/column_last_check/last_check_column.html
Normal file
59
app/table/entry/column_last_check/last_check_column.html
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
<div nv-app="adagios.sidebar" class="nav-side-menu" ng-controller="SideBarCtrl">
|
||||||
|
<div class="brand">ADAGIOS</div>
|
||||||
|
<i class="fa fa-bars fa-2x toggle-btn" data-toggle="collapse" data-target="#menu-content"></i>
|
||||||
|
|
||||||
|
<div class="menu-list">
|
||||||
|
|
||||||
|
<ul id="menu-content" class="menu-content out">
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#shortcut" class="collapsed menu-title">
|
||||||
|
<a href="#"> Shortcut <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="shortcut">
|
||||||
|
<li><a href="#/tactical">Dashboard</a></li>
|
||||||
|
<li><a href="#/hosts">Hosts</a></li>
|
||||||
|
<li><a href="#">Services</a></li>
|
||||||
|
<li><a href="#">Networks parents</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#reports" class="collapsed menu-title">
|
||||||
|
<a href="#"> Reports <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="reports">
|
||||||
|
<li><a href="#">State History</a></li>
|
||||||
|
<li><a href="#">Log</a></li>
|
||||||
|
<li><a href="#">Comments</a></li>
|
||||||
|
<li><a href="#">Downtimes</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#groups" class="collapsed menu-title">
|
||||||
|
<a href="#"> Groups <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="groups">
|
||||||
|
<li><a href="#">Hostgroups</a></li>
|
||||||
|
<li><a href="#">Servicegroups</a></li>
|
||||||
|
<li><a href="#">Contactgroups</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#other" class="collapsed menu-title">
|
||||||
|
<a href="#"> Other <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="other">
|
||||||
|
<li><a href="#">Grafana</a></li>
|
||||||
|
<li><a href="#">Nagvis</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<li>
|
||||||
|
<a href="#">
|
||||||
|
<i class="fa fa-user fa-lg"></i> Profile
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
14
app/table/entry/column_last_check/last_check_column.js
Normal file
14
app/table/entry/column_last_check/last_check_column.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.table.entry.column_last_check', [])
|
||||||
|
|
||||||
|
.controller('SideBarCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
|
return;
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('sidebar', function () {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "sidebar/sidebar.html"
|
||||||
|
};
|
||||||
|
});
|
41
app/table/entry/column_last_check/last_check_column_test.js
Normal file
41
app/table/entry/column_last_check/last_check_column_test.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
146
app/table/entry/column_service_check/service_check_column.css
Normal file
146
app/table/entry/column_service_check/service_check_column.css
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
.nav-side-menu {
|
||||||
|
overflow: auto;
|
||||||
|
font-family: verdana;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 200;
|
||||||
|
background-color: #2e353d;
|
||||||
|
position: fixed;
|
||||||
|
top: 0px;
|
||||||
|
width: 300px;
|
||||||
|
height: 100%;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu .brand {
|
||||||
|
background-color: #23282e;
|
||||||
|
line-height: 50px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul,
|
||||||
|
.nav-side-menu li {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0px;
|
||||||
|
margin: 0px;
|
||||||
|
line-height: 35px;
|
||||||
|
cursor: pointer;
|
||||||
|
/*
|
||||||
|
.collapsed{
|
||||||
|
.arrow:before{
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f053";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left:10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
.nav-side-menu ul :not(collapsed) .arrow:before,
|
||||||
|
.nav-side-menu li :not(collapsed) .arrow:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f078";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .active,
|
||||||
|
.nav-side-menu li .active {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active,
|
||||||
|
.nav-side-menu li .sub-menu li.active {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active a,
|
||||||
|
.nav-side-menu li .sub-menu li.active a {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li,
|
||||||
|
.nav-side-menu li .sub-menu li {
|
||||||
|
background-color: #181c20;
|
||||||
|
border: none;
|
||||||
|
line-height: 28px;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:hover,
|
||||||
|
.nav-side-menu li .sub-menu li:hover {
|
||||||
|
background-color: #020203;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:before,
|
||||||
|
.nav-side-menu li .sub-menu li:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f105";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.nav-side-menu li {
|
||||||
|
padding-left: 0px;
|
||||||
|
border-left: 3px solid #2e353d;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a i {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
}
|
||||||
|
.nav-side-menu li:hover {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
-webkit-transition: all 1s ease;
|
||||||
|
-moz-transition: all 1s ease;
|
||||||
|
-o-transition: all 1s ease;
|
||||||
|
-ms-transition: all 1s ease;
|
||||||
|
transition: all 1s ease;
|
||||||
|
}
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.nav-side-menu {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 10px;
|
||||||
|
top: 10px;
|
||||||
|
z-index: 10 !important;
|
||||||
|
padding: 3px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #000;
|
||||||
|
width: 40px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.brand {
|
||||||
|
text-align: left !important;
|
||||||
|
font-size: 22px;
|
||||||
|
padding-left: 20px;
|
||||||
|
line-height: 50px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (min-width: 767px) {
|
||||||
|
.nav-side-menu .menu-list .menu-content {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,59 @@
|
|||||||
|
<div nv-app="adagios.sidebar" class="nav-side-menu" ng-controller="SideBarCtrl">
|
||||||
|
<div class="brand">ADAGIOS</div>
|
||||||
|
<i class="fa fa-bars fa-2x toggle-btn" data-toggle="collapse" data-target="#menu-content"></i>
|
||||||
|
|
||||||
|
<div class="menu-list">
|
||||||
|
|
||||||
|
<ul id="menu-content" class="menu-content out">
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#shortcut" class="collapsed menu-title">
|
||||||
|
<a href="#"> Shortcut <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="shortcut">
|
||||||
|
<li><a href="#/tactical">Dashboard</a></li>
|
||||||
|
<li><a href="#/hosts">Hosts</a></li>
|
||||||
|
<li><a href="#">Services</a></li>
|
||||||
|
<li><a href="#">Networks parents</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#reports" class="collapsed menu-title">
|
||||||
|
<a href="#"> Reports <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="reports">
|
||||||
|
<li><a href="#">State History</a></li>
|
||||||
|
<li><a href="#">Log</a></li>
|
||||||
|
<li><a href="#">Comments</a></li>
|
||||||
|
<li><a href="#">Downtimes</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#groups" class="collapsed menu-title">
|
||||||
|
<a href="#"> Groups <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="groups">
|
||||||
|
<li><a href="#">Hostgroups</a></li>
|
||||||
|
<li><a href="#">Servicegroups</a></li>
|
||||||
|
<li><a href="#">Contactgroups</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<li data-toggle="collapse" data-target="#other" class="collapsed menu-title">
|
||||||
|
<a href="#"> Other <span class="arrow"></span></a>
|
||||||
|
</li>
|
||||||
|
<ul class="sub-menu collapse" id="other">
|
||||||
|
<li><a href="#">Grafana</a></li>
|
||||||
|
<li><a href="#">Nagvis</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<li>
|
||||||
|
<a href="#">
|
||||||
|
<i class="fa fa-user fa-lg"></i> Profile
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
14
app/table/entry/column_service_check/service_check_column.js
Normal file
14
app/table/entry/column_service_check/service_check_column.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.table.entry.column_service_check', [])
|
||||||
|
|
||||||
|
.controller('SideBarCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
|
return;
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('column', function (col_type) {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "column/" + col_type + ".html"
|
||||||
|
};
|
||||||
|
});
|
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
146
app/table/entry/entry.css
Normal file
146
app/table/entry/entry.css
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
.nav-side-menu {
|
||||||
|
overflow: auto;
|
||||||
|
font-family: verdana;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 200;
|
||||||
|
background-color: #2e353d;
|
||||||
|
position: fixed;
|
||||||
|
top: 0px;
|
||||||
|
width: 300px;
|
||||||
|
height: 100%;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu .brand {
|
||||||
|
background-color: #23282e;
|
||||||
|
line-height: 50px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul,
|
||||||
|
.nav-side-menu li {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0px;
|
||||||
|
margin: 0px;
|
||||||
|
line-height: 35px;
|
||||||
|
cursor: pointer;
|
||||||
|
/*
|
||||||
|
.collapsed{
|
||||||
|
.arrow:before{
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f053";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left:10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
.nav-side-menu ul :not(collapsed) .arrow:before,
|
||||||
|
.nav-side-menu li :not(collapsed) .arrow:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f078";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .active,
|
||||||
|
.nav-side-menu li .active {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active,
|
||||||
|
.nav-side-menu li .sub-menu li.active {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active a,
|
||||||
|
.nav-side-menu li .sub-menu li.active a {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li,
|
||||||
|
.nav-side-menu li .sub-menu li {
|
||||||
|
background-color: #181c20;
|
||||||
|
border: none;
|
||||||
|
line-height: 28px;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:hover,
|
||||||
|
.nav-side-menu li .sub-menu li:hover {
|
||||||
|
background-color: #020203;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:before,
|
||||||
|
.nav-side-menu li .sub-menu li:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f105";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.nav-side-menu li {
|
||||||
|
padding-left: 0px;
|
||||||
|
border-left: 3px solid #2e353d;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a i {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
}
|
||||||
|
.nav-side-menu li:hover {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
-webkit-transition: all 1s ease;
|
||||||
|
-moz-transition: all 1s ease;
|
||||||
|
-o-transition: all 1s ease;
|
||||||
|
-ms-transition: all 1s ease;
|
||||||
|
transition: all 1s ease;
|
||||||
|
}
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.nav-side-menu {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 10px;
|
||||||
|
top: 10px;
|
||||||
|
z-index: 10 !important;
|
||||||
|
padding: 3px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #000;
|
||||||
|
width: 40px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.brand {
|
||||||
|
text-align: left !important;
|
||||||
|
font-size: 22px;
|
||||||
|
padding-left: 20px;
|
||||||
|
line-height: 50px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (min-width: 767px) {
|
||||||
|
.nav-side-menu .menu-list .menu-content {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
4
app/table/entry/entry.html
Normal file
4
app/table/entry/entry.html
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
<td> {{entry.host_name}} </td>
|
||||||
|
<td> {{entry.description}} </td>
|
||||||
|
<td> {{entry.last_check}} </td>
|
||||||
|
<td> {{entry.last_hard_state_change}} </td>
|
18
app/table/entry/entry.js
Normal file
18
app/table/entry/entry.js
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.table.entry', ['adagios.table.entry.column_duration',
|
||||||
|
'adagios.table.entry.column_host',
|
||||||
|
'adagios.table.entry.column_last_check',
|
||||||
|
'adagios.table.entry.column_service_check'
|
||||||
|
])
|
||||||
|
|
||||||
|
.controller('EntryCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
|
return;
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('entry', function () {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "table/entry/entry.html"
|
||||||
|
};
|
||||||
|
});
|
41
app/table/entry/entry_test.js
Normal file
41
app/table/entry/entry_test.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
146
app/table/table.css
Normal file
146
app/table/table.css
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
.nav-side-menu {
|
||||||
|
overflow: auto;
|
||||||
|
font-family: verdana;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 200;
|
||||||
|
background-color: #2e353d;
|
||||||
|
position: fixed;
|
||||||
|
top: 0px;
|
||||||
|
width: 300px;
|
||||||
|
height: 100%;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu .brand {
|
||||||
|
background-color: #23282e;
|
||||||
|
line-height: 50px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul,
|
||||||
|
.nav-side-menu li {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0px;
|
||||||
|
margin: 0px;
|
||||||
|
line-height: 35px;
|
||||||
|
cursor: pointer;
|
||||||
|
/*
|
||||||
|
.collapsed{
|
||||||
|
.arrow:before{
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f053";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left:10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
.nav-side-menu ul :not(collapsed) .arrow:before,
|
||||||
|
.nav-side-menu li :not(collapsed) .arrow:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f078";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .active,
|
||||||
|
.nav-side-menu li .active {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active,
|
||||||
|
.nav-side-menu li .sub-menu li.active {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li.active a,
|
||||||
|
.nav-side-menu li .sub-menu li.active a {
|
||||||
|
color: #d19b3d;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li,
|
||||||
|
.nav-side-menu li .sub-menu li {
|
||||||
|
background-color: #181c20;
|
||||||
|
border: none;
|
||||||
|
line-height: 28px;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:hover,
|
||||||
|
.nav-side-menu li .sub-menu li:hover {
|
||||||
|
background-color: #020203;
|
||||||
|
}
|
||||||
|
.nav-side-menu ul .sub-menu li:before,
|
||||||
|
.nav-side-menu li .sub-menu li:before {
|
||||||
|
font-family: FontAwesome;
|
||||||
|
content: "\f105";
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.nav-side-menu li {
|
||||||
|
padding-left: 0px;
|
||||||
|
border-left: 3px solid #2e353d;
|
||||||
|
border-bottom: 1px solid #23282e;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a {
|
||||||
|
text-decoration: none;
|
||||||
|
color: #e1ffff;
|
||||||
|
}
|
||||||
|
.nav-side-menu li a i {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
}
|
||||||
|
.nav-side-menu li:hover {
|
||||||
|
border-left: 3px solid #d19b3d;
|
||||||
|
background-color: #4f5b69;
|
||||||
|
-webkit-transition: all 1s ease;
|
||||||
|
-moz-transition: all 1s ease;
|
||||||
|
-o-transition: all 1s ease;
|
||||||
|
-ms-transition: all 1s ease;
|
||||||
|
transition: all 1s ease;
|
||||||
|
}
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.nav-side-menu {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.nav-side-menu .toggle-btn {
|
||||||
|
display: block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 10px;
|
||||||
|
top: 10px;
|
||||||
|
z-index: 10 !important;
|
||||||
|
padding: 3px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #000;
|
||||||
|
width: 40px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.brand {
|
||||||
|
text-align: left !important;
|
||||||
|
font-size: 22px;
|
||||||
|
padding-left: 20px;
|
||||||
|
line-height: 50px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@media (min-width: 767px) {
|
||||||
|
.nav-side-menu .menu-list .menu-content {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
16
app/table/table.html
Normal file
16
app/table/table.html
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<div ng-app="adagios.table" ng-controller="TableCtrl" id="table">
|
||||||
|
<table class="table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th ng-repeat="(key, value) in entries[0]">
|
||||||
|
{{key}}
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tr ng-repeat="entry in entries">
|
||||||
|
<td ng-repeat="(key, value) in entry">
|
||||||
|
{{value}}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</div>
|
17
app/table/table.js
Normal file
17
app/table/table.js
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.table', ['ngRoute', 'adagios.table.entry', 'adagios.live'])
|
||||||
|
|
||||||
|
.controller('TableCtrl', ['$scope', '$http', 'GetServices', function ($scope, $http, GetServices) {
|
||||||
|
console.log(new GetServices(['host_name', 'last_check'])
|
||||||
|
.success(function (data) {
|
||||||
|
$scope.entries = data;
|
||||||
|
}));
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('servicesTable', function () {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "table/table.html"
|
||||||
|
};
|
||||||
|
});
|
41
app/table/table_test.js
Normal file
41
app/table/table_test.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Sidebar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.sidebar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('sidebar/sidebar.html').respond('<li></li>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('SideBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
ctrl = $controller('SideBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Sidebar directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile('<sidebar></sidebar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.html()).toBe('<li></li>');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
@ -1,9 +1,8 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
angular.module('adagios.tactical.current_health', ['ngRoute',
|
angular.module('adagios.tactical.current_health', ['ngRoute', 'ngJustGage' ])
|
||||||
'ngJustGage'
|
|
||||||
])
|
.controller('TacticalCurrentHealth', ['$scope', '$http', function ($scope, $http) {
|
||||||
.controller('TacticalCurrentHealth', ['$scope', '$http',
|
|
||||||
function($scope, $http) {
|
|
||||||
$scope.hosts = 75.2;
|
$scope.hosts = 75.2;
|
||||||
$scope.services = 94.4;
|
$scope.services = 94.4;
|
||||||
}])
|
}])
|
||||||
@ -14,5 +13,3 @@ angular.module('adagios.tactical.current_health', ['ngRoute',
|
|||||||
templateUrl: "tactical/current_health/current_health.html"
|
templateUrl: "tactical/current_health/current_health.html"
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
43
app/tactical/current_health/current_health_test.js
Normal file
43
app/tactical/current_health/current_health_test.js
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Current Health tactical submodule', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.tactical.current_health'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('tactical/current_health/current_health.html')
|
||||||
|
.respond('<th>Current Health</th>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('TacticalCurrentHealth', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope, ctrl;
|
||||||
|
scope = {};
|
||||||
|
ctrl = $controller('TacticalCurrentHealth', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Current health directive', function () {
|
||||||
|
|
||||||
|
it('should send a GET request', function () {
|
||||||
|
var element = $compile("<currenthealth></currenthealth>")($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
|
||||||
|
expect(element.text()).toBe('Current Health');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
@ -1,12 +1,17 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
angular.module('adagios.tactical.status_overview', ['ngRoute'
|
angular.module('adagios.tactical.status_overview', ['ngRoute' ])
|
||||||
])
|
|
||||||
.controller('TacticalStatusOverViewCtrl', ['$scope', '$http',
|
.controller('TacticalStatusOverViewCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
function($scope, $http) {
|
$scope.hosts = {
|
||||||
$scope.hosts = {"count": 104,
|
"count": 104,
|
||||||
"problems": 14};
|
"problems": 14
|
||||||
$scope.services = {"count": 1126,
|
};
|
||||||
"problems": 42};
|
|
||||||
|
$scope.services = {
|
||||||
|
"count": 1126,
|
||||||
|
"problems": 42
|
||||||
|
};
|
||||||
}])
|
}])
|
||||||
|
|
||||||
.directive('statusoverview', function () {
|
.directive('statusoverview', function () {
|
||||||
@ -15,5 +20,3 @@ angular.module('adagios.tactical.status_overview', ['ngRoute'
|
|||||||
templateUrl: "tactical/status_overview/status_overview.html"
|
templateUrl: "tactical/status_overview/status_overview.html"
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
45
app/tactical/status_overview/status_overview_test.js
Normal file
45
app/tactical/status_overview/status_overview_test.js
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Status Overview tactical submodule', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.tactical.status_overview'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('tactical/status_overview/status_overview.html')
|
||||||
|
.respond('<td>{{ problems }}</td>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('TacticalStatusOverViewCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope, ctrl;
|
||||||
|
scope = {};
|
||||||
|
ctrl = $controller('TacticalStatusOverViewCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Status overview directive', function () {
|
||||||
|
|
||||||
|
it('should insert the number of warnings', function () {
|
||||||
|
var element = $compile('<statusoverview></statusoverview>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
$rootScope.problems = 31;
|
||||||
|
$rootScope.$digest();
|
||||||
|
|
||||||
|
expect(element.text()).toBe('31');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
@ -19,4 +19,6 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<services-table></services-table>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,17 +1,20 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
angular.module('adagios.tactical', ['ngRoute',
|
angular.module('adagios.tactical', ['ngRoute',
|
||||||
'adagios.tactical.status_overview',
|
'adagios.tactical.status_overview',
|
||||||
'adagios.tactical.current_health',
|
'adagios.tactical.current_health',
|
||||||
'adagios.tactical.top_alert_producers'
|
'adagios.tactical.top_alert_producers',
|
||||||
|
'adagios.table'
|
||||||
|
|
||||||
])
|
])
|
||||||
|
|
||||||
.config(['$routeProvider', function ($routeProvider) {
|
.config(['$routeProvider', function ($routeProvider) {
|
||||||
$routeProvider.when('/tactical', {templateUrl: 'tactical/tactical.html', controller: 'TacticalCtrl'});
|
$routeProvider.when('/tactical', {
|
||||||
}])
|
templateUrl: 'tactical/tactical.html',
|
||||||
|
controller: 'TacticalCtrl'
|
||||||
|
});
|
||||||
|
|
||||||
.controller('TacticalCtrl', ['$scope', '$http',
|
|
||||||
function($scope, $http) {
|
|
||||||
}])
|
}])
|
||||||
|
|
||||||
|
.controller('TacticalCtrl', ['$scope', '$http', function ($scope, $http) {
|
||||||
|
return;
|
||||||
|
}]);
|
||||||
|
18
app/tactical/tactical_test.js
Normal file
18
app/tactical/tactical_test.js
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Tactical module', function () {
|
||||||
|
|
||||||
|
beforeEach(module('adagios.tactical'));
|
||||||
|
|
||||||
|
describe('TacticalCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', inject(function ($controller) {
|
||||||
|
var scope, ctrl;
|
||||||
|
scope = {};
|
||||||
|
ctrl = $controller('TacticalCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
}));
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
@ -1,11 +1,21 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
angular.module('adagios.tactical.top_alert_producers', ['ngRoute'
|
angular.module('adagios.tactical.top_alert_producers', ['ngRoute' ])
|
||||||
])
|
.controller('TacticalTopAlertProducers', ['$scope', '$http', function ($scope, $http) {
|
||||||
.controller('TacticalTopAlertProducers', ['$scope', '$http',
|
$scope.hosts = [
|
||||||
function($scope, $http) {
|
{
|
||||||
$scope.hosts = [{"host_name": "server-18", "problems": 10},
|
"host_name": "server-18",
|
||||||
{"host_name": "server-22", "problems": 5},
|
"problems": 10
|
||||||
{"host_name": "server-13", "problems": 3}]
|
},
|
||||||
|
{
|
||||||
|
"host_name": "server-22",
|
||||||
|
"problems": 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"host_name": "server-13",
|
||||||
|
"problems": 3
|
||||||
|
}
|
||||||
|
];
|
||||||
}])
|
}])
|
||||||
|
|
||||||
.directive('topalertproducers', function () {
|
.directive('topalertproducers', function () {
|
||||||
@ -14,5 +24,3 @@ angular.module('adagios.tactical.top_alert_producers', ['ngRoute'
|
|||||||
templateUrl: "tactical/top_alert_producers/top_alert_producers.html"
|
templateUrl: "tactical/top_alert_producers/top_alert_producers.html"
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
45
app/tactical/top_alert_producers/top_alert_producers_test.js
Normal file
45
app/tactical/top_alert_producers/top_alert_producers_test.js
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Top Alert Producer tactical submodule', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.tactical.top_alert_producers'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('tactical/top_alert_producers/top_alert_producers.html')
|
||||||
|
.respond('<td>{{ problems }}</td>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('TacticalTopAlertProducers', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope, ctrl;
|
||||||
|
scope = {};
|
||||||
|
ctrl = $controller('TacticalTopAlertProducers', { $scope : scope });
|
||||||
|
|
||||||
|
expect(ctrl).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Status overview directive', function () {
|
||||||
|
|
||||||
|
it('should insert the number of warnings', function () {
|
||||||
|
var element = $compile('<topalertproducers></topalertproducers>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
$rootScope.problems = 31;
|
||||||
|
$rootScope.$digest();
|
||||||
|
|
||||||
|
expect(element.text()).toBe('31');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
63
app/topbar/topbar.css
Normal file
63
app/topbar/topbar.css
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
nav#topbar {
|
||||||
|
top: 0%;
|
||||||
|
margin-left: 300px;
|
||||||
|
background-color: #353d48;
|
||||||
|
border-radius: 0px;
|
||||||
|
border: none;
|
||||||
|
height: 82px;
|
||||||
|
min-height: 82px;
|
||||||
|
margin-bottom: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
nav#topbar div.container-fluid{
|
||||||
|
padding-left: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
nav#topbar .navbar-brand{ padding: 0px 30px;font-size: 1.5em;line-height: 80px; }
|
||||||
|
nav#topbar .navbar-nav > li > a { padding: 0px 30px; line-height: 80px; font-size: 1.5em; }
|
||||||
|
nav#topbar .navbar-nav > li > form div {
|
||||||
|
line-height: 55px;
|
||||||
|
font-size: 1.5em;
|
||||||
|
}
|
||||||
|
nav#topbar .navbar-nav > li > form input {
|
||||||
|
height: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
nav#topbar div.navbar-collapse {
|
||||||
|
padding-left: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
form#search input {
|
||||||
|
border: none;
|
||||||
|
background-color: #353d48;
|
||||||
|
font-size: 1.5em;
|
||||||
|
color: #aeb5bf;
|
||||||
|
width: 400px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
a#toggle-sidebar .fa-chevron-left {
|
||||||
|
font-size: 0.5em;
|
||||||
|
vertical-align: super;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
a#search i,
|
||||||
|
a#settings i,
|
||||||
|
a#notifications i,
|
||||||
|
a#toggle-sidebar i {
|
||||||
|
font-size: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
nav#topbar li {
|
||||||
|
border-color: #252b37;
|
||||||
|
border-style: solid;
|
||||||
|
border-width: 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
nav#topbar li a#search {
|
||||||
|
float: left;
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
<nav ng-app="adagios.navbar" id="navbar" class="navbar layout__flexrow" role="navigation" ng-controller="NavBarCtrl">
|
<nav ng-app="adagios.topbar" id="nclass="navbar layout__flexrow" role="navigation" ng-controller="NavBarCtrl">
|
||||||
<ul class="navbar__list navbar__list--left">
|
<ul class="navbar__list navbar__list--left">
|
||||||
<li class="navbar__item navbar__toggle-sidebar">
|
<li class="navbar__item navbar__toggle-sidebar">
|
||||||
<button class="navbar__button"
|
<button class="navbar__button"
|
14
app/topbar/topbar.js
Normal file
14
app/topbar/topbar.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('adagios.topbar', ['adagios.live'])
|
||||||
|
|
||||||
|
.controller('TopBarCtrl', ['$scope', '$http', 'GetProblems', function ($scope, $http, GetProblems) {
|
||||||
|
$scope.notifications = GetProblems;
|
||||||
|
}])
|
||||||
|
|
||||||
|
.directive('topbar', function () {
|
||||||
|
return {
|
||||||
|
restrict: 'E',
|
||||||
|
templateUrl: "topbar/topbar.html"
|
||||||
|
};
|
||||||
|
});
|
43
app/topbar/topbar_test.js
Normal file
43
app/topbar/topbar_test.js
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Topbar module', function () {
|
||||||
|
var $compile,
|
||||||
|
$rootScope,
|
||||||
|
$controller,
|
||||||
|
$httpBackend;
|
||||||
|
|
||||||
|
beforeEach(module('adagios.topbar'));
|
||||||
|
|
||||||
|
beforeEach(inject(function (_$compile_, _$rootScope_, _$controller_, _$httpBackend_) {
|
||||||
|
$compile = _$compile_;
|
||||||
|
$rootScope = _$rootScope_;
|
||||||
|
$controller = _$controller_;
|
||||||
|
$httpBackend = _$httpBackend_;
|
||||||
|
|
||||||
|
$httpBackend.expectGET('topbar/topbar.html').respond('<a>{{ notifications }}</a>');
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('TopBarCtrl', function () {
|
||||||
|
|
||||||
|
it('should be defined', function () {
|
||||||
|
var scope = $rootScope.$new(),
|
||||||
|
topbar = $controller('TopBarCtrl', { $scope : scope });
|
||||||
|
|
||||||
|
expect(topbar).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('Topbar directive', function () {
|
||||||
|
|
||||||
|
it('should insert the number of warnings', function () {
|
||||||
|
var element = $compile('<topbar></topbar>')($rootScope);
|
||||||
|
$httpBackend.flush();
|
||||||
|
$rootScope.notifications = 44;
|
||||||
|
$rootScope.$digest();
|
||||||
|
|
||||||
|
expect(element.text()).toBe('44');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
@ -1,3 +1,5 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
module.exports = function (config) {
|
module.exports = function (config) {
|
||||||
config.set({
|
config.set({
|
||||||
|
|
||||||
@ -7,8 +9,12 @@ module.exports = function(config){
|
|||||||
'app/bower_components/angular/angular.js',
|
'app/bower_components/angular/angular.js',
|
||||||
'app/bower_components/angular-route/angular-route.js',
|
'app/bower_components/angular-route/angular-route.js',
|
||||||
'app/bower_components/angular-mocks/angular-mocks.js',
|
'app/bower_components/angular-mocks/angular-mocks.js',
|
||||||
|
'app/components/live/live.js',
|
||||||
'app/components/**/*.js',
|
'app/components/**/*.js',
|
||||||
'app/view*/**/*.js'
|
'app/topbar/**/*.js',
|
||||||
|
'app/sidebar/**/*.js',
|
||||||
|
'app/tactical/**/*.js',
|
||||||
|
'app/table/**/*.js'
|
||||||
],
|
],
|
||||||
|
|
||||||
autoWatch : true,
|
autoWatch : true,
|
||||||
|
@ -8,8 +8,10 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"bower": "^1.3.1",
|
"bower": "^1.3.1",
|
||||||
"grunt": "^0.4.5",
|
"grunt": "^0.4.5",
|
||||||
|
"grunt-cli": "^0.1.13",
|
||||||
"grunt-contrib-sass": "^0.8.1",
|
"grunt-contrib-sass": "^0.8.1",
|
||||||
"grunt-contrib-watch": "^0.6.1",
|
"grunt-contrib-watch": "^0.6.1",
|
||||||
|
"grunt-jslint": "^1.1.12",
|
||||||
"http-server": "^0.6.1",
|
"http-server": "^0.6.1",
|
||||||
"karma": "~0.10",
|
"karma": "~0.10",
|
||||||
"karma-junit-reporter": "^0.2.2",
|
"karma-junit-reporter": "^0.2.2",
|
||||||
|
29
readme.rst
29
readme.rst
@ -9,23 +9,44 @@ Installation
|
|||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
|
sudo apt-get install npm nodejs-legacy
|
||||||
git clone https://github.com/titilambert/adagios-frontend.git
|
git clone https://github.com/titilambert/adagios-frontend.git
|
||||||
cd adagios-frontend
|
cd adagios-frontend
|
||||||
npm install
|
npm install
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Dev
|
Dev
|
||||||
===
|
===
|
||||||
|
|
||||||
Use grunt to get css files
|
Auto-refresh css files
|
||||||
|
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
|
npm install grunt-cli
|
||||||
grunt
|
grunt
|
||||||
|
|
||||||
|
|
||||||
|
Coding style
|
||||||
|
===========
|
||||||
|
|
||||||
|
This project conforms to JSLint coding style (http://github.com/douglascrockford/JSLint).
|
||||||
|
Run the linter as follows:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
grunt jslint
|
||||||
|
|
||||||
|
Tests
|
||||||
|
=====
|
||||||
|
|
||||||
|
AngularJS comes with Karma which is an automatic unit test runner.
|
||||||
|
While running, Karma automatically executes the tests when any js file changes.
|
||||||
|
To launch Karma :
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
npm test
|
||||||
|
|
||||||
Launch
|
Launch
|
||||||
======
|
======
|
||||||
|
|
||||||
@ -35,5 +56,3 @@ Launch
|
|||||||
|
|
||||||
|
|
||||||
Now, go on http://127.0.0.1:8000
|
Now, go on http://127.0.0.1:8000
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user