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,8 @@ const CloudFolderNullableScalarRelationFilter_schema_1 = require("./CloudFolderN
const CloudFolderListRelationFilter_schema_1 = require("./CloudFolderListRelationFilter.schema");
const UserScalarRelationFilter_schema_1 = require("./UserScalarRelationFilter.schema");
const UserWhereInput_schema_1 = require("./UserWhereInput.schema");
const PatientNullableScalarRelationFilter_schema_1 = require("./PatientNullableScalarRelationFilter.schema");
const PatientWhereInput_schema_1 = require("./PatientWhereInput.schema");
const CloudFileListRelationFilter_schema_1 = require("./CloudFileListRelationFilter.schema");
const cloudfolderwhereinputSchema = z.object({
AND: z.union([z.lazy(() => exports.CloudFolderWhereInputObjectSchema), z.lazy(() => exports.CloudFolderWhereInputObjectSchema).array()]).optional(),
@@ -52,11 +54,13 @@ const cloudfolderwhereinputSchema = z.object({
userId: z.union([z.lazy(() => IntFilter_schema_1.IntFilterObjectSchema), z.number().int()]).optional(),
name: z.union([z.lazy(() => StringFilter_schema_1.StringFilterObjectSchema), z.string()]).optional(),
parentId: z.union([z.lazy(() => IntNullableFilter_schema_1.IntNullableFilterObjectSchema), z.number().int()]).optional().nullable(),
patientId: z.union([z.lazy(() => IntNullableFilter_schema_1.IntNullableFilterObjectSchema), z.number().int()]).optional().nullable(),
createdAt: z.union([z.lazy(() => DateTimeFilter_schema_1.DateTimeFilterObjectSchema), z.coerce.date()]).optional(),
updatedAt: z.union([z.lazy(() => DateTimeFilter_schema_1.DateTimeFilterObjectSchema), z.coerce.date()]).optional(),
parent: z.union([z.lazy(() => CloudFolderNullableScalarRelationFilter_schema_1.CloudFolderNullableScalarRelationFilterObjectSchema), z.lazy(() => exports.CloudFolderWhereInputObjectSchema)]).optional(),
children: z.lazy(() => CloudFolderListRelationFilter_schema_1.CloudFolderListRelationFilterObjectSchema).optional(),
user: z.union([z.lazy(() => UserScalarRelationFilter_schema_1.UserScalarRelationFilterObjectSchema), z.lazy(() => UserWhereInput_schema_1.UserWhereInputObjectSchema)]).optional(),
patient: z.union([z.lazy(() => PatientNullableScalarRelationFilter_schema_1.PatientNullableScalarRelationFilterObjectSchema), z.lazy(() => PatientWhereInput_schema_1.PatientWhereInputObjectSchema)]).optional(),
files: z.lazy(() => CloudFileListRelationFilter_schema_1.CloudFileListRelationFilterObjectSchema).optional()
}).strict();
exports.CloudFolderWhereInputObjectSchema = cloudfolderwhereinputSchema;