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:
@@ -39,13 +39,18 @@ const IntFieldUpdateOperationsInput_schema_1 = require("./IntFieldUpdateOperatio
|
||||
const StringFieldUpdateOperationsInput_schema_1 = require("./StringFieldUpdateOperationsInput.schema");
|
||||
const DateTimeFieldUpdateOperationsInput_schema_1 = require("./DateTimeFieldUpdateOperationsInput.schema");
|
||||
const ClaimUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1 = require("./ClaimUncheckedUpdateManyWithoutNpiProviderNestedInput.schema");
|
||||
const PaymentUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1 = require("./PaymentUncheckedUpdateManyWithoutNpiProviderNestedInput.schema");
|
||||
const CommissionBatchUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1 = require("./CommissionBatchUncheckedUpdateManyWithoutNpiProviderNestedInput.schema");
|
||||
const AppointmentProcedureUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1 = require("./AppointmentProcedureUncheckedUpdateManyWithoutNpiProviderNestedInput.schema");
|
||||
const makeSchema = () => z.object({
|
||||
id: z.union([z.number().int(), z.lazy(() => IntFieldUpdateOperationsInput_schema_1.IntFieldUpdateOperationsInputObjectSchema)]).optional(),
|
||||
npiNumber: z.union([z.string(), z.lazy(() => StringFieldUpdateOperationsInput_schema_1.StringFieldUpdateOperationsInputObjectSchema)]).optional(),
|
||||
providerName: z.union([z.string(), z.lazy(() => StringFieldUpdateOperationsInput_schema_1.StringFieldUpdateOperationsInputObjectSchema)]).optional(),
|
||||
sortOrder: z.union([z.number().int(), z.lazy(() => IntFieldUpdateOperationsInput_schema_1.IntFieldUpdateOperationsInputObjectSchema)]).optional(),
|
||||
createdAt: z.union([z.coerce.date(), z.lazy(() => DateTimeFieldUpdateOperationsInput_schema_1.DateTimeFieldUpdateOperationsInputObjectSchema)]).optional(),
|
||||
claims: z.lazy(() => ClaimUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1.ClaimUncheckedUpdateManyWithoutNpiProviderNestedInputObjectSchema).optional(),
|
||||
payments: z.lazy(() => PaymentUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1.PaymentUncheckedUpdateManyWithoutNpiProviderNestedInputObjectSchema).optional(),
|
||||
commissionBatches: z.lazy(() => CommissionBatchUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1.CommissionBatchUncheckedUpdateManyWithoutNpiProviderNestedInputObjectSchema).optional(),
|
||||
appointmentProcedures: z.lazy(() => AppointmentProcedureUncheckedUpdateManyWithoutNpiProviderNestedInput_schema_1.AppointmentProcedureUncheckedUpdateManyWithoutNpiProviderNestedInputObjectSchema).optional()
|
||||
}).strict();
|
||||
exports.NpiProviderUncheckedUpdateWithoutUserInputObjectSchema = makeSchema();
|
||||
|
||||
Reference in New Issue
Block a user