mirror of
https://github.com/nextcloud/talk-android
synced 2025-06-23 05:29:54 +01:00
Remove avatar image view & add server url switch
Signed-off-by: Mario Danic <mario@lovelyhq.com>
This commit is contained in:
parent
70381bb36b
commit
787e742301
@ -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'
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -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;
|
||||||
|
|
||||||
|
@ -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.
|
||||||
|
@ -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(),
|
||||||
|
@ -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 FlexibleAdapter<AbstractFlexibleItem> adapter;
|
||||||
private List<UserItem> userItems = new ArrayList<>();
|
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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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:layout_centerHorizontal="true"/>
|
||||||
android:scaleType="centerInside"
|
|
||||||
apc:aiv_CornerRadius="@dimen/avatar_corner_radius"
|
|
||||||
apc:aiv_ShowBoarder="false"
|
|
||||||
apc:aiv_TextSizeRatio="0.5"/>
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/display_name_text"
|
android:id="@+id/display_name_text"
|
||||||
|
@ -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: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"/>
|
|
||||||
|
|
||||||
<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"
|
||||||
|
@ -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: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"/>
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name_text"
|
android:id="@+id/name_text"
|
||||||
|
Loading…
Reference in New Issue
Block a user