Browse Source

Remove avatar image view & add server url switch

Signed-off-by: Mario Danic <mario@lovelyhq.com>
Mario Danic 7 years ago
parent
commit
787e742301

+ 0 - 2
app/build.gradle

@@ -116,8 +116,6 @@ dependencies {
     implementation 'eu.davidea:flexible-adapter:5.0.0-rc4'
     implementation 'eu.davidea:flexible-adapter:5.0.0-rc4'
     implementation 'eu.davidea:flexible-adapter-ui:1.0.0-b1'
     implementation 'eu.davidea:flexible-adapter-ui:1.0.0-b1'
 
 
-    implementation 'cn.carbs.android:AvatarImageView:1.0.4'
-
     implementation 'com.github.bumptech.glide:glide:4.3.0'
     implementation 'com.github.bumptech.glide:glide:4.3.0'
     annotationProcessor 'com.github.bumptech.glide:compiler:4.3.0'
     annotationProcessor 'com.github.bumptech.glide:compiler:4.3.0'
     implementation 'com.github.bumptech.glide:okhttp3-integration:4.3.0@aar'
     implementation 'com.github.bumptech.glide:okhttp3-integration:4.3.0@aar'

+ 150 - 0
app/src/main/java/com/nextcloud/talk/adapters/items/AdvancedUserItem.java

@@ -0,0 +1,150 @@
+/*
+ * Nextcloud Talk application
+ *
+ * @author Mario Danic
+ * Copyright (C) 2017 Mario Danic (mario@lovelyhq.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
+ * the Free Software Foundation, either version 3 of the License, or
+ * at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+package com.nextcloud.talk.adapters.items;
+
+import android.view.View;
+import android.widget.ImageView;
+import android.widget.TextView;
+
+import com.bumptech.glide.load.engine.DiskCacheStrategy;
+import com.bumptech.glide.load.model.GlideUrl;
+import com.bumptech.glide.load.model.LazyHeaders;
+import com.bumptech.glide.load.resource.bitmap.CircleCrop;
+import com.bumptech.glide.request.RequestOptions;
+import com.nextcloud.talk.R;
+import com.nextcloud.talk.api.helpers.api.ApiHelper;
+import com.nextcloud.talk.api.models.json.participants.Participant;
+import com.nextcloud.talk.application.NextcloudTalkApplication;
+import com.nextcloud.talk.persistence.entities.UserEntity;
+import com.nextcloud.talk.utils.glide.GlideApp;
+
+import org.apache.commons.lang3.StringUtils;
+
+import java.util.List;
+
+import butterknife.BindView;
+import butterknife.ButterKnife;
+import eu.davidea.flexibleadapter.FlexibleAdapter;
+import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
+import eu.davidea.flexibleadapter.items.IFilterable;
+import eu.davidea.flexibleadapter.utils.FlexibleUtils;
+import eu.davidea.viewholders.FlexibleViewHolder;
+
+public class AdvancedUserItem extends AbstractFlexibleItem<AdvancedUserItem.UserItemViewHolder> implements IFilterable {
+
+    private Participant participant;
+    private UserEntity userEntity;
+
+    public AdvancedUserItem(Participant participant, UserEntity userEntity) {
+        this.participant = participant;
+        this.userEntity = userEntity;
+    }
+
+    @Override
+    public boolean equals(Object o) {
+        if (o instanceof UserItem) {
+            UserItem inItem = (UserItem) o;
+            return participant.equals(inItem.getModel());
+        }
+        return false;
+    }
+
+    @Override
+    public int hashCode() {
+        return participant.hashCode();
+    }
+
+    /**
+     * @return the model object
+     */
+
+    public Participant getModel() {
+        return participant;
+    }
+
+    public UserEntity getEntity() {
+        return userEntity;
+    }
+
+    @Override
+    public int getLayoutRes() {
+        return R.layout.rv_item_call;
+    }
+
+    @Override
+    public UserItemViewHolder createViewHolder(View view, FlexibleAdapter adapter) {
+        return new UserItemViewHolder(view, adapter);
+    }
+
+    @Override
+    public void bindViewHolder(FlexibleAdapter adapter, UserItemViewHolder holder, int position, List payloads) {
+        if (adapter.hasSearchText()) {
+            FlexibleUtils.highlightText(holder.contactDisplayName, participant.getName(), adapter.getSearchText());
+        } else {
+            holder.contactDisplayName.setText(participant.getName());
+        }
+
+        holder.serverUrl.setText(userEntity.getBaseUrl());
+
+        GlideUrl glideUrl = new GlideUrl(ApiHelper.getUrlForAvatarWithName(userEntity.getBaseUrl(),
+                participant.getUserId()), new LazyHeaders.Builder()
+                .setHeader("Accept", "image/*")
+                .setHeader("User-Agent", ApiHelper.getUserAgent())
+                .build());
+
+        GlideApp.with(NextcloudTalkApplication.getSharedApplication().getApplicationContext())
+                .asBitmap()
+                .skipMemoryCache(true)
+                .diskCacheStrategy(DiskCacheStrategy.NONE)
+                .load(glideUrl)
+                .centerInside()
+                .apply(RequestOptions.bitmapTransform(new CircleCrop()))
+                .into(holder.avatarImageView)
+        ;
+    }
+
+    @Override
+    public boolean filter(String constraint) {
+        return participant.getName() != null &&
+                StringUtils.containsIgnoreCase(participant.getName().trim(), constraint);
+    }
+
+
+    static class UserItemViewHolder extends FlexibleViewHolder {
+
+        @BindView(R.id.name_text)
+        public TextView contactDisplayName;
+        @BindView(R.id.secondary_text)
+        public TextView serverUrl;
+        @BindView(R.id.avatar_image)
+        public ImageView avatarImageView;
+
+        /**
+         * Default constructor.
+         */
+        UserItemViewHolder(View view, FlexibleAdapter adapter) {
+            super(view, adapter);
+            ButterKnife.bind(this, view);
+        }
+    }
+
+
+}

+ 6 - 8
app/src/main/java/com/nextcloud/talk/adapters/items/CallItem.java

@@ -24,18 +24,20 @@ import android.text.TextUtils;
 import android.text.format.DateUtils;
 import android.text.format.DateUtils;
 import android.view.View;
 import android.view.View;
 import android.widget.ImageButton;
 import android.widget.ImageButton;
+import android.widget.ImageView;
 import android.widget.TextView;
 import android.widget.TextView;
 
 
 import com.bumptech.glide.load.engine.DiskCacheStrategy;
 import com.bumptech.glide.load.engine.DiskCacheStrategy;
 import com.bumptech.glide.load.model.GlideUrl;
 import com.bumptech.glide.load.model.GlideUrl;
 import com.bumptech.glide.load.model.LazyHeaders;
 import com.bumptech.glide.load.model.LazyHeaders;
+import com.bumptech.glide.load.resource.bitmap.CircleCrop;
+import com.bumptech.glide.request.RequestOptions;
 import com.nextcloud.talk.R;
 import com.nextcloud.talk.R;
 import com.nextcloud.talk.api.helpers.api.ApiHelper;
 import com.nextcloud.talk.api.helpers.api.ApiHelper;
 import com.nextcloud.talk.api.models.json.rooms.Room;
 import com.nextcloud.talk.api.models.json.rooms.Room;
 import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.events.MoreMenuClickEvent;
 import com.nextcloud.talk.events.MoreMenuClickEvent;
 import com.nextcloud.talk.persistence.entities.UserEntity;
 import com.nextcloud.talk.persistence.entities.UserEntity;
-import com.nextcloud.talk.utils.ColorUtils;
 import com.nextcloud.talk.utils.glide.GlideApp;
 import com.nextcloud.talk.utils.glide.GlideApp;
 
 
 import org.apache.commons.lang3.StringUtils;
 import org.apache.commons.lang3.StringUtils;
@@ -45,7 +47,6 @@ import java.util.List;
 
 
 import butterknife.BindView;
 import butterknife.BindView;
 import butterknife.ButterKnife;
 import butterknife.ButterKnife;
-import cn.carbs.android.avatarimageview.library.AvatarImageView;
 import eu.davidea.flexibleadapter.FlexibleAdapter;
 import eu.davidea.flexibleadapter.FlexibleAdapter;
 import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
 import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
 import eu.davidea.flexibleadapter.items.IFilterable;
 import eu.davidea.flexibleadapter.items.IFilterable;
@@ -119,9 +120,6 @@ public class CallItem extends AbstractFlexibleItem<CallItem.RoomItemViewHolder>
                 holder.avatarImageView.setVisibility(View.VISIBLE);
                 holder.avatarImageView.setVisibility(View.VISIBLE);
 
 
                 if (!TextUtils.isEmpty(room.getName())) {
                 if (!TextUtils.isEmpty(room.getName())) {
-                    holder.avatarImageView.setTextAndColorSeed(String.valueOf(room.getName().
-                            toUpperCase().charAt(0)), ColorUtils.colorSeed);
-
                     GlideUrl glideUrl = new GlideUrl(ApiHelper.getUrlForAvatarWithName(userEntity.getBaseUrl(),
                     GlideUrl glideUrl = new GlideUrl(ApiHelper.getUrlForAvatarWithName(userEntity.getBaseUrl(),
                             room.getName()), new LazyHeaders.Builder()
                             room.getName()), new LazyHeaders.Builder()
                             .setHeader("Accept", "image/*")
                             .setHeader("Accept", "image/*")
@@ -133,8 +131,8 @@ public class CallItem extends AbstractFlexibleItem<CallItem.RoomItemViewHolder>
                             .skipMemoryCache(true)
                             .skipMemoryCache(true)
                             .diskCacheStrategy(DiskCacheStrategy.NONE)
                             .diskCacheStrategy(DiskCacheStrategy.NONE)
                             .load(glideUrl)
                             .load(glideUrl)
-                            .circleCrop()
                             .centerInside()
                             .centerInside()
+                            .apply(RequestOptions.bitmapTransform(new CircleCrop()))
                             .into(holder.avatarImageView);
                             .into(holder.avatarImageView);
 
 
                 } else {
                 } else {
@@ -168,10 +166,10 @@ public class CallItem extends AbstractFlexibleItem<CallItem.RoomItemViewHolder>
 
 
         @BindView(R.id.name_text)
         @BindView(R.id.name_text)
         public TextView roomDisplayName;
         public TextView roomDisplayName;
-        @BindView(R.id.timestamp_text)
+        @BindView(R.id.secondary_text)
         public TextView roomLastPing;
         public TextView roomLastPing;
         @BindView(R.id.avatar_image)
         @BindView(R.id.avatar_image)
-        public AvatarImageView avatarImageView;
+        public ImageView avatarImageView;
         @BindView(R.id.more_menu)
         @BindView(R.id.more_menu)
         public ImageButton moreMenuButton;
         public ImageButton moreMenuButton;
 
 

+ 5 - 8
app/src/main/java/com/nextcloud/talk/adapters/items/UserItem.java

@@ -21,17 +21,19 @@
 package com.nextcloud.talk.adapters.items;
 package com.nextcloud.talk.adapters.items;
 
 
 import android.view.View;
 import android.view.View;
+import android.widget.ImageView;
 import android.widget.TextView;
 import android.widget.TextView;
 
 
 import com.bumptech.glide.load.engine.DiskCacheStrategy;
 import com.bumptech.glide.load.engine.DiskCacheStrategy;
 import com.bumptech.glide.load.model.GlideUrl;
 import com.bumptech.glide.load.model.GlideUrl;
 import com.bumptech.glide.load.model.LazyHeaders;
 import com.bumptech.glide.load.model.LazyHeaders;
+import com.bumptech.glide.load.resource.bitmap.CircleCrop;
+import com.bumptech.glide.request.RequestOptions;
 import com.nextcloud.talk.R;
 import com.nextcloud.talk.R;
 import com.nextcloud.talk.api.helpers.api.ApiHelper;
 import com.nextcloud.talk.api.helpers.api.ApiHelper;
 import com.nextcloud.talk.api.models.json.participants.Participant;
 import com.nextcloud.talk.api.models.json.participants.Participant;
 import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.persistence.entities.UserEntity;
 import com.nextcloud.talk.persistence.entities.UserEntity;
-import com.nextcloud.talk.utils.ColorUtils;
 import com.nextcloud.talk.utils.glide.GlideApp;
 import com.nextcloud.talk.utils.glide.GlideApp;
 
 
 import org.apache.commons.lang3.StringUtils;
 import org.apache.commons.lang3.StringUtils;
@@ -40,7 +42,6 @@ import java.util.List;
 
 
 import butterknife.BindView;
 import butterknife.BindView;
 import butterknife.ButterKnife;
 import butterknife.ButterKnife;
-import cn.carbs.android.avatarimageview.library.AvatarImageView;
 import eu.davidea.flexibleadapter.FlexibleAdapter;
 import eu.davidea.flexibleadapter.FlexibleAdapter;
 import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
 import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
 import eu.davidea.flexibleadapter.items.IFilterable;
 import eu.davidea.flexibleadapter.items.IFilterable;
@@ -101,10 +102,6 @@ public class UserItem extends AbstractFlexibleItem<UserItem.UserItemViewHolder>
             holder.contactDisplayName.setText(participant.getName());
             holder.contactDisplayName.setText(participant.getName());
         }
         }
 
 
-        // Awful hack
-        holder.avatarImageView.setTextAndColorSeed(String.valueOf(participant.getName().
-                toUpperCase().charAt(0)), ColorUtils.colorSeed);
-
         GlideUrl glideUrl = new GlideUrl(ApiHelper.getUrlForAvatarWithName(userEntity.getBaseUrl(),
         GlideUrl glideUrl = new GlideUrl(ApiHelper.getUrlForAvatarWithName(userEntity.getBaseUrl(),
                 participant.getUserId()), new LazyHeaders.Builder()
                 participant.getUserId()), new LazyHeaders.Builder()
                 .setHeader("Accept", "image/*")
                 .setHeader("Accept", "image/*")
@@ -116,8 +113,8 @@ public class UserItem extends AbstractFlexibleItem<UserItem.UserItemViewHolder>
                 .skipMemoryCache(true)
                 .skipMemoryCache(true)
                 .diskCacheStrategy(DiskCacheStrategy.NONE)
                 .diskCacheStrategy(DiskCacheStrategy.NONE)
                 .load(glideUrl)
                 .load(glideUrl)
-                .circleCrop()
                 .centerInside()
                 .centerInside()
+                .apply(RequestOptions.bitmapTransform(new CircleCrop()))
                 .into(holder.avatarImageView);
                 .into(holder.avatarImageView);
     }
     }
 
 
@@ -133,7 +130,7 @@ public class UserItem extends AbstractFlexibleItem<UserItem.UserItemViewHolder>
         @BindView(R.id.name_text)
         @BindView(R.id.name_text)
         public TextView contactDisplayName;
         public TextView contactDisplayName;
         @BindView(R.id.avatar_image)
         @BindView(R.id.avatar_image)
-        public AvatarImageView avatarImageView;
+        public ImageView avatarImageView;
 
 
         /**
         /**
          * Default constructor.
          * Default constructor.

+ 5 - 7
app/src/main/java/com/nextcloud/talk/controllers/SettingsController.java

@@ -30,12 +30,15 @@ import android.text.TextUtils;
 import android.view.LayoutInflater;
 import android.view.LayoutInflater;
 import android.view.View;
 import android.view.View;
 import android.view.ViewGroup;
 import android.view.ViewGroup;
+import android.widget.ImageView;
 import android.widget.TextView;
 import android.widget.TextView;
 
 
 import com.bluelinelabs.conductor.RouterTransaction;
 import com.bluelinelabs.conductor.RouterTransaction;
 import com.bluelinelabs.conductor.changehandler.VerticalChangeHandler;
 import com.bluelinelabs.conductor.changehandler.VerticalChangeHandler;
 import com.bumptech.glide.load.model.GlideUrl;
 import com.bumptech.glide.load.model.GlideUrl;
 import com.bumptech.glide.load.model.LazyHeaders;
 import com.bumptech.glide.load.model.LazyHeaders;
+import com.bumptech.glide.load.resource.bitmap.CircleCrop;
+import com.bumptech.glide.request.RequestOptions;
 import com.evernote.android.job.JobRequest;
 import com.evernote.android.job.JobRequest;
 import com.nextcloud.talk.BuildConfig;
 import com.nextcloud.talk.BuildConfig;
 import com.nextcloud.talk.R;
 import com.nextcloud.talk.R;
@@ -45,7 +48,6 @@ import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.controllers.base.BaseController;
 import com.nextcloud.talk.controllers.base.BaseController;
 import com.nextcloud.talk.jobs.AccountRemovalJob;
 import com.nextcloud.talk.jobs.AccountRemovalJob;
 import com.nextcloud.talk.persistence.entities.UserEntity;
 import com.nextcloud.talk.persistence.entities.UserEntity;
-import com.nextcloud.talk.utils.ColorUtils;
 import com.nextcloud.talk.utils.ErrorMessageHolder;
 import com.nextcloud.talk.utils.ErrorMessageHolder;
 import com.nextcloud.talk.utils.database.user.UserUtils;
 import com.nextcloud.talk.utils.database.user.UserUtils;
 import com.nextcloud.talk.utils.glide.GlideApp;
 import com.nextcloud.talk.utils.glide.GlideApp;
@@ -70,7 +72,6 @@ import javax.inject.Inject;
 
 
 import autodagger.AutoInjector;
 import autodagger.AutoInjector;
 import butterknife.BindView;
 import butterknife.BindView;
-import cn.carbs.android.avatarimageview.library.AvatarImageView;
 import io.reactivex.android.schedulers.AndroidSchedulers;
 import io.reactivex.android.schedulers.AndroidSchedulers;
 import io.reactivex.disposables.Disposable;
 import io.reactivex.disposables.Disposable;
 import io.reactivex.schedulers.Schedulers;
 import io.reactivex.schedulers.Schedulers;
@@ -102,7 +103,7 @@ public class SettingsController extends BaseController {
     MaterialStandardPreference versionInfo;
     MaterialStandardPreference versionInfo;
 
 
     @BindView(R.id.avatar_image)
     @BindView(R.id.avatar_image)
-    AvatarImageView avatarImageView;
+    ImageView avatarImageView;
 
 
     @BindView(R.id.display_name_text)
     @BindView(R.id.display_name_text)
     TextView displayNameTextView;
     TextView displayNameTextView;
@@ -264,10 +265,7 @@ public class SettingsController extends BaseController {
                 reauthorizeButton.setEnabled(true);
                 reauthorizeButton.setEnabled(true);
             });
             });
 
 
-            // Awful hack
             if (userEntity.getDisplayName() != null) {
             if (userEntity.getDisplayName() != null) {
-                avatarImageView.setTextAndColorSeed(String.valueOf(userEntity.getDisplayName().
-                        toUpperCase().charAt(0)), ColorUtils.colorSeed);
                 displayNameTextView.setText(userEntity.getDisplayName());
                 displayNameTextView.setText(userEntity.getDisplayName());
             }
             }
 
 
@@ -279,8 +277,8 @@ public class SettingsController extends BaseController {
 
 
             GlideApp.with(NextcloudTalkApplication.getSharedApplication().getApplicationContext())
             GlideApp.with(NextcloudTalkApplication.getSharedApplication().getApplicationContext())
                     .load(glideUrl)
                     .load(glideUrl)
-                    .circleCrop()
                     .centerInside()
                     .centerInside()
+                    .apply(RequestOptions.bitmapTransform(new CircleCrop()))
                     .into(avatarImageView);
                     .into(avatarImageView);
 
 
             profileQueryDisposable = ncApi.getUserProfile(ApiHelper.getCredentials(userEntity.getUsername(),
             profileQueryDisposable = ncApi.getUserProfile(ApiHelper.getCredentials(userEntity.getUsername(),

+ 6 - 5
app/src/main/java/com/nextcloud/talk/controllers/SwitchAccountController.java

@@ -30,7 +30,7 @@ import android.view.View;
 import android.view.ViewGroup;
 import android.view.ViewGroup;
 
 
 import com.nextcloud.talk.R;
 import com.nextcloud.talk.R;
-import com.nextcloud.talk.adapters.items.UserItem;
+import com.nextcloud.talk.adapters.items.AdvancedUserItem;
 import com.nextcloud.talk.api.models.json.participants.Participant;
 import com.nextcloud.talk.api.models.json.participants.Participant;
 import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.application.NextcloudTalkApplication;
 import com.nextcloud.talk.controllers.base.BaseController;
 import com.nextcloud.talk.controllers.base.BaseController;
@@ -47,6 +47,7 @@ import autodagger.AutoInjector;
 import butterknife.BindView;
 import butterknife.BindView;
 import eu.davidea.flexibleadapter.FlexibleAdapter;
 import eu.davidea.flexibleadapter.FlexibleAdapter;
 import eu.davidea.flexibleadapter.common.SmoothScrollLinearLayoutManager;
 import eu.davidea.flexibleadapter.common.SmoothScrollLinearLayoutManager;
+import eu.davidea.flexibleadapter.items.AbstractFlexibleItem;
 import io.reactivex.Observer;
 import io.reactivex.Observer;
 import io.reactivex.disposables.Disposable;
 import io.reactivex.disposables.Disposable;
 
 
@@ -64,15 +65,15 @@ public class SwitchAccountController extends BaseController {
 
 
     @BindView(R.id.swipe_refresh_layout)
     @BindView(R.id.swipe_refresh_layout)
     SwipeRefreshLayout swipeRefreshLayout;
     SwipeRefreshLayout swipeRefreshLayout;
-    private FlexibleAdapter<UserItem> adapter;
-    private List<UserItem> userItems = new ArrayList<>();
+    private FlexibleAdapter<AbstractFlexibleItem> adapter;
+    private List<AbstractFlexibleItem> userItems = new ArrayList<>();
 
 
     private FlexibleAdapter.OnItemClickListener onItemClickListener =
     private FlexibleAdapter.OnItemClickListener onItemClickListener =
             new FlexibleAdapter.OnItemClickListener() {
             new FlexibleAdapter.OnItemClickListener() {
                 @Override
                 @Override
                 public boolean onItemClick(int position) {
                 public boolean onItemClick(int position) {
                     if (userItems.size() > position) {
                     if (userItems.size() > position) {
-                        UserEntity userEntity = userItems.get(position).getEntity();
+                        UserEntity userEntity = ((AdvancedUserItem) userItems.get(position)).getEntity();
                         userUtils.createOrUpdateUser(userEntity.getUsername(),
                         userUtils.createOrUpdateUser(userEntity.getUsername(),
                                 userEntity.getToken(), userEntity.getBaseUrl(), null,
                                 userEntity.getToken(), userEntity.getBaseUrl(), null,
                                 null, true)
                                 null, true)
@@ -128,7 +129,7 @@ public class SwitchAccountController extends BaseController {
                     participant = new Participant();
                     participant = new Participant();
                     participant.setName(userEntity.getDisplayName());
                     participant.setName(userEntity.getDisplayName());
                     participant.setUserId(userEntity.getUsername());
                     participant.setUserId(userEntity.getUsername());
-                    userItems.add(new UserItem(participant, userEntity));
+                    userItems.add(new AdvancedUserItem(participant, userEntity));
                 }
                 }
             }
             }
 
 

+ 2 - 6
app/src/main/res/layout/controller_settings.xml

@@ -47,15 +47,11 @@
             android:layout_width="match_parent"
             android:layout_width="match_parent"
             android:layout_height="wrap_content">
             android:layout_height="wrap_content">
 
 
-            <cn.carbs.android.avatarimageview.library.AvatarImageView
+            <ImageView
                 android:id="@+id/avatar_image"
                 android:id="@+id/avatar_image"
                 android:layout_width="@dimen/avatar_size_big"
                 android:layout_width="@dimen/avatar_size_big"
                 android:layout_height="@dimen/avatar_size_big"
                 android:layout_height="@dimen/avatar_size_big"
-                android:layout_centerHorizontal="true"
-                android:scaleType="centerInside"
-                apc:aiv_CornerRadius="@dimen/avatar_corner_radius"
-                apc:aiv_ShowBoarder="false"
-                apc:aiv_TextSizeRatio="0.5"/>
+                android:layout_centerHorizontal="true"/>
 
 
             <TextView
             <TextView
                 android:id="@+id/display_name_text"
                 android:id="@+id/display_name_text"

+ 3 - 7
app/src/main/res/layout/rv_item_call.xml

@@ -27,17 +27,13 @@
                 android:layout_width="match_parent"
                 android:layout_width="match_parent"
                 android:layout_height="@dimen/item_height">
                 android:layout_height="@dimen/item_height">
 
 
-    <cn.carbs.android.avatarimageview.library.AvatarImageView
+    <ImageView
         android:id="@+id/avatar_image"
         android:id="@+id/avatar_image"
         android:layout_width="@dimen/avatar_size"
         android:layout_width="@dimen/avatar_size"
         android:layout_height="@dimen/avatar_size"
         android:layout_height="@dimen/avatar_size"
         android:layout_centerVertical="true"
         android:layout_centerVertical="true"
         android:layout_marginEnd="@dimen/margin_between_elements"
         android:layout_marginEnd="@dimen/margin_between_elements"
-        android:layout_marginStart="@dimen/activity_horizontal_margin"
-        android:scaleType="centerInside"
-        app:aiv_CornerRadius="@dimen/avatar_corner_radius"
-        app:aiv_ShowBoarder="false"
-        app:aiv_TextSizeRatio="0.5"/>
+        android:layout_marginStart="@dimen/activity_horizontal_margin"/>
 
 
     <LinearLayout
     <LinearLayout
         android:id="@+id/linear_layout"
         android:id="@+id/linear_layout"
@@ -58,7 +54,7 @@
             tools:text="Call item text"/>
             tools:text="Call item text"/>
 
 
         <TextView
         <TextView
-            android:id="@+id/timestamp_text"
+            android:id="@+id/secondary_text"
             android:layout_width="match_parent"
             android:layout_width="match_parent"
             android:layout_height="wrap_content"
             android:layout_height="wrap_content"
             android:singleLine="true"
             android:singleLine="true"

+ 2 - 6
app/src/main/res/layout/rv_item_contact.xml

@@ -28,17 +28,13 @@
                 android:layout_height="@dimen/item_height"
                 android:layout_height="@dimen/item_height"
                 android:orientation="vertical">
                 android:orientation="vertical">
 
 
-    <cn.carbs.android.avatarimageview.library.AvatarImageView
+    <ImageView
         android:id="@+id/avatar_image"
         android:id="@+id/avatar_image"
         android:layout_width="@dimen/avatar_size"
         android:layout_width="@dimen/avatar_size"
         android:layout_height="@dimen/avatar_size"
         android:layout_height="@dimen/avatar_size"
         android:layout_centerVertical="true"
         android:layout_centerVertical="true"
         android:layout_marginEnd="@dimen/activity_horizontal_margin"
         android:layout_marginEnd="@dimen/activity_horizontal_margin"
-        android:layout_marginStart="@dimen/activity_horizontal_margin"
-        android:scaleType="centerInside"
-        app:aiv_CornerRadius="@dimen/avatar_corner_radius"
-        app:aiv_ShowBoarder="false"
-        app:aiv_TextSizeRatio="0.5"/>
+        android:layout_marginStart="@dimen/activity_horizontal_margin"/>
 
 
     <TextView
     <TextView
         android:id="@+id/name_text"
         android:id="@+id/name_text"