utils.dart 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. import 'dart:io';
  2. import 'dart:typed_data';
  3. import 'package:f_cache/manager.dart';
  4. import 'package:flutter/material.dart';
  5. import 'package:get/get.dart';
  6. import 'package:grpc/grpc.dart';
  7. export 'logger.dart';
  8. import 'package:common_pub/common_pub.dart';
  9. import 'styles/color_schemes.g.dart';
  10. import 'view/login/login_view.dart';
  11. import 'pb.dart' as pb;
  12. import 'package:http/http.dart' as http;
  13. Future<void> tryApi(Future<void> Function() call, {
  14. String? errTitle,
  15. Future<bool> Function(GrpcError err)? onError,
  16. Future<void> Function()? onSuccess,
  17. VoidCallback? onFinally,
  18. }) async{
  19. Future<bool> handleError(GrpcError err) async {
  20. if(onError!= null){
  21. return onError(err);
  22. }
  23. if(err.code == StatusCode.unauthenticated){
  24. if (await LoginView.to()){
  25. try{
  26. await call();
  27. }catch(e){
  28. Get.snackbar('出错了', '未知错误');
  29. }
  30. }
  31. return true;
  32. }
  33. return false;
  34. }
  35. await tryCatchGrpc(
  36. call,
  37. onError: handleError,
  38. onSuccess: onSuccess,
  39. onFinally: onFinally,
  40. );
  41. }
  42. class Preview extends StatelessWidget{
  43. const Preview({super.key, required this.child});
  44. final Widget child;
  45. @override
  46. Widget build(BuildContext context) {
  47. return child;
  48. }
  49. }
  50. typedef NetImage = pb.NetImage;
  51. extension NetImageExt on NetImage{
  52. String? get md5Hex {
  53. if(md5.isEmpty){
  54. return null;
  55. }else{
  56. return md5.toHexString();
  57. }
  58. }
  59. Future<Reader> readerBuilder()async{
  60. final url = Uri.parse(this.url);
  61. var request = http.Request('GET', url);
  62. var response = await request.send();
  63. if (response.statusCode != 200) {
  64. throw HttpException('state: ${response.statusCode}', uri: url);
  65. }
  66. final length = response.contentLength ?? 0;
  67. return Reader(response.stream, length);
  68. }
  69. Future<void> preload()async{
  70. await CacheManager().getCached(id: md5Hex ?? '', readerBuilder: readerBuilder);
  71. }
  72. }
  73. extension Uint8ListExtension on Uint8List {
  74. String toHexString({String separator = ''}) {
  75. return isEmpty
  76. ? ""
  77. : map((e) {
  78. var s = e.toRadixString(16).toUpperCase();
  79. if (e < 10) {
  80. s = '0$s';
  81. }
  82. return s;
  83. }).join(separator);
  84. }
  85. }
  86. extension IntListExtension on List<int> {
  87. String toHexString({String separator = ''}) {
  88. return isEmpty
  89. ? ""
  90. : map((e) {
  91. var s = e.toRadixString(16).toUpperCase();
  92. if (e < 10) {
  93. s = '0$s';
  94. }
  95. return s;
  96. }).join(separator);
  97. }
  98. }
  99. void runPreview(Widget child){
  100. runApp(GetMaterialApp(
  101. theme: ThemeData(useMaterial3: true, colorScheme: lightColorScheme),
  102. home: Preview(child: child)));
  103. }