From 5cb3e5937fefeaf90f35c16f2aa98541abea9e93 Mon Sep 17 00:00:00 2001 From: darken Date: Sat, 28 Jul 2018 14:11:24 +0200 Subject: [PATCH] Update policy list when resuming the superuser fragment. Closes #414 --- .../topjohnwu/magisk/SuperuserFragment.java | 37 ++++++++++++------- 1 file changed, 23 insertions(+), 14 deletions(-) diff --git a/app/src/full/java/com/topjohnwu/magisk/SuperuserFragment.java b/app/src/full/java/com/topjohnwu/magisk/SuperuserFragment.java index 1d6f2d79e..71f80d63a 100644 --- a/app/src/full/java/com/topjohnwu/magisk/SuperuserFragment.java +++ b/app/src/full/java/com/topjohnwu/magisk/SuperuserFragment.java @@ -22,6 +22,8 @@ import butterknife.Unbinder; public class SuperuserFragment extends Fragment { private Unbinder unbinder; + private PackageManager pm; + private MagiskManager mm; @BindView(R.id.recyclerView) RecyclerView recyclerView; @BindView(R.id.empty_rv) TextView emptyRv; @@ -31,20 +33,8 @@ public class SuperuserFragment extends Fragment { View view = inflater.inflate(R.layout.fragment_superuser, container, false); unbinder = ButterKnife.bind(this, view); - PackageManager pm = getActivity().getPackageManager(); - MagiskManager mm = getApplication(); - - List policyList = mm.mDB.getPolicyList(pm); - - if (policyList.size() == 0) { - emptyRv.setVisibility(View.VISIBLE); - recyclerView.setVisibility(View.GONE); - } else { - recyclerView.setAdapter(new PolicyAdapter(policyList, mm.mDB, pm)); - emptyRv.setVisibility(View.GONE); - recyclerView.setVisibility(View.VISIBLE); - } - + pm = getActivity().getPackageManager(); + mm = getApplication(); return view; } @@ -54,10 +44,29 @@ public class SuperuserFragment extends Fragment { getActivity().setTitle(getString(R.string.superuser)); } + @Override + public void onResume() { + super.onResume(); + displayPolicyList(); + } + @Override public void onDestroyView() { super.onDestroyView(); unbinder.unbind(); } + private void displayPolicyList() { + List policyList = mm.mDB.getPolicyList(pm); + + if (policyList.size() == 0) { + emptyRv.setVisibility(View.VISIBLE); + recyclerView.setVisibility(View.GONE); + } else { + recyclerView.setAdapter(new PolicyAdapter(policyList, mm.mDB, pm)); + emptyRv.setVisibility(View.GONE); + recyclerView.setVisibility(View.VISIBLE); + } + } + }