mirror of
https://github.com/moparisthebest/open-keychain
synced 2024-11-27 11:12:15 -05:00
Introduce and Switch to mikepenz/MaterialDrawer
This commit is contained in:
parent
702c28854b
commit
3ee2c6fc6a
@ -23,6 +23,11 @@ dependencies {
|
|||||||
compile "com.splitwise:tokenautocomplete:1.3.3@aar"
|
compile "com.splitwise:tokenautocomplete:1.3.3@aar"
|
||||||
compile 'se.emilsjolander:stickylistheaders:2.6.0'
|
compile 'se.emilsjolander:stickylistheaders:2.6.0'
|
||||||
compile 'org.sufficientlysecure:html-textview:1.1'
|
compile 'org.sufficientlysecure:html-textview:1.1'
|
||||||
|
compile 'com.mikepenz.materialdrawer:library:2.7.9@aar'
|
||||||
|
compile 'com.mikepenz.iconics:library:0.9.1@aar'
|
||||||
|
compile 'com.mikepenz.iconics:octicons-typeface:2.2.0@aar'
|
||||||
|
compile 'com.mikepenz.iconics:meteocons-typeface:1.1.1@aar'
|
||||||
|
compile 'com.mikepenz.iconics:community-material-typeface:1.0.0@aar'
|
||||||
|
|
||||||
// libs as submodules
|
// libs as submodules
|
||||||
compile project(':extern:openpgp-api-lib')
|
compile project(':extern:openpgp-api-lib')
|
||||||
@ -56,6 +61,11 @@ dependencyVerification {
|
|||||||
'com.splitwise:tokenautocomplete:20bee71cc59b3828eb000b684d46ddf738efd56b8fee453a509cd16fda42c8cb',
|
'com.splitwise:tokenautocomplete:20bee71cc59b3828eb000b684d46ddf738efd56b8fee453a509cd16fda42c8cb',
|
||||||
'se.emilsjolander:stickylistheaders:8c05981ec5725be33f7cee5e68c13f3db49cd5c75f1aaeb04024920b1ef96ad4',
|
'se.emilsjolander:stickylistheaders:8c05981ec5725be33f7cee5e68c13f3db49cd5c75f1aaeb04024920b1ef96ad4',
|
||||||
'org.sufficientlysecure:html-textview:ca24b1522be88378634093815ce9ff1b4920c72e7513a045a7846e14069ef988',
|
'org.sufficientlysecure:html-textview:ca24b1522be88378634093815ce9ff1b4920c72e7513a045a7846e14069ef988',
|
||||||
|
'com.mikepenz.materialdrawer:library:3ef80c6e1ca1b29cfcbb27fa7927c02b2246e068c17fe52283703c4897449923',
|
||||||
|
'com.mikepenz.iconics:library:4698a36ee4c2af765d0a85779c61474d755b90d66a59020105b6760a8a909e9e',
|
||||||
|
'com.mikepenz.iconics:octicons-typeface:67ed7d456a9ce5f5307b85f955797bfb3dd674e2f6defb31c6b8bbe2ede290be',
|
||||||
|
'com.mikepenz.iconics:meteocons-typeface:39a8a9e70cd8287cdb119af57a672a41dd09240dba6697f5a0dbda1ccc33298b',
|
||||||
|
'com.mikepenz.iconics:community-material-typeface:f1c5afee5f0f10d66beb3ed0df977246a02a9c46de4e05d7c0264bcde53b6b7f',
|
||||||
// 'OpenKeychain.extern:openpgp-api-lib:f05a9215cdad3a6597e4c5ece6fcec92b178d218195a3e88d2c0937c48dd9580',
|
// 'OpenKeychain.extern:openpgp-api-lib:f05a9215cdad3a6597e4c5ece6fcec92b178d218195a3e88d2c0937c48dd9580',
|
||||||
// 'OpenKeychain.extern:openkeychain-api-lib:50f6ebb5452d3fdc7be137ccf857a0ff44d55539fcb7b91baef495766ed7f429',
|
// 'OpenKeychain.extern:openkeychain-api-lib:50f6ebb5452d3fdc7be137ccf857a0ff44d55539fcb7b91baef495766ed7f429',
|
||||||
// 'com.madgag.spongycastle:core:df8fcc028a95ac5ffab3b78c9163f5cfa672e41cd50128ca55d458b6cfbacf4b',
|
// 'com.madgag.spongycastle:core:df8fcc028a95ac5ffab3b78c9163f5cfa672e41cd50128ca55d458b6cfbacf4b',
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2012-2014 Dominik Schürmann <dominik@dominikschuermann.de>
|
* Copyright (C) 2012-2014 Dominik Schürmann <dominik@dominikschuermann.de>
|
||||||
* Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com>
|
* Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com>
|
||||||
|
* Copyright (C) 2015 Kai Jiang <jiangkai@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -20,6 +21,20 @@ package org.sufficientlysecure.keychain.ui;
|
|||||||
|
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.support.v7.app.ActionBarActivity;
|
||||||
|
import android.support.v7.widget.Toolbar;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.AdapterView;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.mikepenz.community_material_typeface_library.CommunityMaterial;
|
||||||
|
import com.mikepenz.google_material_typeface_library.GoogleMaterial;
|
||||||
|
import com.mikepenz.iconics.typeface.FontAwesome;
|
||||||
|
import com.mikepenz.materialdrawer.Drawer;
|
||||||
|
import com.mikepenz.materialdrawer.model.DividerDrawerItem;
|
||||||
|
import com.mikepenz.materialdrawer.model.SectionDrawerItem;
|
||||||
|
import com.mikepenz.materialdrawer.model.PrimaryDrawerItem;
|
||||||
|
import com.mikepenz.materialdrawer.model.interfaces.IDrawerItem;
|
||||||
|
|
||||||
import org.sufficientlysecure.keychain.R;
|
import org.sufficientlysecure.keychain.R;
|
||||||
import org.sufficientlysecure.keychain.operations.results.OperationResult;
|
import org.sufficientlysecure.keychain.operations.results.OperationResult;
|
||||||
@ -29,27 +44,78 @@ import org.sufficientlysecure.keychain.util.FabContainer;
|
|||||||
|
|
||||||
import it.neokree.materialnavigationdrawer.MaterialNavigationDrawer;
|
import it.neokree.materialnavigationdrawer.MaterialNavigationDrawer;
|
||||||
|
|
||||||
public class MainActivity extends MaterialNavigationDrawer implements FabContainer {
|
public class MainActivity extends ActionBarActivity implements FabContainer {
|
||||||
|
|
||||||
|
public Drawer.Result result;
|
||||||
|
|
||||||
|
// public Drawer.Result result;
|
||||||
@Override
|
@Override
|
||||||
public void init(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
// don't open drawer on first run
|
// // don't open drawer on first run
|
||||||
disableLearningPattern();
|
// disableLearningPattern();
|
||||||
|
//
|
||||||
|
//// addMultiPaneSupport();
|
||||||
|
//
|
||||||
|
// // set the header image
|
||||||
|
// // create and set the header
|
||||||
|
// setDrawerHeaderImage(R.drawable.drawer_header);
|
||||||
|
//
|
||||||
|
// // create sections
|
||||||
|
// addSection(newSection(getString(R.string.nav_keys), R.drawable.ic_vpn_key_black_24dp, new KeyListFragment()));
|
||||||
|
// addSection(newSection(getString(R.string.nav_encrypt_decrypt), R.drawable.ic_lock_black_24dp, new EncryptDecryptOverviewFragment()));
|
||||||
|
// addSection(newSection(getString(R.string.title_api_registered_apps), R.drawable.ic_apps_black_24dp, new AppsListFragment()));
|
||||||
|
//
|
||||||
|
// // create bottom section
|
||||||
|
// addBottomSection(newSection(getString(R.string.menu_preferences), R.drawable.ic_settings_black_24dp, new Intent(this, SettingsActivity.class)));
|
||||||
|
// addBottomSection(newSection(getString(R.string.menu_help), R.drawable.ic_help_black_24dp, new Intent(this, HelpActivity.class)));
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.main_activity);
|
||||||
|
|
||||||
// addMultiPaneSupport();
|
final Toolbar toolbar = (Toolbar) findViewById(R.id.activity_main_toolbar);
|
||||||
|
toolbar.setTitle(R.string.app_name);
|
||||||
|
setSupportActionBar(toolbar);
|
||||||
|
|
||||||
// set the header image
|
result = new Drawer()
|
||||||
// create and set the header
|
.withActivity(this)
|
||||||
setDrawerHeaderImage(R.drawable.drawer_header);
|
.withHeader(R.layout.main_drawer_header)
|
||||||
|
.withToolbar(toolbar)
|
||||||
// create sections
|
.addDrawerItems(
|
||||||
addSection(newSection(getString(R.string.nav_keys), R.drawable.ic_vpn_key_black_24dp, new KeyListFragment()));
|
new PrimaryDrawerItem().withName(R.string.nav_keys).withIcon(CommunityMaterial.Icon.cmd_key).withIdentifier(1).withCheckable(false),
|
||||||
addSection(newSection(getString(R.string.nav_encrypt_decrypt), R.drawable.ic_lock_black_24dp, new EncryptDecryptOverviewFragment()));
|
new PrimaryDrawerItem().withName(R.string.nav_encrypt_decrypt).withIcon(FontAwesome.Icon.faw_lock).withIdentifier(2).withCheckable(false),
|
||||||
addSection(newSection(getString(R.string.title_api_registered_apps), R.drawable.ic_apps_black_24dp, new AppsListFragment()));
|
new PrimaryDrawerItem().withName(R.string.title_api_registered_apps).withIcon(CommunityMaterial.Icon.cmd_apps).withIdentifier(3).withCheckable(false),
|
||||||
|
new DividerDrawerItem(),
|
||||||
// create bottom section
|
new PrimaryDrawerItem().withName(R.string.menu_preferences).withIcon(GoogleMaterial.Icon.gmd_settings).withIdentifier(4).withCheckable(false),
|
||||||
addBottomSection(newSection(getString(R.string.menu_preferences), R.drawable.ic_settings_black_24dp, new Intent(this, SettingsActivity.class)));
|
new PrimaryDrawerItem().withName(R.string.menu_help).withIcon(CommunityMaterial.Icon.cmd_help_circle).withIdentifier(5).withCheckable(false)
|
||||||
addBottomSection(newSection(getString(R.string.menu_help), R.drawable.ic_help_black_24dp, new Intent(this, HelpActivity.class)));
|
)
|
||||||
|
.withOnDrawerItemClickListener(new Drawer.OnDrawerItemClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onItemClick(AdapterView<?> parent, View view, int position, long id, IDrawerItem drawerItem) {
|
||||||
|
if (drawerItem != null) {
|
||||||
|
Intent intent = null;
|
||||||
|
switch(drawerItem.getIdentifier()) {
|
||||||
|
case 1:
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
intent = new Intent(MainActivity.this, SettingsActivity.class);
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
intent = new Intent(MainActivity.this, HelpActivity.class);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (intent != null) {
|
||||||
|
MainActivity.this.startActivity(intent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Toast.makeText(MainActivity.this, Integer.toString(drawerItem.getIdentifier()), Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.withSelectedItem(-1)
|
||||||
|
.withSavedInstance(savedInstanceState)
|
||||||
|
.build();
|
||||||
|
|
||||||
// if this is the first time show first time activity
|
// if this is the first time show first time activity
|
||||||
Preferences prefs = Preferences.getPreferences(this);
|
Preferences prefs = Preferences.getPreferences(this);
|
||||||
@ -69,20 +135,47 @@ public class MainActivity extends MaterialNavigationDrawer implements FabContain
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// private void onPreferenceSelected() {
|
||||||
|
// Intent intent = new Intent(this, SettingsActivity.class);
|
||||||
|
// startActivity(intent);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// private void onHelpSelected() {
|
||||||
|
// Intent intent = new Intent(this, HelpActivity.class);
|
||||||
|
// startActivity(intent);
|
||||||
|
// }
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onSaveInstanceState(Bundle outState) {
|
||||||
|
//add the values which need to be saved from the drawer to the bundle
|
||||||
|
outState = result.saveInstanceState(outState);
|
||||||
|
super.onSaveInstanceState(outState);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBackPressed(){
|
||||||
|
//handle the back press :D close the drawer first and if the drawer is closed close the activity
|
||||||
|
if (result != null && result.isDrawerOpen()) {
|
||||||
|
result.closeDrawer();
|
||||||
|
} else {
|
||||||
|
super.onBackPressed();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void fabMoveUp(int height) {
|
public void fabMoveUp(int height) {
|
||||||
Object fragment = getCurrentSection().getTargetFragment();
|
// Object fragment = getCurrentSection().getTargetFragment();
|
||||||
if (fragment instanceof FabContainer) {
|
// if (fragment instanceof FabContainer) {
|
||||||
((FabContainer) fragment).fabMoveUp(height);
|
// ((FabContainer) fragment).fabMoveUp(height);
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void fabRestorePosition() {
|
public void fabRestorePosition() {
|
||||||
Object fragment = getCurrentSection().getTargetFragment();
|
// Object fragment = getCurrentSection().getTargetFragment();
|
||||||
if (fragment instanceof FabContainer) {
|
// if (fragment instanceof FabContainer) {
|
||||||
((FabContainer) fragment).fabRestorePosition();
|
// ((FabContainer) fragment).fabRestorePosition();
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
17
OpenKeychain/src/main/res/layout/main_activity.xml
Normal file
17
OpenKeychain/src/main/res/layout/main_activity.xml
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:orientation="vertical" android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<android.support.v7.widget.Toolbar
|
||||||
|
android:id="@+id/activity_main_toolbar"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="?attr/actionBarSize"
|
||||||
|
android:background="?attr/colorPrimary"/>
|
||||||
|
|
||||||
|
<fragment android:name="org.sufficientlysecure.keychain.ui.KeyListFragment"
|
||||||
|
android:id="@+id/keys_fragment"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_width="match_parent"/>
|
||||||
|
</LinearLayout>
|
9
OpenKeychain/src/main/res/layout/main_drawer_header.xml
Normal file
9
OpenKeychain/src/main/res/layout/main_drawer_header.xml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<ImageView xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:src="@drawable/drawer_header"
|
||||||
|
android:adjustViewBounds="true"
|
||||||
|
android:scaleType="fitCenter">
|
||||||
|
</ImageView>
|
Loading…
Reference in New Issue
Block a user