2014-05-24 21:12:20 -04:00
|
|
|
package org.bspeice.minimalbible.activities.downloader;
|
|
|
|
|
|
|
|
import org.bspeice.minimalbible.R;
|
|
|
|
import org.bspeice.minimalbible.activities.BaseActivity;
|
|
|
|
import org.bspeice.minimalbible.activities.BaseNavigationDrawerFragment;
|
|
|
|
import org.bspeice.minimalbible.activities.downloader.manager.DownloadManager;
|
|
|
|
|
|
|
|
import android.os.Bundle;
|
2014-06-14 14:08:50 -04:00
|
|
|
import android.support.v4.app.Fragment;
|
2014-05-24 21:12:20 -04:00
|
|
|
import android.support.v4.app.FragmentManager;
|
|
|
|
import android.support.v4.widget.DrawerLayout;
|
|
|
|
import android.support.v7.app.ActionBar;
|
|
|
|
import android.view.Menu;
|
|
|
|
import android.view.MenuItem;
|
|
|
|
|
|
|
|
public class DownloadActivity extends BaseActivity implements
|
|
|
|
BaseNavigationDrawerFragment.NavigationDrawerCallbacks {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fragment managing the behaviors, interactions and presentation of the
|
|
|
|
* navigation drawer.
|
|
|
|
*/
|
|
|
|
private DownloadNavDrawerFragment mNavigationDrawerFragment;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to store the last screen title. For use in
|
|
|
|
* {@link #restoreActionBar()}.
|
|
|
|
*/
|
|
|
|
private CharSequence mTitle;
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
|
|
super.onCreate(savedInstanceState);
|
|
|
|
setContentView(R.layout.activity_download);
|
|
|
|
|
|
|
|
mNavigationDrawerFragment = (DownloadNavDrawerFragment) getSupportFragmentManager()
|
|
|
|
.findFragmentById(R.id.navigation_drawer);
|
|
|
|
mTitle = getTitle();
|
|
|
|
|
|
|
|
// Set up the drawer.
|
|
|
|
mNavigationDrawerFragment.setUp(R.id.navigation_drawer,
|
|
|
|
(DrawerLayout) findViewById(R.id.drawer_layout));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onNavigationDrawerItemSelected(int position) {
|
|
|
|
// update the main content by replacing fragments
|
|
|
|
//TODO: Switch to AutoFactory pattern, rather than newInstance()
|
|
|
|
FragmentManager fragmentManager = getSupportFragmentManager();
|
|
|
|
fragmentManager
|
|
|
|
.beginTransaction()
|
|
|
|
.replace(R.id.container,
|
|
|
|
BookListFragment.newInstance(DownloadManager.VALID_CATEGORIES[position])).commit();
|
|
|
|
}
|
|
|
|
|
|
|
|
public void onSectionAttached(String category) {
|
|
|
|
mTitle = category;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void restoreActionBar() {
|
|
|
|
ActionBar actionBar = getSupportActionBar();
|
|
|
|
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD);
|
|
|
|
actionBar.setDisplayShowTitleEnabled(true);
|
|
|
|
actionBar.setTitle(mTitle);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean onCreateOptionsMenu(Menu menu) {
|
|
|
|
if (!mNavigationDrawerFragment.isDrawerOpen()) {
|
|
|
|
// Only show items in the action bar relevant to this screen
|
|
|
|
// if the drawer is not showing. Otherwise, let the drawer
|
|
|
|
// decide what to show in the action bar.
|
|
|
|
getMenuInflater().inflate(R.menu.download, menu);
|
|
|
|
restoreActionBar();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return super.onCreateOptionsMenu(menu);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean onOptionsItemSelected(MenuItem item) {
|
|
|
|
// Handle action bar item clicks here. The action bar will
|
|
|
|
// automatically handle clicks on the Home/Up button, so long
|
|
|
|
// as you specify a parent activity in AndroidManifest.xml.
|
|
|
|
int id = item.getItemId();
|
|
|
|
if (id == R.id.action_settings) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return super.onOptionsItemSelected(item);
|
|
|
|
}
|
|
|
|
}
|