Save as PDFs in React Native

It’s not uncommon for customers to want a setup where a document is read-only but users can still edit it and then use the Save As functionality to save the modified document to a new location. Nutrient supports saving documents with the Save As functionality.

Currently, there are two options for displaying a document using Nutrient React Native SDK:

  • Using the PSPDFKitView component.

  • Using the present API on the native PSPDFKit module, PSPDFKit.present(...).

To implement Save As functionality, we recommend the PSPDFKitView component, as the implementation is much more straightforward.

Using the PSPDFKitView component

In this instance, a document would be displayed like so:

// Omitted lines ...

render(){
 return (
   <View>
      <PSPDFKitView
          ref="pdfView"
          document={writableDocumentPath}
          disableAutomaticSaving={true}
          configuration={{
            iOSBackgroundColor: processColor('lightgrey'),
          }}
          pageIndex={3}
          style={{flex: 1, color: pspdfkitColor}}
     />
   </View>
   );
}

To implement Save As in this scenario, make sure disableAutomaticSaving is set to true, as shown in the previous snippet.

The next step is to include a <Button/> somewhere in the component that uses the processAnnotations API in the PSPDFKit native module to embed changes that were made to the document and save those changes to a path that would ideally be provided by the user:

import { NativeModules } from 'react-native';

// Omitted lines ....


render(){
 return (
   <View>
      <PSPDFKitView ... />
      <View> 
            <Button
                onPress={() => {
               // Ensure that the path to the new document is a writable document path.
               // You can use a React Native package like https://github.com/rnmods/react-native-document-picker to allow users of your application to select the path and the file name for the new document.

            const newDocumentPath = fileSystem.DocumentDirectoryPath + '/newdocument.pdf';

            // Delete the document if it already exists in that path.
            fileSystem
              .exists(newDocumentPath)
              .then(exists => {
                if (exists) {
                  fileSystem.unlink(newDocumentPath);
                }
              })
              // First, save all annotations in the current document.
              .then(() => {
                this.pdfRef?.current?
                  .getDocument()
                  .save()
                  .then(saved => {
                    // Then, embed all the annotations.
                    NativeModules.PSPDFKit.processAnnotations(
                      'embed',
                      'all',
                      writableDocumentPath,
                      newDocumentPath,
                    )
                      .then(success => {
                        if (success) {
                          alert(`Document saved as ${newDocumentPath}`);
                        } else {
                          alert('Failed to save document');
                        }
                      })
                      .catch(error => {
                        alert(JSON.stringify(error));
                      });
                  })
                  .catch(error => {
                    alert(JSON.stringify(error));
                  });
              });
          }}
          title="Save As"
        />
       </View>
   </View>
   );
}