2024-06-01 21:39:28 +08:00
|
|
|
import 'package:cached_network_image/cached_network_image.dart';
|
2024-05-18 18:17:16 +08:00
|
|
|
import 'package:flutter/material.dart';
|
2024-06-01 21:39:28 +08:00
|
|
|
import 'package:solian/platform.dart';
|
2024-05-18 18:17:16 +08:00
|
|
|
import 'package:solian/services.dart';
|
|
|
|
|
|
|
|
class AccountAvatar extends StatelessWidget {
|
2024-05-20 23:11:26 +08:00
|
|
|
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;
|
|
|
|
|
2024-05-29 00:14:41 +08:00
|
|
|
const AccountAvatar({
|
|
|
|
super.key,
|
|
|
|
required this.content,
|
|
|
|
this.bgColor,
|
|
|
|
this.feColor,
|
|
|
|
this.radius,
|
|
|
|
});
|
2024-05-18 18:17:16 +08:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2024-05-20 23:11:26 +08:00
|
|
|
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-07-16 19:46:53 +08:00
|
|
|
if (!isEmpty) isEmpty = content.endsWith('/attachments/0');
|
2024-05-20 23:11:26 +08:00
|
|
|
}
|
2024-05-18 18:17:16 +08:00
|
|
|
|
2024-06-01 21:39:28 +08:00
|
|
|
final url = direct
|
|
|
|
? content
|
2024-07-16 19:46:53 +08:00
|
|
|
: 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,
|
2024-05-22 20:56:10 +08:00
|
|
|
backgroundImage: !isEmpty
|
2024-06-01 21:39:28 +08:00
|
|
|
? (PlatformInfo.canCacheImage
|
|
|
|
? CachedNetworkImageProvider(url)
|
|
|
|
: NetworkImage(url)) as ImageProvider<Object>?
|
2024-05-22 20:56:10 +08:00
|
|
|
: null,
|
|
|
|
child: isEmpty
|
|
|
|
? Icon(
|
|
|
|
Icons.account_circle,
|
|
|
|
size: radius != null ? radius! * 1.2 : 24,
|
2024-05-29 00:14:41 +08:00
|
|
|
color: feColor,
|
2024-05-22 20:56:10 +08:00
|
|
|
)
|
|
|
|
: null,
|
2024-05-18 18:17:16 +08:00
|
|
|
);
|
|
|
|
}
|
2024-05-20 23:11:26 +08:00
|
|
|
}
|
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;
|
2024-07-16 19:46:53 +08:00
|
|
|
if (!isEmpty) isEmpty = content.endsWith('/attachments/0');
|
2024-06-03 23:36:46 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
final url = direct
|
|
|
|
? content
|
2024-07-16 19:46:53 +08:00
|
|
|
: ServiceFinder.buildUrl('files', '/attachments/$content');
|
2024-06-03 23:36:46 +08:00
|
|
|
|
|
|
|
if (PlatformInfo.canCacheImage) {
|
|
|
|
return CachedNetworkImage(
|
|
|
|
imageUrl: url,
|
|
|
|
fit: fit,
|
|
|
|
progressIndicatorBuilder: (context, url, downloadProgress) => Center(
|
|
|
|
child: CircularProgressIndicator(
|
|
|
|
value: downloadProgress.progress,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return Image.network(
|
|
|
|
url,
|
|
|
|
fit: fit,
|
|
|
|
loadingBuilder: (BuildContext context, Widget child,
|
|
|
|
ImageChunkEvent? loadingProgress) {
|
|
|
|
if (loadingProgress == null) return child;
|
|
|
|
return Center(
|
|
|
|
child: CircularProgressIndicator(
|
|
|
|
value: loadingProgress.expectedTotalBytes != null
|
|
|
|
? loadingProgress.cumulativeBytesLoaded /
|
|
|
|
loadingProgress.expectedTotalBytes!
|
|
|
|
: null,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|