2024-03-07 04:27:33 +01:00
|
|
|
import 'package:flutter/material.dart';
|
2024-05-01 04:36:40 +02:00
|
|
|
import 'package:immich_mobile/entities/asset.entity.dart';
|
2024-03-07 04:27:33 +01:00
|
|
|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
|
|
|
|
import 'package:immich_mobile/utils/bytes_units.dart';
|
|
|
|
|
2024-08-09 15:43:47 +02:00
|
|
|
class FileInfo extends StatelessWidget {
|
2024-03-07 04:27:33 +01:00
|
|
|
final Asset asset;
|
|
|
|
|
2024-08-09 15:43:47 +02:00
|
|
|
const FileInfo({
|
2024-03-07 04:27:33 +01:00
|
|
|
super.key,
|
|
|
|
required this.asset,
|
|
|
|
});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final textColor = context.isDarkTheme ? Colors.white : Colors.black;
|
|
|
|
|
2024-12-04 22:03:46 +01:00
|
|
|
final height = asset.orientatedHeight ?? asset.height;
|
|
|
|
final width = asset.orientatedWidth ?? asset.width;
|
|
|
|
String resolution =
|
|
|
|
height != null && width != null ? "$height x $width " : "";
|
2024-03-07 04:27:33 +01:00
|
|
|
String fileSize = asset.exifInfo?.fileSize != null
|
|
|
|
? formatBytes(asset.exifInfo!.fileSize!)
|
|
|
|
: "";
|
|
|
|
String text = resolution + fileSize;
|
|
|
|
final imgSizeString = text.isNotEmpty ? text : null;
|
|
|
|
|
|
|
|
String? title;
|
|
|
|
String? subtitle;
|
|
|
|
|
|
|
|
if (imgSizeString == null && asset.fileName.isNotEmpty) {
|
|
|
|
// There is only filename
|
|
|
|
title = asset.fileName;
|
|
|
|
} else if (imgSizeString != null && asset.fileName.isNotEmpty) {
|
|
|
|
// There is both filename and size information
|
|
|
|
title = asset.fileName;
|
|
|
|
subtitle = imgSizeString;
|
|
|
|
} else if (imgSizeString != null && asset.fileName.isEmpty) {
|
|
|
|
title = imgSizeString;
|
|
|
|
} else {
|
|
|
|
return const SizedBox.shrink();
|
|
|
|
}
|
|
|
|
|
|
|
|
return ListTile(
|
|
|
|
contentPadding: const EdgeInsets.all(0),
|
|
|
|
dense: true,
|
|
|
|
leading: Icon(
|
|
|
|
Icons.image,
|
|
|
|
color: textColor.withAlpha(200),
|
|
|
|
),
|
|
|
|
titleAlignment: ListTileTitleAlignment.center,
|
|
|
|
title: Text(
|
|
|
|
title,
|
|
|
|
style: context.textTheme.labelLarge,
|
|
|
|
),
|
|
|
|
subtitle: subtitle == null ? null : Text(subtitle),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|