import 'dart:convert'; import 'dart:io'; import "ItemMenu.dart"; import "Camera.dart"; import 'package:http/http.dart' as http; import 'package:flutter/material.dart'; import '../classes/events.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'package:intl/intl.dart'; import 'package:intl/date_symbol_data_local.dart'; import 'package:camera/camera.dart'; import '../variable/globals.dart' as globals; // app starting point void main() { initializeDateFormatting("fr_FR", null).then((_) => (const MyApp())); } class MyApp extends StatelessWidget { const MyApp({super.key}); @override Widget build(BuildContext context) { return MaterialApp( home: const ListItemMenu(), debugShowCheckedModeBanner: false, ); } } // homepage class class ListItemMenu extends StatefulWidget { const ListItemMenu({super.key}); @override State createState() => _MyHomePageState(); } // homepage state class _MyHomePageState extends State { // variable to call and store future list of posts Future> postsFuture = getPosts(); // function to fetch data from api and return future list of posts static Future> getPosts() async { SharedPreferences prefs = await SharedPreferences.getInstance(); var accessToken = prefs.getString("access_token") ?? ""; final List body = []; if (accessToken.isNotEmpty) { var url = Uri.parse("${globals.api}/events"); final response = await http.get(url, headers: { "Content-Type": "application/json", HttpHeaders.cookieHeader: "access_token=${accessToken}" }); final List body = json.decode(utf8.decode(response.bodyBytes)); return body.map((e) => Events.fromJson(e)).toList(); } return body; } Future popCamera() async { await availableCameras().then((value) => Navigator.push(context, MaterialPageRoute(builder: (_) => Camera(camera: value.first)))); } // build function @override Widget build(BuildContext context) { return Scaffold( body: Center( // FutureBuilder child: FutureBuilder>( future: postsFuture, builder: (context, snapshot) { if (snapshot.connectionState == ConnectionState.waiting) { // until data is fetched, show loader return const CircularProgressIndicator(); } else if (snapshot.hasData) { // once data is fetched, display it on screen (call buildPosts()) final posts = snapshot.data!; return buildPosts(posts); } else { // if no data, show simple Text return const Text("No data available"); } }, ), ), ); } // function to display fetched data on screen Widget buildPosts(List posts) { // ListView Builder to show data in a list return Scaffold( appBar: AppBar( // Here we take the value from the MyHomePage object that was created by // the App.build method, and use it to set our appbar title. title: Text("Item list menu"), backgroundColor: Colors.blue, foregroundColor: Colors.white, ), body: ListView.separated( itemCount: posts.length, itemBuilder: (context, index) { final post = posts[index]; final startDate = DateTime.parse(post.startDate!); final date = DateFormat.yMd().format(startDate); final time = DateFormat.Hm().format(startDate); return ListTile( title: Text('${post.name!}'), subtitle: Text('${post.place!}\n${date} ${time}'), onTap: () { Navigator.push( context, MaterialPageRoute( builder: (_) => ItemMenu(title: post.id!))); }); }, separatorBuilder: (context, index) { return Divider(); }, ), floatingActionButton: FloatingActionButton( onPressed: popCamera, backgroundColor: Colors.blue, tooltip: 'Recherche', child: const Icon(Icons.search, color: Colors.white), ), ); } }