'use client'; import clsx from 'clsx'; import { SelectSingle } from '@/components/Input'; import { CProps } from '@/components/props'; import { describeConstituenta, describeConstituentaTerm } from '@/utils/labels'; import { ConstituentaID, IConstituenta } from '../models/rsform'; import { matchConstituenta } from '../models/rsformAPI'; import { CstMatchMode } from '../stores/cstSearch'; interface SelectConstituentaProps extends CProps.Styling { value?: IConstituenta; onChange: (newValue?: IConstituenta) => void; items?: IConstituenta[]; placeholder?: string; noBorder?: boolean; } function SelectConstituenta({ className, items, value, onChange, placeholder = 'Выберите конституенту', ...restProps }: SelectConstituentaProps) { const options = items?.map(cst => ({ value: cst.id, label: `${cst.alias}${cst.is_inherited ? '*' : ''}: ${describeConstituenta(cst)}` })) ?? []; function filter(option: { value: ConstituentaID | undefined; label: string }, inputValue: string) { const cst = items?.find(item => item.id === option.value); return !cst ? false : matchConstituenta(cst, inputValue, CstMatchMode.ALL); } return ( onChange(items?.find(cst => cst.id === data?.value))} // @ts-expect-error: TODO: use type definitions from react-select in filter object filterOption={filter} placeholder={placeholder} {...restProps} /> ); } export default SelectConstituenta;