summaryrefslogtreecommitdiffstats
path: root/lib/Kuksa-server/vehicle_methods.dart
diff options
context:
space:
mode:
authorScott Murray <scott.murray@konsulko.com>2022-12-31 00:34:31 -0500
committerScott Murray <scott.murray@konsulko.com>2022-12-31 06:50:16 +0000
commit9ba227f63a5f83055910b502ca90bb523950c77b (patch)
treee8dc553cf3b9264c4081f1bb76a95dd7be2f5afc /lib/Kuksa-server/vehicle_methods.dart
parent7e9b0b78a48b4fb26996d67a07277f86b69e18ed (diff)
Rework Riverpod provider usage
Replace the single Riverpod provider for all vehicle signals with separate ones for each required signal used directly in the widgets that require them. This is more in line with recommended Riverpod practice, and should avoids driving full widget tree rebuilds on every signal received. Bug-AGL: SPEC-4660 Signed-off-by: Scott Murray <scott.murray@konsulko.com> Change-Id: Ibe1ff26f8cd95cbe9cbb477feaf31c9f4919bf6a
Diffstat (limited to 'lib/Kuksa-server/vehicle_methods.dart')
-rw-r--r--lib/Kuksa-server/vehicle_methods.dart190
1 files changed, 0 insertions, 190 deletions
diff --git a/lib/Kuksa-server/vehicle_methods.dart b/lib/Kuksa-server/vehicle_methods.dart
deleted file mode 100644
index 1a99bc7..0000000
--- a/lib/Kuksa-server/vehicle_methods.dart
+++ /dev/null
@@ -1,190 +0,0 @@
-// SPDX-License-Identifier: Apache-2.0
-import 'dart:convert';
-import 'dart:io';
-
-import 'package:dashboard_app/Kuksa-server/vehicle_provider.dart';
-import 'package:dashboard_app/Kuksa-server/vehicle_server_path.dart';
-import 'package:dashboard_app/config.dart';
-import 'package:flutter_riverpod/flutter_riverpod.dart';
-
-class VISS {
- static const requestId = "test-id";
- static void init(WebSocket socket, WidgetRef ref) {
- authorize(socket,ref);
- subscribe(socket,ref, VSPath.vehicleSpeed);
- subscribe(socket,ref, VSPath.vehicleEngineRPM);
- subscribe(socket,ref, VSPath.vehicleFuelLevel);
- subscribe(socket,ref, VSPath.vehicleFrontLeftTire);
- subscribe(socket, ref,VSPath.vehicleFrontRightTire);
- subscribe(socket, ref,VSPath.vehicleRearLeftTire);
- subscribe(socket,ref, VSPath.vehicleRearRightTire);
- subscribe(socket, ref,VSPath.vehicleIsChildLockActiveLeft);
- subscribe(socket,ref, VSPath.vehicleIsChildLockActiveRight);
- subscribe(socket,ref, VSPath.vehicleCurrentLatitude);
- subscribe(socket,ref, VSPath.vehicleCurrentLongitude);
- subscribe(socket,ref, VSPath.vehicleFuelRate);
- subscribe(socket,ref, VSPath.vehicleInsideTemperature);
- subscribe(socket, ref,VSPath.vehicleAmbientAirTemperature);
- }
-
- static void update(WebSocket socket, WidgetRef ref) {
- get(socket,ref, VSPath.vehicleSpeed);
- get(socket,ref, VSPath.vehicleEngineRPM);
- get(socket,ref, VSPath.vehicleFuelLevel);
- get(socket,ref,VSPath.vehicleAmbientAirTemperature);
- get(socket,ref,VSPath.vehicleFrontLeftTire);
- get(socket,ref, VSPath.vehicleFrontRightTire);
- get(socket,ref, VSPath.vehicleRearLeftTire);
- get(socket,ref, VSPath.vehicleRearRightTire);
- get(socket,ref,VSPath.vehicleIsChildLockActiveLeft);
- get(socket,ref, VSPath.vehicleIsChildLockActiveRight);
- get(socket,ref,VSPath.vehicleCurrentLatitude);
- get(socket,ref,VSPath.vehicleCurrentLongitude);
- get(socket,ref,VSPath.vehicleFuelRate);
- get(socket,ref, VSPath.vehicleInsideTemperature);
- }
-
- static void authorize(WebSocket socket,WidgetRef ref) {
- final config = ref.read(ConfigStateprovider);
-
- Map<String, dynamic> map = {
- "action": "authorize",
- "tokens": config.kuksaAuthToken,
- "requestId": requestId
- };
- socket.add(jsonEncode(map));
- }
-
- static void get(WebSocket socket,WidgetRef ref, String path) {
- final config = ref.read(ConfigStateprovider);
-
- Map<String, dynamic> map = {
- "action": "get",
- "tokens": config.kuksaAuthToken,
- "path": path,
- "requestId": requestId
- };
- socket.add(jsonEncode(map));
- }
-
- static void set(WebSocket socket, WidgetRef ref,String path, String value) {
- final config = ref.read(ConfigStateprovider);
- Map<String, dynamic> map = {
- "action": "set",
- "tokens": config.kuksaAuthToken,
- "path": path,
- "requestId": requestId,
- "value": value
- };
- socket.add(jsonEncode(map));
- }
-
- static void subscribe(WebSocket socket,WidgetRef ref, String path) {
- final config = ref.read(ConfigStateprovider);
-
- Map<String, dynamic> map = {
- "action": "subscribe",
- "tokens": config.kuksaAuthToken,
- "path": path,
- "requestId": requestId
- };
- socket.add(jsonEncode(map));
- }
-
- static String? numToGear(int? number) {
- switch (number) {
- case -1:
- return 'R';
- case 0:
- return 'N';
- case 126:
- return 'P';
- case 127:
- return 'D';
- default:
- return null;
- }
- }
-
- static void parseData(WidgetRef ref, String data) {
- final vehicleSignal = ref.read(vehicleSignalProvider.notifier);
- Map<String, dynamic> dataMap = jsonDecode(data);
- if (dataMap["action"] == "subscription" || dataMap["action"] == "get") {
- if (dataMap.containsKey("data")) {
- if ((dataMap["data"] as Map<String, dynamic>).containsKey("dp") &&
- (dataMap["data"] as Map<String, dynamic>).containsKey("path")) {
- String path = dataMap["data"]["path"];
- Map<String, dynamic> dp = dataMap["data"]["dp"];
- if (dp.containsKey("value")) {
- if (dp["value"] != "---") {
- switch (path) {
- case VSPath.vehicleSpeed:
- vehicleSignal.update(speed: dp["value"]);
- break;
- case VSPath.vehicleEngineRPM:
- vehicleSignal.update(rpm: dp["value"].toDouble());
- break;
- case VSPath.vehicleFuelLevel:
- vehicleSignal.update(fuelLevel: dp["value"]);
- break;
- case VSPath.vehicleFrontLeftTire:
- vehicleSignal.update(frontLeftTP: dp["value"]);
- break;
- case VSPath.vehicleFrontRightTire:
- vehicleSignal.update(frontRightTP: dp["value"]);
- break;
- case VSPath.vehicleRearLeftTire:
- vehicleSignal.update(rearLeftTP: dp["value"]);
- break;
- case VSPath.vehicleRearRightTire:
- vehicleSignal.update(rearRightTP: dp["value"]);
- break;
-
-
- case VSPath.vehicleIsChildLockActiveLeft:
- vehicleSignal.update(isChildLockActiveLeft: dp['value']);
- break;
- case VSPath.vehicleIsChildLockActiveRight:
- vehicleSignal.update(isChildLockActiveRight: dp['value']);
- break;
- case VSPath.vehicleCurrentLatitude:
- vehicleSignal.update(
- currentLatitude: dp["value"]);
- break;
- case VSPath.vehicleCurrentLongitude:
- vehicleSignal.update(
- currentLongitude: dp["value"]);
- break;
- case VSPath.vehicleFuelRate:
- vehicleSignal.update(fuelRate: dp["value"]);
- break;
- case VSPath.vehicleInsideTemperature:
- vehicleSignal.update(
- insideTemperature: int.parse(dp["value"]));
- break;
- case VSPath.vehicleAmbientAirTemperature:
- vehicleSignal.update(
- outsideTemperature: int.parse(dp["value"]));
- break;
- default:
- print("$path Not Available yet!");
- }
- } else {
- print("ERROR:Value not available yet! Set Value of $path");
- }
- } else {
- print("ERROR:'value': Key not found!");
- }
- } else if ((!dataMap["data"] as Map<String, dynamic>)
- .containsKey("path")) {
- print("ERROR:'path':key not found !");
- } else if ((dataMap["data"] as Map<String, dynamic>)
- .containsKey("dp")) {
- print("ERROR:'dp':key not found !");
- }
- } else {
- print("ERROR:'data':key not found!");
- }
- }
- }
-}