132 lines
4.7 KiB
Dart
132 lines
4.7 KiB
Dart
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<HomePage> {
|
|
bool connected = false;
|
|
List<StreamElement> streamElements = [];
|
|
final StreamController<StreamElement> controller =
|
|
StreamController<StreamElement>();
|
|
|
|
final ScrollController _scrollController = ScrollController();
|
|
|
|
Widget buildContent(BuildContext context, SharedPreferences prefs) {
|
|
return Column(children: [
|
|
if (!connected)
|
|
Row(mainAxisAlignment: MainAxisAlignment.center, 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;
|
|
});
|
|
})
|
|
]),
|
|
if (connected)
|
|
Row(
|
|
children: [
|
|
TextButton(
|
|
onPressed: () async {
|
|
await Mailer.disconnect(streamController: controller);
|
|
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;
|
|
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<SharedPreferences> 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());
|
|
}
|
|
}));
|
|
}
|
|
}
|