refa: query data (#659)

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
dom
2025-04-10 21:43:01 +08:00
committed by GitHub
parent 99b19e7b03
commit e1b73f4766
128 changed files with 1493 additions and 1987 deletions

View File

@@ -130,7 +130,7 @@ class _NoteListPageState extends CommonSlidePageState<NoteListPage> {
),
);
Widget _buildBody(LoadingState loadingState) {
Widget _buildBody(LoadingState<List<dynamic>?> loadingState) {
return switch (loadingState) {
Loading() => CustomScrollView(
physics: const NeverScrollableScrollPhysics(),
@@ -145,7 +145,7 @@ class _NoteListPageState extends CommonSlidePageState<NoteListPage> {
)
],
),
Success() => (loadingState.response as List?)?.isNotEmpty == true
Success() => loadingState.response?.isNotEmpty == true
? refreshIndicator(
onRefresh: () async {
await _controller.onRefresh();
@@ -156,12 +156,13 @@ class _NoteListPageState extends CommonSlidePageState<NoteListPage> {
slivers: [
SliverList.separated(
itemBuilder: (context, index) {
if (index == loadingState.response.length - 1) {
if (index == loadingState.response!.length - 1) {
_controller.onLoadMore();
}
return _itemWidget(context, loadingState.response[index]);
return _itemWidget(
context, loadingState.response![index]);
},
itemCount: loadingState.response.length,
itemCount: loadingState.response!.length,
separatorBuilder: (context, index) => Divider(
height: 1,
color: Theme.of(context)

View File

@@ -1,10 +1,9 @@
import 'package:PiliPlus/http/loading_state.dart';
import 'package:PiliPlus/http/video.dart';
import 'package:PiliPlus/pages/common/common_controller.dart';
import 'package:PiliPlus/utils/extension.dart';
import 'package:PiliPlus/pages/common/common_list_controller.dart';
import 'package:get/get.dart';
class NoteListPageCtr extends CommonController {
class NoteListPageCtr extends CommonListController {
NoteListPageCtr({this.oid, this.upperMid});
final dynamic oid;
final dynamic upperMid;
@@ -18,21 +17,22 @@ class NoteListPageCtr extends CommonController {
}
@override
bool customHandleResponse(Success response) {
List? getDataList(response) {
return response['list'];
}
@override
void checkIsEnd(int length) {
if (count.value != -1 && length >= count.value) {
isEnd = true;
}
}
@override
bool customHandleResponse(bool isRefresh, Success response) {
dynamic data = response.response;
count.value = data['page']?['total'] ?? -1;
if ((data['list'] as List?).isNullOrEmpty) {
isEnd = true;
}
if (currentPage != 1 && loadingState.value is Success) {
data['list'] ??= [];
data['list'].insertAll(0, (loadingState.value as Success).response);
}
if (isEnd.not && count.value != -1 && data['list'].length >= count.value) {
isEnd = true;
}
loadingState.value = LoadingState.success(data['list']);
return true;
return false;
}
@override