Prevent default behaviour when clicking outside of a Dialog.Panel (#2919)
* use `event.preventDefault()` in the `useOutsideClick` on Dialog's When using a `Dialog`, we should prevent the default behaviour of the event that triggered the "close" in the `useOutsideClick` call. We recently made improvements to improve outside click behaviour on touch devices (https://github.com/tailwindlabs/headlessui/pull/2572) but due to the `touchend` event, the touch is still forwarded and therefore a potential button _behind_ the "backdrop" will also be clicked. This is not what we want. Added the `event.preventDefault()` for the Dialog specifically because there are other places where we use `useOutsideClick` and where we _do_ want the behaviour where the click just continues. A concrete example of this is 2 `Menu`'s next to eachother where you open the first one, and then click on the second one. This should close first one (outside click) and open the second one (by not preventing the event) * update changelog
This commit is contained in:
@@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||
### Fixed
|
||||
|
||||
- Expose `disabled` state on `<Tab />` component ([#2918](https://github.com/tailwindlabs/headlessui/pull/2918))
|
||||
- Prevent default behaviour when clicking outside of a `Dialog.Panel` ([#2919](https://github.com/tailwindlabs/headlessui/pull/2919))
|
||||
|
||||
## [2.0.0-alpha.4] - 2024-01-03
|
||||
|
||||
|
||||
@@ -305,7 +305,14 @@ function DialogFn<TTag extends ElementType = typeof DEFAULT_DIALOG_TAG>(
|
||||
if (hasNestedDialogs) return false
|
||||
return true
|
||||
})()
|
||||
useOutsideClick(resolveRootContainers, close, outsideClickEnabled)
|
||||
useOutsideClick(
|
||||
resolveRootContainers,
|
||||
(event) => {
|
||||
event.preventDefault()
|
||||
close()
|
||||
},
|
||||
outsideClickEnabled
|
||||
)
|
||||
|
||||
// Handle `Escape` to close
|
||||
let escapeToCloseEnabled = (() => {
|
||||
|
||||
@@ -15,6 +15,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||
### Fixed
|
||||
|
||||
- Expose `disabled` state on `<Tab />` component ([#2918](https://github.com/tailwindlabs/headlessui/pull/2918))
|
||||
- Prevent default behaviour when clicking outside of a `DialogPanel` ([#2919](https://github.com/tailwindlabs/headlessui/pull/2919))
|
||||
|
||||
## [1.7.17] - 2024-01-08
|
||||
|
||||
|
||||
@@ -237,7 +237,8 @@ export let Dialog = defineComponent({
|
||||
})
|
||||
useOutsideClick(
|
||||
resolveRootContainers,
|
||||
(_event, target) => {
|
||||
(event, target) => {
|
||||
event.preventDefault()
|
||||
api.close()
|
||||
nextTick(() => target?.focus())
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user