-
Notifications
You must be signed in to change notification settings - Fork 231
/
Copy pathnextSteps.js
129 lines (112 loc) · 4.2 KB
/
nextSteps.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
"use strict";
/* jshint unused: false */
/**
* @ngdoc function
* @name openshiftConsole.controller:NextStepsController
* @description
* # NextStepsController
* Controller of the openshiftConsole
*/
angular.module("openshiftConsole")
.controller("NextStepsController", function($scope, $http, $routeParams, DataService, $q, $location, ProcessedTemplateService, TaskList, $parse, Navigate, Logger, $filter, imageObjectRefFilter, failureObjectNameFilter, ProjectsService) {
var displayNameFilter = $filter('displayName');
var watches = [];
$scope.emptyMessage = "Loading...";
$scope.alerts = [];
$scope.loginBaseUrl = DataService.openshiftAPIBaseUrl();
$scope.buildConfigs = {};
$scope.showParamsTable = false;
$scope.projectName = $routeParams.project;
var imageName = $routeParams.imageStream;
var imageTag = $routeParams.imageTag;
var namespace = $routeParams.namespace;
$scope.fromSampleRepo = $routeParams.fromSample;
var template = $routeParams.template;
var nameLink = "";
if (creatingFromImage()) {
nameLink = "project/" + $scope.projectName + "/create/fromimage?imageName=" + imageName + "&imageTag=" + imageTag + "&namespace=" + namespace + "&name=" + name;
} else if (creatingFromTemplate()) {
nameLink = "project/" + $scope.projectName + "/create/fromtemplate?template=" + template + "&namespace=" + namespace;
}
$scope.breadcrumbs = [
{
title: $scope.projectName,
link: "project/" + $scope.projectName
},
{
title: "Add to Project",
link: "project/" + $scope.projectName + "/create"
},
{
title: name,
link: nameLink
},
{
title: "Next Steps"
}
];
var processedTemplateData = ProcessedTemplateService.getTemplateData();
$scope.parameters = processedTemplateData.params;
_.each($scope.parameters, function(env) {
$filter('altTextForValueFrom')(env);
});
$scope.templateMessage = processedTemplateData.message;
ProcessedTemplateService.clearTemplateData();
ProjectsService
.get($routeParams.project)
.then(_.spread(function(project, context) {
$scope.project = project;
// Update project breadcrumb with display name.
$scope.breadcrumbs[0].title = $filter('displayName')(project);
if (!name) {
Navigate.toProjectOverview($scope.projectName);
return;
}
watches.push(DataService.watch("buildconfigs", context, function(buildconfigs) {
$scope.buildConfigs = buildconfigs.by("metadata.name");
$scope.createdBuildConfig = $scope.buildConfigs[name];
Logger.log("buildconfigs (subscribe)", $scope.buildConfigs);
}));
$scope.createdBuildConfigWithGitHubTrigger = function() {
return _.some(_.get($scope, 'createdBuildConfig.spec.triggers'), {type: 'GitHub'});
};
$scope.createdBuildConfigWithConfigChangeTrigger = function() {
return _.some(_.get($scope, 'createdBuildConfig.spec.triggers'), {type: 'ConfigChange'});
};
$scope.allTasksSuccessful = function(tasks) {
return !pendingTasks(tasks).length && !erroredTasks(tasks).length;
};
$scope.toggleParamsTable = function() {
$scope.showParamsTable = true;
};
function erroredTasks(tasks) {
var erroredTasks = [];
angular.forEach(tasks, function(task) {
if (task.hasErrors) {
erroredTasks.push(task);
}
});
return erroredTasks;
}
$scope.erroredTasks = erroredTasks;
function pendingTasks(tasks) {
var pendingTasks = [];
angular.forEach(tasks, function(task) {
if (task.status !== "completed") {
pendingTasks.push(task);
}
});
return pendingTasks;
}
$scope.pendingTasks = pendingTasks;
$scope.$on('$destroy', function(){
DataService.unwatchAll(watches);
});
}));
function creatingFromTemplate() {
return name && namespace;
}
function creatingFromImage() {
return imageName && imageTag && namespace;
}
});