mirror of
https://github.com/immich-app/immich.git
synced 2025-01-03 13:09:27 +02:00
af32183728
* 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();
|
|
});
|
|
}
|
|
}
|