Frontend: - Replace Next.js with Vite + React + TypeScript - Add new component architecture (app-shell, sidebar, dashboard modules) - Implement product modules: FRAME, safety protocols, walkthrough checkin, campus/staff attendance, personality quiz, sign language, classroom timer - Add shadcn/ui component library with Tailwind CSS - Remove legacy generated components, stores, and pages Backend: - Add product migrations: frame_entries, user_progress, safety_quiz_results, walkthrough_checkins, communication_events, personality_quiz_results, campus_attendance_config/summaries, staff_attendance_records, content_catalog - Add corresponding models, services, and routes - Implement cookie-based auth with refresh token rotation - Add content catalog seeder with product content - Migrate to ESLint flat config - Switch from yarn to npm Infrastructure: - Update .gitignore for new tooling - Add project documentation (CLAUDE.md, docs/) - Remove deprecated config files and yarn.lock Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
924 B
924 B
Campus Catalog
Purpose
Campus records and campus branding come from the backend database through GET /api/public/campuses.
The frontend does not define campus names, campus IDs, mascot labels, online status, descriptions, or per-campus branding in runtime constants.
frontend/src/shared/constants/campusDisplay.ts contains only shared helpers and generic labels.
frontend/tailwind.config.ts safelists allowed branding utility classes so backend-controlled campus branding can render after production builds.
Frontend Flow
- Data access:
frontend/src/shared/api/campuses.ts - Business mapping and React Query hook:
frontend/src/business/campuses/ - Runtime consumers use
useCampusCatalog()and pass mappedCampusInfoview models into components. - Tests use
frontend/src/test-seeds/campuses.ts.
Runtime code must not import campus records from test seeds or define campus rows in appData.ts.