feat: add schedule column labels, office hours enforcement, and appointment move fix

- Schedule columns default to labels A–F (localStorage, per-browser, click to rename)
- Settings → Advanced → Office Hours: configure Doctors (A-C) and Hygienists (D-F) AM/PM hours per weekday
- Gray out schedule slots outside office hours; override dialog for manual exceptions
- Override Office Hours toggle: select specific dates where all slots are open
- Fix appointment move: send only real DB fields to avoid Zod strict-mode rejection of computed fields (hasProcedures, hasClaimWithNumber)
- Fix backend PUT /appointments: safe error logging to prevent Prisma error crashing Node inspect
- Add OfficeHours Prisma model and GET/PUT /api/office-hours route

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Gitead
2026-05-05 09:15:18 -04:00
parent 70ffd8398b
commit 2312ad66ca
465 changed files with 11834 additions and 1461 deletions

View File

@@ -114,14 +114,10 @@ export const appointmentsStorage: IStorage = {
id: number,
updateData: UpdateAppointment
): Promise<Appointment> {
try {
return await db.appointment.update({
where: { id },
data: updateData,
});
} catch (err) {
throw new Error(`Appointment with ID ${id} not found`);
}
return db.appointment.update({
where: { id },
data: updateData,
});
},
async deleteAppointment(id: number): Promise<void> {

View File

@@ -19,6 +19,7 @@ import * as exportPaymentsReportsStorage from "./export-payments-reports-storage
import { cronJobLogStorage } from "./cron-job-log-storage";
import { twilioStorage } from "./twilio-storage";
import { aiSettingsStorage } from "./ai-settings-storage";
import { officeHoursStorage } from "./office-hours-storage";
export const storage = {
@@ -41,6 +42,7 @@ export const storage = {
...cronJobLogStorage,
...twilioStorage,
...aiSettingsStorage,
...officeHoursStorage,
};

View File

@@ -0,0 +1,15 @@
import { prisma as db } from "@repo/db/client";
export const officeHoursStorage = {
async getOfficeHours(userId: number) {
return db.officeHours.findUnique({ where: { userId } });
},
async upsertOfficeHours(userId: number, data: object) {
return db.officeHours.upsert({
where: { userId },
update: { data },
create: { userId, data },
});
},
};