6 plans across 3 waves covering market-aware pricing, exchange rates, community price data, and currency-normalized display. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
17 KiB
Roadmap: GearBox
Milestones
- ✅ v1.0 MVP — Phases 1-3 (shipped 2026-03-15)
- ✅ v1.1 Fixes & Polish — Phases 4-6 (shipped 2026-03-15)
- ✅ v1.2 Collection Power-Ups — Phases 7-9 (shipped 2026-03-16)
- ✅ v1.3 Research & Decision Tools — Phases 10-13 (shipped 2026-04-08)
- ✅ v2.0 Platform Foundation — Phases 14-23 (shipped 2026-04-08)
- ✅ v2.1 Public Discovery — Phases 24-27 (shipped 2026-04-12)
- ✅ v2.2 User Experience Polish — Phases 28-31 (shipped 2026-04-13)
- 🚧 v2.3 Global & Social Ready — Phases 32-34 (planned)
Phases
✅ v1.0 MVP (Phases 1-3) — SHIPPED 2026-03-15
- Phase 1: Foundation and Collection (4/4 plans) — completed 2026-03-14
- Phase 2: Planning Threads (3/3 plans) — completed 2026-03-15
- Phase 3: Setups and Dashboard (3/3 plans) — completed 2026-03-15
✅ v1.1 Fixes & Polish (Phases 4-6) — SHIPPED 2026-03-15
- Phase 4: Database & Planning Fixes (2/2 plans) — completed 2026-03-15
- Phase 5: Image Handling (2/2 plans) — completed 2026-03-15
- Phase 6: Category Icons (3/3 plans) — completed 2026-03-15
✅ v1.2 Collection Power-Ups (Phases 7-9) — SHIPPED 2026-03-16
- Phase 7: Weight Unit Selection (2/2 plans) — completed 2026-03-16
- Phase 8: Search, Filter, and Candidate Status (2/2 plans) — completed 2026-03-16
- Phase 9: Weight Classification and Visualization (2/2 plans) — completed 2026-03-16
✅ v1.3 Research & Decision Tools (Phases 10-13) — SHIPPED 2026-04-08
- Phase 10: Schema Foundation + Pros/Cons Fields (1/1 plans) — completed 2026-03-16
- Phase 11: Candidate Ranking (2/2 plans) — completed 2026-03-16
- Phase 12: Comparison View (1/1 plans) — completed 2026-03-17
- Phase 13: Setup Impact Preview (2/2 plans) — completed 2026-04-08
✅ v2.0 Platform Foundation (Phases 14-23) — SHIPPED 2026-04-08
- Phase 14: PostgreSQL Migration (6/6 plans) — completed 2026-04-05
- Phase 15: External Authentication (3/3 plans) — completed 2026-04-05
- Phase 16: Multi-User Data Model (4/4 plans) — completed 2026-04-05
- Phase 17: Object Storage (3/3 plans) — completed 2026-04-05
- Phase 18: Global Items & Public Profiles (5/5 plans) — completed 2026-04-05
- Phase 19: Reference Item Model & Tags Schema (3/3 plans) — completed 2026-04-05
- Phase 20: FAB & Full-Screen Catalog Search (2/2 plans) — completed 2026-04-06
- Phase 21: Item & Catalog Detail Pages (3/3 plans) — completed 2026-04-06
- Phase 22: Add-from-Catalog & Thread Integration (2/2 plans) — completed 2026-04-06
- Phase 23: Manual Entry Fallback (1/1 plans) — completed 2026-04-06
✅ v2.1 Public Discovery (Phases 24-27) — SHIPPED 2026-04-12
- Phase 24: Public Access & Infrastructure (2/2 plans) — completed 2026-04-10
- Phase 25: Catalog Enrichment & Agent Tools (2/2 plans) — completed 2026-04-10
- Phase 26: Discovery Landing Page (3/3 plans) — completed 2026-04-10
- Phase 27: Top Nav Restructure & Search Bar Rethink (4/4 plans) — completed 2026-04-12
✅ v2.2 User Experience Polish (Phases 28-31) — SHIPPED 2026-04-13
- Phase 28: Profile & Logto Integration (3/3 plans) — completed 2026-04-12
- Phase 29: Image Presentation (5/5 plans) — completed 2026-04-12
- Phase 30: Onboarding Redesign (3/3 plans) — completed 2026-04-12
- Phase 31: Mobile Polish (2/2 plans) — completed 2026-04-12
v2.3 Global & Social Ready (Planned)
Milestone Goal: Make GearBox work for a global audience with setup sharing, multi-currency support, and localization infrastructure.
- Phase 32: Setup Sharing System — Visibility toggle (private/link/public), link sharing, schema future-proofed for likes, friends, and collaborative editing
- Phase 33: Currency System — Multi-currency support (USD/EUR/GBP), price display per user preference
- Phase 34: i18n Foundation — Translation framework, string extraction, locale-aware formatting
Phase Details
Phase 24: Public Access & Infrastructure
Goal: Anyone can browse the catalog, public setups, and user profiles without logging in Depends on: Phase 23 (v2.0 complete) Requirements: PUBL-01, PUBL-02, PUBL-03, PUBL-04, PUBL-05, INFR-01 Success Criteria (what must be TRUE):
- Visiting the app without a session shows the app content immediately — no auth spinner, no redirect to login
- An unauthenticated visitor can browse the global item catalog and open a catalog detail page
- An unauthenticated visitor can view a public setup and see its items and totals
- An unauthenticated visitor can view a user's public profile page
- Attempting to create, edit, or delete any item/setup/thread while unauthenticated redirects to login Plans: 2 plans
Plans:
- 24-01-PLAN.md — Rate limit factory and tiered public endpoint protection
- 24-02-PLAN.md — Client-side public access (render-first root, auth prompt, setup/catalog guards)
UI hint: yes
Phase 25: Catalog Enrichment & Agent Tools
Goal: Global items carry attribution metadata and can be bulk-populated by an MCP agent swarm Depends on: Phase 24 Requirements: CATL-01, CATL-02, CATL-03, CATL-04, CATL-05, SEED-01, SEED-02, SEED-03 Success Criteria (what must be TRUE):
- A catalog item detail page displays image credit and a link to the image source
- Attempting to import two items with the same brand and model updates the existing record rather than creating a duplicate
- A single API call with an array of items imports them all, upserting on (brand, model) conflict
- An MCP agent can call
upsert_catalog_itemwith attribution fields and the item appears in the catalog - An MCP agent can call
bulk_upsert_catalogwith a batch of items and all are persisted with attribution Plans: 2 plans
Plans:
- 25-01-PLAN.md — Schema migration (attribution columns + unique constraint) and upsert service layer
- 25-02-PLAN.md — HTTP upsert routes, MCP catalog tools, and client attribution display
Phase 26: Discovery Landing Page
Goal: The app opens to a public discovery feed with prominent catalog search, not a personal dashboard Depends on: Phase 25 Requirements: DISC-01, DISC-02, DISC-03, DISC-04, DISC-05, INFR-02 Success Criteria (what must be TRUE):
- The root URL shows a landing page with a catalog search bar at the top, visible without logging in
- Below the search bar, a feed of popular public setups is visible with titles, creator names, and item counts
- The landing page shows a section of recently added catalog items
- The landing page shows a section of trending categories
- A logged-in user sees a "Go to Collection" link or button on the landing page that navigates to their personal collection Plans: 3 plans
Plans:
- 26-01-PLAN.md — Discovery service layer with cursor pagination (TDD)
- 26-02-PLAN.md — Discovery routes, server registration, and client hooks
- 26-03-PLAN.md — Landing page UI and PublicSetupCard enhancement UI hint: yes
Phase 27: Top Nav Restructure & Search Bar Rethink
Goal: Replace the minimal TotalsBar with a persistent top navigation bar (logo, section links, catalog search, user avatar) and move mobile navigation to a bottom tab bar — elevating Setups to top-level and removing the landing page hero Depends on: Phase 26 Requirements: NAV-01, NAV-02, NAV-03, NAV-04, NAV-05 Success Criteria (what must be TRUE):
- A persistent top nav bar shows logo, Home/Collection/Setups links, catalog search, and user avatar on desktop
- Clicking Collection or Setups while anonymous triggers AuthPromptModal instead of navigating
- On mobile, navigation appears as a fixed bottom tab bar with Home, Collection, Setups, and Search icons
- The landing page no longer has a hero section — content starts with Popular Setups
- Setups has its own top-level route accessible from the nav bar, not nested in Collection tabs Plans: 4 plans
Plans:
- 27-00-PLAN.md — Wave 0: E2E test scaffolding for nav restructure
- 27-01-PLAN.md — TopNav and BottomTabBar components
- 27-02-PLAN.md — Setups top-level route and Collection tab simplification
- 27-03-PLAN.md — Root layout wiring, hero removal, and visual verification UI hint: yes
Phase 32: Setup Sharing System
Goal: Setup owners can toggle visibility between private, link-shared, and public, with schema designed for future likes, friends, and collaborative editing Depends on: Phase 28 (profiles working) Requirements: TBD (discuss phase) Success Criteria (what must be TRUE): TBD (discuss phase) Plans: 4 plans
Plans:
- 32-01-PLAN.md — Schema migration (isPublic to visibility) + shares table + full-stack update
- 32-02-PLAN.md — Share link service, API routes, and short URL redirect
- 32-03-PLAN.md — Share modal UI component with visibility picker and link management
- 32-04-PLAN.md — Shared setup viewer with token detection and read-only mode UI hint: yes
Phase 33: Currency System
Goal: Users can select their preferred currency (USD/EUR/GBP) and all prices display accordingly — full market-aware pricing system with community price data Depends on: Phase 32 Requirements: D-01 through D-21 (from discuss phase) Success Criteria (what must be TRUE):
- User can select a market/currency in settings and all prices display in that currency
- Catalog items show market-specific MSRP with community price aggregation per market
- Converted prices are clearly labeled as approximate with ~ prefix and dual display format
- Users can submit community prices for items they own (ownership validated)
- Comparison table normalizes candidate prices to user's currency for apples-to-apples comparison
- Exchange rates fetched daily from ECB via frankfurter.app with 24h cache Plans: 6 plans
Plans:
- 33-01-PLAN.md — Schema (market_prices, community_prices tables) + currency conversion service
- 33-02-PLAN.md — [BLOCKING] Database migration generation and push
- 33-03-PLAN.md — Market prices API, exchange rates endpoint, item/candidate currency context
- 33-04-PLAN.md — Community price service (ownership validation, median aggregation) + setup totals
- 33-05-PLAN.md — Formatter evolution, market/currency selector, auto-suggestion, conversion toggle
- 33-06-PLAN.md — Catalog detail market prices, comparison table normalization, MCP tool updates UI hint: yes
Phase 34: i18n Foundation
Goal: Translation framework in place with string extraction, locale-aware formatting, and at least English + one additional language Depends on: Phase 33 Requirements: TBD (discuss phase) Success Criteria (what must be TRUE): TBD (discuss phase) Plans: TBD
Progress
| Phase | Milestone | Plans Complete | Status | Completed |
|---|---|---|---|---|
| 1. Foundation and Collection | v1.0 | 4/4 | Complete | 2026-03-14 |
| 2. Planning Threads | v1.0 | 3/3 | Complete | 2026-03-15 |
| 3. Setups and Dashboard | v1.0 | 3/3 | Complete | 2026-03-15 |
| 4. Database & Planning Fixes | v1.1 | 2/2 | Complete | 2026-03-15 |
| 5. Image Handling | v1.1 | 2/2 | Complete | 2026-03-15 |
| 6. Category Icons | v1.1 | 3/3 | Complete | 2026-03-15 |
| 7. Weight Unit Selection | v1.2 | 2/2 | Complete | 2026-03-16 |
| 8. Search, Filter, and Candidate Status | v1.2 | 2/2 | Complete | 2026-03-16 |
| 9. Weight Classification and Visualization | v1.2 | 2/2 | Complete | 2026-03-16 |
| 10. Schema Foundation + Pros/Cons Fields | v1.3 | 1/1 | Complete | 2026-03-16 |
| 11. Candidate Ranking | v1.3 | 2/2 | Complete | 2026-03-16 |
| 12. Comparison View | v1.3 | 1/1 | Complete | 2026-03-17 |
| 13. Setup Impact Preview | v1.3 | 2/2 | Complete | 2026-04-08 |
| 14. PostgreSQL Migration | v2.0 | 6/6 | Complete | 2026-04-05 |
| 15. External Authentication | v2.0 | 3/3 | Complete | 2026-04-05 |
| 16. Multi-User Data Model | v2.0 | 4/4 | Complete | 2026-04-05 |
| 17. Object Storage | v2.0 | 3/3 | Complete | 2026-04-05 |
| 18. Global Items & Public Profiles | v2.0 | 5/5 | Complete | 2026-04-05 |
| 19. Reference Item Model & Tags Schema | v2.0 | 3/3 | Complete | 2026-04-05 |
| 20. FAB & Full-Screen Catalog Search | v2.0 | 2/2 | Complete | 2026-04-06 |
| 21. Item & Catalog Detail Pages | v2.0 | 3/3 | Complete | 2026-04-06 |
| 22. Add-from-Catalog & Thread Integration | v2.0 | 2/2 | Complete | 2026-04-06 |
| 23. Manual Entry Fallback | v2.0 | 1/1 | Complete | 2026-04-06 |
| 24. Public Access & Infrastructure | v2.1 | 2/2 | Complete | 2026-04-10 |
| 25. Catalog Enrichment & Agent Tools | v2.1 | 2/2 | Complete | 2026-04-10 |
| 26. Discovery Landing Page | v2.1 | 3/3 | Complete | 2026-04-10 |
| 27. Top Nav Restructure & Search Bar Rethink | v2.1 | 4/4 | Complete | 2026-04-12 |
| 28. Profile & Logto Integration | v2.2 | 3/3 | Complete | 2026-04-12 |
| 29. Image Presentation | v2.2 | 5/5 | Complete | 2026-04-13 |
| 30. Onboarding Redesign | v2.2 | 3/3 | Complete | 2026-04-12 |
| 31. Mobile Polish | v2.2 | 2/2 | Complete | 2026-04-12 |
| 32. Setup Sharing System | v2.3 | 0/4 | Planned | — |
| 33. Currency System | v2.3 | 0/6 | Planned | — |
| 34. i18n Foundation | v2.3 | TBD | Pending | — |
Backlog
Phase 999.1: Rewrite E2E Tests for OIDC Auth (BACKLOG)
Goal: E2E tests currently expect local username/password login but auth moved to external OIDC (Logto). Rewrite with mock OIDC provider or API-key-based auth bypass. Seed migration to Postgres is already done. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.2: Revamp Onboarding Flow (BACKLOG)
Goal: Redesign the onboarding experience to match the current app style and flow. Replace the manual item edit form with the catalog search function. Visual refresh to align with the newer UI patterns. Status: Promoted to Phase 30 (v2.2) Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.5: Legal Pages — ToS, Privacy Policy, and Compliance (BACKLOG)
Goal: Create Terms of Service, Privacy Policy, and any other required legal/compliance pages for a public-facing platform. Essential before opening to real users. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.6: Admin Panel (BACKLOG)
Goal: Build an admin panel for reviewing user-submitted items (catalog submissions), managing global/reference items, and general platform administration. Includes approval workflows for community contributions. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.7: User Feedback System (BACKLOG)
Goal: Add an in-app feedback collection mechanism so users can report bugs, suggest features, and share general feedback. Could be a simple form, widget, or integration with an external tool. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.8: Analytics Integration (BACKLOG)
Goal: Integrate privacy-respecting analytics (PostHog, Umami, or similar) to understand usage patterns, popular categories, search behavior, and feature adoption. Self-hosted preferred to align with independent ethos. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.9: Mobile App (BACKLOG)
Goal: Bring GearBox to mobile. Start with a PWA for quick wins (offline support, home screen install), then evaluate dedicated native apps (React Native / Flutter) for richer experience — camera for weight verification, barcode scanning, etc. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.10: Monetization Strategy (BACKLOG)
Goal: Define how GearBox sustains itself financially. Options to explore: sponsored/promoted items (brand X promotes product Y), premium features, affiliate links. Critical tension: revenue vs. independent credibility — GearBox's value is unbiased gear data, so monetization must not compromise trust. Needs deep discussion before implementation. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)
Phase 999.11: Marketing Website (BACKLOG)
Goal: Build a separate marketing/brand website (www.gearbox.de) distinct from the app (app.gearbox.de). Hero section with search bar, value proposition, feature highlights, how-it-works, social proof, and sign-up CTA. This is the public-facing front door — the first thing people see before they enter the app. The current discovery page is the in-app experience; this is the standalone website around it. Requirements: TBD Plans: TBD
Plans:
- TBD (promote with /gsd:review-backlog when ready)