mirror of
https://github.com/immich-app/immich.git
synced 2025-11-19 14:12:35 +09:00
Some checks failed
CodeQL / Analyze (javascript) (push) Has been cancelled
CodeQL / Analyze (python) (push) Has been cancelled
Docker / pre-job (push) Has been cancelled
Docs build / pre-job (push) Has been cancelled
Static Code Analysis / pre-job (push) Has been cancelled
Static Code Analysis / zizmor (push) Has been cancelled
Test / pre-job (push) Has been cancelled
Test / ShellCheck (push) Has been cancelled
Test / OpenAPI Clients (push) Has been cancelled
Test / SQL Schema Checks (push) Has been cancelled
Docker / Re-Tag ML () (push) Has been cancelled
Docker / Re-Tag ML (-armnn) (push) Has been cancelled
Docker / Re-Tag ML (-cuda) (push) Has been cancelled
Docker / Re-Tag ML (-openvino) (push) Has been cancelled
Docker / Re-Tag ML (-rknn) (push) Has been cancelled
Docker / Re-Tag ML (-rocm) (push) Has been cancelled
Docker / Re-Tag Server () (push) Has been cancelled
Docker / Build and Push ML (armnn, linux/arm64, -armnn) (push) Has been cancelled
Docker / Build and Push ML (cpu, ) (push) Has been cancelled
Docker / Build and Push ML (cuda, linux/amd64, -cuda) (push) Has been cancelled
Docker / Build and Push ML (openvino, linux/amd64, -openvino) (push) Has been cancelled
Docker / Build and Push ML (rknn, linux/arm64, -rknn) (push) Has been cancelled
Docker / Build and Push ML (rocm, linux/amd64, {"linux/amd64": "mich"}, -rocm) (push) Has been cancelled
Docker / Build and Push Server (push) Has been cancelled
Docker / Docker Build & Push Server Success (push) Has been cancelled
Docker / Docker Build & Push ML Success (push) Has been cancelled
Docs build / Docs Build (push) Has been cancelled
Static Code Analysis / Run Dart Code Analysis (push) Has been cancelled
Test / Test & Lint Server (push) Has been cancelled
Test / Unit Test CLI (push) Has been cancelled
Test / Unit Test CLI (Windows) (push) Has been cancelled
Test / Lint Web (push) Has been cancelled
Test / Test Web (push) Has been cancelled
Test / Test i18n (push) Has been cancelled
Test / End-to-End Lint (push) Has been cancelled
Test / Medium Tests (Server) (push) Has been cancelled
Test / End-to-End Tests (Server & CLI) (ubuntu-24.04-arm) (push) Has been cancelled
Test / End-to-End Tests (Server & CLI) (ubuntu-latest) (push) Has been cancelled
Test / End-to-End Tests (Web) (ubuntu-24.04-arm) (push) Has been cancelled
Test / End-to-End Tests (Web) (ubuntu-latest) (push) Has been cancelled
Test / End-to-End Tests Success (push) Has been cancelled
Test / Unit Test Mobile (push) Has been cancelled
Test / Unit Test ML (push) Has been cancelled
Test / .github Files Formatting (push) Has been cancelled
* enable border radius, switch exp, const constructor * regenerate provider * more formatting --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
143 lines
4.2 KiB
Dart
143 lines
4.2 KiB
Dart
import 'package:easy_localization/easy_localization.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:immich_mobile/models/map/map_marker.model.dart';
|
|
import 'package:immich_mobile/widgets/common/confirm_dialog.dart';
|
|
import 'package:geolocator/geolocator.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:maplibre_gl/maplibre_gl.dart';
|
|
|
|
class MapUtils {
|
|
const 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(103,58,183,0.0)",
|
|
0.3,
|
|
"rgb(103,58,183)",
|
|
0.5,
|
|
"rgb(33,149,243)",
|
|
0.7,
|
|
"rgb(76,175,79)",
|
|
0.95,
|
|
"rgb(255,235,59)",
|
|
1.0,
|
|
"rgb(255,86,34)",
|
|
],
|
|
heatmapIntensity: [
|
|
Expressions.interpolate, ["linear"], //
|
|
[Expressions.zoom],
|
|
0, 0.5,
|
|
9, 2,
|
|
],
|
|
heatmapRadius: [
|
|
Expressions.interpolate, ["linear"], //
|
|
[Expressions.zoom],
|
|
0, 4,
|
|
4, 8,
|
|
9, 16,
|
|
],
|
|
heatmapOpacity: 0.7,
|
|
);
|
|
|
|
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({
|
|
required BuildContext context,
|
|
bool silent = false,
|
|
}) async {
|
|
try {
|
|
bool serviceEnabled = await Geolocator.isLocationServiceEnabled();
|
|
if (!serviceEnabled && !silent) {
|
|
showDialog(
|
|
context: context,
|
|
builder: (context) => _LocationServiceDisabledDialog(),
|
|
);
|
|
return (null, LocationPermission.deniedForever);
|
|
}
|
|
|
|
LocationPermission permission = await Geolocator.checkPermission();
|
|
bool shouldRequestPermission = false;
|
|
|
|
if (permission == LocationPermission.denied && !silent) {
|
|
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 &&
|
|
!silent) {
|
|
await Geolocator.openAppSettings();
|
|
}
|
|
return (null, LocationPermission.deniedForever);
|
|
}
|
|
|
|
Position currentUserLocation = await Geolocator.getCurrentPosition(
|
|
locationSettings: const LocationSettings(
|
|
accuracy: LocationAccuracy.high,
|
|
distanceFilter: 0,
|
|
timeLimit: Duration(seconds: 5),
|
|
),
|
|
);
|
|
return (currentUserLocation, null);
|
|
} catch (error, stack) {
|
|
_log.severe("Cannot get user's current location", error, stack);
|
|
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: 'cancel'.tr(),
|
|
ok: '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: 'cancel'.tr(),
|
|
ok: 'yes'.tr(),
|
|
onOk: () {},
|
|
);
|
|
}
|