2016-10-11 13:57:01 +02:00
|
|
|
/*
|
2019-01-23 18:03:33 +01:00
|
|
|
* This is the source code of Telegram for Android v. 5.x.x.
|
2016-10-11 13:57:01 +02:00
|
|
|
* It is licensed under GNU GPL v. 2 or later.
|
|
|
|
* You should have received a copy of the license in this archive (see LICENSE).
|
|
|
|
*
|
2019-01-23 18:03:33 +01:00
|
|
|
* Copyright Nikolai Kudashov, 2013-2018.
|
2016-10-11 13:57:01 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
package org.telegram.ui.Cells;
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
import android.animation.Animator;
|
|
|
|
import android.animation.AnimatorListenerAdapter;
|
|
|
|
import android.animation.AnimatorSet;
|
|
|
|
import android.animation.ObjectAnimator;
|
|
|
|
import android.annotation.SuppressLint;
|
2016-10-11 13:57:01 +02:00
|
|
|
import android.content.Context;
|
|
|
|
import android.graphics.Canvas;
|
2020-03-30 14:00:09 +02:00
|
|
|
import android.os.Build;
|
2016-10-11 13:57:01 +02:00
|
|
|
import android.text.TextUtils;
|
|
|
|
import android.util.TypedValue;
|
|
|
|
import android.view.Gravity;
|
2020-03-30 14:00:09 +02:00
|
|
|
import android.view.View;
|
|
|
|
import android.view.animation.OvershootInterpolator;
|
|
|
|
import android.widget.Button;
|
|
|
|
import android.widget.Checkable;
|
2016-10-11 13:57:01 +02:00
|
|
|
import android.widget.FrameLayout;
|
|
|
|
import android.widget.TextView;
|
|
|
|
|
|
|
|
import org.telegram.messenger.AndroidUtilities;
|
2020-12-23 08:48:30 +01:00
|
|
|
import org.telegram.messenger.DocumentObject;
|
2019-01-23 18:03:33 +01:00
|
|
|
import org.telegram.messenger.FileLoader;
|
2019-05-14 14:08:05 +02:00
|
|
|
import org.telegram.messenger.ImageLocation;
|
2016-10-11 13:57:01 +02:00
|
|
|
import org.telegram.messenger.LocaleController;
|
2019-07-18 15:01:39 +02:00
|
|
|
import org.telegram.messenger.MessageObject;
|
2020-03-30 14:00:09 +02:00
|
|
|
import org.telegram.messenger.R;
|
2020-12-23 08:48:30 +01:00
|
|
|
import org.telegram.messenger.SvgHelper;
|
2019-08-22 01:53:26 +02:00
|
|
|
import org.telegram.tgnet.TLObject;
|
2016-10-11 13:57:01 +02:00
|
|
|
import org.telegram.tgnet.TLRPC;
|
2017-03-31 01:58:05 +02:00
|
|
|
import org.telegram.ui.ActionBar.Theme;
|
2016-10-11 13:57:01 +02:00
|
|
|
import org.telegram.ui.Components.BackupImageView;
|
|
|
|
import org.telegram.ui.Components.LayoutHelper;
|
2020-03-30 14:00:09 +02:00
|
|
|
import org.telegram.ui.Components.ProgressButton;
|
|
|
|
import org.telegram.ui.Components.ViewHelper;
|
2016-10-11 13:57:01 +02:00
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
@SuppressLint("ViewConstructor")
|
|
|
|
public class ArchivedStickerSetCell extends FrameLayout implements Checkable {
|
|
|
|
|
|
|
|
private final boolean checkable;
|
|
|
|
|
|
|
|
private final TextView textView;
|
|
|
|
private final TextView valueTextView;
|
|
|
|
private final BackupImageView imageView;
|
|
|
|
private final Button deleteButton;
|
|
|
|
private final ProgressButton addButton;
|
2016-10-11 13:57:01 +02:00
|
|
|
|
|
|
|
private boolean needDivider;
|
2020-03-30 14:00:09 +02:00
|
|
|
private Button currentButton;
|
|
|
|
private AnimatorSet animatorSet;
|
2016-10-11 13:57:01 +02:00
|
|
|
private TLRPC.StickerSetCovered stickersSet;
|
2020-03-30 14:00:09 +02:00
|
|
|
private OnCheckedChangeListener onCheckedChangeListener;
|
|
|
|
private boolean checked;
|
2016-10-11 13:57:01 +02:00
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
public ArchivedStickerSetCell(Context context, boolean checkable) {
|
2016-10-11 13:57:01 +02:00
|
|
|
super(context);
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
if (this.checkable = checkable) {
|
|
|
|
currentButton = addButton = new ProgressButton(context);
|
|
|
|
addButton.setText(LocaleController.getString("Add", R.string.Add));
|
|
|
|
addButton.setTextColor(Theme.getColor(Theme.key_featuredStickers_buttonText));
|
|
|
|
addButton.setProgressColor(Theme.getColor(Theme.key_featuredStickers_buttonProgress));
|
|
|
|
addButton.setBackgroundRoundRect(Theme.getColor(Theme.key_featuredStickers_addButton), Theme.getColor(Theme.key_featuredStickers_addButtonPressed));
|
|
|
|
addView(addButton, LayoutHelper.createFrameRelatively(LayoutHelper.WRAP_CONTENT, 28, Gravity.TOP | Gravity.END, 0, 18, 14, 0));
|
|
|
|
|
|
|
|
final int minWidth = AndroidUtilities.dp(60);
|
|
|
|
deleteButton = new ProgressButton(context);
|
|
|
|
deleteButton.setAllCaps(false);
|
|
|
|
deleteButton.setMinWidth(minWidth);
|
|
|
|
deleteButton.setMinimumWidth(minWidth);
|
|
|
|
deleteButton.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 14);
|
|
|
|
deleteButton.setTextColor(Theme.getColor(Theme.key_featuredStickers_removeButtonText));
|
|
|
|
deleteButton.setText(LocaleController.getString("StickersRemove", R.string.StickersRemove));
|
|
|
|
deleteButton.setBackground(Theme.getRoundRectSelectorDrawable(Theme.getColor(Theme.key_featuredStickers_removeButtonText)));
|
|
|
|
deleteButton.setTypeface(AndroidUtilities.getTypeface("fonts/rmedium.ttf"));
|
|
|
|
ViewHelper.setPadding(deleteButton, 8, 0, 8, 0);
|
|
|
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
|
|
deleteButton.setOutlineProvider(null);
|
|
|
|
}
|
|
|
|
addView(deleteButton, LayoutHelper.createFrameRelatively(LayoutHelper.WRAP_CONTENT, 28, Gravity.TOP | Gravity.END, 0, 18, 14, 0));
|
|
|
|
|
|
|
|
final OnClickListener toggleListener = v -> toggle();
|
|
|
|
addButton.setOnClickListener(toggleListener);
|
|
|
|
deleteButton.setOnClickListener(toggleListener);
|
|
|
|
|
|
|
|
syncButtons(false);
|
|
|
|
} else {
|
|
|
|
addButton = null;
|
|
|
|
deleteButton = null;
|
|
|
|
}
|
|
|
|
|
2016-10-11 13:57:01 +02:00
|
|
|
textView = new TextView(context);
|
2017-03-31 01:58:05 +02:00
|
|
|
textView.setTextColor(Theme.getColor(Theme.key_windowBackgroundWhiteBlackText));
|
2016-10-11 13:57:01 +02:00
|
|
|
textView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
|
|
|
|
textView.setLines(1);
|
|
|
|
textView.setMaxLines(1);
|
|
|
|
textView.setSingleLine(true);
|
|
|
|
textView.setEllipsize(TextUtils.TruncateAt.END);
|
2020-03-30 14:00:09 +02:00
|
|
|
textView.setGravity(LayoutHelper.getAbsoluteGravityStart());
|
|
|
|
addView(textView, LayoutHelper.createFrameRelatively(LayoutHelper.WRAP_CONTENT, LayoutHelper.WRAP_CONTENT, Gravity.START, 71, 10, 21, 0));
|
2016-10-11 13:57:01 +02:00
|
|
|
|
|
|
|
valueTextView = new TextView(context);
|
2017-03-31 01:58:05 +02:00
|
|
|
valueTextView.setTextColor(Theme.getColor(Theme.key_windowBackgroundWhiteGrayText2));
|
2016-10-11 13:57:01 +02:00
|
|
|
valueTextView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 13);
|
|
|
|
valueTextView.setLines(1);
|
|
|
|
valueTextView.setMaxLines(1);
|
|
|
|
valueTextView.setSingleLine(true);
|
2020-03-30 14:00:09 +02:00
|
|
|
valueTextView.setGravity(LayoutHelper.getAbsoluteGravityStart());
|
|
|
|
addView(valueTextView, LayoutHelper.createFrameRelatively(LayoutHelper.WRAP_CONTENT, LayoutHelper.WRAP_CONTENT, Gravity.START, 71, 35, 21, 0));
|
2016-10-11 13:57:01 +02:00
|
|
|
|
|
|
|
imageView = new BackupImageView(context);
|
|
|
|
imageView.setAspectFit(true);
|
2019-07-18 15:01:39 +02:00
|
|
|
imageView.setLayerNum(1);
|
2020-03-30 14:00:09 +02:00
|
|
|
addView(imageView, LayoutHelper.createFrameRelatively(48, 48, Gravity.START | Gravity.TOP, 12, 8, 0, 0));
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
@Override
|
|
|
|
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
|
|
|
|
super.onMeasure(MeasureSpec.makeMeasureSpec(MeasureSpec.getSize(widthMeasureSpec), MeasureSpec.EXACTLY), MeasureSpec.makeMeasureSpec(AndroidUtilities.dp(64) + (needDivider ? 1 : 0), MeasureSpec.EXACTLY));
|
2017-03-31 01:58:05 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
@Override
|
|
|
|
protected void measureChildWithMargins(View child, int parentWidthMeasureSpec, int widthUsed, int parentHeightMeasureSpec, int heightUsed) {
|
|
|
|
if (checkable && child == textView) {
|
|
|
|
widthUsed += Math.max(addButton.getMeasuredWidth(), deleteButton.getMeasuredWidth());
|
|
|
|
}
|
|
|
|
super.measureChildWithMargins(child, parentWidthMeasureSpec, widthUsed, parentHeightMeasureSpec, heightUsed);
|
2017-03-31 01:58:05 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
@Override
|
|
|
|
protected void onDraw(Canvas canvas) {
|
|
|
|
if (needDivider) {
|
|
|
|
canvas.drawLine(0, getHeight() - 1, getWidth() - getPaddingRight(), getHeight() - 1, Theme.dividerPaint);
|
|
|
|
}
|
2017-03-31 01:58:05 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
public void setDrawProgress(boolean drawProgress, boolean animated) {
|
|
|
|
if (addButton != null) {
|
|
|
|
addButton.setDrawProgress(drawProgress, animated);
|
|
|
|
}
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
|
2017-03-31 01:58:05 +02:00
|
|
|
public void setStickersSet(TLRPC.StickerSetCovered set, boolean divider) {
|
2016-10-11 13:57:01 +02:00
|
|
|
needDivider = divider;
|
|
|
|
stickersSet = set;
|
|
|
|
setWillNotDraw(!needDivider);
|
|
|
|
|
|
|
|
textView.setText(stickersSet.set.title);
|
|
|
|
valueTextView.setText(LocaleController.formatPluralString("Stickers", set.set.count));
|
2019-08-22 01:53:26 +02:00
|
|
|
|
|
|
|
TLRPC.Document sticker;
|
|
|
|
if (set.cover != null) {
|
|
|
|
sticker = set.cover;
|
|
|
|
} else if (!set.covers.isEmpty()) {
|
|
|
|
sticker = set.covers.get(0);
|
|
|
|
} else {
|
|
|
|
sticker = null;
|
|
|
|
}
|
|
|
|
if (sticker != null) {
|
2020-12-23 08:48:30 +01:00
|
|
|
TLObject object = FileLoader.getClosestPhotoSizeWithSize(set.set.thumbs, 90);
|
|
|
|
if (object == null) {
|
2019-08-22 01:53:26 +02:00
|
|
|
object = sticker;
|
2019-07-18 15:01:39 +02:00
|
|
|
}
|
2020-12-23 08:48:30 +01:00
|
|
|
SvgHelper.SvgDrawable svgThumb = DocumentObject.getSvgThumb(set.set.thumbs, Theme.key_windowBackgroundGray, 1.0f);
|
2019-08-22 01:53:26 +02:00
|
|
|
ImageLocation imageLocation;
|
|
|
|
|
|
|
|
if (object instanceof TLRPC.Document) {
|
|
|
|
TLRPC.PhotoSize thumb = FileLoader.getClosestPhotoSizeWithSize(sticker.thumbs, 90);
|
|
|
|
imageLocation = ImageLocation.getForDocument(thumb, sticker);
|
|
|
|
} else {
|
|
|
|
TLRPC.PhotoSize thumb = (TLRPC.PhotoSize) object;
|
2021-06-25 02:43:10 +02:00
|
|
|
imageLocation = ImageLocation.getForSticker(thumb, sticker, set.set.thumb_version);
|
2019-08-22 01:53:26 +02:00
|
|
|
}
|
|
|
|
|
2019-12-31 14:08:08 +01:00
|
|
|
if (object instanceof TLRPC.Document && MessageObject.isAnimatedStickerDocument(sticker, true)) {
|
2020-12-23 08:48:30 +01:00
|
|
|
if (svgThumb != null) {
|
|
|
|
imageView.setImage(ImageLocation.getForDocument(sticker), "50_50", svgThumb, 0, set);
|
|
|
|
} else {
|
|
|
|
imageView.setImage(ImageLocation.getForDocument(sticker), "50_50", imageLocation, null, 0, set);
|
|
|
|
}
|
2019-12-31 14:08:08 +01:00
|
|
|
} else if (imageLocation != null && imageLocation.imageType == FileLoader.IMAGE_TYPE_LOTTIE) {
|
2020-12-23 08:48:30 +01:00
|
|
|
imageView.setImage(imageLocation, "50_50", "tgs", svgThumb, set);
|
2019-07-18 15:01:39 +02:00
|
|
|
} else {
|
2020-12-23 08:48:30 +01:00
|
|
|
imageView.setImage(imageLocation, "50_50", "webp", svgThumb, set);
|
2019-07-18 15:01:39 +02:00
|
|
|
}
|
2019-01-23 18:03:33 +01:00
|
|
|
} else {
|
2019-05-14 14:08:05 +02:00
|
|
|
imageView.setImage(null, null, "webp", null, set);
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
public TLRPC.StickerSetCovered getStickersSet() {
|
|
|
|
return stickersSet;
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
private void syncButtons(boolean animated) {
|
|
|
|
if (checkable) {
|
|
|
|
if (animatorSet != null) {
|
|
|
|
animatorSet.cancel();
|
|
|
|
}
|
|
|
|
final float deleteButtonValue = checked ? 1f : 0f;
|
|
|
|
final float addButtonValue = checked ? 0f : 1f;
|
|
|
|
if (animated) {
|
|
|
|
currentButton = checked ? deleteButton : addButton;
|
|
|
|
addButton.setVisibility(VISIBLE);
|
|
|
|
deleteButton.setVisibility(VISIBLE);
|
|
|
|
animatorSet = new AnimatorSet();
|
|
|
|
animatorSet.setDuration(250);
|
|
|
|
animatorSet.playTogether(
|
|
|
|
ObjectAnimator.ofFloat(deleteButton, View.ALPHA, deleteButtonValue),
|
|
|
|
ObjectAnimator.ofFloat(deleteButton, View.SCALE_X, deleteButtonValue),
|
|
|
|
ObjectAnimator.ofFloat(deleteButton, View.SCALE_Y, deleteButtonValue),
|
|
|
|
ObjectAnimator.ofFloat(addButton, View.ALPHA, addButtonValue),
|
|
|
|
ObjectAnimator.ofFloat(addButton, View.SCALE_X, addButtonValue),
|
|
|
|
ObjectAnimator.ofFloat(addButton, View.SCALE_Y, addButtonValue));
|
|
|
|
animatorSet.addListener(new AnimatorListenerAdapter() {
|
|
|
|
@Override
|
|
|
|
public void onAnimationEnd(Animator animation) {
|
|
|
|
if (currentButton == addButton) {
|
|
|
|
deleteButton.setVisibility(INVISIBLE);
|
|
|
|
} else {
|
|
|
|
addButton.setVisibility(INVISIBLE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
animatorSet.setInterpolator(new OvershootInterpolator(1.02f));
|
|
|
|
animatorSet.start();
|
|
|
|
} else {
|
|
|
|
deleteButton.setVisibility(checked ? VISIBLE : INVISIBLE);
|
|
|
|
deleteButton.setAlpha(deleteButtonValue);
|
|
|
|
deleteButton.setScaleX(deleteButtonValue);
|
|
|
|
deleteButton.setScaleY(deleteButtonValue);
|
|
|
|
addButton.setVisibility(checked ? INVISIBLE : VISIBLE);
|
|
|
|
addButton.setAlpha(addButtonValue);
|
|
|
|
addButton.setScaleX(addButtonValue);
|
|
|
|
addButton.setScaleY(addButtonValue);
|
|
|
|
}
|
|
|
|
}
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
//region Checkable
|
|
|
|
public void setOnCheckedChangeListener(OnCheckedChangeListener listener) {
|
|
|
|
onCheckedChangeListener = listener;
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
@Override
|
|
|
|
public void setChecked(boolean checked) {
|
|
|
|
setChecked(checked, true);
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
|
2020-03-30 14:00:09 +02:00
|
|
|
public void setChecked(boolean checked, boolean animated) {
|
|
|
|
setChecked(checked, animated, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setChecked(boolean checked, boolean animated, boolean notify) {
|
|
|
|
if (checkable && this.checked != checked) {
|
|
|
|
this.checked = checked;
|
|
|
|
|
|
|
|
syncButtons(animated);
|
|
|
|
|
|
|
|
if (notify && onCheckedChangeListener != null) {
|
|
|
|
onCheckedChangeListener.onCheckedChanged(this, checked);
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2020-03-30 14:00:09 +02:00
|
|
|
public boolean isChecked() {
|
|
|
|
return checked;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void toggle() {
|
|
|
|
if (checkable) {
|
|
|
|
setChecked(!isChecked());
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|
|
|
|
}
|
2020-03-30 14:00:09 +02:00
|
|
|
|
|
|
|
public interface OnCheckedChangeListener {
|
|
|
|
void onCheckedChanged(ArchivedStickerSetCell cell, boolean isChecked);
|
|
|
|
}
|
|
|
|
//endregion
|
2016-10-11 13:57:01 +02:00
|
|
|
}
|