summaryrefslogtreecommitdiffstats
path: root/src/com/android/browser/BrowserHistoryPage.java
diff options
context:
space:
mode:
authorJohn Reck <jreck@google.com>2010-11-15 17:40:59 -0800
committerJohn Reck <jreck@google.com>2010-11-17 13:45:10 -0800
commit9fed39185e23c71afced2f4176d0d859630dbdc5 (patch)
treef63e1ddcf80f168156403f2b7e456b49355ae59e /src/com/android/browser/BrowserHistoryPage.java
parent8233facddcc51865d612a919d450db6954aa48e3 (diff)
downloadpackages_apps_Browser-9fed39185e23c71afced2f4176d0d859630dbdc5.zip
packages_apps_Browser-9fed39185e23c71afced2f4176d0d859630dbdc5.tar.gz
packages_apps_Browser-9fed39185e23c71afced2f4176d0d859630dbdc5.tar.bz2
Adds "Most Visited" group to history
Bug: 2956361 Adds "Most Visited" as a group in the history tab. It shows the user's 10 most visited URLs. Change-Id: Iac6a3b18be5c647a25f21c6870eabaf7ae80b252
Diffstat (limited to 'src/com/android/browser/BrowserHistoryPage.java')
-rw-r--r--src/com/android/browser/BrowserHistoryPage.java140
1 files changed, 124 insertions, 16 deletions
diff --git a/src/com/android/browser/BrowserHistoryPage.java b/src/com/android/browser/BrowserHistoryPage.java
index 3b0292d..a3ce0b4 100644
--- a/src/com/android/browser/BrowserHistoryPage.java
+++ b/src/com/android/browser/BrowserHistoryPage.java
@@ -32,8 +32,10 @@ import android.content.pm.ResolveInfo;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
+import android.net.Uri;
import android.os.Bundle;
import android.provider.Browser;
+import android.provider.BrowserContract;
import android.provider.BrowserContract.History;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
@@ -47,6 +49,7 @@ import android.webkit.WebIconDatabase.IconListener;
import android.widget.ExpandableListView;
import android.widget.ExpandableListView.ExpandableListContextMenuInfo;
import android.widget.ExpandableListView.OnChildClickListener;
+import android.widget.TextView;
import android.widget.Toast;
/**
@@ -57,6 +60,7 @@ public class BrowserHistoryPage extends Fragment
implements LoaderCallbacks<Cursor>, OnChildClickListener {
static final int LOADER_HISTORY = 1;
+ static final int LOADER_MOST_VISITED = 2;
BookmarksHistoryCallbacks mCallbacks;
ExpandableListView mList;
@@ -64,6 +68,7 @@ public class BrowserHistoryPage extends Fragment
HistoryAdapter mAdapter;
boolean mDisableNewWindow;
HistoryItem mContextHeader;
+ String mMostVisitsLimit;
// Implementation of WebIconDatabase.IconListener
class IconReceiver implements IconListener {
@@ -83,6 +88,7 @@ public class BrowserHistoryPage extends Fragment
History.TITLE, // 2
History.URL, // 3
History.FAVICON, // 4
+ History.VISITS // 5
};
static final int INDEX_ID = 0;
@@ -90,6 +96,7 @@ public class BrowserHistoryPage extends Fragment
static final int INDEX_TITE = 2;
static final int INDEX_URL = 3;
static final int INDEX_FAVICON = 4;
+ static final int INDEX_VISITS = 5;
}
private void copy(CharSequence text) {
@@ -114,6 +121,16 @@ public class BrowserHistoryPage extends Fragment
return loader;
}
+ case LOADER_MOST_VISITED: {
+ Uri uri = History.CONTENT_URI
+ .buildUpon()
+ .appendQueryParameter(BrowserContract.PARAM_LIMIT, mMostVisitsLimit)
+ .build();
+ CursorLoader loader = new CursorLoader(getActivity(), uri,
+ HistoryQuery.PROJECTION, null, null, History.VISITS + " DESC");
+ return loader;
+ }
+
default: {
throw new IllegalArgumentException();
}
@@ -129,20 +146,15 @@ public class BrowserHistoryPage extends Fragment
// Add an empty view late, so it does not claim an empty
// history before the adapter is present
mList.setEmptyView(mEmptyView);
+ break;
+ }
- // Do not post the runnable if there is nothing in the list.
- if (mList.getExpandableListAdapter().getGroupCount() > 0) {
- mList.post(new Runnable() {
- @Override
- public void run() {
- // In case the history gets cleared before this
- // event happens
- if (mList.getExpandableListAdapter().getGroupCount() > 0) {
- mList.expandGroup(0);
- }
- }
- });
- }
+ case LOADER_MOST_VISITED: {
+ mAdapter.changeMostVisitedCursor(data);
+
+ // Add an empty view late, so it does not claim an empty
+ // history before the adapter is present
+ mList.setEmptyView(mEmptyView);
break;
}
@@ -160,6 +172,8 @@ public class BrowserHistoryPage extends Fragment
Bundle args = getArguments();
mDisableNewWindow = args.getBoolean(BrowserBookmarksPage.EXTRA_DISABLE_WINDOW, false);
+ int mvlimit = getResources().getInteger(R.integer.most_visits_limit);
+ mMostVisitsLimit = Integer.toString(mvlimit);
}
@Override
@@ -177,6 +191,7 @@ public class BrowserHistoryPage extends Fragment
// Start the loader
getLoaderManager().initLoader(LOADER_HISTORY, null, this);
+ getLoaderManager().initLoader(LOADER_MOST_VISITED, null, this);
// Register to receive icons in case they haven't all been loaded.
CombinedBookmarkHistoryView.getIconListenerSet().addListener(mIconReceiver);
@@ -188,6 +203,7 @@ public class BrowserHistoryPage extends Fragment
super.onDestroy();
CombinedBookmarkHistoryView.getIconListenerSet().removeListener(mIconReceiver);
getLoaderManager().stopLoader(LOADER_HISTORY);
+ getLoaderManager().stopLoader(LOADER_MOST_VISITED);
}
@Override
@@ -329,11 +345,102 @@ public class BrowserHistoryPage extends Fragment
}
private class HistoryAdapter extends DateSortedExpandableListAdapter {
+ private Cursor mMostVisited, mHistoryCursor;
+
HistoryAdapter(Context context) {
super(context, HistoryQuery.INDEX_DATE_LAST_VISITED);
}
@Override
+ public void changeCursor(Cursor cursor) {
+ mHistoryCursor = cursor;
+ super.changeCursor(cursor);
+ }
+
+ void changeMostVisitedCursor(Cursor cursor) {
+ if (mMostVisited == cursor) {
+ return;
+ }
+ if (mMostVisited != null) {
+ mMostVisited.unregisterDataSetObserver(mDataSetObserver);
+ mMostVisited.close();
+ }
+ mMostVisited = cursor;
+ mMostVisited.registerDataSetObserver(mDataSetObserver);
+ }
+
+ @Override
+ public long getChildId(int groupPosition, int childPosition) {
+ if (!mDataValid) return 0;
+ if (moveCursorToChildPosition(groupPosition, childPosition)) {
+ Cursor cursor = getCursor(groupPosition);
+ return cursor.getLong(HistoryQuery.INDEX_ID);
+ }
+ return 0;
+ }
+
+ @Override
+ public int getGroupCount() {
+ return super.getGroupCount() + (mMostVisited != null ? 1 : 0);
+ }
+
+ @Override
+ public int getChildrenCount(int groupPosition) {
+ if (groupPosition >= super.getGroupCount()) {
+ return mMostVisited.getCount();
+ }
+ return super.getChildrenCount(groupPosition);
+ }
+
+ @Override
+ public boolean isEmpty() {
+ if (!super.isEmpty()) {
+ return false;
+ }
+ return mMostVisited == null
+ || mMostVisited.isClosed()
+ || mMostVisited.getCount() == 0;
+ }
+
+ Cursor getCursor(int groupPosition) {
+ if (groupPosition >= super.getGroupCount()) {
+ return mMostVisited;
+ }
+ return mHistoryCursor;
+ }
+
+ @Override
+ public View getGroupView(int groupPosition, boolean isExpanded,
+ View convertView, ViewGroup parent) {
+ if (groupPosition >= super.getGroupCount()) {
+ if (!mDataValid) throw new IllegalStateException("Data is not valid");
+ TextView item;
+ if (null == convertView || !(convertView instanceof TextView)) {
+ LayoutInflater factory = LayoutInflater.from(getContext());
+ item = (TextView) factory.inflate(R.layout.history_header, null);
+ } else {
+ item = (TextView) convertView;
+ }
+ item.setText(R.string.tab_most_visited);
+ return item;
+ }
+ return super.getGroupView(groupPosition, isExpanded, convertView, parent);
+ }
+
+ @Override
+ boolean moveCursorToChildPosition(
+ int groupPosition, int childPosition) {
+ if (groupPosition >= super.getGroupCount()) {
+ if (mDataValid && !mMostVisited.isClosed()) {
+ mMostVisited.moveToPosition(childPosition);
+ return true;
+ }
+ return false;
+ }
+ return super.moveCursorToChildPosition(groupPosition, childPosition);
+ }
+
+ @Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild,
View convertView, ViewGroup parent) {
HistoryItem item;
@@ -354,10 +461,11 @@ public class BrowserHistoryPage extends Fragment
return item;
}
- item.setName(getString(HistoryQuery.INDEX_TITE));
- String url = getString(HistoryQuery.INDEX_URL);
+ Cursor cursor = getCursor(groupPosition);
+ item.setName(cursor.getString(HistoryQuery.INDEX_TITE));
+ String url = cursor.getString(HistoryQuery.INDEX_URL);
item.setUrl(url);
- byte[] data = getBlob(HistoryQuery.INDEX_FAVICON);
+ byte[] data = cursor.getBlob(HistoryQuery.INDEX_FAVICON);
if (data != null) {
item.setFavicon(BitmapFactory.decodeByteArray(data, 0,
data.length));