Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Hover on nested element removes "hovered" styles #191

Closed
Fifciu opened this issue May 12, 2024 · 4 comments · Fixed by #194
Closed

Hover on nested element removes "hovered" styles #191

Fifciu opened this issue May 12, 2024 · 4 comments · Fixed by #194
Labels
bug Something isn't working

Comments

@Fifciu
Copy link

Fifciu commented May 12, 2024

System info



Reproduction

  1. Create the following component:
<div class="flex flex-col bg-white box-shadow" 
    v-motion 
    :initial="{
      opacity: 0,
      y: 0,
      scale: 0
    }" 
    :visibleOnce="{
      opacity: 1,
      y: 0,
      scale: 1
    }"
    :duration="2300" 
    :hovered="{
      scale: 1.03
    }">
    <img src="https://t3.ftcdn.net/jpg/05/85/86/44/360_F_585864419_kgIYUcDQ0yiLOCo1aRjeu7kRxndcoitz.jpg" />
    <div class="px-2 py-4 flex flex-col gap-2 md:px-4 h-full" id="bugged-childs">
      <h3 class="font-secondary font-medium text-2xl text-neutral-800 hyphens-auto break-words">Lorem ipsum dolor</h3>
      <div class="font-secondary font-light text-base text-neutral-800 flex-auto">
        <p class="line-clamp-6">Lorem ipsum dolor sit amet consectetur. Amet at aenean mauris lacinia sociis habitasse
          at sem. Nisl egestas netus elit vivamus felis odio massa at ultrices. Pharetra sed pulvinar lectus tempor. Sed
          amet natoque nulla tellus.</p>
      </div>
    </div>
  </div>
  1. Play with "hovered" part. When you over on image or padding of main div then it works perfectly. But if you hover on child of #bugged-childs (h3, div, div>p) then hovered styles are removed.

Describe the bug

Hovered styles are removed when we hover on grandchild and it's descendants.

Additional context

No response

Logs

No response

@Fifciu
Copy link
Author

Fifciu commented May 12, 2024

I suspect the problem is caused by event bubbling. I think these handlers

useEventListener(target as any, 'mouseenter', () => (hovered.value = true))
catches events from child and sets hover to false.

As a temporary workaround I set @mouseout.stop @mouseleave.stop on both img and #bugged-childs and it solves the problem.

@gimwachan-git
Copy link

I set child to pointer-events: none; and it worked.

@Fifciu
Copy link
Author

Fifciu commented May 29, 2024

I am pretty sure it's possible to solve without workarounds, so we still can have pointer events inside.

@BobbieGoede BobbieGoede added bug Something isn't working and removed pending triage labels May 29, 2024
@BobbieGoede
Copy link
Member

This behaviour is caused by this:

useEventListener(target as any, 'mouseout', () => {
hovered.value = false
tapped.value = false
})

I wonder if there is any use case for triggering this on mouseout, which also triggers whenever mouse hovers over child elements? If not, we can probably remove this and only handle this on mouseleave.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants