2016-04-17 17:53:26 +02:00
|
|
|
(function() {
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
angular
|
|
|
|
.module('harbor.details')
|
|
|
|
.directive('retrieveProjects', retrieveProjects);
|
2016-04-26 12:23:34 +02:00
|
|
|
|
2016-06-01 08:50:34 +02:00
|
|
|
RetrieveProjectsController.$inject = ['$scope', 'nameFilter', '$filter', 'ListProjectService', '$location', 'getParameterByName', 'CurrentProjectMemberService'];
|
2016-04-19 19:20:07 +02:00
|
|
|
|
2016-06-01 08:50:34 +02:00
|
|
|
function RetrieveProjectsController($scope, nameFilter, $filter, ListProjectService, $location, getParameterByName, CurrentProjectMemberService) {
|
2016-04-26 12:23:34 +02:00
|
|
|
var vm = this;
|
2016-05-17 05:40:36 +02:00
|
|
|
|
2016-05-03 12:29:58 +02:00
|
|
|
vm.projectName = '';
|
2016-05-19 12:54:30 +02:00
|
|
|
vm.isOpen = false;
|
2016-05-04 12:42:05 +02:00
|
|
|
|
2016-05-31 12:49:16 +02:00
|
|
|
if(getParameterByName('is_public', $location.absUrl())) {
|
|
|
|
vm.isPublic = getParameterByName('is_public', $location.absUrl()) === 'true' ? 1 : 0;
|
2016-05-17 05:40:36 +02:00
|
|
|
vm.publicity = (vm.isPublic === 1) ? true : false;
|
|
|
|
}
|
|
|
|
|
2016-05-04 12:42:05 +02:00
|
|
|
vm.retrieve = retrieve;
|
2016-06-01 08:50:34 +02:00
|
|
|
vm.filterInput = "";
|
|
|
|
vm.selectItem = selectItem;
|
|
|
|
vm.checkProjectMember = checkProjectMember;
|
2016-06-01 08:01:35 +02:00
|
|
|
|
2016-05-04 12:42:05 +02:00
|
|
|
$scope.$watch('vm.selectedProject', function(current, origin) {
|
|
|
|
if(current) {
|
|
|
|
vm.selectedId = current.ProjectId;
|
|
|
|
}
|
|
|
|
});
|
2016-06-01 08:50:34 +02:00
|
|
|
|
2016-05-04 12:42:05 +02:00
|
|
|
$scope.$watch('vm.publicity', function(current, origin) {
|
2016-05-20 11:43:47 +02:00
|
|
|
vm.publicity = current ? true : false;
|
2016-05-17 05:40:36 +02:00
|
|
|
vm.isPublic = vm.publicity ? 1 : 0;
|
|
|
|
vm.projectType = (vm.isPublic === 1) ? 'public_projects' : 'my_projects';
|
2016-05-11 09:57:52 +02:00
|
|
|
vm.retrieve();
|
2016-05-04 12:42:05 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
function retrieve() {
|
|
|
|
ListProjectService(vm.projectName, vm.isPublic)
|
|
|
|
.success(getProjectSuccess)
|
|
|
|
.error(getProjectFailed);
|
|
|
|
}
|
2016-05-03 12:29:58 +02:00
|
|
|
|
|
|
|
function getProjectSuccess(data, status) {
|
|
|
|
vm.projects = data;
|
2016-05-17 05:40:36 +02:00
|
|
|
|
|
|
|
if(!angular.isDefined(vm.projects)) {
|
|
|
|
vm.isPublic = 1;
|
2016-05-11 09:57:52 +02:00
|
|
|
vm.publicity = 1;
|
2016-05-17 05:40:36 +02:00
|
|
|
vm.projectType = 'public_projects';
|
|
|
|
console.log('vm.projects is undefined, load public projects.');
|
2016-05-11 09:57:52 +02:00
|
|
|
}
|
|
|
|
|
2016-05-17 05:40:36 +02:00
|
|
|
vm.selectedProject = vm.projects[0];
|
2016-05-11 09:57:52 +02:00
|
|
|
|
2016-05-31 12:49:16 +02:00
|
|
|
if(getParameterByName('project_id', $location.absUrl())){
|
2016-05-03 12:29:58 +02:00
|
|
|
angular.forEach(vm.projects, function(value, index) {
|
2016-05-31 12:49:16 +02:00
|
|
|
if(value['ProjectId'] === Number(getParameterByName('project_id', $location.absUrl()))) {
|
2016-05-03 12:29:58 +02:00
|
|
|
vm.selectedProject = value;
|
|
|
|
}
|
2016-05-04 12:42:05 +02:00
|
|
|
});
|
2016-05-03 12:29:58 +02:00
|
|
|
}
|
2016-06-01 08:01:35 +02:00
|
|
|
|
2016-05-20 11:43:47 +02:00
|
|
|
$location.search('project_id', vm.selectedProject.ProjectId);
|
2016-06-01 08:50:34 +02:00
|
|
|
vm.checkProjectMember(vm.selectedProject.ProjectId);
|
|
|
|
|
2016-05-03 12:29:58 +02:00
|
|
|
vm.resultCount = vm.projects.length;
|
|
|
|
|
|
|
|
$scope.$watch('vm.filterInput', function(current, origin) {
|
|
|
|
vm.resultCount = $filter('name')(vm.projects, vm.filterInput, 'Name').length;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function getProjectFailed(response) {
|
|
|
|
console.log('Failed to list projects:' + response);
|
|
|
|
}
|
2016-06-01 08:01:35 +02:00
|
|
|
|
2016-04-26 12:23:34 +02:00
|
|
|
function selectItem(item) {
|
2016-04-27 12:29:55 +02:00
|
|
|
vm.selectedProject = item;
|
2016-05-03 12:29:58 +02:00
|
|
|
$location.search('project_id', vm.selectedProject.ProjectId);
|
2016-04-26 12:23:34 +02:00
|
|
|
}
|
2016-06-01 08:01:35 +02:00
|
|
|
|
|
|
|
$scope.$on('$locationChangeSuccess', function(e) {
|
|
|
|
var projectId = getParameterByName('project_id', $location.absUrl());
|
2016-06-01 08:50:34 +02:00
|
|
|
vm.checkProjectMember(projectId);
|
2016-06-01 08:01:35 +02:00
|
|
|
vm.isOpen = false;
|
|
|
|
});
|
2016-04-27 12:29:55 +02:00
|
|
|
|
2016-06-01 08:50:34 +02:00
|
|
|
function checkProjectMember(projectId) {
|
|
|
|
CurrentProjectMemberService(projectId)
|
|
|
|
.success(getCurrentProjectMemberSuccess)
|
|
|
|
.error(getCurrentProjectMemberFailed);
|
|
|
|
}
|
|
|
|
|
|
|
|
function getCurrentProjectMemberSuccess(data, status) {
|
|
|
|
console.log('Successful get current project member:' + status);
|
|
|
|
vm.isProjectMember = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getCurrentProjectMemberFailed(data, status) {
|
|
|
|
console.log('Use has no member for current project:' + status);
|
|
|
|
vm.isProjectMember = false;
|
|
|
|
}
|
|
|
|
|
2016-04-17 17:53:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function retrieveProjects() {
|
|
|
|
var directive = {
|
|
|
|
restrict: 'E',
|
|
|
|
templateUrl: '/static/ng/resources/js/components/details/retrieve-projects.directive.html',
|
|
|
|
scope: {
|
2016-04-19 19:20:07 +02:00
|
|
|
'isOpen': '=',
|
2016-05-04 12:42:05 +02:00
|
|
|
'selectedProject': '=',
|
|
|
|
'publicity': '=',
|
|
|
|
'isProjectMember': '='
|
2016-04-17 17:53:26 +02:00
|
|
|
},
|
2016-05-19 12:54:30 +02:00
|
|
|
link: link,
|
2016-04-17 17:53:26 +02:00
|
|
|
controller: RetrieveProjectsController,
|
|
|
|
bindToController: true,
|
|
|
|
controllerAs: 'vm'
|
2016-05-23 12:29:17 +02:00
|
|
|
};
|
2016-04-17 17:53:26 +02:00
|
|
|
|
|
|
|
return directive;
|
2016-04-28 19:36:39 +02:00
|
|
|
|
2016-05-19 12:54:30 +02:00
|
|
|
function link(scope, element, attrs, ctrl) {
|
|
|
|
$(document).on('click', clickHandler);
|
2016-05-24 07:50:09 +02:00
|
|
|
|
2016-05-19 12:54:30 +02:00
|
|
|
function clickHandler(e) {
|
2016-05-24 07:50:09 +02:00
|
|
|
$('[data-toggle="popover"]').each(function () {
|
2016-06-01 08:50:34 +02:00
|
|
|
if (!$(this).is(e.target) &&
|
|
|
|
$(this).has(e.target).length === 0 &&
|
|
|
|
$('.popover').has(e.target).length === 0) {
|
|
|
|
$(this).parent().popover('hide');
|
2016-05-24 04:53:52 +02:00
|
|
|
}
|
|
|
|
});
|
2016-05-19 12:54:30 +02:00
|
|
|
var targetId = $(e.target).attr('id');
|
|
|
|
if(targetId === 'switchPane' ||
|
|
|
|
targetId === 'retrievePane' ||
|
|
|
|
targetId === 'retrieveFilter') {
|
|
|
|
return;
|
|
|
|
}else{
|
|
|
|
ctrl.isOpen = false;
|
|
|
|
scope.$apply();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-17 17:53:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
})();
|