feat: AI API Setting page with 4 provider sections and toggles

Add OpenAI, Claude AI, and DentalManagement AI sections to the AI API
Setting page, each with a masked API key input and an on/off toggle
(defaulting to off). Rename sidebar label from "Google AI Settings" to
"AI API Setting". Add provider-key and provider-enabled backend endpoints
and extend the AiSettings schema with 6 new fields.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
ff
2026-06-05 16:36:01 -04:00
parent 1bbca38344
commit 2457e12b5c
50 changed files with 930 additions and 102 deletions

View File

@@ -5,11 +5,37 @@ export const aiSettingsStorage = {
return db.aiSettings.findUnique({ where: { userId } });
},
async upsertAiSettings(userId: number, apiKey: string) {
async upsertAiSettings(userId: number, apiKey: string, aiEnabled?: boolean) {
return db.aiSettings.upsert({
where: { userId },
update: { apiKey },
create: { userId, apiKey },
update: { apiKey, ...(aiEnabled !== undefined && { aiEnabled }) },
create: { userId, apiKey, aiEnabled: aiEnabled ?? true },
});
},
async setAiEnabled(userId: number, enabled: boolean): Promise<void> {
await db.aiSettings.upsert({
where: { userId },
update: { aiEnabled: enabled },
create: { userId, apiKey: "", aiEnabled: enabled },
});
},
async upsertProviderKey(userId: number, provider: "openAi" | "claudeAi" | "dentalMgmt", key: string): Promise<void> {
const field = provider === "openAi" ? "openAiKey" : provider === "claudeAi" ? "claudeAiKey" : "dentalMgmtKey";
await db.aiSettings.upsert({
where: { userId },
update: { [field]: key },
create: { userId, apiKey: "", [field]: key },
});
},
async setProviderEnabled(userId: number, provider: "openAi" | "claudeAi" | "dentalMgmt", enabled: boolean): Promise<void> {
const field = provider === "openAi" ? "openAiEnabled" : provider === "claudeAi" ? "claudeAiEnabled" : "dentalMgmtEnabled";
await db.aiSettings.upsert({
where: { userId },
update: { [field]: enabled },
create: { userId, apiKey: "", [field]: enabled, openAiEnabled: false, claudeAiEnabled: false, dentalMgmtEnabled: false },
});
},