ConceptPortal-public/rsconcept/frontend/src/components/Common/SelectMulti.tsx

74 lines
2.0 KiB
TypeScript
Raw Normal View History

'use client';
import { useMemo } from 'react';
import Select, { GroupBase, Props, StylesConfig } from 'react-select';
import { useConceptTheme } from '@/context/ThemeContext';
import { selectDarkT, selectLightT } from '@/utils/color';
2023-12-08 19:24:08 +03:00
export interface SelectMultiProps<
Option,
Group extends GroupBase<Option> = GroupBase<Option>
>
2023-11-29 13:07:55 +03:00
extends Omit<Props<Option, true, Group>, 'theme' | 'menuPortalTarget'> {
noPortal?: boolean
}
2023-11-29 13:07:55 +03:00
function SelectMulti<Option, Group extends GroupBase<Option> = GroupBase<Option>> ({
noPortal, ...restProps
}: SelectMultiProps<Option, Group>) {
const { darkMode, colors } = useConceptTheme();
const themeColors = useMemo(
() => !darkMode ? selectLightT : selectDarkT
, [darkMode]);
2023-09-14 16:53:38 +03:00
const adjustedStyles: StylesConfig<Option, true, Group> = useMemo(
() => ({
control: (styles, { isDisabled }) => ({
...styles,
borderRadius: '0.25rem',
2023-12-07 01:21:27 +03:00
cursor: isDisabled ? 'not-allowed' : 'pointer',
boxShadow: 'none'
}),
option: (styles, { isSelected }) => ({
...styles,
backgroundColor: isSelected ? colors.bgSelected : styles.backgroundColor,
color: isSelected ? colors.fgSelected : styles.color,
borderWidth: '1px',
borderColor: colors.border
}),
2023-11-29 13:07:55 +03:00
menuPortal: (styles) => ({
...styles,
zIndex: 9999
}),
2023-10-14 17:14:40 +03:00
menuList: (styles) => ({
...styles,
padding: '0px'
}),
input: (styles) => ({...styles}),
placeholder: (styles) => ({...styles}),
multiValue: (styles) => ({
2023-09-14 16:53:38 +03:00
...styles,
borderRadius: '0.5rem',
backgroundColor: colors.bgSelected,
})
}), [colors]);
return (
<Select isMulti
noOptionsMessage={() => 'Список пуст'}
theme={theme => ({
...theme,
borderRadius: 0,
colors: {
...theme.colors,
...themeColors
},
})}
menuPortalTarget={!noPortal ? document.body : null}
styles={adjustedStyles}
{...restProps}
/>);
}
export default SelectMulti;