Add a simplified landing page for the case where billing is disabled
This commit is contained in:
		
							parent
							
								
									badf002e92
								
							
						
					
					
						commit
						6e2b8d96b8
					
				
					 6 changed files with 271 additions and 151 deletions
				
			
		|  | @ -118,6 +118,9 @@ class DefaultConfig(object): | ||||||
|   # Feature Flag: Whether GitHub login is supported. |   # Feature Flag: Whether GitHub login is supported. | ||||||
|   FEATURE_GITHUB_LOGIN = False |   FEATURE_GITHUB_LOGIN = False | ||||||
| 
 | 
 | ||||||
|  |   # Feature Flag: The logo for the enterprise. | ||||||
|  |   FEATURE_ENTERPRISE_LOGO_URL = 'http://img2.wikia.nocookie.net/__cb20130328225038/logopedia/images/c/c8/Spotify_logo_detail.png' | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| class FakeTransaction(object): | class FakeTransaction(object): | ||||||
|   def __enter__(self): |   def __enter__(self): | ||||||
|  |  | ||||||
|  | @ -1399,6 +1399,50 @@ quayApp.directive('quayClasses', function(Features) { | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | quayApp.directive('quayInclude', function($compile, $templateCache, $http, Features) { | ||||||
|  |   return { | ||||||
|  |     priority: 595, | ||||||
|  |     restrict: 'A', | ||||||
|  |     link: function($scope, $element, $attr, ctrl) { | ||||||
|  |       var getTemplate = function(templateName) { | ||||||
|  |         var templateUrl = '/static/partials/' + templateName; | ||||||
|  |         return $http.get(templateUrl, {cache: $templateCache}); | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       var result = $scope.$eval($attr.quayInclude); | ||||||
|  |       if (!result) { | ||||||
|  |         return; | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       var templatePath = null; | ||||||
|  |       for (var expr in result) { | ||||||
|  |         if (!result.hasOwnProperty(expr)) { continue; } | ||||||
|  | 
 | ||||||
|  |         // Evaluate the expression with the entire features list added.
 | ||||||
|  |         var value = $scope.$eval(expr, Features); | ||||||
|  |         if (value) { | ||||||
|  |           templatePath = result[expr]; | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       if (!templatePath) { | ||||||
|  |         return; | ||||||
|  |       } | ||||||
|  |        | ||||||
|  |       var promise = getTemplate(templatePath).success(function(html) { | ||||||
|  |         $element.html(html); | ||||||
|  |       }).then(function (response) { | ||||||
|  |         $element.replaceWith($compile($element.html())($scope)); | ||||||
|  |         if ($attr.onload) { | ||||||
|  |           $scope.$eval($attr.onload); | ||||||
|  |         } | ||||||
|  |       }); | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| quayApp.directive('entityReference', function () { | quayApp.directive('entityReference', function () { | ||||||
|   var directiveDefinitionObject = { |   var directiveDefinitionObject = { | ||||||
|     priority: 0, |     priority: 0, | ||||||
|  |  | ||||||
|  | @ -262,7 +262,7 @@ function RepoListCtrl($scope, $sanitize, Restangular, UserService, ApiService) { | ||||||
|   loadPublicRepos(); |   loadPublicRepos(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function LandingCtrl($scope, UserService, ApiService) { | function LandingCtrl($scope, UserService, ApiService, Features) { | ||||||
|   $scope.namespace = null; |   $scope.namespace = null; | ||||||
| 
 | 
 | ||||||
|   $scope.$watch('namespace', function(namespace) { |   $scope.$watch('namespace', function(namespace) { | ||||||
|  | @ -303,7 +303,17 @@ function LandingCtrl($scope, UserService, ApiService) { | ||||||
|     }); |     }); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   $scope.chromify = function() { | ||||||
|     browserchrome.update(); |     browserchrome.update(); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   $scope.getEnterpriseLogo = function() { | ||||||
|  |     if (!Features.ENTERPRISE_LOGO_URL) { | ||||||
|  |       return '/static/img/quay-logo.png'; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return Features.ENTERPRISE_LOGO_URL; | ||||||
|  |   }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function RepoCtrl($scope, $sanitize, Restangular, ImageMetadataService, ApiService, $routeParams, $rootScope, $location, $timeout) { | function RepoCtrl($scope, $sanitize, Restangular, ImageMetadataService, ApiService, $routeParams, $rootScope, $location, $timeout) { | ||||||
|  |  | ||||||
							
								
								
									
										58
									
								
								static/partials/landing-login.html
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								static/partials/landing-login.html
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,58 @@ | ||||||
|  | <div class="landing-content"> | ||||||
|  |   <div class="jumbotron landing"> | ||||||
|  |     <div class="container"> | ||||||
|  |       <div class="row messages"> | ||||||
|  |         <div class="col-md-7"> | ||||||
|  |           <div ng-show="user.anonymous" style="text-align: center"> | ||||||
|  |             <span style="display: inline-block; background: white; padding: 10px; border-radius: 10px;"> | ||||||
|  |               <img ng-src="{{ getEnterpriseLogo() }}" style="max-height: 100px;"> | ||||||
|  |             </span> | ||||||
|  |             <h1>Quay.io Enterprise Edition</h1> | ||||||
|  |           </div> | ||||||
|  |            | ||||||
|  |           <div ng-show="!user.anonymous"> | ||||||
|  |             <span class="namespace-selector" user="user" namespace="namespace" ng-show="user.organizations"></span> | ||||||
|  | 
 | ||||||
|  |             <div class="resource-view" resource="my_repositories"> | ||||||
|  |               <!-- Repos --> | ||||||
|  |               <div ng-show="my_repositories.value.length > 0"> | ||||||
|  |                 <h2>Top Repositories</h2>             | ||||||
|  |                 <div class="repo-listing" ng-repeat="repository in my_repositories.value"> | ||||||
|  |                   <span class="repo-circle no-background" repo="repository"></span> | ||||||
|  |                   <a ng-href="/repository/{{ repository.namespace }}/{{ repository.name }}">{{repository.namespace}}/{{repository.name}}</a> | ||||||
|  |                   <div class="markdown-view description" content="repository.description" first-line-only="true"></div> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- No Repos --> | ||||||
|  |               <div ng-show="my_repositories.value.length == 0"> | ||||||
|  |                 <div class="sub-message" style="margin-top: 20px"> | ||||||
|  |                   <span ng-show="namespace != user.username">You don't have access to any repositories in this organization yet.</span> | ||||||
|  |                   <span ng-show="namespace == user.username">You don't have any repositories yet!</span> | ||||||
|  |                   <div class="options"> | ||||||
|  |                     <a class="btn btn-primary" href="/repository/">Browse all repositories</a> | ||||||
|  |                     <a class="btn btn-success" href="/new/" ng-show="canCreateRepo(namespace)">Create a new repository</a> | ||||||
|  |                   </div> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> <!-- col --> | ||||||
|  | 
 | ||||||
|  |         <div class="col-md-4 col-md-offset-1"> | ||||||
|  |           <div ng-show="user.anonymous"> | ||||||
|  |             <h3>Create Username</h3> | ||||||
|  |             <div class="signup-form"></div> | ||||||
|  |           </div> | ||||||
|  |           <div ng-show="!user.anonymous" class="user-welcome"> | ||||||
|  |             <img class="gravatar" src="//www.gravatar.com/avatar/{{ user.gravatar }}?s=128&d=identicon" /> | ||||||
|  |             <div class="sub-message">Welcome <b>{{ user.username }}</b>!</div> | ||||||
|  |             <a ng-show="my_repositories.value" class="btn btn-primary" href="/repository/">Browse all repositories</a> | ||||||
|  |             <a class="btn btn-success" href="/new/">Create a new repository</a> | ||||||
|  |           </div> | ||||||
|  |         </div> <!-- col --> | ||||||
|  |       </div> <!-- row --> | ||||||
|  | 
 | ||||||
|  |     </div> <!-- container --> | ||||||
|  |   </div> <!-- jumbotron --> | ||||||
|  | </div> | ||||||
							
								
								
									
										152
									
								
								static/partials/landing-normal.html
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										152
									
								
								static/partials/landing-normal.html
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,152 @@ | ||||||
|  | <div class="landing-content"> | ||||||
|  |   <div class="jumbotron landing"> | ||||||
|  |     <div class="container"> | ||||||
|  |       <div class="row messages"> | ||||||
|  |         <div class="col-md-7"> | ||||||
|  |           <div ng-show="user.anonymous"> | ||||||
|  |             <h1>Secure hosting for <b>private</b> Docker<a class="disclaimer-link" href="/disclaimer" target="_self">*</a> repositories</h1> | ||||||
|  |             <h3>Use the Docker images <b>your team</b> needs with the safety of <b>private</b> repositories</h3> | ||||||
|  |             <div class="sellcall"><a href="/plans/">Private repository plans starting at $12/mo</a></div> | ||||||
|  |           </div> | ||||||
|  | 
 | ||||||
|  |           <div ng-show="!user.anonymous"> | ||||||
|  |             <span class="namespace-selector" user="user" namespace="namespace" ng-show="user.organizations"></span> | ||||||
|  | 
 | ||||||
|  |             <div class="resource-view" resource="my_repositories"> | ||||||
|  |               <!-- Repos --> | ||||||
|  |               <div ng-show="my_repositories.value.length > 0"> | ||||||
|  |                 <h2>Top Repositories</h2>             | ||||||
|  |                 <div class="repo-listing" ng-repeat="repository in my_repositories.value"> | ||||||
|  |                   <span class="repo-circle no-background" repo="repository"></span> | ||||||
|  |                   <a ng-href="/repository/{{ repository.namespace }}/{{ repository.name }}">{{repository.namespace}}/{{repository.name}}</a> | ||||||
|  |                   <div class="markdown-view description" content="repository.description" first-line-only="true"></div> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <!-- No Repos --> | ||||||
|  |               <div ng-show="my_repositories.value.length == 0"> | ||||||
|  |                 <div class="sub-message" style="margin-top: 20px"> | ||||||
|  |                   <span ng-show="namespace != user.username">You don't have access to any repositories in this organization yet.</span> | ||||||
|  |                   <span ng-show="namespace == user.username">You don't have any repositories yet!</span> | ||||||
|  |                   <div class="options"> | ||||||
|  |                     <a class="btn btn-primary" href="/repository/">Browse all repositories</a> | ||||||
|  |                     <a class="btn btn-success" href="/new/" ng-show="canCreateRepo(namespace)">Create a new repository</a> | ||||||
|  |                   </div> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> <!-- col --> | ||||||
|  | 
 | ||||||
|  |         <div class="col-md-4 col-md-offset-1"> | ||||||
|  |           <div ng-show="user.anonymous"> | ||||||
|  |             <div class="signup-form"></div> | ||||||
|  |           </div> | ||||||
|  |           <div ng-show="!user.anonymous" class="user-welcome"> | ||||||
|  |             <img class="gravatar" src="//www.gravatar.com/avatar/{{ user.gravatar }}?s=128&d=identicon" /> | ||||||
|  |             <div class="sub-message">Welcome <b>{{ user.username }}</b>!</div> | ||||||
|  |             <a ng-show="my_repositories.value" class="btn btn-primary" href="/repository/">Browse all repositories</a> | ||||||
|  |             <a class="btn btn-success" href="/new/">Create a new repository</a> | ||||||
|  |           </div> | ||||||
|  |         </div> <!-- col --> | ||||||
|  |       </div> <!-- row --> | ||||||
|  | 
 | ||||||
|  |       <div class="row" ng-show="user.anonymous"> | ||||||
|  |         <div class="col-md-4 shoutout"> | ||||||
|  |           <i class="fa fa-lock"></i> | ||||||
|  |           <b>Secure</b> | ||||||
|  |           <span class="shoutout-expand"> | ||||||
|  |             Your data is transferred using <strong>SSL at all times</strong> and <strong>encrypted</strong> when at rest. More information available in our <a href="/security/">security guide</a> | ||||||
|  |           </span> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <div class="col-md-4 shoutout"> | ||||||
|  |           <i class="fa fa-group"></i> | ||||||
|  |           <b>Shareable</b> | ||||||
|  |           <span class="shoutout-expand"> | ||||||
|  |             Have to share a repository? No problem! Share with anyone you choose | ||||||
|  |           </span> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <div class="col-md-4 shoutout"> | ||||||
|  |           <i class="fa fa-cloud"></i> | ||||||
|  |           <b>Cloud Hosted</b> | ||||||
|  |           <span class="shoutout-expand"> | ||||||
|  |             Accessible from anywhere, anytime | ||||||
|  |           </span> | ||||||
|  |         </div> | ||||||
|  |       </div> <!-- row --> | ||||||
|  |     </div> <!-- container --> | ||||||
|  |   </div> <!-- jumbotron --> | ||||||
|  | 
 | ||||||
|  |   <div class="product-tour container" ng-show="user.anonymous"> | ||||||
|  |     <div class="tour-header row"> | ||||||
|  |       <div class="tour-shoutout-header"><i class="fa fa-chevron-circle-down"></i></div> | ||||||
|  |       <div class="tour-shoutout">Take a tour of Quay</div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div class="tour-section row"> | ||||||
|  |       <div class="col-md-7"><img src="/static/img/user-home.png" title="User Home - Quay.io" data-screenshot-url="https://quay.io/" class="img-responsive"></div> | ||||||
|  |       <div class="col-md-5"> | ||||||
|  |         <div class="tour-section-title">Customized for you</div> | ||||||
|  |         <div class="tour-section-description"> | ||||||
|  |           Your personal home screen shows those repositories most important to you, ordered by recent activity. | ||||||
|  |         </div> | ||||||
|  |         <div class="tour-section-description">Keep up to date on the status of those repositories you deem important.</div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div class="tour-section row"> | ||||||
|  |       <div class="col-md-7 col-md-push-5"><img src="/static/img/repo-view.png" title="Repository View - Quay.io" data-screenshot-url="https://quay.io/repository/devtable/complex" class="img-responsive"></div> | ||||||
|  |       <div class="col-md-5 col-md-pull-7"> | ||||||
|  |         <div class="tour-section-title">Useful views of respositories</div> | ||||||
|  |         <div class="tour-section-description"> | ||||||
|  |           Each repository is presented with the maximum amount of useful information, including its image history, <b>markdown</b>-based description, and tags. | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div class="tour-section row"> | ||||||
|  |       <div class="col-md-7"><img src="/static/img/build-history.png" title="View Image - Quay.io" | ||||||
|  |                                  data-screenshot-url="https://quay.io/repository/devtable/building/build" | ||||||
|  |                                  class="img-responsive"></div> | ||||||
|  |       <div class="col-md-5"> | ||||||
|  |         <div class="tour-section-title">Dockerfile Build in the cloud</div> | ||||||
|  |         <div class="tour-section-description"> | ||||||
|  |           Like to use <b>Dockerfiles</b> to build your images? Simply upload your Dockerfile (and any additional files it needs) and we'll build your Dockerfile into an image and push it to your repository.         | ||||||
|  |         </div> | ||||||
|  |         <div class="tour-section-description">         | ||||||
|  |           If you store your Dockerfile in <i class="fa fa-github fa-lg" style="margin: 6px;"></i><b>GitHub</b>, add a <b>Build Trigger</b> to your repository and we'll start a Dockerfile build for every change you make. | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div class="tour-section row"> | ||||||
|  |       <div class="col-md-7 col-md-push-5"><img src="/static/img/repo-admin.png" title="Repository Admin - Quay.io" data-screenshot-url="https://quay.io/repository/devtable/complex/admin" class="img-responsive"></div> | ||||||
|  |       <div class="col-md-5 col-md-pull-7"> | ||||||
|  |         <div class="tour-section-title">Share at your control</div> | ||||||
|  |         <div class="tour-section-description"> | ||||||
|  |           Share any repository with as many (or as few) users as you choose. | ||||||
|  |         </div> | ||||||
|  |         <div class="tour-section-description">Need a repository only for your team? Easily <b>share</b> with your team members.</div> | ||||||
|  |         <div class="tour-section-description">Need finer grain control? Mark a user as <b>read-only</b> or <b>read/write</b>.</div> | ||||||
|  |         <div class="tour-section-description">Have a build script or a deploy process that needs access? Generate an <b>access token</b> to grant revocable access for pushing or pulling.</div> | ||||||
|  |         <div class="tour-section-description">Want to share with the world? Make your repository <b>fully public</b>.</div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div class="tour-section row"> | ||||||
|  |       <div class="col-md-7"><img src="/static/img/repo-changes.png" title="View Image - Quay.io" data-screenshot-url="https://quay.io/repository/devtable/image/..." class="img-responsive"></div> | ||||||
|  |       <div class="col-md-5"> | ||||||
|  |         <div class="tour-section-title">Docker diff whenever you need it</div> | ||||||
|  |         <div class="tour-section-description"> | ||||||
|  |           We wanted to know what was changing in each image of our repositories just as much as you do. So we added diffs. Now you can see exactly which files were <b>added</b>, <b>changed</b>, or <b>removed</b> for each image. We've also provided two awesome ways to view your changes, either in a filterable list, or in a drill down tree view. | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div style="border-top: 1px solid #eee; padding-top: 20px;"> | ||||||
|  |       <a href="https://mixpanel.com/f/partner"><img src="//cdn.mxpnl.com/site_media/images/partner/badge_light.png" alt="Mobile Analytics" /></a> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </div> | ||||||
|  | @ -1,150 +1,3 @@ | ||||||
| <div class="jumbotron landing"> | <div quay-include="{'BILLING': 'landing-normal.html', '!BILLING': 'landing-login.html'}" onload="chromify()"> | ||||||
|   <div class="container"> |   <span class="quay-spinner"></span> | ||||||
|     <div class="row messages"> |  | ||||||
|       <div class="col-md-7"> |  | ||||||
|         <div ng-show="user.anonymous"> |  | ||||||
|           <h1>Secure hosting for <b>private</b> Docker<a class="disclaimer-link" href="/disclaimer" target="_self">*</a> repositories</h1> |  | ||||||
|           <h3>Use the Docker images <b>your team</b> needs with the safety of <b>private</b> repositories</h3> |  | ||||||
|           <div class="sellcall"><a href="/plans/">Private repository plans starting at $12/mo</a></div> |  | ||||||
|         </div> |  | ||||||
| 
 |  | ||||||
|         <div ng-show="!user.anonymous"> |  | ||||||
|           <span class="namespace-selector" user="user" namespace="namespace" ng-show="user.organizations"></span> |  | ||||||
| 
 |  | ||||||
|           <div class="resource-view" resource="my_repositories"> |  | ||||||
|             <!-- Repos --> |  | ||||||
|             <div ng-show="my_repositories.value.length > 0"> |  | ||||||
|               <h2>Top Repositories</h2>             |  | ||||||
|               <div class="repo-listing" ng-repeat="repository in my_repositories.value"> |  | ||||||
|                 <span class="repo-circle no-background" repo="repository"></span> |  | ||||||
|                 <a ng-href="/repository/{{ repository.namespace }}/{{ repository.name }}">{{repository.namespace}}/{{repository.name}}</a> |  | ||||||
|                 <div class="markdown-view description" content="repository.description" first-line-only="true"></div> |  | ||||||
|               </div> |  | ||||||
|             </div> |  | ||||||
| 
 |  | ||||||
|             <!-- No Repos --> |  | ||||||
|             <div ng-show="my_repositories.value.length == 0"> |  | ||||||
|               <div class="sub-message" style="margin-top: 20px"> |  | ||||||
|                 <span ng-show="namespace != user.username">You don't have access to any repositories in this organization yet.</span> |  | ||||||
|                 <span ng-show="namespace == user.username">You don't have any repositories yet!</span> |  | ||||||
|                 <div class="options"> |  | ||||||
|                   <a class="btn btn-primary" href="/repository/">Browse all repositories</a> |  | ||||||
|                   <a class="btn btn-success" href="/new/" ng-show="canCreateRepo(namespace)">Create a new repository</a> |  | ||||||
|                 </div> |  | ||||||
|               </div> |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </div> <!-- col --> |  | ||||||
| 
 |  | ||||||
|       <div class="col-md-4 col-md-offset-1"> |  | ||||||
|         <div ng-show="user.anonymous"> |  | ||||||
|           <div class="signup-form"></div> |  | ||||||
|         </div> |  | ||||||
|         <div ng-show="!user.anonymous" class="user-welcome"> |  | ||||||
|           <img class="gravatar" src="//www.gravatar.com/avatar/{{ user.gravatar }}?s=128&d=identicon" /> |  | ||||||
|           <div class="sub-message">Welcome <b>{{ user.username }}</b>!</div> |  | ||||||
|           <a ng-show="my_repositories.value" class="btn btn-primary" href="/repository/">Browse all repositories</a> |  | ||||||
|           <a class="btn btn-success" href="/new/">Create a new repository</a> |  | ||||||
|         </div> |  | ||||||
|       </div> <!-- col --> |  | ||||||
|     </div> <!-- row --> |  | ||||||
| 
 |  | ||||||
|     <div class="row" ng-show="user.anonymous"> |  | ||||||
|       <div class="col-md-4 shoutout"> |  | ||||||
|         <i class="fa fa-lock"></i> |  | ||||||
|         <b>Secure</b> |  | ||||||
|         <span class="shoutout-expand"> |  | ||||||
|           Your data is transferred using <strong>SSL at all times</strong> and <strong>encrypted</strong> when at rest. More information available in our <a href="/security/">security guide</a> |  | ||||||
|         </span> |  | ||||||
|       </div> |  | ||||||
| 
 |  | ||||||
|       <div class="col-md-4 shoutout"> |  | ||||||
|         <i class="fa fa-group"></i> |  | ||||||
|         <b>Shareable</b> |  | ||||||
|         <span class="shoutout-expand"> |  | ||||||
|           Have to share a repository? No problem! Share with anyone you choose |  | ||||||
|         </span> |  | ||||||
|       </div> |  | ||||||
| 
 |  | ||||||
|       <div class="col-md-4 shoutout"> |  | ||||||
|         <i class="fa fa-cloud"></i> |  | ||||||
|         <b>Cloud Hosted</b> |  | ||||||
|         <span class="shoutout-expand"> |  | ||||||
|           Accessible from anywhere, anytime |  | ||||||
|         </span> |  | ||||||
|       </div> |  | ||||||
|     </div> <!-- row --> |  | ||||||
|   </div> <!-- container --> |  | ||||||
| </div> <!-- jumbotron --> |  | ||||||
| 
 |  | ||||||
| <div class="product-tour container" ng-show="user.anonymous"> |  | ||||||
|   <div class="tour-header row"> |  | ||||||
|     <div class="tour-shoutout-header"><i class="fa fa-chevron-circle-down"></i></div> |  | ||||||
|     <div class="tour-shoutout">Take a tour of Quay</div> |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div class="tour-section row"> |  | ||||||
|     <div class="col-md-7"><img src="/static/img/user-home.png" title="User Home - Quay.io" data-screenshot-url="https://quay.io/" class="img-responsive"></div> |  | ||||||
|     <div class="col-md-5"> |  | ||||||
|       <div class="tour-section-title">Customized for you</div> |  | ||||||
|       <div class="tour-section-description"> |  | ||||||
|         Your personal home screen shows those repositories most important to you, ordered by recent activity. |  | ||||||
|       </div> |  | ||||||
|       <div class="tour-section-description">Keep up to date on the status of those repositories you deem important.</div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div class="tour-section row"> |  | ||||||
|     <div class="col-md-7 col-md-push-5"><img src="/static/img/repo-view.png" title="Repository View - Quay.io" data-screenshot-url="https://quay.io/repository/devtable/complex" class="img-responsive"></div> |  | ||||||
|     <div class="col-md-5 col-md-pull-7"> |  | ||||||
|       <div class="tour-section-title">Useful views of respositories</div> |  | ||||||
|       <div class="tour-section-description"> |  | ||||||
|         Each repository is presented with the maximum amount of useful information, including its image history, <b>markdown</b>-based description, and tags. |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div class="tour-section row"> |  | ||||||
|     <div class="col-md-7"><img src="/static/img/build-history.png" title="View Image - Quay.io" |  | ||||||
|                                              data-screenshot-url="https://quay.io/repository/devtable/building/build" |  | ||||||
|                                              class="img-responsive"></div> |  | ||||||
|     <div class="col-md-5"> |  | ||||||
|       <div class="tour-section-title">Dockerfile Build in the cloud</div> |  | ||||||
|       <div class="tour-section-description"> |  | ||||||
|         Like to use <b>Dockerfiles</b> to build your images? Simply upload your Dockerfile (and any additional files it needs) and we'll build your Dockerfile into an image and push it to your repository.         |  | ||||||
|       </div> |  | ||||||
|       <div class="tour-section-description">         |  | ||||||
|         If you store your Dockerfile in <i class="fa fa-github fa-lg" style="margin: 6px;"></i><b>GitHub</b>, add a <b>Build Trigger</b> to your repository and we'll start a Dockerfile build for every change you make. |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div class="tour-section row"> |  | ||||||
|     <div class="col-md-7 col-md-push-5"><img src="/static/img/repo-admin.png" title="Repository Admin - Quay.io" data-screenshot-url="https://quay.io/repository/devtable/complex/admin" class="img-responsive"></div> |  | ||||||
|     <div class="col-md-5 col-md-pull-7"> |  | ||||||
|       <div class="tour-section-title">Share at your control</div> |  | ||||||
|       <div class="tour-section-description"> |  | ||||||
|         Share any repository with as many (or as few) users as you choose. |  | ||||||
|       </div> |  | ||||||
|       <div class="tour-section-description">Need a repository only for your team? Easily <b>share</b> with your team members.</div> |  | ||||||
|       <div class="tour-section-description">Need finer grain control? Mark a user as <b>read-only</b> or <b>read/write</b>.</div> |  | ||||||
|       <div class="tour-section-description">Have a build script or a deploy process that needs access? Generate an <b>access token</b> to grant revocable access for pushing or pulling.</div> |  | ||||||
|       <div class="tour-section-description">Want to share with the world? Make your repository <b>fully public</b>.</div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div class="tour-section row"> |  | ||||||
|     <div class="col-md-7"><img src="/static/img/repo-changes.png" title="View Image - Quay.io" data-screenshot-url="https://quay.io/repository/devtable/image/..." class="img-responsive"></div> |  | ||||||
|     <div class="col-md-5"> |  | ||||||
|       <div class="tour-section-title">Docker diff whenever you need it</div> |  | ||||||
|       <div class="tour-section-description"> |  | ||||||
|         We wanted to know what was changing in each image of our repositories just as much as you do. So we added diffs. Now you can see exactly which files were <b>added</b>, <b>changed</b>, or <b>removed</b> for each image. We've also provided two awesome ways to view your changes, either in a filterable list, or in a drill down tree view. |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div style="border-top: 1px solid #eee; padding-top: 20px;"> |  | ||||||
|     <a href="https://mixpanel.com/f/partner"><img src="//cdn.mxpnl.com/site_media/images/partner/badge_light.png" alt="Mobile Analytics" /></a> |  | ||||||
|   </div> |  | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
		Reference in a new issue