diff --git a/CHANGELOG.md b/CHANGELOG.md index 91f4a44..9654e3e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,8 @@ +## 1.6.0 + +* Fixed unresolved reference issue. +* Fixed random ANR + ## 1.5.2 * Updated the compile SDK and Gradle versions. diff --git a/README.md b/README.md index a5ea45f..8cf0688 100644 --- a/README.md +++ b/README.md @@ -24,6 +24,7 @@ possible. ``` dart List apps = await InstalledApps.getInstalledApps( bool excludeSystemApps, + bool excludeUnlaunchable, bool withIcon, String packageNamePrefix ); diff --git a/android/src/main/kotlin/com/sharmadhiraj/installed_apps/InstalledAppsPlugin.kt b/android/src/main/kotlin/com/sharmadhiraj/installed_apps/InstalledAppsPlugin.kt index 5cf0e6c..ced5155 100644 --- a/android/src/main/kotlin/com/sharmadhiraj/installed_apps/InstalledAppsPlugin.kt +++ b/android/src/main/kotlin/com/sharmadhiraj/installed_apps/InstalledAppsPlugin.kt @@ -19,34 +19,21 @@ import io.flutter.plugin.common.BinaryMessenger import io.flutter.plugin.common.MethodCall import io.flutter.plugin.common.MethodChannel import io.flutter.plugin.common.MethodChannel.MethodCallHandler -import io.flutter.plugin.common.PluginRegistry.Registrar import java.util.Locale.ENGLISH +class InstalledAppsPlugin : MethodCallHandler, FlutterPlugin, ActivityAware { -class InstalledAppsPlugin() : MethodCallHandler, FlutterPlugin, ActivityAware { - - companion object { - - var context: Context? = null - - @JvmStatic - fun registerWith(registrar: Registrar) { - context = registrar.context() - register(registrar.messenger()) - } - - @JvmStatic - fun register(messenger: BinaryMessenger) { - val channel = MethodChannel(messenger, "installed_apps") - channel.setMethodCallHandler(InstalledAppsPlugin()) - } - } + private lateinit var channel: MethodChannel + private var context: Context? = null override fun onAttachedToEngine(binding: FlutterPlugin.FlutterPluginBinding) { - register(binding.binaryMessenger) + context = binding.applicationContext + channel = MethodChannel(binding.binaryMessenger, "installed_apps") + channel.setMethodCallHandler(this) } override fun onDetachedFromEngine(binding: FlutterPlugin.FlutterPluginBinding) { + channel.setMethodCallHandler(null) } override fun onAttachedToActivity(activityPluginBinding: ActivityPluginBinding) { @@ -63,54 +50,59 @@ class InstalledAppsPlugin() : MethodCallHandler, FlutterPlugin, ActivityAware { override fun onMethodCall(call: MethodCall, result: MethodChannel.Result) { if (context == null) { - result.error("", "Something went wrong!", null) + result.error("ERROR", "Context is null", null) return } when (call.method) { "getInstalledApps" -> { - val includeSystemApps = call.argument("exclude_system_apps") ?: true - val withIcon = call.argument("with_icon") ?: false - val packageNamePrefix: String = call.argument("package_name_prefix") ?: "" + val excludeSystemApps = call.argument("exclude_system_apps") ?: true + val excludeLaunchableApps = call.argument("exclude_unlaunchable") ?: true + val withIcon = call.argument("with_icon") ?: false + val packageNamePrefix = call.argument("package_name_prefix") ?: "" + val platformTypeName = call.argument("platform_type") ?: "" + Thread { val apps: List> = - getInstalledApps(includeSystemApps, withIcon, packageNamePrefix) + getInstalledApps(excludeSystemApps, excludeLaunchableApps, withIcon, packageNamePrefix, PlatformType.fromString(platformTypeName)) result.success(apps) }.start() } "startApp" -> { - val packageName: String? = call.argument("package_name") + val packageName = call.argument("package_name") result.success(startApp(packageName)) } "openSettings" -> { - val packageName: String? = call.argument("package_name") + val packageName = call.argument("package_name") openSettings(packageName) } "toast" -> { - val message = call.argument("message") ?: "" - val short = call.argument("short_length") ?: true + val message = call.argument("message") ?: "" + val short = call.argument("short_length") ?: true toast(message, short) } "getAppInfo" -> { - val packageName: String = call.argument("package_name") ?: "" - result.success(getAppInfo(getPackageManager(context!!), packageName)) + val packageName = call.argument("package_name") ?: "" + val platformTypeName = call.argument("platform_type") ?: "" + val platformType = PlatformType.fromString(platformTypeName) + result.success(getAppInfo(getPackageManager(context!!), packageName, platformType)) } "isSystemApp" -> { - val packageName: String = call.argument("package_name") ?: "" + val packageName = call.argument("package_name") ?: "" result.success(isSystemApp(getPackageManager(context!!), packageName)) } "uninstallApp" -> { - val packageName: String = call.argument("package_name") ?: "" + val packageName = call.argument("package_name") ?: "" result.success(uninstallApp(packageName)) } "isAppInstalled" -> { - val packageName: String = call.argument("package_name") ?: "" + val packageName = call.argument("package_name") ?: "" result.success(isAppInstalled(packageName)) } @@ -120,21 +112,25 @@ class InstalledAppsPlugin() : MethodCallHandler, FlutterPlugin, ActivityAware { private fun getInstalledApps( excludeSystemApps: Boolean, + excludeUnlaunchable: Boolean, withIcon: Boolean, - packageNamePrefix: String + packageNamePrefix: String, + platformType: PlatformType? ): List> { val packageManager = getPackageManager(context!!) var installedApps = packageManager.getInstalledApplications(0) if (excludeSystemApps) installedApps = installedApps.filter { app -> !isSystemApp(packageManager, app.packageName) } + if (excludeUnlaunchable) + installedApps = installedApps.filter { app -> isLaunchable(packageManager, app.packageName) } if (packageNamePrefix.isNotEmpty()) installedApps = installedApps.filter { app -> app.packageName.startsWith( packageNamePrefix.lowercase(ENGLISH) ) } - return installedApps.map { app -> convertAppToMap(packageManager, app, withIcon) } + return installedApps.map { app -> convertAppToMap(packageManager, app, withIcon, platformType) } } private fun startApp(packageName: String?): Boolean { @@ -163,6 +159,10 @@ class InstalledAppsPlugin() : MethodCallHandler, FlutterPlugin, ActivityAware { } } + private fun isLaunchable(packageManager: PackageManager, packageName: String): Boolean { + return packageManager.getLaunchIntentForPackage(packageName) != null + } + private fun openSettings(packageName: String?) { if (!isAppInstalled(packageName)) { print("App $packageName is not installed on this device.") @@ -178,12 +178,13 @@ class InstalledAppsPlugin() : MethodCallHandler, FlutterPlugin, ActivityAware { private fun getAppInfo( packageManager: PackageManager, - packageName: String + packageName: String, + platformType: PlatformType? ): Map? { var installedApps = packageManager.getInstalledApplications(0) installedApps = installedApps.filter { app -> app.packageName == packageName } return if (installedApps.isEmpty()) null - else convertAppToMap(packageManager, installedApps[0], true) + else convertAppToMap(packageManager, installedApps[0], true, platformType) } private fun uninstallApp(packageName: String): Boolean { @@ -197,7 +198,6 @@ class InstalledAppsPlugin() : MethodCallHandler, FlutterPlugin, ActivityAware { } } - private fun isAppInstalled(packageName: String?): Boolean { val packageManager: PackageManager = context!!.packageManager return try { diff --git a/android/src/main/kotlin/com/sharmadhiraj/installed_apps/PlatfromType.kt b/android/src/main/kotlin/com/sharmadhiraj/installed_apps/PlatfromType.kt new file mode 100644 index 0000000..c6470da --- /dev/null +++ b/android/src/main/kotlin/com/sharmadhiraj/installed_apps/PlatfromType.kt @@ -0,0 +1,21 @@ +package com.sharmadhiraj.installed_apps +enum class PlatformType(val value: String) { + FLUTTER("flutter"), + REACT_NATIVE("react_native"), + XAMARIN("xamarin"), + IONIC("ionic"), + NATIVE_OR_OTHERS("native_or_others"); + + companion object { + fun fromString(platform: String): PlatformType? { + if (platform.isEmpty()) return null; + return when (platform.lowercase()) { + "flutter" -> FLUTTER + "react_native" -> REACT_NATIVE + "xamarin" -> XAMARIN + "ionic" -> IONIC + else -> NATIVE_OR_OTHERS + } + } + } +} \ No newline at end of file diff --git a/android/src/main/kotlin/com/sharmadhiraj/installed_apps/Util.kt b/android/src/main/kotlin/com/sharmadhiraj/installed_apps/Util.kt index 79a1924..b90c019 100644 --- a/android/src/main/kotlin/com/sharmadhiraj/installed_apps/Util.kt +++ b/android/src/main/kotlin/com/sharmadhiraj/installed_apps/Util.kt @@ -9,13 +9,12 @@ import android.os.Build.VERSION_CODES.P import java.io.File class Util { - companion object { - fun convertAppToMap( packageManager: PackageManager, app: ApplicationInfo, - withIcon: Boolean + withIcon: Boolean, + platformType: PlatformType?, ): HashMap { val map = HashMap() map["name"] = packageManager.getApplicationLabel(app) @@ -26,12 +25,11 @@ class Util { val packageInfo = packageManager.getPackageInfo(app.packageName, 0) map["version_name"] = packageInfo.versionName map["version_code"] = getVersionCode(packageInfo) - map["built_with"] = BuiltWithUtil.getPlatform(packageInfo.applicationInfo) + map["built_with"] = platformType?.value ?: BuiltWithUtil.getPlatform(packageInfo.applicationInfo) map["installed_timestamp"] = File(packageInfo.applicationInfo.sourceDir).lastModified() return map } - fun getPackageManager(context: Context): PackageManager { return context.packageManager } @@ -41,7 +39,5 @@ class Util { return if (SDK_INT < P) packageInfo.versionCode.toLong() else packageInfo.longVersionCode } - } - } \ No newline at end of file diff --git a/example/ios/Flutter/flutter_export_environment.sh b/example/ios/Flutter/flutter_export_environment.sh index 1223ac8..2ac990c 100755 --- a/example/ios/Flutter/flutter_export_environment.sh +++ b/example/ios/Flutter/flutter_export_environment.sh @@ -1,7 +1,7 @@ #!/bin/sh # This is a generated file; do not edit or check into version control. -export "FLUTTER_ROOT=/Users/dhirajsharma/Drive/SDKs/flutter" -export "FLUTTER_APPLICATION_PATH=/Users/dhirajsharma/Drive/Desk/Personal/Projects/Flutter/installed_apps/example" +export "FLUTTER_ROOT=/Users/velibacik/development/flutter" +export "FLUTTER_APPLICATION_PATH=/Users/velibacik/Desktop/development/package/installed_apps/example" export "COCOAPODS_PARALLEL_CODE_SIGN=true" export "FLUTTER_TARGET=lib/main.dart" export "FLUTTER_BUILD_DIR=build" diff --git a/example/lib/screens/app_info.dart b/example/lib/screens/app_info.dart index c7c0758..228a4f8 100644 --- a/example/lib/screens/app_info.dart +++ b/example/lib/screens/app_info.dart @@ -1,6 +1,5 @@ import 'package:flutter/material.dart'; -import 'package:installed_apps/app_info.dart'; -import 'package:installed_apps/installed_apps.dart'; +import 'package:installed_apps/index.dart'; class AppInfoScreen extends StatelessWidget { final AppInfo? app; @@ -21,7 +20,10 @@ class AppInfoScreen extends StatelessWidget { Widget _buildAppInfoWithPackageName() { return FutureBuilder( - future: InstalledApps.getAppInfo("com.google.android.gm"), + future: InstalledApps.getAppInfo( + "com.google.android.gm", + BuiltWith.flutter, + ), builder: (BuildContext buildContext, AsyncSnapshot snapshot) { return snapshot.connectionState == ConnectionState.done ? snapshot.hasData && snapshot.data != null diff --git a/example/lib/screens/app_list.dart b/example/lib/screens/app_list.dart index 708d67e..16f46e5 100644 --- a/example/lib/screens/app_list.dart +++ b/example/lib/screens/app_list.dart @@ -18,7 +18,7 @@ class AppListScreen extends StatelessWidget { Widget _buildBody() { return FutureBuilder>( - future: InstalledApps.getInstalledApps(true, true), + future: InstalledApps.getInstalledApps(false, true, true), builder: ( BuildContext buildContext, AsyncSnapshot> snapshot, diff --git a/example/lib/screens/home.dart b/example/lib/screens/home.dart index 53be99d..b8e4fa0 100644 --- a/example/lib/screens/home.dart +++ b/example/lib/screens/home.dart @@ -23,7 +23,7 @@ class HomeScreen extends StatelessWidget { _buildListItem( context, "Installed Apps", - "Get installed apps on device. With options to exclude system app, get app icon & matching package name prefix.", + "Get installed apps on device. With options to exclude system app, exclude unlaunchable apps, get app icon & matching package name prefix.", () => Navigator.push( context, MaterialPageRoute(builder: (context) => AppListScreen()), diff --git a/example/pubspec.lock b/example/pubspec.lock index 33d8511..be4a3bc 100644 --- a/example/pubspec.lock +++ b/example/pubspec.lock @@ -5,50 +5,50 @@ packages: dependency: transitive description: name: async - sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c" + sha256: d2872f9c19731c2e5f10444b14686eb7cc85c76274bd6c16e1816bff9a3bab63 url: "https://pub.dev" source: hosted - version: "2.11.0" + version: "2.12.0" boolean_selector: dependency: transitive description: name: boolean_selector - sha256: "6cfb5af12253eaf2b368f07bacc5a80d1301a071c73360d746b7f2e32d762c66" + sha256: "8aab1771e1243a5063b8b0ff68042d67334e3feab9e95b9490f9a6ebf73b42ea" url: "https://pub.dev" source: hosted - version: "2.1.1" + version: "2.1.2" characters: dependency: transitive description: name: characters - sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605" + sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803 url: "https://pub.dev" source: hosted - version: "1.3.0" + version: "1.4.0" clock: dependency: transitive description: name: clock - sha256: cb6d7f03e1de671e34607e909a7213e31d7752be4fb66a86d29fe1eb14bfb5cf + sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b url: "https://pub.dev" source: hosted - version: "1.1.1" + version: "1.1.2" collection: dependency: transitive description: name: collection - sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a + sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76" url: "https://pub.dev" source: hosted - version: "1.18.0" + version: "1.19.1" fake_async: dependency: transitive description: name: fake_async - sha256: "511392330127add0b769b75a987850d136345d9227c6b94c96a04cf4a391bf78" + sha256: "6a95e56b2449df2273fd8c45a662d6947ce1ebb7aafe80e550a3f68297f3cacc" url: "https://pub.dev" source: hosted - version: "1.3.1" + version: "1.3.2" flutter: dependency: "direct main" description: flutter @@ -65,23 +65,23 @@ packages: path: ".." relative: true source: path - version: "1.5.0" + version: "1.5.2" leak_tracker: dependency: transitive description: name: leak_tracker - sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05" + sha256: c35baad643ba394b40aac41080300150a4f08fd0fd6a10378f8f7c6bc161acec url: "https://pub.dev" source: hosted - version: "10.0.5" + version: "10.0.8" leak_tracker_flutter_testing: dependency: transitive description: name: leak_tracker_flutter_testing - sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806" + sha256: f8b613e7e6a13ec79cfdc0e97638fddb3ab848452eff057653abd3edba760573 url: "https://pub.dev" source: hosted - version: "3.0.5" + version: "3.0.9" leak_tracker_testing: dependency: transitive description: @@ -94,10 +94,10 @@ packages: dependency: transitive description: name: matcher - sha256: d2323aa2060500f906aa31a895b4030b6da3ebdcc5619d14ce1aada65cd161cb + sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2 url: "https://pub.dev" source: hosted - version: "0.12.16+1" + version: "0.12.17" material_color_utilities: dependency: transitive description: @@ -110,71 +110,71 @@ packages: dependency: transitive description: name: meta - sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7 + sha256: e3641ec5d63ebf0d9b41bd43201a66e3fc79a65db5f61fc181f04cd27aab950c url: "https://pub.dev" source: hosted - version: "1.15.0" + version: "1.16.0" path: dependency: transitive description: name: path - sha256: "087ce49c3f0dc39180befefc60fdb4acd8f8620e5682fe2476afd0b3688bb4af" + sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5" url: "https://pub.dev" source: hosted - version: "1.9.0" + version: "1.9.1" sky_engine: dependency: transitive description: flutter source: sdk - version: "0.0.99" + version: "0.0.0" source_span: dependency: transitive description: name: source_span - sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c" + sha256: "254ee5351d6cb365c859e20ee823c3bb479bf4a293c22d17a9f1bf144ce86f7c" url: "https://pub.dev" source: hosted - version: "1.10.0" + version: "1.10.1" stack_trace: dependency: transitive description: name: stack_trace - sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" + sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1" url: "https://pub.dev" source: hosted - version: "1.11.1" + version: "1.12.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 + sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d" url: "https://pub.dev" source: hosted - version: "2.1.2" + version: "2.1.4" string_scanner: dependency: transitive description: name: string_scanner - sha256: "556692adab6cfa87322a115640c11f13cb77b3f076ddcc5d6ae3c20242bedcde" + sha256: "921cd31725b72fe181906c6a94d987c78e3b98c2e205b397ea399d4054872b43" url: "https://pub.dev" source: hosted - version: "1.2.0" + version: "1.4.1" term_glyph: dependency: transitive description: name: term_glyph - sha256: a29248a84fbb7c79282b40b8c72a1209db169a2e0542bce341da992fe1bc7e84 + sha256: "7f554798625ea768a7518313e58f83891c7f5024f88e46e7182a4558850a4b8e" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.2.2" test_api: dependency: transitive description: name: test_api - sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb" + sha256: fb31f383e2ee25fbbfe06b40fe21e1e458d14080e3c67e7ba0acfde4df4e0bbd url: "https://pub.dev" source: hosted - version: "0.7.2" + version: "0.7.4" vector_math: dependency: transitive description: @@ -187,10 +187,10 @@ packages: dependency: transitive description: name: vm_service - sha256: "5c5f338a667b4c644744b661f309fb8080bb94b18a7e91ef1dbd343bed00ed6d" + sha256: "0968250880a6c5fe7edc067ed0a13d4bae1577fe2771dcf3010d52c4a9d3ca14" url: "https://pub.dev" source: hosted - version: "14.2.5" + version: "14.3.1" sdks: - dart: ">=3.3.0 <4.0.0" + dart: ">=3.7.0-0 <4.0.0" flutter: ">=3.18.0-18.0.pre.54" diff --git a/lib/index.dart b/lib/index.dart new file mode 100644 index 0000000..a15575c --- /dev/null +++ b/lib/index.dart @@ -0,0 +1,2 @@ +export 'installed_apps.dart'; +export 'app_info.dart'; diff --git a/lib/installed_apps.dart b/lib/installed_apps.dart index a3d12d2..f1be6c0 100644 --- a/lib/installed_apps.dart +++ b/lib/installed_apps.dart @@ -8,21 +8,27 @@ class InstalledApps { /// Retrieves a list of installed apps on the device. /// /// [excludeSystemApps] specifies whether to exclude system apps from the list. + /// [excludeUnlaunchable] specifies whether to exclude apps that cannot be launched /// [withIcon] specifies whether to include app icons in the list. /// [packageNamePrefix] is an optional parameter to filter apps with package names starting with a specific prefix. + /// [platformType] is an optional parameter to set the app type. Default is [AppPlatformType.flutter]. /// /// Returns a list of [AppInfo] objects representing the installed apps. static Future> getInstalledApps([ bool excludeSystemApps = true, + bool excludeUnlaunchable = true, bool withIcon = false, String packageNamePrefix = "", + BuiltWith platformType = BuiltWith.flutter, ]) async { dynamic apps = await _channel.invokeMethod( "getInstalledApps", { "exclude_system_apps": excludeSystemApps, + "exclude_unlaunchable": excludeUnlaunchable, "with_icon": withIcon, "package_name_prefix": packageNamePrefix, + "platform_type": platformType.name, }, ); return AppInfo.parseList(apps); @@ -69,10 +75,16 @@ class InstalledApps { /// [packageName] is the package name of the app to retrieve information for. /// /// Returns [AppInfo] for the given package name, or null if not found. - static Future getAppInfo(String packageName) async { + static Future getAppInfo( + String packageName, + BuiltWith? platformType, + ) async { var app = await _channel.invokeMethod( "getAppInfo", - {"package_name": packageName}, + { + "package_name": packageName, + "platform_type": platformType?.name ?? '', + }, ); if (app == null) { return null; diff --git a/pubspec.lock b/pubspec.lock index df9b838..a91a1d4 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -5,50 +5,50 @@ packages: dependency: transitive description: name: async - sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c" + sha256: d2872f9c19731c2e5f10444b14686eb7cc85c76274bd6c16e1816bff9a3bab63 url: "https://pub.dev" source: hosted - version: "2.11.0" + version: "2.12.0" boolean_selector: dependency: transitive description: name: boolean_selector - sha256: "6cfb5af12253eaf2b368f07bacc5a80d1301a071c73360d746b7f2e32d762c66" + sha256: "8aab1771e1243a5063b8b0ff68042d67334e3feab9e95b9490f9a6ebf73b42ea" url: "https://pub.dev" source: hosted - version: "2.1.1" + version: "2.1.2" characters: dependency: transitive description: name: characters - sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605" + sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803 url: "https://pub.dev" source: hosted - version: "1.3.0" + version: "1.4.0" clock: dependency: transitive description: name: clock - sha256: cb6d7f03e1de671e34607e909a7213e31d7752be4fb66a86d29fe1eb14bfb5cf + sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b url: "https://pub.dev" source: hosted - version: "1.1.1" + version: "1.1.2" collection: dependency: transitive description: name: collection - sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a + sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76" url: "https://pub.dev" source: hosted - version: "1.18.0" + version: "1.19.1" fake_async: dependency: transitive description: name: fake_async - sha256: "511392330127add0b769b75a987850d136345d9227c6b94c96a04cf4a391bf78" + sha256: "6a95e56b2449df2273fd8c45a662d6947ce1ebb7aafe80e550a3f68297f3cacc" url: "https://pub.dev" source: hosted - version: "1.3.1" + version: "1.3.2" flutter: dependency: "direct main" description: flutter @@ -63,18 +63,18 @@ packages: dependency: transitive description: name: leak_tracker - sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05" + sha256: c35baad643ba394b40aac41080300150a4f08fd0fd6a10378f8f7c6bc161acec url: "https://pub.dev" source: hosted - version: "10.0.5" + version: "10.0.8" leak_tracker_flutter_testing: dependency: transitive description: name: leak_tracker_flutter_testing - sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806" + sha256: f8b613e7e6a13ec79cfdc0e97638fddb3ab848452eff057653abd3edba760573 url: "https://pub.dev" source: hosted - version: "3.0.5" + version: "3.0.9" leak_tracker_testing: dependency: transitive description: @@ -87,10 +87,10 @@ packages: dependency: transitive description: name: matcher - sha256: d2323aa2060500f906aa31a895b4030b6da3ebdcc5619d14ce1aada65cd161cb + sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2 url: "https://pub.dev" source: hosted - version: "0.12.16+1" + version: "0.12.17" material_color_utilities: dependency: transitive description: @@ -103,71 +103,71 @@ packages: dependency: transitive description: name: meta - sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7 + sha256: e3641ec5d63ebf0d9b41bd43201a66e3fc79a65db5f61fc181f04cd27aab950c url: "https://pub.dev" source: hosted - version: "1.15.0" + version: "1.16.0" path: dependency: transitive description: name: path - sha256: "087ce49c3f0dc39180befefc60fdb4acd8f8620e5682fe2476afd0b3688bb4af" + sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5" url: "https://pub.dev" source: hosted - version: "1.9.0" + version: "1.9.1" sky_engine: dependency: transitive description: flutter source: sdk - version: "0.0.99" + version: "0.0.0" source_span: dependency: transitive description: name: source_span - sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c" + sha256: "254ee5351d6cb365c859e20ee823c3bb479bf4a293c22d17a9f1bf144ce86f7c" url: "https://pub.dev" source: hosted - version: "1.10.0" + version: "1.10.1" stack_trace: dependency: transitive description: name: stack_trace - sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" + sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1" url: "https://pub.dev" source: hosted - version: "1.11.1" + version: "1.12.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 + sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d" url: "https://pub.dev" source: hosted - version: "2.1.2" + version: "2.1.4" string_scanner: dependency: transitive description: name: string_scanner - sha256: "556692adab6cfa87322a115640c11f13cb77b3f076ddcc5d6ae3c20242bedcde" + sha256: "921cd31725b72fe181906c6a94d987c78e3b98c2e205b397ea399d4054872b43" url: "https://pub.dev" source: hosted - version: "1.2.0" + version: "1.4.1" term_glyph: dependency: transitive description: name: term_glyph - sha256: a29248a84fbb7c79282b40b8c72a1209db169a2e0542bce341da992fe1bc7e84 + sha256: "7f554798625ea768a7518313e58f83891c7f5024f88e46e7182a4558850a4b8e" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.2.2" test_api: dependency: transitive description: name: test_api - sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb" + sha256: fb31f383e2ee25fbbfe06b40fe21e1e458d14080e3c67e7ba0acfde4df4e0bbd url: "https://pub.dev" source: hosted - version: "0.7.2" + version: "0.7.4" vector_math: dependency: transitive description: @@ -180,10 +180,10 @@ packages: dependency: transitive description: name: vm_service - sha256: "5c5f338a667b4c644744b661f309fb8080bb94b18a7e91ef1dbd343bed00ed6d" + sha256: "0968250880a6c5fe7edc067ed0a13d4bae1577fe2771dcf3010d52c4a9d3ca14" url: "https://pub.dev" source: hosted - version: "14.2.5" + version: "14.3.1" sdks: - dart: ">=3.3.0 <4.0.0" + dart: ">=3.7.0-0 <4.0.0" flutter: ">=3.18.0-18.0.pre.54" diff --git a/pubspec.yaml b/pubspec.yaml index 40d3caf..6b1a546 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,10 +1,10 @@ name: installed_apps description: Flutter plugin with utility methods related to installed apps on device. -version: 1.5.2 +version: 1.6.0 homepage: https://github.com/sharmadhiraj/installed_apps environment: - sdk: '>=2.12.0 <4.0.0' + sdk: '>=3.0.0 <4.0.0' flutter: ">=1.12.0" dependencies: