Show a bin icon on deleted posts

This commit is contained in:
Balazs Toldi 2023-11-10 10:19:48 +01:00
parent 25495b737a
commit 48776d28bb
No known key found for this signature in database
GPG Key ID: 6C7D440036F99D58
4 changed files with 45 additions and 19 deletions

View File

@ -53,7 +53,6 @@ import com.google.android.exoplayer2.ui.DefaultTimeBar;
import com.google.android.exoplayer2.ui.PlayerView; import com.google.android.exoplayer2.ui.PlayerView;
import com.google.android.exoplayer2.ui.TimeBar; import com.google.android.exoplayer2.ui.TimeBar;
import com.google.android.material.button.MaterialButton; import com.google.android.material.button.MaterialButton;
import com.google.android.material.button.MaterialButtonToggleGroup;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.libRG.CustomTextView; import com.libRG.CustomTextView;
@ -808,6 +807,12 @@ public class PostRecyclerViewAdapter extends PagingDataAdapter<Post, RecyclerVie
} }
} }
if (post.isDeleted()) {
mGlide.load(R.drawable.ic_delete_outline_24).into(((PostBaseViewHolder) holder).stickiedPostImageView);
((PostBaseViewHolder) holder).stickiedPostImageView.setVisibility(View.VISIBLE);
((PostBaseViewHolder) holder).stickiedPostImageView.setColorFilter(mUpvotedColor, android.graphics.PorterDuff.Mode.SRC_IN);
}
if (post.isArchived()) { if (post.isArchived()) {
((PostBaseViewHolder) holder).archivedImageView.setVisibility(View.VISIBLE); ((PostBaseViewHolder) holder).archivedImageView.setVisibility(View.VISIBLE);

View File

@ -181,6 +181,7 @@ public class ParsePost {
boolean nsfw = post.getBoolean("nsfw"); boolean nsfw = post.getBoolean("nsfw");
boolean locked = post.getBoolean("locked"); boolean locked = post.getBoolean("locked");
boolean saved = data.getBoolean("saved"); boolean saved = data.getBoolean("saved");
boolean deleted = post.getBoolean("deleted");
String distinguished = creator.optBoolean("admin") ? "admin" : ""; String distinguished = creator.optBoolean("admin") ? "admin" : "";
String suggestedSort = ""; String suggestedSort = "";
ArrayList<Post.Preview> previews = new ArrayList<>(); ArrayList<Post.Preview> previews = new ArrayList<>();
@ -194,7 +195,7 @@ public class ParsePost {
return parseData(data, permalink, id, communityInfo, return parseData(data, permalink, id, communityInfo,
authorInfo, postTimeMillis, title, previews, authorInfo, postTimeMillis, title, previews,
downvotes, upvotes, voteType, nComments, upvoteRatio, nsfw, locked, saved, downvotes, upvotes, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted,
distinguished, suggestedSort); distinguished, suggestedSort);
} }
@ -203,7 +204,7 @@ public class ParsePost {
long postTimeMillis, String title, ArrayList<Post.Preview> previews, long postTimeMillis, String title, ArrayList<Post.Preview> previews,
int downvotes, int upvotes, int voteType, int nComments, int upvoteRatio, int downvotes, int upvotes, int voteType, int nComments, int upvoteRatio,
boolean nsfw, boolean locked, boolean nsfw, boolean locked,
boolean saved, boolean saved, boolean deleted,
String distinguished, String suggestedSort) throws JSONException { String distinguished, String suggestedSort) throws JSONException {
Post post; Post post;
@ -223,7 +224,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, permalink, downvotes, upvotes, postTimeMillis, title, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, postType, voteType, nComments, upvoteRatio, nsfw,
locked, saved, distinguished, suggestedSort); locked, saved, deleted, distinguished, suggestedSort);
String body = data.getJSONObject("post").getString("body"); String body = data.getJSONObject("post").getString("body");
post.setSelfText(body); post.setSelfText(body);
post.setSelfTextPlain(body); post.setSelfTextPlain(body);
@ -235,7 +236,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
if (previews.isEmpty()) { if (previews.isEmpty()) {
previews.add(new Post.Preview(url, 0, 0, "", "")); previews.add(new Post.Preview(url, 0, 0, "", ""));
@ -247,7 +248,7 @@ public class ParsePost {
int postType = Post.VIDEO_TYPE; int postType = Post.VIDEO_TYPE;
post = new Post(id, communityInfo, author, postTimeMillis, title, permalink, downvotes, upvotes, postType, voteType, post = new Post(id, communityInfo, author, postTimeMillis, title, permalink, downvotes, upvotes, postType, voteType,
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
post.setVideoUrl(url); post.setVideoUrl(url);
post.setVideoDownloadUrl(url); post.setVideoDownloadUrl(url);
@ -256,7 +257,7 @@ public class ParsePost {
int postType = Post.NO_PREVIEW_LINK_TYPE; int postType = Post.NO_PREVIEW_LINK_TYPE;
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
if (data.isNull(JSONUtils.SELFTEXT_KEY)) { if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
post.setSelfText(""); post.setSelfText("");
} else { } else {
@ -291,7 +292,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, permalink, downvotes, upvotes, postTimeMillis, title, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, postType, voteType, nComments, upvoteRatio, nsfw,
locked, saved, distinguished, suggestedSort); locked, saved, deleted, distinguished, suggestedSort);
String body = ""; String body = "";
post.setSelfText(body); post.setSelfText(body);
post.setSelfTextPlain(body); post.setSelfTextPlain(body);
@ -328,7 +329,7 @@ public class ParsePost {
String videoDownloadUrl = redditVideoObject.getString(JSONUtils.FALLBACK_URL_KEY); String videoDownloadUrl = redditVideoObject.getString(JSONUtils.FALLBACK_URL_KEY);
post = new Post(id, communityInfo, author, postTimeMillis, title, permalink, downvotes, upvotes, postType, voteType, post = new Post(id, communityInfo, author, postTimeMillis, title, permalink, downvotes, upvotes, postType, voteType,
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
post.setPreviews(previews); post.setPreviews(previews);
post.setVideoUrl(videoUrl); post.setVideoUrl(videoUrl);
@ -340,7 +341,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted,
distinguished, suggestedSort); distinguished, suggestedSort);
if (previews.isEmpty()) { if (previews.isEmpty()) {
@ -353,7 +354,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, postType, voteType, nComments, upvoteRatio,
nsfw, locked, saved, nsfw, locked, saved, deleted,
distinguished, suggestedSort); distinguished, suggestedSort);
post.setPreviews(previews); post.setPreviews(previews);
@ -369,7 +370,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, postType, voteType, nComments, upvoteRatio,
nsfw, locked, saved, nsfw, locked, saved, deleted,
distinguished, suggestedSort); distinguished, suggestedSort);
post.setPreviews(previews); post.setPreviews(previews);
post.setVideoUrl(url); post.setVideoUrl(url);
@ -381,7 +382,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted,
distinguished, suggestedSort); distinguished, suggestedSort);
post.setPreviews(previews); post.setPreviews(previews);
post.setVideoUrl(url); post.setVideoUrl(url);
@ -392,7 +393,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted,
distinguished, suggestedSort); distinguished, suggestedSort);
if (data.isNull(JSONUtils.SELFTEXT_KEY)) { if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
post.setSelfText(""); post.setSelfText("");
@ -433,7 +434,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
if (previews.isEmpty()) { if (previews.isEmpty()) {
previews.add(new Post.Preview(url, 0, 0, "", "")); previews.add(new Post.Preview(url, 0, 0, "", ""));
@ -445,7 +446,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
post.setPreviews(previews); post.setPreviews(previews);
post.setVideoUrl(url); post.setVideoUrl(url);
post.setVideoDownloadUrl(url); post.setVideoDownloadUrl(url);
@ -455,7 +456,7 @@ public class ParsePost {
post = new Post(id, communityInfo, author, post = new Post(id, communityInfo, author,
postTimeMillis, title, url, permalink, downvotes, upvotes, postTimeMillis, title, url, permalink, downvotes, upvotes,
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort); postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
//Need attention //Need attention
if (data.isNull(JSONUtils.SELFTEXT_KEY)) { if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
post.setSelfText(""); post.setSelfText("");

View File

@ -72,6 +72,8 @@ public class Post implements Parcelable {
private boolean saved; private boolean saved;
private boolean isCrosspost; private boolean isCrosspost;
private boolean isRead; private boolean isRead;
private boolean deleted;
private String crosspostParentId; private String crosspostParentId;
private String distinguished; private String distinguished;
private String suggestedSort; private String suggestedSort;
@ -82,7 +84,7 @@ public class Post implements Parcelable {
BasicUserInfo userInfo, long postTimeMillis, BasicUserInfo userInfo, long postTimeMillis,
String title, String permalink, int downvotes, int upvotes, int postType, int voteType, int nComments, String title, String permalink, int downvotes, int upvotes, int postType, int voteType, int nComments,
int upvoteRatio, int upvoteRatio,
boolean nsfw, boolean locked, boolean saved, boolean nsfw, boolean locked, boolean saved, boolean deleted,
String distinguished, String suggestedSort) { String distinguished, String suggestedSort) {
this.id = id; this.id = id;
this.communityInfo = communityInfo; this.communityInfo = communityInfo;
@ -99,6 +101,7 @@ public class Post implements Parcelable {
this.hidden = hidden; this.hidden = hidden;
this.nsfw = nsfw; this.nsfw = nsfw;
this.archived = archived; this.archived = archived;
this.deleted = deleted;
this.locked = locked; this.locked = locked;
this.saved = saved; this.saved = saved;
this.isCrosspost = isCrosspost; this.isCrosspost = isCrosspost;
@ -111,7 +114,7 @@ public class Post implements Parcelable {
BasicUserInfo author, long postTimeMillis, String title, BasicUserInfo author, long postTimeMillis, String title,
String url, String permalink, int downvotes, int upvotes, int postType, int voteType, int nComments, String url, String permalink, int downvotes, int upvotes, int postType, int voteType, int nComments,
int upvoteRatio, int upvoteRatio,
boolean nsfw, boolean locked, boolean saved, String distinguished, String suggestedSort) { boolean nsfw, boolean locked, boolean saved, boolean deleted, String distinguished, String suggestedSort) {
this.id = id; this.id = id;
this.communityInfo = communityInfo; this.communityInfo = communityInfo;
this.author = author; this.author = author;
@ -130,6 +133,7 @@ public class Post implements Parcelable {
this.archived = archived; this.archived = archived;
this.locked = locked; this.locked = locked;
this.saved = saved; this.saved = saved;
this.deleted = deleted;
this.isCrosspost = isCrosspost; this.isCrosspost = isCrosspost;
this.distinguished = distinguished; this.distinguished = distinguished;
this.suggestedSort = suggestedSort; this.suggestedSort = suggestedSort;
@ -168,6 +172,7 @@ public class Post implements Parcelable {
archived = in.readByte() != 0; archived = in.readByte() != 0;
locked = in.readByte() != 0; locked = in.readByte() != 0;
saved = in.readByte() != 0; saved = in.readByte() != 0;
deleted = in.readByte() != 0;
isCrosspost = in.readByte() != 0; isCrosspost = in.readByte() != 0;
isRead = in.readByte() != 0; isRead = in.readByte() != 0;
crosspostParentId = in.readString(); crosspostParentId = in.readString();
@ -503,6 +508,10 @@ public class Post implements Parcelable {
return author; return author;
} }
public boolean isDeleted() {
return deleted;
}
@Override @Override
public void writeToParcel(Parcel parcel, int i) { public void writeToParcel(Parcel parcel, int i) {
parcel.writeInt(id); parcel.writeInt(id);
@ -536,6 +545,7 @@ public class Post implements Parcelable {
parcel.writeByte((byte) (archived ? 1 : 0)); parcel.writeByte((byte) (archived ? 1 : 0));
parcel.writeByte((byte) (locked ? 1 : 0)); parcel.writeByte((byte) (locked ? 1 : 0));
parcel.writeByte((byte) (saved ? 1 : 0)); parcel.writeByte((byte) (saved ? 1 : 0));
parcel.writeByte((byte) (deleted ? 1 : 0));
parcel.writeByte((byte) (isCrosspost ? 1 : 0)); parcel.writeByte((byte) (isCrosspost ? 1 : 0));
parcel.writeByte((byte) (isRead ? 1 : 0)); parcel.writeByte((byte) (isRead ? 1 : 0));
parcel.writeString(crosspostParentId); parcel.writeString(crosspostParentId);

View File

@ -0,0 +1,10 @@
<vector android:height="24dp"
android:tint="#000000"
android:viewportHeight="24"
android:viewportWidth="24"
android:width="24dp"
xmlns:android="http://schemas.android.com/apk/res/android">
<path
android:fillColor="@android:color/white"
android:pathData="M6,19c0,1.1 0.9,2 2,2h8c1.1,0 2,-0.9 2,-2L18,7L6,7v12zM8,9h8v10L8,19L8,9zM15.5,4l-1,-1h-5l-1,1L5,4v2h14L19,4z" />
</vector>