mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2026-03-13 10:22:08 +08:00
fix(popover): popover positions correctly on all frameworks (#26306)
Resolves #25337
This commit is contained in:
@@ -55,6 +55,17 @@ export const createInlineOverlayComponent = <PropType, ElementType>(
|
||||
componentDidMount() {
|
||||
this.componentDidUpdate(this.props);
|
||||
|
||||
/**
|
||||
* Mount the inner component when the
|
||||
* overlay is about to open.
|
||||
*
|
||||
* For ion-popover, this is when `ionMount` is emitted.
|
||||
* For other overlays, this is when `willPresent` is emitted.
|
||||
*/
|
||||
this.ref.current?.addEventListener('ionMount', () => {
|
||||
this.setState({ isOpen: true });
|
||||
});
|
||||
|
||||
/**
|
||||
* Mount the inner component
|
||||
* when overlay is about to open.
|
||||
|
||||
@@ -83,4 +83,4 @@ const PopoverComponent: React.FC = () => {
|
||||
);
|
||||
};
|
||||
|
||||
export default PopoverComponent;
|
||||
export default PopoverComponent;
|
||||
@@ -139,6 +139,7 @@ export const defineOverlayContainer = <Props extends object>(name: string, defin
|
||||
const elementRef = ref();
|
||||
|
||||
onMounted(() => {
|
||||
elementRef.value.addEventListener('ion-mount', () => isOpen.value = true);
|
||||
elementRef.value.addEventListener('will-present', () => isOpen.value = true);
|
||||
elementRef.value.addEventListener('did-dismiss', () => isOpen.value = false);
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user