From a6a1ee20dee21d4a94ec62b9012bd1a314d05d5b Mon Sep 17 00:00:00 2001 From: Robin Malfait Date: Wed, 2 Mar 2022 11:32:39 +0100 Subject: [PATCH 1/2] reset input if value is reset Fixes: #1177 --- .../src/components/combobox/combobox.test.tsx | 42 +++++++++++++++++++ .../src/components/combobox/combobox.tsx | 2 + .../src/components/combobox/combobox.test.ts | 37 ++++++++++++++++ .../src/components/combobox/combobox.ts | 2 + 4 files changed, 83 insertions(+) diff --git a/packages/@headlessui-react/src/components/combobox/combobox.test.tsx b/packages/@headlessui-react/src/components/combobox/combobox.test.tsx index eb18766358..2d53e0c29b 100644 --- a/packages/@headlessui-react/src/components/combobox/combobox.test.tsx +++ b/packages/@headlessui-react/src/components/combobox/combobox.test.tsx @@ -4349,4 +4349,46 @@ describe('Mouse interactions', () => { assertActiveComboboxOption(options[1]) }) ) + + it( + 'should sync the input field correctly and reset it when resetting the value from outside', + suppressConsoleLogs(async () => { + function Example() { + let [value, setValue] = useState('bob') + + return ( + <> + + + Trigger + + alice + bob + charlie + + + + + ) + } + + render() + + // Open combobox + await click(getComboboxButton()) + + // Verify the input has the selected value + expect(getComboboxInput()?.value).toBe('bob') + + // Override the input by typing something + await type(word('test'), getComboboxInput()) + expect(getComboboxInput()?.value).toBe('test') + + // Reset from outside + await click(getByText('reset')) + + // Verify the input is reset correctly + expect(getComboboxInput()?.value).toBe('') + }) + ) }) diff --git a/packages/@headlessui-react/src/components/combobox/combobox.tsx b/packages/@headlessui-react/src/components/combobox/combobox.tsx index 66f50c5763..04bc3c9cfd 100644 --- a/packages/@headlessui-react/src/components/combobox/combobox.tsx +++ b/packages/@headlessui-react/src/components/combobox/combobox.tsx @@ -330,6 +330,8 @@ let ComboboxRoot = forwardRefWithAs(function Combobox< inputRef.current.value = displayValue(value) } else if (typeof value === 'string') { inputRef.current.value = value + } else { + inputRef.current.value = '' } }, [value, inputRef, inputPropsRef]) diff --git a/packages/@headlessui-vue/src/components/combobox/combobox.test.ts b/packages/@headlessui-vue/src/components/combobox/combobox.test.ts index 9d401dc1ee..32203a9d63 100644 --- a/packages/@headlessui-vue/src/components/combobox/combobox.test.ts +++ b/packages/@headlessui-vue/src/components/combobox/combobox.test.ts @@ -4576,4 +4576,41 @@ describe('Mouse interactions', () => { assertActiveComboboxOption(options[1]) }) ) + + it( + 'should sync the input field correctly and reset it when resetting the value from outside', + suppressConsoleLogs(async () => { + renderTemplate({ + template: html` + + + Trigger + + alice + bob + charlie + + + + `, + setup: () => ({ value: ref('bob') }), + }) + + // Open combobox + await click(getComboboxButton()) + + // Verify the input has the selected value + expect(getComboboxInput()?.value).toBe('bob') + + // Override the input by typing something + await type(word('test'), getComboboxInput()) + expect(getComboboxInput()?.value).toBe('test') + + // Reset from outside + await click(getByText('reset')) + + // Verify the input is reset correctly + expect(getComboboxInput()?.value).toBe('') + }) + ) }) diff --git a/packages/@headlessui-vue/src/components/combobox/combobox.ts b/packages/@headlessui-vue/src/components/combobox/combobox.ts index d915fd1bbf..a5d58726e9 100644 --- a/packages/@headlessui-vue/src/components/combobox/combobox.ts +++ b/packages/@headlessui-vue/src/components/combobox/combobox.ts @@ -177,6 +177,8 @@ export let Combobox = defineComponent({ api.inputRef!.value!.value = displayValue(value) } else if (typeof value === 'string') { api.inputRef!.value!.value = value + } else { + api.inputRef!.value!.value = '' } }, selectOption(id: string) { From d24e85a60d7258f3e56430da393785c9039876bd Mon Sep 17 00:00:00 2001 From: Robin Malfait Date: Wed, 2 Mar 2022 11:34:54 +0100 Subject: [PATCH 2/2] update changelog --- CHANGELOG.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index eafc88fc66..9c522f7e88 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Fix `` flickering issue ([#1118](https://github.com/tailwindlabs/headlessui/pull/1118)) - Improve outside click support ([#1175](https://github.com/tailwindlabs/headlessui/pull/1175)) - Ensure that `appear` works regardless of multiple rerenders ([#1179](https://github.com/tailwindlabs/headlessui/pull/1179)) +- Reset Combobox Input when the value gets reset ([#1181](https://github.com/tailwindlabs/headlessui/pull/1181)) ## [Unreleased - @headlessui/vue] @@ -29,6 +30,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Fix `hover` scroll ([#1161](https://github.com/tailwindlabs/headlessui/pull/1161)) - Guarantee DOM sort order when performing actions ([#1168](https://github.com/tailwindlabs/headlessui/pull/1168)) - Improve outside click support ([#1175](https://github.com/tailwindlabs/headlessui/pull/1175)) +- Reset Combobox Input when the value gets reset ([#1181](https://github.com/tailwindlabs/headlessui/pull/1181)) ## [@headlessui/react@v1.5.0] - 2022-02-17