feat: 评论点赞
This commit is contained in:
@ -104,6 +104,9 @@ class Api {
|
|||||||
// 楼中楼
|
// 楼中楼
|
||||||
static const String replyReplyList = '/x/v2/reply/reply';
|
static const String replyReplyList = '/x/v2/reply/reply';
|
||||||
|
|
||||||
|
// 评论点赞
|
||||||
|
static const String likeReply = '/x/v2/reply/action';
|
||||||
|
|
||||||
// 发表评论
|
// 发表评论
|
||||||
// https://github.com/SocialSisterYi/bilibili-API-collect/blob/master/docs/comment/action.md
|
// https://github.com/SocialSisterYi/bilibili-API-collect/blob/master/docs/comment/action.md
|
||||||
static const String replyAdd = '/x/v2/reply/add';
|
static const String replyAdd = '/x/v2/reply/add';
|
||||||
|
@ -70,4 +70,32 @@ class ReplyHttp {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 评论点赞
|
||||||
|
static Future likeReply({
|
||||||
|
required int type,
|
||||||
|
required int oid,
|
||||||
|
required int rpid,
|
||||||
|
required int action,
|
||||||
|
}) async {
|
||||||
|
var res = await Request().post(
|
||||||
|
Api.likeReply,
|
||||||
|
queryParameters: {
|
||||||
|
'type': type,
|
||||||
|
'oid': oid,
|
||||||
|
'rpid': rpid,
|
||||||
|
'action': action,
|
||||||
|
'csrf': await Request.getCsrf(),
|
||||||
|
},
|
||||||
|
);
|
||||||
|
if (res.data['code'] == 0) {
|
||||||
|
return {'status': true, 'data': res.data['data']};
|
||||||
|
} else {
|
||||||
|
return {
|
||||||
|
'status': false,
|
||||||
|
'date': [],
|
||||||
|
'msg': res.data['message'],
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,6 @@ class DynamicDetailController extends GetxController {
|
|||||||
sort: sortType.index,
|
sort: sortType.index,
|
||||||
);
|
);
|
||||||
if (res['status']) {
|
if (res['status']) {
|
||||||
res['data'] = ReplyData.fromJson(res['data']);
|
|
||||||
acount.value = res['data'].page.acount;
|
acount.value = res['data'].page.acount;
|
||||||
if (res['data'].replies.isNotEmpty) {
|
if (res['data'].replies.isNotEmpty) {
|
||||||
currentPage = currentPage + 1;
|
currentPage = currentPage + 1;
|
||||||
|
@ -9,6 +9,8 @@ import 'package:pilipala/pages/video/detail/controller.dart';
|
|||||||
import 'package:pilipala/pages/video/detail/replyNew/index.dart';
|
import 'package:pilipala/pages/video/detail/replyNew/index.dart';
|
||||||
import 'package:pilipala/utils/utils.dart';
|
import 'package:pilipala/utils/utils.dart';
|
||||||
|
|
||||||
|
import 'zan.dart';
|
||||||
|
|
||||||
class ReplyItem extends StatelessWidget {
|
class ReplyItem extends StatelessWidget {
|
||||||
ReplyItem({
|
ReplyItem({
|
||||||
super.key,
|
super.key,
|
||||||
@ -282,29 +284,7 @@ class ReplyItem extends StatelessWidget {
|
|||||||
},
|
},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
SizedBox(
|
ZanButton(replyItem: replyItem, replyType: replyType),
|
||||||
height: 32,
|
|
||||||
child: TextButton(
|
|
||||||
child: Row(
|
|
||||||
children: [
|
|
||||||
Icon(
|
|
||||||
FontAwesomeIcons.thumbsUp,
|
|
||||||
size: 16,
|
|
||||||
color: color,
|
|
||||||
),
|
|
||||||
const SizedBox(width: 4),
|
|
||||||
Text(
|
|
||||||
replyItem!.like.toString(),
|
|
||||||
style: TextStyle(
|
|
||||||
color: color,
|
|
||||||
fontSize:
|
|
||||||
Theme.of(context).textTheme.labelSmall!.fontSize),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
onPressed: () {},
|
|
||||||
),
|
|
||||||
),
|
|
||||||
const SizedBox(width: 5)
|
const SizedBox(width: 5)
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
82
lib/pages/video/detail/reply/widgets/zan.dart
Normal file
82
lib/pages/video/detail/reply/widgets/zan.dart
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
import 'package:pilipala/http/reply.dart';
|
||||||
|
import 'package:pilipala/models/common/reply_type.dart';
|
||||||
|
import 'package:pilipala/models/video/reply/item.dart';
|
||||||
|
|
||||||
|
class ZanButton extends StatefulWidget {
|
||||||
|
ZanButton({
|
||||||
|
super.key,
|
||||||
|
this.replyItem,
|
||||||
|
this.replyType,
|
||||||
|
});
|
||||||
|
|
||||||
|
ReplyItemModel? replyItem;
|
||||||
|
final ReplyType? replyType;
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<ZanButton> createState() => _ZanButtonState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _ZanButtonState extends State<ZanButton> {
|
||||||
|
// 评论点赞
|
||||||
|
onLikeReply() async {
|
||||||
|
ReplyItemModel replyItem = widget.replyItem!;
|
||||||
|
int oid = replyItem.oid!;
|
||||||
|
int rpid = replyItem.rpid!;
|
||||||
|
// 1 已点赞 2 不喜欢 0 未操作
|
||||||
|
int action = replyItem.action == 0 ? 1 : 0;
|
||||||
|
var res = await ReplyHttp.likeReply(
|
||||||
|
type: widget.replyType!.index, oid: oid, rpid: rpid, action: action);
|
||||||
|
if (res['status']) {
|
||||||
|
SmartDialog.showToast(replyItem.action == 0 ? '点赞成功' : '取消赞');
|
||||||
|
if (action == 1) {
|
||||||
|
replyItem.like = replyItem.like! + 1;
|
||||||
|
replyItem.action = 1;
|
||||||
|
} else {
|
||||||
|
replyItem.like = replyItem.like! - 1;
|
||||||
|
replyItem.action = 0;
|
||||||
|
}
|
||||||
|
setState(() {});
|
||||||
|
} else {
|
||||||
|
SmartDialog.showToast(res['msg']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
var color = Theme.of(context).colorScheme.outline;
|
||||||
|
var primary = Theme.of(context).colorScheme.primary;
|
||||||
|
return SizedBox(
|
||||||
|
height: 32,
|
||||||
|
child: TextButton(
|
||||||
|
child: Row(
|
||||||
|
children: [
|
||||||
|
Icon(
|
||||||
|
widget.replyItem!.action == 1
|
||||||
|
? FontAwesomeIcons.solidThumbsUp
|
||||||
|
: FontAwesomeIcons.thumbsUp,
|
||||||
|
size: 16,
|
||||||
|
color: widget.replyItem!.action == 1 ? primary : color,
|
||||||
|
),
|
||||||
|
const SizedBox(width: 4),
|
||||||
|
AnimatedSwitcher(
|
||||||
|
duration: const Duration(milliseconds: 400),
|
||||||
|
transitionBuilder: (Widget child, Animation<double> animation) {
|
||||||
|
return ScaleTransition(scale: animation, child: child);
|
||||||
|
},
|
||||||
|
child: Text(widget.replyItem!.like.toString(),
|
||||||
|
key: ValueKey<int>(widget.replyItem!.like!),
|
||||||
|
style: TextStyle(
|
||||||
|
color: widget.replyItem!.action == 1 ? primary : color,
|
||||||
|
fontSize:
|
||||||
|
Theme.of(context).textTheme.labelSmall!.fontSize)),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
onPressed: () => onLikeReply(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user