LLM-Prompt (message.post + sos-stream):
- LANG_INSTRUCTIONS Map raus, ersetzt durch dynamische Instruktion
'Reply in {detectedFromUser} ... fallback: {appLang}'
- Lyra matcht jetzt die Sprache der letzten User-Message (per
detectLang Unicode-Detection); App-Locale ist nur noch Fallback
- Instruktion doppelt eingehängt (Anfang + Ende des System-Prompts)
gegen recency bias bei langen deutschen Prompts
TTS (speak dispatcher + speak-cartesia + speak-elevenlabs):
- Kein 'de'-Default mehr für language. detectLang(text, locale) leitet
Sprache primär aus dem Antwort-Text ab (Arabic/Cyrillic/CJK/Turkish-
Letters), Locale als Fallback
- Cartesia + ElevenLabs: language/language_code nur senden wenn
ableitbar, sonst Provider auto-detect statt erzwungenem 'de'
- speak-cartesia: sonic-2 → sonic-3 (Multi-Lang, war beim Dispatcher-
Fix gestern vergessen worden)
- Google: en-US neutraler Fallback statt de-DE-Bias
Neu: server/utils/detect-lang.ts
31 lines
917 B
Swift
31 lines
917 B
Swift
import SwiftUI
|
|
|
|
struct StepIndicator: View {
|
|
let current: WizardStep
|
|
|
|
var body: some View {
|
|
HStack(spacing: 8) {
|
|
ForEach(WizardStep.allCases) { step in
|
|
if step != .done {
|
|
Circle()
|
|
.fill(color(for: step))
|
|
.frame(width: 12, height: 12)
|
|
if step.rawValue < WizardStep.total - 1 {
|
|
Rectangle()
|
|
.fill(Color.gray.opacity(0.3))
|
|
.frame(height: 1)
|
|
.frame(maxWidth: 30)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.padding(.vertical, 12)
|
|
}
|
|
|
|
private func color(for step: WizardStep) -> Color {
|
|
if step.rawValue < current.rawValue { return .green }
|
|
if step == current { return .accentColor }
|
|
return Color.gray.opacity(0.3)
|
|
}
|
|
}
|