GUI, layout and style improvements, updated dependencies
This commit is contained in:
		| @@ -44,20 +44,23 @@ dependencies { | |||||||
|  |  | ||||||
|     compile 'org.slf4j:slf4j-android:1.7.12' |     compile 'org.slf4j:slf4j-android:1.7.12' | ||||||
|  |  | ||||||
|     compile('com.mikepenz:materialdrawer:3.1.0@aar') { |     compile 'com.mikepenz:materialize:1.0.0@aar' | ||||||
|  |     compile('com.mikepenz:materialdrawer:5.6.0@aar') { | ||||||
|         transitive = true |         transitive = true | ||||||
|     } |     } | ||||||
|     compile('com.mikepenz:aboutlibraries:5.3.4@aar') { |     compile('com.mikepenz:aboutlibraries:5.8.1@aar') { | ||||||
|         transitive = true |         transitive = true | ||||||
|     } |     } | ||||||
|     compile 'com.mikepenz:iconics:1.6.2@aar' |     compile 'com.mikepenz:iconics:1.6.2@aar' | ||||||
|     compile 'com.mikepenz:community-material-typeface:1.1.71@aar' |     compile 'com.mikepenz:community-material-typeface:1.5.54.2@aar' | ||||||
|  |  | ||||||
|     compile 'com.journeyapps:zxing-android-embedded:3.1.0@aar' |     compile 'com.journeyapps:zxing-android-embedded:3.1.0@aar' | ||||||
|     compile 'com.google.zxing:core:3.2.0' |     compile 'com.google.zxing:core:3.2.0' | ||||||
|     compile 'io.github.yavski:fab-speed-dial:1.0.2' |     compile 'io.github.yavski:fab-speed-dial:1.0.2' | ||||||
|  |     compile 'com.github.amlcurran.showcaseview:library:5.4.3' | ||||||
|     compile 'com.github.amlcurran.showcaseview:library:5.4.0' |     compile ('com.h6ah4i.android.widget.advrecyclerview:advrecyclerview:0.9.3@aar'){ | ||||||
|  |         transitive=true | ||||||
|  |     } | ||||||
|  |  | ||||||
|     testCompile 'junit:junit:4.12' |     testCompile 'junit:junit:4.12' | ||||||
|     testCompile 'org.mockito:mockito-core:1.10.19' |     testCompile 'org.mockito:mockito-core:1.10.19' | ||||||
|   | |||||||
| @@ -16,12 +16,7 @@ | |||||||
|  |  | ||||||
| package ch.dissem.apps.abit; | package ch.dissem.apps.abit; | ||||||
|  |  | ||||||
| import android.content.Intent; |  | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
| import android.support.v4.app.NavUtils; |  | ||||||
| import android.support.v7.app.AppCompatActivity; |  | ||||||
| import android.support.v7.widget.Toolbar; |  | ||||||
| import android.view.MenuItem; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -33,18 +28,11 @@ import android.view.MenuItem; | |||||||
|  * This activity is mostly just a 'shell' activity containing nothing |  * This activity is mostly just a 'shell' activity containing nothing | ||||||
|  * more than a {@link AddressDetailFragment}. |  * more than a {@link AddressDetailFragment}. | ||||||
|  */ |  */ | ||||||
| public class AddressDetailActivity extends AppCompatActivity { | public class AddressDetailActivity extends DetailActivity { | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     protected void onCreate(Bundle savedInstanceState) { |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|         super.onCreate(savedInstanceState); |         super.onCreate(savedInstanceState); | ||||||
|         setContentView(R.layout.scrolling_toolbar_layout); |  | ||||||
|  |  | ||||||
|         final Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); |  | ||||||
|         setSupportActionBar(toolbar); |  | ||||||
|         // Show the Up button in the action bar. |  | ||||||
|         //noinspection ConstantConditions |  | ||||||
|         getSupportActionBar().setDisplayHomeAsUpEnabled(true); |  | ||||||
|  |  | ||||||
|         // savedInstanceState is non-null when there is fragment state |         // savedInstanceState is non-null when there is fragment state | ||||||
|         // saved from previous configurations of this activity |         // saved from previous configurations of this activity | ||||||
| @@ -68,21 +56,4 @@ public class AddressDetailActivity extends AppCompatActivity { | |||||||
|                     .commit(); |                     .commit(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean onOptionsItemSelected(MenuItem item) { |  | ||||||
|         int id = item.getItemId(); |  | ||||||
|         if (id == android.R.id.home) { |  | ||||||
|             // This ID represents the Home or Up button. In the case of this |  | ||||||
|             // activity, the Up button is shown. Use NavUtils to allow users |  | ||||||
|             // to navigate up one level in the application structure. For |  | ||||||
|             // more details, see the Navigation pattern on Android Design: |  | ||||||
|             // |  | ||||||
|             // http://developer.android.com/design/patterns/navigation.html#up-vs-back |  | ||||||
|             // |  | ||||||
|             NavUtils.navigateUpTo(this, new Intent(this, MainActivity.class)); |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|         return super.onOptionsItemSelected(item); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										52
									
								
								app/src/main/java/ch/dissem/apps/abit/DetailActivity.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								app/src/main/java/ch/dissem/apps/abit/DetailActivity.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | package ch.dissem.apps.abit; | ||||||
|  |  | ||||||
|  | import android.content.Intent; | ||||||
|  | import android.os.Bundle; | ||||||
|  | import android.support.v4.app.NavUtils; | ||||||
|  | import android.support.v7.app.AppCompatActivity; | ||||||
|  | import android.support.v7.widget.Toolbar; | ||||||
|  | import android.view.MenuItem; | ||||||
|  |  | ||||||
|  | import com.mikepenz.materialize.MaterializeBuilder; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author Christian Basler | ||||||
|  |  */ | ||||||
|  | public class DetailActivity extends AppCompatActivity { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|  |         super.onCreate(savedInstanceState); | ||||||
|  |         setContentView(R.layout.scrolling_toolbar_layout); | ||||||
|  |  | ||||||
|  |         final Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); | ||||||
|  |         setSupportActionBar(toolbar); | ||||||
|  |         // Show the Up button in the action bar. | ||||||
|  |         //noinspection ConstantConditions | ||||||
|  |         getSupportActionBar().setDisplayHomeAsUpEnabled(true); | ||||||
|  |  | ||||||
|  |         new MaterializeBuilder() | ||||||
|  |             .withActivity(this) | ||||||
|  |             .withStatusBarColorRes(R.color.colorPrimaryDark) | ||||||
|  |             .withTranslucentStatusBarProgrammatically(true) | ||||||
|  |             .withStatusBarPadding(true) | ||||||
|  |             .build(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean onOptionsItemSelected(MenuItem item) { | ||||||
|  |         int id = item.getItemId(); | ||||||
|  |         if (id == android.R.id.home) { | ||||||
|  |             // This ID represents the Home or Up button. In the case of this | ||||||
|  |             // activity, the Up button is shown. Use NavUtils to allow users | ||||||
|  |             // to navigate up one level in the application structure. For | ||||||
|  |             // more details, see the Navigation pattern on Android Design: | ||||||
|  |             // | ||||||
|  |             // http://developer.android.com/design/patterns/navigation.html#up-vs-back | ||||||
|  |             // | ||||||
|  |             NavUtils.navigateUpTo(this, new Intent(this, MainActivity.class)); | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |         return super.onOptionsItemSelected(item); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -32,7 +32,6 @@ import android.support.v7.app.AppCompatActivity; | |||||||
| import android.support.v7.widget.Toolbar; | import android.support.v7.widget.Toolbar; | ||||||
| import android.view.View; | import android.view.View; | ||||||
| import android.view.ViewGroup; | import android.view.ViewGroup; | ||||||
| import android.widget.AdapterView; |  | ||||||
| import android.widget.CompoundButton; | import android.widget.CompoundButton; | ||||||
| import android.widget.RelativeLayout; | import android.widget.RelativeLayout; | ||||||
| import android.widget.TextView; | import android.widget.TextView; | ||||||
| @@ -43,10 +42,11 @@ import com.github.amlcurran.showcaseview.targets.Target; | |||||||
| import com.mikepenz.community_material_typeface_library.CommunityMaterial; | import com.mikepenz.community_material_typeface_library.CommunityMaterial; | ||||||
| import com.mikepenz.google_material_typeface_library.GoogleMaterial; | import com.mikepenz.google_material_typeface_library.GoogleMaterial; | ||||||
| import com.mikepenz.iconics.IconicsDrawable; | import com.mikepenz.iconics.IconicsDrawable; | ||||||
|  | import com.mikepenz.materialdrawer.AccountHeader; | ||||||
|  | import com.mikepenz.materialdrawer.AccountHeaderBuilder; | ||||||
| import com.mikepenz.materialdrawer.Drawer; | import com.mikepenz.materialdrawer.Drawer; | ||||||
| import com.mikepenz.materialdrawer.DrawerBuilder; | import com.mikepenz.materialdrawer.DrawerBuilder; | ||||||
| import com.mikepenz.materialdrawer.accountswitcher.AccountHeader; | import com.mikepenz.materialdrawer.interfaces.OnCheckedChangeListener; | ||||||
| import com.mikepenz.materialdrawer.accountswitcher.AccountHeaderBuilder; |  | ||||||
| import com.mikepenz.materialdrawer.model.DividerDrawerItem; | import com.mikepenz.materialdrawer.model.DividerDrawerItem; | ||||||
| import com.mikepenz.materialdrawer.model.PrimaryDrawerItem; | import com.mikepenz.materialdrawer.model.PrimaryDrawerItem; | ||||||
| import com.mikepenz.materialdrawer.model.ProfileDrawerItem; | import com.mikepenz.materialdrawer.model.ProfileDrawerItem; | ||||||
| @@ -55,7 +55,6 @@ import com.mikepenz.materialdrawer.model.SwitchDrawerItem; | |||||||
| import com.mikepenz.materialdrawer.model.interfaces.IDrawerItem; | import com.mikepenz.materialdrawer.model.interfaces.IDrawerItem; | ||||||
| import com.mikepenz.materialdrawer.model.interfaces.IProfile; | import com.mikepenz.materialdrawer.model.interfaces.IProfile; | ||||||
| import com.mikepenz.materialdrawer.model.interfaces.Nameable; | import com.mikepenz.materialdrawer.model.interfaces.Nameable; | ||||||
| import com.mikepenz.materialdrawer.model.interfaces.OnCheckedChangeListener; |  | ||||||
|  |  | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| @@ -100,7 +99,7 @@ import static ch.dissem.apps.abit.service.BitmessageService.isRunning; | |||||||
|  * </p> |  * </p> | ||||||
|  */ |  */ | ||||||
| public class MainActivity extends AppCompatActivity | public class MainActivity extends AppCompatActivity | ||||||
|         implements ListSelectionListener<Serializable>, ActionBarListener { |     implements ListSelectionListener<Serializable>, ActionBarListener { | ||||||
|     public static final String EXTRA_SHOW_MESSAGE = "ch.dissem.abit.ShowMessage"; |     public static final String EXTRA_SHOW_MESSAGE = "ch.dissem.abit.ShowMessage"; | ||||||
|     public static final String ACTION_SHOW_INBOX = "ch.dissem.abit.ShowInbox"; |     public static final String ACTION_SHOW_INBOX = "ch.dissem.abit.ShowInbox"; | ||||||
|  |  | ||||||
| @@ -109,7 +108,7 @@ public class MainActivity extends AppCompatActivity | |||||||
|     private static final int MANAGE_IDENTITY = 2; |     private static final int MANAGE_IDENTITY = 2; | ||||||
|     private static final int ADD_CHAN = 3; |     private static final int ADD_CHAN = 3; | ||||||
|  |  | ||||||
|     public static WeakReference<MainActivity> instance; |     private static WeakReference<MainActivity> instance; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Whether or not the activity is in two-pane mode, i.e. running on a tablet |      * Whether or not the activity is in two-pane mode, i.e. running on a tablet | ||||||
| @@ -157,7 +156,7 @@ public class MainActivity extends AppCompatActivity | |||||||
|  |  | ||||||
|         MessageListFragment listFragment = new MessageListFragment(); |         MessageListFragment listFragment = new MessageListFragment(); | ||||||
|         getSupportFragmentManager().beginTransaction().replace(R.id.item_list, listFragment) |         getSupportFragmentManager().beginTransaction().replace(R.id.item_list, listFragment) | ||||||
|                 .commit(); |             .commit(); | ||||||
|  |  | ||||||
|         if (findViewById(R.id.message_detail_container) != null) { |         if (findViewById(R.id.message_detail_container) != null) { | ||||||
|             // The detail container view will be present only in the |             // The detail container view will be present only in the | ||||||
| @@ -187,42 +186,42 @@ public class MainActivity extends AppCompatActivity | |||||||
|         } |         } | ||||||
|         if (drawer.isDrawerOpen()) { |         if (drawer.isDrawerOpen()) { | ||||||
|             RelativeLayout.LayoutParams lps = new RelativeLayout.LayoutParams(ViewGroup |             RelativeLayout.LayoutParams lps = new RelativeLayout.LayoutParams(ViewGroup | ||||||
|                     .LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); |                 .LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); | ||||||
|             lps.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM); |             lps.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM); | ||||||
|             lps.addRule(RelativeLayout.ALIGN_PARENT_LEFT); |             lps.addRule(RelativeLayout.ALIGN_PARENT_LEFT); | ||||||
|             int margin = ((Number) (getResources().getDisplayMetrics().density * 12)).intValue(); |             int margin = ((Number) (getResources().getDisplayMetrics().density * 12)).intValue(); | ||||||
|             lps.setMargins(margin, margin, margin, margin); |             lps.setMargins(margin, margin, margin, margin); | ||||||
|  |  | ||||||
|             showcaseView = new ShowcaseView.Builder(this) |             showcaseView = new ShowcaseView.Builder(this) | ||||||
|                     .withMaterialShowcase() |                 .withMaterialShowcase() | ||||||
|                     .setStyle(R.style.CustomShowcaseTheme) |                 .setStyle(R.style.CustomShowcaseTheme) | ||||||
|                     .setContentTitle(R.string.full_node) |                 .setContentTitle(R.string.full_node) | ||||||
|                     .setContentText(R.string.full_node_description) |                 .setContentText(R.string.full_node_description) | ||||||
|                     .setTarget(new Target() { |                 .setTarget(new Target() { | ||||||
|                                    @Override |                                @Override | ||||||
|                                    public Point getPoint() { |                                public Point getPoint() { | ||||||
|                                        View view = drawer.getStickyFooter(); |                                    View view = drawer.getStickyFooter(); | ||||||
|                                        int[] location = new int[2]; |                                    int[] location = new int[2]; | ||||||
|                                        view.getLocationInWindow(location); |                                    view.getLocationInWindow(location); | ||||||
|                                        int x = location[0] + 7 * view.getWidth() / 8; |                                    int x = location[0] + 7 * view.getWidth() / 8; | ||||||
|                                        int y = location[1] + view.getHeight() / 2; |                                    int y = location[1] + view.getHeight() / 2; | ||||||
|                                        return new Point(x, y); |                                    return new Point(x, y); | ||||||
|                                    } |  | ||||||
|                                } |                                } | ||||||
|                     ) |                            } | ||||||
|                     .replaceEndButton(R.layout.showcase_button) |                 ) | ||||||
|                     .hideOnTouchOutside() |                 .replaceEndButton(R.layout.showcase_button) | ||||||
|                     .build(); |                 .hideOnTouchOutside() | ||||||
|  |                 .build(); | ||||||
|             showcaseView.setButtonPosition(lps); |             showcaseView.setButtonPosition(lps); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void changeList(AbstractItemListFragment<?> listFragment) { |     private void changeList(AbstractItemListFragment<?> listFragment) { | ||||||
|         getSupportFragmentManager() |         getSupportFragmentManager() | ||||||
|                 .beginTransaction() |             .beginTransaction() | ||||||
|                 .replace(R.id.item_list, listFragment) |             .replace(R.id.item_list, listFragment) | ||||||
|                 .addToBackStack(null) |             .addToBackStack(null) | ||||||
|                 .commit(); |             .commit(); | ||||||
|  |  | ||||||
|         if (twoPane) { |         if (twoPane) { | ||||||
|             // In two-pane mode, list items should be given the |             // In two-pane mode, list items should be given the | ||||||
| @@ -236,90 +235,91 @@ public class MainActivity extends AppCompatActivity | |||||||
|         for (BitmessageAddress identity : bmc.addresses().getIdentities()) { |         for (BitmessageAddress identity : bmc.addresses().getIdentities()) { | ||||||
|             LOG.info("Adding identity " + identity.getAddress()); |             LOG.info("Adding identity " + identity.getAddress()); | ||||||
|             profiles.add(new ProfileDrawerItem() |             profiles.add(new ProfileDrawerItem() | ||||||
|                     .withIcon(new Identicon(identity)) |                 .withIcon(new Identicon(identity)) | ||||||
|                     .withName(identity.toString()) |                 .withName(identity.toString()) | ||||||
|                     .withNameShown(true) |                 .withNameShown(true) | ||||||
|                     .withEmail(identity.getAddress()) |                 .withEmail(identity.getAddress()) | ||||||
|                     .withTag(identity) |                 .withTag(identity) | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|         if (profiles.isEmpty()) { |         if (profiles.isEmpty()) { | ||||||
|             // Create an initial identity |             // Create an initial identity | ||||||
|             BitmessageAddress identity = Singleton.getIdentity(this); |             BitmessageAddress identity = Singleton.getIdentity(this); | ||||||
|             profiles.add(new ProfileDrawerItem() |             profiles.add(new ProfileDrawerItem() | ||||||
|                     .withIcon(new Identicon(identity)) |                 .withIcon(new Identicon(identity)) | ||||||
|                     .withName(identity.toString()) |                 .withName(identity.toString()) | ||||||
|                     .withEmail(identity.getAddress()) |                 .withEmail(identity.getAddress()) | ||||||
|                     .withTag(identity) |                 .withTag(identity) | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|         profiles.add(new ProfileSettingDrawerItem() |         profiles.add(new ProfileSettingDrawerItem() | ||||||
|                 .withName(getString(R.string.add_identity)) |             .withName(getString(R.string.add_identity)) | ||||||
|                 .withDescription(getString(R.string.add_identity_summary)) |             .withDescription(getString(R.string.add_identity_summary)) | ||||||
|                 .withIcon(new IconicsDrawable(this, GoogleMaterial.Icon.gmd_add) |             .withIcon(new IconicsDrawable(this, GoogleMaterial.Icon.gmd_add) | ||||||
|                         .actionBar() |                 .actionBar() | ||||||
|                         .paddingDp(5) |                 .paddingDp(5) | ||||||
|                         .colorRes(R.color.icons)) |                 .colorRes(R.color.icons)) | ||||||
|                 .withIdentifier(ADD_IDENTITY) |             .withIdentifier(ADD_IDENTITY) | ||||||
|         ); |         ); | ||||||
|         profiles.add(new ProfileSettingDrawerItem() |         profiles.add(new ProfileSettingDrawerItem() | ||||||
|                 .withName(getString(R.string.add_chan)) |             .withName(getString(R.string.add_chan)) | ||||||
|                 .withDescription(getString(R.string.add_chan_summary)) |             .withDescription(getString(R.string.add_chan_summary)) | ||||||
|                 .withIcon(new IconicsDrawable(this, GoogleMaterial.Icon.gmd_add) |             .withIcon(new IconicsDrawable(this, GoogleMaterial.Icon.gmd_add) | ||||||
|                         .actionBar() |                 .actionBar() | ||||||
|                         .paddingDp(5) |                 .paddingDp(5) | ||||||
|                         .colorRes(R.color.icons)) |                 .colorRes(R.color.icons)) | ||||||
|                 .withIdentifier(ADD_CHAN) |             .withIdentifier(ADD_CHAN) | ||||||
|         ); |         ); | ||||||
|         profiles.add(new ProfileSettingDrawerItem() |         profiles.add(new ProfileSettingDrawerItem() | ||||||
|                 .withName(getString(R.string.manage_identity)) |             .withName(getString(R.string.manage_identity)) | ||||||
|                 .withIcon(GoogleMaterial.Icon.gmd_settings) |             .withIcon(GoogleMaterial.Icon.gmd_settings) | ||||||
|                 .withIdentifier(MANAGE_IDENTITY) |             .withIdentifier(MANAGE_IDENTITY) | ||||||
|         ); |         ); | ||||||
|         // Create the AccountHeader |         // Create the AccountHeader | ||||||
|         accountHeader = new AccountHeaderBuilder() |         accountHeader = new AccountHeaderBuilder() | ||||||
|                 .withActivity(this) |             .withActivity(this) | ||||||
|                 .withHeaderBackground(R.drawable.header) |             .withHeaderBackground(R.drawable.header) | ||||||
|                 .withProfiles(profiles) |             .withProfiles(profiles) | ||||||
|                 .withOnAccountHeaderListener(new AccountHeader.OnAccountHeaderListener() { |             .withOnAccountHeaderListener(new AccountHeader.OnAccountHeaderListener() { | ||||||
|                     @Override |                 @Override | ||||||
|                     public boolean onProfileChanged(View view, IProfile profile, boolean |                 public boolean onProfileChanged(View view, IProfile profile, boolean | ||||||
|                             currentProfile) { |                     currentProfile) { | ||||||
|                         switch (profile.getIdentifier()) { |                     switch ((int) profile.getIdentifier()) { | ||||||
|                             case ADD_IDENTITY: |                         case ADD_IDENTITY: | ||||||
|                                 addIdentityDialog(); |                             addIdentityDialog(); | ||||||
|                                 break; |                             break; | ||||||
|                             case ADD_CHAN: |                         case ADD_CHAN: | ||||||
|                                 addChanDialog(); |                             addChanDialog(); | ||||||
|                                 break; |                             break; | ||||||
|                             case MANAGE_IDENTITY: |                         case MANAGE_IDENTITY: | ||||||
|                                 Intent show = new Intent(MainActivity.this, |                             Intent show = new Intent(MainActivity.this, | ||||||
|                                         AddressDetailActivity.class); |                                 AddressDetailActivity.class); | ||||||
|                                 show.putExtra(AddressDetailFragment.ARG_ITEM, |                             show.putExtra(AddressDetailFragment.ARG_ITEM, | ||||||
|                                         Singleton.getIdentity(getApplicationContext())); |                                 Singleton.getIdentity(getApplicationContext())); | ||||||
|                                 startActivity(show); |                             startActivity(show); | ||||||
|                                 break; |                             break; | ||||||
|                             default: |                         default: | ||||||
|                                 if (profile instanceof ProfileDrawerItem) { |                             if (profile instanceof ProfileDrawerItem) { | ||||||
|                                     Object tag = ((ProfileDrawerItem) profile).getTag(); |                                 Object tag = ((ProfileDrawerItem) profile).getTag(); | ||||||
|                                     if (tag instanceof BitmessageAddress) { |                                 if (tag instanceof BitmessageAddress) { | ||||||
|                                         Singleton.setIdentity((BitmessageAddress) tag); |                                     Singleton.setIdentity((BitmessageAddress) tag); | ||||||
|                                     } |  | ||||||
|                                 } |                                 } | ||||||
|                         } |                             } | ||||||
|                         // false if it should close the drawer |  | ||||||
|                         return false; |  | ||||||
|                     } |                     } | ||||||
|                 }) |                     // false if it should close the drawer | ||||||
|                 .build(); |                     return false; | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .build(); | ||||||
|         if (profiles.size() > 2) { // There's always the add and manage identity items |         if (profiles.size() > 2) { // There's always the add and manage identity items | ||||||
|             accountHeader.setActiveProfile(profiles.get(0), true); |             accountHeader.setActiveProfile(profiles.get(0), true); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ArrayList<IDrawerItem> drawerItems = new ArrayList<>(); |         ArrayList<IDrawerItem> drawerItems = new ArrayList<>(); | ||||||
|         for (Label label : labels) { |         for (Label label : labels) { | ||||||
|             PrimaryDrawerItem item = new PrimaryDrawerItem().withName(label.toString()).withTag |             PrimaryDrawerItem item = new PrimaryDrawerItem() | ||||||
|                     (label); |                 .withName(label.toString()) | ||||||
|  |                 .withTag(label); | ||||||
|             if (label.getType() == null) { |             if (label.getType() == null) { | ||||||
|                 item.withIcon(CommunityMaterial.Icon.cmd_label); |                 item.withIcon(CommunityMaterial.Icon.cmd_label); | ||||||
|             } else { |             } else { | ||||||
| @@ -349,146 +349,144 @@ public class MainActivity extends AppCompatActivity | |||||||
|             drawerItems.add(item); |             drawerItems.add(item); | ||||||
|         } |         } | ||||||
|         drawerItems.add(new PrimaryDrawerItem() |         drawerItems.add(new PrimaryDrawerItem() | ||||||
|                 .withName(R.string.archive) |             .withName(R.string.archive) | ||||||
|                 .withTag(null) |             .withTag(null) | ||||||
|                 .withIcon(CommunityMaterial.Icon.cmd_archive) |             .withIcon(CommunityMaterial.Icon.cmd_archive) | ||||||
|         ); |         ); | ||||||
|         drawerItems.add(new DividerDrawerItem()); |         drawerItems.add(new DividerDrawerItem()); | ||||||
|         drawerItems.add(new PrimaryDrawerItem() |         drawerItems.add(new PrimaryDrawerItem() | ||||||
|                 .withName(R.string.contacts_and_subscriptions) |             .withName(R.string.contacts_and_subscriptions) | ||||||
|                 .withIcon(GoogleMaterial.Icon.gmd_contacts)); |             .withIcon(GoogleMaterial.Icon.gmd_contacts)); | ||||||
|         drawerItems.add(new PrimaryDrawerItem() |         drawerItems.add(new PrimaryDrawerItem() | ||||||
|                 .withName(R.string.settings) |             .withName(R.string.settings) | ||||||
|                 .withIcon(GoogleMaterial.Icon.gmd_settings)); |             .withIcon(GoogleMaterial.Icon.gmd_settings)); | ||||||
|  |  | ||||||
|         drawer = new DrawerBuilder() |         drawer = new DrawerBuilder() | ||||||
|                 .withActivity(this) |             .withActivity(this) | ||||||
|                 .withToolbar(toolbar) |             .withToolbar(toolbar) | ||||||
|                 .withAccountHeader(accountHeader) |             .withAccountHeader(accountHeader) | ||||||
|                 .withDrawerItems(drawerItems) |             .withDrawerItems(drawerItems) | ||||||
|                 .addStickyDrawerItems( |             .addStickyDrawerItems( | ||||||
|                         new SwitchDrawerItem() |                 new SwitchDrawerItem() | ||||||
|                                 .withName(R.string.full_node) |                     .withName(R.string.full_node) | ||||||
|                                 .withIcon(CommunityMaterial.Icon.cmd_cloud_outline) |                     .withIcon(CommunityMaterial.Icon.cmd_cloud_outline) | ||||||
|                                 .withChecked(isRunning()) |                     .withChecked(isRunning()) | ||||||
|                                 .withOnCheckedChangeListener(new OnCheckedChangeListener() { |                     .withOnCheckedChangeListener(new OnCheckedChangeListener() { | ||||||
|                                     @Override |                         @Override | ||||||
|                                     public void onCheckedChanged(IDrawerItem drawerItem, |                         public void onCheckedChanged(IDrawerItem drawerItem, | ||||||
|                                                                  CompoundButton buttonView, |                                                      CompoundButton buttonView, | ||||||
|                                                                  boolean isChecked) { |                                                      boolean isChecked) { | ||||||
|                                         if (isChecked) { |                             if (isChecked) { | ||||||
|                                             checkAndStartNode(buttonView); |                                 checkAndStartNode(buttonView); | ||||||
|                                         } else { |                             } else { | ||||||
|                                             service.shutdownNode(); |                                 service.shutdownNode(); | ||||||
|                                         } |  | ||||||
|                                     } |  | ||||||
|                                 }) |  | ||||||
|                 ) |  | ||||||
|                 .withOnDrawerItemClickListener(new Drawer.OnDrawerItemClickListener() { |  | ||||||
|                     @Override |  | ||||||
|                     public boolean onItemClick(AdapterView<?> adapterView, View view, int i, long |  | ||||||
|                             l, IDrawerItem item) { |  | ||||||
|                         if (item.getTag() instanceof Label) { |  | ||||||
|                             selectedLabel = (Label) item.getTag(); |  | ||||||
|                             showSelectedLabel(); |  | ||||||
|                             return false; |  | ||||||
|                         } else if (item instanceof Nameable<?>) { |  | ||||||
|                             Nameable<?> ni = (Nameable<?>) item; |  | ||||||
|                             switch (ni.getNameRes()) { |  | ||||||
|                                 case R.string.contacts_and_subscriptions: |  | ||||||
|                                     if (!(getSupportFragmentManager().findFragmentById(R.id |  | ||||||
|                                             .item_list) instanceof AddressListFragment)) { |  | ||||||
|                                         changeList(new AddressListFragment()); |  | ||||||
|                                     } else { |  | ||||||
|                                         ((AddressListFragment) getSupportFragmentManager() |  | ||||||
|                                                 .findFragmentById(R.id.item_list)).updateList(); |  | ||||||
|                                     } |  | ||||||
|  |  | ||||||
|                                     break; |  | ||||||
|                                 case R.string.settings: |  | ||||||
|                                     startActivity(new Intent(MainActivity.this, SettingsActivity |  | ||||||
|                                             .class)); |  | ||||||
|                                     break; |  | ||||||
|                                 case R.string.archive: |  | ||||||
|                                     selectedLabel = null; |  | ||||||
|                                     showSelectedLabel(); |  | ||||||
|                                     break; |  | ||||||
|                                 case R.string.full_node: |  | ||||||
|                                     return true; |  | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|  |                     }) | ||||||
|  |             ) | ||||||
|  |             .withOnDrawerItemClickListener(new Drawer.OnDrawerItemClickListener() { | ||||||
|  |                 @Override | ||||||
|  |                 public boolean onItemClick(View view, int position, IDrawerItem item) { | ||||||
|  |                     if (item.getTag() instanceof Label) { | ||||||
|  |                         selectedLabel = (Label) item.getTag(); | ||||||
|  |                         showSelectedLabel(); | ||||||
|                         return false; |                         return false; | ||||||
|  |                     } else if (item instanceof Nameable<?>) { | ||||||
|  |                         Nameable<?> ni = (Nameable<?>) item; | ||||||
|  |                         switch (ni.getName().getTextRes()) { | ||||||
|  |                             case R.string.contacts_and_subscriptions: | ||||||
|  |                                 if (!(getSupportFragmentManager().findFragmentById(R.id | ||||||
|  |                                     .item_list) instanceof AddressListFragment)) { | ||||||
|  |                                     changeList(new AddressListFragment()); | ||||||
|  |                                 } else { | ||||||
|  |                                     ((AddressListFragment) getSupportFragmentManager() | ||||||
|  |                                         .findFragmentById(R.id.item_list)).updateList(); | ||||||
|  |                                 } | ||||||
|  |                                 break; | ||||||
|  |                             case R.string.settings: | ||||||
|  |                                 startActivity(new Intent(MainActivity.this, SettingsActivity | ||||||
|  |                                     .class)); | ||||||
|  |                                 break; | ||||||
|  |                             case R.string.archive: | ||||||
|  |                                 selectedLabel = null; | ||||||
|  |                                 showSelectedLabel(); | ||||||
|  |                                 break; | ||||||
|  |                             case R.string.full_node: | ||||||
|  |                                 return true; | ||||||
|  |                         } | ||||||
|                     } |                     } | ||||||
|                 }) |                     return false; | ||||||
|                 .withShowDrawerOnFirstLaunch(true) |                 } | ||||||
|                 .build(); |             }) | ||||||
|  |             .withShowDrawerOnFirstLaunch(true) | ||||||
|  |             .build(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void addIdentityDialog() { |     private void addIdentityDialog() { | ||||||
|         new AlertDialog.Builder(MainActivity.this) |         new AlertDialog.Builder(MainActivity.this) | ||||||
|                 .setMessage(R.string.add_identity_warning) |             .setMessage(R.string.add_identity_warning) | ||||||
|                 .setPositiveButton(android.R.string.yes, new |             .setPositiveButton(android.R.string.yes, new | ||||||
|                         DialogInterface.OnClickListener() { |                 DialogInterface.OnClickListener() { | ||||||
|  |                     @Override | ||||||
|  |                     public void onClick(DialogInterface dialog, | ||||||
|  |                                         int which) { | ||||||
|  |                         Toast.makeText(MainActivity.this, | ||||||
|  |                             R.string.toast_long_running_operation, | ||||||
|  |                             Toast.LENGTH_SHORT).show(); | ||||||
|  |                         new AsyncTask<Void, Void, BitmessageAddress>() { | ||||||
|                             @Override |                             @Override | ||||||
|                             public void onClick(DialogInterface dialog, |                             protected BitmessageAddress doInBackground(Void... args) { | ||||||
|                                                 int which) { |                                 return bmc.createIdentity(false, Pubkey.Feature.DOES_ACK); | ||||||
|                                 Toast.makeText(MainActivity.this, |  | ||||||
|                                         R.string.toast_long_running_operation, |  | ||||||
|                                         Toast.LENGTH_SHORT).show(); |  | ||||||
|                                 new AsyncTask<Void, Void, BitmessageAddress>() { |  | ||||||
|                                     @Override |  | ||||||
|                                     protected BitmessageAddress doInBackground(Void... args) { |  | ||||||
|                                         return bmc.createIdentity(false, Pubkey.Feature.DOES_ACK); |  | ||||||
|                                     } |  | ||||||
|  |  | ||||||
|                                     @Override |  | ||||||
|                                     protected void onPostExecute(BitmessageAddress chan) { |  | ||||||
|                                         Toast.makeText(MainActivity.this, |  | ||||||
|                                                 R.string.toast_identity_created, |  | ||||||
|                                                 Toast.LENGTH_SHORT).show(); |  | ||||||
|                                         addIdentityEntry(chan); |  | ||||||
|                                     } |  | ||||||
|                                 }.execute(); |  | ||||||
|                             } |                             } | ||||||
|                         }) |  | ||||||
|                 .setNegativeButton(android.R.string.no, null) |                             @Override | ||||||
|                 .show(); |                             protected void onPostExecute(BitmessageAddress chan) { | ||||||
|  |                                 Toast.makeText(MainActivity.this, | ||||||
|  |                                     R.string.toast_identity_created, | ||||||
|  |                                     Toast.LENGTH_SHORT).show(); | ||||||
|  |                                 addIdentityEntry(chan); | ||||||
|  |                             } | ||||||
|  |                         }.execute(); | ||||||
|  |                     } | ||||||
|  |                 }) | ||||||
|  |             .setNegativeButton(android.R.string.no, null) | ||||||
|  |             .show(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void addChanDialog() { |     private void addChanDialog() { | ||||||
|         @SuppressLint("InflateParams") |         @SuppressLint("InflateParams") | ||||||
|         final View dialogView = getLayoutInflater().inflate(R.layout.dialog_input_passphrase, null); |         final View dialogView = getLayoutInflater().inflate(R.layout.dialog_input_passphrase, null); | ||||||
|         new AlertDialog.Builder(MainActivity.this) |         new AlertDialog.Builder(MainActivity.this) | ||||||
|                 .setMessage(R.string.add_chan) |             .setMessage(R.string.add_chan) | ||||||
|                 .setView(dialogView) |             .setView(dialogView) | ||||||
|                 .setPositiveButton(R.string.ok, new DialogInterface.OnClickListener() { |             .setPositiveButton(R.string.ok, new DialogInterface.OnClickListener() { | ||||||
|                     @Override |                 @Override | ||||||
|                     public void onClick(DialogInterface dialogInterface, int i) { |                 public void onClick(DialogInterface dialogInterface, int i) { | ||||||
|                         TextView passphrase = (TextView) dialogView.findViewById(R.id.passphrase); |                     TextView passphrase = (TextView) dialogView.findViewById(R.id.passphrase); | ||||||
|                         Toast.makeText(MainActivity.this, R.string.toast_long_running_operation, |                     Toast.makeText(MainActivity.this, R.string.toast_long_running_operation, | ||||||
|                                 Toast.LENGTH_SHORT).show(); |                         Toast.LENGTH_SHORT).show(); | ||||||
|                         new AsyncTask<String, Void, BitmessageAddress>() { |                     new AsyncTask<String, Void, BitmessageAddress>() { | ||||||
|                             @Override |                         @Override | ||||||
|                             protected BitmessageAddress doInBackground(String... args) { |                         protected BitmessageAddress doInBackground(String... args) { | ||||||
|                                 String pass = args[0]; |                             String pass = args[0]; | ||||||
|                                 BitmessageAddress chan = bmc.createChan(pass); |                             BitmessageAddress chan = bmc.createChan(pass); | ||||||
|                                 chan.setAlias(pass); |                             chan.setAlias(pass); | ||||||
|                                 bmc.addresses().save(chan); |                             bmc.addresses().save(chan); | ||||||
|                                 return chan; |                             return chan; | ||||||
|                             } |                         } | ||||||
|  |  | ||||||
|                             @Override |                         @Override | ||||||
|                             protected void onPostExecute(BitmessageAddress chan) { |                         protected void onPostExecute(BitmessageAddress chan) { | ||||||
|                                 Toast.makeText(MainActivity.this, |                             Toast.makeText(MainActivity.this, | ||||||
|                                         R.string.toast_chan_created, |                                 R.string.toast_chan_created, | ||||||
|                                         Toast.LENGTH_SHORT).show(); |                                 Toast.LENGTH_SHORT).show(); | ||||||
|                                 addIdentityEntry(chan); |                             addIdentityEntry(chan); | ||||||
|                             } |                         } | ||||||
|                         }.execute(passphrase.getText().toString()); |                     }.execute(passphrase.getText().toString()); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .setNegativeButton(R.string.cancel, null) |             .setNegativeButton(R.string.cancel, null) | ||||||
|                 .show(); |             .show(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -500,18 +498,18 @@ public class MainActivity extends AppCompatActivity | |||||||
|  |  | ||||||
|     private void addIdentityEntry(BitmessageAddress identity) { |     private void addIdentityEntry(BitmessageAddress identity) { | ||||||
|         IProfile newProfile = new |         IProfile newProfile = new | ||||||
|                 ProfileDrawerItem() |             ProfileDrawerItem() | ||||||
|                 .withName(identity.toString()) |             .withName(identity.toString()) | ||||||
|                 .withEmail(identity.getAddress()) |             .withEmail(identity.getAddress()) | ||||||
|                 .withTag(identity); |             .withTag(identity); | ||||||
|         if (accountHeader.getProfiles() != null) { |         if (accountHeader.getProfiles() != null) { | ||||||
|             // we know that there are 3 setting |             // we know that there are 3 setting | ||||||
|             // elements. |             // elements. | ||||||
|             // Set the new profile above them ;) |             // Set the new profile above them ;) | ||||||
|             accountHeader.addProfile( |             accountHeader.addProfile( | ||||||
|                     newProfile, accountHeader |                 newProfile, accountHeader | ||||||
|                             .getProfiles().size() |                     .getProfiles().size() | ||||||
|                             - 3); |                     - 3); | ||||||
|         } else { |         } else { | ||||||
|             accountHeader.addProfiles(newProfile); |             accountHeader.addProfiles(newProfile); | ||||||
|         } |         } | ||||||
| @@ -530,20 +528,20 @@ public class MainActivity extends AppCompatActivity | |||||||
|             service.startupNode(); |             service.startupNode(); | ||||||
|         } else { |         } else { | ||||||
|             new AlertDialog.Builder(MainActivity.this) |             new AlertDialog.Builder(MainActivity.this) | ||||||
|                     .setMessage(R.string.full_node_warning) |                 .setMessage(R.string.full_node_warning) | ||||||
|                     .setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() { |                 .setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() { | ||||||
|                         @Override |                     @Override | ||||||
|                         public void onClick(DialogInterface dialog, int which) { |                     public void onClick(DialogInterface dialog, int which) { | ||||||
|                             service.startupNode(); |                         service.startupNode(); | ||||||
|                         } |                     } | ||||||
|                     }) |                 }) | ||||||
|                     .setNegativeButton(android.R.string.no, new DialogInterface.OnClickListener() { |                 .setNegativeButton(android.R.string.no, new DialogInterface.OnClickListener() { | ||||||
|                         @Override |                     @Override | ||||||
|                         public void onClick(DialogInterface dialog, int which) { |                     public void onClick(DialogInterface dialog, int which) { | ||||||
|                             buttonView.setChecked(false); |                         buttonView.setChecked(false); | ||||||
|                         } |                     } | ||||||
|                     }) |                 }) | ||||||
|                     .show(); |                 .show(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -556,7 +554,7 @@ public class MainActivity extends AppCompatActivity | |||||||
|                 if (unread > 0) { |                 if (unread > 0) { | ||||||
|                     ((PrimaryDrawerItem) item).withBadge(String.valueOf(unread)); |                     ((PrimaryDrawerItem) item).withBadge(String.valueOf(unread)); | ||||||
|                 } else { |                 } else { | ||||||
|                     ((PrimaryDrawerItem) item).withBadge(null); |                     ((PrimaryDrawerItem) item).withBadge((String) null); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -564,9 +562,9 @@ public class MainActivity extends AppCompatActivity | |||||||
|  |  | ||||||
|     private void showSelectedLabel() { |     private void showSelectedLabel() { | ||||||
|         if (getSupportFragmentManager().findFragmentById(R.id.item_list) instanceof |         if (getSupportFragmentManager().findFragmentById(R.id.item_list) instanceof | ||||||
|                 MessageListFragment) { |             MessageListFragment) { | ||||||
|             ((MessageListFragment) getSupportFragmentManager() |             ((MessageListFragment) getSupportFragmentManager() | ||||||
|                     .findFragmentById(R.id.item_list)).updateList(selectedLabel); |                 .findFragmentById(R.id.item_list)).updateList(selectedLabel); | ||||||
|         } else { |         } else { | ||||||
|             MessageListFragment listFragment = new MessageListFragment(); |             MessageListFragment listFragment = new MessageListFragment(); | ||||||
|             changeList(listFragment); |             changeList(listFragment); | ||||||
| @@ -593,12 +591,12 @@ public class MainActivity extends AppCompatActivity | |||||||
|                 fragment = new AddressDetailFragment(); |                 fragment = new AddressDetailFragment(); | ||||||
|             else |             else | ||||||
|                 throw new IllegalArgumentException("Plaintext or BitmessageAddress expected, but " + |                 throw new IllegalArgumentException("Plaintext or BitmessageAddress expected, but " + | ||||||
|                         "was " |                     "was " | ||||||
|                         + item.getClass().getSimpleName()); |                     + item.getClass().getSimpleName()); | ||||||
|             fragment.setArguments(arguments); |             fragment.setArguments(arguments); | ||||||
|             getSupportFragmentManager().beginTransaction() |             getSupportFragmentManager().beginTransaction() | ||||||
|                     .replace(R.id.message_detail_container, fragment) |                 .replace(R.id.message_detail_container, fragment) | ||||||
|                     .commit(); |                 .commit(); | ||||||
|         } else { |         } else { | ||||||
|             // In single-pane mode, simply start the detail activity |             // In single-pane mode, simply start the detail activity | ||||||
|             // for the selected item ID. |             // for the selected item ID. | ||||||
| @@ -609,8 +607,8 @@ public class MainActivity extends AppCompatActivity | |||||||
|                 detailIntent = new Intent(this, AddressDetailActivity.class); |                 detailIntent = new Intent(this, AddressDetailActivity.class); | ||||||
|             else |             else | ||||||
|                 throw new IllegalArgumentException("Plaintext or BitmessageAddress expected, but " + |                 throw new IllegalArgumentException("Plaintext or BitmessageAddress expected, but " + | ||||||
|                         "was " |                     "was " | ||||||
|                         + item.getClass().getSimpleName()); |                     + item.getClass().getSimpleName()); | ||||||
|  |  | ||||||
|             detailIntent.putExtra(MessageDetailFragment.ARG_ITEM, item); |             detailIntent.putExtra(MessageDetailFragment.ARG_ITEM, item); | ||||||
|             startActivity(detailIntent); |             startActivity(detailIntent); | ||||||
| @@ -632,7 +630,7 @@ public class MainActivity extends AppCompatActivity | |||||||
|     protected void onStart() { |     protected void onStart() { | ||||||
|         super.onStart(); |         super.onStart(); | ||||||
|         bindService(new Intent(this, BitmessageService.class), connection, Context |         bindService(new Intent(this, BitmessageService.class), connection, Context | ||||||
|                 .BIND_AUTO_CREATE); |             .BIND_AUTO_CREATE); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -1,11 +1,6 @@ | |||||||
| package ch.dissem.apps.abit; | package ch.dissem.apps.abit; | ||||||
|  |  | ||||||
| import android.content.Intent; |  | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
| import android.support.v4.app.NavUtils; |  | ||||||
| import android.support.v7.app.AppCompatActivity; |  | ||||||
| import android.support.v7.widget.Toolbar; |  | ||||||
| import android.view.MenuItem; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -17,18 +12,11 @@ import android.view.MenuItem; | |||||||
|  * This activity is mostly just a 'shell' activity containing nothing |  * This activity is mostly just a 'shell' activity containing nothing | ||||||
|  * more than a {@link MessageDetailFragment}. |  * more than a {@link MessageDetailFragment}. | ||||||
|  */ |  */ | ||||||
| public class MessageDetailActivity extends AppCompatActivity { | public class MessageDetailActivity extends DetailActivity { | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     protected void onCreate(Bundle savedInstanceState) { |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|         super.onCreate(savedInstanceState); |         super.onCreate(savedInstanceState); | ||||||
|         setContentView(R.layout.scrolling_toolbar_layout); |  | ||||||
|  |  | ||||||
|         final Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); |  | ||||||
|         setSupportActionBar(toolbar); |  | ||||||
|         // Show the Up button in the action bar. |  | ||||||
|         //noinspection ConstantConditions |  | ||||||
|         getSupportActionBar().setDisplayHomeAsUpEnabled(true); |  | ||||||
|  |  | ||||||
|         // savedInstanceState is non-null when there is fragment state |         // savedInstanceState is non-null when there is fragment state | ||||||
|         // saved from previous configurations of this activity |         // saved from previous configurations of this activity | ||||||
| @@ -52,21 +40,4 @@ public class MessageDetailActivity extends AppCompatActivity { | |||||||
|                     .commit(); |                     .commit(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean onOptionsItemSelected(MenuItem item) { |  | ||||||
|         int id = item.getItemId(); |  | ||||||
|         if (id == android.R.id.home) { |  | ||||||
|             // This ID represents the Home or Up button. In the case of this |  | ||||||
|             // activity, the Up button is shown. Use NavUtils to allow users |  | ||||||
|             // to navigate up one level in the application structure. For |  | ||||||
|             // more details, see the Navigation pattern on Android Design: |  | ||||||
|             // |  | ||||||
|             // http://developer.android.com/design/patterns/navigation.html#up-vs-back |  | ||||||
|             // |  | ||||||
|             NavUtils.navigateUpTo(this, new Intent(this, MainActivity.class)); |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|         return super.onOptionsItemSelected(item); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,18 +7,10 @@ import android.support.v7.widget.Toolbar; | |||||||
| /** | /** | ||||||
|  * @author Christian Basler |  * @author Christian Basler | ||||||
|  */ |  */ | ||||||
| public class SettingsActivity extends AppCompatActivity { | public class SettingsActivity extends DetailActivity { | ||||||
|     @Override |     @Override | ||||||
|     protected void onCreate(Bundle savedInstanceState) { |     protected void onCreate(Bundle savedInstanceState) { | ||||||
|         super.onCreate(savedInstanceState); |         super.onCreate(savedInstanceState); | ||||||
|         setContentView(R.layout.scrolling_toolbar_layout); |  | ||||||
|  |  | ||||||
|         Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); |  | ||||||
|         setSupportActionBar(toolbar); |  | ||||||
|  |  | ||||||
|         //noinspection ConstantConditions |  | ||||||
|         getSupportActionBar().setDisplayHomeAsUpEnabled(true); |  | ||||||
|         getSupportActionBar().setHomeButtonEnabled(false); |  | ||||||
|  |  | ||||||
|         // Display the fragment as the main content. |         // Display the fragment as the main content. | ||||||
|         getFragmentManager().beginTransaction() |         getFragmentManager().beginTransaction() | ||||||
|   | |||||||
| @@ -21,6 +21,8 @@ import android.support.v7.app.AppCompatActivity; | |||||||
| import android.support.v7.widget.Toolbar; | import android.support.v7.widget.Toolbar; | ||||||
| import android.widget.TextView; | import android.widget.TextView; | ||||||
|  |  | ||||||
|  | import com.mikepenz.materialize.MaterializeBuilder; | ||||||
|  |  | ||||||
| import ch.dissem.apps.abit.service.Singleton; | import ch.dissem.apps.abit.service.Singleton; | ||||||
| import ch.dissem.bitmessage.BitmessageContext; | import ch.dissem.bitmessage.BitmessageContext; | ||||||
| import ch.dissem.bitmessage.entity.BitmessageAddress; | import ch.dissem.bitmessage.entity.BitmessageAddress; | ||||||
| @@ -39,6 +41,13 @@ public class StatusActivity extends AppCompatActivity { | |||||||
|         getSupportActionBar().setDisplayHomeAsUpEnabled(true); |         getSupportActionBar().setDisplayHomeAsUpEnabled(true); | ||||||
|         getSupportActionBar().setHomeButtonEnabled(false); |         getSupportActionBar().setHomeButtonEnabled(false); | ||||||
|  |  | ||||||
|  |         new MaterializeBuilder() | ||||||
|  |             .withActivity(this) | ||||||
|  |             .withStatusBarColorRes(R.color.colorPrimaryDark) | ||||||
|  |             .withTranslucentStatusBarProgrammatically(true) | ||||||
|  |             .withStatusBarPadding(true) | ||||||
|  |             .build(); | ||||||
|  |  | ||||||
|         BitmessageContext bmc = Singleton.getBitmessageContext(this); |         BitmessageContext bmc = Singleton.getBitmessageContext(this); | ||||||
|         StringBuilder status = new StringBuilder(); |         StringBuilder status = new StringBuilder(); | ||||||
|         for (BitmessageAddress address : bmc.addresses().getIdentities()) { |         for (BitmessageAddress address : bmc.addresses().getIdentities()) { | ||||||
|   | |||||||
| @@ -32,20 +32,29 @@ public class WifiReceiver extends BroadcastReceiver { | |||||||
|         if (Preferences.isWifiOnly(ctx)) { |         if (Preferences.isWifiOnly(ctx)) { | ||||||
|             BitmessageContext bmc = Singleton.getBitmessageContext(ctx); |             BitmessageContext bmc = Singleton.getBitmessageContext(ctx); | ||||||
|  |  | ||||||
|             if (!isConnectedToWifi(ctx) && bmc.isRunning()) { |             if (isConnectedToMeteredNetwork(ctx) && bmc.isRunning()) { | ||||||
|                 bmc.shutdown(); |                 bmc.shutdown(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean isConnectedToWifi(Context ctx) { |     public static boolean isConnectedToMeteredNetwork(Context ctx) { | ||||||
|         NetworkInfo netInfo = getNetworkInfo(ctx); |         NetworkInfo netInfo = getNetworkInfo(ctx); | ||||||
|         return netInfo != null && netInfo.getType() == ConnectivityManager.TYPE_WIFI; |         if (netInfo == null || !netInfo.isConnectedOrConnecting()) { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         switch (netInfo.getType()){ | ||||||
|  |             case ConnectivityManager.TYPE_ETHERNET: | ||||||
|  |             case ConnectivityManager.TYPE_WIFI: | ||||||
|  |                 return false; | ||||||
|  |             default: | ||||||
|  |                 return true; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static NetworkInfo getNetworkInfo(Context ctx) { |     private static NetworkInfo getNetworkInfo(Context ctx) { | ||||||
|         ConnectivityManager conMan = (ConnectivityManager) ctx.getSystemService(Context |         ConnectivityManager conMan = (ConnectivityManager) ctx.getSystemService(Context | ||||||
|                 .CONNECTIVITY_SERVICE); |             .CONNECTIVITY_SERVICE); | ||||||
|         return conMan.getActiveNetworkInfo(); |         return conMan.getActiveNetworkInfo(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -101,7 +101,7 @@ public class Preferences { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean isConnectionAllowed(Context ctx) { |     public static boolean isConnectionAllowed(Context ctx) { | ||||||
|         return !isWifiOnly(ctx) || WifiReceiver.isConnectedToWifi(ctx); |         return !isWifiOnly(ctx) || !WifiReceiver.isConnectedToMeteredNetwork(ctx); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean isWifiOnly(Context ctx) { |     public static boolean isWifiOnly(Context ctx) { | ||||||
|   | |||||||
| @@ -1,24 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> |  | ||||||
| <resources> |  | ||||||
|  |  | ||||||
|     <style name="AppTheme" parent="AppTheme.Base"> |  | ||||||
|  |  | ||||||
|         <!-- Main theme colors --> |  | ||||||
|         <!--   your app branding color for the app bar --> |  | ||||||
|         <item name="android:colorPrimary">@color/colorPrimary</item> |  | ||||||
|         <!--   darker variant for the status bar and contextual app bars --> |  | ||||||
|         <item name="android:colorPrimaryDark">@color/colorPrimaryDark</item> |  | ||||||
|         <!--   theme UI controls like checkboxes and text fields --> |  | ||||||
|         <item name="android:colorAccent">@color/colorAccent</item> |  | ||||||
|  |  | ||||||
|         <item name="android:windowContentTransitions">true</item> |  | ||||||
|         <item name="android:windowAllowEnterTransitionOverlap">true</item> |  | ||||||
|         <item name="android:windowAllowReturnTransitionOverlap">true</item> |  | ||||||
|         <item name="android:windowSharedElementEnterTransition">@android:transition/move</item> |  | ||||||
|         <item name="android:windowSharedElementExitTransition">@android:transition/move</item> |  | ||||||
|  |  | ||||||
|         <item name="android:windowDrawsSystemBarBackgrounds">true</item> |  | ||||||
|         <!--<item name="android:statusBarColor">@android:color/transparent</item>--> |  | ||||||
|  |  | ||||||
|     </style> |  | ||||||
| </resources> |  | ||||||
| @@ -1,13 +1,48 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <!-- Palette generated by Material Palette - materialpalette.com/blue-grey/orange --> | <!-- Palette generated by Material Palette - materialpalette.com/blue-grey/orange --> | ||||||
| <resources> | <resources> | ||||||
|   <color name="colorPrimary">#FFC107</color> |     <color name="colorPrimary">#FFC107</color> | ||||||
|   <color name="colorPrimaryDark">#FFA000</color> |     <color name="colorPrimaryDark">#FFA000</color> | ||||||
|   <color name="colorPrimaryDarkText">#DEFFFFFF</color> |     <color name="colorPrimaryDarkText">#DEFFFFFF</color> | ||||||
|   <color name="colorPrimaryLight">#FFECB3</color> |     <color name="colorPrimaryLight">#FFECB3</color> | ||||||
|   <color name="colorAccent">#607D8B</color> |     <color name="colorAccent">#607D8B</color> | ||||||
|   <color name="colorPrimaryText">#212121</color> |     <color name="colorPrimaryText">#212121</color> | ||||||
|   <color name="colorSecondaryText">#727272</color> |     <color name="colorSecondaryText">#727272</color> | ||||||
|   <color name="icons">#212121</color> |     <color name="icons">#212121</color> | ||||||
|   <color name="divider">#B6B6B6</color> |     <color name="divider">#B6B6B6</color> | ||||||
|  |  | ||||||
|  |     <!-- Material DEFAULT colors --> | ||||||
|  |     <color name="material_drawer_primary">@color/colorPrimary</color> | ||||||
|  |     <color name="material_drawer_primary_dark">@color/colorPrimaryDark</color> | ||||||
|  |     <color name="material_drawer_primary_light">@color/colorPrimaryLight</color> | ||||||
|  |     <color name="material_drawer_accent">@color/colorAccent</color> | ||||||
|  |  | ||||||
|  |     <!-- OVERWRITE THESE COLORS FOR A LIGHT THEME --> | ||||||
|  |     <!-- MaterialDrawer DEFAULT colors --> | ||||||
|  |     <color name="material_drawer_background">@color/colorPrimaryDark</color> | ||||||
|  |     <!-- Material DEFAULT text / items colors --> | ||||||
|  |     <color name="material_drawer_primary_text">@color/colorPrimaryText</color> | ||||||
|  |     <color name="material_drawer_primary_icon">@color/icons</color> | ||||||
|  |     <color name="material_drawer_secondary_text">@color/colorSecondaryText</color> | ||||||
|  |     <color name="material_drawer_hint_text">@color/colorSecondaryText</color> | ||||||
|  |     <color name="material_drawer_divider">@color/divider</color> | ||||||
|  |     <!-- Material DEFAULT drawer colors --> | ||||||
|  |     <color name="material_drawer_selected">@color/primary</color> | ||||||
|  |     <color name="material_drawer_selected_text">@color/colorPrimaryText</color> | ||||||
|  |     <color name="material_drawer_header_selection_text">@color/colorPrimaryText</color> | ||||||
|  |  | ||||||
|  |     <!-- OVERWRITE THESE COLORS FOR A DARK THEME --> | ||||||
|  |     <!-- MaterialDrawer DEFAULT DARK colors --> | ||||||
|  |     <color name="material_drawer_dark_background">#303030</color> | ||||||
|  |     <!-- MaterialDrawer DEFAULT DARK text / items colors --> | ||||||
|  |     <color name="material_drawer_dark_primary_text">#DEFFFFFF</color> | ||||||
|  |     <color name="material_drawer_dark_primary_icon">#8AFFFFFF</color> | ||||||
|  |     <color name="material_drawer_dark_secondary_text">#8AFFFFFF</color> | ||||||
|  |     <color name="material_drawer_dark_hint_text">#42FFFFFF</color> | ||||||
|  |     <color name="material_drawer_dark_divider">#1FFFFFFF</color> | ||||||
|  |     <!-- MaterialDrawer DEFAULT DARK drawer colors --> | ||||||
|  |     <color name="material_drawer_dark_selected">#202020</color> | ||||||
|  |     <color name="material_drawer_dark_selected_text">@color/material_drawer_primary</color> | ||||||
|  |     <color name="material_drawer_dark_header_selection_text">#FFF</color> | ||||||
|  |  | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -1,28 +1,12 @@ | |||||||
| <resources> | <resources> | ||||||
|  |  | ||||||
|     <!-- Base application theme. --> |     <!-- Base application theme. --> | ||||||
|     <style name="AppTheme.Base" parent="MaterialDrawerTheme.Light.DarkToolbar.TranslucentStatus"> |     <style name="AppTheme" parent="MaterialDrawerTheme.Light.DarkToolbar.TranslucentStatus"> | ||||||
|  |  | ||||||
|         <item name="android:activatedBackgroundIndicator">@color/colorPrimaryLight</item> |         <item name="android:activatedBackgroundIndicator">@color/colorPrimaryLight</item> | ||||||
|         <item name="android:textColor">@color/colorPrimaryText</item> |         <item name="android:textColor">@color/colorPrimaryText</item> | ||||||
|         <item name="android:textColorSecondary">@color/colorSecondaryText</item> |         <item name="android:textColorSecondary">@color/colorSecondaryText</item> | ||||||
|  |  | ||||||
|         <!-- MaterialDrawer specific values --> |  | ||||||
|         <item name="material_drawer_background">@color/colorPrimaryDark</item> |  | ||||||
|         <item name="material_drawer_icons">@color/colorPrimaryText</item> |  | ||||||
|         <item name="material_drawer_primary_icon">@color/icons</item> |  | ||||||
|         <item name="material_drawer_primary_text">@color/colorPrimaryText</item> |  | ||||||
|         <item name="material_drawer_secondary_text">@color/colorSecondaryText</item> |  | ||||||
|         <item name="material_drawer_hint_text">@color/colorSecondaryText</item> |  | ||||||
|         <item name="material_drawer_divider">@color/divider</item> |  | ||||||
|         <item name="material_drawer_selected">@color/primary</item> |  | ||||||
|         <item name="material_drawer_selected_text">@color/colorPrimaryText</item> |  | ||||||
|         <item name="material_drawer_header_selection_text">@color/colorPrimaryText</item> |  | ||||||
|  |  | ||||||
|     </style> |     </style> | ||||||
|  |  | ||||||
|     <style name="AppTheme" parent="AppTheme.Base"/> |  | ||||||
|  |  | ||||||
|     <style name="CustomShowcaseTheme" parent="ShowcaseView"> |     <style name="CustomShowcaseTheme" parent="ShowcaseView"> | ||||||
|         <item name="sv_backgroundColor">#eeffc107</item> |         <item name="sv_backgroundColor">#eeffc107</item> | ||||||
|         <item name="sv_showcaseColor">#ffc107</item> |         <item name="sv_showcaseColor">#ffc107</item> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user