blob: d47c25f6631592111084272f77d41e9330718992 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
|
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="iso-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html><head>
<%@ include file="head.jsp" %>
<%@ include file="jquery.jsp" %>
<script type="text/javascript" src="<c:url value="/script/scripts.js"/>"></script>
<script type="text/javascript" src="<c:url value="/script/smooth-scroll.js"/>"></script>
<script type="text/javascript" src="<c:url value="/dwr/engine.js"/>"></script>
<script type="text/javascript" src="<c:url value="/dwr/interface/playlistService.js"/>"></script>
<script type="text/javascript" language="javascript">
var playlists;
function init() {
dwr.engine.setErrorHandler(null);
updatePlaylists();
}
function updatePlaylists() {
playlistService.getReadablePlaylists(playlistCallback);
}
function createEmptyPlaylist() {
playlistService.createEmptyPlaylist(playlistCallback);
}
function playlistCallback(playlists) {
this.playlists = playlists;
$("#playlists").empty();
for (var i = 0; i < playlists.length; i++) {
var playlist = playlists[i];
$("<p class='dense'><a target='main' href='playlist.view?id=" +
playlist.id + "'>" + playlist.name + " (" + playlist.fileCount + ")</a></p>").appendTo("#playlists");
}
}
</script>
</head>
<body class="bgcolor2 leftframe" onload="init()">
<a name="top"></a>
<c:if test="${model.scanning}">
<div style="padding-bottom:1.0em">
<div class="warning"><fmt:message key="left.scanning"/></div>
<div class="forward"><a href="left.view"><fmt:message key="common.refresh"/></a></div>
</div>
</c:if>
<div style="padding-bottom:0.5em">
<c:forEach items="${model.indexes}" var="index">
<a href="#${index.index}" accesskey="${index.index}">${index.index}</a>
</c:forEach>
</div>
<c:if test="${model.statistics.songCount gt 0}">
<div class="detail">
<fmt:message key="left.statistics">
<fmt:param value="${model.statistics.artistCount}"/>
<fmt:param value="${model.statistics.albumCount}"/>
<fmt:param value="${model.statistics.songCount}"/>
<fmt:param value="${model.bytes}"/>
<fmt:param value="${model.hours}"/>
</fmt:message>
</div>
</c:if>
<c:if test="${fn:length(model.musicFolders) > 1}">
<div style="padding-top:1em">
<select name="musicFolderId" style="width:100%" onchange="location='left.view?musicFolderId=' + options[selectedIndex].value;" >
<option value="-1"><fmt:message key="left.allfolders"/></option>
<c:forEach items="${model.musicFolders}" var="musicFolder">
<option ${model.selectedMusicFolder.id == musicFolder.id ? "selected" : ""} value="${musicFolder.id}">${musicFolder.name}</option>
</c:forEach>
</select>
</div>
</c:if>
<c:if test="${not empty model.shortcuts}">
<h2 class="bgcolor1"><fmt:message key="left.shortcut"/></h2>
<c:forEach items="${model.shortcuts}" var="shortcut">
<p class="dense" style="padding-left:0.5em">
<sub:url value="main.view" var="mainUrl">
<sub:param name="id" value="${shortcut.id}"/>
</sub:url>
<a target="main" href="${mainUrl}">${shortcut.name}</a>
</p>
</c:forEach>
</c:if>
<h2 class="bgcolor1"><fmt:message key="left.playlists"/></h2>
<div style='padding-left:0.5em'>
<div id="playlists"></div>
<div style="margin-top: 0.3em"><a href="javascript:noop()" onclick="createEmptyPlaylist()"><fmt:message key="left.createplaylist"/></a></div>
<div><a href="importPlaylist.view" target="main"><fmt:message key="left.importplaylist"/></a></div>
</div>
<c:if test="${not empty model.radios}">
<h2 class="bgcolor1"><fmt:message key="left.radio"/></h2>
<c:forEach items="${model.radios}" var="radio">
<p class="dense">
<a target="hidden" href="${radio.streamUrl}">
<img src="<spring:theme code="playImage"/>" alt="<fmt:message key="common.play"/>" title="<fmt:message key="common.play"/>"></a>
<c:choose>
<c:when test="${empty radio.homepageUrl}">
${radio.name}
</c:when>
<c:otherwise>
<a target="main" href="${radio.homepageUrl}">${radio.name}</a>
</c:otherwise>
</c:choose>
</p>
</c:forEach>
</c:if>
<c:forEach items="${model.indexedArtists}" var="entry">
<table class="bgcolor1" style="width:100%;padding:0;margin:1em 0 0 0;border:0">
<tr style="padding:0;margin:0;border:0">
<th style="text-align:left;padding:0;margin:0;border:0"><a name="${entry.key.index}"></a>
<h2 style="padding:0;margin:0;border:0">${entry.key.index}</h2>
</th>
<th style="text-align:right;">
<a href="#top"><img src="<spring:theme code="upImage"/>" alt=""></a>
</th>
</tr>
</table>
<c:forEach items="${entry.value}" var="artist">
<p class="dense" style="padding-left:0.5em">
<span title="${artist.name}">
<sub:url value="main.view" var="mainUrl">
<c:forEach items="${artist.mediaFiles}" var="mediaFile">
<sub:param name="id" value="${mediaFile.id}"/>
</c:forEach>
</sub:url>
<a target="main" href="${mainUrl}"><str:truncateNicely upper="${model.captionCutoff}">${artist.name}</str:truncateNicely></a>
</span>
</p>
</c:forEach>
</c:forEach>
<div style="padding-top:1em"></div>
<c:forEach items="${model.singleSongs}" var="song">
<p class="dense" style="padding-left:0.5em">
<span title="${song.title}">
<c:import url="playAddDownload.jsp">
<c:param name="id" value="${song.id}"/>
<c:param name="playEnabled" value="${model.user.streamRole and not model.partyMode}"/>
<c:param name="addEnabled" value="${model.user.streamRole}"/>
<c:param name="downloadEnabled" value="${model.user.downloadRole and not model.partyMode}"/>
<c:param name="video" value="${song.video and model.player.web}"/>
</c:import>
<str:truncateNicely upper="${model.captionCutoff}">${song.title}</str:truncateNicely>
</span>
</p>
</c:forEach>
<div style="height:5em"></div>
<div class="bgcolor2" style="opacity: 1.0; clear: both; position: fixed; bottom: 0; right: 0; left: 0;
padding: 0.25em 0.75em 0.25em 0.75em; border-top:1px solid black; max-width: 850px;">
<c:forEach items="${model.indexes}" var="index">
<a href="#${index.index}">${index.index}</a>
</c:forEach>
</div>
</body></html>
|