woodpecker/server/app/scripts/controllers/repo.js

117 lines
3.1 KiB
JavaScript
Raw Normal View History

'use strict';
angular.module('app').controller("RepoController", function($scope, $http, $routeParams, $route, repos, feed, repo) {
$scope.repo = repo;
2014-10-05 22:30:50 +00:00
$scope.activating = false;
// subscribes to the global feed to receive
// build status updates.
feed.subscribe(function(item) {
if (item.repo.host == repo.host &&
item.repo.owner == repo.owner &&
item.repo.name == repo.name) {
// display a toast message with the
// commit details, allowing the user to
// reload the page.
$scope.msg = item;
$scope.$apply();
} else {
// we trigger a toast (or html5) notification so the
// user is aware another build started
}
});
// load the repo commit feed
2014-10-02 14:11:13 +00:00
repos.commits(repo.host, repo.owner, repo.name).success(function (commits) {
$scope.commits = (typeof commits==='string')?[]:commits;
$scope.state = 1;
})
.error(function (error) {
$scope.commits = undefined;
$scope.state = 1;
});
2014-10-07 14:57:01 +00:00
//$http({method: 'GET', url: '/api/repos/'+repo.host+'/'+repo.owner+"/"+repo.name+"/feed"}).
// success(function(data, status, headers, config) {
// $scope.commits = (typeof data==='string')?[]:data;
// }).
// error(function(data, status, headers, config) {
// console.log(data);
// });
$scope.activate = function() {
2014-10-05 22:30:50 +00:00
$scope.activating = true;
// request to create a new repository
2014-09-30 07:43:50 +00:00
$http({method: 'POST', url: '/api/repos/'+repo.host+'/'+repo.owner+"/"+repo.name }).
success(function(data, status, headers, config) {
$scope.repo = data;
2014-10-05 22:30:50 +00:00
$scope.activating = false;
}).
error(function(data, status, headers, config) {
$scope.failure = data;
2014-10-05 22:30:50 +00:00
$scope.activating = false;
});
};
$scope.reload = function() {
$route.reload();
};
//$scope.activate = function() {
// repos.activate($scope.host, $scope.name).success(function () {
// window.location.href="/admin/users";
// })
// .error(function (error) {
// console.log(error);
// });
//};
});
2014-10-05 22:30:50 +00:00
angular.module('app').controller("RepoConfigController", function($scope, $http, $timeout, $routeParams, user) {
$scope.user = user;
2014-10-05 22:30:50 +00:00
$scope.saving = false;
var remote = $routeParams.remote;
var owner = $routeParams.owner;
var name = $routeParams.name;
// load the repo meta-data
// request admin details for the repository as well.
2014-09-30 07:43:50 +00:00
$http({method: 'GET', url: '/api/repos/'+remote+'/'+owner+"/"+name+"?admin=1"}).
success(function(data, status, headers, config) {
$scope.repo = data;
}).
error(function(data, status, headers, config) {
console.log(data);
});
$scope.save = function() {
2014-10-05 22:30:50 +00:00
$scope.saving = true;
// request to create a new repository
2014-09-30 07:43:50 +00:00
$http({method: 'PUT', url: '/api/repos/'+remote+'/'+owner+"/"+name, data: $scope.repo }).
success(function(data, status, headers, config) {
delete $scope.failure;
2014-10-05 22:30:50 +00:00
// yes, for UX reasons we make this request look like it
// is taking longer than it really is. Otherwise the loading
// button just instantly flickers.
$timeout(function(){
$scope.saving = false;
}, 1500);
}).
error(function(data, status, headers, config) {
$scope.failure = data;
2014-10-05 22:30:50 +00:00
$scope.saving = false;
});
2014-10-05 22:30:50 +00:00
};
});