From e64e45170d58274d0d839cb71719514eb5b2355c Mon Sep 17 00:00:00 2001 From: Nathan Seva Date: Mon, 22 Jan 2024 11:05:09 +0100 Subject: [PATCH] add default item to dropdown (#389) --- src/components/Dropdown/Dropdown.stories.tsx | 18 +++++++++++++++ src/components/Dropdown/Dropdown.tsx | 23 +++++++++++++------- 2 files changed, 33 insertions(+), 8 deletions(-) diff --git a/src/components/Dropdown/Dropdown.stories.tsx b/src/components/Dropdown/Dropdown.stories.tsx index 2e9ba752..13e78e22 100644 --- a/src/components/Dropdown/Dropdown.stories.tsx +++ b/src/components/Dropdown/Dropdown.stories.tsx @@ -171,6 +171,24 @@ export const _Dropdown = {
+ + ), + item: 'MAS', + onClick: () => console.log('option 1'), + }, + { icon: , item: 'MAS' }, + { icon: , item: 'MAS' }, + ]} + defaultItem={{ item: 'Select a token' }} + /> + +
+ { select?: number; } -interface IDropdownProps extends ComponentPropsWithoutRef<'div'> { +interface DropdownProps extends ComponentPropsWithoutRef<'div'> { options: IOption[]; size?: 'xs' | 'md'; select?: number; readOnly?: boolean; + defaultItem?: IOption; } function Icon({ toggle }: { toggle: boolean }) { - let IconclassName = 'max-w-fit stroke-current'; + let IconClassName = 'max-w-fit stroke-current'; return toggle ? ( - + ) : ( - + ); } -export function Dropdown(props: IDropdownProps) { - let { size = 'md', select = 0, options, readOnly = false } = props; +export function Dropdown(props: DropdownProps) { + let { + size = 'md', + select = 0, + options, + readOnly = false, + defaultItem, + } = props; const ref = useRef(null); @@ -51,7 +58,7 @@ export function Dropdown(props: IDropdownProps) { const firstObject = options[select]; const [toggle, setToggle] = useState(false); - const [selected, setSelected] = useState(firstObject); + const [selected, setSelected] = useState(defaultItem ?? firstObject); const hidden = toggle ? '' : 'hidden'; useClickOutside(ref, () => { @@ -60,7 +67,7 @@ export function Dropdown(props: IDropdownProps) { // refresh the selected item when the select prop changes useEffect(() => { - setSelected(options[select]); + setSelected(defaultItem ?? options[select]); }, [select, options]); const customButtonClass = classes[size].button;