Merge branch 'main' of gitlab.com:XenGi/sanic
This commit is contained in:
		
						commit
						2c2efaaca2
					
				
					 3 changed files with 115 additions and 1 deletions
				
			
		
							
								
								
									
										38
									
								
								mpd.go
									
										
									
									
									
								
							
							
						
						
									
										38
									
								
								mpd.go
									
										
									
									
									
								
							| 
						 | 
					@ -273,3 +273,41 @@ func moveTrackInQueue(c echo.Context) error {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return c.String(http.StatusOK, fmt.Sprintf("Moved song %d to position %d", songId, position))
 | 
						return c.String(http.StatusOK, fmt.Sprintf("Moved song %d to position %d", songId, position))
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Playlists
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func listPlaylists(c echo.Context) error {
 | 
				
			||||||
 | 
						// Connect to MPD server
 | 
				
			||||||
 | 
						conn, err := mpd.Dial("tcp", "localhost:6600")
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.Logger().Error(err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						defer conn.Close()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						playlists, err := conn.ListPlaylists()
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.Logger().Error(err)
 | 
				
			||||||
 | 
							return c.String(http.StatusBadRequest, err.Error())
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return c.JSON(http.StatusOK, playlists)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func listPlaylist(c echo.Context) error {
 | 
				
			||||||
 | 
						// Connect to MPD server
 | 
				
			||||||
 | 
						conn, err := mpd.Dial("tcp", "localhost:6600")
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.Logger().Error(err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						defer conn.Close()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						name := c.Param("name")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						playlist, err := conn.PlaylistContents(name)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.Logger().Error(err)
 | 
				
			||||||
 | 
							return c.String(http.StatusBadRequest, err.Error())
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return c.JSON(http.StatusOK, playlist)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -92,6 +92,9 @@ func main() {
 | 
				
			||||||
	g.GET("/queue/:song_id/delete", deleteTrackFromQueue)
 | 
						g.GET("/queue/:song_id/delete", deleteTrackFromQueue)
 | 
				
			||||||
	g.GET("/queue/:song_id/move/:position", moveTrackInQueue)
 | 
						g.GET("/queue/:song_id/move/:position", moveTrackInQueue)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						g.GET("/playlists", listPlaylists)
 | 
				
			||||||
 | 
						g.GET("/playlists/:name", listPlaylist)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	g.GET("/download", downloadTrack)
 | 
						g.GET("/download", downloadTrack)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	e.GET("/ws", wsServe)
 | 
						e.GET("/ws", wsServe)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -37,6 +37,7 @@ const control_replace_playlist = document.getElementById("control-replace-playli
 | 
				
			||||||
const control_attach_playlist = document.getElementById("control-attach-playlist");
 | 
					const control_attach_playlist = document.getElementById("control-attach-playlist");
 | 
				
			||||||
const control_save_playlist = document.getElementById("control-save-playlist");
 | 
					const control_save_playlist = document.getElementById("control-save-playlist");
 | 
				
			||||||
const control_delete_playlist = document.getElementById("control-delete-playlist");
 | 
					const control_delete_playlist = document.getElementById("control-delete-playlist");
 | 
				
			||||||
 | 
					const result_table = document.querySelector("#result tbody");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Utility functions
 | 
					// Utility functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -152,7 +153,78 @@ control_delete_playlist.addEventListener("click", () => {
 | 
				
			||||||
  });
 | 
					  });
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
control_update_db.addEventListener("click", event => {
 | 
					tab_browser.addEventListener("click", e => {
 | 
				
			||||||
 | 
					  if (!tab_browser.classList.contains("active")) {
 | 
				
			||||||
 | 
					    tab_browser.classList.add("active");
 | 
				
			||||||
 | 
					    tab_search.classList.remove("active")
 | 
				
			||||||
 | 
					    tab_playlists.classList.remove("active")
 | 
				
			||||||
 | 
					    document.getElementById("file-browser").style.display = "block";
 | 
				
			||||||
 | 
					    document.getElementById("search").style.display = "none";
 | 
				
			||||||
 | 
					    document.getElementById("playlist-browser").style.display = "none";
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					tab_search.addEventListener("click", e => {
 | 
				
			||||||
 | 
					  if (!tab_search.classList.contains("active")) {
 | 
				
			||||||
 | 
					    tab_browser.classList.remove("active");
 | 
				
			||||||
 | 
					    tab_search.classList.add("active")
 | 
				
			||||||
 | 
					    tab_playlists.classList.remove("active")
 | 
				
			||||||
 | 
					    document.getElementById("file-browser").style.display = "none";
 | 
				
			||||||
 | 
					    document.getElementById("search").style.display = "block";
 | 
				
			||||||
 | 
					    document.getElementById("playlist-browser").style.display = "none";
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					tab_playlists.addEventListener("click", e => {
 | 
				
			||||||
 | 
					  fetch(`${API_URL}/playlists`).then(async r => {
 | 
				
			||||||
 | 
					    if (r.status === 200) {
 | 
				
			||||||
 | 
					      const playlists = await r.json();
 | 
				
			||||||
 | 
					      control_playlist_list.options.length = 0;  // clear playlists
 | 
				
			||||||
 | 
					      playlists.forEach(p => {
 | 
				
			||||||
 | 
					        const option = document.createElement("option")
 | 
				
			||||||
 | 
					        option.innerText = p["playlist"];
 | 
				
			||||||
 | 
					        option.value = p["playlist"];
 | 
				
			||||||
 | 
					        option.addEventListener("click", () => {
 | 
				
			||||||
 | 
					          fetch(`${API_URL}/playlists/${p["playlist"]}`).then(async r => {
 | 
				
			||||||
 | 
					            if (r.status === 200) {
 | 
				
			||||||
 | 
					              const songs = await r.json();
 | 
				
			||||||
 | 
					              console.log(songs)
 | 
				
			||||||
 | 
					              result_table.innerHTML = "";
 | 
				
			||||||
 | 
					              songs.forEach(song => {
 | 
				
			||||||
 | 
					                const tr = document.createElement("tr");
 | 
				
			||||||
 | 
					                const artist = document.createElement("td");
 | 
				
			||||||
 | 
					                artist.innerText = song["Artist"];
 | 
				
			||||||
 | 
					                const title = document.createElement("td");
 | 
				
			||||||
 | 
					                title.innerText = song["Title"];
 | 
				
			||||||
 | 
					                const time = document.createElement("td");
 | 
				
			||||||
 | 
					                time.innerText = secondsToTrackTime(parseInt(song["Time"]))
 | 
				
			||||||
 | 
					                tr.appendChild(artist);
 | 
				
			||||||
 | 
					                tr.appendChild(title);
 | 
				
			||||||
 | 
					                tr.appendChild(document.createElement("td")); // album
 | 
				
			||||||
 | 
					                tr.appendChild(document.createElement("td")); // genre
 | 
				
			||||||
 | 
					                tr.appendChild(time);
 | 
				
			||||||
 | 
					                result_table.appendChild(tr);
 | 
				
			||||||
 | 
					              });
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          })
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					        control_playlist_list.appendChild(option)
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  });
 | 
				
			||||||
 | 
					  if (!tab_playlists.classList.contains("active")) {
 | 
				
			||||||
 | 
					    tab_browser.classList.remove("active");
 | 
				
			||||||
 | 
					    tab_search.classList.remove("active")
 | 
				
			||||||
 | 
					    tab_playlists.classList.add("active")
 | 
				
			||||||
 | 
					    document.getElementById("file-browser").style.display = "none";
 | 
				
			||||||
 | 
					    document.getElementById("search").style.display = "none";
 | 
				
			||||||
 | 
					    document.getElementById("playlist-browser").style.display = "block";
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Add API calls to controls
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					control_update_db.addEventListener("click", e => {
 | 
				
			||||||
  console.log("Issuing database update")
 | 
					  console.log("Issuing database update")
 | 
				
			||||||
  fetch(`${API_URL}/update_db`).then(async r => {
 | 
					  fetch(`${API_URL}/update_db`).then(async r => {
 | 
				
			||||||
    if (r.status === 200) {
 | 
					    if (r.status === 200) {
 | 
				
			||||||
| 
						 | 
					@ -472,3 +544,4 @@ window.setInterval(() => {
 | 
				
			||||||
    connection_state.innerHTML = "❌ Disconnected";  // ❌ Cross Mark
 | 
					    connection_state.innerHTML = "❌ Disconnected";  // ❌ Cross Mark
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}, 1000);
 | 
					}, 1000);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue