diff options
author | Scott Murray <scott.murray@konsulko.com> | 2023-12-31 16:24:51 -0500 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2024-01-03 18:23:52 -0500 |
commit | 4742fde5c48726357cc8db06d237e9db6c3df608 (patch) | |
tree | dcca2b3e3c6cb3a4a46b7ae603f64fa9ce5a086c /lib/presentation/screens/media_player/player_navigation.dart | |
parent | fcd868bd73d35bd79074f3425317152565aeb275 (diff) |
Initial radio implementation
Notable changes:
- Add radio gRPC API protobuf definitation and generated files.
- Reworked existing single gRPC APIs library to split it into
per-API libraries to avoid name collision issues.
- Add radio gRPC client class and associated radio state class
and RiverPod providers.
- Split media controls and play list table classes into media
player and radio specific versions to facilitate customization
and wiring up their appropriate backends in a straightforward
fashion. Some potential rationalization of styling widgets
may be done as a follow up to avoid some duplication.
- Added radio configuration and presets loading. The presets
will be populated with the contents of a radio-presets.yaml
file from the configured location, the default location is
the /etc/xdg/AGL/ics-homescreen directory.
- Implemented FM radio player against the radio gRPC API.
For the sake of expediency, no attempt has been made to make
the player able to handle AM band support.
- Reworked media page navigation state so that active player is
restored when coming back to the page. Logic has been added to
start/stop the radio on navigating to or leaving the FM radio
sub-page. This will potentially be reworked before CES to work
with the pause/stop button present on the other pages.
- Started pruning down global exports.dart a bit to remove files
only used in a specific page/hierarchy, starting with media.
Bug-AGL: SPEC-5029
Change-Id: I1ae0aca4a7a8218e69e4286c863f01509a1cccb7
Signed-off-by: Scott Murray <scott.murray@konsulko.com>
Diffstat (limited to 'lib/presentation/screens/media_player/player_navigation.dart')
-rw-r--r-- | lib/presentation/screens/media_player/player_navigation.dart | 80 |
1 files changed, 0 insertions, 80 deletions
diff --git a/lib/presentation/screens/media_player/player_navigation.dart b/lib/presentation/screens/media_player/player_navigation.dart deleted file mode 100644 index 8e09e53..0000000 --- a/lib/presentation/screens/media_player/player_navigation.dart +++ /dev/null @@ -1,80 +0,0 @@ -import 'package:flutter_ics_homescreen/core/utils/helpers.dart'; -import 'package:flutter_ics_homescreen/export.dart'; - -class PlayerNavigation extends StatefulWidget { - const PlayerNavigation({super.key, required this.onPressed}); - final Function onPressed; - - @override - State<PlayerNavigation> createState() => _PlayerNavigationState(); -} - -class _PlayerNavigationState extends State<PlayerNavigation> { - List<String> navItems = ["My Media", "FM", "AM", "XM"]; - String selectedNav = "My Media"; - @override - Widget build(BuildContext context) { - return Row( - children: navItems - .map((e) => Expanded( - child: Container( - margin: const EdgeInsets.symmetric(horizontal: 2), - decoration: BoxDecoration( - gradient: LinearGradient(colors: [ - selectedNav == e - ? AGLDemoColors.neonBlueColor - : AGLDemoColors.buttonFillEnabledColor, - AGLDemoColors.gradientBackgroundDarkColor - ], begin: Alignment.topCenter, end: Alignment.bottomCenter), - // color: selectedNav == e - // ? AGLDemoColors.neonBlueColor - // : AGLDemoColors.buttonFillEnabledColor, - ), - child: Material( - color: Colors.transparent, - child: InkWell( - onTap: () { - setState(() { - selectedNav = e; - }); - widget.onPressed(selectedNav); - }, - child: Container( - padding: const EdgeInsets.symmetric(vertical: 7), - decoration: BoxDecoration( - border: Border( - left: selectedNav == e - ? const BorderSide(color: Colors.white12) - : BorderSide.none, - right: selectedNav == e - ? const BorderSide(color: Colors.white12) - : BorderSide.none, - top: BorderSide( - color: selectedNav == e - ? Colors.white - : Colors.white24, - width: selectedNav == e ? 2 : 1))), - child: Text( - e, - textAlign: TextAlign.center, - style: TextStyle( - fontSize: 26, - shadows: [ - selectedNav == e - ? Helpers.dropShadowRegular - : Helpers.dropShadowBig - ], - color: selectedNav == e - ? Colors.white - : AGLDemoColors.periwinkleColor, - fontWeight: selectedNav == e - ? FontWeight.w700 - : FontWeight.w500), - ), - ), - ), - ), - ))) - .toList()); - } -} |