[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 ActivityModuleDetailBinding binding;
|
||||||
protected SearchView searchView;
|
protected SearchView searchView;
|
||||||
private SearchView.OnQueryTextListener mSearchListener;
|
private SearchView.OnQueryTextListener mSearchListener;
|
||||||
|
private final PagerAdapter pagerAdapter = new PagerAdapter();
|
||||||
private final ArrayList<ModuleAdapter> adapters = new ArrayList<>();
|
private final ArrayList<ModuleAdapter> adapters = new ArrayList<>();
|
||||||
|
|
||||||
private static final Handler uninstallHandler;
|
private Handler uninstallHandler;
|
||||||
private PackageManager pm;
|
private PackageManager pm;
|
||||||
private ModuleUtil moduleUtil;
|
private ModuleUtil moduleUtil;
|
||||||
private ModuleUtil.InstalledModule selectedModule;
|
private ModuleUtil.InstalledModule selectedModule;
|
||||||
|
|
||||||
static {
|
@Override
|
||||||
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
HandlerThread uninstallThread = new HandlerThread("uninstall");
|
HandlerThread uninstallThread = new HandlerThread("uninstall");
|
||||||
uninstallThread.start();
|
uninstallThread.start();
|
||||||
uninstallHandler = new Handler(uninstallThread.getLooper());
|
uninstallHandler = new Handler(uninstallThread.getLooper());
|
||||||
}
|
moduleUtil = ModuleUtil.getInstance();
|
||||||
|
pm = getPackageManager();
|
||||||
@Override
|
moduleUtil.addListener(this);
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
binding = ActivityModuleDetailBinding.inflate(getLayoutInflater());
|
binding = ActivityModuleDetailBinding.inflate(getLayoutInflater());
|
||||||
setContentView(binding.getRoot());
|
setContentView(binding.getRoot());
|
||||||
|
|
@ -117,28 +118,6 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
||||||
if (bar != null) {
|
if (bar != null) {
|
||||||
bar.setDisplayHomeAsUpEnabled(true);
|
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.setAdapter(new PagerAdapter());
|
||||||
binding.viewPager.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() {
|
binding.viewPager.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() {
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -167,9 +146,6 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
moduleUtil = ModuleUtil.getInstance();
|
|
||||||
pm = getPackageManager();
|
|
||||||
moduleUtil.addListener(this);
|
|
||||||
if (ConfigManager.getXposedVersionName() == null) {
|
if (ConfigManager.getXposedVersionName() == null) {
|
||||||
Toast.makeText(this, R.string.lsposed_not_active, Toast.LENGTH_LONG).show();
|
Toast.makeText(this, R.string.lsposed_not_active, Toast.LENGTH_LONG).show();
|
||||||
finish();
|
finish();
|
||||||
|
|
@ -195,6 +171,31 @@ public class ModulesActivity extends BaseActivity implements ModuleUtil.ModuleLi
|
||||||
@Override
|
@Override
|
||||||
protected void onResume() {
|
protected void onResume() {
|
||||||
super.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);
|
adapters.forEach(ModuleAdapter::refresh);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -110,7 +110,7 @@ public final class ModuleUtil {
|
||||||
throw new NameNotFoundException();
|
throw new NameNotFoundException();
|
||||||
}
|
}
|
||||||
} catch (NameNotFoundException e) {
|
} catch (NameNotFoundException e) {
|
||||||
InstalledModule old = installedModules.remove(packageName);
|
InstalledModule old = installedModules.remove(Pair.create(packageName, userId));
|
||||||
if (old != null) {
|
if (old != null) {
|
||||||
for (ModuleListener listener : listeners) {
|
for (ModuleListener listener : listeners) {
|
||||||
listener.onSingleInstalledModuleReloaded();
|
listener.onSingleInstalledModuleReloaded();
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue