- Add floating chat window Hand-off to AI toggle (per-patient) and after-hours AI toggle (global) - Add LangGraph-powered appointment reminder flow: AI introduces itself, classifies YES/NO, handles confirmation with appointment date/time - Add multi-step rescheduling flow: ASAP vs next week, tomorrow offer, Mon/Tue/Wed picker, morning/afternoon time slot — automatically updates appointment in DB - Add new patient / after-hours flow: new vs existing patient, dental insurance check, MassHealth Selenium eligibility check (auto-uses saved member ID + DOB for existing patients), self-pay fallback - Add AI Chat Settings page (Settings → Advanced) with editable greeting templates and LangGraph flow diagrams for both reminder and new-patient flows - Add Schedule a New Patient template option in chat window, starts new-patient conversation flow - Add GET/PUT endpoints for AI handoff, after-hours handoff, and AI chat templates - Add multilingual support (7 languages) across all AI reply nodes with LLM generation and hardcoded fallbacks - Add pending reschedule in-memory store and conversation stage tracking across all flows Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
80 lines
4.5 KiB
TypeScript
80 lines
4.5 KiB
TypeScript
import type { Prisma } from '../../generated/prisma';
|
|
import * as z from 'zod';
|
|
import { PatientIncludeObjectSchema as PatientIncludeObjectSchema } from './objects/PatientInclude.schema';
|
|
import { PatientOrderByWithRelationInputObjectSchema as PatientOrderByWithRelationInputObjectSchema } from './objects/PatientOrderByWithRelationInput.schema';
|
|
import { PatientWhereInputObjectSchema as PatientWhereInputObjectSchema } from './objects/PatientWhereInput.schema';
|
|
import { PatientWhereUniqueInputObjectSchema as PatientWhereUniqueInputObjectSchema } from './objects/PatientWhereUniqueInput.schema';
|
|
import { PatientScalarFieldEnumSchema } from './enums/PatientScalarFieldEnum.schema';
|
|
|
|
// Select schema needs to be in file to prevent circular imports
|
|
//------------------------------------------------------
|
|
|
|
export const PatientFindFirstOrThrowSelectSchema: z.ZodType<Prisma.PatientSelect> = 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(),
|
|
preferredLanguage: z.boolean().optional(),
|
|
status: z.boolean().optional(),
|
|
userId: z.boolean().optional(),
|
|
createdAt: z.boolean().optional(),
|
|
updatedAt: z.boolean().optional(),
|
|
user: z.boolean().optional(),
|
|
appointments: z.boolean().optional(),
|
|
procedures: z.boolean().optional(),
|
|
claims: z.boolean().optional(),
|
|
groups: z.boolean().optional(),
|
|
payment: z.boolean().optional(),
|
|
communications: z.boolean().optional(),
|
|
documents: z.boolean().optional(),
|
|
_count: z.boolean().optional()
|
|
}).strict() as unknown as z.ZodType<Prisma.PatientSelect>;
|
|
|
|
export const PatientFindFirstOrThrowSelectZodSchema = 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(),
|
|
preferredLanguage: z.boolean().optional(),
|
|
status: z.boolean().optional(),
|
|
userId: z.boolean().optional(),
|
|
createdAt: z.boolean().optional(),
|
|
updatedAt: z.boolean().optional(),
|
|
user: z.boolean().optional(),
|
|
appointments: z.boolean().optional(),
|
|
procedures: z.boolean().optional(),
|
|
claims: z.boolean().optional(),
|
|
groups: z.boolean().optional(),
|
|
payment: z.boolean().optional(),
|
|
communications: z.boolean().optional(),
|
|
documents: z.boolean().optional(),
|
|
_count: z.boolean().optional()
|
|
}).strict();
|
|
|
|
export const PatientFindFirstOrThrowSchema: z.ZodType<Prisma.PatientFindFirstOrThrowArgs> = z.object({ select: PatientFindFirstOrThrowSelectSchema.optional(), include: z.lazy(() => PatientIncludeObjectSchema.optional()), orderBy: z.union([PatientOrderByWithRelationInputObjectSchema, PatientOrderByWithRelationInputObjectSchema.array()]).optional(), where: PatientWhereInputObjectSchema.optional(), cursor: PatientWhereUniqueInputObjectSchema.optional(), take: z.number().optional(), skip: z.number().optional(), distinct: z.union([PatientScalarFieldEnumSchema, PatientScalarFieldEnumSchema.array()]).optional() }).strict() as unknown as z.ZodType<Prisma.PatientFindFirstOrThrowArgs>;
|
|
|
|
export const PatientFindFirstOrThrowZodSchema = z.object({ select: PatientFindFirstOrThrowSelectSchema.optional(), include: z.lazy(() => PatientIncludeObjectSchema.optional()), orderBy: z.union([PatientOrderByWithRelationInputObjectSchema, PatientOrderByWithRelationInputObjectSchema.array()]).optional(), where: PatientWhereInputObjectSchema.optional(), cursor: PatientWhereUniqueInputObjectSchema.optional(), take: z.number().optional(), skip: z.number().optional(), distinct: z.union([PatientScalarFieldEnumSchema, PatientScalarFieldEnumSchema.array()]).optional() }).strict(); |