import 'dart:async'; import 'dart:math'; import 'package:desktopapp/classes/routes.dart'; import 'package:desktopapp/classes/stream_element.dart'; import 'package:desktopapp/utils/mailer.dart'; import 'package:desktopapp/widgets/components/stream_element_card.dart'; import 'package:desktopapp/widgets/forms/email_form.dart'; import 'package:flutter/material.dart'; import 'package:shared_preferences/shared_preferences.dart'; class HomePage extends StatefulWidget { const HomePage({Key? key}) : super(key: key); @override _HomePageState createState() => _HomePageState(); } class _HomePageState extends State { bool connected = false; List streamElements = []; final StreamController controller = StreamController(); final ScrollController _scrollController = ScrollController(); Widget buildContent(BuildContext context, SharedPreferences prefs) { return Column(children: [ if (!connected) Row(mainAxisAlignment: MainAxisAlignment.spaceAround, children: [ EmailForm( prefs: prefs, onValid: (String email, String password) async { var value = await Mailer.connect( context: context, email: email, password: password, streamController: controller); setState(() { connected = value; }); }), TextButton( onPressed: () async { Navigator.of(context).pushNamed(Routes.mailSettings.path); }, child: const Text('Paramètres')), ]), if (connected) Row( children: [ TextButton( onPressed: () async { await Mailer.disconnect(streamController: controller); setState(() { connected = false; }); }, child: const Text('Se déconnecter')), ], ), Expanded( child: StreamBuilder( stream: controller.stream, builder: (BuildContext context, AsyncSnapshot snapshot) { switch (snapshot.connectionState) { case ConnectionState.none: return const Text('Nothing'); case ConnectionState.waiting: return const Center(child: CircularProgressIndicator()); case ConnectionState.active: if (snapshot.hasData) { int skipNumber = max(0, streamElements.length - 10); bool alreadyAdded = streamElements .skip(skipNumber) .cast() .firstWhere( (element) => element!.uuid == snapshot.data!.uuid, orElse: () => null) != null; if (!alreadyAdded) { streamElements.add(snapshot.data!); } } return ListView.builder( itemCount: streamElements.length, controller: _scrollController, itemBuilder: (BuildContext context, int index) { if (_scrollController.position.maxScrollExtent - _scrollController.offset < 10) { WidgetsBinding.instance! .addPostFrameCallback((timeStamp) { _scrollController.animateTo( _scrollController.position.maxScrollExtent, duration: const Duration(milliseconds: 500), curve: Curves.easeOut); }); } return StreamElementCard( streamElement: streamElements[index]); }, ); case ConnectionState.done: return const Text('Terminate'); } }, ), ) ]); } @override Widget build(BuildContext context) { return Scaffold( body: FutureBuilder( future: SharedPreferences.getInstance(), builder: (BuildContext context, AsyncSnapshot snapshot) { if (snapshot.hasData) { final prefs = snapshot.data!; Future(() async { if (!prefs.containsKey('credentials.access_token')) { Navigator.of(context) .pushReplacementNamed(Routes.streamlabsTutorial.path); } }); return buildContent(context, prefs); } else { return const Center(child: CircularProgressIndicator()); } })); } }