summaryrefslogtreecommitdiff
path: root/android
diff options
context:
space:
mode:
Diffstat (limited to 'android')
-rw-r--r--android/sdremote/src/org/libreoffice/impressremote/activity/ComputersActivity.java47
1 files changed, 44 insertions, 3 deletions
diff --git a/android/sdremote/src/org/libreoffice/impressremote/activity/ComputersActivity.java b/android/sdremote/src/org/libreoffice/impressremote/activity/ComputersActivity.java
index 8054b893cac0..56b87e7e5777 100644
--- a/android/sdremote/src/org/libreoffice/impressremote/activity/ComputersActivity.java
+++ b/android/sdremote/src/org/libreoffice/impressremote/activity/ComputersActivity.java
@@ -27,6 +27,14 @@ import org.libreoffice.impressremote.util.Intents;
import org.libreoffice.impressremote.R;
public class ComputersActivity extends SherlockFragmentActivity implements ActionBar.TabListener, ViewPager.OnPageChangeListener {
+ private static final class TabsIndices {
+ private TabsIndices() {
+ }
+
+ public static final int BLUETOOTH = 0;
+ public static final int WIFI = 1;
+ }
+
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
@@ -47,7 +55,7 @@ public class ComputersActivity extends SherlockFragmentActivity implements Actio
}
private void setUpContent() {
- if (BluetoothOperator.isAvailable()) {
+ if (areMultipleComputersTypesAvailable()) {
setUpComputersLists();
}
else {
@@ -55,6 +63,10 @@ public class ComputersActivity extends SherlockFragmentActivity implements Actio
}
}
+ private boolean areMultipleComputersTypesAvailable() {
+ return BluetoothOperator.isAvailable();
+ }
+
private void setUpComputersLists() {
setContentView(R.layout.activity_computers);
@@ -65,8 +77,8 @@ public class ComputersActivity extends SherlockFragmentActivity implements Actio
private void setUpTabs() {
ActionBar aActionBar = getSupportActionBar();
- aActionBar.addTab(buildActionBarTab(R.string.title_bluetooth));
- aActionBar.addTab(buildActionBarTab(R.string.title_wifi));
+ aActionBar.addTab(buildActionBarTab(R.string.title_bluetooth), TabsIndices.BLUETOOTH);
+ aActionBar.addTab(buildActionBarTab(R.string.title_wifi), TabsIndices.WIFI);
}
private ActionBar.Tab buildActionBarTab(int aTitleResourceId) {
@@ -81,12 +93,18 @@ public class ComputersActivity extends SherlockFragmentActivity implements Actio
@Override
public void onTabSelected(ActionBar.Tab aTab, FragmentTransaction aTransaction) {
getComputersPager().setCurrentItem(aTab.getPosition());
+
+ refreshActionBarMenu();
}
private ViewPager getComputersPager() {
return (ViewPager) findViewById(R.id.pager_computers);
}
+ private void refreshActionBarMenu() {
+ supportInvalidateOptionsMenu();
+ }
+
@Override
public void onTabUnselected(ActionBar.Tab aTab, FragmentTransaction aTransaction) {
}
@@ -133,6 +151,29 @@ public class ComputersActivity extends SherlockFragmentActivity implements Actio
}
@Override
+ public boolean onPrepareOptionsMenu(Menu aMenu) {
+ if (!areMultipleComputersTypesAvailable()) {
+ return super.onPrepareOptionsMenu(aMenu);
+ }
+
+ MenuItem aComputerAddingMenuItem = aMenu.findItem(R.id.menu_add_computer);
+
+ switch (getSupportActionBar().getSelectedNavigationIndex()) {
+ case TabsIndices.BLUETOOTH:
+ aComputerAddingMenuItem.setVisible(false);
+ break;
+
+ case TabsIndices.WIFI:
+ aComputerAddingMenuItem.setVisible(true);
+
+ default:
+ break;
+ }
+
+ return super.onPrepareOptionsMenu(aMenu);
+ }
+
+ @Override
public boolean onOptionsItemSelected(MenuItem aMenuItem) {
switch (aMenuItem.getItemId()) {
case R.id.menu_licenses: