Closes #014 - System-wide handbook sweep, English consolidation & Crypto state persistence

This commit is contained in:
Antigravity Agent
2026-06-13 13:59:29 +02:00
parent f3c549e476
commit dc703e1bb8
18 changed files with 839 additions and 488 deletions

View File

@@ -43,20 +43,20 @@ import {
// Predefined archetypes for Event Creation
const ARCHETYPES: Record<string, { name: string; defaultScores: Record<string, number> }> = {
'🏦 Fed-Zinsentscheid (FOMC)': {
name: 'Fed-Zinsentscheid (FOMC)',
'🏦 Fed Rate Decision (FOMC)': {
name: 'Fed Rate Decision (FOMC)',
defaultScores: { Apple: 1, NASDAQ: 2, Gold: -1, Bitcoin: 2 }
},
'📈 US-Inflationsdaten (CPI)': {
name: 'US-Inflationsdaten (CPI)',
'📈 US Inflation Data (CPI)': {
name: 'US Inflation Data (CPI)',
defaultScores: { Apple: 1, NASDAQ: 2, Gold: -2, Bitcoin: 1 }
},
'💼 Non-Farm Payrolls (NFP)': {
name: 'Non-Farm Payrolls (NFP)',
defaultScores: { Apple: 0, NASDAQ: 1, Gold: -1, Bitcoin: 0 }
},
'🛒 OPEC-Treffen': {
name: 'OPEC-Treffen',
'🛒 OPEC Meeting': {
name: 'OPEC Meeting',
defaultScores: { Apple: -1, NASDAQ: -1, Gold: 2, Bitcoin: 1 }
}
};
@@ -258,7 +258,6 @@ export default function EventsDemo() {
// Custom Event Form State
const [customName, setCustomName] = useState<string>('');
const [customDate, setCustomDate] = useState<string>('2026-06-15');
const [selectedArchetype, setSelectedArchetype] = useState<string>('Custom');
@@ -522,7 +521,7 @@ export default function EventsDemo() {
scores[asset.name] = typeof arch.defaultScores[asset.name] === 'number' ? arch.defaultScores[asset.name] : 0;
});
} else {
name = name || 'Benutzerdefiniertes Ereignis';
name = name || 'Custom Event';
}
addEventToMatrix(name, customDate, scores);
@@ -608,7 +607,7 @@ export default function EventsDemo() {
className="flex items-center gap-1.5 px-3 py-2 rounded-lg bg-slate-950/80 hover:bg-slate-905 border border-slate-800 hover:border-slate-700 transition-all font-semibold text-xs tracking-wider text-rose-400"
>
<BookOpen className="w-3.5 h-3.5" />
<span>📖 Modulerklärung</span>
<span>📖 Quantitative Handbook</span>
</button>
</div>
</div>
@@ -630,7 +629,7 @@ export default function EventsDemo() {
<form onSubmit={handleAddAsset} className="flex items-center gap-1 bg-slate-950 p-1 rounded-lg border border-slate-800">
<input
type="text"
placeholder="Ticker (z.B. TSLA)"
placeholder="Ticker (e.g. TSLA)"
value={newTickerInput}
onChange={(e) => setNewTickerInput(e.target.value)}
className="bg-transparent text-[11px] text-slate-200 focus:outline-none px-2 py-0.5 w-24 uppercase font-mono"
@@ -664,7 +663,7 @@ export default function EventsDemo() {
<button
onClick={() => handleRemoveAsset(asset.symbol)}
className="text-slate-500 hover:text-rose-400 p-0.5 rounded opacity-0 group-hover/header:opacity-100 transition-opacity"
title={`${asset.name} Spalte löschen`}
title={`${asset.name} Column delete`}
>
<Trash2 className="w-3 h-3" />
</button>
@@ -687,7 +686,7 @@ export default function EventsDemo() {
<td className="py-3 px-3 text-slate-400 font-mono">
{ev.date}
<span className="block text-[10px] text-slate-500">
{d === 0 ? 'Heute' : d > 0 ? `In ${d} Tagen` : `Vor ${-d} Tagen`}
{d === 0 ? 'Today' : d > 0 ? `In ${d} days` : `${-d} days ago`}
</span>
</td>
@@ -750,7 +749,7 @@ export default function EventsDemo() {
<button
onClick={() => deleteEventFromMatrix(ev.id)}
className="text-slate-500 hover:text-rose-400 p-1 hover:bg-slate-800/50 rounded transition-all"
title="Event aus Matrix löschen"
title="Delete event from matrix"
>
<Trash2 className="w-3.5 h-3.5" />
</button>
@@ -1082,7 +1081,7 @@ export default function EventsDemo() {
{calibrationSuccess && (
<div className="bg-emerald-950/30 border border-emerald-800/80 text-emerald-400 text-[10px] rounded-lg p-2 flex items-center gap-1.5 justify-center font-semibold">
<Check className="w-3.5 h-3.5" /> Kalibrierung erfolgreich abgeschlossen!
<Check className="w-3.5 h-3.5" /> Calibration successfully completed!
</div>
)}
@@ -1101,7 +1100,7 @@ export default function EventsDemo() {
{lastCalibrationTime && (
<div className="text-[9px] text-slate-500 font-mono">
Letzter Durchlauf: {lastCalibrationTime} ({lmmObservations.length} Obs.)
Last run: {lastCalibrationTime} ({lmmObservations.length} Obs.)
</div>
)}
</div>
@@ -1169,7 +1168,7 @@ export default function EventsDemo() {
</p>
<div>
<label className="block text-slate-500 mb-1 text-[10px] uppercase font-semibold">Fokus Asset</label>
<label className="block text-slate-500 mb-1 text-[10px] uppercase font-semibold">Focus Asset</label>
<select
value={selectedSurvivalAsset}
onChange={(e) => setSelectedSurvivalAsset(e.target.value)}
@@ -1184,7 +1183,7 @@ export default function EventsDemo() {
<div className="grid grid-cols-2 gap-3 mt-2">
<div className="bg-slate-950/40 border border-slate-805 p-3 rounded-xl">
<span className="block text-[10px] text-slate-500 uppercase font-semibold">Right Censoring</span>
<span className="text-sm font-bold text-slate-200 font-mono">30 Tage</span>
<span className="text-sm font-bold text-slate-200 font-mono">30 days</span>
</div>
<div className="bg-slate-950/40 border border-slate-805 p-3 rounded-xl">
<span className="block text-[10px] text-slate-500 uppercase font-semibold">Observation Count</span>
@@ -1226,7 +1225,7 @@ export default function EventsDemo() {
{selectedModel === 'ROC' && (
<div className="w-full h-full">
<div className="text-[10px] font-mono text-slate-400 mb-2 text-center flex items-center justify-center gap-1.5">
<span>Modell-Klassifikationstrennung (FPR vs TPR)</span>
<span>Model Classification Separation (FPR vs TPR)</span>
</div>
<ResponsiveContainer width="100%" height="90%">
<AreaChart data={rocData} margin={{ top: 10, right: 10, left: -25, bottom: 5 }}>