2024-03-07 04:27:33 +01:00
|
|
|
import 'dart:io';
|
|
|
|
|
|
|
|
import 'package:flutter/material.dart';
|
2024-05-07 06:04:21 +02:00
|
|
|
import 'package:immich_mobile/widgets/map/map_thumbnail.dart';
|
2024-05-01 04:36:40 +02:00
|
|
|
import 'package:immich_mobile/entities/exif_info.entity.dart';
|
2024-03-07 04:27:33 +01:00
|
|
|
import 'package:maplibre_gl/maplibre_gl.dart';
|
|
|
|
import 'package:url_launcher/url_launcher.dart';
|
|
|
|
|
|
|
|
class ExifMap extends StatelessWidget {
|
|
|
|
final ExifInfo exifInfo;
|
|
|
|
final String? markerId;
|
|
|
|
|
|
|
|
const ExifMap({
|
|
|
|
super.key,
|
|
|
|
required this.exifInfo,
|
|
|
|
this.markerId = 'marker',
|
|
|
|
});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final hasCoordinates = exifInfo.hasCoordinates;
|
|
|
|
Future<Uri?> createCoordinatesUri() async {
|
|
|
|
if (!hasCoordinates) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
final double latitude = exifInfo.latitude!;
|
|
|
|
final double longitude = exifInfo.longitude!;
|
|
|
|
|
|
|
|
const zoomLevel = 16;
|
|
|
|
|
|
|
|
if (Platform.isAndroid) {
|
|
|
|
Uri uri = Uri(
|
|
|
|
scheme: 'geo',
|
|
|
|
host: '$latitude,$longitude',
|
|
|
|
queryParameters: {
|
|
|
|
'z': '$zoomLevel',
|
2024-08-09 15:43:47 +02:00
|
|
|
'q': '$latitude,$longitude',
|
2024-03-07 04:27:33 +01:00
|
|
|
},
|
|
|
|
);
|
|
|
|
if (await canLaunchUrl(uri)) {
|
|
|
|
return uri;
|
|
|
|
}
|
|
|
|
} else if (Platform.isIOS) {
|
|
|
|
var params = {
|
|
|
|
'll': '$latitude,$longitude',
|
2024-08-09 15:43:47 +02:00
|
|
|
'q': '$latitude,$longitude',
|
2024-03-07 04:27:33 +01:00
|
|
|
'z': '$zoomLevel',
|
|
|
|
};
|
|
|
|
Uri uri = Uri.https('maps.apple.com', '/', params);
|
|
|
|
if (await canLaunchUrl(uri)) {
|
|
|
|
return uri;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Uri(
|
|
|
|
scheme: 'https',
|
|
|
|
host: 'openstreetmap.org',
|
|
|
|
queryParameters: {'mlat': '$latitude', 'mlon': '$longitude'},
|
|
|
|
fragment: 'map=$zoomLevel/$latitude/$longitude',
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-08-09 15:43:47 +02:00
|
|
|
return LayoutBuilder(
|
|
|
|
builder: (context, constraints) {
|
|
|
|
return MapThumbnail(
|
|
|
|
centre: LatLng(
|
|
|
|
exifInfo.latitude ?? 0,
|
|
|
|
exifInfo.longitude ?? 0,
|
|
|
|
),
|
|
|
|
height: 150,
|
|
|
|
width: constraints.maxWidth,
|
|
|
|
zoom: 12.0,
|
|
|
|
assetMarkerRemoteId: markerId,
|
|
|
|
onTap: (tapPosition, latLong) async {
|
|
|
|
Uri? uri = await createCoordinatesUri();
|
2024-03-07 04:27:33 +01:00
|
|
|
|
2024-08-09 15:43:47 +02:00
|
|
|
if (uri == null) {
|
|
|
|
return;
|
|
|
|
}
|
2024-03-07 04:27:33 +01:00
|
|
|
|
2024-08-09 15:43:47 +02:00
|
|
|
debugPrint('Opening Map Uri: $uri');
|
|
|
|
launchUrl(uri);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
},
|
2024-03-07 04:27:33 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|