Superwall

handleDeepLink()

Handles a deep link.

Deprecated SDK

We strongly recommend migrating to the new Superwall Expo SDK, see our migration guide for details.

Purpose

Handles a deep link that may be related to Superwall functionality (e.g., promotional links, paywall deep links).

Signature

async handleDeepLink(url: string): Promise<boolean>

Parameters

NameTypeDescription
urlstringThe deep link URL to handle.

Returns / State

Returns a Promise that resolves to a boolean indicating whether the deep link was handled by Superwall. Returns true if Superwall handled the link, false otherwise.

Usage

// In your deep link handler
const url = "https://your-app.com/paywall?placement=onboarding"
const wasHandled = await Superwall.shared.handleDeepLink(url)

if (!wasHandled) {
  // Handle other deep links in your app
  handleOtherDeepLink(url)
}

Integration

Typically, you'll call this method from your app's deep link handler:

import { Linking } from "react-native"

// Handle initial URL (if app was opened via deep link)
Linking.getInitialURL().then((url) => {
  if (url) {
    Superwall.shared.handleDeepLink(url)
  }
})

// Handle deep links while app is running
Linking.addEventListener("url", (event) => {
  Superwall.shared.handleDeepLink(event.url)
})

How is this guide?

Edit on GitHub