alertmanager/ui/app/js/app.js
2015-10-20 12:38:42 +02:00

156 lines
3.2 KiB
JavaScript

'use strict';
angular.module('am.services', ['ngResource']);
angular.module('am.services').factory('Silence',
function($resource){
return $resource('', {id: '@id'}, {
'query': {method: 'GET', url: '/api/v1/silences'},
'create': {method: 'POST', url: '/api/v1/silences'},
'get': {method: 'GET', url: '/api/v1/silence/:id'},
'save': {method: 'POST', url: '/api/v1/silence/:id'},
'delete': {method: 'DELETE', url: '/api/v1/silence/:id'}
});
}
);
angular.module('am.services').factory('Alert',
function($resource){
return $resource('', {}, {
'query': {method: 'GET', url: '/api/v1/alerts'}
});
}
);
angular.module('am.controllers', []);
angular.module('am.controllers').controller('NavCtrl',
function($scope, $location) {
$scope.items = [
{name: 'Silences', url:'/silences'},
{name: 'Alerts', url:'/alerts'},
{name: 'Status', url:'/status'}
];
$scope.selected = function(item) {
return item.url == $location.path()
}
}
);
angular.module('am.controllers').controller('AlertsCtrl',
function($scope, Alert) {
$scope.alerts = [];
$scope.order = "startsAt";
$scope.refresh = function() {
Alert.query({},
function(data) {
$scope.alerts = data.data || [];
console.log($scope.alerts)
},
function(data) {
}
);
}
$scope.refresh();
}
);
angular.module('am.controllers').controller('SilencesCtrl',
function($scope, Silence) {
$scope.silences = [];
$scope.order = "startsAt";
$scope.refresh = function() {
Silence.query({},
function(data) {
$scope.silences = data.data || [];
},
function(data) {
}
);
}
$scope.delete = function(sil) {
Silence.delete({id: sil.id})
$scope.refresh()
}
$scope.refresh();
}
);
angular.module('am.controllers').controller('SilenceCreateCtrl',
function($scope, Silence) {
$scope.create = function() {
Silence.create($scope.silence,
function(data) {
$scope.refresh();
},
function(data) {
$scope.error = data.data;
}
);
}
$scope.error = null;
$scope.newMatcher = function() {
$scope.silence.matchers.push({});
}
$scope.delMatcher = function(i) {
$scope.silence.matchers.splice(i, 1);
}
$scope.reset = function() {
var now = new Date(),
end = new Date();
now.setMilliseconds(0);
end.setMilliseconds(0);
now.setSeconds(0);
end.setSeconds(0);
end.setHours(end.getHours() + 2)
$scope.silence = {
startsAt: now,
endsAt: end,
matchers: [{}],
comment: "",
createdBy: ""
}
}
$scope.reset();
}
);
angular.module('am', [
'ngRoute',
'am.controllers',
'am.services'
]);
angular.module('am').config(
function($routeProvider) {
$routeProvider.
when('/alerts', {
templateUrl: '/app/partials/alerts.html',
controller: 'AlertsCtrl'
}).
when('/silences', {
templateUrl: '/app/partials/silences.html',
controller: 'SilencesCtrl'
}).
otherwise({
redirectTo: '/silences'
});
}
);