mod: 视频评论页代码整理

This commit is contained in:
guozhigq
2023-07-24 16:11:17 +08:00
parent 4e64c74ee0
commit 7a3f6cf5ee
5 changed files with 42 additions and 91 deletions

View File

@ -1,5 +1,6 @@
import 'package:pilipala/http/api.dart'; import 'package:pilipala/http/api.dart';
import 'package:pilipala/http/init.dart'; import 'package:pilipala/http/init.dart';
import 'package:pilipala/models/video/reply/data.dart';
class ReplyHttp { class ReplyHttp {
static Future replyList({ static Future replyList({
@ -17,7 +18,7 @@ class ReplyHttp {
if (res.data['code'] == 0) { if (res.data['code'] == 0) {
return { return {
'status': true, 'status': true,
'data': res.data['data'], 'data': ReplyData.fromJson(res.data['data']),
}; };
} else { } else {
Map errMap = { Map errMap = {

View File

@ -1,26 +1,21 @@
import 'dart:developer';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:pilipala/http/reply.dart'; import 'package:pilipala/http/reply.dart';
import 'package:pilipala/http/video.dart';
import 'package:pilipala/models/common/reply_sort_type.dart'; import 'package:pilipala/models/common/reply_sort_type.dart';
import 'package:pilipala/models/common/reply_type.dart'; import 'package:pilipala/models/common/reply_type.dart';
import 'package:pilipala/models/video/reply/data.dart';
import 'package:pilipala/models/video/reply/item.dart'; import 'package:pilipala/models/video/reply/item.dart';
class VideoReplyController extends GetxController { class VideoReplyController extends GetxController {
VideoReplyController( VideoReplyController(
this.aid, this.aid,
this.rpid, this.rpid,
this.level, this.replyLevel,
); );
final ScrollController scrollController = ScrollController(); final ScrollController scrollController = ScrollController();
// 视频aid 请求时使用的oid // 视频aid 请求时使用的oid
int? aid; int? aid;
// 层级 2为楼中楼 // 层级 2为楼中楼
String? level; String? replyLevel;
// rpid 请求楼中楼回复 // rpid 请求楼中楼回复
String? rpid; String? rpid;
RxList<ReplyItemModel> replyList = [ReplyItemModel()].obs; RxList<ReplyItemModel> replyList = [ReplyItemModel()].obs;
@ -30,12 +25,6 @@ class VideoReplyController extends GetxController {
RxString noMore = ''.obs; RxString noMore = ''.obs;
// 当前回复的回复 // 当前回复的回复
ReplyItemModel? currentReplyItem; ReplyItemModel? currentReplyItem;
// 回复来源
String replySource = 'main';
// 根评论 id 回复楼中楼回复使用
int? rPid;
// 默认回复主楼
String replyLevel = '0';
ReplySortType sortType = ReplySortType.time; ReplySortType sortType = ReplySortType.time;
RxString sortTypeTitle = ReplySortType.time.titles.obs; RxString sortTypeTitle = ReplySortType.time.titles.obs;
@ -43,51 +32,44 @@ class VideoReplyController extends GetxController {
Future queryReplyList({type = 'init'}) async { Future queryReplyList({type = 'init'}) async {
isLoadingMore = true; isLoadingMore = true;
var res = level == '1' var res = replyLevel == '1'
? await ReplyHttp.replyList( ? await ReplyHttp.replyList(
oid: aid!, oid: aid!,
pageNum: currentPage + 1, pageNum: ++currentPage,
type: ReplyType.video.index, type: ReplyType.video.index,
sort: sortType.index, sort: sortType.index,
) )
: await ReplyHttp.replyReplyList( : await ReplyHttp.replyReplyList(
oid: aid!, root: rpid!, pageNum: currentPage + 1, type: 1); oid: aid!,
root: rpid!,
pageNum: ++currentPage,
type: ReplyType.video.index,
);
if (res['status']) { if (res['status']) {
res['data'] = ReplyData.fromJson(res['data']); List<ReplyItemModel> replies = res['data'].replies;
if (res['data'].replies.isNotEmpty) { if (replies.isNotEmpty) {
currentPage = currentPage + 1;
noMore.value = '加载中'; noMore.value = '加载中';
if (replyList.length == res['data'].page.acount) { if (replyList.length == res['data'].page.acount) {
noMore.value = '没有更多了'; noMore.value = '没有更多了';
} }
} else { } else {
if (currentPage == 0) { // 未登录状态replies可能返回null
noMore.value = '还没有评论'; noMore.value = currentPage == 0 ? '还没有评论' : '没有更多了';
} else {
noMore.value = '没有更多了';
return;
}
} }
if (type == 'init') { if (type == 'init') {
List<ReplyItemModel> replies = res['data'].replies;
// 添加置顶回复 // 添加置顶回复
if (res['data'].upper.top != null) { if (res['data'].upper.top != null) {
bool flag = false; bool flag = res['data']
for (var i = 0; i < res['data'].topReplies.length; i++) { .topReplies
if (res['data'].topReplies[i].rpid == res['data'].upper.top.rpid) { .any((reply) => reply.rpid == res['data'].upper.top.rpid);
flag = true;
}
}
if (!flag) { if (!flag) {
replies.insert(0, res['data'].upper.top); replies.insert(0, res['data'].upper.top);
} }
} }
replies.insertAll(0, res['data'].topReplies); replies.insertAll(0, res['data'].topReplies);
res['data'].replies = replies; replyList.value = replies;
replyList.value = res['data'].replies!;
} else { } else {
replyList.addAll(res['data'].replies!); replyList.addAll(replies);
res['data'].replies.addAll(replyList);
} }
} }
isLoadingMore = false; isLoadingMore = false;

View File

@ -6,7 +6,6 @@ import 'package:get/get.dart';
import 'package:pilipala/common/skeleton/video_reply.dart'; import 'package:pilipala/common/skeleton/video_reply.dart';
import 'package:pilipala/common/widgets/http_error.dart'; import 'package:pilipala/common/widgets/http_error.dart';
import 'package:pilipala/models/common/reply_type.dart'; import 'package:pilipala/models/common/reply_type.dart';
import 'package:pilipala/models/video/reply/item.dart';
import 'package:pilipala/pages/video/detail/index.dart'; import 'package:pilipala/pages/video/detail/index.dart';
import 'package:pilipala/pages/video/detail/replyNew/index.dart'; import 'package:pilipala/pages/video/detail/replyNew/index.dart';
import 'package:pilipala/utils/id_utils.dart'; import 'package:pilipala/utils/id_utils.dart';
@ -14,14 +13,14 @@ import 'controller.dart';
import 'widgets/reply_item.dart'; import 'widgets/reply_item.dart';
class VideoReplyPanel extends StatefulWidget { class VideoReplyPanel extends StatefulWidget {
String? bvid; final String? bvid;
int rpid; final int rpid;
String? level; final String? replyLevel;
Key? key;
VideoReplyPanel({ const VideoReplyPanel({
this.bvid, this.bvid,
this.rpid = 0, this.rpid = 0,
this.level, this.replyLevel,
super.key, super.key,
}); });
@ -46,18 +45,13 @@ class _VideoReplyPanelState extends State<VideoReplyPanel>
void initState() { void initState() {
int oid = widget.bvid != null ? IdUtils.bv2av(widget.bvid!) : 0; int oid = widget.bvid != null ? IdUtils.bv2av(widget.bvid!) : 0;
super.initState(); super.initState();
replyLevel = widget.level ?? '1'; replyLevel = widget.replyLevel ?? '1';
if (widget.level != null && widget.level == '2') { if (replyLevel == '2') {
_videoReplyController = Get.put( _videoReplyController = Get.put(
VideoReplyController(oid, widget.rpid.toString(), '2'), VideoReplyController(oid, widget.rpid.toString(), replyLevel),
tag: widget.rpid.toString()); tag: widget.rpid.toString());
_videoReplyController.rPid = widget.rpid;
} else { } else {
// fix 评论加载不对称 _videoReplyController = Get.put(VideoReplyController(oid, '', replyLevel),
// int oid = Get.parameters['bvid'] != null
// ? IdUtils.bv2av(Get.parameters['bvid']!)
// : 0;
_videoReplyController = Get.put(VideoReplyController(oid, '', '1'),
tag: Get.arguments['heroTag']); tag: Get.arguments['heroTag']);
} }
@ -101,20 +95,6 @@ class _VideoReplyPanelState extends State<VideoReplyPanel>
} }
} }
void _showReply(source, {ReplyItemModel? replyItem, replyLevel}) async {
// source main 直接回复 floor 楼中楼回复
if (source == 'floor') {
_videoReplyController.currentReplyItem = replyItem;
_videoReplyController.replySource = source;
_videoReplyController.replyLevel = replyLevel ?? '1';
} else {
_videoReplyController.replyLevel = '0';
}
// await Future.delayed(const Duration(microseconds: 100));
// _videoReplyController.wakeUpReply();
}
// 展示二级回复 // 展示二级回复
void replyReply(replyItem) { void replyReply(replyItem) {
VideoDetailController videoDetailCtr = VideoDetailController videoDetailCtr =
@ -136,7 +116,6 @@ class _VideoReplyPanelState extends State<VideoReplyPanel>
Widget build(BuildContext context) { Widget build(BuildContext context) {
return RefreshIndicator( return RefreshIndicator(
onRefresh: () async { onRefresh: () async {
setState(() {});
_videoReplyController.currentPage = 0; _videoReplyController.currentPage = 0;
return await _videoReplyController.queryReplyList(); return await _videoReplyController.queryReplyList();
}, },
@ -204,18 +183,15 @@ class _VideoReplyPanelState extends State<VideoReplyPanel>
: SliverList( : SliverList(
delegate: SliverChildBuilderDelegate( delegate: SliverChildBuilderDelegate(
(context, index) { (context, index) {
double bottom =
MediaQuery.of(context).padding.bottom;
if (index == if (index ==
_videoReplyController _videoReplyController
.replyList.length) { .replyList.length) {
return Container( return Container(
padding: EdgeInsets.only( padding:
bottom: MediaQuery.of(context) EdgeInsets.only(bottom: bottom),
.padding height: bottom + 100,
.bottom),
height: MediaQuery.of(context)
.padding
.bottom +
100,
child: Center( child: Center(
child: Obx(() => Text( child: Obx(() => Text(
_videoReplyController _videoReplyController
@ -265,8 +241,6 @@ class _VideoReplyPanelState extends State<VideoReplyPanel>
child: SlideTransition( child: SlideTransition(
position: Tween<Offset>( position: Tween<Offset>(
begin: const Offset(0, 2), begin: const Offset(0, 2),
// 评论内容为空/不足一屏
// begin: const Offset(0, 0),
end: const Offset(0, 0), end: const Offset(0, 0),
).animate(CurvedAnimation( ).animate(CurvedAnimation(
parent: fabAnimationCtr, parent: fabAnimationCtr,

View File

@ -21,11 +21,6 @@ class VideoReplyReplyController extends GetxController {
// 当前回复的回复 // 当前回复的回复
ReplyItemModel? currentReplyItem; ReplyItemModel? currentReplyItem;
// 根评论 id 回复楼中楼回复使用
int? rPid;
// 默认回复主楼
String replyLevel = '0';
@override @override
void onInit() { void onInit() {
super.onInit(); super.onInit();

View File

@ -11,14 +11,14 @@ import 'package:pilipala/utils/storage.dart';
import 'controller.dart'; import 'controller.dart';
class VideoReplyReplyPanel extends StatefulWidget { class VideoReplyReplyPanel extends StatefulWidget {
int? oid; final int? oid;
int? rpid; final int? rpid;
Function? closePanel; final Function? closePanel;
ReplyItemModel? firstFloor; final ReplyItemModel? firstFloor;
String? source; final String? source;
ReplyType? replyType; final ReplyType? replyType;
VideoReplyReplyPanel({ const VideoReplyReplyPanel({
this.oid, this.oid,
this.rpid, this.rpid,
this.closePanel, this.closePanel,
@ -91,7 +91,6 @@ class _VideoReplyReplyPanelState extends State<VideoReplyReplyPanel> {
icon: const Icon(Icons.close), icon: const Icon(Icons.close),
onPressed: () { onPressed: () {
_videoReplyReplyController.currentPage = 0; _videoReplyReplyController.currentPage = 0;
_videoReplyReplyController.rPid = 0;
widget.closePanel!(); widget.closePanel!();
Navigator.pop(context); Navigator.pop(context);
}, },