Open jonesdhtx opened 10 months ago
I managed to work around this by using a controller modal inside the controller modal, see https://github.com/ionic-team/ionic-framework/issues/28840
Maybe you could use useIonPopover, to remedy the issue?
In the documentation on the popover I read: "In addition, nested popovers are not compatible with the controller approach because the popover is automatically added to the root of your application when the create method is called."
I am not sure whether this applies to nested popovers nested in a popover or to nested popovers nested in ANY controller component (like modals).
HTH
Thanks for sharing that @ldikmans . A workaround similar to what you did in the link below gets me functional while framework issue is being found/fixed: https://github.com/ldikmans/ionic-react-nested-modal-bug/blob/main/src/components/InlineModal2.tsx#L31-L39
Hi everyone, I can reproduce this. The problem here appears to be due to mixing controller vs. inline usage. In particular, presenting an inline popover from a controller modal causes events to not be bound to the contents of the popover.
Using both an inline modal and inline popover avoids this issue. Similarly, using both a controller modal and controller popover avoids the issue.
This issue only reproduces in React. Both Angular and Vue allow you to mix nested controller and inline overlays as expected.
edit: This also applies to any element inside of the nested popover in this case. For example click handlers for regular button
elements are not bound either.
It appears that React's synthetic event dispatch system is returning early here when clicking the button in the popover. The root container is a parent of a Portal. It expects that the event will bubble through the Portal. However, it looks like the controller/hook overlay uses a Portal, but the inline overlay does not. This could be contributing to the problem.
@liamdebeasi thanks for clarifying 👍
Prerequisites
Ionic Framework Version
v7.x
Current Behavior
onClick
handler will not get invoked. NOTE: However it's interesting that the click event is received by the IonPopover itself b/c settingdismissOnSelect
does in fact dismiss the popover upon click.Expected Behavior
For any element within an IonPopover (eg IonItem, IonButton, etc) it's
onClick
handler should be invoked when clicked.Steps to Reproduce
Source code for demonstrating the issue: src/pagesHome.tsx
To Reproduce Issue:
onClick
handler is not invoked and the resulting console log is not displayedNOTE: From the main page (outside of the modal) you can click the "Trigger Popover" button and the Button within it works as expected.
Code Reproduction URL
https://github.com/jonesdhtx/ionic-test-case-1
Ionic Info
Ionic:
Ionic CLI : 7.2.0 Ionic Framework : @ionic/react 7.6.4
Capacitor:
Capacitor CLI : 5.6.0 @capacitor/android : not installed @capacitor/core : 5.6.0 @capacitor/ios : not installed
Utility:
cordova-res : not installed globally native-run : 2.0.0
System:
NodeJS : v16.14.0 npm : 8.12.1 OS : macOS Unknown
Additional Information
No response