fix: allow claims without appointment + support post/core multi-tooth input
- Make appointmentId nullable/optional in Prisma Zod schema via @zod rich comment so claims can be submitted without an existing appointment - Convert undefined appointmentId to null in all claim form handlers and the backend claim creation endpoint - Add AI classifier rule for expanding one procedure across multiple comma-separated tooth numbers (e.g. "post/core on #23, 24, 25, 26") - Add "post/core" (slash) alias to CDT lookup maps Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -52,9 +52,11 @@ exports.AppointmentFindFirstOrThrowSelectSchema = z.object({
|
||||
startTime: z.boolean().optional(),
|
||||
endTime: z.boolean().optional(),
|
||||
type: z.boolean().optional(),
|
||||
typeLocked: z.boolean().optional(),
|
||||
notes: z.boolean().optional(),
|
||||
procedureCodeNotes: z.boolean().optional(),
|
||||
status: z.boolean().optional(),
|
||||
movedByAi: z.boolean().optional(),
|
||||
createdAt: z.boolean().optional(),
|
||||
eligibilityStatus: z.boolean().optional(),
|
||||
patient: z.boolean().optional(),
|
||||
@@ -62,6 +64,7 @@ exports.AppointmentFindFirstOrThrowSelectSchema = z.object({
|
||||
staff: z.boolean().optional(),
|
||||
procedures: z.boolean().optional(),
|
||||
claims: z.boolean().optional(),
|
||||
files: z.boolean().optional(),
|
||||
_count: z.boolean().optional()
|
||||
}).strict();
|
||||
exports.AppointmentFindFirstOrThrowSelectZodSchema = z.object({
|
||||
@@ -74,9 +77,11 @@ exports.AppointmentFindFirstOrThrowSelectZodSchema = z.object({
|
||||
startTime: z.boolean().optional(),
|
||||
endTime: z.boolean().optional(),
|
||||
type: z.boolean().optional(),
|
||||
typeLocked: z.boolean().optional(),
|
||||
notes: z.boolean().optional(),
|
||||
procedureCodeNotes: z.boolean().optional(),
|
||||
status: z.boolean().optional(),
|
||||
movedByAi: z.boolean().optional(),
|
||||
createdAt: z.boolean().optional(),
|
||||
eligibilityStatus: z.boolean().optional(),
|
||||
patient: z.boolean().optional(),
|
||||
@@ -84,6 +89,7 @@ exports.AppointmentFindFirstOrThrowSelectZodSchema = z.object({
|
||||
staff: z.boolean().optional(),
|
||||
procedures: z.boolean().optional(),
|
||||
claims: z.boolean().optional(),
|
||||
files: z.boolean().optional(),
|
||||
_count: z.boolean().optional()
|
||||
}).strict();
|
||||
exports.AppointmentFindFirstOrThrowSchema = z.object({ select: exports.AppointmentFindFirstOrThrowSelectSchema.optional(), include: z.lazy(() => AppointmentInclude_schema_1.AppointmentIncludeObjectSchema.optional()), orderBy: z.union([AppointmentOrderByWithRelationInput_schema_1.AppointmentOrderByWithRelationInputObjectSchema, AppointmentOrderByWithRelationInput_schema_1.AppointmentOrderByWithRelationInputObjectSchema.array()]).optional(), where: AppointmentWhereInput_schema_1.AppointmentWhereInputObjectSchema.optional(), cursor: AppointmentWhereUniqueInput_schema_1.AppointmentWhereUniqueInputObjectSchema.optional(), take: z.number().optional(), skip: z.number().optional(), distinct: z.union([AppointmentScalarFieldEnum_schema_1.AppointmentScalarFieldEnumSchema, AppointmentScalarFieldEnum_schema_1.AppointmentScalarFieldEnumSchema.array()]).optional() }).strict();
|
||||
|
||||
Reference in New Issue
Block a user