more headlines stuff

This commit is contained in:
Andrew Dolgov 2011-11-23 15:14:41 +03:00
parent e0c40e5fb8
commit fd99cbdd0c
4 changed files with 65 additions and 15 deletions

View File

@ -21,4 +21,12 @@
<item name="android:textStyle">normal</item> <item name="android:textStyle">normal</item>
</style> </style>
<style name="UnreadArticle">
<item name="android:textStyle">bold</item>
</style>
<style name="Article">
<item name="android:textStyle">normal</item>
</style>
</resources> </resources>

View File

@ -7,7 +7,7 @@ import java.util.List;
import android.app.Activity; import android.app.Activity;
import android.app.Fragment; import android.app.Fragment;
import android.app.FragmentManager; import android.app.FragmentTransaction;
import android.content.Context; import android.content.Context;
import android.content.SharedPreferences; import android.content.SharedPreferences;
import android.os.Bundle; import android.os.Bundle;
@ -15,6 +15,7 @@ import android.preference.PreferenceManager;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AdapterView; import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener; import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter; import android.widget.ArrayAdapter;
@ -31,6 +32,7 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
private final String TAG = this.getClass().getSimpleName(); private final String TAG = this.getClass().getSimpleName();
private SharedPreferences m_prefs; private SharedPreferences m_prefs;
private String m_sessionId; private String m_sessionId;
private int m_activeFeedId;
private FeedListAdapter m_adapter; private FeedListAdapter m_adapter;
private List<Feed> m_feeds = new ArrayList<Feed>(); private List<Feed> m_feeds = new ArrayList<Feed>();
@ -39,7 +41,7 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
if (savedInstanceState != null) { if (savedInstanceState != null) {
m_sessionId = savedInstanceState.getString("sessionId"); 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); 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); ListView list = (ListView)view.findViewById(R.id.feeds);
m_adapter = new FeedListAdapter(getActivity(), R.layout.feeds_row, (ArrayList<Feed>)m_feeds); m_adapter = new FeedListAdapter(getActivity(), R.layout.feeds_row, (ArrayList<Feed>)m_feeds);
list.setAdapter(m_adapter); list.setAdapter(m_adapter);
list.setChoiceMode(AbsListView.CHOICE_MODE_SINGLE);
list.setOnItemClickListener(this); list.setOnItemClickListener(this);
return view; return view;
@ -68,21 +71,39 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
super.onSaveInstanceState(out); super.onSaveInstanceState(out);
out.putString("sessionId", m_sessionId); 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 @Override
public void onItemClick(AdapterView<?> av, View view, int position, long id) { public void onItemClick(AdapterView<?> av, View view, int position, long id) {
ListView list = (ListView)av; ListView list = (ListView)av;
if (list != null) { if (list != null) {
Feed feed = (Feed)list.getItemAtPosition(position); Feed feed = (Feed)list.getItemAtPosition(position);
FragmentManager fm = getFragmentManager(); viewFeed(feed.id);
HeadlinesFragment hf = (HeadlinesFragment) fm.findFragmentById(R.id.headlines_fragment);
if (hf != null) {
hf.initialize(m_sessionId, feed.id);
}
} }
} }
@ -213,7 +234,11 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
if (tt != null) { if (tt != null) {
tt.setText(feed.title); 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); TextView tu = (TextView) v.findViewById(R.id.unread_counter);

View File

@ -52,10 +52,21 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
m_adapter = new ArticleListAdapter(getActivity(), R.layout.headlines_row, (ArrayList<Article>)m_articles); m_adapter = new ArticleListAdapter(getActivity(), R.layout.headlines_row, (ArrayList<Article>)m_articles);
list.setAdapter(m_adapter); list.setAdapter(m_adapter);
list.setOnItemClickListener(this); list.setOnItemClickListener(this);
return view; 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 @Override
public void onAttach(Activity activity) { public void onAttach(Activity activity) {
super.onAttach(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_sessionId = sessionId;
m_feedId = feedId; m_feedId = feedId;
m_prefs = prefs;
refresh(); refresh();
} }
@ -128,8 +140,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
m_adapter.notifyDataSetInvalidated(); m_adapter.notifyDataSetInvalidated();
View v = getView().findViewById(R.id.loading_container); showLoading(false);
v.setVisibility(View.GONE);
} }
}); });
} }
@ -193,6 +204,12 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener {
if (tt != null) { if (tt != null) {
tt.setText(article.title); tt.setText(article.title);
//tt.setTextAppearance(getContext(), R.style.Connection); //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); TextView te = (TextView) v.findViewById(R.id.excerpt);

View File

@ -75,7 +75,7 @@ public class MainActivity extends Activity {
ft.commit(); */ ft.commit(); */
FragmentTransaction ft = getFragmentManager().beginTransaction(); 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.hide(getFragmentManager().findFragmentById(R.id.article_fragment));
ft.commit(); ft.commit();