add interact action throttle

Signed-off-by: dom <githubaccount56556@proton.me>
This commit is contained in:
dom
2026-05-21 12:37:42 +08:00
parent 5795122510
commit 3b6d0179ca
2 changed files with 56 additions and 34 deletions

View File

@@ -3,6 +3,7 @@ import 'package:PiliPlus/pages/dynamics_repost/view.dart';
import 'package:PiliPlus/utils/num_utils.dart'; import 'package:PiliPlus/utils/num_utils.dart';
import 'package:PiliPlus/utils/page_utils.dart'; import 'package:PiliPlus/utils/page_utils.dart';
import 'package:PiliPlus/utils/request_utils.dart'; import 'package:PiliPlus/utils/request_utils.dart';
import 'package:easy_debounce/easy_throttle.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:font_awesome_flutter/font_awesome_flutter.dart'; import 'package:font_awesome_flutter/font_awesome_flutter.dart';
@@ -34,7 +35,10 @@ class ActionPanel extends StatelessWidget {
child: Builder( child: Builder(
builder: (context) { builder: (context) {
return TextButton.icon( return TextButton.icon(
onPressed: () => showModalBottomSheet( onPressed: () => EasyThrottle.throttle(
'interactAction',
const Duration(milliseconds: 200),
() => showModalBottomSheet(
context: context, context: context,
isScrollControlled: true, isScrollControlled: true,
useSafeArea: true, useSafeArea: true,
@@ -49,6 +53,7 @@ class ActionPanel extends StatelessWidget {
}, },
), ),
), ),
),
icon: Icon( icon: Icon(
FontAwesomeIcons.shareFromSquare, FontAwesomeIcons.shareFromSquare,
size: 16, size: 16,
@@ -67,7 +72,11 @@ class ActionPanel extends StatelessWidget {
), ),
Expanded( Expanded(
child: TextButton.icon( child: TextButton.icon(
onPressed: () => PageUtils.pushDynDetail(item, isPush: true), onPressed: () => EasyThrottle.throttle(
'interactAction',
const Duration(milliseconds: 200),
() => PageUtils.pushDynDetail(item, isPush: true),
),
icon: Icon( icon: Icon(
FontAwesomeIcons.comment, FontAwesomeIcons.comment,
size: 16, size: 16,
@@ -92,7 +101,10 @@ class ActionPanel extends StatelessWidget {
semanticLabel: like.status! ? "已赞" : "点赞", semanticLabel: like.status! ? "已赞" : "点赞",
); );
return TextButton.icon( return TextButton.icon(
onPressed: () => RequestUtils.onLikeDynamic( onPressed: () => EasyThrottle.throttle(
'interactAction',
const Duration(milliseconds: 200),
() => RequestUtils.onLikeDynamic(
item, item,
likeIcon.color == primary, likeIcon.color == primary,
() { () {
@@ -101,6 +113,7 @@ class ActionPanel extends StatelessWidget {
} }
}, },
), ),
),
icon: likeIcon, icon: likeIcon,
style: btnStyle, style: btnStyle,
label: Text( label: Text(

View File

@@ -2,6 +2,7 @@ import 'package:PiliPlus/grpc/bilibili/main/community/reply/v1.pb.dart'
show ReplyInfo; show ReplyInfo;
import 'package:PiliPlus/http/reply.dart'; import 'package:PiliPlus/http/reply.dart';
import 'package:PiliPlus/utils/num_utils.dart'; import 'package:PiliPlus/utils/num_utils.dart';
import 'package:easy_debounce/easy_throttle.dart';
import 'package:fixnum/fixnum.dart' as $fixnum; import 'package:fixnum/fixnum.dart' as $fixnum;
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
@@ -117,13 +118,17 @@ class ZanButtonGrpc extends StatelessWidget {
height: 32, height: 32,
child: TextButton( child: TextButton(
style: style, style: style,
onPressed: () => onHateReply( onPressed: () => EasyThrottle.throttle(
'interactAction',
const Duration(milliseconds: 200),
() => onHateReply(
context, context,
isProcessing, isProcessing,
() => isProcessing = false, () => isProcessing = false,
isLike: isLike, isLike: isLike,
isDislike: isDislike, isDislike: isDislike,
), ),
),
child: Icon( child: Icon(
isDislike isDislike
? FontAwesomeIcons.solidThumbsDown ? FontAwesomeIcons.solidThumbsDown
@@ -138,13 +143,17 @@ class ZanButtonGrpc extends StatelessWidget {
height: 32, height: 32,
child: TextButton( child: TextButton(
style: style, style: style,
onPressed: () => onLikeReply( onPressed: () => EasyThrottle.throttle(
'interactAction',
const Duration(milliseconds: 200),
() => onLikeReply(
context, context,
isProcessing, isProcessing,
() => isProcessing = false, () => isProcessing = false,
isLike: isLike, isLike: isLike,
isDislike: isDislike, isDislike: isDislike,
), ),
),
child: Row( child: Row(
spacing: 4, spacing: 4,
children: [ children: [