import React from 'react'; import { mergeRefs } from '../components/react-component-lib/utils'; import { IonLifeCycleContext } from '../contexts/IonLifeCycleContext'; import type { RouteInfo } from '../models'; import { StackContext } from './StackContext'; interface PageManagerProps { className?: string; forwardedRef?: React.ForwardedRef; routeInfo?: RouteInfo; } export class PageManager extends React.PureComponent { ionLifeCycleContext!: React.ContextType; context!: React.ContextType; ionPageElementRef: React.RefObject; stableMergedRefs: React.RefCallback; constructor(props: PageManagerProps) { super(props); this.ionPageElementRef = React.createRef(); // React refs must be stable (not created inline). this.stableMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef); } componentDidMount() { if (this.ionPageElementRef.current) { if (this.context.isInOutlet()) { this.ionPageElementRef.current.classList.add('ion-page-invisible'); } this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo!); this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler.bind(this)); this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler.bind(this)); this.ionPageElementRef.current.addEventListener('ionViewWillLeave', this.ionViewWillLeaveHandler.bind(this)); this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler.bind(this)); } } componentWillUnmount() { if (this.ionPageElementRef.current) { this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler.bind(this)); this.ionPageElementRef.current.removeEventListener('ionViewDidEnter', this.ionViewDidEnterHandler.bind(this)); this.ionPageElementRef.current.removeEventListener('ionViewWillLeave', this.ionViewWillLeaveHandler.bind(this)); this.ionPageElementRef.current.removeEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler.bind(this)); } } ionViewWillEnterHandler() { this.ionLifeCycleContext.ionViewWillEnter(); } ionViewDidEnterHandler() { this.ionLifeCycleContext.ionViewDidEnter(); } ionViewWillLeaveHandler() { this.ionLifeCycleContext.ionViewWillLeave(); } ionViewDidLeaveHandler() { this.ionLifeCycleContext.ionViewDidLeave(); } render() { // eslint-disable-next-line @typescript-eslint/no-unused-vars const { className, children, routeInfo, forwardedRef, ...props } = this.props; return ( {(context) => { this.ionLifeCycleContext = context; return (
{children}
); }}
); } static get contextType() { return StackContext; } } export default PageManager;