- Filter patient list by userId so each user sees only their own patients - Sort patients by updatedAt DESC so recently checked patients appear first - Add updatedAt field to Patient model (DB migration via raw SQL + db:generate) - Fix DDMA name extraction: read from detail page "Name:" label, not search results row text which included appended dates - Fix PDF capture: use driver.get() instead of click() to avoid race condition that was saving the search results page instead of the patient detail page - Strip trailing bare dates from extracted names (e.g. "Rodriguez 04/27/2026") - Handle "Last, First" comma format and single-word last names in splitName - Normalize insuranceId consistently in createOrUpdatePatientByInsuranceId - Fix OTP persistent session: stop clearing LocalStorage/IndexedDB on startup (these hold the DDMA device trust token that skips OTP on subsequent logins) - Increase post-navigation wait time for full page render before PDF generation Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
46 lines
2.8 KiB
TypeScript
46 lines
2.8 KiB
TypeScript
import * as z from 'zod';
|
|
import type { Prisma } from '../../../generated/prisma';
|
|
import { UserArgsObjectSchema as UserArgsObjectSchema } from './UserArgs.schema';
|
|
import { AppointmentFindManySchema as AppointmentFindManySchema } from '../findManyAppointment.schema';
|
|
import { AppointmentProcedureFindManySchema as AppointmentProcedureFindManySchema } from '../findManyAppointmentProcedure.schema';
|
|
import { ClaimFindManySchema as ClaimFindManySchema } from '../findManyClaim.schema';
|
|
import { PdfGroupFindManySchema as PdfGroupFindManySchema } from '../findManyPdfGroup.schema';
|
|
import { PaymentFindManySchema as PaymentFindManySchema } from '../findManyPayment.schema';
|
|
import { CommunicationFindManySchema as CommunicationFindManySchema } from '../findManyCommunication.schema';
|
|
import { PatientDocumentFindManySchema as PatientDocumentFindManySchema } from '../findManyPatientDocument.schema';
|
|
import { PatientCountOutputTypeArgsObjectSchema as PatientCountOutputTypeArgsObjectSchema } from './PatientCountOutputTypeArgs.schema'
|
|
|
|
const makeSchema = () => z.object({
|
|
id: z.boolean().optional(),
|
|
firstName: z.boolean().optional(),
|
|
lastName: z.boolean().optional(),
|
|
dateOfBirth: z.boolean().optional(),
|
|
gender: z.boolean().optional(),
|
|
phone: z.boolean().optional(),
|
|
email: z.boolean().optional(),
|
|
address: z.boolean().optional(),
|
|
city: z.boolean().optional(),
|
|
zipCode: z.boolean().optional(),
|
|
insuranceProvider: z.boolean().optional(),
|
|
insuranceId: z.boolean().optional(),
|
|
groupNumber: z.boolean().optional(),
|
|
policyHolder: z.boolean().optional(),
|
|
allergies: z.boolean().optional(),
|
|
medicalConditions: z.boolean().optional(),
|
|
status: z.boolean().optional(),
|
|
userId: z.boolean().optional(),
|
|
createdAt: z.boolean().optional(),
|
|
updatedAt: z.boolean().optional(),
|
|
user: z.union([z.boolean(), z.lazy(() => UserArgsObjectSchema)]).optional(),
|
|
appointments: z.union([z.boolean(), z.lazy(() => AppointmentFindManySchema)]).optional(),
|
|
procedures: z.union([z.boolean(), z.lazy(() => AppointmentProcedureFindManySchema)]).optional(),
|
|
claims: z.union([z.boolean(), z.lazy(() => ClaimFindManySchema)]).optional(),
|
|
groups: z.union([z.boolean(), z.lazy(() => PdfGroupFindManySchema)]).optional(),
|
|
payment: z.union([z.boolean(), z.lazy(() => PaymentFindManySchema)]).optional(),
|
|
communications: z.union([z.boolean(), z.lazy(() => CommunicationFindManySchema)]).optional(),
|
|
documents: z.union([z.boolean(), z.lazy(() => PatientDocumentFindManySchema)]).optional(),
|
|
_count: z.union([z.boolean(), z.lazy(() => PatientCountOutputTypeArgsObjectSchema)]).optional()
|
|
}).strict();
|
|
export const PatientSelectObjectSchema: z.ZodType<Prisma.PatientSelect> = makeSchema() as unknown as z.ZodType<Prisma.PatientSelect>;
|
|
export const PatientSelectObjectZodSchema = makeSchema();
|