mucke/lib/presentation/widgets/song_customization_buttons.dart
2020-12-10 20:55:37 +01:00

58 lines
1.8 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter_mobx/flutter_mobx.dart';
import 'package:provider/provider.dart';
import '../../domain/entities/song.dart';
import '../state/audio_store.dart';
import '../state/music_data_store.dart';
import '../theming.dart';
class SongCustomizationButtons extends StatelessWidget {
const SongCustomizationButtons({Key key}) : super(key: key);
@override
Widget build(BuildContext context) {
final MusicDataStore musicDataStore = Provider.of<MusicDataStore>(context);
final AudioStore audioStore = Provider.of<AudioStore>(context);
return Observer(
builder: (BuildContext context) {
print('building buttons');
final Song song = audioStore.currentSong;
final bool isBlocked = audioStore.currentSong.blocked;
return Row(
children: [
IconButton(
icon: Icon(
Icons.link,
// size: 20.0,
color: song.next == null ? Colors.white70 : LIGHT1,
),
iconSize: 20.0,
onPressed: () => musicDataStore.toggleNextSongLink(song),
),
const Spacer(),
const IconButton(
icon: Icon(
Icons.favorite,
size: 20.0,
color: Colors.white10,
),
onPressed: null,
),
const Spacer(),
IconButton(
icon: Icon(
Icons.remove_circle_outline,
size: 20.0,
color: isBlocked ? RASPBERRY : Colors.white70,
),
onPressed: () => musicDataStore.setSongBlocked(song, !isBlocked),
),
],
mainAxisAlignment: MainAxisAlignment.center,
);
},
);
}
}