Files
metabuilder/frontends/nextjs/src
johndoe6345789 890b491819 feat: TD-1 Phase 1 & 2.1 complete - Create unified db-client integration
Phase 1 (DBAL Foundation): ALREADY DONE 
- DBAL exports getDBALClient(), seedDatabase(), getPrismaClient()
- All factories and Prisma initialization in DBAL

Phase 2.1 (Unified Integration Point): COMPLETE 
- Created /frontends/nextjs/src/lib/db-client.ts
- Exports unified `db` instance and `getDB()` factory
- Single source of truth for database access in frontend

Support Artifacts:
- Created /TD_1_REFACTORING_GUIDE.md with step-by-step refactoring instructions
- Documents exact patterns to replace 14 Prisma imports + 110+ getAdapter() calls
- Provides 3 implementation approaches (automated, manual, git-based)
- Includes verification checklist and testing strategy

Updated TECH_DEBT.md:
- References new refactoring guide
- Shows Phase 1 is done, Phase 2 ready for execution
- Clear instructions for Phase 2 frontend cleanup
- Phase 3 build system updates

Scope: Ready to refactor ~100 frontend files to use new db-client pattern.

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-01-15 01:16:03 +00:00
..
2026-01-08 17:05:28 +00:00

Source Code (src/)

This directory contains the main React application source code for MetaBuilder's frontend.

Structure

  • components/ - React UI components organized by feature and level
  • lib/ - Utility libraries, database access, authentication, and business logic
  • hooks/ - Custom React hooks for state management and side effects
  • types/ - TypeScript type definitions
  • styles/ - Global stylesheets (SCSS)
  • tests/ - Component and unit tests
  • seed-data/ - Initial database population scripts

Key Files

  • main.tsx - Application entry point
  • App.tsx - Main application component with 5-level architecture logic
  • index.scss - Global styles (imports all component styles)

Architecture

The application uses a 5-level permission system:

  1. Level 1 (Public) - Unauthenticated access
  2. Level 2 (User) - Basic authenticated user
  3. Level 3 (Admin) - Administrative functions
  4. Level 4 (God) - Advanced system functions
  5. Level 5 (Supergod) - Complete system control

Permission checking is handled in lib/auth.ts and enforced throughout the component hierarchy.

Technologies

  • React 18+ - UI framework
  • TypeScript - Type safety
  • Tailwind CSS - Styling
  • Prisma ORM - Database access
  • Shadcn/ui - UI component library
  • Vite - Build tool

Development

# Install dependencies
npm install

# Start development server
npm run dev

# Build for production
npm run build

# Run tests
npm run test

Database

The application uses Prisma ORM with SQLite/PostgreSQL. Database schema is defined in prisma/schema.prisma and migrations are managed through prisma/migrations/.

Adding New Features

  1. Define data model in prisma/schema.prisma
  2. Create Prisma migration: npm run db:migrate
  3. Build components in components/
  4. Implement business logic in lib/
  5. Add permissions check via canAccessLevel()
  6. Test at appropriate permission levels

See /docs/ for comprehensive development guides.