Last updated:
0 purchases
new device apps
Device Apps plugin for Flutter #
A plugin to list installed applications on an Android device (⚠️ iOS is not supported). You can also listen to app changes (eg: installations, updates…)
BREAKING CHANGE - 05th May 2021 #
May 5 2021 will mark a breaking change on how applications requesting QUERY_ALL_PACKAGES are accepted in the Google Play (and only this app store !). Quoting from the doc:
Permitted use involves apps that must discover any and all installed apps on the device, for awareness or interoperability purposes may have eligibility for the permission. Permitted use includes; device search, antivirus apps, file managers, and browsers.
Apps granted access to this permission must comply with the User Data policies, including the Prominent Disclosure and Consent requirements, and may not extend its use to undisclosed or invalid purposes.
More info here: https://support.google.com/googleplay/android-developer/answer/10158779
Starting with version 2.1.0 of this plugin, the QUERY_ALL_PACKAGES permission won't be requested by default!
Change with Android 11 #
Starting with Android 11, Android applications targeting API level 30, willing to list "external" applications have to declare a new "normal" permission in their AndroidManifest.xml file called QUERY_ALL_PACKAGES. A few notes about this:
A normal permission doesn't require the user consent
Before version 2.1 of this plugin, the permission was requested automatically. This is not the case anymore
If you want to use, simply add the following to your AndroidManifest.xml:
<manifest...>
<uses-permission android:name="android.permission.QUERY_ALL_PACKAGES" />
</manifest>
copied to clipboard
However, publishing applications on the Google Play with this kind of feature may change in the future. Quoting from the documentation:
In an upcoming policy update, look for Google Play to provide guidelines for apps that need the QUERY_ALL_PACKAGES permission.
👍 Right now, there is no limitation, but be aware that this may change in the future.
Getting Started #
First, you have to import the package in your dart file with:
import 'package:device_apps/device_apps.dart';
copied to clipboard
List of installed applications #
To list applications installed on the device:
List<Application> apps = await DeviceApps.getInstalledApplications();
copied to clipboard
You can filter system apps if necessary.
Note: The list of apps is not ordered! You have to do it yourself.
Get apps with a launch Intent #
A launch Intent means you can launch the application.
To list only the apps with launch intents, simply use the onlyAppsWithLaunchIntent: true attribute.
// Returns a list of only those apps that have launch intent
List<Application> apps = await DeviceApps.getInstalledApplications(onlyAppsWithLaunchIntent: true, includeSystemApps: true)
copied to clipboard
Get an application #
To get a specific application info, please provide its package name:
Application app = await DeviceApps.getApp('com.frandroid.app');
copied to clipboard
Check if an application is installed #
To check if an app is installed (via its package name):
bool isInstalled = await DeviceApps.isAppInstalled('com.frandroid.app');
copied to clipboard
Open an application #
To open an application (with a launch Intent)
DeviceApps.openApp('com.frandroid.app');
copied to clipboard
Open an application settings screen #
To open an application settings screen
DeviceApps.openAppSettings('com.frandroid.app');
copied to clipboard
Uninstall an application #
To open the screen to uninstall an application:
Add this permission to the AndroidManifest.xml file:
<manifest...>
<uses-permission android:name="android.permission.REQUEST_DELETE_PACKAGES" />
</manifest>
copied to clipboard
Call this method:
DeviceApps.uninstallApp('com.frandroid.app');
copied to clipboard
Include application icon #
When calling getInstalledApplications() or getApp() methods, you can also ask for the icon.
To display the image, just call:
Image.memory(app.icon);
copied to clipboard
Listen to app changes #
To listen to applications events on the device (installation, uninstallation, update, enabled or disabled):
Stream<ApplicationEvent> apps = await DeviceApps.listenToAppsChanges();
copied to clipboard
If you only need events for a single app, just use the Stream API, like so:
DeviceApps.listenToAppsChanges().where((ApplicationEvent event) => event.packageName == 'com.frandroid.app')
copied to clipboard
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.