playlists and queue item go up

This commit is contained in:
stjet
2024-07-07 21:36:12 +00:00
parent f269d8579d
commit 3b113ed4f8
3 changed files with 55 additions and 12 deletions

View File

@@ -62,6 +62,12 @@ for (let listing_type of ["anime", "manga", "music"]) {
)); ));
} }
//get playlists if any (will add to player at a later step)
let playlists: string[] = [];
if (existsSync(path.join(__dirname, "/static_assets/playlists"))) {
playlists.push(...readdirSync(path.join(__dirname, "/static_assets/playlists")).map((name: string) => name));
}
let renderer: Renderer = new Renderer("templates", "components"); let renderer: Renderer = new Renderer("templates", "components");
let builder: Builder = new Builder("/build"); let builder: Builder = new Builder("/build");
@@ -156,6 +162,7 @@ builder.serve_template(renderer, "/stats", "stats", {
}); });
builder.serve_template(renderer, "/player", "player", { builder.serve_template(renderer, "/player", "player", {
playlists,
songs, songs,
artists: listings.filter((l) => l.type === "music").map( artists: listings.filter((l) => l.type === "music").map(
(l) => ( (l) => (

View File

@@ -34,7 +34,7 @@ const request_handler = (req, res) => {
req_path = path.join(__dirname, "build", decodeURI(req.url), "index.html"); req_path = path.join(__dirname, "build", decodeURI(req.url), "index.html");
} else { } else {
//is file //is file
if (url_obj.pathname.startsWith("/anime_assets") || url_obj.pathname.startsWith("/manga_assets") || url_obj.pathname.startsWith("/music_assets") || url_obj.pathname.startsWith("/music_subtitle_assets")) { if (url_obj.pathname.startsWith("/anime_assets") || url_obj.pathname.startsWith("/manga_assets") || url_obj.pathname.startsWith("/music_assets") || url_obj.pathname.startsWith("/music_subtitle_assets") || "/playlists") {
req_path = path.join(__dirname, "static_assets", decodeURI(req.url)); req_path = path.join(__dirname, "static_assets", decodeURI(req.url));
} else { } else {
req_path = path.join(__dirname, "build", decodeURI(req.url)); req_path = path.join(__dirname, "build", decodeURI(req.url));

View File

@@ -38,6 +38,9 @@
margin: 0px; margin: 0px;
padding-left: 2px; padding-left: 2px;
} }
.q-item-button {
margin-left: 5px;
}
label:hover > .add-to-queue-btns { label:hover > .add-to-queue-btns {
display: inline-block; display: inline-block;
} }
@@ -75,6 +78,14 @@
<label for="playlist-upload">Upload Playlist (Adds to Queue Randomly):</label> <label for="playlist-upload">Upload Playlist (Adds to Queue Randomly):</label>
<input id="playlist-upload" type="file" accept=".playlist" onchange="upload_playlist()"/> <input id="playlist-upload" type="file" accept=".playlist" onchange="upload_playlist()"/>
<br> <br>
<label for="playlist-select">Or Select Playlist:</label>
<select id="playlist-select">
[[ for:playlists:playlist ]]
<option value="[[ playlist ]]">[[ playlist ]]</option>
[[ endfor ]]
</select>
<input type="button" value="Add Playlist" onclick="add_selected_playlist()"/>
<br>
<input type="button" value="Download History" onclick="download_history()"/> <input type="button" value="Download History" onclick="download_history()"/>
</div> </div>
</div> </div>
@@ -173,7 +184,23 @@
let queue_name = document.createElement("B"); let queue_name = document.createElement("B");
queue_name.innerText = name; queue_name.innerText = name;
queue_item.appendChild(queue_name); queue_item.appendChild(queue_name);
let queue_up = document.createElement("BUTTON");
queue_up.className = "q-item-button";
queue_up.innerText = "^";
queue_up.onclick = () => {
if (queue.length === 1) return;
let i = queue.findIndex((item) => item[1] === queue_id);
if (i === 0) return;
let qir = document.getElementById(queue_id);
qir.remove();
let t = queue.find((item) => item[1] === queue_id);
queue = queue.filter((item) => item[1] !== queue_id);
queue.splice(i-1, 0, t);
in_queue_ele.insertBefore(qir, in_queue_ele.children.item(i-1));
};
queue_item.appendChild(queue_up);
let queue_remove = document.createElement("BUTTON"); let queue_remove = document.createElement("BUTTON");
queue_remove.className = "q-item-button";
queue_remove.innerText = "Remove From Queue"; queue_remove.innerText = "Remove From Queue";
queue_remove.onclick = () => { queue_remove.onclick = () => {
document.getElementById(queue_id).remove(); document.getElementById(queue_id).remove();
@@ -244,11 +271,7 @@
a.click(); a.click();
} }
function upload_playlist() { function add_playlist(playlist_songs) {
let reader = new FileReader();
reader.readAsText(document.getElementById("playlist-upload").files[0]);
reader.addEventListener("load", () => {
let playlist_songs = reader.result.split("\n");
let randomized = []; let randomized = [];
while (randomized.length < playlist_songs.length) { while (randomized.length < playlist_songs.length) {
let rand = Math.floor(Math.random() * playlist_songs.length); let rand = Math.floor(Math.random() * playlist_songs.length);
@@ -259,17 +282,30 @@
for (const n of randomized) { for (const n of randomized) {
add_to_queue(n); add_to_queue(n);
} }
}
function upload_playlist() {
let reader = new FileReader();
reader.readAsText(document.getElementById("playlist-upload").files[0]);
reader.addEventListener("load", () => {
let playlist_songs = reader.result.split("\n");
add_playlist(playlist_songs);
}); });
} }
function download_history() { function download_history() {
let a = document.createElement("A"); let a = document.createElement("A");
a.href = `data:text/plain;charset=utf-8,${encodeURIComponent(JSON.stringify(history))}`; a.href = `data:text/plain;charset=utf-8,${encodeURIComponent(JSON.stringify(history))}`;
a.download = "queue.playlist"; a.download = `${Date.now()}.history`;
a.style.display = "none"; a.style.display = "none";
document.body.appendChild(a); document.body.appendChild(a);
a.click(); a.click();
} }
async function add_selected_playlist() {
let playlist_songs = (await (await fetch(`/playlists/${document.getElementById("playlist-select").value}`)).text()).split("\n");
add_playlist(playlist_songs);
}
</script> </script>
</body> </body>
</html> </html>