Closes #014 - System-wide handbook sweep, English consolidation & Crypto state persistence
This commit is contained in:
@@ -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 }}>
|
||||
|
||||
Reference in New Issue
Block a user