diff options
author | Scott Murray <scott.murray@konsulko.com> | 2022-12-28 15:05:26 -0500 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2022-12-29 06:35:38 +0000 |
commit | 4fbd3fdb9e01c197d972b78961f0d033534a5cc7 (patch) | |
tree | def7bfc0d0f11746006439b33019b61dfc16e1b8 /lib/homescreen.dart | |
parent | e21709c9601209e26d09dea0a45e37f0636bb605 (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.dart | 125 |
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)) + ]), ], ), ); |