Web app for the Callora API marketplace: developer dashboard, API management, and billing views.
- React 18 + TypeScript
- Vite for build and dev server
- React Router v6 for client-side routing
- Minimal UI (no component library); ready to extend
- Landing page with product overview
- Dashboard (usage stats, vault balance)
- Screen-reader-friendly dashboard usage gauge with visible usage state and remaining allowance
- Marketplace (browse and compare APIs)
- Billing (USDC deposit, Stellar settlement, transaction tracking)
- API Usage analytics view
- 500 error page with retry flow
- 404 catch-all page
- Theme playground for previewing primary/accent/surface tokens live
- Dev proxy to backend at
http://localhost:3000for/api - Global Command Palette: Instantly jump to views, search APIs by name, cycle/toggle light & dark themes, or trigger vault deposits. Use
Cmd+Kon macOS orCtrl+Kon Windows/Linux to open.
- Open Command Palette:
Cmd + K(macOS) orCtrl + K(Windows/Linux) - Navigate options:
Up / Down Arrowkeys - Select option:
Enter - Close Palette:
Escapeor backdrop click
Callora uses a comprehensive design token system and component library. All contributors must follow the UI Design System guide when building or modifying UI.
Key principles:
- Use design tokens, not inline hex values — All colors, spacing, and shadows use CSS custom properties
- Reuse shared components — Use existing components from
src/components/before creating new ones - Maintain accessibility — All UI must be keyboard navigable and screen reader friendly
- Test both themes — Verify appearance in both light and dark modes
-
Prerequisites: Node.js 18+
-
Install and run:
npm install npm run dev
-
Open http://localhost:5173.
The dashboard includes an accessible usage gauge that summarizes API spend for the current cycle. It exposes role="progressbar", numeric ARIA values, and a human-readable usage state such as “Within limit”, “Approaching limit”, “Critical usage”, “Limit reached”, or “No limit configured” so screen-reader users receive the same status information as sighted users.
| Command | Description |
|---|---|
npm run dev |
Start dev server (port 5173) |
npm run build |
TypeScript check + production build |
npm run preview |
Serve production build locally |
| Path | Description |
|---|---|
/ |
Landing page |
/dashboard |
Developer dashboard |
/marketplace |
API marketplace |
/billing |
USDC deposit and settlements |
/api-usage |
API usage analytics |
/theme-playground |
Live theme token playground for designers |
/500 |
Server error page |
* |
404 not found |
callora-frontend/
├── src/
│ ├── App.tsx # Router, layout, and route definitions
│ ├── main.tsx # Entry point
│ ├── index.css # Global styles and design tokens
│ ├── ThemeContext.tsx # Light/dark theme context
│ ├── ThemeToggle.tsx # Theme toggle component
│ ├── ApiUsage.tsx # API usage analytics view
│ ├── config/ # Shared app configuration
│ │ └── constants.ts # App constants (URLs, deposit limits, loading delay)
│ ├── components/ # Shared UI components
│ │ ├── ApiCard.tsx
│ │ ├── Breadcrumb.tsx
│ │ ├── CodeExample.tsx
│ │ ├── CommandPalette.css
│ │ ├── CommandPalette.test.tsx
│ │ ├── CommandPalette.tsx
│ │ ├── CommandPalette_MANUAL_TEST_PLAN.md
│ │ ├── Dashboard.tsx
│ │ ├── EmptyState.tsx
│ │ ├── FiltersSidebar.tsx
│ │ ├── NotFound.tsx
│ │ ├── SearchBar.tsx
│ │ ├── ServerError.tsx
│ │ ├── ServerErrorDemo.tsx
│ │ └── Skeleton.tsx
│ ├── pages/ # Standalone page components
│ │ ├── ApiDetailPage.tsx
│ │ └── MarketplacePage.tsx
│ ├── hooks/ # Custom React hooks
│ │ └── useDebounce.ts
│ ├── data/ # Static and mock data
│ │ └── mockApis.ts
│ ├── utils/ # Utility functions
│ │ └── format.ts # Currency formatters (formatUsdc, formatUsdShortcut, formatPrice)
│ └── vite-env.d.ts
├── docs/
│ └── UI-Design-System.md
├── index.html
├── package.json
├── tsconfig.json
└── vite.config.ts
This repo is part of Callora. Backend and contracts live in separate repos: callora-backend, callora-contracts.
See CONTRIBUTING.md for contribution guidelines.