1
0
Fork 0
mrtiboute/lib/widgets/pages/home.dart

128 lines
4.5 KiB
Dart
Raw Normal View History

2022-04-14 21:57:32 +02:00
import 'dart:async';
import 'dart:math';
2022-03-31 22:04:57 +02:00
import 'package:desktopapp/classes/routes.dart';
2022-04-14 21:57:32 +02:00
import 'package:desktopapp/classes/stream_element.dart';
2022-04-12 22:28:30 +02:00
import 'package:desktopapp/utils/mailer.dart';
2022-04-14 21:57:32 +02:00
import 'package:desktopapp/widgets/components/stream_element_card.dart';
import 'package:desktopapp/widgets/forms/email_form.dart';
2022-03-31 21:34:28 +02:00
import 'package:flutter/material.dart';
2022-03-31 22:04:57 +02:00
import 'package:shared_preferences/shared_preferences.dart';
2022-03-31 21:34:28 +02:00
2022-04-14 21:57:32 +02:00
class HomePage extends StatefulWidget {
2022-03-31 21:34:28 +02:00
const HomePage({Key? key}) : super(key: key);
2022-04-14 21:57:32 +02:00
@override
_HomePageState createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> {
bool connected = false;
List<StreamElement> streamElements = [];
final StreamController<StreamElement> controller =
StreamController<StreamElement>();
2022-04-26 21:28:49 +02:00
final ScrollController _scrollController = ScrollController();
2022-03-31 22:04:57 +02:00
Widget buildContent(BuildContext context, SharedPreferences prefs) {
return Column(children: [
2022-04-14 21:57:32 +02:00
if (!connected)
Row(mainAxisAlignment: MainAxisAlignment.center, children: [
EmailForm(
prefs: prefs,
onValid: (String email, String password) async {
var value = await Mailer.connect(
2022-04-26 21:28:49 +02:00
context: context,
2022-04-14 21:57:32 +02:00
email: email,
password: password,
streamController: controller);
setState(() {
connected = value;
});
})
]),
if (connected)
Row(
children: [
TextButton(
onPressed: () async {
2022-04-14 22:48:15 +02:00
await Mailer.disconnect(streamController: controller);
2022-04-14 21:57:32 +02:00
setState(() {
connected = false;
});
},
child: const Text('Se déconnecter')),
],
),
Expanded(
child: StreamBuilder<StreamElement>(
stream: controller.stream,
builder:
(BuildContext context, AsyncSnapshot<StreamElement> 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<StreamElement?>()
.firstWhere(
(element) => element!.uuid == snapshot.data!.uuid,
orElse: () => null) !=
null;
2022-04-26 21:38:26 +02:00
if (!alreadyAdded) {
streamElements.add(snapshot.data!);
}
2022-04-14 21:57:32 +02:00
}
return ListView.builder(
itemCount: streamElements.length,
2022-04-26 21:28:49 +02:00
controller: _scrollController,
2022-04-14 21:57:32 +02:00
itemBuilder: (BuildContext context, int index) {
2022-04-26 21:38:26 +02:00
WidgetsBinding.instance!.addPostFrameCallback((timeStamp) {
_scrollController.animateTo(
_scrollController.position.maxScrollExtent,
duration: const Duration(milliseconds: 500),
curve: Curves.easeOut);
});
2022-04-14 21:57:32 +02:00
return StreamElementCard(
streamElement: streamElements[index]);
},
);
case ConnectionState.done:
return const Text('Terminate');
2022-03-31 22:04:57 +02:00
}
},
2022-04-14 21:57:32 +02:00
),
)
2022-03-31 22:04:57 +02:00
]);
}
2022-03-31 21:34:28 +02:00
@override
Widget build(BuildContext context) {
2022-03-31 22:04:57 +02:00
return Scaffold(
body: FutureBuilder(
future: SharedPreferences.getInstance(),
builder: (BuildContext context,
AsyncSnapshot<SharedPreferences> snapshot) {
if (snapshot.hasData) {
final prefs = snapshot.data!;
Future(() async {
if (!prefs.containsKey('credentials.access_token')) {
Navigator.of(context)
.pushReplacementNamed(Routes.streamlabsTutorial.path);
}
});
2022-04-14 21:57:32 +02:00
return buildContent(context, prefs);
2022-03-31 22:04:57 +02:00
} else {
return const Center(child: CircularProgressIndicator());
}
}));
2022-03-31 21:34:28 +02:00
}
}