mirror of
https://github.com/KRTirtho/spotube.git
synced 2025-09-13 07:55:18 +00:00
63 lines
1.9 KiB
Dart
63 lines
1.9 KiB
Dart
import 'package:auto_route/annotations.dart';
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:shadcn_flutter/shadcn_flutter.dart';
|
|
import 'package:spotube/collections/spotube_icons.dart';
|
|
import 'package:spotube/components/button/back_button.dart';
|
|
import 'package:spotube/extensions/context.dart';
|
|
import 'package:spotube/hooks/utils/use_palette_color.dart';
|
|
import 'package:spotube/models/metadata/metadata.dart';
|
|
import 'package:spotube/pages/lyrics/plain_lyrics.dart';
|
|
import 'package:spotube/pages/lyrics/synced_lyrics.dart';
|
|
import 'package:spotube/provider/audio_player/audio_player.dart';
|
|
|
|
@RoutePage()
|
|
class PlayerLyricsPage extends HookConsumerWidget {
|
|
const PlayerLyricsPage({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context, ref) {
|
|
final playlist = ref.watch(audioPlayerProvider);
|
|
String albumArt = useMemoized(
|
|
() => (playlist.activeTrack?.album.images).asUrlString(
|
|
index: (playlist.activeTrack?.album.images.length ?? 1) - 1,
|
|
placeholder: ImagePlaceholder.albumArt,
|
|
),
|
|
[playlist.activeTrack?.album.images],
|
|
);
|
|
final selectedIndex = useState(0);
|
|
final palette = usePaletteColor(albumArt, ref);
|
|
|
|
final tabbar = TabList(
|
|
index: selectedIndex.value,
|
|
onChanged: (index) => selectedIndex.value = index,
|
|
children: [
|
|
TabItem(
|
|
child: Text(context.l10n.synced),
|
|
),
|
|
TabItem(
|
|
child: Text(context.l10n.plain),
|
|
),
|
|
],
|
|
);
|
|
|
|
return Scaffold(
|
|
headers: [
|
|
AppBar(
|
|
leading: [tabbar],
|
|
trailing: const [
|
|
BackButton(icon: SpotubeIcons.angleDown),
|
|
],
|
|
),
|
|
],
|
|
child: IndexedStack(
|
|
index: selectedIndex.value,
|
|
children: [
|
|
SyncedLyrics(palette: palette, isModal: false),
|
|
PlainLyrics(palette: palette, isModal: false),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|