summaryrefslogtreecommitdiffstats
path: root/lib/vehicle-signals/viss_connected_widget.dart
diff options
context:
space:
mode:
Diffstat (limited to 'lib/vehicle-signals/viss_connected_widget.dart')
-rw-r--r--lib/vehicle-signals/viss_connected_widget.dart65
1 files changed, 65 insertions, 0 deletions
diff --git a/lib/vehicle-signals/viss_connected_widget.dart b/lib/vehicle-signals/viss_connected_widget.dart
new file mode 100644
index 0000000..dd3e4aa
--- /dev/null
+++ b/lib/vehicle-signals/viss_connected_widget.dart
@@ -0,0 +1,65 @@
+// SPDX-License-Identifier: Apache-2.0
+import 'dart:async';
+import 'dart:io';
+
+import 'package:flutter_homescreen/vehicle-signals/viss_config.dart';
+import 'package:flutter_homescreen/vehicle-signals/viss_methods.dart';
+import 'package:flutter/material.dart';
+import 'package:flutter_riverpod/flutter_riverpod.dart';
+import 'package:flutter_homescreen/vehicle-signals/vss_providers.dart';
+
+class VISServerConnectedWidget extends ConsumerStatefulWidget {
+ const VISServerConnectedWidget(
+ {Key? key, required this.client, required this.socket})
+ : super(key: key);
+ final WebSocket socket;
+ final HttpClient client;
+
+ @override
+ ConsumerState<VISServerConnectedWidget> createState() =>
+ _VISServerConnectedWidgetState();
+}
+
+class _VISServerConnectedWidgetState
+ extends ConsumerState<VISServerConnectedWidget> {
+ late Timer _timer;
+
+ void _updateSocket() {
+ ref.read(VISServerSocketProvider.notifier).update(widget.socket);
+ }
+
+ @override
+ void initState() {
+ super.initState();
+ VISS.init(widget.socket, ref);
+ Future.delayed(Duration.zero, () => _updateSocket());
+ _timer = Timer.periodic(const Duration(seconds: 2), (timer) {
+ if (widget.socket.readyState == 3) {
+ ref.refresh(sockConnectprovider(widget.client));
+ }
+ });
+ WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
+ widget.socket.listen(
+ (data) {
+ VISS.parseData(ref, data);
+ },
+ onError: (e, stk) {
+ print(e.toString());
+ ref.refresh(sockConnectprovider(widget.client));
+ },
+ );
+ });
+ }
+
+ @override
+ void dispose() {
+ super.dispose();
+ _timer.cancel();
+ widget.socket.close(786887, "Connection lost with server!");
+ }
+
+ @override
+ Widget build(BuildContext context) {
+ return Container();
+ }
+}