forked from Cutlery/immich
		
	
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:math';
 | |
| 
 | |
| import 'package:cached_network_image/cached_network_image.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:hooks_riverpod/hooks_riverpod.dart';
 | |
| import 'package:immich_mobile/shared/models/store.dart';
 | |
| import 'package:immich_mobile/shared/models/user.dart';
 | |
| import 'package:immich_mobile/shared/ui/transparent_image.dart';
 | |
| 
 | |
| // ignore: must_be_immutable
 | |
| class UserCircleAvatar extends ConsumerWidget {
 | |
|   final User user;
 | |
|   double radius;
 | |
|   double size;
 | |
| 
 | |
|   UserCircleAvatar({
 | |
|     super.key,
 | |
|     this.radius = 22,
 | |
|     this.size = 44,
 | |
|     required this.user,
 | |
|   });
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context, WidgetRef ref) {
 | |
|     bool isDarkTheme = Theme.of(context).brightness == Brightness.dark;
 | |
|     final profileImageUrl =
 | |
|         '${Store.get(StoreKey.serverEndpoint)}/user/profile-image/${user.id}?d=${Random().nextInt(1024)}';
 | |
| 
 | |
|     final textIcon = Text(
 | |
|       user.name[0].toUpperCase(),
 | |
|       style: TextStyle(
 | |
|         fontWeight: FontWeight.bold,
 | |
|         fontSize: 12,
 | |
|         color: isDarkTheme && user.avatarColor == AvatarColorEnum.primary
 | |
|             ? Colors.black
 | |
|             : Colors.white,
 | |
|       ),
 | |
|     );
 | |
|     return CircleAvatar(
 | |
|       backgroundColor: user.avatarColor.toColor(),
 | |
|       radius: radius,
 | |
|       child: user.profileImagePath.isEmpty
 | |
|           ? textIcon
 | |
|           : ClipRRect(
 | |
|               borderRadius: const BorderRadius.all(Radius.circular(50)),
 | |
|               child: CachedNetworkImage(
 | |
|                 fit: BoxFit.cover,
 | |
|                 cacheKey: user.profileImagePath,
 | |
|                 width: size,
 | |
|                 height: size,
 | |
|                 placeholder: (_, __) => Image.memory(kTransparentImage),
 | |
|                 imageUrl: profileImageUrl,
 | |
|                 httpHeaders: {
 | |
|                   "x-immich-user-token": Store.get(StoreKey.accessToken),
 | |
|                 },
 | |
|                 fadeInDuration: const Duration(milliseconds: 300),
 | |
|                 errorWidget: (context, error, stackTrace) => textIcon,
 | |
|               ),
 | |
|             ),
 | |
|     );
 | |
|   }
 | |
| }
 |