Handling hardware back button navigation on Android with react-native-screens

On Android, calling Navigation#goBack() or using a hardware back button to navigate back from a screen with a PSPDFKitView causes the app to crash when using react-native-screens. This is caused by a known issue in react-native-screens where it tries to redraw the view when it has already been recycled.

To address this issue, we added a destroyView() function to PSPDFKitView, which should be called before navigation happens to destroy the PDFKitView and avoid the redraw, in turn avoiding the crash.

The code snippet below shows how to intercept the back navigation and use the destroyView() function to stop the crash:

import React from 'react';
import PSPDFKitView from 'react-native-pspdfkit';
import { View } from 'react-native';

const DOCUMENT = 'file:///android_asset/report.pdf';

export default function PDFScreen({ navigation }) {
	// This holds the reference to the `PSPDFKitView`.
	const pdfRef = React.createRef();

	// Intercept the back button and destroy the `PSPDFKitView` before performing navigation.
	React.useEffect(() =>
		navigation.addListener('beforeRemove', (e) => {
			// Destroy the view before the screen is removed.
			pdfRef.current.destroyView();
		}),
	);

	return (
		<View style={{ flex: 1 }}>
			<PSPDFKitView
				ref={pdfRef}
				document={DOCUMENT}
				style={{ flex: 1 }}
			/>
		</View>
	);
}