mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
@@ -1,15 +1,9 @@
|
||||
import 'package:PiliPlus/http/loading_state.dart';
|
||||
import 'package:PiliPlus/http/video.dart';
|
||||
import 'package:PiliPlus/models/model_rec_video_item.dart';
|
||||
import 'package:PiliPlus/pages/common/common_list_controller.dart';
|
||||
import 'package:PiliPlus/utils/storage_pref.dart';
|
||||
|
||||
class RcmdController
|
||||
extends
|
||||
CommonListController<
|
||||
List<BaseRecVideoItemModel>,
|
||||
BaseRecVideoItemModel
|
||||
> {
|
||||
class RcmdController extends CommonListController {
|
||||
late bool enableSaveLastData = Pref.enableSaveLastData;
|
||||
final bool appRcmd = Pref.appRcmd;
|
||||
|
||||
@@ -24,16 +18,16 @@ class RcmdController
|
||||
}
|
||||
|
||||
@override
|
||||
Future<LoadingState<List<BaseRecVideoItemModel>>> customGetData() {
|
||||
Future<LoadingState> customGetData() {
|
||||
return appRcmd
|
||||
? VideoHttp.rcmdVideoListApp(freshIdx: page)
|
||||
: VideoHttp.rcmdVideoList(freshIdx: page, ps: 20);
|
||||
}
|
||||
|
||||
@override
|
||||
void handleListResponse(List<BaseRecVideoItemModel> dataList) {
|
||||
void handleListResponse(List dataList) {
|
||||
if (enableSaveLastData && page == 0 && loadingState.value.isSuccess) {
|
||||
final currentList = loadingState.value.data;
|
||||
List? currentList = loadingState.value.data;
|
||||
if (currentList?.isNotEmpty == true) {
|
||||
if (savedRcmdTip) {
|
||||
lastRefreshAt = dataList.length;
|
||||
|
||||
@@ -4,7 +4,6 @@ import 'package:PiliPlus/common/widgets/loading_widget/http_error.dart';
|
||||
import 'package:PiliPlus/common/widgets/refresh_indicator.dart';
|
||||
import 'package:PiliPlus/common/widgets/video_card/video_card_v.dart';
|
||||
import 'package:PiliPlus/http/loading_state.dart';
|
||||
import 'package:PiliPlus/models/model_rec_video_item.dart';
|
||||
import 'package:PiliPlus/pages/common/common_page.dart';
|
||||
import 'package:PiliPlus/pages/rcmd/controller.dart';
|
||||
import 'package:PiliPlus/utils/grid.dart';
|
||||
@@ -60,7 +59,7 @@ class _RcmdPageState extends CommonPageState<RcmdPage, RcmdController>
|
||||
mainAxisExtent: MediaQuery.textScalerOf(context).scale(90),
|
||||
);
|
||||
|
||||
Widget _buildBody(LoadingState<List<BaseRecVideoItemModel>?> loadingState) {
|
||||
Widget _buildBody(LoadingState<List<dynamic>?> loadingState) {
|
||||
return switch (loadingState) {
|
||||
Loading() => _buildSkeleton,
|
||||
Success(:var response) =>
|
||||
|
||||
Reference in New Issue
Block a user