1
0
Fork 0
mirror of https://github.com/s-frick/effigenix.git synced 2026-03-28 19:20:23 +01:00

fix(tui): CountryPicker Error-Handling, zentrale DACH-Defaults und Validierung

DACH-Codes und Default-Country in country-defaults.ts zentralisiert statt
in jedem Screen hardcoded. API-Fetch-Fehler fallen auf DACH-Fallback zurück
statt stiller Fehlerignorierung. Country-Validierung in Pflichtfeld-Formularen
ergänzt.
This commit is contained in:
Sebastian Frick 2026-02-24 09:50:02 +01:00
parent a77f0ec5df
commit 11bda32ffc
5 changed files with 26 additions and 11 deletions

View file

@ -8,6 +8,7 @@ import { CountryPicker } from '../../shared/CountryPicker.js';
import { LoadingSpinner } from '../../shared/LoadingSpinner.js';
import { ErrorDisplay } from '../../shared/ErrorDisplay.js';
import { client } from '../../../utils/api-client.js';
import { DEFAULT_COUNTRY, DACH_FALLBACK } from '../../shared/country-defaults.js';
type Field = 'name' | 'phone' | 'email' | 'contactPerson' | 'street' | 'houseNumber' | 'postalCode' | 'city' | 'countryPicker' | 'paymentDueDays';
const FIELDS: Field[] = ['name', 'phone', 'email', 'contactPerson', 'street', 'houseNumber', 'postalCode', 'city', 'countryPicker', 'paymentDueDays'];
@ -37,12 +38,12 @@ export function SupplierCreateScreen() {
const [activeField, setActiveField] = useState<Field>('name');
const [fieldErrors, setFieldErrors] = useState<Partial<Record<Field, string>>>({});
const [countryQuery, setCountryQuery] = useState('');
const [countryCode, setCountryCode] = useState('DE');
const [countryName, setCountryName] = useState('Deutschland');
const [countryCode, setCountryCode] = useState(DEFAULT_COUNTRY.code);
const [countryName, setCountryName] = useState(DEFAULT_COUNTRY.name);
const [countries, setCountries] = useState<CountryDTO[]>([]);
useEffect(() => {
client.countries.search().then(setCountries).catch(() => {});
client.countries.search().then(setCountries).catch(() => setCountries(DACH_FALLBACK));
}, []);
const setField = (field: Exclude<Field, 'countryPicker'>) => (value: string) => {