Components

Feedback

Components that communicate state and events to the user.

Alert

Contextual feedback messages for user actions or system state. Three variants: banner (filled), outline, and inline (compact).

Types
Variants
Dismissible

Empty State

Placeholder component for empty lists, search results, and drop zones. All slots are optional.

Default
No documents uploaded yet
Drop your PIT-11, ZUS, and any deduction receipts here.
Dashed & Compact variants
Drop documents here
PDF, JPG, PNG — up to 10 MB each
All caught up
No outstanding tasks for tax year 2025.

Toast

Transient notification overlay that auto-dismisses after a configurable duration. Triggered via the JS API or automatically from async form responses.

Types
Custom duration & dismiss

Error Page

Full-viewport error page with dot-grid background, watermark, coloured icon, status pill, title, description, and optional action slots. Five built-in HTTP codes with matching colours and default copy.

Props

PropTypeDefaultDescription
codeint404HTTP status code. Supported: 401, 403, 404, 500, 503. Any other value renders a neutral variant.
title?stringnullOverrides the default title for the given code.
description?stringnullOverrides the default description for the given code.

Slots

SlotRequiredDescription
brandNoBrand corner content (top-left). Pass your logo mark and app name. Hidden when omitted.
actionsNoAction buttons rendered below the description. Hidden when omitted.
footerNoSupport footer text (bottom-centre). Hidden when omitted.
404 — Page not found
Error 404

Page not found

The page you're looking for has moved, been deleted, or never existed. Double-check the URL or head back to the dashboard.

500 — Something went wrong
Error 500

Something went wrong

We hit an unexpected snag on our end. Our team has been automatically notified and is working on a fix. Try refreshing in a moment.

403 — Access denied
Error 403

Access denied

You don't have permission to view this page. If you think this is a mistake, contact your account administrator or reach out to support.

401 — Session expired
Error 401

Session expired

Your session timed out for security. Sign in again to continue — your progress has been saved and you'll pick up right where you left off.

503 — Maintenance
Maintenance

Back very shortly

We're performing scheduled maintenance to improve reliability and performance. Sit tight — we'll be up again in just a few minutes.

Custom copy
Error 500

We'll be right back

Our engineers are on it. Please try again in a few minutes.

With brand, actions & footer slots
A
Acme
Error 404

Page not found

The page you're looking for has moved, been deleted, or never existed. Double-check the URL or head back to the dashboard.