forked from Cutlery/immich
		
	* refactor: autoroutex pushroute * refactor: autoroutex popRoute * refactor: autoroutex navigate and replace * chore: add doc comments for extension methods * refactor: Add LoggerMixin and refactor Album activities to use mixin * refactor: Activity page * chore: activity user from user constructor * fix: update current asset after build method * refactor: tests with similar structure as lib * chore: remove avoid-declaring-call-method rule from dcm analysis * test: fix proper expect order * test: activity_statistics_provider_test * test: activity_provider_test * test: use proper matchers * test: activity_text_field_test & dismissible_activity_test added * test: add http mock to return transparent image * test: download isar core libs during test * test: add widget tags to widget test cases * test: activity_tile_test * build: currentAlbumProvider to generator * movie add / remove like to activity input tile * test: activities_page_test.dart * chore: better error logs * chore: dismissibleactivity as statelesswidget --------- Co-authored-by: shalong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:auto_route/auto_route.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:immich_mobile/modules/search/models/curated_content.dart';
 | |
| import 'package:immich_mobile/modules/search/ui/thumbnail_with_info.dart';
 | |
| import 'package:immich_mobile/routing/router.dart';
 | |
| import 'package:immich_mobile/shared/models/store.dart';
 | |
| import 'package:immich_mobile/utils/image_url_builder.dart';
 | |
| 
 | |
| class ExploreGrid extends StatelessWidget {
 | |
|   final List<CuratedContent> curatedContent;
 | |
|   final bool isPeople;
 | |
| 
 | |
|   const ExploreGrid({
 | |
|     super.key,
 | |
|     required this.curatedContent,
 | |
|     this.isPeople = false,
 | |
|   });
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     if (curatedContent.isEmpty) {
 | |
|       return Padding(
 | |
|         padding: const EdgeInsets.symmetric(horizontal: 16.0),
 | |
|         child: SizedBox(
 | |
|           height: 100,
 | |
|           width: 100,
 | |
|           child: ThumbnailWithInfo(
 | |
|             textInfo: '',
 | |
|             onTap: () {},
 | |
|           ),
 | |
|         ),
 | |
|       );
 | |
|     }
 | |
| 
 | |
|     return GridView.builder(
 | |
|       gridDelegate: const SliverGridDelegateWithMaxCrossAxisExtent(
 | |
|         maxCrossAxisExtent: 140,
 | |
|         mainAxisSpacing: 4,
 | |
|         crossAxisSpacing: 4,
 | |
|       ),
 | |
|       itemBuilder: (context, index) {
 | |
|         final content = curatedContent[index];
 | |
|         final thumbnailRequestUrl = isPeople
 | |
|             ? getFaceThumbnailUrl(content.id)
 | |
|             : '${Store.get(StoreKey.serverEndpoint)}/asset/thumbnail/${content.id}';
 | |
| 
 | |
|         return ThumbnailWithInfo(
 | |
|           imageUrl: thumbnailRequestUrl,
 | |
|           textInfo: content.label,
 | |
|           borderRadius: 0,
 | |
|           onTap: () {
 | |
|             isPeople
 | |
|                 ? context.pushRoute(
 | |
|                     PersonResultRoute(
 | |
|                       personId: content.id,
 | |
|                       personName: content.label,
 | |
|                     ),
 | |
|                   )
 | |
|                 : context.pushRoute(
 | |
|                     SearchResultRoute(searchTerm: 'm:${content.label}'),
 | |
|                   );
 | |
|           },
 | |
|         );
 | |
|       },
 | |
|       itemCount: curatedContent.length,
 | |
|     );
 | |
|   }
 | |
| }
 |