utils.dart 2.1 KB

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