diff --git a/res/anim/slide_in_left.xml b/res/anim/slide_in_left.xml
deleted file mode 100644
index b51d378c..00000000
--- a/res/anim/slide_in_left.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
\ No newline at end of file
diff --git a/res/anim/slide_out_right.xml b/res/anim/slide_out_right.xml
deleted file mode 100644
index d7854d63..00000000
--- a/res/anim/slide_out_right.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
\ No newline at end of file
diff --git a/src/org/fox/ttrss/Feed.java b/src/org/fox/ttrss/Feed.java
index 1f18521b..feed1767 100644
--- a/src/org/fox/ttrss/Feed.java
+++ b/src/org/fox/ttrss/Feed.java
@@ -1,6 +1,9 @@
package org.fox.ttrss;
-public class Feed implements Comparable {
+import android.os.Parcel;
+import android.os.Parcelable;
+
+public class Feed implements Comparable, Parcelable {
String feed_url;
String title;
int id;
@@ -16,4 +19,30 @@ public class Feed implements Comparable {
else
return this.title.compareTo(feed.title);
}
+
+ @Override
+ public int describeContents() {
+ return 0;
+ }
+
+ @Override
+ public void writeToParcel(Parcel out, int flags) {
+ out.writeString(feed_url);
+ out.writeString(title);
+ out.writeInt(id);
+ out.writeInt(unread);
+ out.writeInt(has_icon ? 1 : 0);
+ out.writeInt(cat_id);
+ out.writeInt(last_updated);
+ }
+
+ public void readFromParcel(Parcel in) {
+ feed_url = in.readString();
+ title = in.readString();
+ id = in.readInt();
+ unread = in.readInt();
+ has_icon = in.readInt() == 1;
+ cat_id = in.readInt();
+ last_updated = in.readInt();
+ }
}
\ No newline at end of file
diff --git a/src/org/fox/ttrss/FeedsFragment.java b/src/org/fox/ttrss/FeedsFragment.java
index 7d7863f3..dd0e39d7 100644
--- a/src/org/fox/ttrss/FeedsFragment.java
+++ b/src/org/fox/ttrss/FeedsFragment.java
@@ -11,7 +11,10 @@ import android.app.Fragment;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
+import android.os.Parcel;
+import android.os.Parcelable;
import android.preference.PreferenceManager;
+import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
@@ -31,10 +34,36 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
private final String TAG = this.getClass().getSimpleName();
private SharedPreferences m_prefs;
private FeedListAdapter m_adapter;
- private List m_feeds = new ArrayList();
+ private FeedList m_feeds = new FeedList();
private OnFeedSelectedListener m_feedSelectedListener;
private int m_selectedFeedId;
+ private class FeedList extends ArrayList implements Parcelable {
+
+ @Override
+ public int describeContents() {
+ return 0;
+ }
+
+ @Override
+ public void writeToParcel(Parcel out, int flags) {
+ out.writeInt(this.size());
+ for (Feed feed : this) {
+ out.writeParcelable(feed, flags);
+ }
+ }
+
+ public void readFromParcel(Parcel in) {
+ int length = in.readInt();
+
+ for (int i = 0; i < length; i++) {
+ Feed feed = in.readParcelable(Feed.class.getClassLoader());
+ this.add(feed);
+ }
+
+ }
+ }
+
public interface OnFeedSelectedListener {
public void onFeedSelected(Feed feed);
}
@@ -54,8 +83,8 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
if (savedInstanceState != null) {
- //m_sessionId = savedInstanceState.getString("sessionId");
- //m_activeFeedId = savedInstanceState.getInt("activeFeedId");
+ m_selectedFeedId = savedInstanceState.getInt("selectedFeedId");
+ m_feeds = savedInstanceState.getParcelable("feeds");
}
View view = inflater.inflate(R.layout.feeds_fragment, container, false);
@@ -63,11 +92,12 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
ListView list = (ListView)view.findViewById(R.id.feeds);
m_adapter = new FeedListAdapter(getActivity(), R.layout.feeds_row, (ArrayList)m_feeds);
list.setAdapter(m_adapter);
- //list.setChoiceMode(AbsListView.CHOICE_MODE_SINGLE);
list.setOnItemClickListener(this);
-
- //if (m_sessionId != null)
+
+ if (m_feeds == null || m_feeds.size() == 0)
refresh();
+ else
+ view.findViewById(R.id.loading_container).setVisibility(View.GONE);
return view;
}
@@ -83,17 +113,14 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
m_prefs = PreferenceManager.getDefaultSharedPreferences(getActivity().getApplicationContext());
m_feedSelectedListener = (OnFeedSelectedListener) activity;
-
- //m_sessionId = ((MainActivity)activity).getSessionId();
-
}
@Override
public void onSaveInstanceState (Bundle out) {
super.onSaveInstanceState(out);
- //out.putString("sessionId", m_sessionId);
- //out.putInt("activeFeedId", m_activeFeedId);
+ out.putInt("selectedFeedId", m_selectedFeedId);
+ out.putParcelable("feeds", m_feeds);
}
@Override
@@ -187,13 +214,10 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
}
} catch (Exception e) {
e.printStackTrace();
-
- MainActivity ma = (MainActivity)getActivity();
- ma.toast("Error parsing feedlist: incorrect format");
+ // report invalid object received
}
} else {
- MainActivity ma = (MainActivity)getActivity();
- ma.toast("Error parsing feedlist: null object.");
+ // report null object received
}
return;
diff --git a/src/org/fox/ttrss/HeadlinesFragment.java b/src/org/fox/ttrss/HeadlinesFragment.java
index 36aa0b7b..fa5db0e8 100644
--- a/src/org/fox/ttrss/HeadlinesFragment.java
+++ b/src/org/fox/ttrss/HeadlinesFragment.java
@@ -59,7 +59,8 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
if (savedInstanceState != null) {
//m_sessionId = savedInstanceState.getString("sessionId");
- //m_feedId = savedInstanceState.getInt("feedId");
+
+ m_feed = savedInstanceState.getParcelable("feed");
//m_activeArticleId = savedInstanceState.getInt("activeArticleId");
}
@@ -70,6 +71,8 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
list.setAdapter(m_adapter);
list.setOnItemClickListener(this);
+ Log.d(TAG, "onCreateView, feed=" + m_feed);
+
if (m_feed != null)
refresh();
else
@@ -140,6 +143,8 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
public void onSaveInstanceState (Bundle out) {
super.onSaveInstanceState(out);
+ out.putParcelable("feed", m_feed);
+
//out.putString("sessionId", m_sessionId);
//out.putInt("feedId", m_feedId);
//out.putInt("activeArticleId", m_activeArticleId);
@@ -182,13 +187,10 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
}
} catch (Exception e) {
e.printStackTrace();
-
- MainActivity ma = (MainActivity)getActivity();
- ma.toast("Error parsing headlines: incorrect format");
+ // report invalid object
}
} else {
- MainActivity ma = (MainActivity)getActivity();
- ma.toast("Error parsing headlines: null object.");
+ // report null object
}
return;
diff --git a/src/org/fox/ttrss/MainActivity.java b/src/org/fox/ttrss/MainActivity.java
index 39924685..0b844317 100644
--- a/src/org/fox/ttrss/MainActivity.java
+++ b/src/org/fox/ttrss/MainActivity.java
@@ -11,6 +11,7 @@ import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.preference.PreferenceManager;
+import android.text.method.HideReturnsTransformationMethod;
import android.util.Log;
import android.view.KeyEvent;
import android.view.Menu;
@@ -41,15 +42,15 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
@Override
public void run() {
- Log.d(TAG, "Refreshing feeds...");
-
refreshFeeds();
}
}
public synchronized void refreshFeeds() {
FeedsFragment frag = (FeedsFragment) getFragmentManager().findFragmentById(R.id.feeds_fragment);
-
+
+ Log.d(TAG, "Refreshing feeds..." + frag);
+
if (frag != null) {
frag.refresh();
}
@@ -72,11 +73,6 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
/** Called when the activity is first created. */
- public void toast(String message) {
- Toast toast = Toast.makeText(getApplicationContext(), message, Toast.LENGTH_SHORT);
- toast.show();
- }
-
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
@@ -93,6 +89,8 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
if (savedInstanceState != null) {
m_sessionId = savedInstanceState.getString("sessionId");
+ m_unreadOnly = savedInstanceState.getBoolean("unreadOnly");
+ m_activeFeed = savedInstanceState.getParcelable("activeFeed");
}
setContentView(R.layout.main);
@@ -101,19 +99,14 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
LinearLayout layout = (LinearLayout)findViewById(R.id.main);
layout.setLayoutTransition(transitioner);
- HeadlinesFragment hf = new HeadlinesFragment();
- ArticleFragment af = new ArticleFragment();
-
- FragmentTransaction ft = getFragmentManager().beginTransaction();
- ft.setCustomAnimations(android.R.animator.fade_in, android.R.animator.fade_out);
- ft.replace(R.id.feeds_fragment, new FeedsFragment());
- ft.replace(R.id.headlines_fragment, hf);
- ft.replace(R.id.article_fragment, af);
- ft.commit();
-
findViewById(R.id.article_fragment).setVisibility(View.GONE);
- login();
+ if (m_sessionId != null) {
+ // restarting, TODO set update timers here?
+ loginSuccess();
+ } else {
+ login();
+ }
}
@@ -136,6 +129,9 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
super.onSaveInstanceState(out);
out.putString("sessionId", m_sessionId);
+ out.putBoolean("unreadOnly", m_unreadOnly);
+ out.putParcelable("activeFeed", m_activeFeed);
+
}
@Override
@@ -170,6 +166,8 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
inflater.inflate(R.menu.main_menu, menu);
m_menu = menu;
+
+ initMainMenu();
return true;
}
@@ -240,6 +238,52 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
m_selectedArticle = null;
}
+
+ private void initMainMenu() {
+ if (m_menu != null) {
+
+ if (m_sessionId != null) {
+ m_menu.findItem(R.id.login).setVisible(false);
+
+ m_menu.findItem(R.id.logout).setVisible(true);
+
+ m_menu.findItem(R.id.update_feeds).setEnabled(true);
+ m_menu.findItem(R.id.show_feeds).setEnabled(true);
+
+ } 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.update_feeds).setEnabled(false);
+ m_menu.findItem(R.id.show_feeds).setEnabled(false);
+ }
+ }
+ }
+
+ private void loginSuccess() {
+ findViewById(R.id.loading_container).setVisibility(View.INVISIBLE);
+ findViewById(R.id.main).setVisibility(View.VISIBLE);
+
+ initMainMenu();
+
+ if (m_refreshTask != null) {
+ m_refreshTask.cancel();
+ m_refreshTask = null;
+ }
+
+ if (m_refreshTimer != null) {
+ m_refreshTimer.cancel();
+ m_refreshTimer = null;
+ }
+
+ m_refreshTask = new RefreshTask();
+ m_refreshTimer = new Timer("Refresh");
+
+ m_refreshTimer.schedule(m_refreshTask, 60*1000L, 60*1000L);
+ }
private class LoginRequest extends ApiRequest {
@@ -255,39 +299,18 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
if (content != null) {
m_sessionId = content.get("session_id").getAsString();
+ Log.d(TAG, "Authenticated!");
+
setLoadingStatus(R.string.loading_message, true);
-
- findViewById(R.id.loading_container).setVisibility(View.INVISIBLE);
- findViewById(R.id.main).setVisibility(View.VISIBLE);
-
+
FeedsFragment frag = new FeedsFragment();
FragmentTransaction ft = getFragmentManager().beginTransaction();
ft.replace(R.id.feeds_fragment, frag);
- ft.show(frag);
ft.commit();
- m_menu.findItem(R.id.login).setVisible(false);
+ loginSuccess();
- m_menu.findItem(R.id.logout).setVisible(true);
-
- m_menu.findItem(R.id.update_feeds).setEnabled(true);
- m_menu.findItem(R.id.show_feeds).setEnabled(true);
-
- if (m_refreshTask != null) {
- m_refreshTask.cancel();
- m_refreshTask = null;
- }
-
- if (m_refreshTimer != null) {
- m_refreshTimer.cancel();
- m_refreshTimer = null;
- }
-
- m_refreshTask = new RefreshTask();
- m_refreshTimer = new Timer("Refresh");
-
- m_refreshTimer.schedule(m_refreshTask, 60*1000L, 60*1000L);
}
} else {
JsonObject content = rv.get("content").getAsJsonObject();
@@ -318,37 +341,30 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
@Override
public void onFeedSelected(Feed feed) {
Log.d(TAG, "Selected feed: " + feed.toString());
-
- m_activeFeed = feed;
-
- HeadlinesFragment hf = new HeadlinesFragment();
-
- FragmentTransaction ft = getFragmentManager().beginTransaction();
- //ft.setCustomAnimations(android.R.animator.fade_in, android.R.animator.fade_out);
- ft.show(getFragmentManager().findFragmentById(R.id.headlines_fragment));
- ft.replace(R.id.headlines_fragment, hf);
- ft.addToBackStack(null);
- ft.commit();
+ viewFeed(feed);
}
public Article getSelectedArticle() {
return m_selectedArticle;
}
- @Override
- public void onArticleSelected(Article article) {
- Log.d(TAG, "Selected article: " + article.toString());
+ public void viewFeed(Feed feed) {
+ m_activeFeed = feed;
+ HeadlinesFragment hf = new HeadlinesFragment();
+
+ FragmentTransaction ft = getFragmentManager().beginTransaction();
+ ft.replace(R.id.headlines_fragment, hf);
+ ft.commit();
+ }
+
+ public void openArticle(Article article) {
m_selectedArticle = article;
ArticleFragment frag = new ArticleFragment();
FragmentTransaction ft = getFragmentManager().beginTransaction();
- //ft.setCustomAnimations(android.R.animator.fade_in, android.R.animator.fade_out);
- //ft.setCustomAnimations(R.anim.slide_in_left, R.anim.slide_out_right);
- ft.show(getFragmentManager().findFragmentById(R.id.article_fragment));
ft.replace(R.id.article_fragment, frag);
- ft.addToBackStack(null);
ft.commit();
findViewById(R.id.feeds_fragment).setVisibility(View.GONE);
@@ -358,7 +374,11 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
m_menu.findItem(R.id.close_article).setVisible(true);
m_menu.findItem(R.id.share_article).setVisible(true);
}
-
+ }
+
+ @Override
+ public void onArticleSelected(Article article) {
+ openArticle(article);
}
public Feed getActiveFeed() {
@@ -368,17 +388,8 @@ public class MainActivity extends Activity implements FeedsFragment.OnFeedSelect
public void logout() {
findViewById(R.id.loading_container).setVisibility(View.VISIBLE);
findViewById(R.id.main).setVisibility(View.INVISIBLE);
-
- if (m_menu != null) {
- 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.update_feeds).setEnabled(false);
- m_menu.findItem(R.id.show_feeds).setEnabled(false);
- }
+
+ initMainMenu();
if (m_refreshTask != null) {
m_refreshTask.cancel();