Files
opencrm/frontend/src/components/ui/Select.tsx
T
duffyduck 4fb700cf57 Vertrags-Forms: Mini-Links zu Stammdaten in neuem Tab
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>
2026-06-01 07:47:40 +02:00

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;