opt: unread & zan grpc & readlist open with browser (#852)

* opt: unread

* opt: zan grpc

* feat: readlist open with browser
This commit is contained in:
My-Responsitories
2025-05-11 18:58:00 +08:00
committed by GitHub
parent 8d34e6f340
commit 72734d4b4e
13 changed files with 127 additions and 208 deletions

View File

@@ -22,13 +22,16 @@ class ZanButtonGrpc extends StatefulWidget {
}
class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
bool get isLike => widget.replyItem.replyControl.action == $fixnum.Int64.ONE;
bool get isDislike =>
widget.replyItem.replyControl.action == $fixnum.Int64.TWO;
Future<void> onHateReply() async {
feedBack();
final int oid = widget.replyItem.oid.toInt();
final int rpid = widget.replyItem.id.toInt();
// 1 已点赞 2 不喜欢 0 未操作
final int action =
widget.replyItem.replyControl.action.toInt() != 2 ? 2 : 0;
final int action = isDislike ? 0 : 2;
final res = await ReplyHttp.hateReply(
type: widget.replyItem.type.toInt(),
action: action == 2 ? 1 : 0,
@@ -37,13 +40,9 @@ class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
);
// SmartDialog.dismiss();
if (res['status']) {
SmartDialog.showToast(
widget.replyItem.replyControl.action.toInt() != 2 ? '点踩成功' : '取消踩');
SmartDialog.showToast(isDislike ? '取消踩' : '点踩成功');
if (action == 2) {
if (widget.replyItem.replyControl.action.toInt() == 1) {
widget.replyItem.like =
$fixnum.Int64(widget.replyItem.like.toInt() - 1);
}
if (isLike) widget.replyItem.like -= $fixnum.Int64.ONE;
widget.replyItem.replyControl.action = $fixnum.Int64.TWO;
} else {
widget.replyItem.replyControl.action = $fixnum.Int64.ZERO;
@@ -60,8 +59,7 @@ class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
final int oid = widget.replyItem.oid.toInt();
final int rpid = widget.replyItem.id.toInt();
// 1 已点赞 2 不喜欢 0 未操作
final int action =
widget.replyItem.replyControl.action.toInt() != 1 ? 1 : 0;
final int action = isLike ? 0 : 1;
final res = await ReplyHttp.likeReply(
type: widget.replyItem.type.toInt(),
oid: oid,
@@ -69,15 +67,12 @@ class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
action: action,
);
if (res['status']) {
SmartDialog.showToast(
widget.replyItem.replyControl.action.toInt() != 1 ? '点赞成功' : '取消赞');
SmartDialog.showToast(isLike ? '取消赞' : '点赞成功');
if (action == 1) {
widget.replyItem.like =
$fixnum.Int64(widget.replyItem.like.toInt() + 1);
widget.replyItem.like += $fixnum.Int64.ONE;
widget.replyItem.replyControl.action = $fixnum.Int64.ONE;
} else {
widget.replyItem.like =
$fixnum.Int64(widget.replyItem.like.toInt() - 1);
widget.replyItem.like -= $fixnum.Int64.ONE;
widget.replyItem.replyControl.action = $fixnum.Int64.ZERO;
}
setState(() {});
@@ -115,16 +110,12 @@ class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
style: _style,
onPressed: () => handleState(onHateReply),
child: Icon(
widget.replyItem.replyControl.action.toInt() == 2
isDislike
? FontAwesomeIcons.solidThumbsDown
: FontAwesomeIcons.thumbsDown,
size: 16,
color: widget.replyItem.replyControl.action.toInt() == 2
? primary
: color,
semanticLabel: widget.replyItem.replyControl.action.toInt() == 2
? '已踩'
: '点踩',
color: isDislike ? primary : color,
semanticLabel: isDislike ? '已踩' : '点踩',
),
),
),
@@ -136,17 +127,12 @@ class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
child: Row(
children: [
Icon(
widget.replyItem.replyControl.action.toInt() == 1
isLike
? FontAwesomeIcons.solidThumbsUp
: FontAwesomeIcons.thumbsUp,
size: 16,
color: widget.replyItem.replyControl.action.toInt() == 1
? primary
: color,
semanticLabel:
widget.replyItem.replyControl.action.toInt() == 1
? '已赞'
: '点赞',
color: isLike ? primary : color,
semanticLabel: isLike ? '已赞' : '点赞',
),
const SizedBox(width: 4),
AnimatedSwitcher(
@@ -158,9 +144,7 @@ class _ZanButtonGrpcState extends State<ZanButtonGrpc> {
child: Text(
Utils.numFormat(widget.replyItem.like.toInt()),
style: TextStyle(
color: widget.replyItem.replyControl.action.toInt() == 1
? primary
: color,
color: isLike ? primary : color,
fontSize: theme.textTheme.labelSmall!.fontSize,
),
),