mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-01-12 11:17:11 +01:00
Display the Follow Chip only if the user can be followed. Change schemes of database users.
This commit is contained in:
parent
0bd0639a4e
commit
047e31936f
@ -16,13 +16,16 @@ public class UserData extends SubscribedUserData {
|
|||||||
private boolean isGold;
|
private boolean isGold;
|
||||||
@ColumnInfo(name = "is_friend")
|
@ColumnInfo(name = "is_friend")
|
||||||
private boolean isFriend;
|
private boolean isFriend;
|
||||||
|
@ColumnInfo(name = "can_be_followed")
|
||||||
|
private boolean canBeFollowed;
|
||||||
|
|
||||||
public UserData(@NonNull String name, String iconUrl, String banner, int karma, boolean isGold, boolean isFriend) {
|
public UserData(@NonNull String name, String iconUrl, String banner, int karma, boolean isGold, boolean isFriend, boolean canBeFollowed) {
|
||||||
super(name, iconUrl);
|
super(name, iconUrl);
|
||||||
this.banner = banner;
|
this.banner = banner;
|
||||||
this.karma = karma;
|
this.karma = karma;
|
||||||
this.isGold = isGold;
|
this.isGold = isGold;
|
||||||
this.isFriend = isFriend;
|
this.isFriend = isFriend;
|
||||||
|
this.canBeFollowed = canBeFollowed;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getBanner() {
|
public String getBanner() {
|
||||||
@ -40,4 +43,8 @@ public class UserData extends SubscribedUserData {
|
|||||||
public boolean isFriend() {
|
public boolean isFriend() {
|
||||||
return isFriend;
|
return isFriend;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isCanBeFollowed() {
|
||||||
|
return canBeFollowed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
package ml.docilealligator.infinityforreddit;
|
package ml.docilealligator.infinityforreddit;
|
||||||
|
|
||||||
import android.arch.lifecycle.Observer;
|
|
||||||
import android.arch.lifecycle.ViewModelProviders;
|
import android.arch.lifecycle.ViewModelProviders;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.os.AsyncTask;
|
import android.os.AsyncTask;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.annotation.Nullable;
|
|
||||||
import android.support.v4.app.Fragment;
|
import android.support.v4.app.Fragment;
|
||||||
import android.support.v4.view.GravityCompat;
|
import android.support.v4.view.GravityCompat;
|
||||||
import android.support.v4.widget.DrawerLayout;
|
import android.support.v4.widget.DrawerLayout;
|
||||||
@ -166,33 +164,27 @@ public class MainActivity extends AppCompatActivity {
|
|||||||
subscribedSubredditRecyclerView.setAdapter(subredditadapter);
|
subscribedSubredditRecyclerView.setAdapter(subredditadapter);
|
||||||
|
|
||||||
mSubscribedSubredditViewModel = ViewModelProviders.of(this).get(SubscribedSubredditViewModel.class);
|
mSubscribedSubredditViewModel = ViewModelProviders.of(this).get(SubscribedSubredditViewModel.class);
|
||||||
mSubscribedSubredditViewModel.getAllSubscribedSubreddits().observe(this, new Observer<List<SubscribedSubredditData>>() {
|
mSubscribedSubredditViewModel.getAllSubscribedSubreddits().observe(this, subscribedSubredditData -> {
|
||||||
@Override
|
if (subscribedSubredditData == null || subscribedSubredditData.size() == 0) {
|
||||||
public void onChanged(@Nullable final List<SubscribedSubredditData> subscribedSubredditData) {
|
subscriptionsLabelTextView.setVisibility(View.GONE);
|
||||||
if (subscribedSubredditData == null || subscribedSubredditData.size() == 0) {
|
} else {
|
||||||
subscriptionsLabelTextView.setVisibility(View.GONE);
|
subscriptionsLabelTextView.setVisibility(View.VISIBLE);
|
||||||
} else {
|
|
||||||
subscriptionsLabelTextView.setVisibility(View.VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
subredditadapter.setSubscribedSubreddits(subscribedSubredditData);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
subredditadapter.setSubscribedSubreddits(subscribedSubredditData);
|
||||||
});
|
});
|
||||||
|
|
||||||
final SubscribedUserRecyclerViewAdapter userAdapter =
|
final SubscribedUserRecyclerViewAdapter userAdapter =
|
||||||
new SubscribedUserRecyclerViewAdapter(this, drawer::closeDrawers);
|
new SubscribedUserRecyclerViewAdapter(this, drawer::closeDrawers);
|
||||||
subscribedUserRecyclerView.setAdapter(userAdapter);
|
subscribedUserRecyclerView.setAdapter(userAdapter);
|
||||||
mSubscribedUserViewModel = ViewModelProviders.of(this).get(SubscribedUserViewModel.class);
|
mSubscribedUserViewModel = ViewModelProviders.of(this).get(SubscribedUserViewModel.class);
|
||||||
mSubscribedUserViewModel.getAllSubscribedUsers().observe(this, new Observer<List<SubscribedUserData>>() {
|
mSubscribedUserViewModel.getAllSubscribedUsers().observe(this, subscribedUserData -> {
|
||||||
@Override
|
if (subscribedUserData == null || subscribedUserData.size() == 0) {
|
||||||
public void onChanged(@Nullable final List<SubscribedUserData> subscribedUserData) {
|
followingLabelTextView.setVisibility(View.GONE);
|
||||||
if (subscribedUserData == null || subscribedUserData.size() == 0) {
|
} else {
|
||||||
followingLabelTextView.setVisibility(View.GONE);
|
followingLabelTextView.setVisibility(View.VISIBLE);
|
||||||
} else {
|
|
||||||
followingLabelTextView.setVisibility(View.VISIBLE);
|
|
||||||
}
|
|
||||||
userAdapter.setSubscribedUsers(subscribedUserData);
|
|
||||||
}
|
}
|
||||||
|
userAdapter.setSubscribedUsers(subscribedUserData);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,8 +43,12 @@ public class ParseUserData {
|
|||||||
String userName = jsonResponse.getString(JSONUtils.NAME_KEY);
|
String userName = jsonResponse.getString(JSONUtils.NAME_KEY);
|
||||||
String iconImageUrl = jsonResponse.getString(JSONUtils.ICON_IMG_KEY);
|
String iconImageUrl = jsonResponse.getString(JSONUtils.ICON_IMG_KEY);
|
||||||
String bannerImageUrl = "";
|
String bannerImageUrl = "";
|
||||||
|
boolean canBeFollowed;
|
||||||
if(jsonResponse.has(JSONUtils.SUBREDDIT_KEY) && !jsonResponse.isNull(JSONUtils.SUBREDDIT_KEY)) {
|
if(jsonResponse.has(JSONUtils.SUBREDDIT_KEY) && !jsonResponse.isNull(JSONUtils.SUBREDDIT_KEY)) {
|
||||||
bannerImageUrl = jsonResponse.getJSONObject(JSONUtils.SUBREDDIT_KEY).getString(JSONUtils.BANNER_IMG_KEY);
|
bannerImageUrl = jsonResponse.getJSONObject(JSONUtils.SUBREDDIT_KEY).getString(JSONUtils.BANNER_IMG_KEY);
|
||||||
|
canBeFollowed = true;
|
||||||
|
} else {
|
||||||
|
canBeFollowed = false;
|
||||||
}
|
}
|
||||||
int linkKarma = jsonResponse.getInt(JSONUtils.LINK_KARMA_KEY);
|
int linkKarma = jsonResponse.getInt(JSONUtils.LINK_KARMA_KEY);
|
||||||
int commentKarma = jsonResponse.getInt(JSONUtils.COMMENT_KARMA_KEY);
|
int commentKarma = jsonResponse.getInt(JSONUtils.COMMENT_KARMA_KEY);
|
||||||
@ -52,7 +56,7 @@ public class ParseUserData {
|
|||||||
boolean isGold = jsonResponse.getBoolean(JSONUtils.IS_GOLD_KEY);
|
boolean isGold = jsonResponse.getBoolean(JSONUtils.IS_GOLD_KEY);
|
||||||
boolean isFriend = jsonResponse.getBoolean(JSONUtils.IS_FRIEND_KEY);
|
boolean isFriend = jsonResponse.getBoolean(JSONUtils.IS_FRIEND_KEY);
|
||||||
|
|
||||||
userData = new UserData(userName, iconImageUrl, bannerImageUrl, karma, isGold, isFriend);
|
userData = new UserData(userName, iconImageUrl, bannerImageUrl, karma, isGold, isFriend, canBeFollowed);
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
parseFailed = true;
|
parseFailed = true;
|
||||||
Log.i("parse user data error", e.getMessage());
|
Log.i("parse user data error", e.getMessage());
|
||||||
|
@ -666,11 +666,8 @@ class PostRecyclerViewAdapter extends PagedListAdapter<Post, RecyclerView.ViewHo
|
|||||||
DataViewHolder(View itemView) {
|
DataViewHolder(View itemView) {
|
||||||
super(itemView);
|
super(itemView);
|
||||||
ButterKnife.bind(this, itemView);
|
ButterKnife.bind(this, itemView);
|
||||||
scoreTextView.setOnClickListener(new View.OnClickListener() {
|
scoreTextView.setOnClickListener(view -> {
|
||||||
@Override
|
//Do nothing in order to prevent clicking this to start ViewPostDetailActivity
|
||||||
public void onClick(View view) {
|
|
||||||
//Do nothing in order to prevent clicking this to start ViewPostDetailActivity
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -70,7 +70,7 @@ class UserFollowing {
|
|||||||
}
|
}
|
||||||
userFollowingListener.onUserFollowingSuccess();
|
userFollowingListener.onUserFollowingSuccess();
|
||||||
} else {
|
} else {
|
||||||
Log.i("call failed", response.message());
|
Log.i("call failed", Integer.toString(response.code()));
|
||||||
userFollowingListener.onUserFollowingFail();
|
userFollowingListener.onUserFollowingFail();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@ import android.support.design.widget.Snackbar;
|
|||||||
import android.support.v7.app.AppCompatActivity;
|
import android.support.v7.app.AppCompatActivity;
|
||||||
import android.support.v7.widget.Toolbar;
|
import android.support.v7.widget.Toolbar;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
@ -98,6 +99,7 @@ public class ViewUserDetailActivity extends AppCompatActivity {
|
|||||||
|
|
||||||
String userName = getIntent().getExtras().getString(EXTRA_USER_NAME_KEY);
|
String userName = getIntent().getExtras().getString(EXTRA_USER_NAME_KEY);
|
||||||
String title = "u/" + userName;
|
String title = "u/" + userName;
|
||||||
|
userNameTextView.setText(title);
|
||||||
|
|
||||||
CollapsingToolbarLayout collapsingToolbarLayout = findViewById(R.id.collapsing_toolbar_layout_view_user_detail_activity);
|
CollapsingToolbarLayout collapsingToolbarLayout = findViewById(R.id.collapsing_toolbar_layout_view_user_detail_activity);
|
||||||
AppBarLayout appBarLayout = findViewById(R.id.app_bar_layout_view_user_detail_activity);
|
AppBarLayout appBarLayout = findViewById(R.id.app_bar_layout_view_user_detail_activity);
|
||||||
@ -127,65 +129,7 @@ public class ViewUserDetailActivity extends AppCompatActivity {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
subscribeUserChip.setOnClickListener(view -> {
|
|
||||||
if(subscriptionReady) {
|
|
||||||
subscriptionReady = false;
|
|
||||||
if(subscribeUserChip.getText().equals(getResources().getString(R.string.follow))) {
|
|
||||||
UserFollowing.followUser(mOauthRetrofit, mRetrofit, sharedPreferences,
|
|
||||||
userName, subscribedUserDao, new UserFollowing.UserFollowingListener() {
|
|
||||||
@Override
|
|
||||||
public void onUserFollowingSuccess() {
|
|
||||||
subscribeUserChip.setText(R.string.unfollow);
|
|
||||||
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorAccent));
|
|
||||||
makeSnackbar(R.string.followed);
|
|
||||||
subscriptionReady = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onUserFollowingFail() {
|
|
||||||
makeSnackbar(R.string.follow_failed);
|
|
||||||
subscriptionReady = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
UserFollowing.unfollowUser(mOauthRetrofit, mRetrofit, sharedPreferences,
|
|
||||||
userName, subscribedUserDao, new UserFollowing.UserFollowingListener() {
|
|
||||||
@Override
|
|
||||||
public void onUserFollowingSuccess() {
|
|
||||||
subscribeUserChip.setText(R.string.follow);
|
|
||||||
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorPrimaryDark));
|
|
||||||
makeSnackbar(R.string.unfollowed);
|
|
||||||
subscriptionReady = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onUserFollowingFail() {
|
|
||||||
makeSnackbar(R.string.unfollow_failed);
|
|
||||||
subscriptionReady = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
subscribedUserDao = SubscribedUserRoomDatabase.getDatabase(this).subscribedUserDao();
|
subscribedUserDao = SubscribedUserRoomDatabase.getDatabase(this).subscribedUserDao();
|
||||||
|
|
||||||
new CheckIsFollowingUserAsyncTask(subscribedUserDao, userName, new CheckIsFollowingUserAsyncTask.CheckIsFollowingUserListener() {
|
|
||||||
@Override
|
|
||||||
public void isSubscribed() {
|
|
||||||
subscribeUserChip.setText(R.string.unfollow);
|
|
||||||
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorAccent));
|
|
||||||
subscriptionReady = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void isNotSubscribed() {
|
|
||||||
subscribeUserChip.setText(R.string.follow);
|
|
||||||
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorPrimaryDark));
|
|
||||||
subscriptionReady = true;
|
|
||||||
}
|
|
||||||
}).execute();
|
|
||||||
|
|
||||||
glide = Glide.with(this);
|
glide = Glide.with(this);
|
||||||
|
|
||||||
userViewModel = ViewModelProviders.of(this, new UserViewModel.Factory(getApplication(), userName))
|
userViewModel = ViewModelProviders.of(this, new UserViewModel.Factory(getApplication(), userName))
|
||||||
@ -244,6 +188,68 @@ public class ViewUserDetailActivity extends AppCompatActivity {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(userData.isCanBeFollowed()) {
|
||||||
|
subscribeUserChip.setVisibility(View.VISIBLE);
|
||||||
|
subscribeUserChip.setOnClickListener(view -> {
|
||||||
|
if(subscriptionReady) {
|
||||||
|
subscriptionReady = false;
|
||||||
|
if(subscribeUserChip.getText().equals(getResources().getString(R.string.follow))) {
|
||||||
|
UserFollowing.followUser(mOauthRetrofit, mRetrofit, sharedPreferences,
|
||||||
|
userName, subscribedUserDao, new UserFollowing.UserFollowingListener() {
|
||||||
|
@Override
|
||||||
|
public void onUserFollowingSuccess() {
|
||||||
|
subscribeUserChip.setText(R.string.unfollow);
|
||||||
|
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorAccent));
|
||||||
|
makeSnackbar(R.string.followed);
|
||||||
|
subscriptionReady = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onUserFollowingFail() {
|
||||||
|
makeSnackbar(R.string.follow_failed);
|
||||||
|
subscriptionReady = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
UserFollowing.unfollowUser(mOauthRetrofit, mRetrofit, sharedPreferences,
|
||||||
|
userName, subscribedUserDao, new UserFollowing.UserFollowingListener() {
|
||||||
|
@Override
|
||||||
|
public void onUserFollowingSuccess() {
|
||||||
|
subscribeUserChip.setText(R.string.follow);
|
||||||
|
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorPrimaryDark));
|
||||||
|
makeSnackbar(R.string.unfollowed);
|
||||||
|
subscriptionReady = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onUserFollowingFail() {
|
||||||
|
makeSnackbar(R.string.unfollow_failed);
|
||||||
|
subscriptionReady = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
new CheckIsFollowingUserAsyncTask(subscribedUserDao, userName, new CheckIsFollowingUserAsyncTask.CheckIsFollowingUserListener() {
|
||||||
|
@Override
|
||||||
|
public void isSubscribed() {
|
||||||
|
subscribeUserChip.setText(R.string.unfollow);
|
||||||
|
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorAccent));
|
||||||
|
subscriptionReady = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void isNotSubscribed() {
|
||||||
|
subscribeUserChip.setText(R.string.follow);
|
||||||
|
subscribeUserChip.setChipBackgroundColor(getResources().getColorStateList(R.color.colorPrimaryDark));
|
||||||
|
subscriptionReady = true;
|
||||||
|
}
|
||||||
|
}).execute();
|
||||||
|
} else {
|
||||||
|
subscribeUserChip.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
|
||||||
String userFullName = "u/" + userData.getName();
|
String userFullName = "u/" + userData.getName();
|
||||||
userNameTextView.setText(userFullName);
|
userNameTextView.setText(userFullName);
|
||||||
String karma = getString(R.string.karma_info, userData.getKarma());
|
String karma = getString(R.string.karma_info, userData.getKarma());
|
||||||
|
@ -68,6 +68,7 @@
|
|||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
|
android:layout_marginBottom="16dp"
|
||||||
android:textColor="@android:color/black"
|
android:textColor="@android:color/black"
|
||||||
android:layout_gravity="center_horizontal"/>
|
android:layout_gravity="center_horizontal"/>
|
||||||
|
|
||||||
@ -75,10 +76,10 @@
|
|||||||
android:id="@+id/subscribe_user_chip_view_user_detail_activity"
|
android:id="@+id/subscribe_user_chip_view_user_detail_activity"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="16dp"
|
|
||||||
android:layout_marginBottom="16dp"
|
android:layout_marginBottom="16dp"
|
||||||
android:textColor="@android:color/white"
|
android:textColor="@android:color/white"
|
||||||
android:layout_gravity="center_horizontal"/>
|
android:layout_gravity="center_horizontal"
|
||||||
|
android:visibility="gone"/>
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user