# Expo Documentation Superwall is a platform for remotely configuring and A/B testing mobile app paywalls — no app update required. It provides SDKs for iOS, Android, Flutter, Expo, Unity, and React Native, plus a dashboard for managing paywall presentation, experiments, and subscription analytics. Curl the pages below to read docs for each page. You can request markdown files by appending .md to a route, for example: - https://superwall.com/docs/expo/guides/advanced/game-controller-support.md Note: Doc URLs return a 307 redirect. Always use `curl -sL` (follow redirects) when fetching them. ## Other sections - [All Documentation](/docs/llms.txt) - [Dashboard Documentation](/docs/llms-dashboard.txt) - [iOS Documentation](/docs/llms-ios.txt) - [Android Documentation](/docs/llms-android.txt) - [Flutter Documentation](/docs/llms-flutter.txt) - [Unity Documentation](/docs/llms-unity.txt) - [React Native Documentation](/docs/llms-react-native.txt) - [Integrations Documentation](/docs/llms-integrations.txt) - [Web Checkout Documentation](/docs/llms-web-checkout.txt) - [Changelog](/docs/expo/changelog): Release notes for the Superwall Expo SDK - [Cohorting in 3rd Party Tools](/docs/expo/guides/3rd-party-analytics/cohorting-in-3rd-party-tools): To easily view Superwall cohorts in 3rd party tools, we recommend you set user attributes based on the experiments that users are included in. You can also use custom placements for creating analytics events for actions such as interacting with an element on a paywall. - [Custom Paywall Analytics](/docs/expo/guides/3rd-party-analytics/custom-paywall-analytics): Learn how to log events from paywalls, such as a button tap or product change, to forward to your analytics service. - [3rd Party Analytics](/docs/expo/guides/3rd-party-analytics) - [Superwall Events](/docs/expo/guides/3rd-party-analytics/tracking-analytics): The SDK automatically tracks some events, which power the charts in the dashboard. - [Advanced Purchasing](/docs/expo/guides/advanced-configuration): If you need fine-grain control over the purchasing pipeline, use a purchase controller to manually handle purchases and subscription status. - [Custom Paywall Actions](/docs/expo/guides/advanced/custom-paywall-actions) - [Game Controller Support](/docs/expo/guides/advanced/game-controller-support) - [Observer Mode](/docs/expo/guides/advanced/observer-mode) - [Retrieving and Presenting a Paywall Yourself](/docs/expo/guides/advanced/presenting-paywalls) - [Using the Presentation Handler](/docs/expo/guides/advanced/using-the-presentation-handler) - [Viewing Purchased Products](/docs/expo/guides/advanced/viewing-purchased-products) - [Configuring](/docs/expo/guides/configuring) - [Consumable Products](/docs/expo/guides/consumable-products): Set up consumable products for Superwall paywalls in Expo apps. - [Debugging](/docs/expo/guides/debugging): Common issues and solutions when integrating the Superwall Expo SDK. - [Experimental Flags](/docs/expo/guides/experimental-flags) - [Handling Deep Links](/docs/expo/guides/handling-deep-links): Use handleDeepLink and campaign rules to present paywalls from deep links without hardcoding logic in your app. - [Local Resources](/docs/expo/guides/local-resources): Bundle images, videos, and other assets in your app so paywalls can load them instantly from the device. - [Managing Users](/docs/expo/guides/managing-users): Learn how to manage users in your app. - [Migrating from React Native SDK](/docs/expo/guides/migrating-react-native): Guide to migrating from the legacy React Native SDK - [Migrating from v1 to v2 - React Native](/docs/expo/guides/migrations/migrating-to-v2): SuperwallKit 2.0 is a major release of Superwall's React Native SDK. This introduces breaking changes. - [Setting a Locale](/docs/expo/guides/setting-locale): Override the default device locale when using the Expo SDK so you can preview localized paywalls and targeting. - [StoreKit testing (iOS only)](/docs/expo/guides/testing-purchases): How to set up StoreKit testing for iOS when using the Expo SDK. - [Using Expo SDK in Bare React Native Apps](/docs/expo/guides/using-expo-sdk-in-bare-react-native): Install Superwall's Expo SDK in existing React Native projects without Expo - [Using RevenueCat](/docs/expo/guides/using-revenuecat): If you want to use RevenueCat to handle your subscription-related logic with Superwall, follow this guide. - [Using the Superwall Delegate](/docs/expo/guides/using-superwall-delegate) - [Vibe Coding](/docs/expo/guides/vibe-coding): How to Vibe Code using the knowledge of the Superwall Docs - [Web Checkout](/docs/expo/guides/web-checkout): Integrate Superwall web checkout with your iOS app for seamless cross-platform subscriptions - [Redeeming In-App](/docs/expo/guides/web-checkout/linking-membership-to-iOS-app): Handle a deep link in your app and use the delegate methods. - [Post-Checkout Redirecting](/docs/expo/guides/web-checkout/post-checkout-redirecting): Learn how to handle users redirecting back to your app after a web purchase. - [Using RevenueCat](/docs/expo/guides/web-checkout/using-revenuecat): Handle a deep link in your app and use the delegate methods to link web checkouts with RevenueCat. - [Welcome](/docs/expo): Welcome to the Superwall Expo SDK documentation - [Configure the SDK](/docs/expo/quickstart/configure) - [Feature Gating](/docs/expo/quickstart/feature-gating) - [Handling Deep Links](/docs/expo/quickstart/in-app-paywall-previews) - [Install the SDK](/docs/expo/quickstart/install): Install the Superwall React Native SDK via your favorite package manager. - [Present Your First Paywall](/docs/expo/quickstart/present-first-paywall): Learn how to present paywalls in your app. - [Setting User Attributes](/docs/expo/quickstart/setting-user-properties) - [Tracking Subscription State](/docs/expo/quickstart/tracking-subscription-state): Here's how to view whether or not a user is on a paid plan in React Native. - [User Management](/docs/expo/quickstart/user-management) - [CustomPurchaseControllerProvider](/docs/expo/sdk-reference/components/CustomPurchaseControllerProvider): A modern, hooks-based approach to handling purchases and purchase restores with the Superwall SDK. - [SuperwallError](/docs/expo/sdk-reference/components/SuperwallError) - [SuperwallLoaded](/docs/expo/sdk-reference/components/SuperwallLoaded) - [SuperwallLoading](/docs/expo/sdk-reference/components/SuperwallLoading) - [SuperwallProvider](/docs/expo/sdk-reference/components/SuperwallProvider) - [consume()](/docs/expo/sdk-reference/hooks/consume): Consume a Google Play purchase token from the Expo compat API. - [getPresentationResult()](/docs/expo/sdk-reference/hooks/getPresentationResult): Check the outcome of a placement without presenting a paywall. - [usePlacement](/docs/expo/sdk-reference/hooks/usePlacement): A React hook that registers a placement so it can remotely trigger a paywall, gate feature access, and expose paywall-lifecycle state. - [useSuperwall](/docs/expo/sdk-reference/hooks/useSuperwall) - [useSuperwallEvents](/docs/expo/sdk-reference/hooks/useSuperwallEvents) - [useUser](/docs/expo/sdk-reference/hooks/useUser) - [Overview](/docs/expo/sdk-reference): Reference documentation for the Superwall Expo SDK.