import 'package:easy_localization/easy_localization.dart'; import 'package:flutter/material.dart'; import 'package:immich_mobile/extensions/build_context_extensions.dart'; import 'package:immich_mobile/entities/album.entity.dart'; import 'package:immich_mobile/entities/store.entity.dart'; import 'package:immich_mobile/widgets/common/immich_thumbnail.dart'; class AlbumThumbnailCard extends StatelessWidget { final Function()? onTap; /// Whether or not to show the owner of the album (or "Owned") /// in the subtitle of the album final bool showOwner; const AlbumThumbnailCard({ super.key, required this.album, this.onTap, this.showOwner = false, }); final Album album; @override Widget build(BuildContext context) { var isDarkTheme = context.isDarkTheme; return LayoutBuilder( builder: (context, constraints) { var cardSize = constraints.maxWidth; buildEmptyThumbnail() { return Container( height: cardSize, width: cardSize, decoration: BoxDecoration( color: isDarkTheme ? Colors.grey[800] : Colors.grey[200], ), child: Center( child: Icon( Icons.no_photography, size: cardSize * .15, ), ), ); } buildAlbumThumbnail() => ImmichThumbnail( asset: album.thumbnail.value, width: cardSize, height: cardSize, ); buildAlbumTextRow() { // Add the owner name to the subtitle String? owner; if (showOwner) { if (album.ownerId == Store.get(StoreKey.currentUser).id) { owner = 'album_thumbnail_owned'.tr(); } else if (album.ownerName != null) { owner = 'album_thumbnail_shared_by'.tr(args: [album.ownerName!]); } } return RichText( overflow: TextOverflow.fade, text: TextSpan( children: [ TextSpan( text: album.assetCount == 1 ? 'album_thumbnail_card_item' .tr(args: ['${album.assetCount}']) : 'album_thumbnail_card_items' .tr(args: ['${album.assetCount}']), style: context.textTheme.bodyMedium, ), if (owner != null) const TextSpan(text: ' ยท '), if (owner != null) TextSpan( text: owner, style: context.textTheme.bodyMedium, ), ], ), ); } return GestureDetector( onTap: onTap, child: Flex( direction: Axis.vertical, children: [ Flexible( child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ SizedBox( width: cardSize, height: cardSize, child: ClipRRect( borderRadius: BorderRadius.circular(20), child: album.thumbnail.value == null ? buildEmptyThumbnail() : buildAlbumThumbnail(), ), ), Padding( padding: const EdgeInsets.only(top: 8.0), child: SizedBox( width: cardSize, child: Text( album.name, overflow: TextOverflow.ellipsis, style: context.textTheme.bodyMedium?.copyWith( color: context.primaryColor, fontWeight: FontWeight.w500, ), ), ), ), buildAlbumTextRow(), ], ), ), ], ), ); }, ); } }