feat: fix DDMA eligibility — patient list, name extraction, PDF page, OTP session

- 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>
This commit is contained in:
Gitead
2026-05-01 21:40:04 -04:00
parent 24bbaed6ab
commit e26ebf7fd5
213 changed files with 1698 additions and 1425 deletions

View File

@@ -11,7 +11,7 @@ export interface IStorage {
getPatient(id: number): Promise<Patient | undefined>;
getPatientByInsuranceId(insuranceId: string): Promise<Patient | null>;
getPatientsByUserId(userId: number): Promise<Patient[]>;
getRecentPatients(limit: number, offset: number): Promise<Patient[]>;
getRecentPatients(limit: number, offset: number, userId: number): Promise<Patient[]>;
getPatientsByIds(ids: number[]): Promise<Patient[]>;
createPatient(patient: InsertPatient): Promise<Patient>;
updatePatient(id: number, patient: UpdatePatient): Promise<Patient>;
@@ -33,7 +33,7 @@ export interface IStorage {
status: string;
}[]
>;
getTotalPatientCount(): Promise<number>;
getTotalPatientCount(userId: number): Promise<number>;
countPatients(filters: any): Promise<number>; // optional but useful
getPatientFinancialRows(
patientId: number,
@@ -59,11 +59,12 @@ export const patientsStorage: IStorage = {
});
},
async getRecentPatients(limit: number, offset: number): Promise<Patient[]> {
async getRecentPatients(limit: number, offset: number, userId: number): Promise<Patient[]> {
return db.patient.findMany({
where: { userId },
skip: offset,
take: limit,
orderBy: { createdAt: "desc" },
orderBy: { updatedAt: "desc" },
});
},
@@ -85,6 +86,7 @@ export const patientsStorage: IStorage = {
status: true,
userId: true,
createdAt: true,
updatedAt: true,
},
});
},
@@ -124,7 +126,7 @@ export const patientsStorage: IStorage = {
}) {
return db.patient.findMany({
where: filters,
orderBy: { createdAt: "desc" },
orderBy: { updatedAt: "desc" },
take: limit,
skip: offset,
select: {
@@ -141,8 +143,8 @@ export const patientsStorage: IStorage = {
});
},
async getTotalPatientCount(): Promise<number> {
return db.patient.count();
async getTotalPatientCount(userId: number): Promise<number> {
return db.patient.count({ where: { userId } });
},
async countPatients(filters: any) {