-
Notifications
You must be signed in to change notification settings - Fork 47
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
Toasts on-top of modals aren't interactive #429
Comments
Just tested it with the toast rendered at another position and I noticed that the close button of the toast is not reacting. I seems that there is not click event on the toast when triggered with an open flyout / modal. |
I was able to recreate the bug. I'll post the code here for future reference. This is actually a bug in the way browsers handle popovers on-top of elements that were triggered using I will try to raise some awareness around this issue and see if there are any plans on fixing it. I'll leave this open until I can at least confirm it's a browser bug. Thank you. <?php
use Livewire\Volt\Component;
new class extends Component {
public function triggerToast()
{
Flux::toast(text: 'I am a toast that will pop up over the submit button in the flyou modal.');
}
};
?>
<div>
<flux:modal.trigger name="edit-profile">
<flux:button>Open Dialog</flux:button>
</flux:modal.trigger>
<flux:modal name="edit-profile" class="max-w-lg flex flex-col justify-between" variant="flyout">
<flux:text>Press the button to trigger the toast and observe that the toast's close button doesn't work and all mouse events pass through to the underlying button.</flux:text>
<flux:button wire:click="triggerToast">Trigger toast</flux:button>
</flux:modal>
</div> |
Howdy, I think I solved (solved?) this. Basically, the ::backdrop is covering the toast. If you place the toast render tag inside the modal, it works again. Basically, the toast was never unresponsive, you just couldn't click the trigger because all objects outside of the popover are inert. There's an open issue here that discusses it: TLDR: This is working as intended. If you want to render an element while a modal is active, it needs to be within the modal. Doing this works:
But this does not:
Since the toast renderer is global-ish, it might be good to be able to have more than one toast and target it by an identifier so that something like this can be done:
Or you could target nearest toast which would solve it by convention instead of configuration. |
Thanks. I should have clarified, everything stacks correctly when nested as you've described, however, because toasts are global it's kinda hard to have the global toast provider inside your one-off modal? But yeah, good clarification. Thanks also for listing that github issue, I'll give it a read through |
Hi, I have a flyout with a form in it. The submit triggers a toast which is shown exactly over the save button of the form. When I pressing the close button of the toast, the toast is closed but also the underlying button is triggerd so the form is submitted again and again.
The text was updated successfully, but these errors were encountered: