Minor change to distinguish moderators/admins

This commit is contained in:
Balazs Toldi 2024-07-19 16:01:32 +02:00
parent 4741198c78
commit 9ecbaba3d4
2 changed files with 20 additions and 2 deletions

View File

@ -292,6 +292,9 @@ public class ParseComment {
JSONObject postObj = jsonObject.getJSONObject("post"); JSONObject postObj = jsonObject.getJSONObject("post");
JSONObject communityObj = jsonObject.getJSONObject("community"); JSONObject communityObj = jsonObject.getJSONObject("community");
JSONObject countsObj = jsonObject.getJSONObject("counts"); JSONObject countsObj = jsonObject.getJSONObject("counts");
boolean isModerator = jsonObject.optBoolean("creator_is_moderator");
boolean isAdmin = jsonObject.optBoolean("creator_is_admin");
int id = commentObj.getInt("id"); int id = commentObj.getInt("id");
int postID = postObj.getInt("id"); int postID = postObj.getInt("id");
@ -342,7 +345,7 @@ public class ParseComment {
} }
} }
boolean isSubmitter = creatorObj.getInt("id") == postObj.getInt("creator_id"); boolean isSubmitter = creatorObj.getInt("id") == postObj.getInt("creator_id");
String distinguished = commentObj.getString("distinguished"); String distinguished = isModerator ? "moderator" : (isAdmin ? "admin" : "");
String permalink = commentObj.getString("ap_id"); String permalink = commentObj.getString("ap_id");
String[] path = commentObj.getString("path").split(Pattern.quote(".")); String[] path = commentObj.getString("path").split(Pattern.quote("."));

View File

@ -142,6 +142,8 @@ public class ParsePost {
JSONObject creator = data.getJSONObject("creator"); JSONObject creator = data.getJSONObject("creator");
JSONObject community = data.getJSONObject("community"); JSONObject community = data.getJSONObject("community");
JSONObject counts = data.getJSONObject("counts"); JSONObject counts = data.getJSONObject("counts");
boolean isModerator = data.getBoolean("creator_is_moderator");
boolean isAdmin = creator.optBoolean("admin") || data.optBoolean("creator_is_admin");
int id = post.getInt("id"); int id = post.getInt("id");
String fullName = post.getString("name"); String fullName = post.getString("name");
@ -182,7 +184,7 @@ public class ParsePost {
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"); boolean deleted = post.getBoolean("deleted");
String distinguished = creator.optBoolean("admin") ? "admin" : ""; String distinguished = (isModerator) ? "moderator" : (isAdmin) ? "admin" : "";
String suggestedSort = ""; String suggestedSort = "";
ArrayList<Post.Preview> previews = new ArrayList<>(); ArrayList<Post.Preview> previews = new ArrayList<>();
if (!post.isNull("thumbnail_url")) { if (!post.isNull("thumbnail_url")) {
@ -642,6 +644,19 @@ public class ParsePost {
return post; return post;
} }
private boolean isModerator(JSONArray moderators, String username) {
for (int i = 0; i < moderators.length(); i++) {
try {
if (moderators.getJSONObject(i).getString("name").equals(username)) {
return true;
}
} catch (JSONException e) {
e.printStackTrace();
}
}
return false;
}
public interface ParsePostsListingListener { public interface ParsePostsListingListener {
void onParsePostsListingSuccess(LinkedHashSet<Post> newPostData, String lastItem); void onParsePostsListingSuccess(LinkedHashSet<Post> newPostData, String lastItem);
void onParsePostsListingFail(); void onParsePostsListingFail();