From 75b1ed08b49e5d67359486f4d833d972decbb51d Mon Sep 17 00:00:00 2001 From: Alex Tran Date: Mon, 14 Feb 2022 14:42:06 -0600 Subject: [PATCH] Fixed problem of not disconnecting Websocket when logging out --- .../asset_viewer/views/image_viewer_page.dart | 91 +++++++++---------- .../shared/providers/websocket.provider.dart | 2 +- 2 files changed, 46 insertions(+), 47 deletions(-) diff --git a/mobile/lib/modules/asset_viewer/views/image_viewer_page.dart b/mobile/lib/modules/asset_viewer/views/image_viewer_page.dart index d90f705afd..4f3585e3c0 100644 --- a/mobile/lib/modules/asset_viewer/views/image_viewer_page.dart +++ b/mobile/lib/modules/asset_viewer/views/image_viewer_page.dart @@ -51,56 +51,55 @@ class ImageViewerPage extends HookConsumerWidget { }); }, ), - body: Center( - child: Hero( - tag: heroTag, - child: CachedNetworkImage( - fit: BoxFit.cover, - imageUrl: imageUrl, - httpHeaders: {"Authorization": "Bearer ${box.get(accessTokenKey)}"}, - fadeInDuration: const Duration(milliseconds: 250), - errorWidget: (context, url, error) => ConstrainedBox( - constraints: const BoxConstraints(maxWidth: 300), - child: Wrap( - spacing: 32, - runSpacing: 32, - alignment: WrapAlignment.center, - children: [ - const Text( - "Failed To Render Image - Possibly Corrupted Data", - textAlign: TextAlign.center, - style: TextStyle(fontSize: 16, color: Colors.white), - ), - SingleChildScrollView( - child: Text( - error.toString(), + body: SafeArea( + child: Center( + child: Hero( + tag: heroTag, + child: CachedNetworkImage( + fit: BoxFit.cover, + imageUrl: imageUrl, + httpHeaders: {"Authorization": "Bearer ${box.get(accessTokenKey)}"}, + fadeInDuration: const Duration(milliseconds: 250), + errorWidget: (context, url, error) => ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 300), + child: Wrap( + spacing: 32, + runSpacing: 32, + alignment: WrapAlignment.center, + children: [ + const Text( + "Failed To Render Image - Possibly Corrupted Data", textAlign: TextAlign.center, - style: TextStyle(fontSize: 12, color: Colors.grey[400]), + style: TextStyle(fontSize: 16, color: Colors.white), ), - ), - ], + SingleChildScrollView( + child: Text( + error.toString(), + textAlign: TextAlign.center, + style: TextStyle(fontSize: 12, color: Colors.grey[400]), + ), + ), + ], + ), ), + placeholder: (context, url) { + return CachedNetworkImage( + cacheKey: thumbnailUrl, + fit: BoxFit.cover, + imageUrl: thumbnailUrl, + httpHeaders: {"Authorization": "Bearer ${box.get(accessTokenKey)}"}, + placeholderFadeInDuration: const Duration(milliseconds: 0), + progressIndicatorBuilder: (context, url, downloadProgress) => Transform.scale( + scale: 0.2, + child: CircularProgressIndicator(value: downloadProgress.progress), + ), + errorWidget: (context, url, error) => Icon( + Icons.error, + color: Colors.grey[300], + ), + ); + }, ), - // imageBuilder: (context, imageProvider) { - // return PhotoView(imageProvider: imageProvider); - // }, - placeholder: (context, url) { - return CachedNetworkImage( - cacheKey: thumbnailUrl, - fit: BoxFit.cover, - imageUrl: thumbnailUrl, - httpHeaders: {"Authorization": "Bearer ${box.get(accessTokenKey)}"}, - placeholderFadeInDuration: const Duration(milliseconds: 0), - progressIndicatorBuilder: (context, url, downloadProgress) => Transform.scale( - scale: 0.2, - child: CircularProgressIndicator(value: downloadProgress.progress), - ), - errorWidget: (context, url, error) => Icon( - Icons.error, - color: Colors.grey[300], - ), - ); - }, ), ), ), diff --git a/mobile/lib/shared/providers/websocket.provider.dart b/mobile/lib/shared/providers/websocket.provider.dart index f0d82c1581..3a9c0190ec 100644 --- a/mobile/lib/shared/providers/websocket.provider.dart +++ b/mobile/lib/shared/providers/websocket.provider.dart @@ -51,7 +51,7 @@ class WebsocketNotifier extends StateNotifier { final Ref ref; connect() { - var authenticationState = ref.watch(authenticationProvider); + var authenticationState = ref.read(authenticationProvider); if (authenticationState.isAuthenticated) { var accessToken = Hive.box(userInfoBox).get(accessTokenKey);