refactor: member dynamic page

fix: DynamicsDataModel parsing error

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2024-11-21 12:21:35 +08:00
parent 76d1219978
commit f54859098c
14 changed files with 155 additions and 176 deletions

View File

@@ -1,48 +1,51 @@
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:PiliPalaX/http/loading_state.dart';
import 'package:PiliPalaX/pages/common/common_controller.dart';
import 'package:PiliPalaX/utils/extension.dart';
import 'package:PiliPalaX/http/member.dart';
import 'package:PiliPalaX/models/dynamics/result.dart';
class MemberDynamicsController extends GetxController {
class MemberDynamicsController extends CommonController {
MemberDynamicsController(this.mid);
final ScrollController scrollController = ScrollController();
int? mid;
int mid;
String offset = '';
int count = 0;
bool hasMore = true;
RxList<DynamicItemModel> dynamicsList = <DynamicItemModel>[].obs;
// TODO: refactor
late Future futureBuilderFuture;
@override
void onInit() async {
super.onInit();
futureBuilderFuture = getMemberDynamic('onRefresh');
queryData();
}
Future getMemberDynamic(type) async {
if (type == 'onRefresh') {
offset = '';
dynamicsList.clear();
}
if (offset == '-1') {
return;
}
var res = await MemberHttp.memberDynamic(
offset: offset,
mid: mid,
);
if (res['status']) {
dynamicsList.addAll(res['data'].items);
offset = res['data'].offset != '' ? res['data'].offset : '-1';
hasMore = res['data'].hasMore;
}
return res;
@override
Future onRefresh() {
offset = '';
hasMore = true;
return super.onRefresh();
}
// 上拉加载
Future onLoad() async {
getMemberDynamic('onLoad');
@override
Future queryData([bool isRefresh = true]) {
if (isRefresh.not && (hasMore.not || offset == '-1')) {
return Future.value();
}
return super.queryData(isRefresh);
}
@override
bool customHandleResponse(Success response) {
DynamicsDataModel data = response.response;
offset = data.offset?.isNotEmpty == true ? data.offset! : '-1';
hasMore = data.hasMore ?? false;
if (currentPage != 1 && loadingState.value is Success) {
data.items?.insertAll(0, (loadingState.value as Success).response);
}
loadingState.value = LoadingState.success(data.items);
return true;
}
@override
Future<LoadingState> customGetData() => MemberHttp.memberDynamic(
offset: offset,
mid: mid,
);
}