mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-24 23:42:06 -04:00 
			
		
		
		
	* fix(mobile): upgrade maplibre_gl package to fix issue with crash in ios7.4 above simulator * chore: switch from deprecated widget and controller name to new name in latest sdk * remove todo --------- Co-authored-by: Alex <alex.tran1502@gmail.com>
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:async';
 | |
| import 'dart:math';
 | |
| 
 | |
| import 'package:flutter/services.dart';
 | |
| import 'package:immich_mobile/models/map/map_marker.model.dart';
 | |
| import 'package:immich_mobile/utils/map_utils.dart';
 | |
| import 'package:maplibre_gl/maplibre_gl.dart';
 | |
| 
 | |
| extension MapMarkers on MapLibreMapController {
 | |
|   static var _completer = Completer()..complete();
 | |
| 
 | |
|   Future<void> addGeoJSONSourceForMarkers(List<MapMarker> markers) async {
 | |
|     return addSource(
 | |
|       MapUtils.defaultSourceId,
 | |
|       GeojsonSourceProperties(
 | |
|         data: MapUtils.generateGeoJsonForMarkers(markers.toList()),
 | |
|       ),
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   Future<void> reloadAllLayersForMarkers(List<MapMarker> markers) async {
 | |
|     // Wait for previous reload to complete
 | |
|     if (!_completer.isCompleted) {
 | |
|       return _completer.future;
 | |
|     }
 | |
|     _completer = Completer();
 | |
| 
 | |
|     // !! Make sure to remove layers before sources else the native
 | |
|     // maplibre library would crash when removing the source saying that
 | |
|     // the source is still in use
 | |
|     final existingLayers = await getLayerIds();
 | |
|     if (existingLayers.contains(MapUtils.defaultHeatMapLayerId)) {
 | |
|       await removeLayer(MapUtils.defaultHeatMapLayerId);
 | |
|     }
 | |
| 
 | |
|     final existingSources = await getSourceIds();
 | |
|     if (existingSources.contains(MapUtils.defaultSourceId)) {
 | |
|       await removeSource(MapUtils.defaultSourceId);
 | |
|     }
 | |
| 
 | |
|     await addGeoJSONSourceForMarkers(markers);
 | |
| 
 | |
|     await addHeatmapLayer(
 | |
|       MapUtils.defaultSourceId,
 | |
|       MapUtils.defaultHeatMapLayerId,
 | |
|       MapUtils.defaultHeatMapLayerProperties,
 | |
|     );
 | |
| 
 | |
|     _completer.complete();
 | |
|   }
 | |
| 
 | |
|   Future<Symbol?> addMarkerAtLatLng(LatLng centre) async {
 | |
|     // no marker is displayed if asset-path is incorrect
 | |
|     try {
 | |
|       final ByteData bytes = await rootBundle.load("assets/location-pin.png");
 | |
|       await addImage("mapMarker", bytes.buffer.asUint8List());
 | |
|       return addSymbol(
 | |
|         SymbolOptions(
 | |
|           geometry: centre,
 | |
|           iconImage: "mapMarker",
 | |
|           iconSize: 0.15,
 | |
|           iconAnchor: "bottom",
 | |
|         ),
 | |
|       );
 | |
|     } finally {
 | |
|       // no-op
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   Future<LatLngBounds> getBoundsFromPoint(
 | |
|     Point<double> point,
 | |
|     double distance,
 | |
|   ) async {
 | |
|     final southWestPx = Point(point.x - distance, point.y + distance);
 | |
|     final northEastPx = Point(point.x + distance, point.y - distance);
 | |
| 
 | |
|     final southWest = await toLatLng(southWestPx);
 | |
|     final northEast = await toLatLng(northEastPx);
 | |
| 
 | |
|     return LatLngBounds(southwest: southWest, northeast: northEast);
 | |
|   }
 | |
| }
 |