announcement_api.dart 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. import 'package:flutter_riverpod/flutter_riverpod.dart';
  2. import '../../core/network/api_client.dart';
  3. import '../../app.dart';
  4. import '../../shared/models/pagination_model.dart';
  5. import 'announcement_model.dart';
  6. final announcementApiProvider = Provider<AnnouncementApi>(
  7. (ref) => AnnouncementApi(ref.read(apiClientProvider)),
  8. );
  9. class AnnouncementApi {
  10. final ApiClient _client;
  11. AnnouncementApi(this._client);
  12. Future<PaginatedData<AnnouncementModel>> fetchList({
  13. int page = 1,
  14. int size = 20,
  15. }) async {
  16. final response = await _client.get<Map<String, dynamic>>(
  17. '/announcement/list',
  18. queryParameters: {'page': page, 'size': size},
  19. );
  20. final data = response.data!;
  21. final list = (data['list'] as List<dynamic>)
  22. .map((e) => AnnouncementModel.fromJson(e as Map<String, dynamic>))
  23. .toList();
  24. return PaginatedData(
  25. list: list,
  26. page: data['page'] as int,
  27. size: data['size'] as int,
  28. total: data['total'] as int,
  29. );
  30. }
  31. Future<AnnouncementModel> fetchDetail(String id) async {
  32. final response = await _client.get<Map<String, dynamic>>(
  33. '/announcement/detail/$id',
  34. );
  35. return AnnouncementModel.fromJson(response.data!);
  36. }
  37. }