|
@@ -7,11 +7,20 @@ import java.util.Map;
|
|
|
|
|
|
import android.accounts.Account;
|
|
|
import android.accounts.AccountManager;
|
|
|
+import android.accounts.AccountManagerCallback;
|
|
|
+import android.accounts.AccountManagerFuture;
|
|
|
import android.content.Context;
|
|
|
import android.content.Intent;
|
|
|
import android.os.Bundle;
|
|
|
+import android.os.Handler;
|
|
|
+import android.util.Log;
|
|
|
+import android.view.ContextMenu;
|
|
|
import android.view.View;
|
|
|
import android.view.ViewGroup;
|
|
|
+import android.view.ContextMenu.ContextMenuInfo;
|
|
|
+import android.widget.AdapterView;
|
|
|
+import android.widget.AdapterView.AdapterContextMenuInfo;
|
|
|
+import android.widget.AdapterView.OnItemLongClickListener;
|
|
|
import android.widget.CheckedTextView;
|
|
|
import android.widget.ListView;
|
|
|
import android.widget.SimpleAdapter;
|
|
@@ -27,8 +36,11 @@ import eu.alefzero.owncloud.authenticator.AccountAuthenticator;
|
|
|
import eu.alefzero.owncloud.AccountUtils;
|
|
|
import eu.alefzero.owncloud.R;
|
|
|
|
|
|
-public class AccountSelectActivity extends SherlockListActivity {
|
|
|
+public class AccountSelectActivity extends SherlockListActivity
|
|
|
+ implements AccountManagerCallback<Boolean> {
|
|
|
|
|
|
+ private final Handler mHandler = new Handler();
|
|
|
+
|
|
|
@Override
|
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
|
super.onCreate(savedInstanceState);
|
|
@@ -41,22 +53,7 @@ public class AccountSelectActivity extends SherlockListActivity {
|
|
|
@Override
|
|
|
protected void onResume() {
|
|
|
super.onResume();
|
|
|
-
|
|
|
- AccountManager am = (AccountManager) getSystemService(ACCOUNT_SERVICE);
|
|
|
- Account accounts[] = am.getAccountsByType(AccountAuthenticator.ACCOUNT_TYPE);
|
|
|
- LinkedList< HashMap<String, String>> ll = new LinkedList<HashMap<String,String>>();
|
|
|
- for (Account a : accounts) {
|
|
|
- HashMap<String, String> h = new HashMap<String, String>();
|
|
|
- h.put("NAME", a.name);
|
|
|
- h.put("VER", "ownCloud version: " + am.getUserData(a, AccountAuthenticator.KEY_OC_VERSION));
|
|
|
- ll.add(h);
|
|
|
- }
|
|
|
-
|
|
|
- setListAdapter(new AccountCheckedSimpleAdepter(this,
|
|
|
- ll,
|
|
|
- android.R.layout.simple_list_item_single_choice,
|
|
|
- new String[]{"NAME"},
|
|
|
- new int[]{android.R.id.text1}));
|
|
|
+ populateAccountList();
|
|
|
}
|
|
|
|
|
|
@Override
|
|
@@ -66,6 +63,13 @@ public class AccountSelectActivity extends SherlockListActivity {
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
+ @Override
|
|
|
+ public void onCreateContextMenu(ContextMenu menu, View v,
|
|
|
+ ContextMenuInfo menuInfo) {
|
|
|
+ getMenuInflater().inflate(R.menu.account_picker_long_click, menu);
|
|
|
+ super.onCreateContextMenu(menu, v, menuInfo);
|
|
|
+ }
|
|
|
+
|
|
|
@Override
|
|
|
protected void onListItemClick(ListView l, View v, int position, long id) {
|
|
|
String accountName = ((TextView)v.findViewById(android.R.id.text1)).getText().toString();
|
|
@@ -74,7 +78,7 @@ public class AccountSelectActivity extends SherlockListActivity {
|
|
|
startActivity(i);
|
|
|
finish();
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
@Override
|
|
|
public boolean onMenuItemSelected(int featureId, MenuItem item) {
|
|
|
if (item.getItemId() == R.id.createAccount) {
|
|
@@ -87,6 +91,51 @@ public class AccountSelectActivity extends SherlockListActivity {
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
+ @Override
|
|
|
+ public boolean onContextItemSelected(android.view.MenuItem item) {
|
|
|
+ AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo();
|
|
|
+ int index = info.position;
|
|
|
+ HashMap<String, String> map = (HashMap<String, String>)getListAdapter().getItem(index);
|
|
|
+ String accountName = map.get("NAME");
|
|
|
+ AccountManager am = (AccountManager)getSystemService(ACCOUNT_SERVICE);
|
|
|
+ Account accounts[] = am.getAccountsByType(AccountAuthenticator.ACCOUNT_TYPE);
|
|
|
+ for (Account a : accounts) {
|
|
|
+ if (a.name.equals(accountName)) {
|
|
|
+ am.removeAccount(a, this, mHandler);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private void populateAccountList() {
|
|
|
+ AccountManager am = (AccountManager) getSystemService(ACCOUNT_SERVICE);
|
|
|
+ Account accounts[] = am.getAccountsByType(AccountAuthenticator.ACCOUNT_TYPE);
|
|
|
+ LinkedList< HashMap<String, String>> ll = new LinkedList<HashMap<String,String>>();
|
|
|
+ for (Account a : accounts) {
|
|
|
+ HashMap<String, String> h = new HashMap<String, String>();
|
|
|
+ h.put("NAME", a.name);
|
|
|
+ h.put("VER", "ownCloud version: " + am.getUserData(a, AccountAuthenticator.KEY_OC_VERSION));
|
|
|
+ ll.add(h);
|
|
|
+ }
|
|
|
+
|
|
|
+ setListAdapter(new AccountCheckedSimpleAdepter(this,
|
|
|
+ ll,
|
|
|
+ android.R.layout.simple_list_item_single_choice,
|
|
|
+ new String[]{"NAME"},
|
|
|
+ new int[]{android.R.id.text1}));
|
|
|
+ registerForContextMenu(getListView());
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void run(AccountManagerFuture<Boolean> future) {
|
|
|
+ if (future.isDone()) {
|
|
|
+ AccountUtils.setCurrentOwnCloudAccount(this, AccountUtils.getCurrentOwnCloudAccount(this).name);
|
|
|
+ populateAccountList();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
private class AccountCheckedSimpleAdepter extends SimpleAdapter {
|
|
|
private Account mCurrentAccount;
|
|
|
private List<? extends Map<String, ?>> mPrivateData;
|
|
@@ -113,5 +162,6 @@ public class AccountSelectActivity extends SherlockListActivity {
|
|
|
|
|
|
|
|
|
}
|
|
|
+
|
|
|
}
|
|
|
|