0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-21 00:52:43 -05:00

fix(mobile): map crashes on Android (#10773)

Revert "fix(mobile): upgrade maplibre_gl package to fix issue with crash in ios7.4 above simulator (#10182)"

This reverts commit 99c6fdbc1c.
This commit is contained in:
Alex 2024-07-02 13:43:52 -05:00 committed by GitHub
parent 14d94df1b8
commit f23401d911
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
8 changed files with 46 additions and 39 deletions

View file

@ -17,9 +17,9 @@ PODS:
- fluttertoast (0.0.2): - fluttertoast (0.0.2):
- Flutter - Flutter
- Toast - Toast
- FMDB (2.7.11): - FMDB (2.7.5):
- FMDB/standard (= 2.7.11) - FMDB/standard (= 2.7.5)
- FMDB/standard (2.7.11) - FMDB/standard (2.7.5)
- geolocator_apple (1.2.0): - geolocator_apple (1.2.0):
- Flutter - Flutter
- image_picker_ios (0.0.1): - image_picker_ios (0.0.1):
@ -28,10 +28,10 @@ PODS:
- Flutter - Flutter
- isar_flutter_libs (1.0.0): - isar_flutter_libs (1.0.0):
- Flutter - Flutter
- MapLibre (6.5.0) - MapLibre (5.14.0-pre3)
- maplibre_gl (0.0.1): - maplibre_gl (0.0.1):
- Flutter - Flutter
- MapLibre (= 6.5.0) - MapLibre (= 5.14.0-pre3)
- package_info_plus (0.4.5): - package_info_plus (0.4.5):
- Flutter - Flutter
- path_provider_foundation (0.0.1): - path_provider_foundation (0.0.1):
@ -44,7 +44,7 @@ PODS:
- photo_manager (2.0.0): - photo_manager (2.0.0):
- Flutter - Flutter
- FlutterMacOS - FlutterMacOS
- ReachabilitySwift (5.2.3) - ReachabilitySwift (5.0.0)
- SAMKeychain (1.5.3) - SAMKeychain (1.5.3)
- share_plus (0.0.1): - share_plus (0.0.1):
- Flutter - Flutter
@ -54,7 +54,7 @@ PODS:
- sqflite (0.0.3): - sqflite (0.0.3):
- Flutter - Flutter
- FMDB (>= 2.7.5) - FMDB (>= 2.7.5)
- Toast (4.1.1) - Toast (4.0.0)
- url_launcher_ios (0.0.1): - url_launcher_ios (0.0.1):
- Flutter - Flutter
- video_player_avfoundation (0.0.1): - video_player_avfoundation (0.0.1):
@ -156,24 +156,24 @@ SPEC CHECKSUMS:
flutter_udid: a2482c67a61b9c806ef59dd82ed8d007f1b7ac04 flutter_udid: a2482c67a61b9c806ef59dd82ed8d007f1b7ac04
flutter_web_auth: c25208760459cec375a3c39f6a8759165ca0fa4d flutter_web_auth: c25208760459cec375a3c39f6a8759165ca0fa4d
fluttertoast: 31b00dabfa7fb7bacd9e7dbee580d7a2ff4bf265 fluttertoast: 31b00dabfa7fb7bacd9e7dbee580d7a2ff4bf265
FMDB: 57486c1117fd8e0e6b947b2f54c3f42bf8e57a4e FMDB: 2ce00b547f966261cd18927a3ddb07cb6f3db82a
geolocator_apple: 9157311f654584b9bb72686c55fc02a97b73f461 geolocator_apple: 9157311f654584b9bb72686c55fc02a97b73f461
image_picker_ios: 4a8aadfbb6dc30ad5141a2ce3832af9214a705b5 image_picker_ios: 4a8aadfbb6dc30ad5141a2ce3832af9214a705b5
integration_test: ce0a3ffa1de96d1a89ca0ac26fca7ea18a749ef4 integration_test: ce0a3ffa1de96d1a89ca0ac26fca7ea18a749ef4
isar_flutter_libs: b69f437aeab9c521821c3f376198c4371fa21073 isar_flutter_libs: b69f437aeab9c521821c3f376198c4371fa21073
MapLibre: 0ebfa9329d313cec8bf0a5ba5a336a1dc903785e MapLibre: 620fc933c1d6029b33738c905c1490d024e5d4ef
maplibre_gl: 943a491fffb3337c1b9de57fd377206d18c16e34 maplibre_gl: a2efec727dd340e4c65e26d2b03b584f14881fd9
package_info_plus: 115f4ad11e0698c8c1c5d8a689390df880f47e85 package_info_plus: 115f4ad11e0698c8c1c5d8a689390df880f47e85
path_provider_foundation: 29f094ae23ebbca9d3d0cec13889cd9060c0e943 path_provider_foundation: 29f094ae23ebbca9d3d0cec13889cd9060c0e943
path_provider_ios: 14f3d2fd28c4fdb42f44e0f751d12861c43cee02 path_provider_ios: 14f3d2fd28c4fdb42f44e0f751d12861c43cee02
permission_handler_apple: e76247795d700c14ea09e3a2d8855d41ee80a2e6 permission_handler_apple: e76247795d700c14ea09e3a2d8855d41ee80a2e6
photo_manager: 4f6810b7dfc4feb03b461ac1a70dacf91fba7604 photo_manager: 4f6810b7dfc4feb03b461ac1a70dacf91fba7604
ReachabilitySwift: 7f151ff156cea1481a8411701195ac6a984f4979 ReachabilitySwift: 985039c6f7b23a1da463388634119492ff86c825
SAMKeychain: 483e1c9f32984d50ca961e26818a534283b4cd5c SAMKeychain: 483e1c9f32984d50ca961e26818a534283b4cd5c
share_plus: c3fef564749587fc939ef86ffb283ceac0baf9f5 share_plus: c3fef564749587fc939ef86ffb283ceac0baf9f5
shared_preferences_foundation: 5b919d13b803cadd15ed2dc053125c68730e5126 shared_preferences_foundation: 5b919d13b803cadd15ed2dc053125c68730e5126
sqflite: 31f7eba61e3074736dff8807a9b41581e4f7f15a sqflite: 31f7eba61e3074736dff8807a9b41581e4f7f15a
Toast: 1f5ea13423a1e6674c4abdac5be53587ae481c4e Toast: 91b396c56ee72a5790816f40d3a94dd357abc196
url_launcher_ios: bbd758c6e7f9fd7b5b1d4cde34d2b95fcce5e812 url_launcher_ios: bbd758c6e7f9fd7b5b1d4cde34d2b95fcce5e812
video_player_avfoundation: 02011213dab73ae3687df27ce441fbbcc82b5579 video_player_avfoundation: 02011213dab73ae3687df27ce441fbbcc82b5579
wakelock_plus: 8b09852c8876491e4b6d179e17dfe2a0b5f60d47 wakelock_plus: 8b09852c8876491e4b6d179e17dfe2a0b5f60d47

View file

@ -6,7 +6,7 @@ import 'package:immich_mobile/models/map/map_marker.model.dart';
import 'package:immich_mobile/utils/map_utils.dart'; import 'package:immich_mobile/utils/map_utils.dart';
import 'package:maplibre_gl/maplibre_gl.dart'; import 'package:maplibre_gl/maplibre_gl.dart';
extension MapMarkers on MapLibreMapController { extension MapMarkers on MaplibreMapController {
static var _completer = Completer()..complete(); static var _completer = Completer()..complete();
Future<void> addGeoJSONSourceForMarkers(List<MapMarker> markers) async { Future<void> addGeoJSONSourceForMarkers(List<MapMarker> markers) async {

View file

@ -36,7 +36,7 @@ class MapPage extends HookConsumerWidget {
@override @override
Widget build(BuildContext context, WidgetRef ref) { Widget build(BuildContext context, WidgetRef ref) {
final mapController = useRef<MapLibreMapController?>(null); final mapController = useRef<MaplibreMapController?>(null);
final markers = useRef<List<MapMarker>>([]); final markers = useRef<List<MapMarker>>([]);
final markersInBounds = useRef<List<MapMarker>>([]); final markersInBounds = useRef<List<MapMarker>>([]);
final bottomSheetStreamController = useStreamController<MapEvent>(); final bottomSheetStreamController = useStreamController<MapEvent>();
@ -156,7 +156,7 @@ class MapPage extends HookConsumerWidget {
} }
} }
void onMapCreated(MapLibreMapController controller) async { void onMapCreated(MaplibreMapController controller) async {
mapController.value = controller; mapController.value = controller;
controller.addListener(() { controller.addListener(() {
if (controller.isCameraMoving && selectedMarker.value != null) { if (controller.isCameraMoving && selectedMarker.value != null) {
@ -379,7 +379,7 @@ class _MapWithMarker extends StatelessWidget {
child: Stack( child: Stack(
children: [ children: [
style.widgetWhen( style.widgetWhen(
onData: (style) => MapLibreMap( onData: (style) => MaplibreMap(
initialCameraPosition: initialCameraPosition:
const CameraPosition(target: LatLng(0, 0)), const CameraPosition(target: LatLng(0, 0)),
styleString: style, styleString: style,
@ -393,7 +393,7 @@ class _MapWithMarker extends StatelessWidget {
tiltGesturesEnabled: false, tiltGesturesEnabled: false,
dragEnabled: false, dragEnabled: false,
myLocationEnabled: false, myLocationEnabled: false,
attributionButtonPosition: AttributionButtonPosition.topRight, attributionButtonPosition: AttributionButtonPosition.TopRight,
rotateGesturesEnabled: false, rotateGesturesEnabled: false,
), ),
), ),

View file

@ -24,7 +24,7 @@ class MapLocationPickerPage extends HookConsumerWidget {
@override @override
Widget build(BuildContext context, WidgetRef ref) { Widget build(BuildContext context, WidgetRef ref) {
final selectedLatLng = useValueNotifier<LatLng>(initialLatLng); final selectedLatLng = useValueNotifier<LatLng>(initialLatLng);
final controller = useRef<MapLibreMapController?>(null); final controller = useRef<MaplibreMapController?>(null);
final marker = useRef<Symbol?>(null); final marker = useRef<Symbol?>(null);
Future<void> onStyleLoaded() async { Future<void> onStyleLoaded() async {
@ -74,7 +74,7 @@ class MapLocationPickerPage extends HookConsumerWidget {
bottomRight: Radius.circular(40), bottomRight: Radius.circular(40),
), ),
), ),
child: MapLibreMap( child: MaplibreMap(
initialCameraPosition: initialCameraPosition:
CameraPosition(target: initialLatLng, zoom: 12), CameraPosition(target: initialLatLng, zoom: 12),
styleString: style, styleString: style,

View file

@ -41,7 +41,7 @@ final getAllPlacesProvider =
final curatedContent = assetPlaces final curatedContent = assetPlaces
.map( .map(
(data) => SearchCuratedContent( (data) => SearchCuratedContent(
label: data.exifInfo?.city ?? '', label: data.exifInfo!.city!,
id: data.id, id: data.id,
), ),
) )

View file

@ -41,10 +41,10 @@ class MapThumbnail extends HookConsumerWidget {
@override @override
Widget build(BuildContext context, WidgetRef ref) { Widget build(BuildContext context, WidgetRef ref) {
final offsettedCentre = LatLng(centre.latitude + 0.002, centre.longitude); final offsettedCentre = LatLng(centre.latitude + 0.002, centre.longitude);
final controller = useRef<MapLibreMapController?>(null); final controller = useRef<MaplibreMapController?>(null);
final position = useValueNotifier<Point<num>?>(null); final position = useValueNotifier<Point<num>?>(null);
Future<void> onMapCreated(MapLibreMapController mapController) async { Future<void> onMapCreated(MaplibreMapController mapController) async {
controller.value = mapController; controller.value = mapController;
if (assetMarkerRemoteId != null) { if (assetMarkerRemoteId != null) {
// The iOS impl returns wrong toScreenLocation without the delay // The iOS impl returns wrong toScreenLocation without the delay
@ -73,7 +73,7 @@ class MapThumbnail extends HookConsumerWidget {
alignment: Alignment.center, alignment: Alignment.center,
children: [ children: [
style.widgetWhen( style.widgetWhen(
onData: (style) => MapLibreMap( onData: (style) => MaplibreMap(
initialCameraPosition: initialCameraPosition:
CameraPosition(target: offsettedCentre, zoom: zoom), CameraPosition(target: offsettedCentre, zoom: zoom),
styleString: style, styleString: style,

View file

@ -911,27 +911,30 @@ packages:
maplibre_gl: maplibre_gl:
dependency: "direct main" dependency: "direct main"
description: description:
name: maplibre_gl path: "."
sha256: ea2fa443e7d5dc18db7f37a0f6f5af40642888c56b81a14441aeddea077adaea ref: acb428a005efd9832a0a8e7ef0945f899dfb3ca5
url: "https://pub.dev" resolved-ref: acb428a005efd9832a0a8e7ef0945f899dfb3ca5
source: hosted url: "https://github.com/maplibre/flutter-maplibre-gl.git"
version: "0.20.0" source: git
version: "0.18.0"
maplibre_gl_platform_interface: maplibre_gl_platform_interface:
dependency: transitive dependency: transitive
description: description:
name: maplibre_gl_platform_interface path: maplibre_gl_platform_interface
sha256: "718c3503f36936fbf35c34d6ddf8bf770474c5ba1e6cb1d8caece44efae424af" ref: main
url: "https://pub.dev" resolved-ref: acb428a005efd9832a0a8e7ef0945f899dfb3ca5
source: hosted url: "https://github.com/maplibre/flutter-maplibre-gl.git"
version: "0.20.0" source: git
version: "0.18.0"
maplibre_gl_web: maplibre_gl_web:
dependency: transitive dependency: transitive
description: description:
name: maplibre_gl_web path: maplibre_gl_web
sha256: e7d71b08f24dca70e9c9cf841b096704a677e6239447d87220ec071355768149 ref: main
url: "https://pub.dev" resolved-ref: acb428a005efd9832a0a8e7ef0945f899dfb3ca5
source: hosted url: "https://github.com/maplibre/flutter-maplibre-gl.git"
version: "0.20.0" source: git
version: "0.18.0"
matcher: matcher:
dependency: transitive dependency: transitive
description: description:

View file

@ -28,7 +28,11 @@ dependencies:
video_player: ^2.8.2 video_player: ^2.8.2
chewie: ^1.7.4 chewie: ^1.7.4
socket_io_client: ^2.0.3+1 socket_io_client: ^2.0.3+1
maplibre_gl: ^0.20.0 # TODO: Update it to tag once next stable release
maplibre_gl:
git:
url: https://github.com/maplibre/flutter-maplibre-gl.git
ref: acb428a005efd9832a0a8e7ef0945f899dfb3ca5
geolocator: ^11.0.0 # used to move to current location in map view geolocator: ^11.0.0 # used to move to current location in map view
flutter_udid: ^3.0.0 flutter_udid: ^3.0.0
flutter_svg: ^2.0.9 flutter_svg: ^2.0.9