summaryrefslogtreecommitdiffstats
path: root/templates/show_mpdpl.inc
diff options
context:
space:
mode:
authorKarl 'vollmerk' Vollmer <vollmer@ampache.org>2005-06-30 14:43:11 +0000
committerKarl 'vollmerk' Vollmer <vollmer@ampache.org>2005-06-30 14:43:11 +0000
commit224f007c59eab093bea69eb227faa64104ed4e15 (patch)
tree44486b935f6d1defaa67e56379a15aab5ec57af9 /templates/show_mpdpl.inc
parent10f8a1ec3378c3540a35f73e986cc284f2e66f1d (diff)
downloadampache-224f007c59eab093bea69eb227faa64104ed4e15.tar.gz
ampache-224f007c59eab093bea69eb227faa64104ed4e15.tar.bz2
ampache-224f007c59eab093bea69eb227faa64104ed4e15.zip
new mpd interface
Diffstat (limited to 'templates/show_mpdpl.inc')
-rw-r--r--templates/show_mpdpl.inc172
1 files changed, 172 insertions, 0 deletions
diff --git a/templates/show_mpdpl.inc b/templates/show_mpdpl.inc
new file mode 100644
index 00000000..fdf513a6
--- /dev/null
+++ b/templates/show_mpdpl.inc
@@ -0,0 +1,172 @@
+<?php
+/*
+
+ Copyright (c) 2001 - 2005 Ampache.org
+ All rights reserved.
+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation; either version 2
+ of the License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+*/
+$web_path = conf('web_path');
+/*
+Instructions on incorporating this code:
+1) You need to add a row with a name of 'condPL' into the table preferences. Initial value is 1 (condensed playlist by default)
+or 0 (not condensed by default).
+2) Insert the following function at the end of /mpd.php and change show_mpd_control() above it to "require" (instead of require_once):
+
+TTD:
+- It would be nice if flagged songs showed up in a flagged color (e.g. red).
+- Accept one or more parameters by which the caller specify which columns are displayed.
+- What is the best way to deal with the play pointer when stopped. MPD doesn't report a "position" but stop restarts at the song
+ that was playing before the stop.
+
+*/
+
+/* The following mpd init code is from amp-mpd.php and should probably go into a mpdinit file that gets executed by initmpd
+since other pages or items on index.php that come before this (like an MPD control in the header!) might need myMpd.
+*/
+
+
+if (!class_exists('mpd')) { require_once(conf('prefix')."/modules/mpd/mpd.class.php"); }
+if (!is_object($myMpd)) { $myMpd = new mpd(conf('mpd_host'),conf('mpd_port')); }
+if (!$myMpd->connected)
+ {
+ echo "<font class=\"error\">" . _("Error Connecting") . ": " . $myMpd->errStr . "</font><br />\n";
+ log_event ($_SESSION['userdata']['username'],' connection_failed ',"Error: unable to connect to MPD, ".$myMpd->errStr);
+ return;
+ }
+
+$nopad = "style='padding: 0px 0px 0px 0px'";
+$minpad = "style='padding: 0px 2px 0px 2px'";
+
+?>
+<td colspan=2 valign="top">
+
+<form action="<?php echo conf('web_path')."/amp-mpd.php"; ?>" method="post" enctype="multipart/form-data">
+
+<table class="border" border="0" cellpadding="0" cellspacing="1" width="100%">
+<tr><td align="center" class="headrow"><b>MPD Server Playlist</b><br>
+ <i>[<a title="<?php echo _("Refresh the Playlist Window"); ?>" href="<?php echo conf('web_path'); ?>">refresh</a>]
+<?php if ( $myMpd->playlist_count > 0 ) {
+ $un = (conf('condPL')) ? "un" : ""; ?>
+ [<a title="<?php echo _("Click to shuffle (randomize) the playlist"); ?>" href="<?php echo conf('web_path'); ?>/amp-mpd.php?action=shuffle"><?php echo _("shuffle")?></a>]
+ [<a title="<?php echo _("Click to the clear the playlist"); ?>" href="<?php echo conf('web_path'); ?>/amp-mpd.php?action=clear">clear</a>]
+ [<a title="<?php echo 'Click to '.$un.'condense playlist'; ?>" href="<?php echo conf('web_path'); ?>/amp-mpd.php?action=condPL"><?php echo $un?>condense</a>]
+ [<a title="<?php echo _("Click to the remove all except the Now Playing"); ?>"href="<?php echo conf('web_path'); ?>/amp-mpd.php?action=crop">crop</a>]
+<?php } ?> </i></td></tr>
+<tr><td <?php echo $nopad ?>>
+<table cellspacing="0" cellpadding="0" border="0" width="100%"><tr class="table-header">
+ <th <?php echo $minpad ?>><a href="#" onclick="check_songs(); return false;">Flip</a></th>
+ <th align="left"><?php echo _("Song title"); ?></th>
+ <th align="left"><?php echo _("Artist"); ?></th>
+ <th align="left"><?php echo _("Album"); ?></th>
+ <th align="right" <?php echo $minpad ?>><?php echo _("Track"); ?></td>
+ <th align="right" <?php echo $minpad ?>><?php echo _("Time"); ?></th>
+ <th <?php echo $minpad ?>><?php echo _("Genre"); ?></th>
+ <th><?php echo _("Action"); ?></th>
+ </tr>
+ <?php
+ $pl = $myMpd->playlist;
+ if (is_null($pl)) echo "ERROR: ".$myMpd->errStr."\n";
+ else {
+ $maxlen = strlen (count($pl));
+ $condPL = conf('condPL');
+ if ($condPL)
+ {
+ echo "<tr class=\"".flip_class()."\"><td colspan=8 align=\"center\" style=\"padding: 3px 0px 3px 0px\">... Condensed Playlist ...</td></tr>";
+ }
+
+ foreach ($pl as $id=>$entry) {
+
+ if ( ($condPL) and (($id < $myMpd->current_track_id-1) or ($id > $myMpd->current_track_id + 10)) )
+ { continue; }
+
+ unset($text_class);
+
+ $track = $id+1;
+ $len=strlen($track);
+ while ($len < $maxlen)
+ {
+ $track = "0".$track;
+ $len++;
+ }
+
+ // Still needed crap
+ $totalsize += $song->size;
+ $totaltime += $entry['Time'];
+ ?>
+
+ <tr class="<?php echo flip_class(); ?>">
+ <?php if ($id==$myMpd->current_track_id)
+ {$tdstyle = "style='padding: 0px 2px 0px 2px; font-weight: bold'";}
+ else {$tdstyle = $minpad;} ?>
+<?php
+$mpddir = conf('mpd_dir')."/";
+$sql = "SELECT genre.name, song.genre, song.id, song.album, song.artist FROM song, genre WHERE file = \"".$mpddir.$entry['file']."\" AND song.genre=genre.id";
+$db_results = @mysql_query($sql,dbh());
+$count=0;
+$r = @mysql_fetch_object ($db_results);
+?>
+ <td align="center" <?php echo $minpad ?>><input type="checkbox" name="song[<?php echo $entry['Pos']?>]" value="1" id="song_<?php echo $entry['Pos']; ?>"></input></td>
+ <td align="left" <?php echo $tdstyle ?>><?php echo $track.". ";?><a href="<?php echo $web_path; ?>/amp-mpd.php?action=skipto&val=<?php echo $entry['Pos']; ?>" title="<?php echo $entry['Title']; ?>" <?php echo $text_class; ?>><?php echo $entry['Title']; ?> </a></td>
+ <td align="left" <?php echo $tdstyle ?>><a href="<?php echo $web_path; ?>/artists.php?action=show&artist=<?php echo $r->artist; ?>" title="More from <?php echo $entry['Artist']; ?>" <?php echo $text_class; ?>> <?php echo $entry['Artist']; ?> </a></td>
+ <td align="left" <?php echo $tdstyle ?>><a href="<?php echo $web_path; ?>/albums.php?action=show&album=<?php echo $r->album; ?>" title="More on <?php echo $entry['Album']; ?>" <?php echo $text_class; ?>> <?php echo $entry['Album']; ?> </a></td>
+ <td align="right" <?php echo $tdstyle ?>><?php echo $entry['Track']; ?></td>
+ <td align="right" <?php echo $tdstyle ?>><?php echo sprintf ("%d:%02d",$entry['Time']/60,$entry['Time']%60) ?></td>
+
+ <td align="center" <?php echo $tdstyle.">".$r->name ?></td>
+
+ <td <?php echo $tdstyle ?>><?php echo "<a href=".$web_path."/flag.php?song=".$r->id."&action=flag title=\"Flag '".$entry['file']."' by ".$entry['Artist']."\" ".$text_class.">f</a>&nbsp".
+ "<a href=".$web_path."/amp-mpd.php?action=movenext&val=".$entry['Pos']." title=\"Move '".$entry['Title']."' to play next\" ".$text_class.">n</a>&nbsp".
+ // "^&nbsp".
+ // "v&nbsp".
+ "<a href=".$web_path."/amp-mpd.php?action=rem&id=".$entry['Pos']." title=\"Remove '".$entry['Title']."' from playlist\" ".$text_class.">x</a>"; ?></td>
+ <?php if ($id==$myMpd->current_track_id) { echo "</b>"; } ?>
+ </tr>
+
+ <?
+ }// foreach loop
+ if (($condPL) && ($myMpd->current_track_id+10 <= $myMpd->playlistcount))
+ {
+ echo "<tr class=\"".flip_class()."\"><td colspan=8 align=\"center\" style=\"padding: 3px 0px 3px 0px\">... Condensed Playlist ...</td></tr>";
+ }
+ } //else
+
+ $time = floor($totaltime/60) . ":" . sprintf("%02d", ($totaltime%60) );
+ $num = count($pl);
+
+ ?>
+
+ <tr class="table-header" valign=middle>
+ <input type="hidden" name="action" value="plact">
+ <td><button name="submit" value="submit" type="submit" style = "font-family: <?php echo conf('font')?>; font-size: <?php echo conf('font_size')?>px" title="Take Action on the checked songs">Do</button></td>
+ <td valign=middle><select name="todo" style = "font-family: <?php echo conf('font')?>; font-size: <?php echo conf('font_size')?>px" size=1>
+ <option>Delete
+ <!-- <option>move Next This isn't working yet -->
+ <option>Crop</select></td>
+ <td valign=middle><?php echo _("Total"); ?>:</td>
+ <td valign=middle><?php echo $num; ?> song(s)</td>
+ <td></td>
+ <td valign=middle align="right" <?php echo $minpad; ?> nowrap><?php echo $time; ?></td>
+ <td>&nbsp</td>
+ <td>&nbsp</td>
+<?php ?>
+ </tr>
+ </table></td></tr>
+</table>
+<br />
+</form>
+</td/>
+