From e93270ab0a478d165d33e8625ada465620aebbf1 Mon Sep 17 00:00:00 2001 From: Norbel Ambanumben Date: Sun, 23 Mar 2025 11:03:51 +0100 Subject: chore: remove camera permission for custom branded versions --- app/src/main/AndroidManifest.xml | 5 +-- .../fragments/ProviderSelectionFragment.java | 40 ++++++++-------------- .../fragments/helpers/AbstractQrScannerHelper.java | 16 +++++++++ 3 files changed, 32 insertions(+), 29 deletions(-) create mode 100644 app/src/main/java/se/leap/bitmaskclient/providersetup/fragments/helpers/AbstractQrScannerHelper.java (limited to 'app/src/main') diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 6759862e..254f38d6 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -20,10 +20,7 @@ android:name="android.permission.WRITE_EXTERNAL_STORAGE" tools:ignore="ScopedStorage" /> - - + scannerActivityResultLauncher; +public class ProviderSelectionFragment extends BaseSetupFragment implements CancelCallback, AbstractQrScannerHelper.ScanResultCallback { private ProviderSelectionViewModel viewModel; private ArrayList radioButtons; private FProviderSelectionBinding binding; + private QrScannerHelper qrScannerHelper; public static ProviderSelectionFragment newInstance(int position) { ProviderSelectionFragment fragment = new ProviderSelectionFragment(); @@ -56,17 +53,7 @@ public class ProviderSelectionFragment extends BaseSetupFragment implements Canc getContext().getApplicationContext().getAssets())). get(ProviderSelectionViewModel.class); - scannerActivityResultLauncher = registerForActivityResult(new ScanContract(), result -> { - if(result.getContents() != null) { - try { - Introducer introducer = Introducer.fromUrl(result.getContents()); - binding.editCustomProvider.setText(introducer.toUrl()); - } catch (Exception e) { - e.printStackTrace(); - //binding.editCustomProvider.setText(result.getContents()); - } - } - }); + qrScannerHelper = new QrScannerHelper(this, this); } @Override @@ -112,13 +99,7 @@ public class ProviderSelectionFragment extends BaseSetupFragment implements Canc } private void initQrScanner() { - binding.btnQrScanner.setOnClickListener(v -> { - ScanOptions options = new ScanOptions(); - options.setBeepEnabled(false); - options.setBarcodeImageEnabled(false); - options.setOrientationLocked(false); - scannerActivityResultLauncher.launch(options); - }); + binding.btnQrScanner.setOnClickListener(v -> qrScannerHelper.startScan()); } @@ -241,4 +222,13 @@ public class ProviderSelectionFragment extends BaseSetupFragment implements Canc public void onCanceled() { binding.providerRadioGroup.check(0); } + + @Override + public void onScanResult(Introducer introducer) { + try { + binding.editCustomProvider.setText(introducer.toUrl()); + } catch (Exception e) { + e.printStackTrace(); + } + } } \ No newline at end of file diff --git a/app/src/main/java/se/leap/bitmaskclient/providersetup/fragments/helpers/AbstractQrScannerHelper.java b/app/src/main/java/se/leap/bitmaskclient/providersetup/fragments/helpers/AbstractQrScannerHelper.java new file mode 100644 index 00000000..132d8cc9 --- /dev/null +++ b/app/src/main/java/se/leap/bitmaskclient/providersetup/fragments/helpers/AbstractQrScannerHelper.java @@ -0,0 +1,16 @@ +package se.leap.bitmaskclient.providersetup.fragments.helpers; + +import androidx.fragment.app.Fragment; + +import se.leap.bitmaskclient.base.models.Introducer; + +public abstract class AbstractQrScannerHelper { + public interface ScanResultCallback { + void onScanResult(Introducer introducer); + } + + public AbstractQrScannerHelper(Fragment fragment, ScanResultCallback callback) { + } + + public abstract void startScan(); +} -- cgit v1.2.3