feat: 首页推荐视频缓存

This commit is contained in:
guozhigq
2023-05-17 10:27:54 +08:00
parent 83fac74630
commit 75ed91c29d
17 changed files with 526 additions and 14 deletions

View File

@ -1,7 +1,9 @@
import 'package:flutter/cupertino.dart';
import 'package:get/get.dart';
import 'package:hive/hive.dart';
import 'package:pilipala/http/video.dart';
import 'package:pilipala/models/model_rec_video_item.dart';
import 'package:pilipala/utils/storage.dart';
class HomeController extends GetxController {
final ScrollController scrollController = ScrollController();
@ -12,11 +14,18 @@ class HomeController extends GetxController {
bool isLoadingMore = false;
bool flag = false;
OverlayEntry? popupDialog;
Box recVideo = GStrorage.recVideo;
@override
void onInit() {
super.onInit();
// queryRcmdFeed('init');
if(recVideo.get('cacheList') != null && recVideo.get('cacheList').isNotEmpty){
List<RecVideoItemModel> list = [];
for(var i in recVideo.get('cacheList')){
list.add(i);
}
videoList.value = list;
}
}
// 获取推荐
@ -33,6 +42,7 @@ class HomeController extends GetxController {
} else if (type == 'onLoad') {
videoList.addAll(res['data']);
}
recVideo.put('cacheList', res['data']);
_currentPage += 1;
}
isLoadingMore = false;

View File

@ -89,8 +89,15 @@ class _HomePageState extends State<HomePage>
);
}
} else {
// 缓存数据
if(_homeController.videoList.isNotEmpty) {
return contentGrid(
_homeController, _homeController.videoList);
}
// 骨架屏
return contentGrid(_homeController, []);
else{
return contentGrid(_homeController, []);
}
}
},
),

View File

@ -46,7 +46,13 @@ class HomeAppBar extends StatelessWidget {
// ),
IconButton(
onPressed: () {
Get.bottomSheet(const MinePage());
Get.bottomSheet(
const SizedBox(
height: 450,
child: MinePage(),
),
clipBehavior: Clip.hardEdge,
isScrollControlled: true);
},
icon: const Icon(CupertinoIcons.person, size: 22),
),

View File

@ -6,6 +6,7 @@ import 'package:pilipala/common/widgets/network_img_layer.dart';
import 'package:pilipala/pages/home/view.dart';
import 'package:pilipala/pages/hot/view.dart';
import 'package:pilipala/pages/media/index.dart';
import 'package:pilipala/pages/mine/index.dart';
import 'package:pilipala/utils/storage.dart';
class MainController extends GetxController {

View File

@ -1,11 +1,14 @@
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:hive/hive.dart';
import 'package:pilipala/http/user.dart';
import 'package:pilipala/models/user/fav_folder.dart';
import 'package:pilipala/utils/storage.dart';
class MediaController extends GetxController {
Rx<FavFolderData> favFolderData = FavFolderData().obs;
Box user = GStrorage.user;
RxBool userLogin = false.obs;
List list = [
{
'icon': Icons.file_download_outlined,
@ -29,7 +32,16 @@ class MediaController extends GetxController {
},
];
@override
void onInit() {
super.onInit();
userLogin.value = user.get(UserBoxKey.userLogin) ?? false;
}
Future<dynamic> queryFavFolder() async {
if (!userLogin.value) {
return {'status': false, 'data': [], 'msg': '未登录'};
}
var res = await await UserHttp.userfavFolder(
pn: 1,
ps: 5,

View File

@ -17,7 +17,7 @@ class _MediaPageState extends State<MediaPage>
Future? _futureBuilderFuture;
@override
bool get wantKeepAlive => true;
bool get wantKeepAlive => false;
@override
void initState() {
@ -65,7 +65,9 @@ class _MediaPageState extends State<MediaPage>
),
),
],
favFolder()
Obx(() => _mediaController.userLogin.value == true
? favFolder()
: const SizedBox())
],
),
);

View File

@ -64,7 +64,6 @@ class _MinePageState extends State<MinePage> {
future: _mineController.queryUserInfo(),
builder: (context, snapshot) {
if (snapshot.connectionState == ConnectionState.done) {
print(snapshot.data);
if (snapshot.data['status']) {
return Obx(() => userInfoBuild());
} else {
@ -75,7 +74,6 @@ class _MinePageState extends State<MinePage> {
}
},
),
const SizedBox(height: 20),
],
),
),