You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

96 lines
2.9KB

  1. import 'dart:io';
  2. import 'package:dio/dio.dart';
  3. import 'package:farm_tpf/custom_model/CropPlot.dart';
  4. import 'package:farm_tpf/custom_model/Device.dart';
  5. import 'package:farm_tpf/custom_model/user.dart';
  6. import 'package:farm_tpf/custom_model/user_request.dart';
  7. import 'package:farm_tpf/data/api/app_exception.dart';
  8. import 'package:farm_tpf/data/api/dio_provider.dart';
  9. import 'package:farm_tpf/data/api/rest_client.dart';
  10. import 'package:farm_tpf/models/PagedResult.dart';
  11. import 'package:farm_tpf/models/Supply.dart';
  12. import 'package:farm_tpf/models/index.dart';
  13. import 'package:farm_tpf/utils/const_common.dart';
  14. class Repository {
  15. final dio = DioProvider.instance();
  16. Future<List<ActionType>> getActionTypes() {
  17. final client = RestClient(dio);
  18. return client.getActionTypes();
  19. }
  20. Future<CropPlot> getPlotDetail(int cropId, {int page, int size}) {
  21. final client = RestClient(dio);
  22. return client.getCropDetail(cropId, page: page, size: size);
  23. }
  24. Future<List<Crop>> getPlots({int page, int size, String searchString}) {
  25. final client = RestClient(dio);
  26. return client.getPlots(page: page, size: size, query: searchString);
  27. }
  28. Future<void> updatePlot(TbCropDTO tbCropDTO) {
  29. final client = RestClient(dio);
  30. return client.updateCrop(tbCropDTO);
  31. }
  32. Future<User> signInWithCredentials(String username, String password) {
  33. final client = RestClient(dio);
  34. return client.login(UserRequest(username: username, password: password));
  35. }
  36. Future<PagedResult<T>> getInfinityList<T>(String url,
  37. {int page = 0, int size = 20}) async {
  38. var initUrl = "/api/activities/latest-env-by-activity-type/1/2";
  39. var url =
  40. ConstCommon.baseUrl + initUrl + "?page=$page&paged=true&size=$size";
  41. var response = await dio.get(url);
  42. final value = PagedResult<T>.fromJson(response.data, getInstanceClass());
  43. return value;
  44. }
  45. Future<List<Supply>> getSupplies(String type) async {
  46. final client = RestClient(dio);
  47. return client.getSupplies(type);
  48. }
  49. Object getInstanceClass() {
  50. var instanceClass;
  51. if (1 == 1) {
  52. instanceClass = new Crop();
  53. }
  54. return instanceClass;
  55. }
  56. //Action
  57. Future<void> createNursery(Function(dynamic) onSuccess,
  58. Function(String) onError, String activityNursery,
  59. {List<String> filePaths}) async {
  60. var formData = FormData();
  61. filePaths.forEach((f) {
  62. formData.files.add(MapEntry("images", MultipartFile.fromFileSync(f)));
  63. });
  64. formData.fields.add(MapEntry("activityNursery", activityNursery));
  65. try {
  66. await dio
  67. .post("${ConstCommon.baseUrl}/api/createNursery", data: formData)
  68. .then((value) {
  69. onSuccess(value);
  70. }).catchError((onError) {
  71. onError(AppException.handleError(onError));
  72. });
  73. } catch (e) {
  74. onError(AppException.handleError(e));
  75. }
  76. }
  77. //Device
  78. Future<List<Device>> getDevices() {
  79. final client = RestClient(dio);
  80. return client.getDevices();
  81. }
  82. }