From f18324e2d6065b827855a26f8bc52c95bc706ebb Mon Sep 17 00:00:00 2001 From: Veeti Paananen Date: Mon, 16 Dec 2013 22:17:52 +0200 Subject: [PATCH 1/2] Add tab swiping in the contact picker --- res/layout/contact_selection_activity.xml | 6 +- .../securesms/ContactSelectionActivity.java | 132 ++++++++++++------ 2 files changed, 91 insertions(+), 47 deletions(-) diff --git a/res/layout/contact_selection_activity.xml b/res/layout/contact_selection_activity.xml index 6810629dca..7fe22f57a9 100644 --- a/res/layout/contact_selection_activity.xml +++ b/res/layout/contact_selection_activity.xml @@ -5,8 +5,8 @@ android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android"> - + \ No newline at end of file diff --git a/src/org/thoughtcrime/securesms/ContactSelectionActivity.java b/src/org/thoughtcrime/securesms/ContactSelectionActivity.java index 4349c82292..aa9456d877 100644 --- a/src/org/thoughtcrime/securesms/ContactSelectionActivity.java +++ b/src/org/thoughtcrime/securesms/ContactSelectionActivity.java @@ -20,7 +20,9 @@ import android.content.Intent; import android.os.Bundle; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; +import android.support.v4.app.FragmentPagerAdapter; import android.support.v4.app.FragmentTransaction; +import android.support.v4.view.ViewPager; import org.thoughtcrime.securesms.recipients.Recipients; import org.thoughtcrime.securesms.util.DynamicTheme; @@ -44,6 +46,7 @@ public class ContactSelectionActivity extends PassphraseRequiredSherlockFragment private final DynamicTheme dynamicTheme = new DynamicTheme(); + private ViewPager viewPager; private ContactSelectionListFragment contactsFragment; private ContactSelectionGroupsFragment groupsFragment; private ContactSelectionRecentFragment recentFragment; @@ -61,9 +64,9 @@ public class ContactSelectionActivity extends PassphraseRequiredSherlockFragment setContentView(R.layout.contact_selection_activity); - setupContactsTab(); - setupGroupsTab(); - setupRecentTab(); + setupFragments(); + setupViewPager(); + setupTabs(); } @Override @@ -104,56 +107,97 @@ public class ContactSelectionActivity extends PassphraseRequiredSherlockFragment finish(); } - private ActionBar.Tab constructTab(final Fragment fragment) { - ActionBar actionBar = this.getSupportActionBar(); - ActionBar.Tab tab = actionBar.newTab(); + private void setupViewPager() { + viewPager = (ViewPager) findViewById(R.id.pager); + viewPager.setAdapter(new SelectionPagerAdapter()); + viewPager.setOnPageChangeListener(new TabSwitchingPageListener()); + } - tab.setTabListener(new TabListener(){ - @Override - public void onTabSelected(Tab tab, FragmentTransaction ignore) { - FragmentManager manager = ContactSelectionActivity.this.getSupportFragmentManager(); - FragmentTransaction ft = manager.beginTransaction(); + private void setupTabs() { + int[] icons = new int[] { R.drawable.ic_tab_contacts, R.drawable.ic_tab_groups, R.drawable.ic_tab_recent }; - ft.add(R.id.fragment_container, fragment); - ft.commit(); + for (int i = 0; i < icons.length; i++) { + ActionBar.Tab tab = getSupportActionBar().newTab(); + tab.setIcon(icons[i]); + tab.setTabListener(new ViewPagerTabListener(i)); + getSupportActionBar().addTab(tab); + } + } + + private void setupFragments() { + contactsFragment = new ContactSelectionListFragment(); + groupsFragment = new ContactSelectionGroupsFragment(); + recentFragment = new ContactSelectionRecentFragment(); + } + + private class SelectionPagerAdapter extends FragmentPagerAdapter { + + public SelectionPagerAdapter() { + super(getSupportFragmentManager()); + } + + @Override + public Fragment getItem(int i) { + switch (i) { + case 0: + return contactsFragment; + case 1: + return groupsFragment; + case 2: + default: + return recentFragment; } + } - @Override - public void onTabUnselected(Tab tab, FragmentTransaction ignore) { - FragmentManager manager = ContactSelectionActivity.this.getSupportFragmentManager(); - FragmentTransaction ft = manager.beginTransaction(); - ft.remove(fragment); - ft.commit(); - } - @Override - public void onTabReselected(Tab tab, FragmentTransaction ft) {} - }); + @Override + public int getCount() { + return 3; + } - return tab; } - private void setupContactsTab() { - contactsFragment = (ContactSelectionListFragment)Fragment.instantiate(this, - ContactSelectionListFragment.class.getName()); - ActionBar.Tab contactsTab = constructTab(contactsFragment); - contactsTab.setIcon(R.drawable.ic_tab_contacts); - this.getSupportActionBar().addTab(contactsTab); + private class ViewPagerTabListener implements TabListener { + + private int tabIndex; + + public ViewPagerTabListener(int index) { + tabIndex = index; + } + + @Override + public void onTabSelected(Tab tab, FragmentTransaction fragmentTransaction) { + viewPager.setCurrentItem(tabIndex); + } + + @Override + public void onTabUnselected(Tab tab, FragmentTransaction fragmentTransaction) { + + } + + @Override + public void onTabReselected(Tab tab, FragmentTransaction fragmentTransaction) { + + } + } - private void setupGroupsTab() { - groupsFragment = (ContactSelectionGroupsFragment)Fragment.instantiate(this, - ContactSelectionGroupsFragment.class.getName()); - ActionBar.Tab groupsTab = constructTab(groupsFragment); - groupsTab.setIcon(R.drawable.ic_tab_groups); - this.getSupportActionBar().addTab(groupsTab); + private class TabSwitchingPageListener implements ViewPager.OnPageChangeListener { + + @Override + public void onPageScrolled(int i, float v, int i2) { + + } + + @Override + public void onPageSelected(int i) { + getSupportActionBar().setSelectedNavigationItem(i); + } + + @Override + public void onPageScrollStateChanged(int i) { + + } + } - private void setupRecentTab() { - recentFragment = (ContactSelectionRecentFragment)Fragment.instantiate(this, - ContactSelectionRecentFragment.class.getName()); - - ActionBar.Tab recentTab = constructTab(recentFragment); - recentTab.setIcon(R.drawable.ic_tab_recent); - this.getSupportActionBar().addTab(recentTab); - } } From bee964dcf84a0eaee7807858246332d3177139ed Mon Sep 17 00:00:00 2001 From: Veeti Paananen Date: Mon, 16 Dec 2013 22:27:10 +0200 Subject: [PATCH 2/2] Improve appearance of "no contacts" indicators by centering them. Also remove pointless scroll views. --- .../contact_selection_group_activity.xml | 24 ++++++------------- .../contact_selection_list_activity.xml | 21 +++++----------- .../contact_selection_recent_activity.xml | 22 +++++------------ 3 files changed, 19 insertions(+), 48 deletions(-) diff --git a/res/layout/contact_selection_group_activity.xml b/res/layout/contact_selection_group_activity.xml index 40e4900d66..7cb1ffdd72 100644 --- a/res/layout/contact_selection_group_activity.xml +++ b/res/layout/contact_selection_group_activity.xml @@ -2,27 +2,17 @@ android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical"> - + - - - - + android:textSize="20sp" /> + \ No newline at end of file diff --git a/res/layout/contact_selection_list_activity.xml b/res/layout/contact_selection_list_activity.xml index 24e91a0cfc..272840e04a 100644 --- a/res/layout/contact_selection_list_activity.xml +++ b/res/layout/contact_selection_list_activity.xml @@ -9,20 +9,11 @@ android:layout_height="fill_parent" android:fastScrollEnabled="true" /> - - - + android:textSize="20sp" /> + diff --git a/res/layout/contact_selection_recent_activity.xml b/res/layout/contact_selection_recent_activity.xml index 15b6d260a0..8a5fa6c0e9 100644 --- a/res/layout/contact_selection_recent_activity.xml +++ b/res/layout/contact_selection_recent_activity.xml @@ -10,21 +10,11 @@ android:layout_height="fill_parent" android:fastScrollEnabled="true" /> - - - - + android:textSize="20sp" /> +