Fix issue #430 - Update json payload
This commit is contained in:
parent
0c27c839d3
commit
d18dce9919
|
@ -15,34 +15,21 @@ package app.fedilab.android.activities;
|
||||||
* see <http://www.gnu.org/licenses>. */
|
* see <http://www.gnu.org/licenses>. */
|
||||||
|
|
||||||
|
|
||||||
import static androidx.core.text.HtmlCompat.FROM_HTML_MODE_LEGACY;
|
|
||||||
|
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.text.Html;
|
|
||||||
import android.text.SpannableString;
|
import android.text.SpannableString;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.TextView;
|
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import androidx.lifecycle.ViewModelProvider;
|
import androidx.lifecycle.ViewModelProvider;
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import app.fedilab.android.BaseMainActivity;
|
|
||||||
import app.fedilab.android.R;
|
import app.fedilab.android.R;
|
||||||
import app.fedilab.android.client.entities.api.Account;
|
|
||||||
import app.fedilab.android.databinding.ActivityInstanceProfileBinding;
|
import app.fedilab.android.databinding.ActivityInstanceProfileBinding;
|
||||||
import app.fedilab.android.helper.Helper;
|
import app.fedilab.android.helper.Helper;
|
||||||
import app.fedilab.android.helper.ThemeHelper;
|
import app.fedilab.android.helper.ThemeHelper;
|
||||||
import app.fedilab.android.ui.drawer.AccountAdapter;
|
|
||||||
import app.fedilab.android.viewmodel.mastodon.NodeInfoVM;
|
import app.fedilab.android.viewmodel.mastodon.NodeInfoVM;
|
||||||
import app.fedilab.android.viewmodel.mastodon.SearchVM;
|
|
||||||
import es.dmoral.toasty.Toasty;
|
import es.dmoral.toasty.Toasty;
|
||||||
|
|
||||||
public class InstanceProfileActivity extends BaseActivity {
|
public class InstanceProfileActivity extends BaseActivity {
|
||||||
|
@ -75,40 +62,13 @@ public class InstanceProfileActivity extends BaseActivity {
|
||||||
finish();
|
finish();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
binding.name.setText(nodeInfo.metadata != null ? nodeInfo.metadata.nodeName : instance);
|
binding.name.setText(instance);
|
||||||
SpannableString descriptionSpan;
|
SpannableString descriptionSpan;
|
||||||
if (nodeInfo.metadata != null && nodeInfo.metadata.nodeDescription != null) {
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N)
|
|
||||||
descriptionSpan = new SpannableString(Html.fromHtml(nodeInfo.metadata.nodeDescription, FROM_HTML_MODE_LEGACY));
|
|
||||||
else
|
|
||||||
descriptionSpan = new SpannableString(Html.fromHtml(nodeInfo.metadata.nodeDescription));
|
|
||||||
binding.description.setText(descriptionSpan, TextView.BufferType.SPANNABLE);
|
|
||||||
}
|
|
||||||
binding.userCount.setText(Helper.withSuffix((nodeInfo.usage.users.total)));
|
binding.userCount.setText(Helper.withSuffix((nodeInfo.usage.users.total)));
|
||||||
binding.statusCount.setText(Helper.withSuffix(((nodeInfo.usage.localPosts))));
|
binding.statusCount.setText(Helper.withSuffix(((nodeInfo.usage.localPosts))));
|
||||||
String softwareStr = nodeInfo.software.name + " - ";
|
String softwareStr = nodeInfo.software.name + " - ";
|
||||||
binding.software.setText(softwareStr);
|
binding.software.setText(softwareStr);
|
||||||
binding.version.setText(nodeInfo.software.version);
|
binding.version.setText(nodeInfo.software.version);
|
||||||
if (nodeInfo.metadata != null && nodeInfo.metadata.staffAccounts != null && nodeInfo.metadata.staffAccounts.size() > 0) {
|
|
||||||
SearchVM searchVM = new ViewModelProvider(InstanceProfileActivity.this).get(SearchVM.class);
|
|
||||||
List<Account> accounts = new ArrayList<>();
|
|
||||||
for (String accountURL : nodeInfo.metadata.staffAccounts) {
|
|
||||||
searchVM.search(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, accountURL, null, "accounts", false, true, false, 0, null, null, 1)
|
|
||||||
.observe(InstanceProfileActivity.this, results -> {
|
|
||||||
if (results.accounts != null && results.accounts.size() > 0) {
|
|
||||||
accounts.add(results.accounts.get(0));
|
|
||||||
}
|
|
||||||
if (accounts.size() == nodeInfo.metadata.staffAccounts.size()) {
|
|
||||||
AccountAdapter accountsListAdapter = new AccountAdapter(accounts);
|
|
||||||
binding.lvAccounts.setAdapter(accountsListAdapter);
|
|
||||||
final LinearLayoutManager mLayoutManager;
|
|
||||||
mLayoutManager = new LinearLayoutManager(InstanceProfileActivity.this);
|
|
||||||
binding.lvAccounts.setLayoutManager(mLayoutManager);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
binding.instanceContainer.setVisibility(View.VISIBLE);
|
binding.instanceContainer.setVisibility(View.VISIBLE);
|
||||||
binding.loader.setVisibility(View.GONE);
|
binding.loader.setVisibility(View.GONE);
|
||||||
});
|
});
|
||||||
|
|
|
@ -37,8 +37,6 @@ public class WellKnownNodeinfo {
|
||||||
public Software software;
|
public Software software;
|
||||||
@SerializedName("usage")
|
@SerializedName("usage")
|
||||||
public Usage usage;
|
public Usage usage;
|
||||||
@SerializedName("metadata")
|
|
||||||
public Metadata metadata;
|
|
||||||
@SerializedName("openRegistrations")
|
@SerializedName("openRegistrations")
|
||||||
public boolean openRegistrations;
|
public boolean openRegistrations;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue