This commit is contained in:
hiddify-com
2024-05-31 23:13:39 +02:00
parent 5a02c4b546
commit 8ef59d7552
6 changed files with 46 additions and 39 deletions

View File

@@ -136,7 +136,7 @@ jobs:
if: startsWith(matrix.platform,'android')
uses: gradle/actions/setup-gradle@v3
with:
gradle-version: 8.1
gradle-version: 7.5
- name: Setup dependencies
run: |
make ${{ matrix.platform }}-install-dependencies

View File

@@ -1,3 +1,3 @@
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
org.gradle.jvmargs=-Xmx4048m -Dfile.encoding=UTF-8
android.useAndroidX=true
android.enableJetifier=true

View File

@@ -18,8 +18,8 @@ pluginManagement {
plugins {
id "dev.flutter.flutter-plugin-loader" version "1.0.0"
id "com.android.application" version "8.0.0" apply false
id "org.jetbrains.kotlin.android" version "1.8.0" apply false
id "com.android.application" version "7.5.0" apply false
id "org.jetbrains.kotlin.android" version "1.7.5" apply false
}
include ":app"

View File

@@ -1,15 +1,15 @@
import 'package:dartx/dartx.dart';
import 'package:fluentui_system_icons/fluentui_system_icons.dart';
import 'package:flutter/material.dart';
// import 'package:flutter_easy_permission/easy_permissions.dart';
import 'package:flutter_easy_permission/easy_permissions.dart';
import 'package:hiddify/core/localization/translations.dart';
import 'package:hiddify/utils/utils.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:mobile_scanner/mobile_scanner.dart';
// import 'package:permission_handler/permission_handler.dart';
// const permissions = [Permissions.CAMERA];
// const permissionGroup = [PermissionGroup.Camera];
const permissions = [Permissions.CAMERA];
const permissionGroup = [PermissionGroup.Camera];
class QRCodeScannerScreen extends StatefulHookConsumerWidget {
const QRCodeScannerScreen({super.key});
@@ -31,52 +31,51 @@ class _QRCodeScannerScreenState extends ConsumerState<QRCodeScannerScreen> with
final controller = MobileScannerController(detectionTimeoutMs: 500, autoStart: false);
bool started = false;
// late FlutterEasyPermission _easyPermission;
late FlutterEasyPermission _easyPermission;
@override
void initState() {
super.initState();
WidgetsBinding.instance.addObserver(this);
// _easyPermission = FlutterEasyPermission()
// ..addPermissionCallback(onGranted: (requestCode, androidPerms, iosPerm) {
// debugPrint("android:$androidPerms");
// debugPrint("iOS:$iosPerm");
// startQrScannerIfPermissionGranted();
// }, onDenied: (requestCode, androidPerms, iosPerm, isPermanent) {
// if (isPermanent) {
// FlutterEasyPermission.showAppSettingsDialog(title: "Camera");
// } else {
// debugPrint("android:$androidPerms");
// debugPrint("iOS:$iosPerm");
// }
// }, onSettingsReturned: () {
// startQrScannerIfPermissionGranted();
// });
_easyPermission = FlutterEasyPermission()
..addPermissionCallback(onGranted: (requestCode, androidPerms, iosPerm) {
debugPrint("android:$androidPerms");
debugPrint("iOS:$iosPerm");
startQrScannerIfPermissionGranted();
}, onDenied: (requestCode, androidPerms, iosPerm, isPermanent) {
if (isPermanent) {
FlutterEasyPermission.showAppSettingsDialog(title: "Camera");
} else {
debugPrint("android:$androidPerms");
debugPrint("iOS:$iosPerm");
}
}, onSettingsReturned: () {
startQrScannerIfPermissionGranted();
});
}
@override
void dispose() {
controller.stop();
// _easyPermission.dispose();
_easyPermission.dispose();
WidgetsBinding.instance.removeObserver(this);
super.dispose();
}
void startQrScannerIfPermissionGranted() {
// FlutterEasyPermission.has(perms: permissions, permsGroup: permissionGroup)
// .then((value) {
// if (value) {
// controller.start().then((result) {
// if (result != null) {
// setState(() {
// started = true;
// });
// }
// }).catchError((error) {
// loggy.warning("Error starting scanner: $error");
// });
// } else {}
// });
FlutterEasyPermission.has(perms: permissions, permsGroup: permissionGroup).then((value) {
if (value) {
controller.start().then((result) {
if (result != null) {
setState(() {
started = true;
});
}
}).catchError((error) {
loggy.warning("Error starting scanner: $error");
});
} else {}
});
}
@override

View File

@@ -487,6 +487,14 @@ packages:
url: "https://pub.dev"
source: hosted
version: "0.6.0"
flutter_easy_permission:
dependency: "direct main"
description:
name: flutter_easy_permission
sha256: "05eb1b561c894adef28b3ae38d8087fc2635f1047c5e18cf2698fb42b6ccc132"
url: "https://pub.dev"
source: hosted
version: "1.1.2"
flutter_gen_core:
dependency: transitive
description:

View File

@@ -81,7 +81,7 @@ dependencies:
timezone_to_country: ^2.1.0
json_path: ^0.7.1
# permission_handler: ^11.3.0 # is not compatible with windows
# flutter_easy_permission: ^1.1.2
flutter_easy_permission: ^1.1.2
in_app_review: ^2.0.9
# circle_flags: ^4.0.2
circle_flags: