From 642236c0016d1a3dc1d7c8a56f9bd2f98e182dcd Mon Sep 17 00:00:00 2001 From: Jeff Phillips Date: Wed, 31 Jul 2024 14:59:25 -0400 Subject: [PATCH] fix(TypeaheadSelect): Update input value only when appropriate (#10826) --- .../src/components/Select/TypeaheadSelect.tsx | 17 +++++++++++------ .../Select/examples/TypeaheadSelectDemo.tsx | 2 +- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/packages/react-templates/src/components/Select/TypeaheadSelect.tsx b/packages/react-templates/src/components/Select/TypeaheadSelect.tsx index 7bbc5c24ad6..4863ce2413a 100644 --- a/packages/react-templates/src/components/Select/TypeaheadSelect.tsx +++ b/packages/react-templates/src/components/Select/TypeaheadSelect.tsx @@ -22,14 +22,14 @@ export interface TypeaheadSelectOption extends Omit { +export interface TypeaheadSelectProps extends Omit { /** @hide Forwarded ref */ innerRef?: React.Ref; /** Initial options of the select. */ initialOptions: TypeaheadSelectOption[]; /** Callback triggered on selection. */ onSelect?: ( - _event: React.MouseEvent | React.KeyboardEvent, + _event: React.MouseEvent | React.KeyboardEvent | undefined, selection: string | number ) => void; /** Callback triggered when the select opens or closes. */ @@ -154,14 +154,19 @@ export const TypeaheadSelectBase: React.FunctionComponent ]); React.useEffect(() => { + // If the selected option changed and the current input value is the previously selected item, update the displayed value. const selectedOption = initialOptions.find((o) => o.selected); - setInputValue(String(selectedOption?.content ?? '')); + if (inputValue === selected && selectedOption?.value !== selected) { + setInputValue(String(selectedOption?.content ?? '')); + } + // Only update when options change + // eslint-disable-next-line react-hooks/exhaustive-deps }, [initialOptions]); const setActiveAndFocusedItem = (itemIndex: number) => { setFocusedItemIndex(itemIndex); const focusedItem = selectOptions[itemIndex]; - setActiveItemId(focusedItem.value as string); + setActiveItemId(String(focusedItem.value)); }; const resetActiveAndFocusedItem = () => { @@ -291,7 +296,7 @@ export const TypeaheadSelectBase: React.FunctionComponent const onToggleClick = () => { onToggle && onToggle(!isOpen); setIsOpen(!isOpen); - textInputRef?.current?.focus(); + textInputRef.current?.focus(); }; const onClearButtonClick = () => { @@ -300,7 +305,7 @@ export const TypeaheadSelectBase: React.FunctionComponent onInputChange && onInputChange(''); setFilterValue(''); resetActiveAndFocusedItem(); - textInputRef?.current?.focus(); + textInputRef.current?.focus(); onClearSelection && onClearSelection(); }; diff --git a/packages/react-templates/src/components/Select/examples/TypeaheadSelectDemo.tsx b/packages/react-templates/src/components/Select/examples/TypeaheadSelectDemo.tsx index 6fbbb933092..d2c06a92e8d 100644 --- a/packages/react-templates/src/components/Select/examples/TypeaheadSelectDemo.tsx +++ b/packages/react-templates/src/components/Select/examples/TypeaheadSelectDemo.tsx @@ -35,7 +35,7 @@ export const SelectTypeaheadDemo: React.FunctionComponent = () => { noOptionsFoundMessage={(filter) => `No state was found for "${filter}"`} onClearSelection={() => setSelected(undefined)} onSelect={(_ev, selection) => { - if (!options.find((o) => o.content === selection)) { + if (!options.find((o) => o.value === selection)) { setOptions([...options, { content: String(selection), value: String(selection) }]); } setSelected(String(selection));