utils.dart 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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. void runPreview(Widget child){
  74. runApp(GetMaterialApp(
  75. theme: ThemeData(useMaterial3: true, colorScheme: lightColorScheme),
  76. home: Preview(child: child)));
  77. }