Skip to content

Commit

Permalink
cleanup unnecessary code
Browse files Browse the repository at this point in the history
  • Loading branch information
RobinMalfait committed Jun 2, 2022
1 parent a31e594 commit d8b5012
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 23 deletions.
22 changes: 10 additions & 12 deletions packages/@headlessui-react/src/components/dialog/dialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ import { Description, useDescriptions } from '../description/description'
import { useOpenClosed, State } from '../../internal/open-closed'
import { useServerHandoffComplete } from '../../hooks/use-server-handoff-complete'
import { StackProvider, StackMessage } from '../../internal/stack-context'
import { useOutsideClick, Features as OutsideClickFeatures } from '../../hooks/use-outside-click'
import { useOutsideClick } from '../../hooks/use-outside-click'
import { getOwnerDocument } from '../../utils/owner'
import { useOwnerDocument } from '../../hooks/use-owner'
import { useEventListener } from '../../hooks/use-event-listener'
Expand Down Expand Up @@ -100,13 +100,7 @@ let DEFAULT_DIALOG_TAG = 'div' as const
interface DialogRenderPropArg {
open: boolean
}
type DialogPropsWeControl =
| 'id'
| 'role'
| 'aria-modal'
| 'aria-describedby'
| 'aria-labelledby'
| 'onClick'
type DialogPropsWeControl = 'id' | 'role' | 'aria-modal' | 'aria-describedby' | 'aria-labelledby'

let DialogRenderFeatures = Features.RenderStrategy | Features.Static

Expand Down Expand Up @@ -224,7 +218,7 @@ let DialogRoot = forwardRefWithAs(function Dialog<

close()
},
OutsideClickFeatures.IgnoreScrollbars
enabled
)

// Handle `Escape` to close
Expand Down Expand Up @@ -311,9 +305,6 @@ let DialogRoot = forwardRefWithAs(function Dialog<
'aria-modal': dialogState === DialogStates.Open ? true : undefined,
'aria-labelledby': state.titleId,
'aria-describedby': describedby,
onClick(event: ReactMouseEvent) {
event.stopPropagation()
},
}

return (
Expand Down Expand Up @@ -492,10 +483,17 @@ let Panel = forwardRefWithAs(function Panel<TTag extends ElementType = typeof DE
[dialogState]
)

// Prevent the click events inside the Dialog.Panel from bubbling through the React Tree which
// could submit wrapping <form> elements even if we portalled the Dialog.
let handleClick = useEvent((event: ReactMouseEvent) => {
event.stopPropagation()
})

let theirProps = props
let ourProps = {
ref: panelRef,
id,
onClick: handleClick,
}

return render({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,10 @@ function useRestoreFocus({ ownerDocument }: { ownerDocument: Document | null },
useWatch(() => {
if (enabled) return

focusElement(restoreElement.current)
if (ownerDocument?.activeElement === ownerDocument?.body) {
focusElement(restoreElement.current)
}

restoreElement.current = null
}, [enabled])

Expand Down
1 change: 0 additions & 1 deletion packages/@headlessui-react/src/components/menu/menu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -344,7 +344,6 @@ let Button = forwardRefWithAs(function Button<TTag extends ElementType = typeof
d.nextFrame(() => state.buttonRef.current?.focus({ preventScroll: true }))
} else {
event.preventDefault()
event.stopPropagation()
dispatch({ type: ActionTypes.OpenMenu })
}
})
Expand Down
15 changes: 7 additions & 8 deletions packages/@headlessui-vue/src/components/dialog/dialog.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ import { ForcePortalRoot } from '../../internal/portal-force-root'
import { Description, useDescriptions } from '../description/description'
import { dom } from '../../utils/dom'
import { useOpenClosed, State } from '../../internal/open-closed'
import { useOutsideClick, Features as OutsideClickFeatures } from '../../hooks/use-outside-click'
import { useOutsideClick } from '../../hooks/use-outside-click'
import { getOwnerDocument } from '../../utils/owner'
import { useEventListener } from '../../hooks/use-event-listener'
import { Hidden, Features as HiddenFeatures } from '../../internal/hidden'
Expand Down Expand Up @@ -196,8 +196,7 @@ export let Dialog = defineComponent({

api.close()
nextTick(() => target?.focus())
},
OutsideClickFeatures.IgnoreScrollbars
}
)

// Handle `Escape` to close
Expand Down Expand Up @@ -264,10 +263,6 @@ export let Dialog = defineComponent({
onInvalidate(() => observer.disconnect())
})

function handleClick(event: MouseEvent) {
event.stopPropagation()
}

return () => {
let ourProps = {
// Manually passthrough the attributes, because Vue can't automatically pass
Expand All @@ -279,7 +274,6 @@ export let Dialog = defineComponent({
'aria-modal': dialogState.value === DialogStates.Open ? true : undefined,
'aria-labelledby': titleId.value,
'aria-describedby': describedby.value,
onClick: handleClick,
}
let { open: _, initialFocus, ...incomingProps } = props

Expand Down Expand Up @@ -417,10 +411,15 @@ export let DialogPanel = defineComponent({

expose({ el: api.panelRef, $el: api.panelRef })

function handleClick(event: MouseEvent) {
event.stopPropagation()
}

return () => {
let ourProps = {
id,
ref: api.panelRef,
onClick: handleClick,
}
let incomingProps = props

Expand Down
1 change: 0 additions & 1 deletion packages/@headlessui-vue/src/components/menu/menu.ts
Original file line number Diff line number Diff line change
Expand Up @@ -289,7 +289,6 @@ export let MenuButton = defineComponent({
nextTick(() => dom(api.buttonRef)?.focus({ preventScroll: true }))
} else {
event.preventDefault()
event.stopPropagation()
api.openMenu()
nextFrame(() => dom(api.itemsRef)?.focus({ preventScroll: true }))
}
Expand Down

0 comments on commit d8b5012

Please sign in to comment.