Solian/lib/widgets/account/account_avatar.dart

127 lines
3.1 KiB
Dart
Raw Normal View History

2024-05-18 18:17:16 +08:00
import 'package:flutter/material.dart';
import 'package:solian/services.dart';
2024-10-12 00:41:03 +08:00
import 'package:solian/widgets/account/account_profile_popup.dart';
import 'package:solian/widgets/auto_cache_image.dart';
2024-05-18 18:17:16 +08:00
2024-10-12 00:41:03 +08:00
class AttachedCircleAvatar extends StatelessWidget {
final dynamic content;
2024-05-29 00:14:41 +08:00
final Color? bgColor;
final Color? feColor;
2024-05-18 18:17:16 +08:00
final double? radius;
final Widget? fallbackWidget;
2024-05-18 18:17:16 +08:00
2024-10-12 00:41:03 +08:00
const AttachedCircleAvatar({
2024-05-29 00:14:41 +08:00
super.key,
required this.content,
this.bgColor,
this.feColor,
this.radius,
this.fallbackWidget,
2024-05-29 00:14:41 +08:00
});
2024-05-18 18:17:16 +08:00
@override
Widget build(BuildContext context) {
bool direct = false;
bool isEmpty = content == null;
if (content is String) {
direct = content.startsWith('http');
2024-05-26 00:11:00 +08:00
if (!isEmpty) isEmpty = content.isEmpty;
}
2024-05-18 18:17:16 +08:00
2024-06-01 21:39:28 +08:00
final url = direct
? content
: ServiceFinder.buildUrl('files', '/attachments/$content');
2024-06-01 21:39:28 +08:00
2024-05-18 18:17:16 +08:00
return CircleAvatar(
2024-05-19 18:01:00 +08:00
key: Key('a$content'),
2024-05-18 18:17:16 +08:00
radius: radius,
2024-05-29 00:14:41 +08:00
backgroundColor: bgColor,
backgroundImage: !isEmpty ? AutoCacheImage.provider(url) : null,
child: isEmpty
? (fallbackWidget ??
Icon(
2024-10-12 00:41:03 +08:00
Icons.image,
size: radius != null ? radius! * 1.2 : 24,
color: feColor,
))
: null,
2024-05-18 18:17:16 +08:00
);
}
}
2024-06-03 23:36:46 +08:00
2024-10-12 00:41:03 +08:00
class AccountAvatar extends StatelessWidget {
final dynamic content;
final String username;
final Color? bgColor;
final Color? feColor;
final double? radius;
final Widget? fallbackWidget;
const AccountAvatar({
super.key,
required this.content,
required this.username,
this.bgColor,
this.feColor,
this.radius,
this.fallbackWidget,
});
@override
Widget build(BuildContext context) {
return GestureDetector(
child: AttachedCircleAvatar(
content: content,
bgColor: bgColor,
feColor: feColor,
radius: radius,
fallbackWidget: (fallbackWidget ??
Icon(
Icons.account_circle,
size: radius != null ? radius! * 1.2 : 24,
color: feColor,
)),
),
onTap: () {
showModalBottomSheet(
useRootNavigator: true,
isScrollControlled: true,
backgroundColor: Theme.of(context).colorScheme.surface,
context: context,
builder: (context) => AccountProfilePopup(
name: username,
),
);
},
);
}
}
2024-06-03 23:36:46 +08:00
class AccountProfileImage extends StatelessWidget {
final dynamic content;
final BoxFit fit;
const AccountProfileImage({
super.key,
required this.content,
this.fit = BoxFit.cover,
});
@override
Widget build(BuildContext context) {
bool direct = false;
bool isEmpty = content == null;
if (content is String) {
direct = content.startsWith('http');
if (!isEmpty) isEmpty = content.isEmpty;
if (!isEmpty) isEmpty = content.endsWith('/attachments/0');
2024-06-03 23:36:46 +08:00
}
final url = direct
? content
: ServiceFinder.buildUrl('files', '/attachments/$content');
2024-06-03 23:36:46 +08:00
return AutoCacheImage(url, fit: fit, noErrorWidget: true);
2024-06-03 23:36:46 +08:00
}
}