mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-03 19:17:11 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			106 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
import 'package:easy_localization/easy_localization.dart';
 | 
						|
import 'package:flutter/material.dart';
 | 
						|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
 | 
						|
import 'package:immich_mobile/widgets/asset_viewer/exif_sheet/exif_map.dart';
 | 
						|
import 'package:immich_mobile/entities/asset.entity.dart';
 | 
						|
import 'package:immich_mobile/entities/exif_info.entity.dart';
 | 
						|
 | 
						|
class ExifLocation extends StatelessWidget {
 | 
						|
  final Asset asset;
 | 
						|
  final ExifInfo? exifInfo;
 | 
						|
  final void Function() editLocation;
 | 
						|
  final String formattedDateTime;
 | 
						|
 | 
						|
  const ExifLocation({
 | 
						|
    super.key,
 | 
						|
    required this.asset,
 | 
						|
    required this.exifInfo,
 | 
						|
    required this.editLocation,
 | 
						|
    required this.formattedDateTime,
 | 
						|
  });
 | 
						|
 | 
						|
  @override
 | 
						|
  Widget build(BuildContext context) {
 | 
						|
    final hasCoordinates = exifInfo?.hasCoordinates ?? false;
 | 
						|
    // Guard no lat/lng
 | 
						|
    if (!hasCoordinates) {
 | 
						|
      return asset.isRemote
 | 
						|
          ? ListTile(
 | 
						|
              minLeadingWidth: 0,
 | 
						|
              contentPadding: const EdgeInsets.all(0),
 | 
						|
              leading: const Icon(Icons.location_on),
 | 
						|
              title: Text(
 | 
						|
                "exif_bottom_sheet_location_add",
 | 
						|
                style: context.textTheme.bodyMedium?.copyWith(
 | 
						|
                  fontWeight: FontWeight.w600,
 | 
						|
                  color: context.primaryColor,
 | 
						|
                ),
 | 
						|
              ).tr(),
 | 
						|
              onTap: editLocation,
 | 
						|
            )
 | 
						|
          : const SizedBox.shrink();
 | 
						|
    }
 | 
						|
 | 
						|
    return Column(
 | 
						|
      children: [
 | 
						|
        // Location
 | 
						|
        Column(
 | 
						|
          crossAxisAlignment: CrossAxisAlignment.start,
 | 
						|
          children: [
 | 
						|
            Row(
 | 
						|
              mainAxisAlignment: MainAxisAlignment.spaceBetween,
 | 
						|
              children: [
 | 
						|
                Text(
 | 
						|
                  "exif_bottom_sheet_location",
 | 
						|
                  style: context.textTheme.labelMedium?.copyWith(
 | 
						|
                    color: context.textTheme.labelMedium?.color?.withAlpha(200),
 | 
						|
                    fontWeight: FontWeight.w600,
 | 
						|
                  ),
 | 
						|
                ).tr(),
 | 
						|
                if (asset.isRemote)
 | 
						|
                  IconButton(
 | 
						|
                    onPressed: editLocation,
 | 
						|
                    icon: const Icon(Icons.edit_outlined),
 | 
						|
                    iconSize: 20,
 | 
						|
                  ),
 | 
						|
              ],
 | 
						|
            ),
 | 
						|
            ExifMap(
 | 
						|
              exifInfo: exifInfo!,
 | 
						|
              formattedDateTime: formattedDateTime,
 | 
						|
              markerId: asset.remoteId,
 | 
						|
            ),
 | 
						|
            RichText(
 | 
						|
              text: TextSpan(
 | 
						|
                style: context.textTheme.labelLarge,
 | 
						|
                children: [
 | 
						|
                  if (exifInfo != null && exifInfo?.city != null)
 | 
						|
                    TextSpan(
 | 
						|
                      text: exifInfo!.city,
 | 
						|
                    ),
 | 
						|
                  if (exifInfo != null &&
 | 
						|
                      exifInfo?.city != null &&
 | 
						|
                      exifInfo?.state != null)
 | 
						|
                    const TextSpan(
 | 
						|
                      text: ", ",
 | 
						|
                    ),
 | 
						|
                  if (exifInfo != null && exifInfo?.state != null)
 | 
						|
                    TextSpan(
 | 
						|
                      text: exifInfo!.state,
 | 
						|
                    ),
 | 
						|
                ],
 | 
						|
              ),
 | 
						|
            ),
 | 
						|
            Text(
 | 
						|
              "${exifInfo!.latitude!.toStringAsFixed(4)}, ${exifInfo!.longitude!.toStringAsFixed(4)}",
 | 
						|
              style: context.textTheme.labelMedium?.copyWith(
 | 
						|
                color: context.textTheme.labelMedium?.color?.withAlpha(150),
 | 
						|
              ),
 | 
						|
            ),
 | 
						|
          ],
 | 
						|
        ),
 | 
						|
      ],
 | 
						|
    );
 | 
						|
  }
 | 
						|
}
 |