forked from Cutlery/immich
		
	* chore: maplibre gl pubspec * refactor(wip): maplibre for maps * refactor(wip): dual pane + location button * chore: remove flutter_map and deps * refactor(wip): map zoom to location * refactor: location picker * open gallery_viewer on marker tap * remove detectScaleGesture param * test: debounce and throttle * chore: rename get location method * feat(mobile): Adds gps locator to map prompt for easy geolocation (#6282) * Refactored get gps coords * Use var for linter's sake, should handle errors better * Cleanup * Fix linter issues * chore(dep): update maplibre to official lib --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com> Co-authored-by: Joshua Herrera <joshua.herrera227@gmail.com>
		
			
				
	
	
		
			139 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:easy_localization/easy_localization.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:immich_mobile/modules/map/models/map_marker.dart';
 | |
| import 'package:immich_mobile/shared/ui/confirm_dialog.dart';
 | |
| import 'package:geolocator/geolocator.dart';
 | |
| import 'package:logging/logging.dart';
 | |
| import 'package:maplibre_gl/maplibre_gl.dart';
 | |
| 
 | |
| class MapUtils {
 | |
|   MapUtils._();
 | |
| 
 | |
|   static final Logger _log = Logger("MapUtils");
 | |
|   static const defaultSourceId = 'asset-map-markers';
 | |
|   static const defaultHeatMapLayerId = 'asset-heatmap-layer';
 | |
| 
 | |
|   static const defaultHeatMapLayerProperties = HeatmapLayerProperties(
 | |
|     heatmapColor: [
 | |
|       Expressions.interpolate,
 | |
|       ["linear"],
 | |
|       ["heatmap-density"],
 | |
|       0.0,
 | |
|       "rgba(246,239,247,0.0)",
 | |
|       0.2,
 | |
|       "rgb(208,209,230)",
 | |
|       0.4,
 | |
|       "rgb(166,189,219)",
 | |
|       0.6,
 | |
|       "rgb(103,169,207)",
 | |
|       0.8,
 | |
|       "rgb(28,144,153)",
 | |
|       1.0,
 | |
|       "rgb(1,108,89)",
 | |
|     ],
 | |
|     heatmapIntensity: [
 | |
|       Expressions.interpolate, ["linear"], //
 | |
|       [Expressions.zoom],
 | |
|       0, 0.5,
 | |
|       9, 2,
 | |
|     ],
 | |
|     heatmapRadius: [
 | |
|       Expressions.interpolate, ["linear"], //
 | |
|       [Expressions.zoom],
 | |
|       0, 4,
 | |
|       4, 8,
 | |
|       9, 16,
 | |
|     ],
 | |
|   );
 | |
| 
 | |
|   static Map<String, dynamic> _addFeature(MapMarker marker) => {
 | |
|         'type': 'Feature',
 | |
|         'id': marker.assetRemoteId,
 | |
|         'geometry': {
 | |
|           'type': 'Point',
 | |
|           'coordinates': [marker.latLng.longitude, marker.latLng.latitude],
 | |
|         },
 | |
|       };
 | |
| 
 | |
|   static Map<String, dynamic> generateGeoJsonForMarkers(
 | |
|     List<MapMarker> markers,
 | |
|   ) =>
 | |
|       {
 | |
|         'type': 'FeatureCollection',
 | |
|         'features': markers.map(_addFeature).toList(),
 | |
|       };
 | |
| 
 | |
|   static Future<(Position?, LocationPermission?)> checkPermAndGetLocation(
 | |
|     BuildContext context,
 | |
|   ) async {
 | |
|     try {
 | |
|       bool serviceEnabled = await Geolocator.isLocationServiceEnabled();
 | |
|       if (!serviceEnabled) {
 | |
|         showDialog(
 | |
|           context: context,
 | |
|           builder: (context) => _LocationServiceDisabledDialog(),
 | |
|         );
 | |
|         return (null, LocationPermission.deniedForever);
 | |
|       }
 | |
| 
 | |
|       LocationPermission permission = await Geolocator.checkPermission();
 | |
|       bool shouldRequestPermission = false;
 | |
| 
 | |
|       if (permission == LocationPermission.denied) {
 | |
|         shouldRequestPermission = await showDialog(
 | |
|           context: context,
 | |
|           builder: (context) => _LocationPermissionDisabledDialog(),
 | |
|         );
 | |
|         if (shouldRequestPermission) {
 | |
|           permission = await Geolocator.requestPermission();
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       if (permission == LocationPermission.denied ||
 | |
|           permission == LocationPermission.deniedForever) {
 | |
|         // Open app settings only if you did not request for permission before
 | |
|         if (permission == LocationPermission.deniedForever &&
 | |
|             !shouldRequestPermission) {
 | |
|           await Geolocator.openAppSettings();
 | |
|         }
 | |
|         return (null, LocationPermission.deniedForever);
 | |
|       }
 | |
| 
 | |
|       Position currentUserLocation = await Geolocator.getCurrentPosition(
 | |
|         desiredAccuracy: LocationAccuracy.medium,
 | |
|         timeLimit: const Duration(seconds: 5),
 | |
|       );
 | |
|       return (currentUserLocation, null);
 | |
|     } catch (error) {
 | |
|       _log.severe(
 | |
|         "Cannot get user's current location due to ${error.toString()}",
 | |
|       );
 | |
|       return (null, LocationPermission.unableToDetermine);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| class _LocationServiceDisabledDialog extends ConfirmDialog {
 | |
|   _LocationServiceDisabledDialog()
 | |
|       : super(
 | |
|           title: 'map_location_service_disabled_title'.tr(),
 | |
|           content: 'map_location_service_disabled_content'.tr(),
 | |
|           cancel: 'map_location_dialog_cancel'.tr(),
 | |
|           ok: 'map_location_dialog_yes'.tr(),
 | |
|           onOk: () async {
 | |
|             await Geolocator.openLocationSettings();
 | |
|           },
 | |
|         );
 | |
| }
 | |
| 
 | |
| class _LocationPermissionDisabledDialog extends ConfirmDialog {
 | |
|   _LocationPermissionDisabledDialog()
 | |
|       : super(
 | |
|           title: 'map_no_location_permission_title'.tr(),
 | |
|           content: 'map_no_location_permission_content'.tr(),
 | |
|           cancel: 'map_location_dialog_cancel'.tr(),
 | |
|           ok: 'map_location_dialog_yes'.tr(),
 | |
|           onOk: () {},
 | |
|         );
 | |
| }
 |