2024-01-05 05:20:55 +00:00
|
|
|
import 'package:immich_mobile/constants/errors.dart';
|
|
|
|
import 'package:immich_mobile/mixins/error_logger.mixin.dart';
|
2024-05-01 02:36:40 +00:00
|
|
|
import 'package:immich_mobile/models/activities/activity.model.dart';
|
2024-05-02 20:59:14 +00:00
|
|
|
import 'package:immich_mobile/services/api.service.dart';
|
2023-11-06 15:46:26 +00:00
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:openapi/api.dart';
|
|
|
|
|
2024-01-05 05:20:55 +00:00
|
|
|
class ActivityService with ErrorLoggerMixin {
|
2023-11-06 15:46:26 +00:00
|
|
|
final ApiService _apiService;
|
2024-01-05 05:20:55 +00:00
|
|
|
|
|
|
|
@override
|
|
|
|
final Logger logger = Logger("ActivityService");
|
2023-11-06 15:46:26 +00:00
|
|
|
|
|
|
|
ActivityService(this._apiService);
|
|
|
|
|
|
|
|
Future<List<Activity>> getAllActivities(
|
2024-01-05 05:20:55 +00:00
|
|
|
String albumId, {
|
2023-11-06 15:46:26 +00:00
|
|
|
String? assetId,
|
2024-01-05 05:20:55 +00:00
|
|
|
}) async {
|
|
|
|
return logError(
|
|
|
|
() async {
|
2024-05-29 22:26:57 +00:00
|
|
|
final list = await _apiService.activitiesApi
|
2024-01-05 05:20:55 +00:00
|
|
|
.getActivities(albumId, assetId: assetId);
|
|
|
|
return list != null ? list.map(Activity.fromDto).toList() : [];
|
|
|
|
},
|
|
|
|
defaultValue: [],
|
2024-02-24 03:38:57 +00:00
|
|
|
errorMessage: "Failed to get all activities for album $albumId",
|
2024-01-05 05:20:55 +00:00
|
|
|
);
|
2023-11-06 15:46:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Future<int> getStatistics(String albumId, {String? assetId}) async {
|
2024-01-05 05:20:55 +00:00
|
|
|
return logError(
|
|
|
|
() async {
|
2024-05-29 22:26:57 +00:00
|
|
|
final dto = await _apiService.activitiesApi
|
2024-01-05 05:20:55 +00:00
|
|
|
.getActivityStatistics(albumId, assetId: assetId);
|
|
|
|
return dto?.comments ?? 0;
|
|
|
|
},
|
|
|
|
defaultValue: 0,
|
2024-02-24 03:38:57 +00:00
|
|
|
errorMessage: "Failed to statistics for album $albumId",
|
2024-01-05 05:20:55 +00:00
|
|
|
);
|
2023-11-06 15:46:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Future<bool> removeActivity(String id) async {
|
2024-01-05 05:20:55 +00:00
|
|
|
return logError(
|
|
|
|
() async {
|
2024-05-29 22:26:57 +00:00
|
|
|
await _apiService.activitiesApi.deleteActivity(id);
|
2024-01-05 05:20:55 +00:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
defaultValue: false,
|
2024-02-24 03:38:57 +00:00
|
|
|
errorMessage: "Failed to delete activity",
|
2024-01-05 05:20:55 +00:00
|
|
|
);
|
2023-11-06 15:46:26 +00:00
|
|
|
}
|
|
|
|
|
2024-01-05 05:20:55 +00:00
|
|
|
AsyncFuture<Activity> addActivity(
|
2023-11-06 15:46:26 +00:00
|
|
|
String albumId,
|
|
|
|
ActivityType type, {
|
|
|
|
String? assetId,
|
|
|
|
String? comment,
|
|
|
|
}) async {
|
2024-02-24 03:38:57 +00:00
|
|
|
return guardError(
|
|
|
|
() async {
|
2024-05-29 22:26:57 +00:00
|
|
|
final dto = await _apiService.activitiesApi.createActivity(
|
2024-02-24 03:38:57 +00:00
|
|
|
ActivityCreateDto(
|
|
|
|
albumId: albumId,
|
|
|
|
type: type == ActivityType.comment
|
|
|
|
? ReactionType.comment
|
|
|
|
: ReactionType.like,
|
|
|
|
assetId: assetId,
|
|
|
|
comment: comment,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
if (dto != null) {
|
|
|
|
return Activity.fromDto(dto);
|
|
|
|
}
|
|
|
|
throw NoResponseDtoError();
|
|
|
|
},
|
|
|
|
errorMessage: "Failed to create $type for album $albumId",
|
|
|
|
);
|
2023-11-06 15:46:26 +00:00
|
|
|
}
|
|
|
|
}
|