- Change the tag check bar to only select the current page (by default), but allow for selecting ALL tags - Limit the number of tags compared in the visualization view to 10 - Fix the multiselect dropdown to limit itself to 10 items selected - Remove saving the selected tags in the URL, as it is too slow and overloads the URLs in Chrome when there are 1000+ tags selected - Change the images API to not return locations: By skipping the extra join and looping, it made the /images API call 10x faster (in hand tests) Fixes #292 Fixes #293
		
			
				
	
	
		
			105 lines
		
	
	
	
		
			3.7 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
	
		
			3.7 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <div class="image-info-sidebar-element">
 | |
|   <!-- Comment -->
 | |
|   <div class="image-comment" ng-if="imageData.comment">
 | |
|     <blockquote style="margin-top: 10px;">
 | |
|       <span class="markdown-view" content="imageData.comment"></span>
 | |
|     </blockquote>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Image ID -->
 | |
|   <div class="image-section">
 | |
|     <i class="fa fa-code section-icon" bs-tooltip="tooltip.title" data-title="Full Image ID"></i>
 | |
|     <span class="section-info">
 | |
|       <a class="current-image-link" ng-href="{{ tracker.imageLink(image) }}">
 | |
|         {{ imageData.id }}
 | |
|       </a>
 | |
|     </span>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Tags -->
 | |
|   <div class="image-section">
 | |
|     <i class="fa fa-tag section-icon" data-title="Current Tags" bs-tooltip></i>
 | |
|     <span class="section-info section-info-with-dropdown">
 | |
|       <a class="label tag label-default" ng-repeat="tag in imageData.tags"
 | |
|          href="javascript:void(0)" ng-click="tagSelected({'tag': tag})">
 | |
|         {{ tag }}
 | |
|       </a>
 | |
|       <span style="color: #ccc;" ng-if="!imageData.tags.length">(No Tags)</span>
 | |
| 
 | |
|       <div class="dropdown" data-placement="top"
 | |
|            ng-if="tracker.repository.can_write || imageData.tags">
 | |
|         <a href="javascript:void(0)" class="dropdown-button" data-toggle="dropdown"
 | |
|            bs-tooltip="tooltip.title" data-title="Manage Tags"
 | |
|            data-container="body">
 | |
|           <b class="caret"></b>
 | |
|         </a>
 | |
| 
 | |
|         <ul class="dropdown-menu pull-right">
 | |
|           <li ng-repeat="tag in imageData.tags">
 | |
|             <a href="javascript:void(0)" ng-click="tagSelected({'tag': tag})">
 | |
|               <i class="fa fa-tag"></i>{{ tag }}
 | |
|             </a>
 | |
|           </li>
 | |
|           <li class="divider" role="presentation"
 | |
|               ng-if="tracker.repository.can_write && imageData.tags"></li>
 | |
|           <li>
 | |
|             <a href="javascript:void(0)"
 | |
|                ng-click="addTagRequested({'image': image})"
 | |
|                ng-if="tracker.repository.can_write">
 | |
|               <i class="fa fa-plus"></i>Add New Tag
 | |
|             </a>
 | |
|           </li>
 | |
|         </ul>
 | |
|       </div>
 | |
|     </span>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Command -->
 | |
|   <div class="image-section" ng-if="imageData.command && imageData.command.length">
 | |
|     <i class="fa fa-terminal section-icon" data-title="Image Command" bs-tooltip></i>
 | |
|     <span class="section-info">
 | |
|       <span class="formatted-command trimmed"
 | |
|          data-html="true"
 | |
|          data-title="{{ getTooltipCommand(imageData) }}"
 | |
|          data-placement="top" bs-tooltip>{{ getFormattedCommand(imageData) }}</span>
 | |
|     </span>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Created -->
 | |
|   <div class="image-section">
 | |
|     <i class="fa fa-calendar section-icon" data-title="Created" bs-tooltip></i>
 | |
|     <span class="section-info">
 | |
|       <dd am-time-ago="parseDate(imageData.created)"></dd>
 | |
|     </span>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Size -->
 | |
|   <div class="image-section">
 | |
|     <i class="fa fa-cloud-upload section-icon"
 | |
|        data-title="The amount of data sent between Docker and the registry when pushing/pulling"
 | |
|        bs-tooltip></i>
 | |
|     <span class="section-info">{{ imageData.size | bytes }}</span>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Locations -->
 | |
|   <div class="image-section" ng-if="imageData.locations">
 | |
|     <i class="fa fa-map-marker section-icon"
 | |
|        data-title="The geographic region(s) in which this image data is located"
 | |
|        bs-tooltip></i>
 | |
|     <span class="section-info">
 | |
|       <span class="location-view" location="location"
 | |
|             ng-repeat="location in imageData.locations"></span>
 | |
|     </span>
 | |
|   </div>
 | |
| 
 | |
|   <!-- Changes -->
 | |
|   <div class="image-section" ng-show="hasImageChanges">
 | |
|     <i class="fa fa-code-fork section-icon"
 | |
|        data-title="File Changes"
 | |
|        bs-tooltip></i>
 | |
|     <span class="section-info">
 | |
|       <div class="image-changes-view" repository="tracker.repository" image="image"
 | |
|            has-changes="hasImageChanges"></div>
 | |
|     </span>
 | |
|   </div>
 | |
| </div>
 |