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:
@@ -43,8 +43,10 @@ const decimal_js_1 = __importDefault(require("decimal.js"));
|
||||
const PaymentStatus_schema_1 = require("../enums/PaymentStatus.schema");
|
||||
const ClaimCreateNestedOneWithoutPaymentInput_schema_1 = require("./ClaimCreateNestedOneWithoutPaymentInput.schema");
|
||||
const UserCreateNestedOneWithoutUpdatedPaymentsInput_schema_1 = require("./UserCreateNestedOneWithoutUpdatedPaymentsInput.schema");
|
||||
const NpiProviderCreateNestedOneWithoutPaymentsInput_schema_1 = require("./NpiProviderCreateNestedOneWithoutPaymentsInput.schema");
|
||||
const ServiceLineTransactionCreateNestedManyWithoutPaymentInput_schema_1 = require("./ServiceLineTransactionCreateNestedManyWithoutPaymentInput.schema");
|
||||
const ServiceLineCreateNestedManyWithoutPaymentInput_schema_1 = require("./ServiceLineCreateNestedManyWithoutPaymentInput.schema");
|
||||
const CommissionBatchItemCreateNestedManyWithoutPaymentInput_schema_1 = require("./CommissionBatchItemCreateNestedManyWithoutPaymentInput.schema");
|
||||
const decimal_helpers_1 = require("../../helpers/decimal-helpers");
|
||||
const makeSchema = () => z.object({
|
||||
userId: z.number().int(),
|
||||
@@ -84,6 +86,33 @@ 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(),
|
||||
@@ -91,8 +120,10 @@ const makeSchema = () => z.object({
|
||||
updatedAt: z.coerce.date().optional(),
|
||||
claim: z.lazy(() => ClaimCreateNestedOneWithoutPaymentInput_schema_1.ClaimCreateNestedOneWithoutPaymentInputObjectSchema).optional(),
|
||||
updatedBy: z.lazy(() => UserCreateNestedOneWithoutUpdatedPaymentsInput_schema_1.UserCreateNestedOneWithoutUpdatedPaymentsInputObjectSchema).optional(),
|
||||
npiProvider: z.lazy(() => NpiProviderCreateNestedOneWithoutPaymentsInput_schema_1.NpiProviderCreateNestedOneWithoutPaymentsInputObjectSchema).optional(),
|
||||
serviceLineTransactions: z.lazy(() => ServiceLineTransactionCreateNestedManyWithoutPaymentInput_schema_1.ServiceLineTransactionCreateNestedManyWithoutPaymentInputObjectSchema).optional(),
|
||||
serviceLines: z.lazy(() => ServiceLineCreateNestedManyWithoutPaymentInput_schema_1.ServiceLineCreateNestedManyWithoutPaymentInputObjectSchema).optional()
|
||||
serviceLines: z.lazy(() => ServiceLineCreateNestedManyWithoutPaymentInput_schema_1.ServiceLineCreateNestedManyWithoutPaymentInputObjectSchema).optional(),
|
||||
commissionBatchItems: z.lazy(() => CommissionBatchItemCreateNestedManyWithoutPaymentInput_schema_1.CommissionBatchItemCreateNestedManyWithoutPaymentInputObjectSchema).optional()
|
||||
}).strict();
|
||||
exports.PaymentCreateWithoutPatientInputObjectSchema = makeSchema();
|
||||
exports.PaymentCreateWithoutPatientInputObjectZodSchema = makeSchema();
|
||||
|
||||
Reference in New Issue
Block a user