Fix JS error due to merge and show a spinner in the sign in form when signing in
This commit is contained in:
		
							parent
							
								
									15a2f0d56f
								
							
						
					
					
						commit
						77bf10323c
					
				
					 3 changed files with 13 additions and 9 deletions
				
			
		|  | @ -2636,21 +2636,19 @@ quayApp.directive('externalLoginButton', function () { | |||
|       'action': '@action' | ||||
|     }, | ||||
|     controller: function($scope, $timeout, $interval, ApiService, KeyService, CookieService, Features, Config) { | ||||
|       var getRedirectUrl = function() { | ||||
|         return $scope.redirectUrl; | ||||
|       }; | ||||
| 
 | ||||
|       $scope.signingIn = false; | ||||
|       $scope.startSignin = function(service) { | ||||
|         $scope.signInStarted({'service': service}); | ||||
| 
 | ||||
|         var url = KeyService.getExternalLoginUrl(service, $scope.action || 'login'); | ||||
|          | ||||
|         // Save the redirect URL in a cookie so that we can redirect back after the service returns to us.
 | ||||
|         var redirectURL = getRedirectUrl() || window.location.toString(); | ||||
|         var redirectURL = $scope.redirectUrl || window.location.toString(); | ||||
|         CookieService.putPermanent('quay.redirectAfterLoad', redirectURL); | ||||
| 
 | ||||
|         // Needed to ensure that UI work done by the started callback is finished before the location
 | ||||
|         // changes.
 | ||||
|         $scope.signingIn = true; | ||||
|         $timeout(function() { | ||||
|           document.location = url; | ||||
|         }, 250); | ||||
|  | @ -2676,8 +2674,10 @@ quayApp.directive('signinForm', function () { | |||
|     controller: function($scope, $location, $timeout, $interval, ApiService, KeyService, UserService, CookieService, Features, Config) { | ||||
|       $scope.tryAgainSoon = 0; | ||||
|       $scope.tryAgainInterval = null; | ||||
|       $scope.signingIn = false; | ||||
| 
 | ||||
|       $scope.markStarted = function() { | ||||
|        $scope.signingIn = true; | ||||
|        if ($scope.signInStarted != null) { | ||||
|          $scope.signInStarted(); | ||||
|        } | ||||
|  | @ -2708,6 +2708,7 @@ quayApp.directive('signinForm', function () { | |||
|         $scope.cancelInterval(); | ||||
| 
 | ||||
|         ApiService.signinUser($scope.user).then(function() { | ||||
|           $scope.signingIn = false; | ||||
|           $scope.needsEmailVerification = false; | ||||
|           $scope.invalidCredentials = false; | ||||
| 
 | ||||
|  | @ -2722,13 +2723,15 @@ quayApp.directive('signinForm', function () { | |||
|           // Note: The timeout of 500ms is needed to ensure dialogs containing sign in
 | ||||
|           // forms get removed before the location changes.
 | ||||
|           $timeout(function() { | ||||
|             var redirectUrl = getRedirectUrl(); | ||||
|             var redirectUrl = $scope.redirectUrl; | ||||
|             if (redirectUrl == $location.path() || redirectUrl == null) { | ||||
|               return; | ||||
|             } | ||||
|             window.location = (redirectUrl ? redirectUrl : '/'); | ||||
|           }, 500); | ||||
|         }, function(result) { | ||||
|           $scope.signingIn = false; | ||||
| 
 | ||||
|           if (result.status == 429 /* try again later */) { | ||||
|             $scope.needsEmailVerification = false; | ||||
|             $scope.invalidCredentials = false; | ||||
|  |  | |||
		Reference in a new issue