202 lines
5.9 KiB
Dart
Raw Normal View History

2024-11-11 14:48:23 +01:00
import 'dart:convert';
2024-11-13 23:47:40 +01:00
import 'dart:typed_data';
2024-11-11 14:48:23 +01:00
import 'dart:io';
2024-11-13 23:47:40 +01:00
import 'package:flutter/services.dart'; // For loading assets
2024-11-11 14:48:23 +01:00
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'package:mapbox_gl/mapbox_gl.dart';
import 'package:flutter_dotenv/flutter_dotenv.dart'; // Import dotenv
import '../classes/alert.dart'; // Assuming this contains your error dialog code.
import '../classes/events.dart'; // Your Event class, assuming you are using it.
import '../variable/globals.dart' as globals;
2024-11-15 23:22:17 +01:00
import 'package:shared_preferences/shared_preferences.dart';
2024-11-11 14:48:23 +01:00
void main() async {
await dotenv.load(fileName: ".env"); // Load .env file
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
2024-11-15 23:22:17 +01:00
home: const Mapboxpages(title: 'Event Location', place: "Flutter"),
2024-11-11 14:48:23 +01:00
);
}
}
class Mapboxpages extends StatefulWidget {
2024-11-15 23:22:17 +01:00
const Mapboxpages({Key? key, required this.title, required this.place})
: super(key: key);
2024-11-11 14:48:23 +01:00
final String title;
2024-11-15 23:22:17 +01:00
final String place;
2024-11-11 14:48:23 +01:00
@override
State<Mapboxpages> createState() => _MapboxpagesState();
}
class _MapboxpagesState extends State<Mapboxpages> with ShowErrorDialog {
late String mapboxAccessToken;
2024-11-15 22:48:05 +01:00
late MapboxMapController mapController; // Mark mapController as nullable
2024-11-11 14:48:23 +01:00
double longitude = 0.0;
double latitude = 0.0;
bool isLoading = true;
@override
void initState() {
super.initState();
_initToken();
2024-11-15 23:22:17 +01:00
_getEventInfo();
2024-11-11 14:48:23 +01:00
}
// Load the Mapbox access token from the .env file
2024-11-15 23:22:17 +01:00
void _initToken() {
2024-11-11 14:48:23 +01:00
mapboxAccessToken = dotenv.env['MAPBOX_ACCESS_TOKEN'] ?? '';
if (mapboxAccessToken.isEmpty) {
showErrorDialog(context, "Mapbox Access Token is not available.");
return;
}
}
2024-11-15 23:22:17 +01:00
Future<void> _getEventInfo() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
var accessToken = prefs.getString("access_token") ?? "";
if (accessToken.isNotEmpty) {
var urlGet = Uri.parse("${globals.api}/events/${widget.title}");
var responseGet = await http.get(urlGet,
headers: {HttpHeaders.cookieHeader: 'access_token=${accessToken}'});
stderr.writeln('Response Get status: ${responseGet.statusCode}');
if (responseGet.statusCode == 200) {
var events = jsonDecode(utf8.decode(responseGet.bodyBytes));
latitude = events["latitude"];
longitude = events["longitude"];
setState(() {
isLoading = false;
});
2024-11-11 14:48:23 +01:00
} else {
2024-11-15 23:22:17 +01:00
var text = "";
switch (responseGet.statusCode) {
case 400:
{
text = "Requête mal construite";
}
break;
case 406:
{
text = "Mot de passe incorrect";
}
break;
case 404:
{
text = "Utilisateur inconnu";
}
break;
case 403:
{
text = "Vous n'avez pas l'autorisation de faire cette action";
}
break;
case 410:
{
text = "Token invalide";
}
break;
case 500:
{
text = "Probleme interne du serveur";
}
break;
default:
{
text = "Probleme d'authentification inconnu";
}
break;
}
showErrorDialog(context, text);
2024-11-11 14:48:23 +01:00
}
2024-11-15 23:22:17 +01:00
} else {
showErrorDialog(context, "Cache invalide");
2024-11-11 14:48:23 +01:00
}
}
2024-11-13 23:47:40 +01:00
// Load image from assets as Uint8List
Future<Uint8List> _loadMarkerImage() async {
final ByteData data = await rootBundle.load('images/marker.png');
return data.buffer.asUint8List();
}
2024-11-15 22:48:05 +01:00
void _onMapCreated(MapboxMapController controller) {
2024-11-11 14:48:23 +01:00
mapController = controller;
2024-11-15 22:48:05 +01:00
}
2024-11-11 14:48:23 +01:00
2024-11-15 22:48:05 +01:00
// Called when the map is created
void _onStyleLoaded() async {
2024-11-11 14:48:23 +01:00
// Log the map controller and coordinates
print("Mapbox controller initialized: $mapController");
print("lat - long : $latitude - $longitude");
// Check if the mapController is really initialized
if (mapController != null) {
try {
2024-11-13 23:47:40 +01:00
// Ensure the coordinates are valid
if (latitude != 0.0 && longitude != 0.0) {
// Load marker image as Uint8List
final markerImage = await _loadMarkerImage();
// Register the image with Mapbox
await mapController!.addImage("custom-marker", markerImage);
final symbolOptions = SymbolOptions(
geometry: LatLng(latitude, longitude),
iconImage: "custom-marker", // Use the registered custom marker
iconSize: 0.5, // Optional: Adjust size
);
// Debugging symbol options
print("Adding symbol with options: $symbolOptions");
// Add symbol to map
mapController!.addSymbol(symbolOptions);
} else {
print("Error: Invalid coordinates, cannot add symbol.");
}
2024-11-11 14:48:23 +01:00
} catch (e) {
// Handle any exception that occurs when adding the symbol
print("Error when adding symbol: $e");
}
} else {
print(
"Error: MapboxMapController is null at the time of symbol addition");
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
2024-11-15 23:22:17 +01:00
appBar: AppBar(title: Text(widget.place)),
2024-11-11 14:48:23 +01:00
body: isLoading
? Center(child: CircularProgressIndicator())
: MapboxMap(
accessToken: mapboxAccessToken, // Your Mapbox API key
onMapCreated: _onMapCreated,
2024-11-15 22:48:05 +01:00
onStyleLoadedCallback: _onStyleLoaded,
2024-11-11 14:48:23 +01:00
initialCameraPosition: CameraPosition(
target: LatLng(latitude, longitude),
zoom: 14.0,
),
),
);
}
}