## Bug Fixes ### Note Card Actions - Fix broken size change functionality (missing state declaration) - Implement React 19 useOptimistic for instant UI feedback - Add startTransition for non-blocking updates - Ensure smooth animations without page refresh - All note actions now work: pin, archive, color, size, checklist ### Markdown LaTeX Rendering - Add remark-math and rehype-katex plugins - Support inline equations with dollar sign syntax - Support block equations with double dollar sign syntax - Import KaTeX CSS for proper styling - Equations now render correctly instead of showing raw LaTeX ## Technical Details - Replace undefined currentNote references with optimistic state - Add optimistic updates before server actions for instant feedback - Use router.refresh() in transitions for smart cache invalidation - Install remark-math, rehype-katex, and katex packages ## Testing - Build passes successfully with no TypeScript errors - Dev server hot-reloads changes correctly
56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
import prisma from './prisma';
|
|
|
|
export async function getSystemConfig() {
|
|
try {
|
|
const configs = await prisma.systemConfig.findMany();
|
|
return configs.reduce((acc, conf) => {
|
|
acc[conf.key] = conf.value;
|
|
return acc;
|
|
}, {} as Record<string, string>);
|
|
} catch (e) {
|
|
console.error('Failed to load system config from DB:', e);
|
|
return {};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get a config value with a default fallback
|
|
*/
|
|
export async function getConfigValue(key: string, defaultValue: string = ''): Promise<string> {
|
|
const config = await getSystemConfig();
|
|
return config[key] || defaultValue;
|
|
}
|
|
|
|
/**
|
|
* Get a numeric config value with a default fallback
|
|
*/
|
|
export async function getConfigNumber(key: string, defaultValue: number): Promise<number> {
|
|
const value = await getConfigValue(key, String(defaultValue));
|
|
const num = parseFloat(value);
|
|
return isNaN(num) ? defaultValue : num;
|
|
}
|
|
|
|
/**
|
|
* Get a boolean config value with a default fallback
|
|
*/
|
|
export async function getConfigBoolean(key: string, defaultValue: boolean): Promise<boolean> {
|
|
const value = await getConfigValue(key, String(defaultValue));
|
|
return value === 'true';
|
|
}
|
|
|
|
/**
|
|
* Search configuration defaults
|
|
*/
|
|
export const SEARCH_DEFAULTS = {
|
|
SEMANTIC_THRESHOLD: 0.65,
|
|
RRF_K_BASE: 20,
|
|
RRF_K_ADAPTIVE: true,
|
|
KEYWORD_BOOST_EXACT: 2.0,
|
|
KEYWORD_BOOST_CONCEPTUAL: 0.7,
|
|
SEMANTIC_BOOST_EXACT: 0.7,
|
|
SEMANTIC_BOOST_CONCEPTUAL: 1.5,
|
|
QUERY_EXPANSION_ENABLED: false,
|
|
QUERY_EXPANSION_MAX_SYNONYMS: 3,
|
|
DEBUG_MODE: false,
|
|
} as const;
|