add real data to ai

This commit is contained in:
Danel Kungla
2025-09-23 14:27:41 +03:00
parent 258e18e6a6
commit 4962ba8ec2
10 changed files with 152 additions and 87 deletions

View File

@@ -1,29 +1,26 @@
import { cache } from 'react';
import { AccountWithParams } from '@/packages/features/accounts/src/types/accounts';
import { createUserAnalysesApi } from '@/packages/features/user-analyses/src/server/api';
import { getSupabaseServerClient } from '@/packages/supabase/src/clients/server-client';
import { createServerClient } from '@supabase/ssr';
import { Database } from '@/packages/supabase/src/database.types';
import OpenAI from 'openai';
import PersonalCode from '~/lib/utils';
import { AnalysisTestResponse } from '../../(dashboard)/analysis-results/test/test-responses';
import { OrderAnalysisCard } from '../../_components/order-analyses-cards';
export const loadRecommendations = cache(recommendationsLoader);
type FormattedAnalysisResponse = {
value: string;
name: string;
responseTime: string;
};
type AnalysisResponses =
Database['medreport']['Functions']['get_latest_analysis_response_elements_for_current_user']['Returns'];
const getLatestResponseTime = (items: FormattedAnalysisResponse[]) => {
const getLatestResponseTime = (items: AnalysisResponses) => {
if (!items?.length) return null;
let latest = null;
for (const it of items) {
const d = new Date(it.responseTime);
const d = new Date(it.response_time);
const t = d.getTime();
if (!Number.isNaN(t) && (latest === null || t > latest.getTime())) {
latest = d;
@@ -32,45 +29,10 @@ const getLatestResponseTime = (items: FormattedAnalysisResponse[]) => {
return latest;
};
const getLatestUniqueAnalysResponses = (
analysisResponses: AnalysisTestResponse[],
): { name: string; value: string; responseTime: string }[] => {
const analysisElements = analysisResponses
.map(({ orderedAnalysisElements }) => orderedAnalysisElements)
.flat();
console.log('analysisElements', analysisElements.length);
const byName = analysisElements.reduce<
Record<string, { name: string; value: string; responseTime: string }>
>((acc, it) => {
const responseTime = it?.results?.responseTime;
const responseValue = it?.results?.responseValue;
if (!responseTime || !responseValue) return acc;
const key = it.analysisName;
const cur = acc[key];
const t = Date.parse(responseTime);
const prevT = cur ? Date.parse(cur.responseTime) : -Infinity;
if (!cur || t > prevT) {
acc[key] = {
name: key,
value: responseValue.toString(),
responseTime,
};
}
return acc;
}, {});
return Object.values(byName);
};
async function recommendationsLoader(
analysisResponses: AnalysisTestResponse[],
analyses: OrderAnalysisCard[],
account: AccountWithParams | null,
): Promise<any> {
): Promise<string[]> {
if (!process.env.OPENAI_API_KEY) {
return [];
}
@@ -78,15 +40,14 @@ async function recommendationsLoader(
return [];
}
const supabaseClient = getSupabaseServerClient();
const userAnalysesApi = createUserAnalysesApi(supabaseClient);
const analysisResponses = await userAnalysesApi.getAllUserAnalysisResponses();
const analysesRecommendationsPromptId =
'pmpt_68ca9c8bfa8c8193b27eadc6496c36440df449ece4f5a8dd';
const latestUniqueAnalysResponses =
getLatestUniqueAnalysResponses(analysisResponses);
const latestResponseTime = getLatestResponseTime(latestUniqueAnalysResponses);
const latestResponseTime = getLatestResponseTime(analysisResponses);
const latestISO = latestResponseTime
? new Date(latestResponseTime).toISOString()
: 'none';
: new Date('2025').toISOString();
const previouslyRecommended = await supabaseClient
.schema('medreport')
@@ -97,16 +58,28 @@ async function recommendationsLoader(
.eq('latest_data_change', latestISO);
if (previouslyRecommended.data?.[0]?.response) {
return previouslyRecommended.data[0].response;
return JSON.parse(previouslyRecommended.data[0].response as string)
.recommended;
}
const openAIClient = new OpenAI();
const { gender, age } = PersonalCode.parsePersonalCode(account.personal_code);
const weight = account.accountParams?.weight || 'unknown';
console.log('analysisResponses', analysisResponses);
console.log('analyises', analyses);
const formattedAnalysisResponses = latestUniqueAnalysResponses.map(
({ name, value }) => ({ name, value }),
const formattedAnalysisResponses = analysisResponses.map(
({
analysis_name_lab,
response_value,
norm_upper,
norm_lower,
norm_status,
}) => ({
name: analysis_name_lab,
value: response_value,
normUpper: norm_upper,
normLower: norm_lower,
normStatus: norm_status,
}),
);
const formattedAnalyses = analyses.map(({ description, title }) => ({
description,
@@ -128,23 +101,28 @@ async function recommendationsLoader(
});
const json = JSON.parse(response.output_text);
const updateAiResponse = await supabaseClient
.schema('medreport')
.from('ai_responses')
.insert({
account_id: account.id,
prompt_name: 'Analysis Recommendations',
prompt_id: analysesRecommendationsPromptId,
input: JSON.stringify({
analyses: formattedAnalyses,
results: formattedAnalysisResponses,
gender,
age,
weight,
}),
latest_data_change: latestISO,
response: response.output_text,
});
try {
await supabaseClient
.schema('medreport')
.from('ai_responses')
.insert({
account_id: account.id,
prompt_name: 'Analysis Recommendations',
prompt_id: analysesRecommendationsPromptId,
input: JSON.stringify({
analyses: formattedAnalyses,
results: formattedAnalysisResponses,
gender,
age,
weight,
}),
latest_data_change: latestISO,
response: response.output_text,
});
} catch (error) {
console.error('Error saving AI response: ', error);
}
return json.recommended;
}