flutter_install_referrer 2.0.2 copy "flutter_install_referrer: ^2.0.2" to clipboard
flutter_install_referrer: ^2.0.2 copied to clipboard

Detect from where your application was installed (Google Play, App Store, TestFlight…)

flutter_install_referrer #

Pub

A Flutter plugin that allows you to detect how your application was installed.

This plugin was originally developed by daad.mobi, and you can find the upstream repository here. However, it was discontinued and had not been updated for two years. This new package forks and rewrites the project, migrating the old Java/Objective-C code to modern Kotlin and Swift. Additionally, support for Swift Package Manager has been added.

Supported platforms #

  • Android: ✅
  • iOS: ✅

Feel free to open a PR to add support for new platforms or suggest changes.

Installation #

  1. Add flutter_install_referrer: ^2.0.1 to your pubspec.yaml file.
  2. Import import 'package:flutter_install_referrer/flutter_install_referrer.dart';
  3. Get the value by invoking the Future InstallReferrer.referrer

Possibles values #

Android #

Store Value
Google Play InstallationAppReferrer.androidGooglePlay
Amazon App Store InstallationAppReferrer.androidAmazonAppStore
Huawei App Gallery InstallationAppReferrer.androidHuaweiAppGallery
Oppo App Market InstallationAppReferrer.androidOppoAppMarket
Samsung App Shop InstallationAppReferrer.androidSamsungAppShop
Vivo App Store InstallationAppReferrer.androidVivoAppStore
Xiaomi App Store InstallationAppReferrer.androidXiaomiAppStore
Others InstallationAppReferrer.androidManually

If the application was installed from a third party app (eg: GMail, Google Drive, Chrome…), it will be considered as a manual installation (InstallationAppReferrer.androidManually).

If the application was installed from a store (FDroid, Amazon App Shop…) which was not preinstalled on the device (a "non-system" app), it will also be considered as a manual installation (InstallationAppReferrer.androidManually).

If the Android application is in debug mode, it will be marked as InstallationAppReferrer.androidDebug.

iOS #

Store Value
App Store InstallationAppReferrer.iosAppStore
Test Flight InstallationAppReferrer.iosTestFlight

If the iOS application is in debug mode (eg: from the simulator), it will be marked as InstallationAppReferrer.iosDebug.

Package name #

You can also get the package name (Android) or app id (iOS), by calling instead InstallReferrer.app

Widgets #

If you want to receive the result directly in a Widget, you have two choices: InstallReferrerDetectorListener and InstallReferrerDetectorBuilder :

InstallReferrerDetectorBuilder(
  builder: (BuildContext context, InstallationApp? app) {
    if (app == null) {
      return const CircularProgressIndicator.adaptive();
    } else {
      return Text(
        'Package name:\n${app.packageName ?? 'Unknown'}\n'
        'Referrer:\n${referrerToReadableString(app.referrer)}',
          textAlign: TextAlign.center,
      );
    }
  },
);
InstallReferrerDetectorListener(
  child: YourWidget(),
    onReferrerAvailable: (InstallationApp? app) {
      // TODO
    },
);
6
likes
160
points
2.33k
downloads

Publisher

verified publisherall-win-solutions.com

Weekly Downloads

Detect from where your application was installed (Google Play, App Store, TestFlight…)

Repository (GitHub)
Contributing

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

flutter

More

Packages that depend on flutter_install_referrer