mirror of
https://github.com/KRTirtho/spotube.git
synced 2025-09-13 07:55:18 +00:00
90 lines
3.4 KiB
Dart
90 lines
3.4 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:spotify/spotify.dart';
|
|
import 'package:spotube/components/Player/PlayerQueue.dart';
|
|
import 'package:spotube/components/Shared/DownloadTrackButton.dart';
|
|
import 'package:spotube/components/Shared/HeartButton.dart';
|
|
import 'package:spotube/hooks/useForceUpdate.dart';
|
|
import 'package:spotube/models/Logger.dart';
|
|
import 'package:spotube/provider/Auth.dart';
|
|
import 'package:spotube/provider/Playback.dart';
|
|
import 'package:spotube/provider/SpotifyDI.dart';
|
|
import 'package:spotube/provider/SpotifyRequests.dart';
|
|
|
|
class PlayerActions extends HookConsumerWidget {
|
|
final MainAxisAlignment mainAxisAlignment;
|
|
PlayerActions({
|
|
this.mainAxisAlignment = MainAxisAlignment.center,
|
|
Key? key,
|
|
}) : super(key: key);
|
|
final logger = getLogger(PlayerActions);
|
|
|
|
@override
|
|
Widget build(BuildContext context, ref) {
|
|
final SpotifyApi spotifyApi = ref.watch(spotifyProvider);
|
|
final Playback playback = ref.watch(playbackProvider);
|
|
final Auth auth = ref.watch(authProvider);
|
|
final update = useForceUpdate();
|
|
return Row(
|
|
mainAxisAlignment: mainAxisAlignment,
|
|
children: [
|
|
IconButton(
|
|
icon: const Icon(Icons.queue_music_rounded),
|
|
onPressed: playback.playlist != null
|
|
? () {
|
|
showModalBottomSheet(
|
|
context: context,
|
|
isDismissible: true,
|
|
enableDrag: true,
|
|
isScrollControlled: true,
|
|
backgroundColor: Colors.transparent,
|
|
shape: RoundedRectangleBorder(
|
|
borderRadius: BorderRadius.circular(10),
|
|
),
|
|
constraints: BoxConstraints(
|
|
maxHeight: MediaQuery.of(context).size.height * .7,
|
|
),
|
|
builder: (context) {
|
|
return const PlayerQueue();
|
|
},
|
|
);
|
|
}
|
|
: null,
|
|
),
|
|
DownloadTrackButton(
|
|
track: playback.track,
|
|
),
|
|
if (auth.isLoggedIn)
|
|
FutureBuilder<bool>(
|
|
future: playback.track?.id != null
|
|
? spotifyApi.tracks.me.containsOne(playback.track!.id!)
|
|
: Future.value(false),
|
|
initialData: false,
|
|
builder: (context, snapshot) {
|
|
bool isLiked = snapshot.data ?? false;
|
|
return HeartButton(
|
|
isLiked: isLiked,
|
|
onPressed: () async {
|
|
try {
|
|
if (playback.track?.id == null) return;
|
|
isLiked
|
|
? await spotifyApi.tracks.me
|
|
.removeOne(playback.track!.id!)
|
|
: await spotifyApi.tracks.me
|
|
.saveOne(playback.track!.id!);
|
|
} catch (e, stack) {
|
|
logger.e("FavoriteButton.onPressed", e, stack);
|
|
} finally {
|
|
update();
|
|
ref.refresh(currentUserSavedTracksQuery);
|
|
ref.refresh(
|
|
playlistTracksQuery("user-liked-tracks"),
|
|
);
|
|
}
|
|
});
|
|
}),
|
|
],
|
|
);
|
|
}
|
|
}
|