123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- import 'package:domain/entity/property_sale_rent_entity.dart';
- import 'package:plugin_platform/http/http_result.dart';
- import 'package:riverpod_annotation/riverpod_annotation.dart';
- import 'package:shared/utils/log_utils.dart';
- import 'package:plugin_platform/engine/toast/toast_engine.dart';
- import 'package:widgets/load_state_layout.dart';
- import 'package:widgets/widget_export.dart';
- import '../../../respository/property_resposity.dart';
- import '../page/property_sale_state.dart';
- part 'property_sale_vm.g.dart';
- @riverpod
- class PropertySaleVm extends _$PropertySaleVm {
- late PropertyRespository propertyRespositoryInstance;
- bool _needShowPlaceholder = false;
- int _page = 1;
- int _limit = 10;
- int _count = 0;
-
- final EasyRefreshController refreshController = EasyRefreshController(
- controlFinishRefresh: true,
- controlFinishLoad: true,
- );
- PropertySaleState initState() {
- return PropertySaleState(
- list: [],
- );
- }
- @override
- PropertySaleState build() {
-
- propertyRespositoryInstance = ref.read(propertyRespositoryProvider);
-
- PropertySaleState state = initState();
-
- return state;
- }
-
- void changeLoadingState(LoadState loadState, String? errorMsg) {
- state = state.copyWith(
- loadingState: loadState,
- errorMessage: errorMsg
- );
- }
-
- initPageData() {
- Log.d("----property_news_vm-----initPageData");
- onRefresh();
- }
-
- Future loadMore() async {
- Log.d("----property_news_vm-----loadMore");
-
-
-
-
-
-
-
-
-
- _page++;
- getListData();
- }
-
- Future onRefresh() async {
- Log.d("----property_news_vm-----onRefresh ");
-
- _page = 1;
- getListData();
- }
-
- Future retryRequest() async {
- _page = 1;
- _needShowPlaceholder = true;
- getListData();
- }
-
- Future getListData<T>() async {
- if (_needShowPlaceholder) {
- changeLoadingState(LoadState.State_Loading, null);
- }
- Log.d("加载listData数据---------------start--${_page}---");
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- try {
-
- Map<String, dynamic> params = {
- "type": 1,
- "page": _page,
- "limit": _limit,
- };
- Log.d("请求参数------$params");
- final result = await propertyRespositoryInstance.fetchTransactionList(params);
-
- if (result.isSuccess) {
-
- handlerResultList((result.data as PropertySaleRentEntity).list);
- } else {
- String errorMessage = result.errorMsg!;
- changeLoadingState(LoadState.State_Error, errorMessage);
- ToastEngine.show(result.errorMsg ?? "Network Load Error");
- }
- } catch (e) {
- ToastEngine.show("Error: $e");
- }
- }
- void handlerResultList(List<PropertySaleRentList>? list) {
- if (list != null && list.isNotEmpty) {
-
- if (_page == 1) {
-
- state.list!.clear();
- state.list!.addAll(list.map((item)=> item.toJson()).toList());
- refreshController.finishRefresh();
-
- changeLoadingState(LoadState.State_Success, null);
- } else {
-
- final allList = state.list;
- state = state.copyWith(list: allList);
- refreshController.finishLoad();
- }
- } else {
- if (_page == 1) {
-
- state.list!.clear();
- changeLoadingState(LoadState.State_Empty, null);
- refreshController.finishRefresh();
- } else {
-
- if(state.list!.length == 0){
- changeLoadingState(LoadState.State_Empty, null);
- refreshController.finishLoad();
- }else {
- if(_needShowPlaceholder){
- changeLoadingState(LoadState.State_Success, null);
- }
- }
-
- refreshController.finishLoad(IndicatorResult.noMore);
- }
- }
- }
- }
|