summaryrefslogtreecommitdiffstats
path: root/lib/homescreen.dart
diff options
context:
space:
mode:
authorScott Murray <scott.murray@konsulko.com>2022-12-28 15:05:26 -0500
committerScott Murray <scott.murray@konsulko.com>2022-12-29 06:35:38 +0000
commit4fbd3fdb9e01c197d972b78961f0d033534a5cc7 (patch)
treedef7bfc0d0f11746006439b33019b61dfc16e1b8 /lib/homescreen.dart
parente21709c9601209e26d09dea0a45e37f0636bb605 (diff)
Add volume control to bottom panel
Changes: - Import a reworked version of the KUKSA.val client code from the Flutter dashboard app, with the aggregated signal Riverpod provider replaced with per-signal providers for the signal the homescreen needs and a couple of temperature ones it might use. Using separate providers is more in-line with recommended Riverpod best practices. - Various tweaks to enable using Riverpod. - Split the bottom panel out into its own widget, and add a stack in it to layer the default logo panel with the volume control slider, which has been added as a new widget definition to provide the hook to drive timer based lowering behavior like the Qt homescreen does. - The KUKSA.val connection widget has been added to the bottom panel rather than overriding the top-level widget as in the dashboard and HVAC apps. This seems preferable with respect to still providing some functionality in the event KUKSA.val is unavailable. - Remove the old demo dashboard and HVAC pages that are now unused, along with the image assets they needed, to allow cleaning up pubspec.yaml and ease maintenance. Bug-AGL: SPEC-4659 Signed-off-by: Scott Murray <scott.murray@konsulko.com> Change-Id: I5d9180a3461948a58321564e71134c4961ce0ef7
Diffstat (limited to 'lib/homescreen.dart')
-rw-r--r--lib/homescreen.dart125
1 files changed, 60 insertions, 65 deletions
diff --git a/lib/homescreen.dart b/lib/homescreen.dart
index d666bd3..7501292 100644
--- a/lib/homescreen.dart
+++ b/lib/homescreen.dart
@@ -1,17 +1,18 @@
+import 'dart:io';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
-import 'package:provider/provider.dart';
+import 'package:flutter_homescreen/config.dart';
import 'package:grpc/grpc.dart';
-import 'package:jovial_svg/jovial_svg.dart';
import 'package:flutter_homescreen/generated/applauncher.pbgrpc.dart';
-import 'package:flutter_homescreen/homescreen_model.dart';
import 'package:flutter_homescreen/page_apps.dart';
import 'package:flutter_homescreen/widget_clock.dart';
+import 'package:flutter_homescreen/bottom_panel.dart';
enum PageIndex { home, dashboard, hvac, media }
class Homescreen extends StatefulWidget {
- Homescreen({Key? key}) : super(key: key);
+ Homescreen({Key? key, required this.client}) : super(key: key);
+ final HttpClient client;
@override
_HomescreenState createState() => _HomescreenState();
@@ -49,7 +50,8 @@ class _HomescreenState extends State<Homescreen> with TickerProviderStateMixin {
activateApp(String id) async {
try {
- agl_shell_channel.invokeMethod('activate_app', { 'app_id': id, 'index': 0 });
+ agl_shell_channel
+ .invokeMethod('activate_app', {'app_id': id, 'index': 0});
} catch (e) {
print('Could not invoke flutter/agl_shell/activate_app: $e');
}
@@ -82,7 +84,7 @@ class _HomescreenState extends State<Homescreen> with TickerProviderStateMixin {
}
}
}
- } catch(e) {
+ } catch (e) {
print(e);
}
}
@@ -149,9 +151,9 @@ class _HomescreenState extends State<Homescreen> with TickerProviderStateMixin {
var railSize = 160.0;
var iconSize = railSize / 2;
var foregroundColor = Theme.of(context)
- .navigationBarTheme
- .iconTheme!
- .resolve({MaterialState.pressed})!.color!;
+ .navigationBarTheme
+ .iconTheme!
+ .resolve({MaterialState.pressed})!.color!;
return Scaffold(
body: Column(
@@ -211,9 +213,8 @@ class _HomescreenState extends State<Homescreen> with TickerProviderStateMixin {
endIndent: railSize / 16)),
Container(
color: NavigationBarTheme.of(context).backgroundColor,
- child: ClockWidget(
- textColor: foregroundColor,
- size: railSize)),
+ child:
+ ClockWidget(textColor: foregroundColor, size: railSize)),
Container(
color: NavigationBarTheme.of(context).backgroundColor,
child: VerticalDivider(
@@ -225,70 +226,64 @@ class _HomescreenState extends State<Homescreen> with TickerProviderStateMixin {
Container(
color: NavigationBarTheme.of(context).backgroundColor,
child: Column(
- crossAxisAlignment: CrossAxisAlignment.center,
- mainAxisAlignment: MainAxisAlignment.spaceAround,
- children: <Widget>[
- Icon(Icons.bluetooth, color: foregroundColor, size: 32),
- Icon(Icons.wifi, color: foregroundColor, size: 32),
- Icon(Icons.signal_cellular_4_bar, color: foregroundColor, size: 32),
- ])),
+ crossAxisAlignment: CrossAxisAlignment.center,
+ mainAxisAlignment: MainAxisAlignment.spaceAround,
+ children: <Widget>[
+ Icon(Icons.bluetooth, color: foregroundColor, size: 32),
+ Icon(Icons.wifi, color: foregroundColor, size: 32),
+ Icon(Icons.signal_cellular_4_bar,
+ color: foregroundColor, size: 32),
+ ])),
SizedBox(
width: 16,
child: Container(
- color:
- Theme.of(context).navigationBarTheme.backgroundColor)),
+ color: Theme.of(context)
+ .navigationBarTheme
+ .backgroundColor)),
]),
),
// This is the main content.
Expanded(
- child: ChangeNotifierProvider(
- // See: https://docs.flutter.dev/development/data-and-backend/state-mgmt/simple
- // Also: https://docs.flutter.dev/development/data-and-backend/state-mgmt/options
- create: (context) => HomescreenModel(),
- child: AnimatedSwitcher(
- duration: const Duration(milliseconds: 500),
- reverseDuration: const Duration(milliseconds: 500),
- switchInCurve: Curves.easeInOut,
- switchOutCurve: Curves.easeInOut,
- transitionBuilder: (Widget child, Animation<double> animation) {
- if (child.key != ValueKey(_selectedIndex)) {
- return FadeTransition(
- opacity: Tween<double>(begin: 1.0, end: 1.0)
- .animate(animation),
- child: child,
- );
- }
- Offset beginOffset = new Offset(
- 0.0, (_selectedIndex > _previousIndex ? 1.0 : -1.0));
- return SlideTransition(
- position:
- Tween<Offset>(begin: beginOffset, end: Offset.zero)
- .animate(animation),
- child: FadeTransition(
- opacity: Tween<double>(begin: 0.0, end: 1.0).animate(
- CurvedAnimation(
- parent: animation,
- curve: Interval(0.5, 1.0),
- ),
+ child: AnimatedSwitcher(
+ duration: const Duration(milliseconds: 500),
+ reverseDuration: const Duration(milliseconds: 500),
+ switchInCurve: Curves.easeInOut,
+ switchOutCurve: Curves.easeInOut,
+ transitionBuilder: (Widget child, Animation<double> animation) {
+ if (child.key != ValueKey(_selectedIndex)) {
+ return FadeTransition(
+ opacity:
+ Tween<double>(begin: 1.0, end: 1.0).animate(animation),
+ child: child,
+ );
+ }
+ Offset beginOffset = new Offset(
+ 0.0, (_selectedIndex > _previousIndex ? 1.0 : -1.0));
+ return SlideTransition(
+ position: Tween<Offset>(begin: beginOffset, end: Offset.zero)
+ .animate(animation),
+ child: FadeTransition(
+ opacity: Tween<double>(begin: 0.0, end: 1.0).animate(
+ CurvedAnimation(
+ parent: animation,
+ curve: Interval(0.5, 1.0),
),
- child: child,
),
- );
- },
- child: _childForIndex(_selectedIndex),
- ),
+ child: child,
+ ),
+ );
+ },
+ child: _childForIndex(_selectedIndex),
),
),
- SizedBox(
- height: railSize,
- child: Container(
- color: NavigationBarTheme.of(context).backgroundColor,
- child: Align(
- alignment: Alignment.center,
- child: ScalableImageWidget.fromSISource(
- si: ScalableImageSource.fromSvg(rootBundle,
- 'images/Utility_Logo_Grey-01.svg'))))
- )
+ Stack(children: [
+ BottomPanelWidget(
+ height: railSize,
+ color: NavigationBarTheme.of(context).backgroundColor),
+ Align(
+ alignment: Alignment.bottomLeft,
+ child: GetConfig(client: widget.client))
+ ]),
],
),
);