Fix Stripe dialog in IE and mobile safari
This commit is contained in:
parent
5744f0f888
commit
5028172c51
1 changed files with 31 additions and 6 deletions
|
@ -1543,7 +1543,7 @@ quayApp = angular.module('quay', quayDependencies, function($provide, cfpLoading
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
planService.changePlan = function($scope, orgname, planId, callbacks) {
|
planService.changePlan = function($scope, orgname, planId, callbacks, opt_async) {
|
||||||
if (!Features.BILLING) { return; }
|
if (!Features.BILLING) { return; }
|
||||||
|
|
||||||
if (callbacks['started']) {
|
if (callbacks['started']) {
|
||||||
|
@ -1556,7 +1556,7 @@ quayApp = angular.module('quay', quayDependencies, function($provide, cfpLoading
|
||||||
planService.getCardInfo(orgname, function(cardInfo) {
|
planService.getCardInfo(orgname, function(cardInfo) {
|
||||||
if (plan.price > 0 && (previousSubscribeFailure || !cardInfo.last4)) {
|
if (plan.price > 0 && (previousSubscribeFailure || !cardInfo.last4)) {
|
||||||
var title = cardInfo.last4 ? 'Subscribe' : 'Start Trial ({{amount}} plan)';
|
var title = cardInfo.last4 ? 'Subscribe' : 'Start Trial ({{amount}} plan)';
|
||||||
planService.showSubscribeDialog($scope, orgname, planId, callbacks, title);
|
planService.showSubscribeDialog($scope, orgname, planId, callbacks, title, /* async */true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1629,9 +1629,34 @@ quayApp = angular.module('quay', quayDependencies, function($provide, cfpLoading
|
||||||
return email;
|
return email;
|
||||||
};
|
};
|
||||||
|
|
||||||
planService.showSubscribeDialog = function($scope, orgname, planId, callbacks, opt_title) {
|
planService.showSubscribeDialog = function($scope, orgname, planId, callbacks, opt_title, opt_async) {
|
||||||
if (!Features.BILLING) { return; }
|
if (!Features.BILLING) { return; }
|
||||||
|
|
||||||
|
// If the async parameter is true and this is a browser that does not allow async popup of the
|
||||||
|
// Stripe dialog (such as Mobile Safari or IE), show a bootbox to show the dialog instead.
|
||||||
|
var isIE = navigator.appName.indexOf("Internet Explorer") != -1;
|
||||||
|
var isMobileSafari = navigator.userAgent.match(/(iPod|iPhone|iPad)/) && navigator.userAgent.match(/AppleWebKit/);
|
||||||
|
|
||||||
|
if (opt_async && (isIE || isMobileSafari)) {
|
||||||
|
bootbox.dialog({
|
||||||
|
"message": "Please click 'Subscribe' to continue",
|
||||||
|
"buttons": {
|
||||||
|
"subscribe": {
|
||||||
|
"label": "Subscribe",
|
||||||
|
"className": "btn-primary",
|
||||||
|
"callback": function() {
|
||||||
|
planService.showSubscribeDialog($scope, orgname, planId, callbacks, opt_title, false);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"close": {
|
||||||
|
"label": "Cancel",
|
||||||
|
"className": "btn-default"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (callbacks['opening']) {
|
if (callbacks['opening']) {
|
||||||
callbacks['opening']();
|
callbacks['opening']();
|
||||||
}
|
}
|
||||||
|
@ -3904,7 +3929,7 @@ quayApp.directive('planManager', function () {
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.changeSubscription = function(planId) {
|
$scope.changeSubscription = function(planId, opt_async) {
|
||||||
if ($scope.planChanging) { return; }
|
if ($scope.planChanging) { return; }
|
||||||
|
|
||||||
var callbacks = {
|
var callbacks = {
|
||||||
|
@ -3918,7 +3943,7 @@ quayApp.directive('planManager', function () {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
PlanService.changePlan($scope, $scope.organization, planId, callbacks);
|
PlanService.changePlan($scope, $scope.organization, planId, callbacks, opt_async);
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.cancelSubscription = function() {
|
$scope.cancelSubscription = function() {
|
||||||
|
@ -3981,7 +4006,7 @@ quayApp.directive('planManager', function () {
|
||||||
if ($scope.readyForPlan) {
|
if ($scope.readyForPlan) {
|
||||||
var planRequested = $scope.readyForPlan();
|
var planRequested = $scope.readyForPlan();
|
||||||
if (planRequested && planRequested != PlanService.getFreePlan()) {
|
if (planRequested && planRequested != PlanService.getFreePlan()) {
|
||||||
$scope.changeSubscription(planRequested);
|
$scope.changeSubscription(planRequested, /* async */true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Reference in a new issue