[app] Fix module list crashes (#578)
This commit is contained in:
parent
c9f4970ccc
commit
fe17834fa3
|
|
@ -92,21 +92,22 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
|||
protected ActivityModuleDetailBinding binding;
|
||||
protected SearchView searchView;
|
||||
private SearchView.OnQueryTextListener mSearchListener;
|
||||
private final PagerAdapter pagerAdapter = new PagerAdapter();
|
||||
private final ArrayList<ModuleAdapter> adapters = new ArrayList<>();
|
||||
|
||||
private static final Handler uninstallHandler;
|
||||
private Handler uninstallHandler;
|
||||
private PackageManager pm;
|
||||
private ModuleUtil moduleUtil;
|
||||
private ModuleUtil.InstalledModule selectedModule;
|
||||
|
||||
static {
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
HandlerThread uninstallThread = new HandlerThread("uninstall");
|
||||
uninstallThread.start();
|
||||
uninstallHandler = new Handler(uninstallThread.getLooper());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
moduleUtil = ModuleUtil.getInstance();
|
||||
pm = getPackageManager();
|
||||
moduleUtil.addListener(this);
|
||||
super.onCreate(savedInstanceState);
|
||||
binding = ActivityModuleDetailBinding.inflate(getLayoutInflater());
|
||||
setContentView(binding.getRoot());
|
||||
|
|
@ -117,28 +118,6 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
|||
if (bar != null) {
|
||||
bar.setDisplayHomeAsUpEnabled(true);
|
||||
}
|
||||
int[] users = ConfigManager.getUsers();
|
||||
if (users != null) {
|
||||
adapters.clear();
|
||||
if (users.length != 1) {
|
||||
binding.viewPager.setUserInputEnabled(true);
|
||||
ArrayList<String> titles = new ArrayList<>();
|
||||
for (int userId : users) {
|
||||
var adapter = new ModuleAdapter(userId);
|
||||
adapter.setHasStableIds(true);
|
||||
adapters.add(adapter);
|
||||
titles.add(getString(R.string.user_title, userId));
|
||||
}
|
||||
new TabLayoutMediator(binding.tabLayout, binding.viewPager, (tab, position) -> tab.setText(titles.get(position))).attach();
|
||||
binding.tabLayout.setVisibility(View.VISIBLE);
|
||||
} else {
|
||||
binding.viewPager.setUserInputEnabled(false);
|
||||
var adapter = new ModuleAdapter(0);
|
||||
adapter.setHasStableIds(true);
|
||||
adapters.add(adapter);
|
||||
binding.tabLayout.setVisibility(View.GONE);
|
||||
}
|
||||
}
|
||||
binding.viewPager.setAdapter(new PagerAdapter());
|
||||
binding.viewPager.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() {
|
||||
@Override
|
||||
|
|
@ -167,9 +146,6 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
|||
return false;
|
||||
}
|
||||
};
|
||||
moduleUtil = ModuleUtil.getInstance();
|
||||
pm = getPackageManager();
|
||||
moduleUtil.addListener(this);
|
||||
if (ConfigManager.getXposedVersionName() == null) {
|
||||
Toast.makeText(this, R.string.lsposed_not_active, Toast.LENGTH_LONG).show();
|
||||
finish();
|
||||
|
|
@ -195,6 +171,31 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
|||
@Override
|
||||
protected void onResume() {
|
||||
super.onResume();
|
||||
int[] users = ConfigManager.getUsers();
|
||||
if (users != null) {
|
||||
if (users.length != adapters.size()) {
|
||||
adapters.clear();
|
||||
if (users.length != 1) {
|
||||
binding.viewPager.setUserInputEnabled(true);
|
||||
ArrayList<String> titles = new ArrayList<>();
|
||||
for (int userId : users) {
|
||||
var adapter = new ModuleAdapter(userId);
|
||||
adapter.setHasStableIds(true);
|
||||
adapters.add(adapter);
|
||||
titles.add(getString(R.string.user_title, userId));
|
||||
}
|
||||
new TabLayoutMediator(binding.tabLayout, binding.viewPager, (tab, position) -> tab.setText(titles.get(position))).attach();
|
||||
binding.tabLayout.setVisibility(View.VISIBLE);
|
||||
} else {
|
||||
binding.viewPager.setUserInputEnabled(false);
|
||||
var adapter = new ModuleAdapter(0);
|
||||
adapter.setHasStableIds(true);
|
||||
adapters.add(adapter);
|
||||
binding.tabLayout.setVisibility(View.GONE);
|
||||
}
|
||||
pagerAdapter.notifyDataSetChanged();
|
||||
}
|
||||
}
|
||||
adapters.forEach(ModuleAdapter::refresh);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -110,7 +110,7 @@ public final class ModuleUtil {
|
|||
throw new NameNotFoundException();
|
||||
}
|
||||
} catch (NameNotFoundException e) {
|
||||
InstalledModule old = installedModules.remove(packageName);
|
||||
InstalledModule old = installedModules.remove(Pair.create(packageName, userId));
|
||||
if (old != null) {
|
||||
for (ModuleListener listener : listeners) {
|
||||
listener.onSingleInstalledModuleReloaded();
|
||||
|
|
|
|||
Loading…
Reference in New Issue