Files
web/packages/design-system/lib/components/Form/Country/CountrySelect.tsx
Anton Gunnarsson 66b7af877a Merged in fix/loy-514-fix-validation-tracking-in-signup-form (pull request #3445)
fix(LOY-514): Fix validation error tracking in SignupForm

* Fix issue with form submit handling

* Fix

* Remove browser validation

* Add automatic tracking of validatione rrors


Approved-by: Rasmus Langvad
Approved-by: Matilda Landström
2026-01-19 08:34:24 +00:00

72 lines
1.7 KiB
TypeScript

"use client"
import { useMemo } from "react"
import { useController } from "react-hook-form"
import { Select } from "../../Select"
import { ErrorMessage } from "../ErrorMessage"
import type { CountryProps } from "./country"
const prioCountryCode = ["DE", "DK", "FI", "NO", "SE"]
export default function CountrySelect({
className = "",
errorMessage,
label,
countries,
lang = "en",
name = "country",
disabled = false,
registerOptions = {},
}: CountryProps) {
const { field, formState, fieldState } = useController({
name,
rules: registerOptions,
})
const items = useMemo(() => {
function mapCountry(country: (typeof countries)[number]) {
return {
value: country.code,
label: country.displayName || country.name,
}
}
const collator = new Intl.Collator(lang)
const prioCountries = countries
.filter((c) => prioCountryCode.includes(c.code))
.map(mapCountry)
.sort((a, b) => collator.compare(a.label, b.label))
const restCountries = countries
.filter((c) => !prioCountryCode.includes(c.code))
.map(mapCountry)
.sort((a, b) => collator.compare(a.label, b.label))
return [...prioCountries, ...restCountries]
}, [lang, countries])
return (
<div className={className}>
<Select
items={items}
label={label}
isDisabled={disabled}
isInvalid={fieldState.invalid}
name={name}
onBlur={field.onBlur}
onSelectionChange={(c) => field.onChange(c ?? "")}
selectedKey={field.value}
data-testid={name}
/>
<ErrorMessage
errors={formState.errors}
name={name}
messageLabel={errorMessage}
/>
</div>
)
}