Remove dynamic form builder and complete RoundProject→roundId migration
Major cleanup and schema migration: - Remove unused dynamic form builder system (ApplicationForm, ApplicationFormField, etc.) - Complete migration from RoundProject junction table to direct Project.roundId - Add sortOrder and entryNotificationType fields to Round model - Add country field to User model for mentor matching - Enhance onboarding with profile photo and country selection steps - Fix all TypeScript errors related to roundProjects references - Remove unused libraries (@radix-ui/react-toast, embla-carousel-react, vaul) Files removed: - admin/forms/* pages and related components - admin/onboarding/* pages - applicationForm.ts and onboarding.ts routers - Dynamic form builder Prisma models and enums Schema changes: - Removed ApplicationForm, ApplicationFormField, OnboardingStep, ApplicationFormSubmission, SubmissionFile models - Removed FormFieldType and SpecialFieldType enums - Added Round.sortOrder, Round.entryNotificationType - Added User.country Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -82,11 +82,7 @@ export const learningResourceRouter = router({
|
||||
include: {
|
||||
project: {
|
||||
select: {
|
||||
roundProjects: {
|
||||
select: { status: true },
|
||||
orderBy: { addedAt: 'desc' },
|
||||
take: 1,
|
||||
},
|
||||
status: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
@@ -95,12 +91,12 @@ export const learningResourceRouter = router({
|
||||
// Determine highest cohort level
|
||||
let userCohortLevel: 'ALL' | 'SEMIFINALIST' | 'FINALIST' = 'ALL'
|
||||
for (const assignment of assignments) {
|
||||
const rpStatus = assignment.project.roundProjects[0]?.status
|
||||
if (rpStatus === 'FINALIST') {
|
||||
const projectStatus = assignment.project.status
|
||||
if (projectStatus === 'FINALIST') {
|
||||
userCohortLevel = 'FINALIST'
|
||||
break
|
||||
}
|
||||
if (rpStatus === 'SEMIFINALIST') {
|
||||
if (projectStatus === 'SEMIFINALIST') {
|
||||
userCohortLevel = 'SEMIFINALIST'
|
||||
}
|
||||
}
|
||||
@@ -166,11 +162,7 @@ export const learningResourceRouter = router({
|
||||
include: {
|
||||
project: {
|
||||
select: {
|
||||
roundProjects: {
|
||||
select: { status: true },
|
||||
orderBy: { addedAt: 'desc' as const },
|
||||
take: 1,
|
||||
},
|
||||
status: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
@@ -178,12 +170,12 @@ export const learningResourceRouter = router({
|
||||
|
||||
let userCohortLevel: 'ALL' | 'SEMIFINALIST' | 'FINALIST' = 'ALL'
|
||||
for (const assignment of assignments) {
|
||||
const rpStatus = assignment.project.roundProjects[0]?.status
|
||||
if (rpStatus === 'FINALIST') {
|
||||
const projectStatus = assignment.project.status
|
||||
if (projectStatus === 'FINALIST') {
|
||||
userCohortLevel = 'FINALIST'
|
||||
break
|
||||
}
|
||||
if (rpStatus === 'SEMIFINALIST') {
|
||||
if (projectStatus === 'SEMIFINALIST') {
|
||||
userCohortLevel = 'SEMIFINALIST'
|
||||
}
|
||||
}
|
||||
@@ -241,11 +233,7 @@ export const learningResourceRouter = router({
|
||||
include: {
|
||||
project: {
|
||||
select: {
|
||||
roundProjects: {
|
||||
select: { status: true },
|
||||
orderBy: { addedAt: 'desc' as const },
|
||||
take: 1,
|
||||
},
|
||||
status: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
@@ -253,12 +241,12 @@ export const learningResourceRouter = router({
|
||||
|
||||
let userCohortLevel: 'ALL' | 'SEMIFINALIST' | 'FINALIST' = 'ALL'
|
||||
for (const assignment of assignments) {
|
||||
const rpStatus = assignment.project.roundProjects[0]?.status
|
||||
if (rpStatus === 'FINALIST') {
|
||||
const projectStatus = assignment.project.status
|
||||
if (projectStatus === 'FINALIST') {
|
||||
userCohortLevel = 'FINALIST'
|
||||
break
|
||||
}
|
||||
if (rpStatus === 'SEMIFINALIST') {
|
||||
if (projectStatus === 'SEMIFINALIST') {
|
||||
userCohortLevel = 'SEMIFINALIST'
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user