From df80137f46b67475707387e49beea79f11aa05fc Mon Sep 17 00:00:00 2001 From: Valentin CZERYBA Date: Mon, 21 Oct 2024 22:29:02 +0200 Subject: [PATCH] add organizers item list --- covas_mobile/lib/pages/ItemMenu.dart | 8 ++ .../lib/pages/ListItemByOrganizers.dart | 123 ++++++++++++++++++ 2 files changed, 131 insertions(+) create mode 100644 covas_mobile/lib/pages/ListItemByOrganizers.dart diff --git a/covas_mobile/lib/pages/ItemMenu.dart b/covas_mobile/lib/pages/ItemMenu.dart index 5d93215..6e9f417 100644 --- a/covas_mobile/lib/pages/ItemMenu.dart +++ b/covas_mobile/lib/pages/ItemMenu.dart @@ -17,6 +17,7 @@ import '../classes/events.dart'; import 'ListItemMenu.dart'; import 'ListItemByTags.dart'; +import 'ListItemByOrganizers.dart'; void main() { initializeDateFormatting("fr_FR", null).then((_) => (const MyApp())); @@ -280,6 +281,13 @@ class _ItemMenuState extends State with ShowErrorDialog { mainAxisSize: MainAxisSize.min, children: [ InkWell( + onTap: () { + Navigator.push( + context, + MaterialPageRoute( + builder: (_) => ListItemOrganizers( + organizer: '$tag'))); + }, child: Text( '$tag', style: const TextStyle(color: Colors.white), diff --git a/covas_mobile/lib/pages/ListItemByOrganizers.dart b/covas_mobile/lib/pages/ListItemByOrganizers.dart new file mode 100644 index 0000000..8a78c62 --- /dev/null +++ b/covas_mobile/lib/pages/ListItemByOrganizers.dart @@ -0,0 +1,123 @@ +import 'dart:convert'; +import 'dart:io'; +import "ItemMenu.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 '../variable/globals.dart' as globals; + +// app starting point +void main() { + initializeDateFormatting("fr_FR", null).then((_) => (const MyApp())); +} + +class MyApp extends StatelessWidget { + const MyApp({Key? key}) : super(key: key); + + @override + Widget build(BuildContext context) { + return MaterialApp( + home: const ListItemOrganizers(organizer: "default"), + debugShowCheckedModeBanner: false, + ); + } +} + +// homepage class +class ListItemOrganizers extends StatefulWidget { + const ListItemOrganizers({Key? key, required this.organizer}) + : super(key: key); + + final String organizer; + @override + State createState() => _MyHomePageState(); +} + +// homepage state +class _MyHomePageState extends State { + // variable to call and store future list of posts + + // function to fetch data from api and return future list of posts + static Future> getPosts(organizer) 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?organizers=${organizer}"); + 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; + } + + // build function + @override + Widget build(BuildContext context) { + return Scaffold( + body: Center( + // FutureBuilder + child: FutureBuilder>( + future: getPosts(widget.organizer), + 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("Organisateur : ${widget.organizer}"), + 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(); + }, + ), + ); + } +}