Skip to main content

Onboarding Wizard

A 4-step tenant onboarding flow: Organisation details → Plan selection → Team setup → Review & confirm.

Components used

Wizard · Stepper · WizardNav · Step · SummaryCard · Input · Select · RadioGroup · Button

Preview · Onboarding Wizard

Code

<div style="background:var(--muted);min-height:500px;display:flex;align-items:flex-start;justify-content:center;padding:2rem;box-sizing:border-box">
<div style="width:100%;max-width:640px">

<!-- Progress -->
<div style="margin-bottom:1.5rem">
<div style="display:flex;justify-content:space-between;margin-bottom:0.5rem;font-size:0.8rem">
<span style="font-weight:500">Step 2 of 4 — Plan Selection</span>
<span style="color:var(--muted-foreground)">50% complete</span>
</div>
<div style="height:4px;background:var(--border);border-radius:4px;overflow:hidden">
<div style="width:50%;height:100%;background:var(--primary);border-radius:4px"></div>
</div>
<div style="display:flex;gap:0;margin-top:0.75rem;border:1px solid var(--border);border-radius:6px;overflow:hidden;font-size:0.8rem">
<div style="flex:1;padding:0.5rem 0.75rem;background:color-mix(in srgb,var(--primary) 10%,transparent);color:var(--primary);text-align:center;font-weight:500">✓ Details</div>
<div style="flex:1;padding:0.5rem 0.75rem;background:var(--primary);color:var(--primary-foreground);text-align:center;font-weight:600;border-left:1px solid var(--border)">Plan</div>
<div style="flex:1;padding:0.5rem 0.75rem;text-align:center;color:var(--muted-foreground);border-left:1px solid var(--border)">Team</div>
<div style="flex:1;padding:0.5rem 0.75rem;text-align:center;color:var(--muted-foreground);border-left:1px solid var(--border)">Review</div>
</div>
</div>

<!-- Step card -->
<div class="card" style="padding:2rem">
<h2 style="margin:0 0 0.5rem;font-size:1.125rem;font-weight:700">Choose your plan</h2>
<p style="margin:0 0 1.5rem;font-size:0.875rem;color:var(--muted-foreground)">Select the plan that fits your team. You can upgrade at any time.</p>

<div class="vstack" style="gap:0.75rem">
<!-- Plan options as radio-style cards -->
<label style="display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:8px;cursor:pointer">
<input type="radio" name="plan" style="margin-top:3px" />
<div>
<div style="font-weight:600;font-size:0.9rem">Starter</div>
<div style="font-size:0.8rem;color:var(--muted-foreground);margin:0.25rem 0">Up to 10 users · 5GB storage</div>
<div style="font-weight:700;font-size:1rem">$49 <span style="font-weight:400;font-size:0.8rem;color:var(--muted-foreground)">/month</span></div>
</div>
</label>
<label style="display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:2px solid var(--primary);border-radius:8px;cursor:pointer;background:color-mix(in srgb,var(--primary) 4%,transparent)">
<input type="radio" name="plan" checked style="margin-top:3px" />
<div style="flex:1">
<div style="display:flex;align-items:center;gap:0.5rem">
<span style="font-weight:600;font-size:0.9rem">Pro</span>
<span class="badge accent" style="font-size:0.65rem">Recommended</span>
</div>
<div style="font-size:0.8rem;color:var(--muted-foreground);margin:0.25rem 0">Up to 100 users · 50GB storage</div>
<div style="font-weight:700;font-size:1rem">$249 <span style="font-weight:400;font-size:0.8rem;color:var(--muted-foreground)">/month</span></div>
</div>
</label>
<label style="display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:8px;cursor:pointer">
<input type="radio" name="plan" style="margin-top:3px" />
<div>
<div style="font-weight:600;font-size:0.9rem">Enterprise</div>
<div style="font-size:0.8rem;color:var(--muted-foreground);margin:0.25rem 0">Unlimited users · custom storage</div>
<div style="font-weight:700;font-size:1rem">Custom pricing</div>
</div>
</label>
</div>
</div>

<!-- Nav -->
<div style="display:flex;justify-content:space-between;margin-top:1rem">
<button data-variant="secondary" class="small">← Back</button>
<button class="small">Next — Team Setup →</button>
</div>
</div>
</div>