diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/org/fox/ttrss/Feed.java | 31 | ||||
-rw-r--r-- | src/org/fox/ttrss/FeedsFragment.java | 56 | ||||
-rw-r--r-- | src/org/fox/ttrss/HeadlinesFragment.java | 14 | ||||
-rw-r--r-- | src/org/fox/ttrss/MainActivity.java | 155 |
4 files changed, 161 insertions, 95 deletions
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<Feed> {
+import android.os.Parcel;
+import android.os.Parcelable;
+
+public class Feed implements Comparable<Feed>, Parcelable {
String feed_url;
String title;
int id;
@@ -16,4 +19,30 @@ public class Feed implements Comparable<Feed> { 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<Feed> m_feeds = new ArrayList<Feed>();
+ private FeedList m_feeds = new FeedList();
private OnFeedSelectedListener m_feedSelectedListener;
private int m_selectedFeedId;
+ private class FeedList extends ArrayList<Feed> 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<Feed>)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(); - setLoadingStatus(R.string.loading_message, true); - - findViewById(R.id.loading_container).setVisibility(View.INVISIBLE); - findViewById(R.id.main).setVisibility(View.VISIBLE); + Log.d(TAG, "Authenticated!"); + setLoadingStatus(R.string.loading_message, true); + 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); - - 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"); + loginSuccess(); - 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()); - + viewFeed(feed); + } + + public Article getSelectedArticle() { + return m_selectedArticle; + } + + public void viewFeed(Feed feed) { 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(); } - public Article getSelectedArticle() { - return m_selectedArticle; - } - - @Override - public void onArticleSelected(Article article) { - Log.d(TAG, "Selected article: " + article.toString()); - + 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(); |