# @pyre/web User-facing PYRE web app. **Skeleton only** — no wallet or business logic is implemented yet (see [`CLAUDE.md`](../../CLAUDE.md) and §13 of the design doc). Stack: Next.js (App Router) + TypeScript + Tailwind + Solana Wallet Adapter + React Query. ## Responsibilities (§13) - Landing page - Wallet connect (Solana Wallet Adapter) - Scanner UI — display token accounts and classification grouping - Cleanup preview — accounts to close, tokens to burn, rent returned, fees, warnings, rent destination (decode tx and match against preview before signing) - Receipt page — tx signature, accounts closed, tokens burned, rent returned, skipped accounts - Prometheus generation preview — Spawn name/ticker/lore/image-prompt review - Admin review page — approve/reject generated Spawn packages ## Trust rules (do not weaken) - PYRE never holds private keys; all signing is client-side in the user's wallet. - Always show a preview and match the decoded transaction against it before requesting a signature. - Recovered ATA rent returns to the user by default. ## TODO - [ ] Tailwind + PostCSS config and global styles - [ ] WalletAdapter / React Query providers - [ ] Scanner page wired to `POST /api/scan` - [ ] Cleanup preview + transaction decode/match UI - [ ] Sign flow via wallet adapter - [ ] Receipt page wired to `POST /api/receipt` - [ ] Prometheus generation preview + admin review pages ## Scripts - `dev` — `next dev` - `build` — `next build` - `typecheck` — `tsc --noEmit` - `lint` / `test` — placeholders for now