Files
android
assets
ios
lib
database
models
pods
screens
services
widgets
account
account_picker.dart
account_picker.g.dart
badge.dart
leveling_progress.dart
status.dart
status.g.dart
status_creation.dart
chat
content
post
realms
tour
alert.dart
app_scaffold.dart
check_in.dart
check_in.g.dart
context_menu.dart
response.dart
firebase_options.dart
main.dart
route.dart
route.gr.dart
linux
macos
web
windows
.gitignore
.metadata
README.md
analysis_options.yaml
build.yaml
devtools_options.yaml
firebase.json
pubspec.lock
pubspec.yaml
App/lib/widgets/account/badge.dart
2025-05-13 00:36:48 +08:00

47 lines
1.3 KiB
Dart

import 'package:easy_localization/easy_localization.dart';
import 'package:flutter/material.dart';
import 'package:island/models/user.dart';
import 'package:island/models/badge.dart';
class BadgeList extends StatelessWidget {
final List<SnAccountBadge> badges;
const BadgeList({super.key, required this.badges});
@override
Widget build(BuildContext context) {
return Wrap(
spacing: 8,
runSpacing: 8,
children: badges.map((badge) => BadgeItem(badge: badge)).toList(),
);
}
}
class BadgeItem extends StatelessWidget {
final SnAccountBadge badge;
const BadgeItem({super.key, required this.badge});
@override
Widget build(BuildContext context) {
final template = kBadgeTemplates[badge.type];
final name = badge.label ?? template?.name.tr() ?? 'unknown'.tr();
final description = badge.caption ?? template?.description.tr() ?? '';
return Tooltip(
message: '$name\n$description',
child: Container(
padding: const EdgeInsets.all(4),
decoration: BoxDecoration(
color: (template?.color ?? Colors.blue).withOpacity(0.1),
shape: BoxShape.circle,
),
child: Icon(
template?.icon ?? Icons.stars,
color: template?.color ?? Colors.orange,
size: 20,
),
),
);
}
}