summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRasmus Steinke <rasi@xssn.at>2017-09-21 20:59:42 +0200
committerRasmus Steinke <rasi@xssn.at>2017-09-21 20:59:42 +0200
commit151ca161cd0ef3a0cab25f3aa82fdac97b653f62 (patch)
tree9c266d32e27ce2b16cce796522ee6e3356bfe009
parentf2b15bfdb096a25f9483e692494f1ec9a945fb1d (diff)
downloadperl-app-clerk-151ca161cd0ef3a0cab25f3aa82fdac97b653f62.tar.gz
perl-app-clerk-151ca161cd0ef3a0cab25f3aa82fdac97b653f62.tar.xz
add rating support to tracks view
-rwxr-xr-xclerk28
1 files changed, 21 insertions, 7 deletions
diff --git a/clerk b/clerk
index f5b112f..37bc217 100755
--- a/clerk
+++ b/clerk
@@ -354,17 +354,31 @@ sub do_action {
}
}
} elsif ($context eq "tracks") {
- my @action_items = ("Add\n", "Replace\n");
+ my @action_items = ("Add\n", "Replace\n", "Rate\n");
$action = backend_call(\@action_items);
if ($action eq "Replace\n") {
$mpd->clear();
}
- my $input;
- foreach my $line (split /\n/, $in) {
- my $uri = (split /[\t\n]/, $line)[-1];
- $uri = decode('UTF-8', $uri );
- $mpd->add($uri);
- system(@queue_cmd);
+ if ($action eq "Rate\n") {
+ my @rating_value = ("1\n", "2\n", "3\n", "4\n", "5\n", "6\n", "7\n", "8\n", "9\n", "10\n");
+ my $rating;
+ $rating = backend_call(\@rating_value);
+ chomp $rating;
+ my $input;
+ foreach my $line (split /\n/, $in) {
+ my $uri = (split /[\t\n]/, $line)[-1];
+ $uri = decode('UTF-8', $uri );
+ $mpd->sticker_value("song", "$uri", "rating", "$rating")
+ }
+ }
+ elsif ($action eq "Add\n" // $action eq "Replace\n") {
+ my $input;
+ foreach my $line (split /\n/, $in) {
+ my $uri = (split /[\t\n]/, $line)[-1];
+ $uri = decode('UTF-8', $uri );
+ $mpd->add($uri);
+ system(@queue_cmd);
+ }
}
if ($action eq "Replace\n") {
$mpd->play();