mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-31 02:27:08 -04:00 
			
		
		
		
	* 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>
		
			
				
	
	
		
			75 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:immich_mobile/constants/errors.dart';
 | |
| import 'package:immich_mobile/mixins/error_logger.mixin.dart';
 | |
| import 'package:immich_mobile/modules/activities/models/activity.model.dart';
 | |
| import 'package:immich_mobile/shared/services/api.service.dart';
 | |
| import 'package:logging/logging.dart';
 | |
| import 'package:openapi/api.dart';
 | |
| 
 | |
| class ActivityService with ErrorLoggerMixin {
 | |
|   final ApiService _apiService;
 | |
| 
 | |
|   @override
 | |
|   final Logger logger = Logger("ActivityService");
 | |
| 
 | |
|   ActivityService(this._apiService);
 | |
| 
 | |
|   Future<List<Activity>> getAllActivities(
 | |
|     String albumId, {
 | |
|     String? assetId,
 | |
|   }) async {
 | |
|     return logError(
 | |
|       () async {
 | |
|         final list = await _apiService.activityApi
 | |
|             .getActivities(albumId, assetId: assetId);
 | |
|         return list != null ? list.map(Activity.fromDto).toList() : [];
 | |
|       },
 | |
|       defaultValue: [],
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   Future<int> getStatistics(String albumId, {String? assetId}) async {
 | |
|     return logError(
 | |
|       () async {
 | |
|         final dto = await _apiService.activityApi
 | |
|             .getActivityStatistics(albumId, assetId: assetId);
 | |
|         return dto?.comments ?? 0;
 | |
|       },
 | |
|       defaultValue: 0,
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   Future<bool> removeActivity(String id) async {
 | |
|     return logError(
 | |
|       () async {
 | |
|         await _apiService.activityApi.deleteActivity(id);
 | |
|         return true;
 | |
|       },
 | |
|       defaultValue: false,
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   AsyncFuture<Activity> addActivity(
 | |
|     String albumId,
 | |
|     ActivityType type, {
 | |
|     String? assetId,
 | |
|     String? comment,
 | |
|   }) async {
 | |
|     return guardError(() async {
 | |
|       final dto = await _apiService.activityApi.createActivity(
 | |
|         ActivityCreateDto(
 | |
|           albumId: albumId,
 | |
|           type: type == ActivityType.comment
 | |
|               ? ReactionType.comment
 | |
|               : ReactionType.like,
 | |
|           assetId: assetId,
 | |
|           comment: comment,
 | |
|         ),
 | |
|       );
 | |
|       if (dto != null) {
 | |
|         return Activity.fromDto(dto);
 | |
|       }
 | |
|       throw NoResponseDtoError();
 | |
|     });
 | |
|   }
 | |
| }
 |