From 78403feedcf6d61a527cf0c904cb55ca43c0f3cb Mon Sep 17 00:00:00 2001 From: Winson Chung Date: Fri, 21 Jan 2011 15:38:02 -0800 Subject: [PATCH] Changing downloads tab to my apps and making most recent first. (3377455) Change-Id: I75ae46ad601457ecfc9555aff7f7ff5284440317 --- res/values/strings.xml | 8 ++++---- src/com/android/launcher2/AllAppsPagedView.java | 1 + src/com/android/launcher2/ApplicationInfo.java | 10 +++++++++- src/com/android/launcher2/LauncherModel.java | 8 ++++++++ 4 files changed, 22 insertions(+), 5 deletions(-) diff --git a/res/values/strings.xml b/res/values/strings.xml index f473880c48..0c4aa26cb8 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -60,12 +60,12 @@ All - + Apps - + Games - - Downloaded + + My Apps diff --git a/src/com/android/launcher2/AllAppsPagedView.java b/src/com/android/launcher2/AllAppsPagedView.java index fe7312d69e..59065996e5 100644 --- a/src/com/android/launcher2/AllAppsPagedView.java +++ b/src/com/android/launcher2/AllAppsPagedView.java @@ -314,6 +314,7 @@ public class AllAppsPagedView extends PagedViewWithDraggableItems implements All filteredApps.add(info); } } + Collections.sort(filteredApps, LauncherModel.APP_INSTALL_TIME_COMPARATOR); } return filteredApps; } diff --git a/src/com/android/launcher2/ApplicationInfo.java b/src/com/android/launcher2/ApplicationInfo.java index 0851cd3509..3adea373e7 100644 --- a/src/com/android/launcher2/ApplicationInfo.java +++ b/src/com/android/launcher2/ApplicationInfo.java @@ -52,6 +52,11 @@ class ApplicationInfo extends ItemInfo { */ Bitmap iconBitmap; + /** + * The time at which the app was first installed. + */ + long firstInstallTime; + ComponentName componentName; static final int APP_FLAG = 1; @@ -82,6 +87,7 @@ class ApplicationInfo extends ItemInfo { if ((appFlags & android.content.pm.ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0) { flags |= DOWNLOADED_FLAG; } + firstInstallTime = pm.getPackageInfo(packageName, 0).firstInstallTime; // TODO: Figure out how to determine what is a game // If it's not a game, it's an app @@ -101,6 +107,7 @@ class ApplicationInfo extends ItemInfo { title = info.title.toString(); intent = new Intent(info.intent); flags = info.flags; + firstInstallTime = info.firstInstallTime; } /** @@ -128,7 +135,8 @@ class ApplicationInfo extends ItemInfo { Log.d(tag, label + " size=" + list.size()); for (ApplicationInfo info: list) { Log.d(tag, " title=\"" + info.title + "\" titleBitmap=" + info.titleBitmap - + " iconBitmap=" + info.iconBitmap); + + " iconBitmap=" + info.iconBitmap + " firstInstallTime=" + + info.firstInstallTime); } } diff --git a/src/com/android/launcher2/LauncherModel.java b/src/com/android/launcher2/LauncherModel.java index 7e72610380..005273749a 100644 --- a/src/com/android/launcher2/LauncherModel.java +++ b/src/com/android/launcher2/LauncherModel.java @@ -1747,6 +1747,14 @@ public class LauncherModel extends BroadcastReceiver { return sCollator.compare(a.title.toString(), b.title.toString()); } }; + public static final Comparator APP_INSTALL_TIME_COMPARATOR + = new Comparator() { + public final int compare(ApplicationInfo a, ApplicationInfo b) { + if (a.firstInstallTime < b.firstInstallTime) return 1; + if (a.firstInstallTime > b.firstInstallTime) return -1; + return 0; + } + }; public void dumpState() { Log.d(TAG, "mCallbacks=" + mCallbacks);