forked from Cutlery/immich
		
	
		
			
				
	
	
		
			142 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:auto_route/auto_route.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:hooks_riverpod/hooks_riverpod.dart';
 | |
| import 'package:immich_mobile/modules/backup/providers/error_backup_list.provider.dart';
 | |
| import 'package:intl/intl.dart';
 | |
| import 'package:photo_manager/photo_manager.dart';
 | |
| 
 | |
| class FailedBackupStatusPage extends HookConsumerWidget {
 | |
|   const FailedBackupStatusPage({Key? key}) : super(key: key);
 | |
|   @override
 | |
|   Widget build(BuildContext context, WidgetRef ref) {
 | |
|     final errorBackupList = ref.watch(errorBackupListProvider);
 | |
| 
 | |
|     return Scaffold(
 | |
|       appBar: AppBar(
 | |
|         elevation: 0,
 | |
|         title: Text(
 | |
|           "Failed Backup (${errorBackupList.length})",
 | |
|           style: const TextStyle(fontSize: 16, fontWeight: FontWeight.bold),
 | |
|         ),
 | |
|         leading: IconButton(
 | |
|           onPressed: () {
 | |
|             AutoRouter.of(context).pop(true);
 | |
|           },
 | |
|           splashRadius: 24,
 | |
|           icon: const Icon(
 | |
|             Icons.arrow_back_ios_rounded,
 | |
|           ),
 | |
|         ),
 | |
|       ),
 | |
|       body: ListView.builder(
 | |
|         shrinkWrap: true,
 | |
|         itemCount: errorBackupList.length,
 | |
|         itemBuilder: ((context, index) {
 | |
|           var errorAsset = errorBackupList.elementAt(index);
 | |
| 
 | |
|           return Padding(
 | |
|             padding: const EdgeInsets.symmetric(
 | |
|               horizontal: 12.0,
 | |
|               vertical: 4,
 | |
|             ),
 | |
|             child: Card(
 | |
|               shape: RoundedRectangleBorder(
 | |
|                 borderRadius: BorderRadius.circular(15), // if you need this
 | |
|                 side: const BorderSide(
 | |
|                   color: Colors.black12,
 | |
|                   width: 1,
 | |
|                 ),
 | |
|               ),
 | |
|               elevation: 0,
 | |
|               child: Row(
 | |
|                 crossAxisAlignment: CrossAxisAlignment.center,
 | |
|                 mainAxisAlignment: MainAxisAlignment.spaceBetween,
 | |
|                 children: [
 | |
|                   ConstrainedBox(
 | |
|                     constraints: const BoxConstraints(
 | |
|                       minWidth: 100,
 | |
|                       minHeight: 150,
 | |
|                       maxWidth: 100,
 | |
|                       maxHeight: 200,
 | |
|                     ),
 | |
|                     child: ClipRRect(
 | |
|                       borderRadius: const BorderRadius.only(
 | |
|                         bottomLeft: Radius.circular(15),
 | |
|                         topLeft: Radius.circular(15),
 | |
|                       ),
 | |
|                       clipBehavior: Clip.hardEdge,
 | |
|                       child: Image(
 | |
|                         fit: BoxFit.cover,
 | |
|                         image: AssetEntityImageProvider(
 | |
|                           errorAsset.asset,
 | |
|                           isOriginal: false,
 | |
|                           thumbnailSize: const ThumbnailSize.square(512),
 | |
|                           thumbnailFormat: ThumbnailFormat.jpeg,
 | |
|                         ),
 | |
|                       ),
 | |
|                     ),
 | |
|                   ),
 | |
|                   Expanded(
 | |
|                     child: Padding(
 | |
|                       padding: const EdgeInsets.all(16.0),
 | |
|                       child: Column(
 | |
|                         crossAxisAlignment: CrossAxisAlignment.start,
 | |
|                         mainAxisAlignment: MainAxisAlignment.spaceEvenly,
 | |
|                         children: [
 | |
|                           Row(
 | |
|                             mainAxisAlignment: MainAxisAlignment.spaceBetween,
 | |
|                             children: [
 | |
|                               Text(
 | |
|                                 DateFormat.yMMMMd().format(
 | |
|                                   DateTime.parse(
 | |
|                                     errorAsset.fileCreatedAt.toString(),
 | |
|                                   ).toLocal(),
 | |
|                                 ),
 | |
|                                 style: TextStyle(
 | |
|                                   fontSize: 12,
 | |
|                                   fontWeight: FontWeight.w600,
 | |
|                                   color: Colors.grey[700],
 | |
|                                 ),
 | |
|                               ),
 | |
|                               Icon(
 | |
|                                 Icons.error,
 | |
|                                 color: Colors.red.withAlpha(200),
 | |
|                                 size: 18,
 | |
|                               ),
 | |
|                             ],
 | |
|                           ),
 | |
|                           Padding(
 | |
|                             padding: const EdgeInsets.symmetric(vertical: 8.0),
 | |
|                             child: Text(
 | |
|                               errorAsset.fileName,
 | |
|                               maxLines: 1,
 | |
|                               overflow: TextOverflow.ellipsis,
 | |
|                               style: TextStyle(
 | |
|                                 fontWeight: FontWeight.bold,
 | |
|                                 fontSize: 12,
 | |
|                                 color: Theme.of(context).primaryColor,
 | |
|                               ),
 | |
|                             ),
 | |
|                           ),
 | |
|                           Text(
 | |
|                             errorAsset.errorMessage,
 | |
|                             style: TextStyle(
 | |
|                               fontSize: 12,
 | |
|                               fontWeight: FontWeight.w500,
 | |
|                               color: Colors.grey[800],
 | |
|                             ),
 | |
|                           ),
 | |
|                         ],
 | |
|                       ),
 | |
|                     ),
 | |
|                   )
 | |
|                 ],
 | |
|               ),
 | |
|             ),
 | |
|           );
 | |
|         }),
 | |
|       ),
 | |
|     );
 | |
|   }
 | |
| }
 |