summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--res/values/style.xml8
-rw-r--r--src/org/fox/ttrss/FeedsFragment.java45
-rw-r--r--src/org/fox/ttrss/HeadlinesFragment.java25
-rw-r--r--src/org/fox/ttrss/MainActivity.java2
4 files changed, 65 insertions, 15 deletions
diff --git a/res/values/style.xml b/res/values/style.xml
index ba0bca29..a52af801 100644
--- a/res/values/style.xml
+++ b/res/values/style.xml
@@ -21,4 +21,12 @@
<item name="android:textStyle">normal</item>
</style>
+ <style name="UnreadArticle">
+ <item name="android:textStyle">bold</item>
+ </style>
+
+ <style name="Article">
+ <item name="android:textStyle">normal</item>
+ </style>
+
</resources> \ No newline at end of file
diff --git a/src/org/fox/ttrss/FeedsFragment.java b/src/org/fox/ttrss/FeedsFragment.java
index 56c42de0..b321b48e 100644
--- a/src/org/fox/ttrss/FeedsFragment.java
+++ b/src/org/fox/ttrss/FeedsFragment.java
@@ -7,7 +7,7 @@ import java.util.List;
import android.app.Activity;
import android.app.Fragment;
-import android.app.FragmentManager;
+import android.app.FragmentTransaction;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
@@ -15,6 +15,7 @@ import android.preference.PreferenceManager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
+import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
@@ -31,6 +32,7 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
private final String TAG = this.getClass().getSimpleName();
private SharedPreferences m_prefs;
private String m_sessionId;
+ private int m_activeFeedId;
private FeedListAdapter m_adapter;
private List<Feed> m_feeds = new ArrayList<Feed>();
@@ -39,7 +41,7 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
if (savedInstanceState != null) {
m_sessionId = savedInstanceState.getString("sessionId");
- //m_activeFeedId = savedInstanceState.getInt("activeFeedId");
+ m_activeFeedId = savedInstanceState.getInt("activeFeedId");
}
View view = inflater.inflate(R.layout.feeds_fragment, container, false);
@@ -47,6 +49,7 @@ 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);
return view;
@@ -68,21 +71,39 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
super.onSaveInstanceState(out);
out.putString("sessionId", m_sessionId);
+ out.putInt("activeFeedId", m_activeFeedId);
}
+ public void setActiveFeedId(int feedId) {
+ m_activeFeedId = feedId;
+ }
+
+ public void viewFeed(int feedId) {
+ //FragmentManager fm = getFragmentManager();
+ //HeadlinesFragment hf = (HeadlinesFragment) fm.findFragmentById(R.id.headlines_fragment);
+
+ HeadlinesFragment hf = new HeadlinesFragment();
+ hf.initialize(m_sessionId, feedId, m_prefs);
+
+ if (hf != null) {
+ setActiveFeedId(feedId);
+
+ 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.commit();
+ }
+ }
+
@Override
public void onItemClick(AdapterView<?> av, View view, int position, long id) {
ListView list = (ListView)av;
if (list != null) {
Feed feed = (Feed)list.getItemAtPosition(position);
-
- FragmentManager fm = getFragmentManager();
- HeadlinesFragment hf = (HeadlinesFragment) fm.findFragmentById(R.id.headlines_fragment);
-
- if (hf != null) {
- hf.initialize(m_sessionId, feed.id);
- }
+
+ viewFeed(feed.id);
}
}
@@ -213,7 +234,11 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
if (tt != null) {
tt.setText(feed.title);
- //tt.setTextAppearance(getContext(), R.style.Connection);
+
+ if (feed.id == m_activeFeedId)
+ tt.setTextAppearance(getContext(), R.style.SelectedFeed);
+ else
+ tt.setTextAppearance(getContext(), R.style.Feed);
}
TextView tu = (TextView) v.findViewById(R.id.unread_counter);
diff --git a/src/org/fox/ttrss/HeadlinesFragment.java b/src/org/fox/ttrss/HeadlinesFragment.java
index 6d14d55b..53656517 100644
--- a/src/org/fox/ttrss/HeadlinesFragment.java
+++ b/src/org/fox/ttrss/HeadlinesFragment.java
@@ -52,10 +52,21 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
m_adapter = new ArticleListAdapter(getActivity(), R.layout.headlines_row, (ArrayList<Article>)m_articles);
list.setAdapter(m_adapter);
list.setOnItemClickListener(this);
-
+
return view;
}
+ public void showLoading(boolean show) {
+ View v = getView();
+
+ if (v != null) {
+ v = v.findViewById(R.id.loading_container);
+
+ if (v != null)
+ v.setVisibility(show ? View.VISIBLE : View.GONE);
+ }
+ }
+
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
@@ -68,9 +79,10 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
}
- public void initialize(String sessionId, int feedId) {
+ public void initialize(String sessionId, int feedId, SharedPreferences prefs) {
m_sessionId = sessionId;
m_feedId = feedId;
+ m_prefs = prefs;
refresh();
}
@@ -128,8 +140,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
m_adapter.notifyDataSetInvalidated();
- View v = getView().findViewById(R.id.loading_container);
- v.setVisibility(View.GONE);
+ showLoading(false);
}
});
}
@@ -193,6 +204,12 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
if (tt != null) {
tt.setText(article.title);
//tt.setTextAppearance(getContext(), R.style.Connection);
+
+ if (article.unread)
+ tt.setTextAppearance(getContext(), R.style.UnreadArticle);
+ else
+ tt.setTextAppearance(getContext(), R.style.Article);
+
}
TextView te = (TextView) v.findViewById(R.id.excerpt);
diff --git a/src/org/fox/ttrss/MainActivity.java b/src/org/fox/ttrss/MainActivity.java
index 1606033c..1fa20f7e 100644
--- a/src/org/fox/ttrss/MainActivity.java
+++ b/src/org/fox/ttrss/MainActivity.java
@@ -75,7 +75,7 @@ public class MainActivity extends Activity {
ft.commit(); */
FragmentTransaction ft = getFragmentManager().beginTransaction();
- //ft.hide(getFragmentManager().findFragmentById(R.id.headlines_fragment));
+ ft.hide(getFragmentManager().findFragmentById(R.id.headlines_fragment));
ft.hide(getFragmentManager().findFragmentById(R.id.article_fragment));
ft.commit();