diff --git a/res/menu/main_menu.xml b/res/menu/main_menu.xml
index 97e713e4..0e5380a6 100644
--- a/res/menu/main_menu.xml
+++ b/res/menu/main_menu.xml
@@ -20,7 +20,12 @@
android:title="@string/close_article"
android:showAsAction="ifRoom|withText"/>
-
+
+
- Share article
Could not decode content (UnsupportedEncodingException)
Sort feeds by unread count
+ More headlines...
diff --git a/src/org/fox/ttrss/HeadlinesFragment.java b/src/org/fox/ttrss/HeadlinesFragment.java
index c8da3371..f3790ec9 100644
--- a/src/org/fox/ttrss/HeadlinesFragment.java
+++ b/src/org/fox/ttrss/HeadlinesFragment.java
@@ -79,7 +79,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
Log.d(TAG, "onCreateView, feed=" + m_feed);
if (m_feed != null && (m_articles == null || m_articles.size() == 0))
- refresh();
+ refresh(false);
else
view.findViewById(R.id.loading_container).setVisibility(View.GONE);
@@ -121,13 +121,26 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
}
}
- public void refresh() {
+ public void refresh(boolean append) {
HeadlinesRequest req = new HeadlinesRequest();
req.setApi(m_prefs.getString("ttrss_url", null));
final String sessionId = ((MainActivity)getActivity()).getSessionId();
-
+ int skip = 0;
+
+ if (append) {
+ for (Article a : m_articles) {
+ if (a.unread) ++skip;
+ }
+
+ if (skip == 0) skip = m_articles.size();
+ }
+
+ final int fskip = skip;
+
+ req.setOffset(skip);
+
HashMap map = new HashMap() {
{
put("op", "getHeadlines");
@@ -137,6 +150,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
put("limit", String.valueOf(30));
put("offset", String.valueOf(0));
put("view_mode", "adaptive");
+ put("skip", String.valueOf(fskip));
}
};
@@ -154,6 +168,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
}
private class HeadlinesRequest extends ApiRequest {
+ int m_offset = 0;
protected void onPostExecute(JsonElement result) {
if (result != null) {
@@ -172,12 +187,14 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
getActivity().runOnUiThread(new Runnable() {
public void run() {
- m_articles.clear();
+
+ if (m_offset == 0)
+ m_articles.clear();
for (Article f : articles)
m_articles.add(f);
- m_adapter.notifyDataSetInvalidated();
+ m_adapter.notifyDataSetChanged();
showLoading(false);
}
@@ -199,6 +216,10 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
return;
}
+
+ public void setOffset(int skip) {
+ m_offset = skip;
+ }
}
public void catchupArticle(final Article article) {
diff --git a/src/org/fox/ttrss/MainActivity.java b/src/org/fox/ttrss/MainActivity.java
index 1c7207bf..ea5921b5 100644
--- a/src/org/fox/ttrss/MainActivity.java
+++ b/src/org/fox/ttrss/MainActivity.java
@@ -225,6 +225,9 @@ public class MainActivity extends FragmentActivity implements FeedsFragment.OnFe
case R.id.close_article:
closeArticle();
return true;
+ case R.id.load_more_articles:
+ viewFeed(m_activeFeed, true);
+ return true;
case R.id.share_article:
shareArticle(m_selectedArticle);
return true;
@@ -285,14 +288,17 @@ public class MainActivity extends FragmentActivity implements FeedsFragment.OnFe
m_menu.findItem(R.id.update_feeds).setEnabled(true);
m_menu.findItem(R.id.show_feeds).setEnabled(true);
}
-
+
+ m_menu.findItem(R.id.load_more_articles).setVisible(m_activeFeed != null);
+
} else {
m_menu.findItem(R.id.login).setVisible(true);
m_menu.findItem(R.id.logout).setVisible(false);
m_menu.findItem(R.id.close_article).setVisible(false);
m_menu.findItem(R.id.share_article).setVisible(false);
-
+ m_menu.findItem(R.id.load_more_articles).setVisible(false);
+
m_menu.findItem(R.id.update_feeds).setEnabled(false);
m_menu.findItem(R.id.show_feeds).setEnabled(false);
}
@@ -377,21 +383,30 @@ public class MainActivity extends FragmentActivity implements FeedsFragment.OnFe
@Override
public void onFeedSelected(Feed feed) {
Log.d(TAG, "Selected feed: " + feed.toString());
- viewFeed(feed);
+ viewFeed(feed, false);
}
public Article getSelectedArticle() {
return m_selectedArticle;
}
- public void viewFeed(Feed feed) {
+ public void viewFeed(Feed feed, boolean append) {
m_activeFeed = feed;
+
+ initMainMenu();
- HeadlinesFragment hf = new HeadlinesFragment();
+ if (!append) {
+ HeadlinesFragment hf = new HeadlinesFragment();
- FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
- ft.replace(R.id.headlines_fragment, hf);
- ft.commit();
+ FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
+ ft.replace(R.id.headlines_fragment, hf);
+ ft.commit();
+ } else {
+ HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment);
+ if (hf != null) {
+ hf.refresh(true);
+ }
+ }
}
public void openArticle(Article article) {