summaryrefslogtreecommitdiffstats
path: root/lib/presentation/screens/media_player/player_navigation.dart
diff options
context:
space:
mode:
authorScott Murray <scott.murray@konsulko.com>2023-12-31 16:24:51 -0500
committerScott Murray <scott.murray@konsulko.com>2024-01-03 18:23:52 -0500
commit4742fde5c48726357cc8db06d237e9db6c3df608 (patch)
treedcca2b3e3c6cb3a4a46b7ae603f64fa9ce5a086c /lib/presentation/screens/media_player/player_navigation.dart
parentfcd868bd73d35bd79074f3425317152565aeb275 (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.dart80
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());
- }
-}