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

@@ -43,6 +43,7 @@ const decimal_js_1 = __importDefault(require("decimal.js"));
const PaymentStatus_schema_1 = require("../enums/PaymentStatus.schema");
const ServiceLineTransactionUncheckedCreateNestedManyWithoutPaymentInput_schema_1 = require("./ServiceLineTransactionUncheckedCreateNestedManyWithoutPaymentInput.schema");
const ServiceLineUncheckedCreateNestedManyWithoutPaymentInput_schema_1 = require("./ServiceLineUncheckedCreateNestedManyWithoutPaymentInput.schema");
const CommissionBatchItemUncheckedCreateNestedManyWithoutPaymentInput_schema_1 = require("./CommissionBatchItemUncheckedCreateNestedManyWithoutPaymentInput.schema");
const decimal_helpers_1 = require("../../helpers/decimal-helpers");
const makeSchema = () => z.object({
id: z.number().int().optional(),
@@ -50,6 +51,7 @@ const makeSchema = () => z.object({
patientId: z.number().int(),
userId: z.number().int(),
updatedById: z.number().int().optional().nullable(),
npiProviderId: z.number().int().optional().nullable(),
totalBilled: z.union([
z.number(),
z.string(),
@@ -86,12 +88,40 @@ const makeSchema = () => z.object({
]).refine((v) => (0, decimal_helpers_1.isValidDecimalInput)(v), {
message: "Field 'totalDue' must be a Decimal",
}),
mhPaidAmount: z.union([
z.number(),
z.string(),
z.instanceof(decimal_js_1.default),
z.instanceof(prisma_1.Prisma.Decimal),
decimal_helpers_1.DecimalJSLikeSchema,
]).refine((v) => (0, decimal_helpers_1.isValidDecimalInput)(v), {
message: "Field 'mhPaidAmount' must be a Decimal",
}).optional().nullable(),
copayment: z.union([
z.number(),
z.string(),
z.instanceof(decimal_js_1.default),
z.instanceof(prisma_1.Prisma.Decimal),
decimal_helpers_1.DecimalJSLikeSchema,
]).refine((v) => (0, decimal_helpers_1.isValidDecimalInput)(v), {
message: "Field 'copayment' must be a Decimal",
}).optional(),
adjustment: z.union([
z.number(),
z.string(),
z.instanceof(decimal_js_1.default),
z.instanceof(prisma_1.Prisma.Decimal),
decimal_helpers_1.DecimalJSLikeSchema,
]).refine((v) => (0, decimal_helpers_1.isValidDecimalInput)(v), {
message: "Field 'adjustment' must be a Decimal",
}).optional(),
status: PaymentStatus_schema_1.PaymentStatusSchema.optional(),
notes: z.string().optional().nullable(),
icn: z.string().optional().nullable(),
createdAt: z.coerce.date().optional(),
serviceLineTransactions: z.lazy(() => ServiceLineTransactionUncheckedCreateNestedManyWithoutPaymentInput_schema_1.ServiceLineTransactionUncheckedCreateNestedManyWithoutPaymentInputObjectSchema).optional(),
serviceLines: z.lazy(() => ServiceLineUncheckedCreateNestedManyWithoutPaymentInput_schema_1.ServiceLineUncheckedCreateNestedManyWithoutPaymentInputObjectSchema).optional()
serviceLines: z.lazy(() => ServiceLineUncheckedCreateNestedManyWithoutPaymentInput_schema_1.ServiceLineUncheckedCreateNestedManyWithoutPaymentInputObjectSchema).optional(),
commissionBatchItems: z.lazy(() => CommissionBatchItemUncheckedCreateNestedManyWithoutPaymentInput_schema_1.CommissionBatchItemUncheckedCreateNestedManyWithoutPaymentInputObjectSchema).optional()
}).strict();
exports.PaymentUncheckedCreateInputObjectSchema = makeSchema();
exports.PaymentUncheckedCreateInputObjectZodSchema = makeSchema();