cpd_2022_zi/lib/widgets/scanner.dart

69 lines
2.0 KiB
Dart
Raw Normal View History

2023-02-27 20:30:24 +01:00
import 'package:awesome_dialog/awesome_dialog.dart';
2023-02-27 17:00:28 +01:00
import 'package:flutter/material.dart';
import 'package:mobile_scanner/mobile_scanner.dart';
2023-02-27 17:15:34 +01:00
import 'package:provider/provider.dart';
2023-02-27 17:00:28 +01:00
import 'package:smoke_cess_app/models/settings.dart';
import 'package:smoke_cess_app/services/json_service.dart';
import 'package:smoke_cess_app/services/settings_service.dart';
2023-02-27 17:15:34 +01:00
import '../providers/settings_provider.dart';
import '../services/notification_service.dart';
2023-02-27 17:00:28 +01:00
class MyScanner extends StatefulWidget {
const MyScanner({super.key});
@override
State<StatefulWidget> createState() => MyScannerState();
}
class MyScannerState extends State<MyScanner> {
bool scanning = false;
void handleSucces(String? rawValue) {
String qrText = rawValue!;
Map<String, dynamic> json = stringToJSON(qrText);
Settings settings = Settings.fromJson(json);
saveSettings(settings);
2023-02-27 17:15:34 +01:00
var settingsModel = context.read<SettingsProvider>();
settingsModel.initSettings();
NotificationService().setAllNotifications();
2023-02-27 17:00:28 +01:00
setState(() {
scanning = false;
2023-02-27 20:30:24 +01:00
AwesomeDialog(
context: context,
dialogType: DialogType.success,
title: 'Geschafft',
desc: 'Der Code wurde erfolgreich gescannt!',
).show();
2023-02-27 17:00:28 +01:00
});
}
void onDetect(capture) {
2023-02-27 20:36:59 +01:00
final List<Barcode> barcodes = capture.barcodes;
for (final barcode in barcodes) {
if (barcode.rawValue != null) {
return handleSucces(barcode.rawValue);
2023-02-27 17:00:28 +01:00
}
}
}
@override
Widget build(BuildContext context) {
return scanning
? Expanded(
child: MobileScanner(
fit: BoxFit.contain,
controller: MobileScannerController(
detectionTimeoutMs: 2000,
),
onDetect: onDetect))
: ElevatedButton(
style: ElevatedButton.styleFrom(
textStyle: const TextStyle(fontSize: 20)),
onPressed: () {
setState(() => scanning = true);
},
child: const Text('Scan QR Code'),
);
}
}