diff --git a/res/menu/main_menu.xml b/res/menu/main_menu.xml index e9b0798c..fb5cb50b 100644 --- a/res/menu/main_menu.xml +++ b/res/menu/main_menu.xml @@ -19,13 +19,13 @@ - + android:title="@string/back_to_categories"/> --> - + - + - + - - + + @@ -80,13 +81,13 @@ 0; } - + return false; } @@ -137,15 +141,15 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } private boolean hasOfflineData() { - Cursor c = getReadableDb().query("articles", + Cursor c = getReadableDb().query("articles", new String[] { "COUNT(*)" }, null, null, null, null, null); if (c.moveToFirst()) { int modified = c.getInt(0); c.close(); - + return modified > 0; } - + return false; } @@ -153,14 +157,14 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public void saveArticleUnread(final Article article) { ApiRequest req = new ApiRequest(getApplicationContext()); - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", String.valueOf(article.id)); put("mode", article.unread ? "1" : "0"); put("field", "2"); - } + } }; req.execute(map); @@ -169,15 +173,15 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @SuppressWarnings({ "unchecked", "serial" }) public void saveArticleMarked(final Article article) { ApiRequest req = new ApiRequest(getApplicationContext()); - - HashMap map = new HashMap() { + + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", String.valueOf(article.id)); put("mode", article.marked ? "1" : "0"); put("field", "0"); - } + } }; req.execute(map); @@ -186,33 +190,33 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @SuppressWarnings({ "unchecked", "serial" }) public void saveArticlePublished(final Article article) { ApiRequest req = new ApiRequest(getApplicationContext()); - - HashMap map = new HashMap() { + + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", String.valueOf(article.id)); put("mode", article.published ? "1" : "0"); put("field", "1"); - } + } }; req.execute(map); } - + public static String articlesToIdString(ArticleList articles) { String tmp = ""; - - for (Article a : articles) + + for (Article a : articles) tmp += String.valueOf(a.id) + ","; - + return tmp.replaceAll(",$", ""); } @SuppressWarnings("unchecked") public void catchupFeed(final Feed feed) { Log.d(TAG, "catchupFeed=" + feed); - + ApiRequest req = new ApiRequest(getApplicationContext()) { protected void onPostExecute(JsonElement result) { if (!m_enableCats || m_activeCategory != null) @@ -220,17 +224,18 @@ public class MainActivity extends FragmentActivity implements OnlineServices { else refreshCategories(); } - + }; - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "catchupFeed"); put("feed_id", String.valueOf(feed.id)); - if (feed.is_cat) put("is_cat", "1"); - } + if (feed.is_cat) + put("is_cat", "1"); + } }; req.execute(map); @@ -239,16 +244,16 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @SuppressWarnings("unchecked") private void toggleArticlesMarked(final ArticleList articles) { ApiRequest req = new ApiRequest(getApplicationContext()); - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", articlesToIdString(articles)); put("mode", "2"); put("field", "0"); - } + } }; req.execute(map); @@ -257,16 +262,16 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @SuppressWarnings("unchecked") private void toggleArticlesUnread(final ArticleList articles) { ApiRequest req = new ApiRequest(getApplicationContext()); - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", articlesToIdString(articles)); put("mode", "2"); put("field", "2"); - } + } }; req.execute(map); @@ -275,16 +280,16 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @SuppressWarnings("unchecked") private void toggleArticlesPublished(final ArticleList articles) { ApiRequest req = new ApiRequest(getApplicationContext()); - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", articlesToIdString(articles)); put("mode", "2"); put("field", "1"); - } + } }; req.execute(map); @@ -294,12 +299,14 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @Override public void run() { - ConnectivityManager cm = (ConnectivityManager) getApplicationContext().getSystemService(Context.CONNECTIVITY_SERVICE); - + ConnectivityManager cm = (ConnectivityManager) getApplicationContext() + .getSystemService(Context.CONNECTIVITY_SERVICE); + if (cm.getBackgroundDataSetting()) { NetworkInfo networkInfo = cm.getActiveNetworkInfo(); - if (networkInfo != null && networkInfo.isAvailable() && networkInfo.isConnected()) { - + if (networkInfo != null && networkInfo.isAvailable() + && networkInfo.isConnected()) { + if (!m_enableCats || m_activeCategory != null) refreshFeeds(); else @@ -308,13 +315,14 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } } } - + public synchronized void refreshFeeds() { if (m_sessionId != null) { - FeedsFragment frag = (FeedsFragment) getSupportFragmentManager().findFragmentById(R.id.feeds_fragment); - + FeedsFragment frag = (FeedsFragment) getSupportFragmentManager() + .findFragmentById(R.id.feeds_fragment); + Log.d(TAG, "Refreshing feeds..."); - + if (frag != null) { frag.refresh(true); } @@ -323,10 +331,11 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public synchronized void refreshHeadlines() { if (m_sessionId != null) { - HeadlinesFragment frag = (HeadlinesFragment) getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - + HeadlinesFragment frag = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + Log.d(TAG, "Refreshing headlines..."); - + if (frag != null) { frag.refresh(true); } @@ -335,10 +344,11 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public synchronized void refreshCategories() { if (m_sessionId != null) { - FeedCategoriesFragment frag = (FeedCategoriesFragment) getSupportFragmentManager().findFragmentById(R.id.cats_fragment); - + FeedCategoriesFragment frag = (FeedCategoriesFragment) getSupportFragmentManager() + .findFragmentById(R.id.cats_fragment); + Log.d(TAG, "Refreshing categories..."); - + if (frag != null) { frag.refresh(true); } @@ -347,26 +357,29 @@ public class MainActivity extends FragmentActivity implements OnlineServices { private void setUnreadOnly(boolean unread) { m_unreadOnly = unread; - - if (!m_enableCats || m_activeCategory != null ) + + if (!m_enableCats || m_activeCategory != null) refreshFeeds(); else refreshCategories(); } - + @Override public boolean getUnreadOnly() { return m_unreadOnly; } - /* private void setUnreadArticlesOnly(boolean unread) { - m_unreadArticlesOnly = unread; - - HeadlinesFragment frag = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - - if (frag != null) frag.refresh(false); - } */ - + /* + * private void setUnreadArticlesOnly(boolean unread) { m_unreadArticlesOnly + * = unread; + * + * HeadlinesFragment frag = + * (HeadlinesFragment)getSupportFragmentManager().findFragmentById + * (R.id.headlines_fragment); + * + * if (frag != null) frag.refresh(false); } + */ + @Override public boolean getUnreadArticlesOnly() { return m_unreadArticlesOnly; @@ -381,13 +394,14 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public boolean isSmallScreen() { return m_smallScreenMode; } - + @Override public void onCreate(Bundle savedInstanceState) { - m_prefs = PreferenceManager.getDefaultSharedPreferences(getApplicationContext()); + m_prefs = PreferenceManager + .getDefaultSharedPreferences(getApplicationContext()); m_compatMode = android.os.Build.VERSION.SDK_INT <= 10; - + if (m_prefs.getString("theme", "THEME_DARK").equals("THEME_DARK")) { setTheme(R.style.DarkTheme); } else { @@ -397,56 +411,65 @@ public class MainActivity extends FragmentActivity implements OnlineServices { super.onCreate(savedInstanceState); m_themeName = m_prefs.getString("theme", "THEME_DARK"); - + if (savedInstanceState != null) { m_sessionId = savedInstanceState.getString("sessionId"); m_unreadOnly = savedInstanceState.getBoolean("unreadOnly"); m_activeFeed = savedInstanceState.getParcelable("activeFeed"); - m_selectedArticle = savedInstanceState.getParcelable("selectedArticle"); - m_unreadArticlesOnly = savedInstanceState.getBoolean("unreadArticlesOnly"); - m_activeCategory = savedInstanceState.getParcelable("activeCategory"); + m_selectedArticle = savedInstanceState + .getParcelable("selectedArticle"); + m_unreadArticlesOnly = savedInstanceState + .getBoolean("unreadArticlesOnly"); + m_activeCategory = savedInstanceState + .getParcelable("activeCategory"); m_apiLevel = savedInstanceState.getInt("apiLevel"); m_isLicensed = savedInstanceState.getInt("isLicensed"); } - + m_enableCats = m_prefs.getBoolean("enable_cats", false); - + Display display = getWindowManager().getDefaultDisplay(); - + int width = display.getWidth(); int height = display.getHeight(); - - if (height > width) { int tmp = height; width = tmp; height = width; } - - m_smallScreenMode = width < 960 || height < 720; - + + if (height > width) { + int tmp = height; + width = tmp; + height = width; + } + + m_smallScreenMode = width < 960 || height < 720; + setContentView(R.layout.main); initDatabase(); - - IntentFilter filter = new IntentFilter("org.fox.ttrss.intent.action.DownloadComplete"); + + IntentFilter filter = new IntentFilter( + "org.fox.ttrss.intent.action.DownloadComplete"); filter.addCategory(Intent.CATEGORY_DEFAULT); - + registerReceiver(m_broadcastReceiver, filter); - + m_isOffline = m_prefs.getBoolean("offline_mode_active", false); - + Log.d(TAG, "m_isOffline=" + m_isOffline); Log.d(TAG, "m_smallScreenMode=" + m_smallScreenMode); Log.d(TAG, "m_compatMode=" + m_compatMode); - if (!m_compatMode) { - new TransitionHelper((LinearLayout)findViewById(R.id.main)); + new TransitionHelper((LinearLayout) findViewById(R.id.main)); } if (m_isOffline) { - Intent offline = new Intent(MainActivity.this, OfflineActivity.class); + Intent offline = new Intent(MainActivity.this, + OfflineActivity.class); startActivity(offline); finish(); } else { - List pkgs = getPackageManager().getInstalledPackages(0); - + List pkgs = getPackageManager() + .getInstalledPackages(0); + for (PackageInfo p : pkgs) { if ("org.fox.ttrss.key".equals(p.packageName)) { m_isLicensed = 1; @@ -454,81 +477,62 @@ public class MainActivity extends FragmentActivity implements OnlineServices { break; } } - - if (!m_compatMode && !m_smallScreenMode) { - - m_bar = getActionBar(); - - m_bar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS); - m_bar.setDisplayOptions(0, ActionBar.DISPLAY_SHOW_TITLE); - //m_bar.setDisplayHomeAsUpEnabled(true); TODO - - if (m_enableCats && !m_prefs.getBoolean("browse_cats_like_feeds", false)) { - m_rootTab = m_bar.newTab().setText("Categories").setTabListener(new RootTabListener()); - m_bar.addTab(m_rootTab); - if (m_activeCategory != null) { - m_catTab = m_bar.newTab().setText(m_activeCategory.title).setTabListener(new CategoryTabListener(m_activeCategory)); - m_bar.addTab(m_catTab); - m_bar.selectTab(m_catTab); - } - } else if (m_enableCats) { - m_rootTab = m_bar.newTab().setText("Categories").setTabListener(new RootTabListener()); - m_bar.addTab(m_rootTab); - } else { - m_rootTab = m_bar.newTab().setText("Feeds").setTabListener(new RootTabListener()); - m_bar.addTab(m_rootTab); - - if (m_activeFeed != null && m_selectedArticle != null) { - m_feedTab = m_bar.newTab().setText(m_activeFeed.title).setTabListener(new FeedTabListener(m_activeFeed, m_selectedArticle)); - m_bar.addTab(m_feedTab); - m_bar.selectTab(m_feedTab); - } - } + if (!m_compatMode && !m_smallScreenMode) { + // getActionBar().setDisplayHomeAsUpEnabled(true); TODO } - + if (m_smallScreenMode) { if (m_selectedArticle != null) { findViewById(R.id.feeds_fragment).setVisibility(View.GONE); findViewById(R.id.cats_fragment).setVisibility(View.GONE); - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); + findViewById(R.id.headlines_fragment).setVisibility( + View.GONE); } else if (m_activeFeed != null) { findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.article_fragment).setVisibility(View.GONE); + findViewById(R.id.article_fragment) + .setVisibility(View.GONE); findViewById(R.id.cats_fragment).setVisibility(View.GONE); } else { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - //findViewById(R.id.article_fragment).setVisibility(View.GONE); - + findViewById(R.id.headlines_fragment).setVisibility( + View.GONE); + // findViewById(R.id.article_fragment).setVisibility(View.GONE); + if (m_enableCats && m_activeCategory == null) { - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); + findViewById(R.id.feeds_fragment).setVisibility( + View.GONE); + findViewById(R.id.cats_fragment).setVisibility( + View.VISIBLE); } else { - findViewById(R.id.cats_fragment).setVisibility(View.GONE); + findViewById(R.id.cats_fragment).setVisibility( + View.GONE); } } } else { if (m_selectedArticle == null) { - findViewById(R.id.article_fragment).setVisibility(View.GONE); - + findViewById(R.id.article_fragment) + .setVisibility(View.GONE); + if (!m_enableCats || m_activeCategory != null) - findViewById(R.id.cats_fragment).setVisibility(View.GONE); + findViewById(R.id.cats_fragment).setVisibility( + View.GONE); else - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - + findViewById(R.id.feeds_fragment).setVisibility( + View.GONE); + } else { findViewById(R.id.feeds_fragment).setVisibility(View.GONE); findViewById(R.id.cats_fragment).setVisibility(View.GONE); } } - + if (m_sessionId != null) { loginSuccess(); } else { login(); } } - + } private void initDatabase() { @@ -536,91 +540,103 @@ public class MainActivity extends FragmentActivity implements OnlineServices { m_writableDb = dh.getWritableDatabase(); m_readableDb = dh.getReadableDatabase(); } - + public synchronized SQLiteDatabase getReadableDb() { return m_readableDb; } - + public synchronized SQLiteDatabase getWritableDb() { return m_writableDb; } - + @SuppressWarnings("unchecked") private void switchOffline() { - - AlertDialog.Builder builder = new AlertDialog.Builder(this). - setMessage(R.string.dialog_offline_switch_prompt). - setPositiveButton(R.string.dialog_offline_go, new Dialog.OnClickListener() { - public void onClick(DialogInterface dialog, int which) { - - if (m_sessionId != null) { - Log.d(TAG, "offline: starting"); - ServiceConnection m_serviceConnection = new ServiceConnection() { - - @Override - public void onServiceDisconnected(ComponentName name) { - Log.d(TAG, "download service disconnected"); + AlertDialog.Builder builder = new AlertDialog.Builder(this) + .setMessage(R.string.dialog_offline_switch_prompt) + .setPositiveButton(R.string.dialog_offline_go, + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + + if (m_sessionId != null) { + Log.d(TAG, "offline: starting"); + + ServiceConnection m_serviceConnection = new ServiceConnection() { + + @Override + public void onServiceDisconnected( + ComponentName name) { + Log.d(TAG, + "download service disconnected"); + } + + @Override + public void onServiceConnected( + ComponentName name, + IBinder service) { + Log.d(TAG, + "download service connected"); + // ((OfflineDownloadService.LocalBinder)service).getService().download(); + } + }; + + Intent intent = new Intent( + MainActivity.this, + OfflineDownloadService.class); + intent.putExtra("sessionId", m_sessionId); + + startService(intent); + + // bindService(intent, m_serviceConnection, + // Context.BIND_AUTO_CREATE); + + } } - - @Override - public void onServiceConnected(ComponentName name, IBinder service) { - Log.d(TAG, "download service connected"); - //((OfflineDownloadService.LocalBinder)service).getService().download(); + }) + .setNegativeButton(R.string.dialog_cancel, + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + // } - }; - - Intent intent = new Intent(MainActivity.this, OfflineDownloadService.class); - intent.putExtra("sessionId", m_sessionId); - - startService(intent); - - //bindService(intent, m_serviceConnection, Context.BIND_AUTO_CREATE); - - } - } - }). - setNegativeButton(R.string.dialog_cancel, new Dialog.OnClickListener() { - public void onClick(DialogInterface dialog, int which) { - // - } - }); - + }); + AlertDialog dlg = builder.create(); dlg.show(); } - + private void switchOfflineSuccess() { logout(); - //setLoadingStatus(R.string.blank, false); + // setLoadingStatus(R.string.blank, false); SharedPreferences.Editor editor = m_prefs.edit(); editor.putBoolean("offline_mode_active", true); editor.commit(); - + Intent offline = new Intent(MainActivity.this, OfflineActivity.class); startActivity(offline); finish(); - + } - + private void setLoadingStatus(int status, boolean showProgress) { - TextView tv = (TextView)findViewById(R.id.loading_message); - + TextView tv = (TextView) findViewById(R.id.loading_message); + if (tv != null) { tv.setText(status); } - + View pb = findViewById(R.id.loading_progress); - + if (pb != null) { pb.setVisibility(showProgress ? View.VISIBLE : View.GONE); } } - + @Override - public void onSaveInstanceState (Bundle out) { + public void onSaveInstanceState(Bundle out) { super.onSaveInstanceState(out); out.putString("sessionId", m_sessionId); @@ -637,9 +653,10 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public void onResume() { super.onResume(); - boolean needRefresh = !m_prefs.getString("theme", "THEME_DARK").equals(m_themeName) || - m_prefs.getBoolean("enable_cats", false) != m_enableCats; - + boolean needRefresh = !m_prefs.getString("theme", "THEME_DARK").equals( + m_themeName) + || m_prefs.getBoolean("enable_cats", false) != m_enableCats; + if (needRefresh) { Intent refresh = new Intent(MainActivity.this, MainActivity.class); startActivity(refresh); @@ -647,8 +664,8 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } else if (m_sessionId != null) { m_refreshTask = new RefreshTask(); m_refreshTimer = new Timer("Refresh"); - - m_refreshTimer.schedule(m_refreshTask, 60*1000L, 120*1000L); + + m_refreshTimer.schedule(m_refreshTask, 60 * 1000L, 120 * 1000L); } } @@ -656,165 +673,117 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public boolean onCreateOptionsMenu(Menu menu) { MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.main_menu, menu); - + m_menu = menu; - + initMainMenu(); - + MenuItem item = menu.findItem(R.id.show_feeds); - + if (getUnreadOnly()) { item.setTitle(R.string.menu_all_feeds); } else { item.setTitle(R.string.menu_unread_feeds); } - /* item = menu.findItem(R.id.show_all_articles); - - if (getUnreadArticlesOnly()) { - item.setTitle(R.string.show_all_articles); - } else { - item.setTitle(R.string.show_unread_articles); - } */ + /* + * item = menu.findItem(R.id.show_all_articles); + * + * if (getUnreadArticlesOnly()) { + * item.setTitle(R.string.show_all_articles); } else { + * item.setTitle(R.string.show_unread_articles); } + */ return true; } private void setMenuLabel(int id, int labelId) { MenuItem mi = m_menu.findItem(id); - + if (mi != null) { mi.setTitle(labelId); } } - + @Override public void onBackPressed() { - if (m_smallScreenMode) { - if (m_selectedArticle != null) { - closeArticle(); - } else if (m_activeFeed != null) { - if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); - } - - if (m_activeFeed != null && m_activeFeed.is_cat) { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - - refreshCategories(); - } else { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); + if (m_smallScreenMode) { + if (m_selectedArticle != null) { + closeArticle(); + } else if (m_activeFeed != null) { + if (m_compatMode) { + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, + R.anim.slide_right)); + } - refreshFeeds(); - } + if (m_activeFeed != null && m_activeFeed.is_cat) { + findViewById(R.id.headlines_fragment).setVisibility( + View.GONE); + findViewById(R.id.cats_fragment) + .setVisibility(View.VISIBLE); + + refreshCategories(); + } else { + findViewById(R.id.headlines_fragment).setVisibility( + View.GONE); + findViewById(R.id.feeds_fragment).setVisibility( + View.VISIBLE); + + refreshFeeds(); + } m_activeFeed = null; - - - initMainMenu(); - } else if (m_activeCategory != null) { - if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); - } + initMainMenu(); - closeCategory(); - - } else { - finish(); - } - } else { - if (m_selectedArticle != null) { - closeArticle(); - } else if (m_activeCategory != null) { - closeCategory(); - } else { - finish(); - } - } + } else if (m_activeCategory != null) { + if (m_compatMode) { + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, + R.anim.slide_right)); + } + + closeCategory(); + + } else { + finish(); + } + } else { + if (m_selectedArticle != null) { + closeArticle(); + } else if (m_activeCategory != null) { + closeCategory(); + } else { + finish(); + } + } } - - /* @Override - public boolean onKeyDown(int keyCode, KeyEvent event) { - if (keyCode == KeyEvent.KEYCODE_BACK) { - - if (m_smallScreenMode) { - if (m_selectedArticle != null) { - closeArticle(); - } else if (m_activeFeed != null) { - if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); - } - - if (m_activeFeed != null && m_activeFeed.is_cat) { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - - refreshCategories(); - } else { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); - refreshFeeds(); - } - m_activeFeed = null; - - - initMainMenu(); - - } else if (m_activeCategory != null) { - if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); - } - - closeCategory(); - - } else { - finish(); - } - } else { - if (m_selectedArticle != null) { - closeArticle(); - } else if (m_activeCategory != null) { - closeCategory(); - } else { - finish(); - } - } - - return false; - } - return super.onKeyDown(keyCode, event); - } */ - private void closeCategory() { - if (m_bar != null && m_catTab != null) { - m_bar.selectTab(m_rootTab); - } else { - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - - m_activeCategory = null; - - initMainMenu(); - refreshCategories(); - } + findViewById(R.id.feeds_fragment).setVisibility(View.GONE); + findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); + + m_activeCategory = null; + + initMainMenu(); + refreshCategories(); } @SuppressWarnings("unchecked") @Override public boolean onOptionsItemSelected(MenuItem item) { - final HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + final HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); switch (item.getItemId()) { case R.id.preferences: - Intent intent = new Intent(MainActivity.this, PreferencesActivity.class); + Intent intent = new Intent(MainActivity.this, + PreferencesActivity.class); startActivityForResult(intent, 0); return true; case R.id.update_feeds: - if (!m_enableCats || m_activeCategory != null ) + if (!m_enableCats || m_activeCategory != null) refreshFeeds(); else refreshCategories(); @@ -831,34 +800,39 @@ public class MainActivity extends FragmentActivity implements OnlineServices { case R.id.close_article: closeArticle(); return true; - /* case R.id.back_to_categories: - closeCategory(); - return true; */ + /* + * case R.id.back_to_categories: closeCategory(); return true; + */ case R.id.headlines_select: if (hf != null) { Dialog dialog = new Dialog(this); AlertDialog.Builder builder = new AlertDialog.Builder(this) - .setTitle(R.string.headlines_select_dialog) - .setSingleChoiceItems(new String[] { getString(R.string.headlines_select_all), - getString(R.string.headlines_select_unread), getString(R.string.headlines_select_none) }, 0, new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int which) { - switch (which) { - case 0: - hf.setSelection(HeadlinesFragment.ArticlesSelection.ALL); - break; - case 1: - hf.setSelection(HeadlinesFragment.ArticlesSelection.UNREAD); - break; - case 2: - hf.setSelection(HeadlinesFragment.ArticlesSelection.NONE); - break; - } - dialog.cancel(); - initMainMenu(); - } - }); - + .setTitle(R.string.headlines_select_dialog) + .setSingleChoiceItems( + new String[] { + getString(R.string.headlines_select_all), + getString(R.string.headlines_select_unread), + getString(R.string.headlines_select_none) }, + 0, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, + int which) { + switch (which) { + case 0: + hf.setSelection(HeadlinesFragment.ArticlesSelection.ALL); + break; + case 1: + hf.setSelection(HeadlinesFragment.ArticlesSelection.UNREAD); + break; + case 2: + hf.setSelection(HeadlinesFragment.ArticlesSelection.NONE); + break; + } + dialog.cancel(); + initMainMenu(); + } + }); + dialog = builder.create(); dialog.show(); } @@ -866,25 +840,25 @@ public class MainActivity extends FragmentActivity implements OnlineServices { case R.id.headlines_mark_as_read: if (hf != null) { ArticleList articles = hf.getUnreadArticles(); - + for (Article a : articles) a.unread = false; - + hf.notifyUpdated(); - + ApiRequest req = new ApiRequest(getApplicationContext()); final String articleIds = articlesToIdString(articles); @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", articleIds); put("mode", "0"); put("field", "2"); - } + } }; req.execute(map); @@ -901,7 +875,7 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } return true; case R.id.selection_select_none: - if (hf != null) { + if (hf != null) { ArticleList selected = hf.getSelectedArticles(); if (selected.size() > 0) { selected.clear(); @@ -911,13 +885,13 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } return true; case R.id.selection_toggle_unread: - if (hf != null) { + if (hf != null) { ArticleList selected = hf.getSelectedArticles(); - - if (selected.size() > 0) { + + if (selected.size() > 0) { for (Article a : selected) a.unread = !a.unread; - + toggleArticlesUnread(selected); hf.notifyUpdated(); } @@ -926,11 +900,11 @@ public class MainActivity extends FragmentActivity implements OnlineServices { case R.id.selection_toggle_marked: if (hf != null) { ArticleList selected = hf.getSelectedArticles(); - + if (selected.size() > 0) { for (Article a : selected) a.marked = !a.marked; - + toggleArticlesMarked(selected); hf.notifyUpdated(); } @@ -939,7 +913,7 @@ public class MainActivity extends FragmentActivity implements OnlineServices { case R.id.selection_toggle_published: if (hf != null) { ArticleList selected = hf.getSelectedArticles(); - + if (selected.size() > 0) { for (Article a : selected) a.published = !a.published; @@ -989,20 +963,21 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } else { item.setTitle(R.string.menu_unread_feeds); } - + return true; - /* case R.id.show_all_articles: - setUnreadArticlesOnly(!getUnreadArticlesOnly()); - - if (getUnreadArticlesOnly()) { - item.setTitle(R.string.show_all_articles); - } else { - item.setTitle(R.string.show_unread_articles); - } - - return true; */ + /* + * case R.id.show_all_articles: + * setUnreadArticlesOnly(!getUnreadArticlesOnly()); + * + * if (getUnreadArticlesOnly()) { + * item.setTitle(R.string.show_all_articles); } else { + * item.setTitle(R.string.show_unread_articles); } + * + * return true; + */ default: - Log.d(TAG, "onOptionsItemSelected, unhandled id=" + item.getItemId()); + Log.d(TAG, + "onOptionsItemSelected, unhandled id=" + item.getItemId()); return super.onOptionsItemSelected(item); } } @@ -1010,33 +985,38 @@ public class MainActivity extends FragmentActivity implements OnlineServices { private void shareArticle(Article article) { if (article != null) { Intent intent = new Intent(Intent.ACTION_SEND); - + intent.setType("text/plain"); intent.putExtra(Intent.EXTRA_SUBJECT, article.title); intent.putExtra(Intent.EXTRA_TEXT, article.link); - startActivity(Intent.createChooser(intent, getString(R.id.share_article))); + startActivity(Intent.createChooser(intent, + getString(R.id.share_article))); } } - + private void closeArticle() { if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, R.anim.slide_right)); } - //boolean browseCats = m_prefs.getBoolean("browse_cats_like_feeds", false); - + // boolean browseCats = m_prefs.getBoolean("browse_cats_like_feeds", + // false); + if (m_smallScreenMode) { - findViewById(R.id.article_fragment).setVisibility(View.GONE); - findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); + findViewById(R.id.article_fragment).setVisibility(View.GONE); + findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); } else { - findViewById(R.id.article_fragment).setVisibility(View.GONE); - + findViewById(R.id.article_fragment).setVisibility(View.GONE); + if (m_activeFeed != null) { if (m_activeFeed.is_cat) { - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); + findViewById(R.id.cats_fragment) + .setVisibility(View.VISIBLE); } else { - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); + findViewById(R.id.feeds_fragment).setVisibility( + View.VISIBLE); } } } @@ -1051,110 +1031,74 @@ public class MainActivity extends FragmentActivity implements OnlineServices { @Override public void initMainMenu() { if (m_menu != null) { + + m_menu.setGroupVisible(R.id.menu_group_feeds, false); + m_menu.setGroupVisible(R.id.menu_group_headlines, false); + m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); + m_menu.setGroupVisible(R.id.menu_group_article, false); + if (m_sessionId != null) { - HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - int numSelected = 0; - - if (hf != null) - numSelected = hf.getSelectedArticles().size(); - m_menu.setGroupVisible(R.id.menu_group_logged_in, true); m_menu.setGroupVisible(R.id.menu_group_logged_out, false); - if (m_activeFeed == null) { - m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - } - - if (m_selectedArticle != null && numSelected == 0) { + HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + + int numSelected = 0; + + if (hf != null) + numSelected = hf.getSelectedArticles().size(); + + if (numSelected != 0) { + m_menu.setGroupVisible(R.id.menu_group_headlines_selection, true); + } else if (m_selectedArticle != null) { m_menu.setGroupVisible(R.id.menu_group_article, true); - - m_menu.setGroupVisible(R.id.menu_group_feeds, false); - - //if (m_smallScreenMode) { - m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - //} else { - // m_menu.setGroupVisible(R.id.menu_group_headlines, true); - //} - + } else if (m_activeFeed != null || m_activeCategory != null) { + m_menu.setGroupVisible(R.id.menu_group_headlines, true); } else { - m_menu.setGroupVisible(R.id.menu_group_article, false); - - if (m_activeFeed != null) { - - if (numSelected != 0) { - m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, true); - } else { - m_menu.setGroupVisible(R.id.menu_group_headlines, true); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - } - - m_menu.setGroupVisible(R.id.menu_group_feeds, false); - } else { - m_menu.setGroupVisible(R.id.menu_group_feeds, true); - } - - /* if (!m_smallScreenMode || m_activeFeed == null) { - m_menu.findItem(R.id.show_feeds).setVisible(true); - m_menu.findItem(R.id.update_feeds).setVisible(true); - } */ - - //m_menu.findItem(R.id.back_to_categories).setVisible(m_activeCategory != null); + m_menu.setGroupVisible(R.id.menu_group_feeds, true); } } else { m_menu.setGroupVisible(R.id.menu_group_logged_in, false); - m_menu.setGroupVisible(R.id.menu_group_feeds, false); - m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_article, false); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - - /* if (m_isOffline) { - m_menu.setGroupVisible(R.id.menu_group_logged_out, false); - m_menu.findItem(R.id.go_online).setVisible(true); - - } else { */ - m_menu.setGroupVisible(R.id.menu_group_logged_out, true); - //} + m_menu.setGroupVisible(R.id.menu_group_logged_out, true); } - } + } } - + @Override public void onPause() { super.onPause(); - + if (m_refreshTask != null) { m_refreshTask.cancel(); m_refreshTask = null; } - + if (m_refreshTimer != null) { m_refreshTimer.cancel(); m_refreshTimer = null; } } - + @Override public void onDestroy() { super.onDestroy(); - + unregisterReceiver(m_broadcastReceiver); - + m_readableDb.close(); m_writableDb.close(); - + } private void syncOfflineRead() { Log.d(TAG, "syncing modified offline data... (read)"); final String ids = getOfflineModifiedIds(ModifiedCriteria.READ); - + if (ids.length() > 0) { ApiRequest req = new ApiRequest(getApplicationContext()) { @Override @@ -1166,16 +1110,16 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } } }; - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", ids); put("mode", "0"); put("field", "2"); - } + } }; req.execute(map); @@ -1188,7 +1132,7 @@ public class MainActivity extends FragmentActivity implements OnlineServices { Log.d(TAG, "syncing modified offline data... (marked)"); final String ids = getOfflineModifiedIds(ModifiedCriteria.MARKED); - + if (ids.length() > 0) { ApiRequest req = new ApiRequest(getApplicationContext()) { @Override @@ -1200,16 +1144,16 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } } }; - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", ids); put("mode", "0"); put("field", "0"); - } + } }; req.execute(map); @@ -1222,7 +1166,7 @@ public class MainActivity extends FragmentActivity implements OnlineServices { Log.d(TAG, "syncing modified offline data... (published)"); final String ids = getOfflineModifiedIds(ModifiedCriteria.MARKED); - + if (ids.length() > 0) { ApiRequest req = new ApiRequest(getApplicationContext()) { @Override @@ -1236,16 +1180,16 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } } }; - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "updateArticle"); put("article_ids", ids); put("mode", "0"); put("field", "1"); - } + } }; req.execute(map); @@ -1260,15 +1204,15 @@ public class MainActivity extends FragmentActivity implements OnlineServices { setLoadingStatus(R.string.syncing_offline_data, true); syncOfflineRead(); } - + private void loginSuccessInitUI() { FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - + if (m_enableCats) { FeedCategoriesFragment frag = new FeedCategoriesFragment(); ft.replace(R.id.cats_fragment, frag); } else { - FeedsFragment frag = new FeedsFragment(); + FeedsFragment frag = new FeedsFragment(); ft.replace(R.id.feeds_fragment, frag); } @@ -1278,37 +1222,39 @@ public class MainActivity extends FragmentActivity implements OnlineServices { e.printStackTrace(); } } - + private void loginSuccess() { findViewById(R.id.loading_container).setVisibility(View.INVISIBLE); findViewById(R.id.main).setVisibility(View.VISIBLE); m_isOffline = false; - + 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, 120*1000L); + + m_refreshTimer.schedule(m_refreshTask, 60 * 1000L, 120 * 1000L); } - - private enum ModifiedCriteria { READ, MARKED, PUBLISHED }; - + + private enum ModifiedCriteria { + READ, MARKED, PUBLISHED + }; + private String getOfflineModifiedIds(ModifiedCriteria criteria) { - + String criteriaStr = ""; - + switch (criteria) { case READ: criteriaStr = "unread = 0"; @@ -1320,55 +1266,56 @@ public class MainActivity extends FragmentActivity implements OnlineServices { criteriaStr = "published = 1"; break; } - - Cursor c = getReadableDb().query("articles", - null, "modified = 1 AND " + criteriaStr, null, null, null, null); + + Cursor c = getReadableDb().query("articles", null, + "modified = 1 AND " + criteriaStr, null, null, null, null); String tmp = ""; - + while (c.moveToNext()) { tmp += c.getInt(0) + ","; } tmp = tmp.replaceAll(",$", ""); - - //Log.d(TAG, "getOfflineModifiedIds " + criteria + " = " + tmp); - + + // Log.d(TAG, "getOfflineModifiedIds " + criteria + " = " + tmp); + c.close(); - + return tmp; } - + private class LoginRequest extends ApiRequest { public LoginRequest(Context context) { super(context); } - + @SuppressWarnings("unchecked") protected void onPostExecute(JsonElement result) { if (result != null) { - try { + try { JsonObject content = result.getAsJsonObject(); if (content != null) { m_sessionId = content.get("session_id").getAsString(); - + Log.d(TAG, "Authenticated!"); - + ApiRequest req = new ApiRequest(m_context) { protected void onPostExecute(JsonElement result) { if (result != null) { - m_apiLevel = result.getAsJsonObject().get("level").getAsInt(); + m_apiLevel = result.getAsJsonObject() + .get("level").getAsInt(); } else { m_apiLevel = 0; } - + Log.d(TAG, "Received API level: " + m_apiLevel); - + if (hasPendingOfflineData()) { syncOfflineData(); - - //loginSuccess(); + + // loginSuccess(); } else { loginSuccessInitUI(); loginSuccess(); @@ -1376,51 +1323,56 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } }; - + @SuppressWarnings("serial") - HashMap map = new HashMap() { + HashMap map = new HashMap() { { put("sid", m_sessionId); put("op", "getApiLevel"); - } + } }; req.execute(map); - + setLoadingStatus(R.string.loading_message, true); - + return; } - + } catch (Exception e) { - e.printStackTrace(); + e.printStackTrace(); } } - + m_sessionId = null; setLoadingStatus(getErrorMessage(), false); - + if (hasOfflineData()) { - - AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this). - setMessage(R.string.dialog_offline_prompt). - setPositiveButton(R.string.dialog_offline_go, new Dialog.OnClickListener() { - public void onClick(DialogInterface dialog, int which) { - switchOfflineSuccess(); - } - }). - setNegativeButton(R.string.dialog_cancel, new Dialog.OnClickListener() { - public void onClick(DialogInterface dialog, int which) { - // - } - }); - + + AlertDialog.Builder builder = new AlertDialog.Builder( + MainActivity.this) + .setMessage(R.string.dialog_offline_prompt) + .setPositiveButton(R.string.dialog_offline_go, + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + switchOfflineSuccess(); + } + }) + .setNegativeButton(R.string.dialog_cancel, + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + // + } + }); + AlertDialog dlg = builder.create(); dlg.show(); - } - - //m_menu.findItem(R.id.login).setVisible(true); + } + + // m_menu.findItem(R.id.login).setVisible(true); } } @@ -1433,25 +1385,27 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public Article getSelectedArticle() { return m_selectedArticle; } - + public void viewFeed(Feed feed, boolean append) { m_activeFeed = feed; - + initMainMenu(); - + if (m_smallScreenMode) { findViewById(R.id.feeds_fragment).setVisibility(View.GONE); findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); } - + if (!append) { HeadlinesFragment hf = new HeadlinesFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); + + FragmentTransaction ft = getSupportFragmentManager() + .beginTransaction(); ft.replace(R.id.headlines_fragment, hf); ft.commit(); } else { - HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); if (hf != null) { hf.refresh(true); } @@ -1459,95 +1413,82 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } public void viewCategory(FeedCategory cat, boolean openAsFeed) { - - Log.d(TAG, "viewCategory"); - - if (!openAsFeed) { - if (m_bar != null) { - if (m_catTab != null) m_bar.removeTab(m_catTab); - - m_catTab = m_bar.newTab().setText(cat.title).setTabListener(new CategoryTabListener(cat)); - m_bar.addTab(m_catTab); - m_bar.selectTab(m_catTab); - } else { - findViewById(R.id.cats_fragment).setVisibility(View.GONE); - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); - m_activeCategory = cat; - - FeedsFragment frag = new FeedsFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - ft.replace(R.id.feeds_fragment, frag); - ft.commit(); - } + Log.d(TAG, "viewCategory"); + + if (!openAsFeed) { + findViewById(R.id.cats_fragment).setVisibility(View.GONE); + findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); + + m_activeCategory = cat; + + FeedsFragment frag = new FeedsFragment(); + + FragmentTransaction ft = getSupportFragmentManager() + .beginTransaction(); + ft.replace(R.id.feeds_fragment, frag); + ft.commit(); } else { - if (m_smallScreenMode) findViewById(R.id.cats_fragment).setVisibility(View.GONE); + if (m_smallScreenMode) + findViewById(R.id.cats_fragment).setVisibility(View.GONE); findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); m_activeFeed = new Feed(cat.id, cat.title, true); - + HeadlinesFragment frag = new HeadlinesFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); + + FragmentTransaction ft = getSupportFragmentManager() + .beginTransaction(); ft.replace(R.id.headlines_fragment, frag); ft.commit(); - + } - + initMainMenu(); } public void openArticle(Article article, int compatAnimation) { m_selectedArticle = article; - + if (article.unread) { article.unread = false; saveArticleUnread(article); } - + initMainMenu(); - HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - + HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + if (hf != null) { hf.setActiveArticleId(article.id); } - - - if (m_bar != null) { - if (m_feedTab != null) m_bar.removeTab(m_feedTab); - - m_feedTab = m_bar.newTab().setText(m_activeFeed.title).setTabListener(new FeedTabListener(m_activeFeed, m_selectedArticle)); - m_bar.addTab(m_feedTab); - m_bar.selectTab(m_feedTab); - } else { - if (m_smallScreenMode) { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.article_fragment).setVisibility(View.VISIBLE); - } else { - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.GONE); - findViewById(R.id.article_fragment).setVisibility(View.VISIBLE); - } - ArticleFragment frag = new ArticleFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - ft.replace(R.id.article_fragment, frag); - ft.commit(); + if (m_smallScreenMode) { + findViewById(R.id.headlines_fragment).setVisibility(View.GONE); + findViewById(R.id.article_fragment).setVisibility(View.VISIBLE); + } else { + findViewById(R.id.feeds_fragment).setVisibility(View.GONE); + findViewById(R.id.cats_fragment).setVisibility(View.GONE); + findViewById(R.id.article_fragment).setVisibility(View.VISIBLE); } + ArticleFragment frag = new ArticleFragment(); + + FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); + ft.replace(R.id.article_fragment, frag); + ft.commit(); + if (m_compatMode) { if (compatAnimation == 0) - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_left)); + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, R.anim.slide_left)); else - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, compatAnimation)); + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, compatAnimation)); } - - } - + @Override public Feed getActiveFeed() { return m_activeFeed; @@ -1557,113 +1498,117 @@ public class MainActivity extends FragmentActivity implements OnlineServices { public FeedCategory getActiveCategory() { return m_activeCategory; } - + private void logout() { if (m_refreshTask != null) { m_refreshTask.cancel(); m_refreshTask = null; } - + if (m_refreshTimer != null) { m_refreshTimer.cancel(); m_refreshTimer = null; } m_sessionId = null; - + findViewById(R.id.loading_container).setVisibility(View.VISIBLE); findViewById(R.id.main).setVisibility(View.INVISIBLE); - - TextView tv = (TextView)findViewById(R.id.loading_message); - + + TextView tv = (TextView) findViewById(R.id.loading_message); + if (tv != null) { - tv.setText(R.string.login_ready); + tv.setText(R.string.login_ready); } - + findViewById(R.id.loading_progress).setVisibility(View.GONE); - + initMainMenu(); } @Override @SuppressWarnings({ "unchecked", "serial" }) - public void login() { + public void login() { logout(); - + if (m_prefs.getString("ttrss_url", "").trim().length() == 0) { setLoadingStatus(R.string.login_need_configure, false); - + } else { - + LoginRequest ar = new LoginRequest(getApplicationContext()); - - HashMap map = new HashMap() { + + HashMap map = new HashMap() { { put("op", "login"); put("user", m_prefs.getString("login", "").trim()); put("password", m_prefs.getString("password", "").trim()); - } + } }; - + ar.execute(map); - + setLoadingStatus(R.string.login_in_progress, true); } } - + @Override public boolean onContextItemSelected(MenuItem item) { - AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo(); - - HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - FeedsFragment ff = (FeedsFragment)getSupportFragmentManager().findFragmentById(R.id.feeds_fragment); - FeedCategoriesFragment cf = (FeedCategoriesFragment)getSupportFragmentManager().findFragmentById(R.id.cats_fragment); + AdapterContextMenuInfo info = (AdapterContextMenuInfo) item + .getMenuInfo(); - switch (item.getItemId()) { - case R.id.browse_articles: - if (cf != null) { - FeedCategory cat = cf.getCategoryAtPosition(info.position); - if (cat != null) { - viewCategory(cat, true); - cf.setSelectedCategory(cat); - } - } - return true; - case R.id.browse_feeds: - if (cf != null) { - FeedCategory cat = cf.getCategoryAtPosition(info.position); - if (cat != null) { - viewCategory(cat, false); - cf.setSelectedCategory(cat); - } - } - return true; - case R.id.catchup_category: - if (cf != null) { - FeedCategory cat = cf.getCategoryAtPosition(info.position); - if (cat != null) { - catchupFeed(new Feed(cat.id, cat.title, true)); - } - } - return true; - case R.id.catchup_feed: - if (ff != null) { - Feed feed = ff.getFeedAtPosition(info.position); - if (feed != null) { - catchupFeed(feed); - } - } - return true; + HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + FeedsFragment ff = (FeedsFragment) getSupportFragmentManager() + .findFragmentById(R.id.feeds_fragment); + FeedCategoriesFragment cf = (FeedCategoriesFragment) getSupportFragmentManager() + .findFragmentById(R.id.cats_fragment); + + switch (item.getItemId()) { + case R.id.browse_articles: + if (cf != null) { + FeedCategory cat = cf.getCategoryAtPosition(info.position); + if (cat != null) { + viewCategory(cat, true); + cf.setSelectedCategory(cat); + } + } + return true; + case R.id.browse_feeds: + if (cf != null) { + FeedCategory cat = cf.getCategoryAtPosition(info.position); + if (cat != null) { + viewCategory(cat, false); + cf.setSelectedCategory(cat); + } + } + return true; + case R.id.catchup_category: + if (cf != null) { + FeedCategory cat = cf.getCategoryAtPosition(info.position); + if (cat != null) { + catchupFeed(new Feed(cat.id, cat.title, true)); + } + } + return true; + case R.id.catchup_feed: + if (ff != null) { + Feed feed = ff.getFeedAtPosition(info.position); + if (feed != null) { + catchupFeed(feed); + } + } + return true; case R.id.selection_toggle_marked: if (hf != null) { ArticleList selected = hf.getSelectedArticles(); - + if (selected.size() > 0) { for (Article a : selected) a.marked = !a.marked; - + toggleArticlesMarked(selected); hf.notifyUpdated(); } else { @@ -1679,7 +1624,7 @@ public class MainActivity extends FragmentActivity implements OnlineServices { case R.id.selection_toggle_published: if (hf != null) { ArticleList selected = hf.getSelectedArticles(); - + if (selected.size() > 0) { for (Article a : selected) a.published = !a.published; @@ -1697,13 +1642,13 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } return true; case R.id.selection_toggle_unread: - if (hf != null) { + if (hf != null) { ArticleList selected = hf.getSelectedArticles(); - - if (selected.size() > 0) { + + if (selected.size() > 0) { for (Article a : selected) a.unread = !a.unread; - + toggleArticlesUnread(selected); hf.notifyUpdated(); } else { @@ -1742,248 +1687,118 @@ public class MainActivity extends FragmentActivity implements OnlineServices { } } return true; - /* case R.id.set_unread: - if (hf != null) { - Article article = hf.getArticleAtPosition(info.position); - if (article != null) { - article.unread = true; - saveArticleUnread(article); - } - } - break; */ - default: - Log.d(TAG, "onContextItemSelected, unhandled id=" + item.getItemId()); - return super.onContextItemSelected(item); - } + /* + * case R.id.set_unread: if (hf != null) { Article article = + * hf.getArticleAtPosition(info.position); if (article != null) { + * article.unread = true; saveArticleUnread(article); } } break; + */ + default: + Log.d(TAG, + "onContextItemSelected, unhandled id=" + item.getItemId()); + return super.onContextItemSelected(item); + } } - @Override public Article getRelativeArticle(Article article, RelativeArticle ra) { - HeadlinesFragment frag = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + HeadlinesFragment frag = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); if (frag != null) { ArticleList articles = frag.getAllArticles(); for (int i = 0; i < articles.size(); i++) { Article a = articles.get(i); - + if (a.id == article.id) { if (ra == RelativeArticle.AFTER) { try { - return articles.get(i+1); + return articles.get(i + 1); } catch (IndexOutOfBoundsException e) { return null; } } else { try { - return articles.get(i-1); + return articles.get(i - 1); } catch (IndexOutOfBoundsException e) { return null; } } } } - } + } return null; } @Override public boolean dispatchKeyEvent(KeyEvent event) { - int action = event.getAction(); - int keyCode = event.getKeyCode(); - switch (keyCode) { - case KeyEvent.KEYCODE_VOLUME_DOWN: - if (action == KeyEvent.ACTION_DOWN) { - HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + int action = event.getAction(); + int keyCode = event.getKeyCode(); + switch (keyCode) { + case KeyEvent.KEYCODE_VOLUME_DOWN: + if (action == KeyEvent.ACTION_DOWN) { + HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); - if (hf != null && m_activeFeed != null) { - Article base = hf.getArticleById(hf.getActiveArticleId()); - - Article next = base != null ? getRelativeArticle(base, RelativeArticle.AFTER) : hf.getArticleAtPosition(0); - - if (next != null) { - hf.setActiveArticleId(next.id); - - boolean combinedMode = m_prefs.getBoolean("combined_mode", false); - - if (combinedMode || m_selectedArticle == null) { - next.unread = false; - saveArticleUnread(next); - } else { - openArticle(next, 0); - } - } - } - } - return true; - case KeyEvent.KEYCODE_VOLUME_UP: - if (action == KeyEvent.ACTION_UP) { - HeadlinesFragment hf = (HeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + if (hf != null && m_activeFeed != null) { + Article base = hf.getArticleById(hf.getActiveArticleId()); - if (hf != null && m_activeFeed != null) { - Article base = hf.getArticleById(hf.getActiveArticleId()); - - Article prev = base != null ? getRelativeArticle(base, RelativeArticle.BEFORE) : hf.getArticleAtPosition(0); - - if (prev != null) { - hf.setActiveArticleId(prev.id); - - boolean combinedMode = m_prefs.getBoolean("combined_mode", false); - - if (combinedMode || m_selectedArticle == null) { - prev.unread = false; - saveArticleUnread(prev); - } else { - openArticle(prev, 0); - } - } - } + Article next = base != null ? getRelativeArticle(base, + RelativeArticle.AFTER) : hf.getArticleAtPosition(0); + + if (next != null) { + hf.setActiveArticleId(next.id); + + boolean combinedMode = m_prefs.getBoolean( + "combined_mode", false); + + if (combinedMode || m_selectedArticle == null) { + next.unread = false; + saveArticleUnread(next); + } else { + openArticle(next, 0); + } + } + } + } + return true; + case KeyEvent.KEYCODE_VOLUME_UP: + if (action == KeyEvent.ACTION_UP) { + HeadlinesFragment hf = (HeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + + if (hf != null && m_activeFeed != null) { + Article base = hf.getArticleById(hf.getActiveArticleId()); + + Article prev = base != null ? getRelativeArticle(base, + RelativeArticle.BEFORE) : hf + .getArticleAtPosition(0); + + if (prev != null) { + hf.setActiveArticleId(prev.id); + + boolean combinedMode = m_prefs.getBoolean( + "combined_mode", false); + + if (combinedMode || m_selectedArticle == null) { + prev.unread = false; + saveArticleUnread(prev); + } else { + openArticle(prev, 0); + } + } + } + + } + return true; + default: + return super.dispatchKeyEvent(event); + } + } - } - return true; - default: - return super.dispatchKeyEvent(event); - } - } - @Override public void onCatSelected(FeedCategory cat) { Log.d(TAG, "onCatSelected"); boolean browse = m_prefs.getBoolean("browse_cats_like_feeds", false); - + viewCategory(cat, browse && cat.id >= 0); } - - private class RootTabListener implements ActionBar.TabListener { - - @Override - public void onTabReselected(Tab arg0, - android.app.FragmentTransaction arg1) { - // TODO Auto-generated method stub - - } - - @Override - public void onTabSelected(Tab arg0, android.app.FragmentTransaction arg1) { - // TODO Auto-generated method stub - - if (m_catTab != null) m_bar.removeTab(m_catTab); - if (m_feedTab != null) m_bar.removeTab(m_feedTab); - - } - - @Override - public void onTabUnselected(Tab arg0, - android.app.FragmentTransaction arg1) { - // TODO Auto-generated method stub - - } - - } - - - private class CategoryTabListener implements ActionBar.TabListener { - - private FeedCategory m_cat = null; - - public CategoryTabListener(FeedCategory cat) { - m_cat = cat; - } - - @Override - public void onTabReselected(Tab tab, - android.app.FragmentTransaction _ft) { - - //closeArticle(); - } - - @Override - public void onTabSelected(Tab tab, android.app.FragmentTransaction _ft) { - if (m_cat != null) { - m_activeCategory = m_cat; - - initMainMenu(); - - findViewById(R.id.cats_fragment).setVisibility(View.GONE); - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); - - FeedsFragment frag = new FeedsFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - ft.replace(R.id.feeds_fragment, frag); - ft.commit(); - } - } - - @Override - public void onTabUnselected(Tab tab, - android.app.FragmentTransaction _ft) { - - if (m_selectedArticle != null) - closeArticle(); - - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - - m_activeCategory = null; - - initMainMenu(); - refreshCategories(); - - } - } - -private class FeedTabListener implements ActionBar.TabListener { - - private Feed m_feed = null; - private Article m_article = null; - - public FeedTabListener(Feed cat, Article article) { - m_feed = cat; - m_article = article; - } - - @Override - public void onTabReselected(Tab tab, - android.app.FragmentTransaction _ft) { - - refreshHeadlines(); - } - - @Override - public void onTabSelected(Tab tab, android.app.FragmentTransaction _ft) { - if (m_feed != null) { - - m_activeFeed = m_feed; - m_selectedArticle = m_article; - - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.GONE); - findViewById(R.id.article_fragment).setVisibility(View.VISIBLE); - - ArticleFragment frag = new ArticleFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - ft.replace(R.id.article_fragment, frag); - ft.commit(); - - initMainMenu(); - - } - } - - @Override - public void onTabUnselected(Tab tab, - android.app.FragmentTransaction _ft) { - - if (m_selectedArticle != null) { - closeArticle(); - refreshFeeds(); - } - - //m_activeFeed = null; - - initMainMenu(); - } - } - } \ No newline at end of file diff --git a/src/org/fox/ttrss/OfflineActivity.java b/src/org/fox/ttrss/OfflineActivity.java index bff1e46a..54b62fb4 100644 --- a/src/org/fox/ttrss/OfflineActivity.java +++ b/src/org/fox/ttrss/OfflineActivity.java @@ -28,7 +28,8 @@ import android.widget.AdapterView.AdapterContextMenuInfo; import android.widget.LinearLayout; import android.widget.TextView; -public class OfflineActivity extends FragmentActivity implements OfflineServices { +public class OfflineActivity extends FragmentActivity implements + OfflineServices { private final String TAG = this.getClass().getSimpleName(); private SharedPreferences m_prefs; @@ -39,24 +40,25 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices private boolean m_unreadArticlesOnly = true; private boolean m_compatMode = false; private boolean m_enableCats = false; - + private int m_activeFeedId = 0; private int m_selectedArticleId = 0; - + private SQLiteDatabase m_readableDb; private SQLiteDatabase m_writableDb; - + @Override public boolean isSmallScreen() { return m_smallScreenMode; } - + @Override public void onCreate(Bundle savedInstanceState) { - m_prefs = PreferenceManager.getDefaultSharedPreferences(getApplicationContext()); + m_prefs = PreferenceManager + .getDefaultSharedPreferences(getApplicationContext()); m_compatMode = android.os.Build.VERSION.SDK_INT <= 10; - + if (m_prefs.getString("theme", "THEME_DARK").equals("THEME_DARK")) { setTheme(R.style.DarkTheme); } else { @@ -64,43 +66,48 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices } super.onCreate(savedInstanceState); - - NotificationManager nmgr = (NotificationManager)getSystemService(NOTIFICATION_SERVICE); + + NotificationManager nmgr = (NotificationManager) getSystemService(NOTIFICATION_SERVICE); nmgr.cancel(OfflineDownloadService.NOTIFY_DOWNLOADING); m_themeName = m_prefs.getString("theme", "THEME_DARK"); - + if (savedInstanceState != null) { m_unreadOnly = savedInstanceState.getBoolean("unreadOnly"); - m_unreadArticlesOnly = savedInstanceState.getBoolean("unreadArticlesOnly"); + m_unreadArticlesOnly = savedInstanceState + .getBoolean("unreadArticlesOnly"); m_activeFeedId = savedInstanceState.getInt("offlineActiveFeedId"); m_selectedArticleId = savedInstanceState.getInt("offlineArticleId"); } - + m_enableCats = m_prefs.getBoolean("enable_cats", false); - + Display display = getWindowManager().getDefaultDisplay(); - + int width = display.getWidth(); int height = display.getHeight(); - - if (height > width) { int tmp = height; width = tmp; height = width; } - - m_smallScreenMode = width < 960 || height < 720; - + + if (height > width) { + int tmp = height; + width = tmp; + height = width; + } + + m_smallScreenMode = width < 960 || height < 720; + setContentView(R.layout.main); initDatabase(); - + Log.d(TAG, "m_smallScreenMode=" + m_smallScreenMode); Log.d(TAG, "m_compatMode=" + m_compatMode); if (!m_compatMode) { - new TransitionHelper((LinearLayout)findViewById(R.id.main)); + new TransitionHelper((LinearLayout) findViewById(R.id.main)); } initMainMenu(); - + findViewById(R.id.loading_container).setVisibility(View.INVISIBLE); findViewById(R.id.main).setVisibility(View.VISIBLE); @@ -115,37 +122,41 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices findViewById(R.id.cats_fragment).setVisibility(View.GONE); } else { findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - //findViewById(R.id.article_fragment).setVisibility(View.GONE); - - /*if (m_enableCats && m_activeCategory == null) { - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - } else { - findViewById(R.id.cats_fragment).setVisibility(View.GONE); - } */ - + // findViewById(R.id.article_fragment).setVisibility(View.GONE); + + /* + * if (m_enableCats && m_activeCategory == null) { + * findViewById(R.id.feeds_fragment).setVisibility(View.GONE); + * findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); + * } else { + * findViewById(R.id.cats_fragment).setVisibility(View.GONE); } + */ + findViewById(R.id.cats_fragment).setVisibility(View.GONE); } } else { if (m_selectedArticleId == 0) { findViewById(R.id.article_fragment).setVisibility(View.GONE); - - /* if (!m_enableCats || m_activeCategory != null) - findViewById(R.id.cats_fragment).setVisibility(View.GONE); - else - findViewById(R.id.feeds_fragment).setVisibility(View.GONE); */ - + + /* + * if (!m_enableCats || m_activeCategory != null) + * findViewById(R.id.cats_fragment).setVisibility(View.GONE); + * else + * findViewById(R.id.feeds_fragment).setVisibility(View.GONE); + */ + findViewById(R.id.cats_fragment).setVisibility(View.GONE); - + } else { findViewById(R.id.feeds_fragment).setVisibility(View.GONE); findViewById(R.id.cats_fragment).setVisibility(View.GONE); } } - + if (m_activeFeedId == 0) { - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - OfflineFeedsFragment frag = new OfflineFeedsFragment(); + FragmentTransaction ft = getSupportFragmentManager() + .beginTransaction(); + OfflineFeedsFragment frag = new OfflineFeedsFragment(); ft.replace(R.id.feeds_fragment, frag); ft.commit(); } @@ -156,48 +167,48 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices m_writableDb = dh.getWritableDatabase(); m_readableDb = dh.getReadableDatabase(); } - + @Override public synchronized SQLiteDatabase getReadableDb() { return m_readableDb; } - + @Override public synchronized SQLiteDatabase getWritableDb() { return m_writableDb; } - + private void switchOnline() { SharedPreferences.Editor editor = m_prefs.edit(); editor.putBoolean("offline_mode_active", false); editor.commit(); - + Intent refresh = new Intent(this, MainActivity.class); startActivity(refresh); finish(); } - + @Override public int getActiveFeedId() { return m_activeFeedId; } - + private void setLoadingStatus(int status, boolean showProgress) { - TextView tv = (TextView)findViewById(R.id.loading_message); - + TextView tv = (TextView) findViewById(R.id.loading_message); + if (tv != null) { tv.setText(status); } - + View pb = findViewById(R.id.loading_progress); - + if (pb != null) { pb.setVisibility(showProgress ? View.VISIBLE : View.GONE); } } - + @Override - public void onSaveInstanceState (Bundle out) { + public void onSaveInstanceState(Bundle out) { super.onSaveInstanceState(out); out.putBoolean("unreadOnly", m_unreadOnly); @@ -205,18 +216,18 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices out.putInt("offlineActiveFeedId", m_activeFeedId); out.putInt("offlineArticleId", m_selectedArticleId); } - + private void setUnreadOnly(boolean unread) { m_unreadOnly = unread; - + refreshViews(); - - /*if (!m_enableCats || m_activeCategory != null ) - refreshFeeds(); - else - refreshCategories(); */ + + /* + * if (!m_enableCats || m_activeCategory != null ) refreshFeeds(); else + * refreshCategories(); + */ } - + @Override public boolean getUnreadOnly() { return m_unreadOnly; @@ -226,9 +237,10 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices public void onResume() { super.onResume(); - boolean needRefresh = !m_prefs.getString("theme", "THEME_DARK").equals(m_themeName) || - m_prefs.getBoolean("enable_cats", false) != m_enableCats; - + boolean needRefresh = !m_prefs.getString("theme", "THEME_DARK").equals( + m_themeName) + || m_prefs.getBoolean("enable_cats", false) != m_enableCats; + if (needRefresh) { Intent refresh = new Intent(this, OfflineActivity.class); startActivity(refresh); @@ -240,13 +252,13 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices public boolean onCreateOptionsMenu(Menu menu) { MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.offline_menu, menu); - + m_menu = menu; - + initMainMenu(); - + MenuItem item = menu.findItem(R.id.show_feeds); - + if (getUnreadOnly()) { item.setTitle(R.string.menu_all_feeds); } else { @@ -258,102 +270,93 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices private void setMenuLabel(int id, int labelId) { MenuItem mi = m_menu.findItem(id); - + if (mi != null) { mi.setTitle(labelId); } } - + @Override public void onBackPressed() { - if (m_smallScreenMode) { - if (m_selectedArticleId != 0) { - closeArticle(); - } else if (m_activeFeedId != 0) { - if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); - } - - /* if (m_activeFeed != null && m_activeFeed.is_cat) { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - - refreshCategories(); - } else { */ - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); - //} + if (m_smallScreenMode) { + if (m_selectedArticleId != 0) { + closeArticle(); + } else if (m_activeFeedId != 0) { + if (m_compatMode) { + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, + R.anim.slide_right)); + } + + /* + * if (m_activeFeed != null && m_activeFeed.is_cat) { + * findViewById + * (R.id.headlines_fragment).setVisibility(View.GONE); + * findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); + * + * refreshCategories(); } else { + */ + findViewById(R.id.headlines_fragment).setVisibility(View.GONE); + findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); + // } m_activeFeedId = 0; refreshViews(); - initMainMenu(); + initMainMenu(); - } else { - finish(); - } - } else { - if (m_selectedArticleId != 0) { - closeArticle(); - } else { - finish(); - } - } + } else { + finish(); + } + } else { + if (m_selectedArticleId != 0) { + closeArticle(); + } else { + finish(); + } + } } - -/* @Override - public boolean onKeyDown(int keyCode, KeyEvent event) { - if (keyCode == KeyEvent.KEYCODE_BACK) { - - if (m_smallScreenMode) { - if (m_selectedArticleId != 0) { - closeArticle(); - } else if (m_activeFeedId != 0) { - if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); - } */ - - /* if (m_activeFeed != null && m_activeFeed.is_cat) { - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); - - refreshCategories(); - } else { */ /* - findViewById(R.id.headlines_fragment).setVisibility(View.GONE); - findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); - //} - m_activeFeedId = 0; - refreshViews(); - initMainMenu(); - } else { - finish(); - } - } else { - if (m_selectedArticleId != 0) { - closeArticle(); - } else { - finish(); - } - } + /* + * @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if + * (keyCode == KeyEvent.KEYCODE_BACK) { + * + * if (m_smallScreenMode) { if (m_selectedArticleId != 0) { closeArticle(); + * } else if (m_activeFeedId != 0) { if (m_compatMode) { + * findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, + * R.anim.slide_right)); } + */ + + /* + * if (m_activeFeed != null && m_activeFeed.is_cat) { + * findViewById(R.id.headlines_fragment).setVisibility(View.GONE); + * findViewById(R.id.cats_fragment).setVisibility(View.VISIBLE); + * + * refreshCategories(); } else { + *//* + * findViewById(R.id.headlines_fragment).setVisibility(View.GONE); + * findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); //} + * m_activeFeedId = 0; refreshViews(); initMainMenu(); + * + * } else { finish(); } } else { if (m_selectedArticleId != 0) { + * closeArticle(); } else { finish(); } } + * + * return false; } return super.onKeyDown(keyCode, event); } + */ - return false; - } - return super.onKeyDown(keyCode, event); - } */ - private Cursor getArticleById(int articleId) { - Cursor c = getReadableDb().query("articles", null, BaseColumns._ID + "=?", + Cursor c = getReadableDb().query("articles", null, + BaseColumns._ID + "=?", new String[] { String.valueOf(articleId) }, null, null, null); - + c.moveToFirst(); - + return c; } - + private void shareArticle(int articleId) { Cursor article = getArticleById(articleId); - + if (article != null) { shareArticle(article); article.close(); @@ -365,29 +368,32 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices if (article != null) { String title = article.getString(article.getColumnIndex("title")); String link = article.getString(article.getColumnIndex("link")); - + Intent intent = new Intent(Intent.ACTION_SEND); - + intent.setType("text/plain"); intent.putExtra(Intent.EXTRA_SUBJECT, title); intent.putExtra(Intent.EXTRA_TEXT, link); - startActivity(Intent.createChooser(intent, getString(R.id.share_article))); + startActivity(Intent.createChooser(intent, + getString(R.id.share_article))); } } private void refreshHeadlines() { - OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); if (ohf != null) { ohf.refresh(); } } - + @Override public boolean onOptionsItemSelected(MenuItem item) { - OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); + OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); switch (item.getItemId()) { case R.id.preferences: @@ -400,51 +406,61 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices case R.id.close_article: closeArticle(); return true; - case R.id.back_to_categories: - //closeCategory(); - return true; + /* case R.id.back_to_categories: + // closeCategory(); + return true; */ case R.id.headlines_select: if (ohf != null) { Dialog dialog = new Dialog(this); AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle(R.string.headlines_select_dialog); - - builder.setSingleChoiceItems(new String[] { getString(R.string.headlines_select_all), - getString(R.string.headlines_select_unread), getString(R.string.headlines_select_none) }, 0, new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int which) { - switch (which) { - case 0: - SQLiteStatement stmtSelectAll = getWritableDb().compileStatement("UPDATE articles SET selected = 1 WHERE feed_id = ?"); - stmtSelectAll.bindLong(1, m_activeFeedId); - stmtSelectAll.execute(); - stmtSelectAll.close(); - break; - case 1: - SQLiteStatement stmtSelectUnread = getWritableDb().compileStatement("UPDATE articles SET selected = 1 WHERE feed_id = ? AND unread = 1"); - stmtSelectUnread.bindLong(1, m_activeFeedId); - stmtSelectUnread.execute(); - stmtSelectUnread.close(); - break; - case 2: - deselectAllArticles(); - break; - } - refreshViews(); - initMainMenu(); - - dialog.cancel(); - } - }); - + builder.setSingleChoiceItems(new String[] { + getString(R.string.headlines_select_all), + getString(R.string.headlines_select_unread), + getString(R.string.headlines_select_none) }, 0, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, + int which) { + switch (which) { + case 0: + SQLiteStatement stmtSelectAll = getWritableDb() + .compileStatement( + "UPDATE articles SET selected = 1 WHERE feed_id = ?"); + stmtSelectAll.bindLong(1, m_activeFeedId); + stmtSelectAll.execute(); + stmtSelectAll.close(); + break; + case 1: + SQLiteStatement stmtSelectUnread = getWritableDb() + .compileStatement( + "UPDATE articles SET selected = 1 WHERE feed_id = ? AND unread = 1"); + stmtSelectUnread + .bindLong(1, m_activeFeedId); + stmtSelectUnread.execute(); + stmtSelectUnread.close(); + break; + case 2: + deselectAllArticles(); + break; + } + + refreshViews(); + initMainMenu(); + + dialog.cancel(); + } + }); + dialog = builder.create(); dialog.show(); } return true; case R.id.headlines_mark_as_read: if (m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 WHERE feed_id = ?"); + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = 0 WHERE feed_id = ?"); stmt.bindLong(1, m_activeFeedId); stmt.execute(); stmt.close(); @@ -456,7 +472,9 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.toggle_marked: if (m_selectedArticleId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET marked = NOT marked WHERE " + BaseColumns._ID + " = ?"); + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET marked = NOT marked WHERE " + + BaseColumns._ID + " = ?"); stmt.bindLong(1, m_selectedArticleId); stmt.execute(); stmt.close(); @@ -468,7 +486,9 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.selection_toggle_unread: if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = NOT unread WHERE selected = 1 AND feed_id = ?"); + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET unread = NOT unread WHERE selected = 1 AND feed_id = ?"); stmt.bindLong(1, m_activeFeedId); stmt.execute(); stmt.close(); @@ -477,7 +497,9 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.selection_toggle_marked: if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET marked = NOT marked WHERE selected = 1 AND feed_id = ?"); + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET marked = NOT marked WHERE selected = 1 AND feed_id = ?"); stmt.bindLong(1, m_activeFeedId); stmt.execute(); stmt.close(); @@ -486,7 +508,9 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.selection_toggle_published: if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET published = NOT published WHERE selected = 1 AND feed_id = ?"); + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET published = NOT published WHERE selected = 1 AND feed_id = ?"); stmt.bindLong(1, m_activeFeedId); stmt.execute(); stmt.close(); @@ -495,7 +519,9 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.toggle_published: if (m_selectedArticleId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET published = NOT published WHERE " + BaseColumns._ID + " = ?"); + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET published = NOT published WHERE " + + BaseColumns._ID + " = ?"); stmt.bindLong(1, m_selectedArticleId); stmt.execute(); stmt.close(); @@ -504,8 +530,10 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.catchup_above: if (m_selectedArticleId != 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 WHERE updated >= " + - "(SELECT updated FROM articles WHERE " + BaseColumns._ID + " = ?) AND feed_id = ?"); + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = 0 WHERE updated >= " + + "(SELECT updated FROM articles WHERE " + + BaseColumns._ID + " = ?) AND feed_id = ?"); stmt.bindLong(1, m_selectedArticleId); stmt.bindLong(2, m_activeFeedId); stmt.execute(); @@ -515,7 +543,9 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices return true; case R.id.set_unread: if (m_selectedArticleId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 1 WHERE " + BaseColumns._ID + " = ?"); + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = 1 WHERE " + + BaseColumns._ID + " = ?"); stmt.bindLong(1, m_selectedArticleId); stmt.execute(); stmt.close(); @@ -530,34 +560,37 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices } else { item.setTitle(R.string.menu_unread_feeds); } - + return true; default: - Log.d(TAG, "onOptionsItemSelected, unhandled id=" + item.getItemId()); + Log.d(TAG, + "onOptionsItemSelected, unhandled id=" + item.getItemId()); return super.onOptionsItemSelected(item); } } private void refreshFeeds() { - OfflineFeedsFragment frag = (OfflineFeedsFragment)getSupportFragmentManager().findFragmentById(R.id.feeds_fragment); - + OfflineFeedsFragment frag = (OfflineFeedsFragment) getSupportFragmentManager() + .findFragmentById(R.id.feeds_fragment); + if (frag != null) { frag.refresh(); } } - + private void closeArticle() { if (m_compatMode) { - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_right)); + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, R.anim.slide_right)); } if (m_smallScreenMode) { - findViewById(R.id.article_fragment).setVisibility(View.GONE); - findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); + findViewById(R.id.article_fragment).setVisibility(View.GONE); + findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); } else { findViewById(R.id.article_fragment).setVisibility(View.GONE); findViewById(R.id.feeds_fragment).setVisibility(View.VISIBLE); - + } m_selectedArticleId = 0; @@ -566,358 +599,365 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices refreshViews(); } - + private int getSelectedArticleCount() { - Cursor c = getReadableDb().query("articles", new String[] { "COUNT(*)" }, "selected = 1", null, null, null, null); + Cursor c = getReadableDb().query("articles", + new String[] { "COUNT(*)" }, "selected = 1", null, null, null, + null); c.moveToFirst(); int selected = c.getInt(0); c.close(); - + return selected; } - + @Override public void initMainMenu() { if (m_menu != null) { + int numSelected = getSelectedArticleCount(); + m_menu.setGroupVisible(R.id.menu_group_feeds, false); m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_article, false); m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); + m_menu.setGroupVisible(R.id.menu_group_article, false); - if (m_selectedArticleId != 0) { + if (numSelected != 0) { + m_menu.setGroupVisible(R.id.menu_group_headlines_selection, true); + } else if (m_selectedArticleId != 0) { m_menu.setGroupVisible(R.id.menu_group_article, true); - - m_menu.setGroupVisible(R.id.menu_group_feeds, false); - - if (m_smallScreenMode) { - m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - } else { - m_menu.setGroupVisible(R.id.menu_group_headlines, true); - } - + } else if (m_activeFeedId != 0 /*|| m_activeCategory != null */) { + m_menu.setGroupVisible(R.id.menu_group_headlines, true); } else { - if (m_activeFeedId != 0) { - - OfflineHeadlinesFragment hf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - - if (hf != null) { - if (getSelectedArticleCount() != 0) { - m_menu.setGroupVisible(R.id.menu_group_headlines, false); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, true); - } else { - m_menu.setGroupVisible(R.id.menu_group_headlines, true); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - } - - } else { - m_menu.setGroupVisible(R.id.menu_group_headlines, true); - m_menu.setGroupVisible(R.id.menu_group_headlines_selection, false); - } - - m_menu.setGroupVisible(R.id.menu_group_feeds, false); - } else { - m_menu.setGroupVisible(R.id.menu_group_feeds, true); - } - - if (!m_smallScreenMode || m_activeFeedId == 0) { - m_menu.findItem(R.id.show_feeds).setVisible(true); - } - - //m_menu.findItem(R.id.back_to_categories).setVisible(m_activeCategory != null); - m_menu.findItem(R.id.back_to_categories).setVisible(false); - + m_menu.setGroupVisible(R.id.menu_group_feeds, true); } } - } - - + } + @Override public void onPause() { super.onPause(); - + } - + @Override public void onDestroy() { super.onDestroy(); - + m_readableDb.close(); m_writableDb.close(); - + } private void refreshViews() { refreshFeeds(); refreshHeadlines(); } - + @Override public boolean onContextItemSelected(MenuItem item) { - AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo(); + AdapterContextMenuInfo info = (AdapterContextMenuInfo) item + .getMenuInfo(); - OfflineHeadlinesFragment hf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - OfflineFeedsFragment ff = (OfflineFeedsFragment)getSupportFragmentManager().findFragmentById(R.id.feeds_fragment); - - switch (item.getItemId()) { - case R.id.browse_articles: - // TODO cat stuff - return true; - case R.id.browse_feeds: - // TODO cat stuff - return true; - case R.id.catchup_category: - // TODO cat stuff - return true; - case R.id.catchup_feed: - if (ff != null) { - int feedId = ff.getFeedIdAtPosition(info.position); - - if (feedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 WHERE feed_id = ?"); - stmt.bindLong(1, feedId); - stmt.execute(); - stmt.close(); - refreshViews(); - } - } - return true; - case R.id.selection_toggle_unread: - if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = NOT unread WHERE selected = 1 AND feed_id = ?"); - stmt.bindLong(1, m_activeFeedId); - stmt.execute(); - stmt.close(); - refreshViews(); - } else { - int articleId = hf.getArticleIdAtPosition(info.position); - if (articleId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = NOT unread WHERE " + - BaseColumns._ID + " = ?"); - stmt.bindLong(1, articleId); - stmt.execute(); - stmt.close(); - refreshViews(); - } - } - return true; - case R.id.selection_toggle_marked: - if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET marked = NOT marked WHERE selected = 1 AND feed_id = ?"); - stmt.bindLong(1, m_activeFeedId); - stmt.execute(); - stmt.close(); - refreshViews(); - } else { - int articleId = hf.getArticleIdAtPosition(info.position); - if (articleId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET marked = NOT marked WHERE " + - BaseColumns._ID + " = ?"); - stmt.bindLong(1, articleId); - stmt.execute(); - stmt.close(); - refreshViews(); - } - } - return true; - case R.id.selection_toggle_published: - if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET published = NOT published WHERE selected = 1 AND feed_id = ?"); - stmt.bindLong(1, m_activeFeedId); - stmt.execute(); - stmt.close(); - refreshViews(); - } else { - int articleId = hf.getArticleIdAtPosition(info.position); - if (articleId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET published = NOT published WHERE " + - BaseColumns._ID + " = ?"); - stmt.bindLong(1, articleId); - stmt.execute(); - stmt.close(); - refreshViews(); - } - } - return true; - case R.id.share_article: - Cursor article = hf.getArticleAtPosition(info.position); - - if (article != null) { - shareArticle(article); - } - return true; - case R.id.catchup_above: - int articleId = hf.getArticleIdAtPosition(info.position); - - if (articleId != 0 && m_activeFeedId != 0) { - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 WHERE updated >= " + - "(SELECT updated FROM articles WHERE " + BaseColumns._ID + " = ?) AND feed_id = ?"); - stmt.bindLong(1, articleId); - stmt.bindLong(2, m_activeFeedId); + OfflineHeadlinesFragment hf = (OfflineHeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + OfflineFeedsFragment ff = (OfflineFeedsFragment) getSupportFragmentManager() + .findFragmentById(R.id.feeds_fragment); + + switch (item.getItemId()) { + case R.id.browse_articles: + // TODO cat stuff + return true; + case R.id.browse_feeds: + // TODO cat stuff + return true; + case R.id.catchup_category: + // TODO cat stuff + return true; + case R.id.catchup_feed: + if (ff != null) { + int feedId = ff.getFeedIdAtPosition(info.position); + + if (feedId != 0) { + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = 0 WHERE feed_id = ?"); + stmt.bindLong(1, feedId); stmt.execute(); stmt.close(); refreshViews(); - } - return true; - default: - Log.d(TAG, "onContextItemSelected, unhandled id=" + item.getItemId()); - return super.onContextItemSelected(item); - } + } + } + return true; + case R.id.selection_toggle_unread: + if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET unread = NOT unread WHERE selected = 1 AND feed_id = ?"); + stmt.bindLong(1, m_activeFeedId); + stmt.execute(); + stmt.close(); + refreshViews(); + } else { + int articleId = hf.getArticleIdAtPosition(info.position); + if (articleId != 0) { + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = NOT unread WHERE " + + BaseColumns._ID + " = ?"); + stmt.bindLong(1, articleId); + stmt.execute(); + stmt.close(); + refreshViews(); + } + } + return true; + case R.id.selection_toggle_marked: + if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET marked = NOT marked WHERE selected = 1 AND feed_id = ?"); + stmt.bindLong(1, m_activeFeedId); + stmt.execute(); + stmt.close(); + refreshViews(); + } else { + int articleId = hf.getArticleIdAtPosition(info.position); + if (articleId != 0) { + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET marked = NOT marked WHERE " + + BaseColumns._ID + " = ?"); + stmt.bindLong(1, articleId); + stmt.execute(); + stmt.close(); + refreshViews(); + } + } + return true; + case R.id.selection_toggle_published: + if (getSelectedArticleCount() > 0 && m_activeFeedId != 0) { + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET published = NOT published WHERE selected = 1 AND feed_id = ?"); + stmt.bindLong(1, m_activeFeedId); + stmt.execute(); + stmt.close(); + refreshViews(); + } else { + int articleId = hf.getArticleIdAtPosition(info.position); + if (articleId != 0) { + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET published = NOT published WHERE " + + BaseColumns._ID + " = ?"); + stmt.bindLong(1, articleId); + stmt.execute(); + stmt.close(); + refreshViews(); + } + } + return true; + case R.id.share_article: + Cursor article = hf.getArticleAtPosition(info.position); + + if (article != null) { + shareArticle(article); + } + return true; + case R.id.catchup_above: + int articleId = hf.getArticleIdAtPosition(info.position); + + if (articleId != 0 && m_activeFeedId != 0) { + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = 0 WHERE updated >= " + + "(SELECT updated FROM articles WHERE " + + BaseColumns._ID + " = ?) AND feed_id = ?"); + stmt.bindLong(1, articleId); + stmt.bindLong(2, m_activeFeedId); + stmt.execute(); + stmt.close(); + refreshViews(); + } + return true; + default: + Log.d(TAG, + "onContextItemSelected, unhandled id=" + item.getItemId()); + return super.onContextItemSelected(item); + } } @Override public boolean dispatchKeyEvent(KeyEvent event) { - int action = event.getAction(); - int keyCode = event.getKeyCode(); - switch (keyCode) { - case KeyEvent.KEYCODE_VOLUME_DOWN: - if (action == KeyEvent.ACTION_DOWN) { - - OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - - int nextId = getRelativeArticleId(m_selectedArticleId, m_activeFeedId, RelativeArticle.AFTER); - - if (nextId != 0 && ohf != null) { - if (m_prefs.getBoolean("combined_mode", false)) { - ohf.setActiveArticleId(nextId); - - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 " + - "WHERE " + BaseColumns._ID + " = ?"); - - stmt.bindLong(1, nextId); - stmt.execute(); - stmt.close(); + int action = event.getAction(); + int keyCode = event.getKeyCode(); + switch (keyCode) { + case KeyEvent.KEYCODE_VOLUME_DOWN: + if (action == KeyEvent.ACTION_DOWN) { - } else { - openArticle(nextId, 0); - } - } - } - return true; - case KeyEvent.KEYCODE_VOLUME_UP: - if (action == KeyEvent.ACTION_UP) { - - OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - - int prevId = getRelativeArticleId(m_selectedArticleId, m_activeFeedId, RelativeArticle.BEFORE); - - if (prevId != 0 && ohf != null) { - if (m_prefs.getBoolean("combined_mode", false)) { - ohf.setActiveArticleId(prevId); - - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 " + - "WHERE " + BaseColumns._ID + " = ?"); - - stmt.bindLong(1, prevId); - stmt.execute(); - stmt.close(); + OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); - } else { - openArticle(prevId, 0); - } - } - } - return true; - default: - return super.dispatchKeyEvent(event); - } - } + int nextId = getRelativeArticleId(m_selectedArticleId, + m_activeFeedId, RelativeArticle.AFTER); + + if (nextId != 0 && ohf != null) { + if (m_prefs.getBoolean("combined_mode", false)) { + ohf.setActiveArticleId(nextId); + + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET unread = 0 " + + "WHERE " + BaseColumns._ID + + " = ?"); + + stmt.bindLong(1, nextId); + stmt.execute(); + stmt.close(); + + } else { + openArticle(nextId, 0); + } + } + } + return true; + case KeyEvent.KEYCODE_VOLUME_UP: + if (action == KeyEvent.ACTION_UP) { + + OfflineHeadlinesFragment ohf = (OfflineHeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + + int prevId = getRelativeArticleId(m_selectedArticleId, + m_activeFeedId, RelativeArticle.BEFORE); + + if (prevId != 0 && ohf != null) { + if (m_prefs.getBoolean("combined_mode", false)) { + ohf.setActiveArticleId(prevId); + + SQLiteStatement stmt = getWritableDb() + .compileStatement( + "UPDATE articles SET unread = 0 " + + "WHERE " + BaseColumns._ID + + " = ?"); + + stmt.bindLong(1, prevId); + stmt.execute(); + stmt.close(); + + } else { + openArticle(prevId, 0); + } + } + } + return true; + default: + return super.dispatchKeyEvent(event); + } + } private void deselectAllArticles() { getWritableDb().execSQL("UPDATE articles SET selected = 0 "); } - + @Override - public int getRelativeArticleId(int baseId, int feedId, OnlineServices.RelativeArticle mode) { - + public int getRelativeArticleId(int baseId, int feedId, + OnlineServices.RelativeArticle mode) { + Cursor c; - - /* if (baseId == 0) { - c = getReadableDb().query("articles", - null, "feed_id = ?", - new String[] { String.valueOf(feedId) }, null, null, "updated DESC LIMIT 1"); - - if (c.moveToFirst()) { - baseId = c.getInt(0); - } - - c.close(); - - return baseId; - } */ - - if (mode == RelativeArticle.BEFORE) { - c = getReadableDb().query("articles", - null, "updated > (SELECT updated FROM articles WHERE "+BaseColumns._ID+" = ?) AND feed_id = ?", - new String[] { String.valueOf(baseId), String.valueOf(feedId) }, null, null, "updated LIMIT 1"); - + + /* + * if (baseId == 0) { c = getReadableDb().query("articles", null, + * "feed_id = ?", new String[] { String.valueOf(feedId) }, null, null, + * "updated DESC LIMIT 1"); + * + * if (c.moveToFirst()) { baseId = c.getInt(0); } + * + * c.close(); + * + * return baseId; } + */ + + if (mode == RelativeArticle.BEFORE) { + c = getReadableDb().query( + "articles", + null, + "updated > (SELECT updated FROM articles WHERE " + + BaseColumns._ID + " = ?) AND feed_id = ?", + new String[] { String.valueOf(baseId), + String.valueOf(feedId) }, null, null, + "updated LIMIT 1"); + } else { - c = getReadableDb().query("articles", - null, "updated < (SELECT updated FROM articles WHERE "+BaseColumns._ID+" = ?) AND feed_id = ?", - new String[] { String.valueOf(baseId), String.valueOf(feedId) }, null, null, "updated DESC LIMIT 1"); + c = getReadableDb().query( + "articles", + null, + "updated < (SELECT updated FROM articles WHERE " + + BaseColumns._ID + " = ?) AND feed_id = ?", + new String[] { String.valueOf(baseId), + String.valueOf(feedId) }, null, null, + "updated DESC LIMIT 1"); } int id = 0; - - if (c.moveToFirst()) { + + if (c.moveToFirst()) { id = c.getInt(0); } - + c.close(); return id; } - + @Override public void viewFeed(int feedId) { m_activeFeedId = feedId; - + initMainMenu(); - + if (m_smallScreenMode) { findViewById(R.id.feeds_fragment).setVisibility(View.GONE); findViewById(R.id.headlines_fragment).setVisibility(View.VISIBLE); } - + deselectAllArticles(); - + FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); - OfflineHeadlinesFragment frag = new OfflineHeadlinesFragment(); + OfflineHeadlinesFragment frag = new OfflineHeadlinesFragment(); ft.replace(R.id.headlines_fragment, frag); ft.commit(); - + } @Override public void openArticle(int articleId, int compatAnimation) { m_selectedArticleId = articleId; - + initMainMenu(); - OfflineHeadlinesFragment hf = (OfflineHeadlinesFragment)getSupportFragmentManager().findFragmentById(R.id.headlines_fragment); - + OfflineHeadlinesFragment hf = (OfflineHeadlinesFragment) getSupportFragmentManager() + .findFragmentById(R.id.headlines_fragment); + if (hf != null) { hf.setActiveArticleId(articleId); } - SQLiteStatement stmt = getWritableDb().compileStatement("UPDATE articles SET unread = 0 " + - "WHERE " + BaseColumns._ID + " = ?"); - + SQLiteStatement stmt = getWritableDb().compileStatement( + "UPDATE articles SET unread = 0 " + "WHERE " + BaseColumns._ID + + " = ?"); + stmt.bindLong(1, articleId); stmt.execute(); stmt.close(); - + OfflineArticleFragment frag = new OfflineArticleFragment(); - - FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); + + FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); ft.replace(R.id.article_fragment, frag); ft.commit(); if (m_compatMode) { if (compatAnimation == 0) - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, R.anim.slide_left)); + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, R.anim.slide_left)); else - findViewById(R.id.main).setAnimation(AnimationUtils.loadAnimation(this, compatAnimation)); + findViewById(R.id.main).setAnimation( + AnimationUtils.loadAnimation(this, compatAnimation)); } if (m_smallScreenMode) { @@ -929,7 +969,6 @@ public class OfflineActivity extends FragmentActivity implements OfflineServices findViewById(R.id.article_fragment).setVisibility(View.VISIBLE); } - } @Override