GUI, layout and style improvements, updated dependencies
This commit is contained in:
parent
af2bfc796b
commit
c8a0301402
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user