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:
2026-06-28 22:57:24 -04:00
parent c9d08028a9
commit e1fe4862d5
1613 changed files with 59200 additions and 422 deletions

View File

@@ -45,6 +45,8 @@ const PdfGroupOrderByRelationAggregateInput_schema_1 = require("./PdfGroupOrderB
const PaymentOrderByRelationAggregateInput_schema_1 = require("./PaymentOrderByRelationAggregateInput.schema");
const CommunicationOrderByRelationAggregateInput_schema_1 = require("./CommunicationOrderByRelationAggregateInput.schema");
const PatientDocumentOrderByRelationAggregateInput_schema_1 = require("./PatientDocumentOrderByRelationAggregateInput.schema");
const PatientConversationOrderByWithRelationInput_schema_1 = require("./PatientConversationOrderByWithRelationInput.schema");
const CloudFolderOrderByRelationAggregateInput_schema_1 = require("./CloudFolderOrderByRelationAggregateInput.schema");
const makeSchema = () => z.object({
id: SortOrder_schema_1.SortOrderSchema.optional(),
firstName: SortOrder_schema_1.SortOrderSchema.optional(),
@@ -62,9 +64,11 @@ const makeSchema = () => z.object({
policyHolder: z.union([SortOrder_schema_1.SortOrderSchema, z.lazy(() => SortOrderInput_schema_1.SortOrderInputObjectSchema)]).optional(),
allergies: z.union([SortOrder_schema_1.SortOrderSchema, z.lazy(() => SortOrderInput_schema_1.SortOrderInputObjectSchema)]).optional(),
medicalConditions: z.union([SortOrder_schema_1.SortOrderSchema, z.lazy(() => SortOrderInput_schema_1.SortOrderInputObjectSchema)]).optional(),
preferredLanguage: z.union([SortOrder_schema_1.SortOrderSchema, z.lazy(() => SortOrderInput_schema_1.SortOrderInputObjectSchema)]).optional(),
status: SortOrder_schema_1.SortOrderSchema.optional(),
userId: SortOrder_schema_1.SortOrderSchema.optional(),
createdAt: SortOrder_schema_1.SortOrderSchema.optional(),
updatedAt: SortOrder_schema_1.SortOrderSchema.optional(),
user: z.lazy(() => UserOrderByWithRelationInput_schema_1.UserOrderByWithRelationInputObjectSchema).optional(),
appointments: z.lazy(() => AppointmentOrderByRelationAggregateInput_schema_1.AppointmentOrderByRelationAggregateInputObjectSchema).optional(),
procedures: z.lazy(() => AppointmentProcedureOrderByRelationAggregateInput_schema_1.AppointmentProcedureOrderByRelationAggregateInputObjectSchema).optional(),
@@ -72,7 +76,9 @@ const makeSchema = () => z.object({
groups: z.lazy(() => PdfGroupOrderByRelationAggregateInput_schema_1.PdfGroupOrderByRelationAggregateInputObjectSchema).optional(),
payment: z.lazy(() => PaymentOrderByRelationAggregateInput_schema_1.PaymentOrderByRelationAggregateInputObjectSchema).optional(),
communications: z.lazy(() => CommunicationOrderByRelationAggregateInput_schema_1.CommunicationOrderByRelationAggregateInputObjectSchema).optional(),
documents: z.lazy(() => PatientDocumentOrderByRelationAggregateInput_schema_1.PatientDocumentOrderByRelationAggregateInputObjectSchema).optional()
documents: z.lazy(() => PatientDocumentOrderByRelationAggregateInput_schema_1.PatientDocumentOrderByRelationAggregateInputObjectSchema).optional(),
conversation: z.lazy(() => PatientConversationOrderByWithRelationInput_schema_1.PatientConversationOrderByWithRelationInputObjectSchema).optional(),
cloudFolders: z.lazy(() => CloudFolderOrderByRelationAggregateInput_schema_1.CloudFolderOrderByRelationAggregateInputObjectSchema).optional()
}).strict();
exports.PatientOrderByWithRelationInputObjectSchema = makeSchema();
exports.PatientOrderByWithRelationInputObjectZodSchema = makeSchema();