4fb700cf57
ContractEmailsSection (Vertragsansicht): Zusätzlich zu "Postfach öffnen" gibt es jetzt "Stressfrei wechseln Adressen" → Tab in der Kundenakte. ContractForm (Bearbeiten): Kleine ExternalLink-Icons neben den Select-Labels: - Lieferadresse + Rechnungsadresse → Kundenakte/Adressen - Bankkarte → Kundenakte/Bankkarten - Ausweis → Kundenakte/Ausweise - Anbieter + Tarif → Settings/Anbieter & Tarife - Vertriebsplattform → Settings/Vertriebsplattformen Select-Komponente nimmt jetzt ReactNode als label (statt nur string), um JSX-Labels mit eingebettetem Link zu erlauben. Rückwärts- kompatibel zu allen bestehenden String-Aufrufen. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
import { SelectHTMLAttributes, forwardRef, ReactNode } from 'react';
|
|
|
|
interface SelectProps extends SelectHTMLAttributes<HTMLSelectElement> {
|
|
label?: ReactNode;
|
|
error?: string;
|
|
options: { value: string | number; label: string }[];
|
|
placeholder?: string;
|
|
}
|
|
|
|
const Select = forwardRef<HTMLSelectElement, SelectProps>(
|
|
({ className = '', label, error, options, id, placeholder = 'Bitte wählen...', ...props }, ref) => {
|
|
const selectId = id || props.name;
|
|
// Wenn keine Breitenklasse in className, dann w-full als Standard
|
|
const hasWidthClass = /\bw-\d+\b|\bw-\[|\bflex-/.test(className);
|
|
|
|
return (
|
|
<div className={hasWidthClass ? className : 'w-full'}>
|
|
{label && (
|
|
<label htmlFor={selectId} className="block text-sm font-medium text-gray-700 mb-1">
|
|
{label}
|
|
</label>
|
|
)}
|
|
<select
|
|
ref={ref}
|
|
id={selectId}
|
|
className={`block w-full px-3 py-2 border rounded-lg shadow-sm focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-blue-500 ${
|
|
error ? 'border-red-500' : 'border-gray-300'
|
|
}`}
|
|
{...props}
|
|
>
|
|
<option value="">{placeholder}</option>
|
|
{options.map((opt) => (
|
|
<option key={opt.value} value={opt.value}>
|
|
{opt.label}
|
|
</option>
|
|
))}
|
|
</select>
|
|
{error && <p className="mt-1 text-sm text-red-600">{error}</p>}
|
|
</div>
|
|
);
|
|
}
|
|
);
|
|
|
|
Select.displayName = 'Select';
|
|
|
|
export default Select;
|