[PULSE-57] Billing UX: renewal display, design fixes, React crash fix #32

Merged
uz1mani merged 16 commits from staging into main 2026-02-20 17:32:33 +00:00
12 changed files with 341 additions and 40 deletions
Showing only changes of commit 96b3919e52 - Show all commits

View File

@@ -6,13 +6,13 @@
* Fetches session status and redirects to dashboard on success. * Fetches session status and redirects to dashboard on success.
*/ */
import { useEffect, useState } from 'react' import { Suspense, useEffect, useState } from 'react'
import { useRouter, useSearchParams } from 'next/navigation' import { useRouter, useSearchParams } from 'next/navigation'
import { getCheckoutSessionStatus } from '@/lib/api/billing' import { getCheckoutSessionStatus } from '@/lib/api/billing'
import { LoadingOverlay } from '@ciphera-net/ui' import { LoadingOverlay } from '@ciphera-net/ui'
import Link from 'next/link' import Link from 'next/link'
export default function CheckoutReturnPage() { function CheckoutReturnContent() {
const router = useRouter() const router = useRouter()
const searchParams = useSearchParams() const searchParams = useSearchParams()
const sessionId = searchParams.get('session_id') const sessionId = searchParams.get('session_id')
@@ -91,3 +91,11 @@ export default function CheckoutReturnPage() {
</div> </div>
) )
} }
export default function CheckoutReturnPage() {
return (
<Suspense fallback={<LoadingOverlay logoSrc="/pulse_icon_no_margins.png" title="Loading…" />}>
<CheckoutReturnContent />
</Suspense>
)
}