show user medal

Signed-off-by: dom <githubaccount56556@proton.me>
This commit is contained in:
dom
2026-03-22 15:01:30 +08:00
parent fc7fc18b14
commit 2bebf200df
151 changed files with 1435 additions and 1321 deletions

View File

@@ -1,4 +1,4 @@
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/style.dart';
import 'package:PiliPlus/common/widgets/gesture/tap_gesture_recognizer.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
import 'package:PiliPlus/http/dynamics.dart';
@@ -21,7 +21,7 @@ Widget? addWidget(
late final Color bgColor = floor == 1
? theme.dividerColor.withValues(alpha: 0.08)
: theme.colorScheme.surface;
late final borderRadius = floor == 1 ? null : StyleString.mdRadius;
late final borderRadius = floor == 1 ? null : Style.mdRadius;
Widget? child;
try {
switch (type) {

View File

@@ -1,6 +1,7 @@
import 'dart:math';
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/assets.dart';
import 'package:PiliPlus/common/style.dart';
import 'package:PiliPlus/common/widgets/dialog/report.dart';
import 'package:PiliPlus/common/widgets/pendant_avatar.dart';
import 'package:PiliPlus/http/constants.dart';
@@ -52,21 +53,6 @@ class AuthorPanel extends StatelessWidget {
this.onSetReplySubject,
});
Widget _buildAvatar(ModuleAuthorModel moduleAuthor) {
final pendant = moduleAuthor.pendant?.image;
final hasPendant = pendant != null && pendant.isNotEmpty;
Widget avatar = PendantAvatar(
avatar: moduleAuthor.face,
size: hasPendant ? 34 : 40,
officialType: null, // 已被注释
garbPendantImage: pendant,
);
if (hasPendant) {
avatar = Padding(padding: const EdgeInsets.all(3), child: avatar);
}
return avatar;
}
@override
Widget build(BuildContext context) {
final theme = Theme.of(context);
@@ -105,147 +91,145 @@ class AuthorPanel extends StatelessWidget {
);
}
}
final moduleTagText = !isDetail ? item.modules.moduleTag?.text : null;
return Stack(
clipBehavior: Clip.none,
alignment: Alignment.center,
children: [
Align(
alignment: Alignment.centerLeft,
child: GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: moduleAuthor.type == 'AUTHOR_TYPE_NORMAL'
? () {
feedBack();
Get.toNamed('/member?mid=${moduleAuthor.mid}');
}
: null,
child: Row(
spacing: 10,
mainAxisSize: MainAxisSize.min,
Widget header = GestureDetector(
onTap: moduleAuthor.type == 'AUTHOR_TYPE_NORMAL'
? () {
feedBack();
Get.toNamed('/member?mid=${moduleAuthor.mid}');
}
: null,
child: Row(
spacing: 10,
children: [
PendantAvatar(
size: 40,
moduleAuthor.face,
pendantImage: moduleAuthor.pendant?.image,
),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
_buildAvatar(moduleAuthor),
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
moduleAuthor.name ?? '',
style: TextStyle(
color:
moduleAuthor.vip != null &&
moduleAuthor.vip!.status > 0 &&
moduleAuthor.vip!.type == 2
? theme.colorScheme.vipColor
: theme.colorScheme.onSurface,
fontSize: theme.textTheme.titleSmall!.fontSize,
),
),
?pubTs,
],
Text(
moduleAuthor.name!,
maxLines: 1,
overflow: .ellipsis,
style: TextStyle(
color:
moduleAuthor.vip != null &&
moduleAuthor.vip!.status > 0 &&
moduleAuthor.vip!.type == 2
? theme.colorScheme.vipColor
: theme.colorScheme.onSurface,
fontSize: theme.textTheme.titleSmall!.fontSize,
),
),
?pubTs,
],
),
),
),
Align(
alignment: Alignment.centerRight,
child: moduleTagText != null
? Row(
mainAxisSize: MainAxisSize.min,
children: [
Container(
padding: const EdgeInsets.symmetric(
horizontal: 4,
vertical: 2,
),
decoration: BoxDecoration(
borderRadius: const BorderRadius.all(
Radius.circular(4),
),
border: Border.all(
width: 1.25,
color: theme.colorScheme.primary,
),
),
child: Text(
moduleTagText,
style: TextStyle(
height: 1,
fontSize: 12,
color: theme.colorScheme.primary,
),
strutStyle: const StrutStyle(
height: 1,
leading: 0,
fontSize: 12,
),
),
),
_moreWidget(context),
],
)
: moduleAuthor.decorate != null
? Row(
mainAxisSize: MainAxisSize.min,
children: [
Stack(
clipBehavior: Clip.none,
alignment: Alignment.centerRight,
children: [
CachedNetworkImage(
height: 32,
memCacheHeight: 32.cacheSize(context),
imageUrl: ImageUtils.safeThumbnailUrl(
moduleAuthor.decorate!.cardUrl,
),
placeholder: (_, _) => const SizedBox.shrink(),
),
if (moduleAuthor.decorate!.fan?.numStr?.isNotEmpty ==
true)
Padding(
padding: const EdgeInsets.only(right: 32),
child: Text(
'${moduleAuthor.decorate!.fan!.numStr}',
style: TextStyle(
height: 1,
fontSize: 11,
fontFamily: 'digital_id_num',
color:
moduleAuthor.decorate!.fan?.color
?.startsWith('#') ==
true
? Utils.parseColor(
moduleAuthor.decorate!.fan!.color!,
)
: null,
),
),
),
],
),
_moreWidget(context),
],
)
: _moreWidget(context),
),
],
],
),
);
}
Widget _moreWidget(BuildContext context) => isSave
? const SizedBox.shrink()
: SizedBox(
width: 32,
height: 32,
child: IconButton(
tooltip: '更多',
style: const ButtonStyle(
padding: WidgetStatePropertyAll(EdgeInsets.zero),
Widget? moreBtn = isSave
? null
: SizedBox(
width: 32,
height: 32,
child: IconButton(
tooltip: '更多',
style: const ButtonStyle(
padding: WidgetStatePropertyAll(EdgeInsets.zero),
),
onPressed: () => morePanel(context),
icon: const Icon(Icons.more_vert_outlined, size: 18),
),
);
final moduleTagText = !isDetail ? item.modules.moduleTag?.text : null;
if (moduleTagText != null) {
header = Row(
children: [
Expanded(child: header),
Container(
padding: const .symmetric(horizontal: 4, vertical: 2),
decoration: BoxDecoration(
borderRadius: const .all(.circular(4)),
border: .all(width: 1.25, color: theme.colorScheme.primary),
),
child: Text(
moduleTagText,
style: TextStyle(
height: 1,
fontSize: 12,
color: theme.colorScheme.primary,
),
strutStyle: const StrutStyle(height: 1, leading: 0, fontSize: 12),
),
onPressed: () => morePanel(context),
icon: const Icon(Icons.more_vert_outlined, size: 18),
),
?moreBtn,
],
);
} else if (moduleAuthor.decorate != null) {
const height = 32.0;
header = Stack(
clipBehavior: .none,
children: [
Positioned(
top: 0,
right: 0,
height: height,
child: CachedNetworkImage(
height: height,
memCacheHeight: height.cacheSize(context),
imageUrl: ImageUtils.safeThumbnailUrl(
moduleAuthor.decorate!.cardUrl,
),
placeholder: (_, _) => const SizedBox.shrink(),
),
),
if (moduleAuthor.decorate!.fan?.numStr?.isNotEmpty == true)
Positioned(
top: 0,
right: height,
height: height,
child: Center(
child: Text(
moduleAuthor.decorate!.fan!.numStr!.toString(),
style: TextStyle(
height: 1,
fontSize: 11,
fontFamily: Assets.digitalNum,
color: Utils.parseColor(
moduleAuthor.decorate!.fan!.color!,
),
),
),
),
),
Padding(
padding: const .only(right: 80),
child: header,
),
],
);
if (moreBtn != null) {
header = Row(
children: [
Expanded(child: header),
moreBtn,
],
);
}
} else if (moreBtn != null) {
header = Row(
children: [
Expanded(child: header),
moreBtn,
],
);
}
return header;
}
void morePanel(BuildContext context) {
String? bvid;
@@ -283,7 +267,7 @@ class AuthorPanel extends StatelessWidget {
children: [
InkWell(
onTap: Get.back,
borderRadius: StyleString.bottomSheetRadius,
borderRadius: Style.bottomSheetRadius,
child: SizedBox(
height: 35,
child: Center(

View File

@@ -1,4 +1,5 @@
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/assets.dart';
import 'package:PiliPlus/common/style.dart';
import 'package:PiliPlus/common/widgets/badge.dart';
import 'package:PiliPlus/common/widgets/flutter/layout_builder.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
@@ -42,7 +43,7 @@ Widget livePanelSub(
LayoutBuilder(
builder: (context, constraints) => NetworkImgLayer(
width: constraints.maxWidth,
height: constraints.maxWidth / StyleString.aspectRatio,
height: constraints.maxWidth / Style.aspectRatio,
src: live.cover,
quality: 40,
),
@@ -61,7 +62,7 @@ Widget livePanelSub(
child: Image.asset(
height: 16,
cacheHeight: 16.cacheSize(context),
'assets/images/live/live.gif',
Assets.livingRect,
filterQuality: FilterQuality.low,
),
)
@@ -90,7 +91,7 @@ Widget livePanelSub(
],
),
borderRadius: BorderRadius.vertical(
bottom: StyleString.imgRadius,
bottom: Style.imgRadius,
),
),
child: Text(

View File

@@ -1,4 +1,5 @@
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/assets.dart';
import 'package:PiliPlus/common/style.dart';
import 'package:PiliPlus/common/widgets/badge.dart';
import 'package:PiliPlus/common/widgets/flutter/layout_builder.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
@@ -36,7 +37,7 @@ Widget liveRcmdPanel(
LayoutBuilder(
builder: (context, constraints) => NetworkImgLayer(
width: constraints.maxWidth,
height: constraints.maxWidth / StyleString.aspectRatio,
height: constraints.maxWidth / Style.aspectRatio,
src: liveRcmd.cover,
quality: 40,
),
@@ -55,7 +56,7 @@ Widget liveRcmdPanel(
child: Image.asset(
height: 16,
cacheHeight: 16.cacheSize(context),
'assets/images/live/live.gif',
Assets.livingRect,
filterQuality: FilterQuality.low,
),
)
@@ -85,7 +86,7 @@ Widget liveRcmdPanel(
],
),
borderRadius: BorderRadius.vertical(
bottom: StyleString.imgRadius,
bottom: Style.imgRadius,
),
),
child: Text(

View File

@@ -1,4 +1,4 @@
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/style.dart';
import 'package:PiliPlus/common/widgets/badge.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
import 'package:PiliPlus/grpc/bilibili/app/listener/v1.pbenum.dart'
@@ -114,9 +114,9 @@ Widget module(
: theme.colorScheme.surface,
shape: floor == 1
? null
: const RoundedRectangleBorder(borderRadius: StyleString.mdRadius),
: const RoundedRectangleBorder(borderRadius: Style.mdRadius),
child: InkWell(
borderRadius: floor == 1 ? null : StyleString.mdRadius,
borderRadius: floor == 1 ? null : Style.mdRadius,
onTap: () {
try {
String url = common.jumpUrl!;
@@ -179,7 +179,7 @@ Widget module(
);
case 'DYNAMIC_TYPE_MUSIC':
final music = major!.music!;
final borderRadius = floor == 1 ? null : StyleString.mdRadius;
final borderRadius = floor == 1 ? null : Style.mdRadius;
final Color bgColor = floor == 1
? theme.dividerColor.withValues(alpha: 0.08)
: theme.colorScheme.surface;

View File

@@ -1,3 +1,4 @@
import 'package:PiliPlus/common/assets.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
import 'package:PiliPlus/models/common/dynamic/up_panel_position.dart';
import 'package:PiliPlus/models/common/image_type.dart';
@@ -162,7 +163,7 @@ class _UpPanelState extends State<UpPanel> {
width: 38,
height: 38,
cacheWidth: 38.cacheSize(context),
'assets/images/logo/logo.png',
Assets.logo,
),
);
} else {

View File

@@ -1,5 +1,6 @@
// 视频or合集
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/assets.dart';
import 'package:PiliPlus/common/style.dart';
import 'package:PiliPlus/common/widgets/badge.dart';
import 'package:PiliPlus/common/widgets/flutter/layout_builder.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
@@ -53,7 +54,7 @@ Widget videoSeasonWidget(
LayoutBuilder(
builder: (context, constraints) => NetworkImgLayer(
width: constraints.maxWidth,
height: constraints.maxWidth / StyleString.aspectRatio,
height: constraints.maxWidth / Style.aspectRatio,
src: cover,
quality: 40,
),
@@ -88,7 +89,7 @@ Widget videoSeasonWidget(
],
),
borderRadius: BorderRadius.vertical(
bottom: StyleString.imgRadius,
bottom: Style.imgRadius,
),
),
child: DefaultTextStyle.merge(
@@ -122,7 +123,7 @@ Widget videoSeasonWidget(
],
const Spacer(),
Image.asset(
'assets/images/play.png',
Assets.play,
width: 50,
height: 50,
cacheHeight: 50.cacheSize(context),