diff --git a/services/web/app/src/Features/Subscription/SubscriptionViewModelBuilder.js b/services/web/app/src/Features/Subscription/SubscriptionViewModelBuilder.js index f85c7e1e68..dfc91aaee8 100644 --- a/services/web/app/src/Features/Subscription/SubscriptionViewModelBuilder.js +++ b/services/web/app/src/Features/Subscription/SubscriptionViewModelBuilder.js @@ -272,6 +272,11 @@ function buildUsersSubscriptionViewModel(user, callback) { pendingSubscriptionTax, recurlySubscription.currency ) + personalSubscription.recurly.currentPlanDisplayPrice = + SubscriptionFormatters.formatPrice( + recurlySubscription.unit_amount_in_cents + addOnPrice + tax, + recurlySubscription.currency + ) const pendingTotalLicenses = (pendingPlan.membersLimit || 0) + pendingAdditionalLicenses personalSubscription.recurly.pendingAdditionalLicenses = diff --git a/services/web/frontend/js/main/subscription-dashboard.js b/services/web/frontend/js/main/subscription-dashboard.js index cc12850560..1c20fe65ab 100644 --- a/services/web/frontend/js/main/subscription-dashboard.js +++ b/services/web/frontend/js/main/subscription-dashboard.js @@ -210,6 +210,10 @@ App.controller( function ($scope, $modal, RecurlyPricing) { if (!ensureRecurlyIsSetup()) return + function stripCentsIfZero(displayPrice) { + return displayPrice ? displayPrice.replace(/\.00$/, '') : '...' + } + $scope.changePlan = () => $modal.open({ templateUrl: 'confirmChangePlanModalTemplate', @@ -239,6 +243,26 @@ App.controller( const planCode = plan.planCode const subscription = getMeta('ol-subscription') const { currency, taxRate } = subscription.recurly + if (subscription.recurly.displayPrice) { + if (subscription.pendingPlan?.planCode === planCode) { + $scope.displayPrice = stripCentsIfZero( + subscription.recurly.displayPrice + ) + return + } + if (subscription.planCode === planCode) { + if (subscription.pendingPlan) { + $scope.displayPrice = stripCentsIfZero( + subscription.recurly.currentPlanDisplayPrice + ) + } else { + $scope.displayPrice = stripCentsIfZero( + subscription.recurly.displayPrice + ) + } + return + } + } $scope.displayPrice = '...' // Placeholder while we talk to recurly RecurlyPricing.loadDisplayPriceWithTax(planCode, currency, taxRate).then( recurlyPrice => {