From dac0f6417029b23cea8eb66a8ef813b909e39e40 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Adrien=20B=C3=A9raud?= <adrien.beraud@savoirfairelinux.com>
Date: Fri, 11 Dec 2015 14:32:20 -0500
Subject: [PATCH] contacts: group by upper-case first char

Tuleap: #178
Change-Id: I117e7f6c891e8d3d9e19e56634a8d021483eda83
---
 .../cx/ring/adapters/ContactsAdapter.java     | 40 +++++--------------
 1 file changed, 10 insertions(+), 30 deletions(-)

diff --git a/ring-android/app/src/main/java/cx/ring/adapters/ContactsAdapter.java b/ring-android/app/src/main/java/cx/ring/adapters/ContactsAdapter.java
index 63c10d9be..54aa4352f 100644
--- a/ring-android/app/src/main/java/cx/ring/adapters/ContactsAdapter.java
+++ b/ring-android/app/src/main/java/cx/ring/adapters/ContactsAdapter.java
@@ -2,6 +2,7 @@
  *  Copyright (C) 2004-2014 Savoir-Faire Linux Inc.
  *
  *  Author: Alexandre Lision <alexandre.lision@savoirfairelinux.com>
+ *  Author: Adrien Béraud <adrien.beraud@savoirfairelinux.com>
  *
  *  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
@@ -16,26 +17,13 @@
  *  You should have received a copy of the GNU General Public License
  *  along with this program; if not, write to the Free Software
  *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- *
- *  Additional permission under GNU GPL version 3 section 7:
- *
- *  If you modify this program, or any covered work, by linking or
- *  combining it with the OpenSSL project's OpenSSL library (or a
- *  modified version of that library), containing parts covered by the
- *  terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
- *  grants you additional permission to convey the resulting work.
- *  Corresponding Source for a non-source form of such a combination
- *  shall include the source code for the parts of OpenSSL used as well
- *  as that of the covered work.
  */
 
 package cx.ring.adapters;
 
 import java.lang.ref.WeakReference;
 import java.util.ArrayList;
-import java.util.HashMap;
 import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
 
 import cx.ring.R;
 import cx.ring.fragments.ContactListFragment;
@@ -44,8 +32,6 @@ import se.emilsjolander.stickylistheaders.StickyListHeadersAdapter;
 
 import android.content.Context;
 import android.graphics.Bitmap;
-import android.util.Log;
-import android.util.LongSparseArray;
 import android.util.LruCache;
 import android.view.LayoutInflater;
 import android.view.View;
@@ -83,18 +69,16 @@ public class ContactsAdapter extends BaseAdapter implements StickyListHeadersAda
         infos_fetcher = pool;
     }
 
-    public static final int TYPE_HEADER = 0;
-    public static final int TYPE_CONTACT = 1;
-
     private int[] getSectionIndices() {
-        ArrayList<Integer> sectionIndices = new ArrayList<>();
+        ArrayList<Integer> sectionIndices = new ArrayList<>(32);
         if (mContacts.isEmpty())
             return new int[0];
-        char lastFirstChar = mContacts.get(0).getDisplayName().charAt(0);
+        char lastFirstChar = Character.toUpperCase(mContacts.get(0).getDisplayName().charAt(0));
         sectionIndices.add(0);
         for (int i = 1; i < mContacts.size(); i++) {
-            if (mContacts.get(i).getDisplayName().charAt(0) != lastFirstChar) {
-                lastFirstChar = mContacts.get(i).getDisplayName().charAt(0);
+            char c = Character.toUpperCase(mContacts.get(i).getDisplayName().charAt(0));
+            if (c != lastFirstChar) {
+                lastFirstChar = c;
                 sectionIndices.add(i);
             }
         }
@@ -107,9 +91,8 @@ public class ContactsAdapter extends BaseAdapter implements StickyListHeadersAda
 
     private Character[] getSectionLetters() {
         Character[] letters = new Character[mSectionIndices.length];
-        for (int i = 0; i < mSectionIndices.length; i++) {
-            letters[i] = mContacts.get(mSectionIndices[i]).getDisplayName().charAt(0);
-        }
+        for (int i = 0; i < mSectionIndices.length; i++)
+            letters[i] = Character.toUpperCase(mContacts.get(mSectionIndices[i]).getDisplayName().charAt(0));
         return letters;
     }
 
@@ -234,12 +217,9 @@ public class ContactsAdapter extends BaseAdapter implements StickyListHeadersAda
         }
 
         // set header text as first char in name
-        char headerChar = mContacts.get(position).getDisplayName().subSequence(0, 1).charAt(0);
-
-        holder.text.setText("" + headerChar);
+        holder.text.setText(String.valueOf(Character.toUpperCase(mContacts.get(position).getDisplayName().charAt(0))));
 
         return convertView;
-
     }
 
     class HeaderViewHolder {
@@ -250,7 +230,7 @@ public class ContactsAdapter extends BaseAdapter implements StickyListHeadersAda
     public long getHeaderId(int position) {
         // return the first character of the name as ID because this is what
         // headers are based upon
-        return mContacts.get(position).getDisplayName().subSequence(0, 1).charAt(0);
+        return Character.toUpperCase(mContacts.get(position).getDisplayName().charAt(0));
     }
 
     @Override
-- 
GitLab