2022-12-26 20:26:30 +00:00
|
|
|
import 'dart:io';
|
|
|
|
|
|
|
|
import 'package:flutter/foundation.dart';
|
2022-11-19 19:16:46 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2022-11-09 02:23:56 +00:00
|
|
|
import 'package:get_it/get_it.dart';
|
|
|
|
import 'package:uuid/uuid.dart';
|
|
|
|
|
2023-03-22 16:43:38 +00:00
|
|
|
const macOsGroupId = 'T69YZGT58U.relatica';
|
|
|
|
|
2022-11-09 02:23:56 +00:00
|
|
|
final getIt = GetIt.instance;
|
|
|
|
|
|
|
|
String randomId() => const Uuid().v4().toString();
|
2022-11-19 19:16:46 +00:00
|
|
|
|
2022-12-26 20:26:30 +00:00
|
|
|
final platformHasCamera = Platform.isIOS || Platform.isAndroid;
|
|
|
|
|
|
|
|
final useImagePicker = kIsWeb || Platform.isAndroid || Platform.isIOS;
|
|
|
|
|
2023-04-03 21:11:25 +00:00
|
|
|
const usePhpDebugging = true;
|
2023-03-20 13:58:02 +00:00
|
|
|
|
2022-11-19 19:16:46 +00:00
|
|
|
Future<bool?> showConfirmDialog(BuildContext context, String caption) {
|
|
|
|
return showDialog<bool>(
|
|
|
|
context: context,
|
2023-03-11 04:23:44 +00:00
|
|
|
barrierDismissible: true,
|
2022-11-19 19:16:46 +00:00
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
title: Text(caption),
|
|
|
|
actions: <Widget>[
|
|
|
|
ElevatedButton(
|
|
|
|
child: const Text('OK'),
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.pop(context, true); // showDialog() returns true
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<bool?> showYesNoDialog(BuildContext context, String caption) {
|
|
|
|
return showDialog<bool>(
|
|
|
|
context: context,
|
|
|
|
barrierDismissible: false,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
title: Text(caption),
|
|
|
|
actions: <Widget>[
|
|
|
|
ElevatedButton(
|
|
|
|
child: const Text('Yes'),
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.pop(context, true); // showDialog() returns true
|
|
|
|
},
|
|
|
|
),
|
|
|
|
ElevatedButton(
|
|
|
|
child: const Text('No'),
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.pop(context, false); // showDialog() returns false
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
2023-01-30 06:04:50 +00:00
|
|
|
|
|
|
|
Future<String?> showChooseOptions(
|
|
|
|
BuildContext context,
|
|
|
|
String caption,
|
|
|
|
List<String> options,
|
|
|
|
) {
|
|
|
|
return showDialog<String?>(
|
|
|
|
context: context,
|
|
|
|
barrierDismissible: false,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
title: Text(caption),
|
|
|
|
actions: options
|
|
|
|
.map((o) => ElevatedButton(
|
|
|
|
child: Text(o),
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.pop(context, o); // showDialog() returns true
|
|
|
|
},
|
|
|
|
))
|
|
|
|
.toList());
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
2023-02-27 20:39:02 +00:00
|
|
|
|
2023-03-14 03:47:40 +00:00
|
|
|
// void clearCaches() {
|
|
|
|
// getIt<TimelineManager>().clear();
|
|
|
|
// getIt<IConnectionsRepo>().clear();
|
|
|
|
// getIt<NotificationsManager>().clear();
|
|
|
|
// }
|