import 'package:auto_route/auto_route.dart'; import 'package:flutter/material.dart'; import 'package:flutter_hooks/flutter_hooks.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:immich_mobile/modules/asset_viewer/models/image_viewer_page_state.model.dart'; import 'package:immich_mobile/modules/asset_viewer/providers/image_viewer_page_state.provider.dart'; import 'package:immich_mobile/modules/asset_viewer/ui/download_loading_indicator.dart'; import 'package:immich_mobile/modules/asset_viewer/ui/exif_bottom_sheet.dart'; import 'package:immich_mobile/modules/asset_viewer/ui/remote_photo_view.dart'; import 'package:immich_mobile/modules/home/services/asset.service.dart'; import 'package:immich_mobile/utils/image_url_builder.dart'; import 'package:openapi/api.dart'; // ignore: must_be_immutable class ImageViewerPage extends HookConsumerWidget { final String heroTag; final AssetResponseDto asset; final String authToken; final ValueNotifier isZoomedListener; final void Function() isZoomedFunction; final void Function() onLoadingCompleted; final void Function() onLoadingStart; final bool threeStageLoading; ImageViewerPage({ Key? key, required this.heroTag, required this.asset, required this.authToken, required this.isZoomedFunction, required this.isZoomedListener, required this.onLoadingCompleted, required this.onLoadingStart, required this.threeStageLoading, }) : super(key: key); AssetResponseDto? assetDetail; @override Widget build(BuildContext context, WidgetRef ref) { final downloadAssetStatus = ref.watch(imageViewerStateProvider).downloadAssetStatus; getAssetExif() async { assetDetail = await ref.watch(assetServiceProvider).getAssetById(asset.id); } useEffect( () { getAssetExif(); return null; }, [], ); showInfo() { showModalBottomSheet( backgroundColor: Colors.black, barrierColor: Colors.transparent, isScrollControlled: false, context: context, builder: (context) { return ExifBottomSheet(assetDetail: assetDetail ?? asset); }, ); } return Stack( children: [ Center( child: Hero( tag: heroTag, child: RemotePhotoView( thumbnailUrl: getThumbnailUrl(asset), cacheKey: asset.id, imageUrl: getImageUrl(asset), previewUrl: threeStageLoading ? getThumbnailUrl(asset, type: ThumbnailFormat.JPEG) : null, authToken: authToken, isZoomedFunction: isZoomedFunction, isZoomedListener: isZoomedListener, onSwipeDown: () => AutoRouter.of(context).pop(), onSwipeUp: () => showInfo(), onLoadingCompleted: onLoadingCompleted, onLoadingStart: onLoadingStart, ), ), ), if (downloadAssetStatus == DownloadAssetStatus.loading) const Center( child: DownloadLoadingIndicator(), ), ], ); } }