2023-02-14 09:49:32 -08:00
|
|
|
import clsx from 'clsx';
|
2022-11-25 09:04:11 -08:00
|
|
|
import React from 'react';
|
2022-03-21 11:09:01 -07:00
|
|
|
|
2022-06-08 09:06:05 -07:00
|
|
|
interface ISelect extends React.SelectHTMLAttributes<HTMLSelectElement> {
|
2023-02-15 13:26:27 -08:00
|
|
|
children: Iterable<React.ReactNode>
|
2022-06-08 09:06:05 -07:00
|
|
|
}
|
|
|
|
|
2022-04-30 21:39:58 -07:00
|
|
|
/** Multiple-select dropdown. */
|
2022-06-08 09:06:05 -07:00
|
|
|
const Select = React.forwardRef<HTMLSelectElement, ISelect>((props, ref) => {
|
2022-07-22 10:30:16 -07:00
|
|
|
const { children, className, ...filteredProps } = props;
|
2022-03-21 11:09:01 -07:00
|
|
|
|
|
|
|
return (
|
|
|
|
<select
|
|
|
|
ref={ref}
|
2023-02-14 09:49:32 -08:00
|
|
|
className={clsx(
|
|
|
|
'w-full truncate rounded-md border-gray-300 py-2 pl-3 pr-10 text-base focus:border-primary-500 focus:outline-none focus:ring-primary-500 disabled:opacity-50 dark:border-gray-800 dark:bg-gray-900 dark:text-gray-100 dark:ring-1 dark:ring-gray-800 dark:focus:border-primary-500 dark:focus:ring-primary-500 sm:text-sm',
|
|
|
|
className,
|
|
|
|
)}
|
2022-03-21 11:09:01 -07:00
|
|
|
{...filteredProps}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</select>
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
export default Select;
|