From c8b20e393a11a1a434ea1dda3af9a7d1e3d399f9 Mon Sep 17 00:00:00 2001 From: Sergey Eremin Date: Fri, 1 Jul 2016 03:30:15 +0300 Subject: [PATCH] Implements issue #8. Number of contacts is now shown in the tab title. --- .../ManageContactsActivity.java | 31 ++++++++++++------- 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/app/src/main/java/com/github/yeriomin/dumbphoneassistant/ManageContactsActivity.java b/app/src/main/java/com/github/yeriomin/dumbphoneassistant/ManageContactsActivity.java index a4202d2..39c5c61 100644 --- a/app/src/main/java/com/github/yeriomin/dumbphoneassistant/ManageContactsActivity.java +++ b/app/src/main/java/com/github/yeriomin/dumbphoneassistant/ManageContactsActivity.java @@ -21,6 +21,7 @@ import android.widget.ListView; import android.widget.RelativeLayout; import android.widget.TabHost; +import android.widget.TabWidget; import android.widget.TextView; import android.widget.Toast; @@ -77,8 +78,7 @@ protected void onActivityResult(int requestCode, int resultCode, Intent data) { // if this was called after editing a phone contact, refresh the view if (requestCode == EDIT_REQUEST_CODE) { phoneContacts = phoneUtil.get(); - phoneAdapter.notifyDataSetChanged(); - simAdapter.notifyDataSetChanged(); + update(); } else { super.onActivityResult(requestCode, resultCode, data); } @@ -183,6 +183,18 @@ public void onClick(DialogInterface i, int which) { simContacts = simUtil.get(); simAdapter = new SimRowAdapter(simContacts); simView.setAdapter(simAdapter); + + update(); + } + + private void update() { + simAdapter.notifyDataSetChanged(); + phoneAdapter.notifyDataSetChanged(); + TabWidget tabWidget = getTabHost().getTabWidget(); + TextView labelPhone = (TextView) tabWidget.getChildAt(0).findViewById(android.R.id.title); + TextView labelSim = (TextView) tabWidget.getChildAt(1).findViewById(android.R.id.title); + labelPhone.setText(getString(R.string.phone_tab_title) + " (" + phoneContacts.size() + ")"); + labelSim.setText(getString(R.string.sim_tab_title) + " (" + simContacts.size() + ")"); } private void startContactEditActivity(Contact contact) { @@ -216,11 +228,10 @@ private void copyToSim(Contact contact) throws Exception { // create contact on SIM card try { simUtil.create(newSimContact); + simContacts.add(0, newSimContact); } catch (Exception e) { throw new Exception(getString(R.string.error_sim_contact_not_stored)); } - - simContacts.add(0, newSimContact); } private void copyToPhone(Contact contact) throws Exception { @@ -326,8 +337,7 @@ public void onClick(View v) { try { copyToSim((Contact) v.getTag()); message = getString(R.string.confirm_sim_contact_stored); - phoneAdapter.notifyDataSetChanged(); - simAdapter.notifyDataSetChanged(); + update(); } catch (Exception e) { message = e.getMessage(); } @@ -378,8 +388,7 @@ public void onClick(View v) { Contact contact = (Contact) v.getTag(); copyToPhone(contact); message = getString(R.string.confirm_phone_contact_number_stored, contact.getName()); - phoneAdapter.notifyDataSetChanged(); - simAdapter.notifyDataSetChanged(); + update(); } catch (Exception e) { message = e.getMessage(); } @@ -428,8 +437,7 @@ public void onClick(DialogInterface dialog, int which) { boolean success = false; try { success = deleteFromSim(contact); - simAdapter.notifyDataSetChanged(); - phoneAdapter.notifyDataSetChanged(); + update(); } catch (Exception e) { // TODO: decide what to do with failed deletions } @@ -496,8 +504,7 @@ public void run() { @Override public void run() { progressDialog.dismiss(); - phoneAdapter.notifyDataSetChanged(); - simAdapter.notifyDataSetChanged(); + update(); if (failures > 0) { String message = getString(R.string.error_bulk_copy, failures); if (mode == COPY_ALL_TO_SIM) {