mucke/lib/presentation/widgets/song_customization_buttons.dart
2021-05-10 19:19:54 +02:00

52 lines
1.7 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter_mobx/flutter_mobx.dart';
import 'package:get_it/get_it.dart';
import '../../domain/entities/song.dart';
import '../state/audio_store.dart';
import '../state/music_data_store.dart';
import 'like_button.dart';
class SongCustomizationButtons extends StatelessWidget {
const SongCustomizationButtons({Key key}) : super(key: key);
@override
Widget build(BuildContext context) {
final MusicDataStore musicDataStore = GetIt.I<MusicDataStore>();
final AudioStore audioStore = GetIt.I<AudioStore>();
return Observer(
builder: (BuildContext context) {
final Song song = audioStore.currentSongStream.value;
return Container(
child: Row(
children: [
IconButton(
icon: Icon(
song.next == null ? Icons.link_off : Icons.link,
color: song.next == null ? Colors.white24 : Colors.white,
),
iconSize: 20.0,
onPressed: () => musicDataStore.toggleNextSongLink(song),
visualDensity: VisualDensity.compact,
),
const LikeButton(
iconSize: 20.0,
),
IconButton(
icon: Icon(
Icons.remove_circle_outline_rounded,
size: 20.0,
color: song.blocked ? Colors.white : Colors.white24,
),
onPressed: () => musicDataStore.setSongBlocked(song, !song.blocked),
visualDensity: VisualDensity.compact,
),
],
mainAxisAlignment: MainAxisAlignment.spaceBetween,
),
);
},
);
}
}