gecko/lib/providers/home.dart

245 lines
7.6 KiB
Dart
Raw Normal View History

import 'dart:convert';
2021-01-26 21:00:26 +01:00
import 'dart:io';
import 'dart:math';
2021-09-12 06:47:50 +02:00
// import 'package:audioplayers/audio_cache.dart';
// import 'package:audioplayers/audioplayers.dart';
2021-01-26 21:00:26 +01:00
import 'package:flutter/material.dart';
2021-02-02 20:33:09 +01:00
import 'package:flutter/services.dart';
2021-01-26 21:00:26 +01:00
import 'dart:async';
import 'package:gecko/globals.dart';
2022-05-27 16:58:03 +02:00
import 'package:gecko/models/wallet_data.dart';
import 'package:gecko/providers/my_wallets.dart';
import 'package:gecko/providers/wallets_profiles.dart';
import 'package:gecko/screens/myWallets/unlocking_wallet.dart';
import 'package:gecko/screens/myWallets/wallets_home.dart';
2022-05-27 16:58:03 +02:00
import 'package:gecko/screens/search.dart';
2021-12-20 21:33:03 +01:00
import 'package:hive_flutter/hive_flutter.dart';
2022-05-28 21:15:47 +02:00
import 'package:flutter/foundation.dart' show kDebugMode, kIsWeb;
2021-12-20 21:33:03 +01:00
import 'package:path_provider/path_provider.dart' as pp;
import 'package:package_info_plus/package_info_plus.dart';
import 'package:path_provider/path_provider.dart';
2022-05-27 16:58:03 +02:00
import 'package:provider/provider.dart';
2021-01-26 21:00:26 +01:00
class HomeProvider with ChangeNotifier {
2021-12-23 12:36:09 +01:00
bool? isSearching;
2021-11-14 19:21:20 +01:00
Icon searchIcon = const Icon(Icons.search);
final TextEditingController searchQuery = TextEditingController();
2021-02-16 04:57:13 +01:00
Widget appBarTitle = Text('Ğecko', style: TextStyle(color: Colors.grey[850]));
Widget appBarExplorer =
Text('Explorateur', style: TextStyle(color: Colors.grey[850]));
String homeMessage = "y'a pas de lézard ;-)";
2022-06-01 21:00:17 +02:00
String defaultMessage = "y'a pas de lézard ;-)";
2021-12-20 21:33:03 +01:00
Future<void> initHive() async {
2021-12-23 12:36:09 +01:00
late Directory hivePath;
2021-12-20 21:33:03 +01:00
2021-12-21 06:56:42 +01:00
if (!kIsWeb) {
if (Platform.isLinux || Platform.isMacOS) {
final home = Platform.environment['HOME'];
hivePath = Directory('$home/.gecko/db');
} else if (Platform.isWindows) {
final home = Platform.environment['UserProfile'];
hivePath = Directory('$home/.gecko/db');
} else if (Platform.isAndroid || Platform.isIOS) {
final home = await pp.getApplicationDocumentsDirectory();
hivePath = Directory('${home.path}/db');
}
if (!await hivePath.exists()) {
await hivePath.create(recursive: true);
}
await Hive.initFlutter(hivePath.path);
} else {
await Hive.initFlutter();
2021-12-20 21:33:03 +01:00
}
// Init app folders
final documentDir = await getApplicationDocumentsDirectory();
imageDirectory = Directory('${documentDir.path}/images');
if (!await imageDirectory.exists()) {
await imageDirectory.create();
}
2021-12-20 21:33:03 +01:00
}
Future<String> getAppVersion() async {
2021-04-19 23:22:45 +02:00
String version;
String buildNumber;
PackageInfo packageInfo = await PackageInfo.fromPlatform();
version = packageInfo.version;
2022-05-28 21:15:47 +02:00
buildNumber = kDebugMode
? packageInfo.buildNumber
: (int.parse(packageInfo.buildNumber) - 1000).toString();
2021-01-26 21:00:26 +01:00
notifyListeners();
return version + '+' + buildNumber;
}
Future changeMessage(String newMessage, int seconds) async {
homeMessage = newMessage;
notifyListeners();
await Future.delayed(Duration(seconds: seconds));
2022-06-01 21:00:17 +02:00
if (seconds != 0) homeMessage = defaultMessage;
notifyListeners();
}
Future<List?> getValidEndpoints() async {
await configBox.delete('endpoint');
List _listEndpoints = [];
if (!configBox.containsKey('endpoint') ||
configBox.get('endpoint') == [] ||
configBox.get('endpoint') == '') {
_listEndpoints = await rootBundle
.loadString('config/gdev_endpoints.json')
.then((jsonStr) => jsonDecode(jsonStr));
_listEndpoints.shuffle();
configBox.put('endpoint', _listEndpoints);
}
log.i('ENDPOINT: ' + _listEndpoints.toString());
return _listEndpoints;
2021-01-26 21:00:26 +01:00
}
T getRandomElement<T>(List<T> list) {
2021-02-16 04:57:13 +01:00
final random = Random();
2021-01-26 21:00:26 +01:00
var i = random.nextInt(list.length);
return list[i];
}
2021-02-16 04:57:13 +01:00
void handleSearchStart() {
isSearching = true;
notifyListeners();
}
2021-09-12 06:47:50 +02:00
// void playSound(String customSound, double volume) async {
// await player.play('$customSound.wav',
// volume: volume, mode: PlayerMode.LOW_LATENCY, stayAwake: false);
// }
Widget bottomAppBar(BuildContext context) {
2022-05-27 16:58:03 +02:00
MyWalletsProvider _myWalletProvider =
Provider.of<MyWalletsProvider>(context, listen: false);
WalletsProfilesProvider _historyProvider =
Provider.of<WalletsProfilesProvider>(context, listen: false);
2022-05-30 14:48:12 +02:00
final size = MediaQuery.of(context).size;
2022-05-27 16:58:03 +02:00
const bool _showBottomBar = true;
return Visibility(
visible: _showBottomBar,
child: Container(
color: yellowC,
2022-05-30 14:48:12 +02:00
width: size.width,
2022-05-27 16:58:03 +02:00
height: 80,
2022-05-30 14:48:12 +02:00
child:
// Stack(
// children: [
// // CustomPaint(
// // size: Size(size.width, 110),
// // painter: CustomRoundedButton(),
// // ),
Row(mainAxisAlignment: MainAxisAlignment.spaceAround, children: [
IconButton(
iconSize: 40,
icon: const Image(image: AssetImage('assets/loupe-noire.png')),
onPressed: () {
Navigator.popUntil(
context,
ModalRoute.withName('/'),
);
Navigator.push(
context,
MaterialPageRoute(builder: (homeContext) {
return const SearchScreen();
}),
);
},
),
IconButton(
iconSize: 70,
icon: const Image(image: AssetImage('assets/qrcode-scan.png')),
onPressed: () async {
Navigator.popUntil(
context,
ModalRoute.withName('/'),
);
_historyProvider.scan(homeContext);
},
),
IconButton(
iconSize: 60,
icon: const Image(image: AssetImage('assets/wallet.png')),
onPressed: () async {
2022-05-30 14:48:12 +02:00
WalletData? defaultWallet = _myWalletProvider.getDefaultWallet();
String? _pin;
if (_myWalletProvider.pinCode == '') {
_pin = await Navigator.push(
context,
MaterialPageRoute(
builder: (homeContext) {
return UnlockingWallet(wallet: defaultWallet);
},
),
);
}
if (_pin != null || _myWalletProvider.pinCode != '') {
Navigator.popUntil(
context,
ModalRoute.withName('/'),
);
Navigator.push(
context,
MaterialPageRoute(builder: (context) {
return const WalletsHome();
}),
);
}
2022-05-30 14:48:12 +02:00
},
),
]),
2022-05-27 16:58:03 +02:00
),
);
}
2021-02-16 04:57:13 +01:00
void handleSearchEnd() {
searchIcon = Icon(
Icons.search,
color: Colors.grey[850],
);
appBarTitle = Text('Ğecko', style: TextStyle(color: Colors.grey[850]));
appBarExplorer =
Text('Explorateur', style: TextStyle(color: Colors.grey[850]));
2021-02-16 04:57:13 +01:00
isSearching = false;
searchQuery.clear();
notifyListeners();
}
2021-04-05 20:48:28 +02:00
void rebuildWidget() {
notifyListeners();
}
2021-01-26 21:00:26 +01:00
}
2022-05-30 14:48:12 +02:00
class CustomRoundedButton extends CustomPainter {
@override
void paint(Canvas canvas, Size size) {
Paint paint = Paint()
..color = yellowC
..style = PaintingStyle.fill;
Path path = Path();
path.lineTo(size.width * 0.4, 0);
path.quadraticBezierTo(size.width * 0.5, -40, size.width * 0.6, 0);
path.lineTo(size.width, 0);
path.lineTo(size.width, size.height);
path.lineTo(0, size.height);
canvas.drawPath(path, paint);
}
@override
bool shouldRepaint(covariant CustomPainter oldDelegate) {
return false;
}
}