Commit b235eb16 authored by Filipe de Lima Brito's avatar Filipe de Lima Brito

Update some classes

parent 0595999e
...@@ -6,8 +6,6 @@ import android.graphics.Canvas; ...@@ -6,8 +6,6 @@ import android.graphics.Canvas;
import android.graphics.Typeface; import android.graphics.Typeface;
import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.support.graphics.drawable.VectorDrawableCompat;
import chat.rocket.android.R;
import chat.rocket.android.log.RCLog; import chat.rocket.android.log.RCLog;
import chat.rocket.android.widget.AbsoluteUrl; import chat.rocket.android.widget.AbsoluteUrl;
import chat.rocket.android.widget.RocketChatAvatar; import chat.rocket.android.widget.RocketChatAvatar;
...@@ -87,17 +85,11 @@ public class Avatar { ...@@ -87,17 +85,11 @@ public class Avatar {
/** /**
* render avatar into RocketChatAvatar. * render avatar into RocketChatAvatar.
*/ */
public void into(final RocketChatAvatar rocketChatAvatar) { public void into(final RocketChatAvatar rocketChatAvatar, boolean showFailureImage) {
final Context context = rocketChatAvatar.getContext(); if (showFailureImage)
rocketChatAvatar.loadImage(getImageUrl(), getTextDrawable(context)); rocketChatAvatar.showFailureImage();
} else
rocketChatAvatar.loadImage(getImageUrl());
/**
* render error avatar into RocketChatAvatar.
*/
public void errorInto(final RocketChatAvatar rocketChatAvatar) {
final Context context = rocketChatAvatar.getContext();
rocketChatAvatar.loadImage(VectorDrawableCompat.create(context.getResources(), R.drawable.ic_error_outline_black_24dp, null));
} }
public Drawable getTextDrawable(Context context) { public Drawable getTextDrawable(Context context) {
......
...@@ -25,13 +25,13 @@ public abstract class AbstractMessageViewHolder extends ModelViewHolder<PairedMe ...@@ -25,13 +25,13 @@ public abstract class AbstractMessageViewHolder extends ModelViewHolder<PairedMe
*/ */
public AbstractMessageViewHolder(View itemView, AbsoluteUrl absoluteUrl) { public AbstractMessageViewHolder(View itemView, AbsoluteUrl absoluteUrl) {
super(itemView); super(itemView);
avatar = (RocketChatAvatar) itemView.findViewById(R.id.user_avatar); avatar = itemView.findViewById(R.id.user_avatar);
username = (TextView) itemView.findViewById(R.id.username); username = itemView.findViewById(R.id.username);
subUsername = (TextView) itemView.findViewById(R.id.sub_username); subUsername = itemView.findViewById(R.id.sub_username);
timestamp = (TextView) itemView.findViewById(R.id.timestamp); timestamp = itemView.findViewById(R.id.timestamp);
userAndTimeContainer = itemView.findViewById(R.id.user_and_timestamp_container); userAndTimeContainer = itemView.findViewById(R.id.user_and_timestamp_container);
newDayContainer = itemView.findViewById(R.id.newday_container); newDayContainer = itemView.findViewById(R.id.newday_container);
newDayText = (TextView) itemView.findViewById(R.id.newday_text); newDayText = itemView.findViewById(R.id.newday_text);
this.absoluteUrl = absoluteUrl; this.absoluteUrl = absoluteUrl;
} }
...@@ -39,12 +39,10 @@ public abstract class AbstractMessageViewHolder extends ModelViewHolder<PairedMe ...@@ -39,12 +39,10 @@ public abstract class AbstractMessageViewHolder extends ModelViewHolder<PairedMe
* bind the view model. * bind the view model.
*/ */
public final void bind(PairedMessage pairedMessage, boolean autoloadImages) { public final void bind(PairedMessage pairedMessage, boolean autoloadImages) {
if (pairedMessage.target != null) {
if (pairedMessage.target.getSyncState() != SyncState.SYNCED) if (pairedMessage.target.getSyncState() != SyncState.SYNCED)
itemView.setAlpha(0.6f); itemView.setAlpha(0.6f);
else else
itemView.setAlpha(1.0f); itemView.setAlpha(1.0f);
}
bindMessage(pairedMessage, autoloadImages); bindMessage(pairedMessage, autoloadImages);
renderNewDayAndSequential(pairedMessage); renderNewDayAndSequential(pairedMessage);
......
...@@ -58,12 +58,12 @@ public class RoomUserAdapter extends RecyclerView.Adapter<RoomUserViewHolder> { ...@@ -58,12 +58,12 @@ public class RoomUserAdapter extends RecyclerView.Adapter<RoomUserViewHolder> {
.setUtcOffset(0) .setUtcOffset(0)
.build(); .build();
new UserRenderer(context, user) new UserRenderer(context, user)
.avatarInto(holder.avatar, absoluteUrl) .avatarInto(holder.avatar, absoluteUrl, false)
.usernameInto(holder.username); .usernameInto(holder.username);
} else { } else {
new UserRenderer(context, realmUser.asUser()) new UserRenderer(context, realmUser.asUser())
.statusColorInto(holder.status) .statusColorInto(holder.status)
.avatarInto(holder.avatar, absoluteUrl) .avatarInto(holder.avatar, absoluteUrl, false)
.usernameInto(holder.username); .usernameInto(holder.username);
} }
} }
......
...@@ -28,7 +28,7 @@ public class SuggestUserAdapter extends RealmAutoCompleteAdapter<RealmUser> { ...@@ -28,7 +28,7 @@ public class SuggestUserAdapter extends RealmAutoCompleteAdapter<RealmUser> {
protected void onBindItemView(View itemView, RealmUser user) { protected void onBindItemView(View itemView, RealmUser user) {
new UserRenderer(itemView.getContext(), user.asUser()) new UserRenderer(itemView.getContext(), user.asUser())
.statusColorInto((ImageView) itemView.findViewById(R.id.room_user_status)) .statusColorInto((ImageView) itemView.findViewById(R.id.room_user_status))
.avatarInto((RocketChatAvatar) itemView.findViewById(R.id.room_user_avatar), absoluteUrl); .avatarInto((RocketChatAvatar) itemView.findViewById(R.id.room_user_avatar), absoluteUrl, false);
} }
@Override @Override
......
...@@ -4,7 +4,6 @@ import android.content.Context; ...@@ -4,7 +4,6 @@ import android.content.Context;
import android.view.View; import android.view.View;
import android.widget.TextView; import android.widget.TextView;
import chat.rocket.android.R; import chat.rocket.android.R;
import chat.rocket.android.helper.Avatar;
import chat.rocket.android.helper.DateTime; import chat.rocket.android.helper.DateTime;
import chat.rocket.android.helper.TextUtils; import chat.rocket.android.helper.TextUtils;
import chat.rocket.android.widget.AbsoluteUrl; import chat.rocket.android.widget.AbsoluteUrl;
...@@ -15,7 +14,6 @@ import chat.rocket.android.widget.message.RocketChatMessageUrlsLayout; ...@@ -15,7 +14,6 @@ import chat.rocket.android.widget.message.RocketChatMessageUrlsLayout;
import chat.rocket.core.SyncState; import chat.rocket.core.SyncState;
import chat.rocket.core.models.Attachment; import chat.rocket.core.models.Attachment;
import chat.rocket.core.models.Message; import chat.rocket.core.models.Message;
import chat.rocket.core.models.User;
import chat.rocket.core.models.WebContent; import chat.rocket.core.models.WebContent;
import java.util.List; import java.util.List;
...@@ -37,20 +35,20 @@ public class MessageRenderer extends AbstractRenderer<Message> { ...@@ -37,20 +35,20 @@ public class MessageRenderer extends AbstractRenderer<Message> {
* show Avatar image. * show Avatar image.
*/ */
public MessageRenderer avatarInto(RocketChatAvatar rocketChatAvatar, AbsoluteUrl absoluteUrl) { public MessageRenderer avatarInto(RocketChatAvatar rocketChatAvatar, AbsoluteUrl absoluteUrl) {
if (!shouldHandle(rocketChatAvatar)) { if (!shouldHandle(rocketChatAvatar))
return this; return this;
}
if (object.getSyncState() == SyncState.FAILED) switch (object.getSyncState()){
// rocketChatAvatar.loadImage(VectorDrawableCompat.create(context.getResources(), R.drawable.ic_error_outline_black_24dp, null)); case SyncState.FAILED:
userRenderer.errorAvatarInto(rocketChatAvatar); userRenderer.avatarInto(rocketChatAvatar, absoluteUrl, true);
else if (TextUtils.isEmpty(object.getAvatar())) break;
userRenderer.avatarInto(rocketChatAvatar, absoluteUrl); default:
else { if (TextUtils.isEmpty(object.getAvatar()))
final User user = object.getUser(); userRenderer.avatarInto(rocketChatAvatar, absoluteUrl, false);
setAvatarInto(object.getAvatar(), absoluteUrl, user == null ? null : user.getUsername(), rocketChatAvatar); else
rocketChatAvatar.loadImage(object.getAvatar());
break;
} }
return this; return this;
} }
...@@ -60,12 +58,10 @@ public class MessageRenderer extends AbstractRenderer<Message> { ...@@ -60,12 +58,10 @@ public class MessageRenderer extends AbstractRenderer<Message> {
public MessageRenderer usernameInto(TextView usernameTextView, TextView subUsernameTextView) { public MessageRenderer usernameInto(TextView usernameTextView, TextView subUsernameTextView) {
if (TextUtils.isEmpty(object.getAlias())) { if (TextUtils.isEmpty(object.getAlias())) {
userRenderer.usernameInto(usernameTextView); userRenderer.usernameInto(usernameTextView);
if (subUsernameTextView != null) { if (subUsernameTextView != null)
subUsernameTextView.setVisibility(View.GONE); subUsernameTextView.setVisibility(View.GONE);
} } else
} else {
aliasAndUsernameInto(usernameTextView, subUsernameTextView); aliasAndUsernameInto(usernameTextView, subUsernameTextView);
}
return this; return this;
} }
...@@ -73,9 +69,8 @@ public class MessageRenderer extends AbstractRenderer<Message> { ...@@ -73,9 +69,8 @@ public class MessageRenderer extends AbstractRenderer<Message> {
* show timestamp in textView. * show timestamp in textView.
*/ */
public MessageRenderer timestampInto(TextView textView) { public MessageRenderer timestampInto(TextView textView) {
if (!shouldHandle(textView)) { if (!shouldHandle(textView))
return this; return this;
}
switch (object.getSyncState()) { switch (object.getSyncState()) {
case SyncState.SYNCING: case SyncState.SYNCING:
...@@ -91,7 +86,6 @@ public class MessageRenderer extends AbstractRenderer<Message> { ...@@ -91,7 +86,6 @@ public class MessageRenderer extends AbstractRenderer<Message> {
textView.setText(DateTime.fromEpocMs(object.getTimestamp(), DateTime.Format.TIME)); textView.setText(DateTime.fromEpocMs(object.getTimestamp(), DateTime.Format.TIME));
break; break;
} }
return this; return this;
} }
...@@ -99,12 +93,10 @@ public class MessageRenderer extends AbstractRenderer<Message> { ...@@ -99,12 +93,10 @@ public class MessageRenderer extends AbstractRenderer<Message> {
* show body in RocketChatMessageLayout. * show body in RocketChatMessageLayout.
*/ */
public MessageRenderer bodyInto(RocketChatMessageLayout rocketChatMessageLayout) { public MessageRenderer bodyInto(RocketChatMessageLayout rocketChatMessageLayout) {
if (!shouldHandle(rocketChatMessageLayout)) { if (!shouldHandle(rocketChatMessageLayout))
return this; return this;
}
rocketChatMessageLayout.setText(object.getMessage()); rocketChatMessageLayout.setText(object.getMessage());
return this; return this;
} }
...@@ -112,59 +104,48 @@ public class MessageRenderer extends AbstractRenderer<Message> { ...@@ -112,59 +104,48 @@ public class MessageRenderer extends AbstractRenderer<Message> {
* show urls in RocketChatMessageUrlsLayout. * show urls in RocketChatMessageUrlsLayout.
*/ */
public MessageRenderer urlsInto(RocketChatMessageUrlsLayout urlsLayout) { public MessageRenderer urlsInto(RocketChatMessageUrlsLayout urlsLayout) {
if (!shouldHandle(urlsLayout)) { if (!shouldHandle(urlsLayout))
return this; return this;
}
List<WebContent> webContents = object.getWebContents(); List<WebContent> webContents = object.getWebContents();
if (webContents == null || webContents.size() == 0) { if (webContents == null || webContents.size() == 0)
urlsLayout.setVisibility(View.GONE); urlsLayout.setVisibility(View.GONE);
} else { else {
urlsLayout.setVisibility(View.VISIBLE); urlsLayout.setVisibility(View.VISIBLE);
urlsLayout.setUrls(webContents, autoloadImages); urlsLayout.setUrls(webContents, autoloadImages);
} }
return this; return this;
} }
/** /**
* show urls in RocketChatMessageUrlsLayout. * show urls in RocketChatMessageUrlsLayout.
*/ */
public MessageRenderer attachmentsInto(RocketChatMessageAttachmentsLayout attachmentsLayout, public MessageRenderer attachmentsInto(RocketChatMessageAttachmentsLayout attachmentsLayout, AbsoluteUrl absoluteUrl) {
AbsoluteUrl absoluteUrl) { if (!shouldHandle(attachmentsLayout))
if (!shouldHandle(attachmentsLayout)) {
return this; return this;
}
List<Attachment> attachments = object.getAttachments(); List<Attachment> attachments = object.getAttachments();
if (attachments == null || attachments.size() == 0) { if (attachments == null || attachments.size() == 0)
attachmentsLayout.setVisibility(View.GONE); attachmentsLayout.setVisibility(View.GONE);
} else { else {
attachmentsLayout.setVisibility(View.VISIBLE); attachmentsLayout.setVisibility(View.VISIBLE);
attachmentsLayout.setAbsoluteUrl(absoluteUrl); attachmentsLayout.setAbsoluteUrl(absoluteUrl);
attachmentsLayout.setAttachments(attachments, autoloadImages); attachmentsLayout.setAttachments(attachments, autoloadImages);
} }
return this; return this;
} }
private void setAvatarInto(String avatar, AbsoluteUrl absoluteUrl, String username, RocketChatAvatar imageView) {
imageView.loadImage(avatar, new Avatar(absoluteUrl, username).getTextDrawable(context));
}
private void aliasAndUsernameInto(TextView aliasTextView, TextView usernameTextView) { private void aliasAndUsernameInto(TextView aliasTextView, TextView usernameTextView) {
if (shouldHandle(aliasTextView)) { if (shouldHandle(aliasTextView))
aliasTextView.setText(object.getAlias()); aliasTextView.setText(object.getAlias());
}
if (shouldHandle(usernameTextView)) { if (shouldHandle(usernameTextView)) {
if (object.getUser() != null) { if (object.getUser() != null) {
usernameTextView.setText("@" + object.getUser().getUsername()); usernameTextView.setText("@" + object.getUser().getUsername());
usernameTextView.setVisibility(View.VISIBLE); usernameTextView.setVisibility(View.VISIBLE);
} else { } else
usernameTextView.setVisibility(View.GONE); usernameTextView.setVisibility(View.GONE);
} }
} }
}
} }
\ No newline at end of file
...@@ -21,27 +21,14 @@ public class UserRenderer extends AbstractRenderer<User> { ...@@ -21,27 +21,14 @@ public class UserRenderer extends AbstractRenderer<User> {
/** /**
* show Avatar image * show Avatar image
*/ */
public UserRenderer avatarInto(RocketChatAvatar rocketChatAvatar, AbsoluteUrl absoluteUrl) { public UserRenderer avatarInto(RocketChatAvatar rocketChatAvatar, AbsoluteUrl absoluteUrl, boolean showFailureImage) {
if (!shouldHandle(rocketChatAvatar)) { if (!shouldHandle(rocketChatAvatar)) {
return this; return this;
} }
if (!TextUtils.isEmpty(object.getUsername())) { if (!TextUtils.isEmpty(object.getUsername())) {
new Avatar(absoluteUrl, object.getUsername()).into(rocketChatAvatar); new Avatar(absoluteUrl, object.getUsername())
} .into(rocketChatAvatar, showFailureImage);
return this;
}
/**
* show Avatar error image
*/
public UserRenderer errorAvatarInto(RocketChatAvatar rocketChatAvatar) {
if (!shouldHandle(rocketChatAvatar)) {
return this;
}
if (!TextUtils.isEmpty(object.getUsername())) {
new Avatar(null, object.getUsername()).errorInto(rocketChatAvatar);
} }
return this; return this;
} }
......
...@@ -2,15 +2,11 @@ package chat.rocket.android.widget; ...@@ -2,15 +2,11 @@ package chat.rocket.android.widget;
import android.annotation.TargetApi; import android.annotation.TargetApi;
import android.content.Context; import android.content.Context;
import android.graphics.drawable.Drawable;
import android.net.Uri;
import android.os.Build; import android.os.Build;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.widget.FrameLayout; import android.widget.FrameLayout;
import com.facebook.drawee.backends.pipeline.Fresco; import chat.rocket.android.widget.helper.FrescoAvatarHelper;
import com.facebook.drawee.generic.GenericDraweeHierarchy;
import com.facebook.drawee.interfaces.DraweeController;
import com.facebook.drawee.view.SimpleDraweeView; import com.facebook.drawee.view.SimpleDraweeView;
public class RocketChatAvatar extends FrameLayout { public class RocketChatAvatar extends FrameLayout {
...@@ -39,36 +35,19 @@ public class RocketChatAvatar extends FrameLayout { ...@@ -39,36 +35,19 @@ public class RocketChatAvatar extends FrameLayout {
} }
private void initialize(Context context, AttributeSet attrs) { private void initialize(Context context, AttributeSet attrs) {
LayoutInflater.from(context) LayoutInflater
.from(context)
.inflate(R.layout.message_avatar, this, true); .inflate(R.layout.message_avatar, this, true);
draweeView = findViewById(R.id.drawee_avatar);
draweeView = (SimpleDraweeView) findViewById(R.id.drawee_avatar);
} }
public void loadImage(Drawable drawable) { public void loadImage(String imageUrl) {
// final GenericDraweeHierarchy hierarchy = draweeView.getHierarchy(); FrescoAvatarHelper
// hierarchy.setImage(drawable, 100, true); // Is there a better way? .loadImage(draweeView, imageUrl);
final GenericDraweeHierarchy hierarchy = draweeView.getHierarchy();
hierarchy.setPlaceholderImage(drawable);
hierarchy.setFailureImage(drawable);
final DraweeController controller = Fresco.newDraweeControllerBuilder()
.setAutoPlayAnimations(true)
.build();
draweeView.setController(controller);
} }
public void loadImage(String url, Drawable placeholder) { public void showFailureImage() {
final GenericDraweeHierarchy hierarchy = draweeView.getHierarchy(); FrescoAvatarHelper
hierarchy.setPlaceholderImage(placeholder); .showFailureImage(draweeView);
hierarchy.setFailureImage(placeholder);
final DraweeController controller = Fresco.newDraweeControllerBuilder()
.setUri(Uri.parse(url))
.setAutoPlayAnimations(true)
.build();
draweeView.setController(controller);
} }
} }
\ No newline at end of file
package chat.rocket.android.widget; package chat.rocket.android.widget;
import android.content.Context; import android.content.Context;
import chat.rocket.android.widget.fresco.CustomImageFormatConfigurator;
import com.facebook.drawee.backends.pipeline.DraweeConfig; import com.facebook.drawee.backends.pipeline.DraweeConfig;
import com.facebook.drawee.backends.pipeline.Fresco; import com.facebook.drawee.backends.pipeline.Fresco;
import com.facebook.imagepipeline.backends.okhttp3.OkHttpImagePipelineConfigFactory; import com.facebook.imagepipeline.backends.okhttp3.OkHttpImagePipelineConfigFactory;
import com.facebook.imagepipeline.core.ImagePipelineConfig; import com.facebook.imagepipeline.core.ImagePipelineConfig;
import chat.rocket.android.widget.fresco.ImageFormatConfigurator;
import okhttp3.OkHttpClient; import okhttp3.OkHttpClient;
public class RocketChatWidgets { public class RocketChatWidgets {
...@@ -16,14 +14,12 @@ public class RocketChatWidgets { ...@@ -16,14 +14,12 @@ public class RocketChatWidgets {
ImagePipelineConfig config = OkHttpImagePipelineConfigFactory ImagePipelineConfig config = OkHttpImagePipelineConfigFactory
.newBuilder(context, okHttpClient) .newBuilder(context, okHttpClient)
.setDownsampleEnabled(true) .setDownsampleEnabled(true)
.setImageDecoderConfig(ImageFormatConfigurator.createImageDecoderConfig()) .setImageDecoderConfig(CustomImageFormatConfigurator.createImageDecoderConfig())
.build(); .build();
DraweeConfig.Builder draweeConfigBuilder = DraweeConfig.newBuilder(); DraweeConfig.Builder draweeConfigBuilder = DraweeConfig.newBuilder();
ImageFormatConfigurator.addCustomDrawableFactories(draweeConfigBuilder); CustomImageFormatConfigurator.addCustomDrawableFactories(draweeConfigBuilder);
Fresco.initialize(context, config, draweeConfigBuilder.build()); Fresco.initialize(context, config, draweeConfigBuilder.build());
Fresco.getImagePipeline().clearCaches();
} }
} }
\ No newline at end of file
...@@ -22,10 +22,8 @@ public class FrescoHelper { ...@@ -22,10 +22,8 @@ public class FrescoHelper {
public static void setupDrawee(SimpleDraweeView draweeView) { public static void setupDrawee(SimpleDraweeView draweeView) {
final GenericDraweeHierarchy hierarchy = draweeView.getHierarchy(); final GenericDraweeHierarchy hierarchy = draweeView.getHierarchy();
hierarchy.setPlaceholderImage( hierarchy.setPlaceholderImage(VectorDrawableCompat.create(draweeView.getResources(), R.drawable.image_dummy, null));
VectorDrawableCompat.create(draweeView.getResources(), R.drawable.image_dummy, null)); hierarchy.setFailureImage(VectorDrawableCompat.create(draweeView.getResources(), R.drawable.image_error, null));
hierarchy.setFailureImage(
VectorDrawableCompat.create(draweeView.getResources(), R.drawable.image_error, null));
hierarchy.setProgressBarImage(new ProgressBarDrawable()); hierarchy.setProgressBarImage(new ProgressBarDrawable());
} }
......
...@@ -54,21 +54,15 @@ public class UserViewHolder extends AutocompleteViewHolder<UserItem> { ...@@ -54,21 +54,15 @@ public class UserViewHolder extends AutocompleteViewHolder<UserItem> {
final String suggestion = userItem.getSuggestion(); final String suggestion = userItem.getSuggestion();
if (titleTextView != null) { if (titleTextView != null)
titleTextView.setText(suggestion); titleTextView.setText(suggestion);
}
if (avatar != null) { if (avatar != null)
avatar.loadImage( avatar.loadImage(getImageUrl(suggestion, userItem.getAbsoluteUrl()));
getImageUrl(suggestion, userItem.getAbsoluteUrl()),
getTextDrawable(itemView.getContext(), suggestion)
);
}
if (status != null) { if (status != null)
status.setImageResource(userItem.getStatusResId()); status.setImageResource(userItem.getStatusResId());
} }
}
@Override @Override
public void showAsEmpty() { public void showAsEmpty() {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment