mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 08:12:33 -04:00 
			
		
		
		
	* Bump to Flutter 3.13.0 * Updates permission status * Adds hidden to app livecycle state * Updates and switches to WakelockPlus * bump flutter version github action * mobile test version * fix format * video player * video uri * ios test * Update android target sdk requirement to PlayStore --------- Co-authored-by: Alex Tran <Alex.Tran@conductix.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:math';
 | |
| 
 | |
| 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;
 | |
|   bool useRandomBackgroundColor;
 | |
| 
 | |
|   UserCircleAvatar({
 | |
|     super.key,
 | |
|     this.radius = 22,
 | |
|     this.size = 44,
 | |
|     this.useRandomBackgroundColor = false,
 | |
|     required this.user,
 | |
|   });
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context, WidgetRef ref) {
 | |
|     final randomColors = [
 | |
|       Colors.red[200],
 | |
|       Colors.blue[200],
 | |
|       Colors.green[200],
 | |
|       Colors.yellow[200],
 | |
|       Colors.purple[200],
 | |
|       Colors.orange[200],
 | |
|       Colors.pink[200],
 | |
|       Colors.teal[200],
 | |
|       Colors.indigo[200],
 | |
|       Colors.cyan[200],
 | |
|       Colors.brown[200],
 | |
|     ];
 | |
| 
 | |
|     final profileImageUrl =
 | |
|         '${Store.get(StoreKey.serverEndpoint)}/user/profile-image/${user.id}?d=${Random().nextInt(1024)}';
 | |
|     return CircleAvatar(
 | |
|       backgroundColor: useRandomBackgroundColor
 | |
|           ? randomColors[Random().nextInt(randomColors.length)]
 | |
|           : Theme.of(context).primaryColor,
 | |
|       radius: radius,
 | |
|       child: user.profileImagePath == ""
 | |
|           ? Text(
 | |
|               user.firstName[0],
 | |
|               style: const TextStyle(
 | |
|                 fontWeight: FontWeight.bold,
 | |
|                 color: Colors.black,
 | |
|               ),
 | |
|             )
 | |
|           : ClipRRect(
 | |
|               borderRadius: BorderRadius.circular(50),
 | |
|               child: FadeInImage(
 | |
|                 fit: BoxFit.cover,
 | |
|                 placeholder: MemoryImage(kTransparentImage),
 | |
|                 width: size,
 | |
|                 height: size,
 | |
|                 image: NetworkImage(
 | |
|                   profileImageUrl,
 | |
|                   headers: {
 | |
|                     "Authorization": "Bearer ${Store.get(StoreKey.accessToken)}",
 | |
|                   },
 | |
|                 ),
 | |
|                 fadeInDuration: const Duration(milliseconds: 200),
 | |
|                 imageErrorBuilder: (context, error, stackTrace) =>
 | |
|                     Image.memory(kTransparentImage),
 | |
|               ),
 | |
|             ),
 | |
|     );
 | |
|   }
 | |
| }
 |