Commit Graph

34 Commits

Author SHA1 Message Date
2ee68c7ac2 feat(preview): add interactive address bar and visual editing tools to preview header 2026-06-12 10:52:38 -07:00
e240481ba6 design(chat): hide verbose command args for dev server and shell tools to keep UI clean 2026-06-11 17:14:15 -07:00
2bff945dd8 design(chat): simplify tool labels to plain English 2026-06-11 11:52:36 -07:00
180f0bdc0a design(chat): replace heavy phase dividers with sticky active-status bar; flatten tool groups to match Base44 aesthetic 2026-06-11 11:40:16 -07:00
82a41f7e95 fix(stop+stability): stop button interrupts live generation; classifier, prompt + preview pane improvements
Stop button fix:
- Plumb AbortSignal end-to-end: callVibnChat → Gemini SDK (config.abortSignal) / OpenAI fetch → executeMcpTool (/api/mcp fetch)
- Treat abort as clean user stop (not fatal error); partial reply persisted with '(stopped by user)'

Classifier fix:
- Add timeout/gateway/5xx/connection-error vocabulary to diagnose intent
- Prevents 'I get a gateway timeout' from falling through to feature_build (40 rounds) and looping

Prompt / agent behaviour:
- Render verification is now scope-aware: small edits stop at green healthCheck; no browser_console/curl audit on healthy server
- Sanitize stale '### Phase Checkpoint' walls from loaded history so old threads stop biasing new turns
- Next.js dev command updated to --no-turbopack for container stability (per-route lazy compile caused cold-start 503s)
- New public page prompt: agent checks middleware allowlist in the same turn
- Scope discipline and QA-tool gating carried forward from prior session

Code cleanup:
- Remove duplicate AgentPhase declaration (TS2440)
- Remove dead checkpoint emit branch and orphan 'checkpoint' phase value
- Remove unused MAX_TOOL_ROUNDS constant

Preview pane (build status):
- 4-state machine: initial-load / building (with elapsed timer) / build-failed / not-running
- pollMs 0 → 5 000ms so dev-server recovery and build completion auto-update without refresh
- anatomy route + use-anatomy type: inFlightBuild gains createdAt for elapsed timer
2026-06-10 21:40:48 -07:00
39cb9194a5 feat(verification): acceptance-check layer + executor fix-loop; hide phase-checkpoint walls; guaranteed turn-end summary. Verification gated behind VIBN_VERIFICATION_ENABLED. 2026-06-10 19:43:36 -07:00
46291becd3 ux(chat): remove the reasoning/suggestion bubble and the 'executing tools & planning next steps' status line 2026-06-10 17:52:38 -07:00
a87faa2353 ux(chat): clean tool-pill results (no raw JSON, Failed/exit verbs); structured build-health status instead of 'didn't reach a clean stopping point'; label active toolbar mode 2026-06-10 17:44:19 -07:00
3c0a6860fc design(chat): align composer action buttons to the right 2026-06-10 14:15:14 -07:00
6a2027b0d4 design(chat): add paperclip button to chat input and auto-resize textarea 2026-06-10 14:13:31 -07:00
662caf230a design(chat): implement glass-box phase tracker and checkpoint rendering in timeline 2026-06-09 19:01:44 -07:00
ef4a06a57c ux(chat): tune silent-loop status nudge threshold to 6 rounds and strip leaked tool trace payloads from UI 2026-06-09 15:02:34 -07:00
b5b18ccd32 design(chat): replace raw mcp tool logs with active-progressive visual badges 2026-06-09 13:06:31 -07:00
2714f8cdf3 feat(frontend): email+password auth, /signin + /signup pages, marketing consolidation, onboarding workspace naming + full data persistence 2026-06-06 20:28:38 -07:00
0480b306f1 feat: flatten routes and merge marketing and onboarding directories 2026-06-06 18:52:03 -07:00
4d40496739 feat: complete live-verified GTM onboarding flow & places autocomplete search proxies 2026-06-06 17:53:13 -07:00
91a376ac0a feat(refactor): dynamic agent status ticker card across all execution rounds 2026-05-21 17:24:12 -07:00
b3dd3714c3 feat(refactor): live zed-style codebase files autocomplete and context attachment 2026-05-21 17:20:31 -07:00
8049a7f1ab feat(refactor): premium zed-style chat UI, collapsible reasoning, and comprehensive strict type sweeps 2026-05-21 17:05:42 -07:00
7c45fdc5cc fix(ai): bump roundSinceText cutoff to 30 to prevent panic loops 2026-05-19 15:26:15 -07:00
63b64d5fc2 feat(ui): implement explicit chat modes for collaborate, delegate, and vibe coding 2026-05-19 15:18:30 -07:00
618f7796b2 feat(ai): optimize tool loops, fix deployments, and integrate new onboarding flow 2026-05-19 12:52:47 -07:00
331312b648 fix(ui): adopt SWR for useAnatomy to deduplicate requests across components and fix API flooding 2026-05-17 20:18:19 -07:00
6b8862ef2b feat(api): comprehensive QA hardening — security gates, chat improvements, beta scaffolds
Closes checklist items F-01..F-06, D-01..D-28, S-01..S-10, C-01..C-07,
B-01..B-07, R-01..R-02, O-03.

Security (28 deletions + 10 auth gates):
- Delete 28 unauthenticated debug/cursor/firebase/test routes
- Gate ai/chat, ai/conversation, context/summarize, work-completed with withTenantProject/withAuth
- Add HMAC-SHA256 signature verification to webhooks/coolify
- Switch all admin secret comparisons to timingSafeStringEq

Foundations (lib/server/*):
- api-handler.ts: withAuth, withTenantProject, withWorkspace, withAdminSecret, withRateLimit
- logger.ts: structured request-scoped logging with turnId
- audit-log.ts: writeAuditLog helper + audit_log table
- rate-limit.ts: Postgres sliding window rate limiter
- coolify-webhook.ts: verifyCoolifySignature
- timing-safe.ts: timingSafeStringEq

Chat hardening (chat/route.ts):
- MAX_TOOL_ROUNDS 15 → 8 (C-01)
- Loop detection: hard-break at 3 identical fingerprints (was 5) (C-02)
- Add 6-consecutive-tool-call hard-break (C-02)
- Mode: respond first, act second prompt block (C-03)
- SSE heartbeat every 25s via setInterval (C-04)
- Per-tool 45s timeout via Promise.race (C-05)
- turnId per-turn UUID for log correlation (C-06)
- Recovery fires when roundsSinceText >= 4 (C-07)
- SSE plan event on plan_task_add/edit (B-05)

Beta features:
- invites table + GET/POST /api/invites (P4.8)
- invites/[token] validate + redeem (P4.8)
- fs_project_dev_servers table + lib/server/dev-server-state.ts (P6.B1)
- fs_project_secrets table + CRUD routes (P6.D2)
- lib/integrations/brief-extract.ts (P3.7)

Documentation:
- app/api/ROUTES.md: full route map with auth + tenant
2026-05-17 19:17:22 -07:00
8cb7a9450b feat(ui): add manual reload button to preview device toggles 2026-05-15 16:31:31 -07:00
4adf7a7659 feat(ui): remove design tab from primary navigation 2026-05-15 15:49:01 -07:00
dc82ccc47a feat(ui): move preview device toggles into the global nav rail 2026-05-15 15:42:49 -07:00
f3b957ace2 feat(ui): add showcase toggle and runtime renderer to design explorer 2026-05-15 14:09:27 -07:00
b4821b3eba fix(ui): handle fallback UI for design systems without visual previews 2026-05-15 14:00:01 -07:00
f9d74205fb feat(ui): implement split-pane live preview for design systems 2026-05-15 13:56:12 -07:00
8487acc9e0 fix(ui): import missing Sparkles icon in chat panel 2026-05-15 13:15:10 -07:00
69c89892d5 feat(ui): add animated thinking bubble to chat panel to indicate ai progress 2026-05-13 20:36:22 -07:00
432065d18f feat(ui): add expandable tool details to timeline tool group components 2026-05-13 15:12:58 -07:00
abf9bf89c2 chore: convert submodules to standard directories for true monorepo structure 2026-05-13 14:54:23 -07:00