- 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>
53 lines
4.4 KiB
TypeScript
53 lines
4.4 KiB
TypeScript
import * as z from 'zod';
|
|
import type { Prisma } from '../../../generated/prisma';
|
|
import { PatientFindManySchema as PatientFindManySchema } from '../findManyPatient.schema';
|
|
import { AppointmentFindManySchema as AppointmentFindManySchema } from '../findManyAppointment.schema';
|
|
import { StaffFindManySchema as StaffFindManySchema } from '../findManyStaff.schema';
|
|
import { NpiProviderFindManySchema as NpiProviderFindManySchema } from '../findManyNpiProvider.schema';
|
|
import { ClaimFindManySchema as ClaimFindManySchema } from '../findManyClaim.schema';
|
|
import { InsuranceCredentialFindManySchema as InsuranceCredentialFindManySchema } from '../findManyInsuranceCredential.schema';
|
|
import { PaymentFindManySchema as PaymentFindManySchema } from '../findManyPayment.schema';
|
|
import { DatabaseBackupFindManySchema as DatabaseBackupFindManySchema } from '../findManyDatabaseBackup.schema';
|
|
import { BackupDestinationFindManySchema as BackupDestinationFindManySchema } from '../findManyBackupDestination.schema';
|
|
import { NotificationFindManySchema as NotificationFindManySchema } from '../findManyNotification.schema';
|
|
import { CloudFolderFindManySchema as CloudFolderFindManySchema } from '../findManyCloudFolder.schema';
|
|
import { CloudFileFindManySchema as CloudFileFindManySchema } from '../findManyCloudFile.schema';
|
|
import { CommunicationFindManySchema as CommunicationFindManySchema } from '../findManyCommunication.schema';
|
|
import { TwilioSettingsArgsObjectSchema as TwilioSettingsArgsObjectSchema } from './TwilioSettingsArgs.schema';
|
|
import { AiSettingsArgsObjectSchema as AiSettingsArgsObjectSchema } from './AiSettingsArgs.schema';
|
|
import { OfficeHoursArgsObjectSchema as OfficeHoursArgsObjectSchema } from './OfficeHoursArgs.schema';
|
|
import { OfficeContactArgsObjectSchema as OfficeContactArgsObjectSchema } from './OfficeContactArgs.schema';
|
|
import { ProcedureTimeslotArgsObjectSchema as ProcedureTimeslotArgsObjectSchema } from './ProcedureTimeslotArgs.schema';
|
|
import { InsuranceContactFindManySchema as InsuranceContactFindManySchema } from '../findManyInsuranceContact.schema';
|
|
import { UserCountOutputTypeArgsObjectSchema as UserCountOutputTypeArgsObjectSchema } from './UserCountOutputTypeArgs.schema'
|
|
|
|
const makeSchema = () => z.object({
|
|
id: z.boolean().optional(),
|
|
username: z.boolean().optional(),
|
|
password: z.boolean().optional(),
|
|
autoBackupEnabled: z.boolean().optional(),
|
|
usbBackupEnabled: z.boolean().optional(),
|
|
patients: z.union([z.boolean(), z.lazy(() => PatientFindManySchema)]).optional(),
|
|
appointments: z.union([z.boolean(), z.lazy(() => AppointmentFindManySchema)]).optional(),
|
|
staff: z.union([z.boolean(), z.lazy(() => StaffFindManySchema)]).optional(),
|
|
npiProviders: z.union([z.boolean(), z.lazy(() => NpiProviderFindManySchema)]).optional(),
|
|
claims: z.union([z.boolean(), z.lazy(() => ClaimFindManySchema)]).optional(),
|
|
insuranceCredentials: z.union([z.boolean(), z.lazy(() => InsuranceCredentialFindManySchema)]).optional(),
|
|
updatedPayments: z.union([z.boolean(), z.lazy(() => PaymentFindManySchema)]).optional(),
|
|
backups: z.union([z.boolean(), z.lazy(() => DatabaseBackupFindManySchema)]).optional(),
|
|
backupDestinations: z.union([z.boolean(), z.lazy(() => BackupDestinationFindManySchema)]).optional(),
|
|
notifications: z.union([z.boolean(), z.lazy(() => NotificationFindManySchema)]).optional(),
|
|
cloudFolders: z.union([z.boolean(), z.lazy(() => CloudFolderFindManySchema)]).optional(),
|
|
cloudFiles: z.union([z.boolean(), z.lazy(() => CloudFileFindManySchema)]).optional(),
|
|
communications: z.union([z.boolean(), z.lazy(() => CommunicationFindManySchema)]).optional(),
|
|
twilioSettings: z.union([z.boolean(), z.lazy(() => TwilioSettingsArgsObjectSchema)]).optional(),
|
|
aiSettings: z.union([z.boolean(), z.lazy(() => AiSettingsArgsObjectSchema)]).optional(),
|
|
officeHours: z.union([z.boolean(), z.lazy(() => OfficeHoursArgsObjectSchema)]).optional(),
|
|
officeContact: z.union([z.boolean(), z.lazy(() => OfficeContactArgsObjectSchema)]).optional(),
|
|
procedureTimeslot: z.union([z.boolean(), z.lazy(() => ProcedureTimeslotArgsObjectSchema)]).optional(),
|
|
insuranceContacts: z.union([z.boolean(), z.lazy(() => InsuranceContactFindManySchema)]).optional(),
|
|
_count: z.union([z.boolean(), z.lazy(() => UserCountOutputTypeArgsObjectSchema)]).optional()
|
|
}).strict();
|
|
export const UserSelectObjectSchema: z.ZodType<Prisma.UserSelect> = makeSchema() as unknown as z.ZodType<Prisma.UserSelect>;
|
|
export const UserSelectObjectZodSchema = makeSchema();
|