mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-25 15:52:33 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:flutter/material.dart';
 | |
| import 'package:fluttertoast/fluttertoast.dart';
 | |
| 
 | |
| enum ToastType { info, success, error }
 | |
| 
 | |
| class ImmichToast {
 | |
|   static show({
 | |
|     required BuildContext context,
 | |
|     required String msg,
 | |
|     ToastType toastType = ToastType.info,
 | |
|     ToastGravity gravity = ToastGravity.TOP,
 | |
|     int durationInSecond = 3,
 | |
|   }) {
 | |
|     final isDarkTheme = Theme.of(context).brightness == Brightness.dark;
 | |
|     final fToast = FToast();
 | |
|     fToast.init(context);
 | |
| 
 | |
|     Color getColor(ToastType type, BuildContext context) {
 | |
|       switch (type) {
 | |
|         case ToastType.info:
 | |
|           return Theme.of(context).primaryColor;
 | |
|         case ToastType.success:
 | |
|           return const Color.fromARGB(255, 78, 140, 124);
 | |
|         case ToastType.error:
 | |
|           return const Color.fromARGB(255, 220, 48, 85);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     Icon getIcon(ToastType type) {
 | |
|       switch (type) {
 | |
|         case ToastType.info:
 | |
|           return Icon(
 | |
|             Icons.info_outline_rounded,
 | |
|             color: Theme.of(context).primaryColor,
 | |
|           );
 | |
|         case ToastType.success:
 | |
|           return const Icon(
 | |
|             Icons.check_circle_rounded,
 | |
|             color: Color.fromARGB(255, 78, 140, 124),
 | |
|           );
 | |
|         case ToastType.error:
 | |
|           return const Icon(
 | |
|             Icons.error_outline_rounded,
 | |
|             color: Color.fromARGB(255, 240, 162, 156),
 | |
|           );
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     fToast.showToast(
 | |
|       child: Container(
 | |
|         padding: const EdgeInsets.symmetric(horizontal: 24.0, vertical: 12.0),
 | |
|         decoration: BoxDecoration(
 | |
|           borderRadius: BorderRadius.circular(5.0),
 | |
|           color: isDarkTheme ? Colors.grey[900] : Colors.grey[50],
 | |
|           border: Border.all(
 | |
|             color: Colors.black12,
 | |
|             width: 1,
 | |
|           ),
 | |
|         ),
 | |
|         child: Row(
 | |
|           mainAxisSize: MainAxisSize.min,
 | |
|           children: [
 | |
|             getIcon(toastType),
 | |
|             const SizedBox(
 | |
|               width: 12.0,
 | |
|             ),
 | |
|             Flexible(
 | |
|               child: Text(
 | |
|                 msg,
 | |
|                 style: TextStyle(
 | |
|                   color: getColor(toastType, context),
 | |
|                   fontWeight: FontWeight.bold,
 | |
|                   fontSize: 15,
 | |
|                 ),
 | |
|               ),
 | |
|             ),
 | |
|           ],
 | |
|         ),
 | |
|       ),
 | |
|       gravity: gravity,
 | |
|       toastDuration: Duration(seconds: durationInSecond),
 | |
|     );
 | |
|   }
 | |
| }
 |