Add better messaging and UI around repos and images that are currently being pushed
This commit is contained in:
		
							parent
							
								
									27c2680380
								
							
						
					
					
						commit
						e7daca5d95
					
				
					 4 changed files with 63 additions and 19 deletions
				
			
		|  | @ -24,6 +24,7 @@ def image_view(image): | ||||||
|     'dbid': image.id, |     'dbid': image.id, | ||||||
|     'size': extended_props.image_size, |     'size': extended_props.image_size, | ||||||
|     'locations': list(image.storage.locations), |     'locations': list(image.storage.locations), | ||||||
|  |     'uploading': image.storage.uploading, | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -431,6 +431,27 @@ function RepoCtrl($scope, $sanitize, Restangular, ImageMetadataService, ApiServi | ||||||
|     $location.search('current', buildInfo.id); |     $location.search('current', buildInfo.id); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   $scope.isPushing = function(images) { | ||||||
|  |     if (!images) { return false; } | ||||||
|  | 
 | ||||||
|  |     var cached = images.__isPushing; | ||||||
|  |     if (cached !== undefined) { | ||||||
|  |       return cached; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return images.__isPushing = $scope.isPushingInternal(images); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   $scope.isPushingInternal = function(images) { | ||||||
|  |     if (!images) { return false; } | ||||||
|  | 
 | ||||||
|  |     for (var i = 0; i < images.length; ++i) { | ||||||
|  |       if (images[i].uploading) { return true; } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return false; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|   $scope.getTooltipCommand = function(image) { |   $scope.getTooltipCommand = function(image) { | ||||||
|     var sanitized = ImageMetadataService.getEscapedFormattedCommand(image); |     var sanitized = ImageMetadataService.getEscapedFormattedCommand(image); | ||||||
|     return '<span class=\'codetooltip\'>' + sanitized + '</span>'; |     return '<span class=\'codetooltip\'>' + sanitized + '</span>'; | ||||||
|  |  | ||||||
|  | @ -402,6 +402,10 @@ ImageHistoryTree.prototype.buildRoot_ = function() { | ||||||
|   var roots = []; |   var roots = []; | ||||||
|   for (var i = 0; i < this.images_.length; ++i) { |   for (var i = 0; i < this.images_.length; ++i) { | ||||||
|     var image = this.images_[i]; |     var image = this.images_[i]; | ||||||
|  | 
 | ||||||
|  |     // Skip images that are currently uploading.
 | ||||||
|  |     if (image.uploading) { continue; } | ||||||
|  | 
 | ||||||
|     var imageNode = imageByDBID[image.dbid]; |     var imageNode = imageByDBID[image.dbid]; | ||||||
|     var ancestors = this.getAncestors_(image); |     var ancestors = this.getAncestors_(image); | ||||||
|     var immediateParent = ancestors[ancestors.length - 1] * 1; |     var immediateParent = ancestors[ancestors.length - 1] * 1; | ||||||
|  | @ -432,6 +436,10 @@ ImageHistoryTree.prototype.buildRoot_ = function() { | ||||||
|   var maxChildCount = roots.length; |   var maxChildCount = roots.length; | ||||||
|   for (var i = 0; i < this.images_.length; ++i) { |   for (var i = 0; i < this.images_.length; ++i) { | ||||||
|     var image = this.images_[i]; |     var image = this.images_[i]; | ||||||
|  | 
 | ||||||
|  |     // Skip images that are currently uploading.
 | ||||||
|  |     if (image.uploading) { continue; } | ||||||
|  | 
 | ||||||
|     var imageNode = imageByDBID[image.dbid]; |     var imageNode = imageByDBID[image.dbid]; | ||||||
|     maxChildCount = Math.max(maxChildCount, this.determineMaximumChildCount_(imageNode)); |     maxChildCount = Math.max(maxChildCount, this.determineMaximumChildCount_(imageNode)); | ||||||
|   } |   } | ||||||
|  | @ -582,6 +590,10 @@ ImageHistoryTree.prototype.setTag_ = function(tagName) { | ||||||
|   // Ensure that the children are in the correct order.
 |   // Ensure that the children are in the correct order.
 | ||||||
|   for (var i = 0; i < this.images_.length; ++i) { |   for (var i = 0; i < this.images_.length; ++i) { | ||||||
|     var image = this.images_[i]; |     var image = this.images_[i]; | ||||||
|  | 
 | ||||||
|  |     // Skip images that are currently uploading.
 | ||||||
|  |     if (image.uploading) { continue; } | ||||||
|  | 
 | ||||||
|     var imageNode = this.imageByDBID_[image.dbid]; |     var imageNode = this.imageByDBID_[image.dbid]; | ||||||
|     var ancestors = this.getAncestors_(image); |     var ancestors = this.getAncestors_(image); | ||||||
|     var immediateParent = ancestors[ancestors.length - 1] * 1; |     var immediateParent = ancestors[ancestors.length - 1] * 1; | ||||||
|  |  | ||||||
|  | @ -76,33 +76,43 @@ | ||||||
|     <div class="description markdown-input" content="repo.description" can-write="repo.can_write" |     <div class="description markdown-input" content="repo.description" can-write="repo.can_write" | ||||||
|          content-changed="updateForDescription" field-title="'repository description'"></div> |          content-changed="updateForDescription" field-title="'repository description'"></div> | ||||||
| 
 | 
 | ||||||
|     <!-- Empty message --> |     <!-- Empty messages --> | ||||||
|     <div class="repo-content" ng-show="!currentTag.image_id && !currentImage && !repo.is_building"> |     <div ng-if="!currentTag.image_id && !currentImage"> | ||||||
|       <div class="empty-message"> |       <!-- !building && !pushing --> | ||||||
|         This repository is empty |       <div class="repo-content" ng-show="!repo.is_building && !isPushing(images)"> | ||||||
|       </div> |         <div class="empty-message"> | ||||||
|  |           This repository is empty | ||||||
|  |         </div> | ||||||
| 
 | 
 | ||||||
|       <div class="empty-description" ng-show="repo.can_write"> |         <div class="empty-description" ng-show="repo.can_write"> | ||||||
|         <div class="panel-default"> |           <div class="panel-default"> | ||||||
|           <div class="panel-heading">How to push a new image to this repository:</div> |             <div class="panel-heading">How to push a new image to this repository:</div> | ||||||
|           <div class="panel-body"> |             <div class="panel-body"> | ||||||
|             First login to the registry (if you have not done so already): |               First login to the registry (if you have not done so already): | ||||||
|             <pre class="command">sudo docker login {{ Config.getDomain() }}</pre> |               <pre class="command">sudo docker login {{ Config.getDomain() }}</pre> | ||||||
| 
 | 
 | ||||||
|             Tag an image to this repository: |               Tag an image to this repository: | ||||||
|             <pre class="command">sudo docker tag <i>0u123imageidgoeshere</i> {{ Config.getDomain() }}/{{repo.namespace}}/{{repo.name}}</pre> |               <pre class="command">sudo docker tag <i>0u123imageidgoeshere</i> {{ Config.getDomain() }}/{{repo.namespace}}/{{repo.name}}</pre> | ||||||
| 
 | 
 | ||||||
|             Push the image to this repository: |               Push the image to this repository: | ||||||
|             <pre class="command">sudo docker push {{ Config.getDomain() }}/{{repo.namespace}}/{{repo.name}}</pre> |               <pre class="command">sudo docker push {{ Config.getDomain() }}/{{repo.namespace}}/{{repo.name}}</pre> | ||||||
|  |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|     </div> |       <!-- building --> | ||||||
|  |       <div class="repo-content" ng-show="repo.is_building"> | ||||||
|  |         <div class="empty-message"> | ||||||
|  |           A build is currently processing. If this takes longer than an hour, please <a href="/contact">contact us</a> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
| 
 | 
 | ||||||
|     <div class="repo-content" ng-show="!currentTag.image_id && repo.is_building"> |       <!-- pushing --> | ||||||
|       <div class="empty-message"> |       <div class="repo-content" ng-show="!repo.is_building && isPushing(images)"> | ||||||
|         A build is currently processing. If this takes longer than an hour, please <a href="/contact">contact us</a> |         <div class="empty-message"> | ||||||
|  |           A push to this repository is in progress. | ||||||
|  |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Reference in a new issue