Add support for multi-step phase delimitation in build logs view

This commit is contained in:
Joseph Schorr 2017-06-23 16:00:22 -04:00
parent 1d60414a23
commit 09e9b5cb53
4 changed files with 47 additions and 10 deletions

View file

@ -0,0 +1,16 @@
.build-log-command-element.multistep-seperator {
margin-top: 10px;
padding-top: 10px;
border-top: 1px solid #666;
}
.build-log-command-element .from-name {
position: absolute;
top: 3px;
left: 22px;
background-color: #263945;
display: inline-block;
color: #aaa;
font-size: 12px;
padding-right: 10px;
}

View file

@ -87,16 +87,15 @@
.build-logs-view .container-header .label { .build-logs-view .container-header .label {
padding-top: 4px; padding-top: 4px;
text-align: right; text-align: right;
margin-right: 4px; margin-left: 2px;
margin-right: 10px;
width: 86px; width: 86px;
display: inline-block; display: inline-block;
border-right: 4px solid #aaa; border-right: 4px solid #aaa;
background-color: #717171; background-color: #717171;
position: absolute; position: relative;
top: 4px;
left: 24px;
} }
.build-logs-view .dockerfile-command { .build-logs-view .dockerfile-command {
@ -112,10 +111,6 @@
padding-left: 20px; padding-left: 20px;
} }
.build-logs-view .container-header .container-content.build-log-command {
padding-left: 120px;
}
.build-logs-view .log-entry { .build-logs-view .log-entry {
position: relative; position: relative;
} }

View file

@ -1 +1,4 @@
<div class="build-log-command-element" ng-class="::{'multistep-seperator': !!isSecondaryFrom(command.message) || fromName(command.message)}">
<span class="from-name" ng-if="::!!fromName(command.message)">{{ ::fromName(command.message) }}</span>
<dockerfile-command class="command" command="getWithoutStep(command.message)"></dockerfile-command> <dockerfile-command class="command" command="getWithoutStep(command.message)"></dockerfile-command>
</div>

View file

@ -9,7 +9,7 @@ angular.module('quay').directive('buildLogCommand', function () {
transclude: false, transclude: false,
restrict: 'C', restrict: 'C',
scope: { scope: {
'command': '=command' 'command': '<command'
}, },
controller: function($scope, $element) { controller: function($scope, $element) {
$scope.getWithoutStep = function(fullTitle) { $scope.getWithoutStep = function(fullTitle) {
@ -20,6 +20,29 @@ angular.module('quay').directive('buildLogCommand', function () {
return $.trim(fullTitle.substring(colon + 1)); return $.trim(fullTitle.substring(colon + 1));
}; };
$scope.isSecondaryFrom = function(fullTitle) {
if (!fullTitle) { return false; }
var command = $scope.getWithoutStep(fullTitle);
return command.indexOf('FROM ') == 0 && fullTitle.indexOf('Step 1 ') < 0;
};
$scope.fromName = function(fullTitle) {
var command = $scope.getWithoutStep(fullTitle);
if (command.indexOf('FROM ') != 0) {
return null;
}
var parts = command.split(' ');
for (var i = 0; i < parts.length - 1; i++) {
var part = parts[i];
if ($.trim(part) == 'as') {
return parts[i + 1];
}
}
return null;
}
} }
}; };
return directiveDefinitionObject; return directiveDefinitionObject;