Loading app/src/main/java/app/fedilab/android/mastodon/activities/StatusInfoActivity.java +38 −8 Original line number Diff line number Diff line Loading @@ -15,6 +15,9 @@ package app.fedilab.android.mastodon.activities; * see <http://www.gnu.org/licenses>. */ import static app.fedilab.android.BaseMainActivity.currentInstance; import static app.fedilab.android.BaseMainActivity.currentToken; import android.os.Bundle; import android.view.MenuItem; import android.view.View; Loading @@ -24,10 +27,11 @@ import androidx.lifecycle.ViewModelProvider; import androidx.recyclerview.widget.LinearLayoutManager; import androidx.recyclerview.widget.RecyclerView; import java.net.MalformedURLException; import java.net.URL; import java.util.ArrayList; import java.util.List; import app.fedilab.android.BaseMainActivity; import app.fedilab.android.R; import app.fedilab.android.databinding.ActivityStatusInfoBinding; import app.fedilab.android.mastodon.client.entities.api.Account; Loading @@ -50,6 +54,9 @@ public class StatusInfoActivity extends BaseActivity { private boolean flagLoading; private Status status; private boolean checkRemotely; private String instance, token; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Loading @@ -62,20 +69,41 @@ public class StatusInfoActivity extends BaseActivity { getSupportActionBar().setDisplayShowHomeEnabled(true); } accountList = new ArrayList<>(); checkRemotely = false; Bundle b = getIntent().getExtras(); if (b != null) { type = (typeOfInfo) b.getSerializable(Helper.ARG_TYPE_OF_INFO); status = (Status) b.getSerializable(Helper.ARG_STATUS); checkRemotely = b.getBoolean(Helper.ARG_CHECK_REMOTELY, false); } if (type == null || status == null) { finish(); return; } token = currentToken; instance = currentInstance; if (checkRemotely) { try { URL url = new URL(status.uri); instance = url.getHost(); } catch (MalformedURLException e) { e.printStackTrace(); } token = null; if (instance != null && instance.equalsIgnoreCase(currentInstance)) { checkRemotely = false; instance = currentInstance; token = currentToken; } } flagLoading = false; max_id = null; setTitle(""); binding.title.setText(type == typeOfInfo.BOOSTED_BY ? R.string.boosted_by : R.string.favourited_by); StatusesVM statusesVM = new ViewModelProvider(StatusInfoActivity.this).get(StatusesVM.class); accountAdapter = new AccountAdapter(accountList); accountAdapter = new AccountAdapter(accountList, false, checkRemotely ? instance : null); LinearLayoutManager mLayoutManager = new LinearLayoutManager(StatusInfoActivity.this); binding.lvAccounts.setLayoutManager(mLayoutManager); binding.lvAccounts.setAdapter(accountAdapter); Loading @@ -92,9 +120,9 @@ public class StatusInfoActivity extends BaseActivity { flagLoading = true; binding.loadingNextAccounts.setVisibility(View.VISIBLE); if (type == typeOfInfo.BOOSTED_BY) { statusesVM.rebloggedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); statusesVM.rebloggedBy(instance, token, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); } else if (type == typeOfInfo.LIKED_BY) { statusesVM.favouritedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); statusesVM.favouritedBy(instance, token, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); } } } else { Loading @@ -104,9 +132,9 @@ public class StatusInfoActivity extends BaseActivity { } }); if (type == typeOfInfo.BOOSTED_BY) { statusesVM.rebloggedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); statusesVM.rebloggedBy(instance, token, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); } else if (type == typeOfInfo.LIKED_BY) { statusesVM.favouritedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); statusesVM.favouritedBy(instance, token, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); } } Loading @@ -114,7 +142,9 @@ public class StatusInfoActivity extends BaseActivity { binding.loadingNextAccounts.setVisibility(View.GONE); if (accountList != null && accounts != null && accounts.accounts != null) { int position = this.accountList.size(); if (!checkRemotely) { fetchRelationShip(accounts.accounts, position); } int startId = 0; //There are some statuses present in the timeline if (accountList.size() > 0) { Loading @@ -133,7 +163,7 @@ public class StatusInfoActivity extends BaseActivity { ids.add(account.id); } AccountsVM accountsVM = new ViewModelProvider(StatusInfoActivity.this).get(AccountsVM.class); accountsVM.getRelationships(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, ids) accountsVM.getRelationships(instance, token, ids) .observe(StatusInfoActivity.this, relationShips -> { if (relationShips != null) { for (RelationShip relationShip : relationShips) { Loading app/src/main/java/app/fedilab/android/mastodon/ui/drawer/StatusAdapter.java +12 −46 Original line number Diff line number Diff line Loading @@ -1758,57 +1758,23 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> } holder.binding.statusContent.setMovementMethod(LongClickLinkMovementMethod.getInstance()); holder.binding.reblogInfo.setOnClickListener(v -> { if (remote) { Toasty.info(context, context.getString(R.string.retrieve_remote_status), Toasty.LENGTH_SHORT).show(); searchVM.search(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, statusToDeal.uri, null, "statuses", false, true, false, 0, null, null, 1) .observe((LifecycleOwner) context, results -> { if (results != null && results.statuses != null && results.statuses.size() > 0) { Status fetchedStatus = results.statuses.get(0); if (fetchedStatus.reblogs_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.BOOSTED_BY); intent.putExtra(Helper.ARG_STATUS, fetchedStatus); context.startActivity(intent); } } else { Toasty.info(context, context.getString(R.string.toast_error_search), Toasty.LENGTH_SHORT).show(); } }); } else { if (statusToDeal.reblogs_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.BOOSTED_BY); intent.putExtra(Helper.ARG_STATUS, statusToDeal); intent.putExtra(Helper.ARG_CHECK_REMOTELY, remote); context.startActivity(intent); } } }); holder.binding.favouriteInfo.setOnClickListener(v -> { if (remote) { Toasty.info(context, context.getString(R.string.retrieve_remote_status), Toasty.LENGTH_SHORT).show(); searchVM.search(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, statusToDeal.uri, null, "statuses", false, true, false, 0, null, null, 1) .observe((LifecycleOwner) context, results -> { if (results != null && results.statuses != null && results.statuses.size() > 0) { Status fetchedStatus = results.statuses.get(0); if (fetchedStatus.favourites_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.LIKED_BY); intent.putExtra(Helper.ARG_STATUS, fetchedStatus); context.startActivity(intent); } } else { Toasty.info(context, context.getString(R.string.toast_error_search), Toasty.LENGTH_SHORT).show(); } }); } else { if (statusToDeal.favourites_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.LIKED_BY); intent.putExtra(Helper.ARG_STATUS, statusToDeal); intent.putExtra(Helper.ARG_CHECK_REMOTELY, remote); context.startActivity(intent); } } }); // --- POLL --- Loading app/src/main/java/app/fedilab/android/mastodon/viewmodel/mastodon/StatusesVM.java +6 −0 Original line number Diff line number Diff line Loading @@ -19,6 +19,7 @@ import android.app.Application; import android.net.Uri; import android.os.Handler; import android.os.Looper; import android.util.Log; import androidx.annotation.NonNull; import androidx.lifecycle.AndroidViewModel; Loading Loading @@ -474,14 +475,19 @@ public class StatusesVM extends AndroidViewModel { List<Account> accounts = null; Headers headers = null; if (accountsCall != null) { Log.v(Helper.TAG, "accountsCall: " + accountsCall.request()); try { Response<List<Account>> accountsResponse = accountsCall.execute(); if (accountsResponse.isSuccessful()) { accounts = accountsResponse.body(); Log.v(Helper.TAG, "accounts: " + accounts); } else { Log.v(Helper.TAG, "err: " + accountsResponse.errorBody().string()); } headers = accountsResponse.headers(); } catch (Exception e) { e.printStackTrace(); Log.v(Helper.TAG, "er: " + e.getMessage()); } } Accounts accountsPagination = new Accounts(); Loading src/fdroid/fastlane/metadata/android/en/changelogs/486.txt +2 −3 Original line number Diff line number Diff line Added: - Check remotely following/followers from profiles Changed: - Display all following/followers lists from remote profiles - Display all accounts that boosted/fav from a remote message Fixed: - Fix a crash with auto-fetch messages No newline at end of file Loading
app/src/main/java/app/fedilab/android/mastodon/activities/StatusInfoActivity.java +38 −8 Original line number Diff line number Diff line Loading @@ -15,6 +15,9 @@ package app.fedilab.android.mastodon.activities; * see <http://www.gnu.org/licenses>. */ import static app.fedilab.android.BaseMainActivity.currentInstance; import static app.fedilab.android.BaseMainActivity.currentToken; import android.os.Bundle; import android.view.MenuItem; import android.view.View; Loading @@ -24,10 +27,11 @@ import androidx.lifecycle.ViewModelProvider; import androidx.recyclerview.widget.LinearLayoutManager; import androidx.recyclerview.widget.RecyclerView; import java.net.MalformedURLException; import java.net.URL; import java.util.ArrayList; import java.util.List; import app.fedilab.android.BaseMainActivity; import app.fedilab.android.R; import app.fedilab.android.databinding.ActivityStatusInfoBinding; import app.fedilab.android.mastodon.client.entities.api.Account; Loading @@ -50,6 +54,9 @@ public class StatusInfoActivity extends BaseActivity { private boolean flagLoading; private Status status; private boolean checkRemotely; private String instance, token; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Loading @@ -62,20 +69,41 @@ public class StatusInfoActivity extends BaseActivity { getSupportActionBar().setDisplayShowHomeEnabled(true); } accountList = new ArrayList<>(); checkRemotely = false; Bundle b = getIntent().getExtras(); if (b != null) { type = (typeOfInfo) b.getSerializable(Helper.ARG_TYPE_OF_INFO); status = (Status) b.getSerializable(Helper.ARG_STATUS); checkRemotely = b.getBoolean(Helper.ARG_CHECK_REMOTELY, false); } if (type == null || status == null) { finish(); return; } token = currentToken; instance = currentInstance; if (checkRemotely) { try { URL url = new URL(status.uri); instance = url.getHost(); } catch (MalformedURLException e) { e.printStackTrace(); } token = null; if (instance != null && instance.equalsIgnoreCase(currentInstance)) { checkRemotely = false; instance = currentInstance; token = currentToken; } } flagLoading = false; max_id = null; setTitle(""); binding.title.setText(type == typeOfInfo.BOOSTED_BY ? R.string.boosted_by : R.string.favourited_by); StatusesVM statusesVM = new ViewModelProvider(StatusInfoActivity.this).get(StatusesVM.class); accountAdapter = new AccountAdapter(accountList); accountAdapter = new AccountAdapter(accountList, false, checkRemotely ? instance : null); LinearLayoutManager mLayoutManager = new LinearLayoutManager(StatusInfoActivity.this); binding.lvAccounts.setLayoutManager(mLayoutManager); binding.lvAccounts.setAdapter(accountAdapter); Loading @@ -92,9 +120,9 @@ public class StatusInfoActivity extends BaseActivity { flagLoading = true; binding.loadingNextAccounts.setVisibility(View.VISIBLE); if (type == typeOfInfo.BOOSTED_BY) { statusesVM.rebloggedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); statusesVM.rebloggedBy(instance, token, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); } else if (type == typeOfInfo.LIKED_BY) { statusesVM.favouritedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); statusesVM.favouritedBy(instance, token, status.id, max_id, null, null).observe(StatusInfoActivity.this, accounts -> manageView(accounts)); } } } else { Loading @@ -104,9 +132,9 @@ public class StatusInfoActivity extends BaseActivity { } }); if (type == typeOfInfo.BOOSTED_BY) { statusesVM.rebloggedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); statusesVM.rebloggedBy(instance, token, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); } else if (type == typeOfInfo.LIKED_BY) { statusesVM.favouritedBy(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); statusesVM.favouritedBy(instance, token, status.id, null, null, null).observe(StatusInfoActivity.this, this::manageView); } } Loading @@ -114,7 +142,9 @@ public class StatusInfoActivity extends BaseActivity { binding.loadingNextAccounts.setVisibility(View.GONE); if (accountList != null && accounts != null && accounts.accounts != null) { int position = this.accountList.size(); if (!checkRemotely) { fetchRelationShip(accounts.accounts, position); } int startId = 0; //There are some statuses present in the timeline if (accountList.size() > 0) { Loading @@ -133,7 +163,7 @@ public class StatusInfoActivity extends BaseActivity { ids.add(account.id); } AccountsVM accountsVM = new ViewModelProvider(StatusInfoActivity.this).get(AccountsVM.class); accountsVM.getRelationships(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, ids) accountsVM.getRelationships(instance, token, ids) .observe(StatusInfoActivity.this, relationShips -> { if (relationShips != null) { for (RelationShip relationShip : relationShips) { Loading
app/src/main/java/app/fedilab/android/mastodon/ui/drawer/StatusAdapter.java +12 −46 Original line number Diff line number Diff line Loading @@ -1758,57 +1758,23 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> } holder.binding.statusContent.setMovementMethod(LongClickLinkMovementMethod.getInstance()); holder.binding.reblogInfo.setOnClickListener(v -> { if (remote) { Toasty.info(context, context.getString(R.string.retrieve_remote_status), Toasty.LENGTH_SHORT).show(); searchVM.search(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, statusToDeal.uri, null, "statuses", false, true, false, 0, null, null, 1) .observe((LifecycleOwner) context, results -> { if (results != null && results.statuses != null && results.statuses.size() > 0) { Status fetchedStatus = results.statuses.get(0); if (fetchedStatus.reblogs_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.BOOSTED_BY); intent.putExtra(Helper.ARG_STATUS, fetchedStatus); context.startActivity(intent); } } else { Toasty.info(context, context.getString(R.string.toast_error_search), Toasty.LENGTH_SHORT).show(); } }); } else { if (statusToDeal.reblogs_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.BOOSTED_BY); intent.putExtra(Helper.ARG_STATUS, statusToDeal); intent.putExtra(Helper.ARG_CHECK_REMOTELY, remote); context.startActivity(intent); } } }); holder.binding.favouriteInfo.setOnClickListener(v -> { if (remote) { Toasty.info(context, context.getString(R.string.retrieve_remote_status), Toasty.LENGTH_SHORT).show(); searchVM.search(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, statusToDeal.uri, null, "statuses", false, true, false, 0, null, null, 1) .observe((LifecycleOwner) context, results -> { if (results != null && results.statuses != null && results.statuses.size() > 0) { Status fetchedStatus = results.statuses.get(0); if (fetchedStatus.favourites_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.LIKED_BY); intent.putExtra(Helper.ARG_STATUS, fetchedStatus); context.startActivity(intent); } } else { Toasty.info(context, context.getString(R.string.toast_error_search), Toasty.LENGTH_SHORT).show(); } }); } else { if (statusToDeal.favourites_count > 0) { Intent intent = new Intent(context, StatusInfoActivity.class); intent.putExtra(Helper.ARG_TYPE_OF_INFO, StatusInfoActivity.typeOfInfo.LIKED_BY); intent.putExtra(Helper.ARG_STATUS, statusToDeal); intent.putExtra(Helper.ARG_CHECK_REMOTELY, remote); context.startActivity(intent); } } }); // --- POLL --- Loading
app/src/main/java/app/fedilab/android/mastodon/viewmodel/mastodon/StatusesVM.java +6 −0 Original line number Diff line number Diff line Loading @@ -19,6 +19,7 @@ import android.app.Application; import android.net.Uri; import android.os.Handler; import android.os.Looper; import android.util.Log; import androidx.annotation.NonNull; import androidx.lifecycle.AndroidViewModel; Loading Loading @@ -474,14 +475,19 @@ public class StatusesVM extends AndroidViewModel { List<Account> accounts = null; Headers headers = null; if (accountsCall != null) { Log.v(Helper.TAG, "accountsCall: " + accountsCall.request()); try { Response<List<Account>> accountsResponse = accountsCall.execute(); if (accountsResponse.isSuccessful()) { accounts = accountsResponse.body(); Log.v(Helper.TAG, "accounts: " + accounts); } else { Log.v(Helper.TAG, "err: " + accountsResponse.errorBody().string()); } headers = accountsResponse.headers(); } catch (Exception e) { e.printStackTrace(); Log.v(Helper.TAG, "er: " + e.getMessage()); } } Accounts accountsPagination = new Accounts(); Loading
src/fdroid/fastlane/metadata/android/en/changelogs/486.txt +2 −3 Original line number Diff line number Diff line Added: - Check remotely following/followers from profiles Changed: - Display all following/followers lists from remote profiles - Display all accounts that boosted/fav from a remote message Fixed: - Fix a crash with auto-fetch messages No newline at end of file