mirror of
https://github.com/idanoo/GoScrobble.git
synced 2024-11-24 17:35:16 +00:00
Add extra info to track page + API
This commit is contained in:
parent
97dd3e5bba
commit
f914575e09
@ -75,8 +75,8 @@ func main() {
|
|||||||
defer goscrobble.CloseRedisConn()
|
defer goscrobble.CloseRedisConn()
|
||||||
|
|
||||||
// Start background workers
|
// Start background workers
|
||||||
go goscrobble.StartBackgroundWorkers()
|
// go goscrobble.StartBackgroundWorkers()
|
||||||
defer goscrobble.EndBackgroundWorkers()
|
// defer goscrobble.EndBackgroundWorkers()
|
||||||
|
|
||||||
// Boot up API webserver \o/
|
// Boot up API webserver \o/
|
||||||
goscrobble.HandleRequests(port)
|
goscrobble.HandleRequests(port)
|
||||||
|
@ -554,12 +554,20 @@ func getTrack(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Load track obj
|
||||||
track, err := getTrackByUUID(uuid)
|
track, err := getTrackByUUID(uuid)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
throwOkError(w, err.Error())
|
throwOkError(w, err.Error())
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Load in Album/Artist info
|
||||||
|
err = track.loadExtraTrackInfo()
|
||||||
|
if err != nil {
|
||||||
|
throwOkError(w, err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
json, _ := json.Marshal(&track)
|
json, _ := json.Marshal(&track)
|
||||||
w.WriteHeader(http.StatusOK)
|
w.WriteHeader(http.StatusOK)
|
||||||
w.Write(json)
|
w.Write(json)
|
||||||
|
@ -9,13 +9,15 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Track struct {
|
type Track struct {
|
||||||
UUID string `json:"uuid"`
|
UUID string `json:"uuid"`
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Length int `json:"length"`
|
Length int `json:"length"`
|
||||||
Desc string `json:"desc"`
|
Desc string `json:"desc"`
|
||||||
Img string `json:"img"`
|
Img string `json:"img"`
|
||||||
MusicBrainzID string `json:"mbid"`
|
MusicBrainzID string `json:"mbid"`
|
||||||
SpotifyID string `json:"spotify_id"`
|
SpotifyID string `json:"spotify_id"`
|
||||||
|
Artists []Artist `json:"artists"` // Optional Artist
|
||||||
|
Albums []Album `json:"albums"` // Optional Albums
|
||||||
}
|
}
|
||||||
|
|
||||||
type TopTrack struct {
|
type TopTrack struct {
|
||||||
@ -219,3 +221,76 @@ func getTopTracks(userUuid string) (TopTracks, error) {
|
|||||||
|
|
||||||
return topTracks, nil
|
return topTracks, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (track *Track) loadExtraTrackInfo() error {
|
||||||
|
err := track.getArtistsForTrack()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = track.getAlbumsForTrack()
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (track *Track) getArtistsForTrack() error {
|
||||||
|
artists := []Artist{}
|
||||||
|
|
||||||
|
rows, err := db.Query("SELECT BIN_TO_UUID(`track_artist`.`artist`, true) "+
|
||||||
|
"FROM `track_artist` "+
|
||||||
|
"WHERE `track_artist`.`track` = UUID_TO_BIN(?, true)",
|
||||||
|
track.UUID)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Failed to fetch artists for track: %+v", err)
|
||||||
|
return errors.New("Failed to fetch top tracks")
|
||||||
|
}
|
||||||
|
defer rows.Close()
|
||||||
|
|
||||||
|
for rows.Next() {
|
||||||
|
var artistUUID string
|
||||||
|
err := rows.Scan(&artistUUID)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Failed to fetch track_artist: %+v", err)
|
||||||
|
return errors.New("Failed to fetch track")
|
||||||
|
}
|
||||||
|
|
||||||
|
artist, err := getArtistByUUID(artistUUID)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
artists = append(artists, artist)
|
||||||
|
}
|
||||||
|
|
||||||
|
track.Artists = artists
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (track *Track) getAlbumsForTrack() error {
|
||||||
|
albums := []Album{}
|
||||||
|
|
||||||
|
rows, err := db.Query("SELECT BIN_TO_UUID(`track_album`.`album`, true) "+
|
||||||
|
"FROM `track_album` "+
|
||||||
|
"WHERE `track_album`.`track` = UUID_TO_BIN(?, true)",
|
||||||
|
track.UUID)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Failed to fetch album for track: %+v", err)
|
||||||
|
return errors.New("Failed to fetch top tracks")
|
||||||
|
}
|
||||||
|
defer rows.Close()
|
||||||
|
|
||||||
|
for rows.Next() {
|
||||||
|
var albumUUID string
|
||||||
|
err := rows.Scan(&albumUUID)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Failed to fetch track_album: %+v", err)
|
||||||
|
return errors.New("Failed to fetch track")
|
||||||
|
}
|
||||||
|
|
||||||
|
album, err := getAlbumByUUID(albumUUID)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
albums = append(albums, album)
|
||||||
|
}
|
||||||
|
|
||||||
|
track.Albums = albums
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -145,7 +145,7 @@ func filterSlice(s []string) []string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var result []string
|
var result []string
|
||||||
for item, _ := range m {
|
for item := range m {
|
||||||
result = append(result, item)
|
result = append(result, item)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1 +0,0 @@
|
|||||||
DROP TABLE IF EXISTS `files`;
|
|
@ -1,7 +0,0 @@
|
|||||||
CREATE TABLE IF NOT EXISTS `files` (
|
|
||||||
`uuid` BINARY(16) PRIMARY KEY,
|
|
||||||
`path` VARCHAR(255) NOT NULL,
|
|
||||||
`filesize` INT NULL DEFAULT NULL,
|
|
||||||
`dimension` VARCHAR(4) NOT NULL,
|
|
||||||
KEY `dimensionLookup` (`uuid`, `dimension`)
|
|
||||||
) DEFAULT CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci;
|
|
5706
web/package-lock.json
generated
5706
web/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -51,7 +51,6 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"redux-devtools-extension": "^2.13.9",
|
"redux-devtools-extension": "^2.13.9"
|
||||||
"webpack-dev-server": "^3.11.1"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ import '../App.css';
|
|||||||
import './Track.css';
|
import './Track.css';
|
||||||
import ScaleLoader from 'react-spinners/ScaleLoader';
|
import ScaleLoader from 'react-spinners/ScaleLoader';
|
||||||
import { getTrack } from '../Api/index'
|
import { getTrack } from '../Api/index'
|
||||||
|
import { Link } from 'react-router-dom';
|
||||||
|
|
||||||
const Track = (route) => {
|
const Track = (route) => {
|
||||||
const [loading, setLoading] = useState(true);
|
const [loading, setLoading] = useState(true);
|
||||||
@ -49,18 +50,53 @@ const Track = (route) => {
|
|||||||
length = new Date(track.length * 1000).toISOString().substr(11, 8)
|
length = new Date(track.length * 1000).toISOString().substr(11, 8)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let artists = [];
|
||||||
|
for (let artist of track.artists) {
|
||||||
|
const row = (
|
||||||
|
<Link
|
||||||
|
key={artist.uuid}
|
||||||
|
to={"/artist/" + artist.uuid}
|
||||||
|
>{artist.name} </Link>
|
||||||
|
);
|
||||||
|
artists.push(row);
|
||||||
|
}
|
||||||
|
|
||||||
|
let albums = [];
|
||||||
|
for (let album of track.albums) {
|
||||||
|
const row = (
|
||||||
|
<Link
|
||||||
|
key={album.uuid}
|
||||||
|
to={"/album/" + album.uuid}
|
||||||
|
>{album.name} </Link>
|
||||||
|
);
|
||||||
|
albums.push(row);
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="pageWrapper">
|
<div className="pageWrapper">
|
||||||
<h1>
|
<div className="pageBody">
|
||||||
{track.name}
|
<div style={{display: `flex`, flexWrap: `wrap`, textAlign: `center`}}>
|
||||||
</h1>
|
<div style={{width: `300px`, padding: `0 10px 10px 10px`, textAlign: `left`}}>
|
||||||
|
<h1 style={{margin: 0}}>
|
||||||
<div className="pageBody" style={{textAlign: `center`}}>
|
{track.name}
|
||||||
<img src={process.env.REACT_APP_API_URL + "/img/" + track.img + "_full.jpg"} alt={track.name} style={{maxWidth: `300px`, maxHeight: `300px`}}/><br/><br/>
|
</h1>
|
||||||
{track.mbid && <a rel="noreferrer" target="_blank" href={"https://musicbrainz.org/track/" + track.mbid}>Open on MusicBrainz<br/></a>}
|
<span>
|
||||||
{track.spotify_id && <a rel="noreferrer" target="_blank" href={"https://open.spotify.com/track/" + track.spotify_id}>Open on Spotify<br/></a>}
|
{artists}
|
||||||
Track Length: {length && length}
|
</span>
|
||||||
|
<br/>
|
||||||
|
<span>
|
||||||
|
{albums}
|
||||||
|
</span>
|
||||||
|
<img src={process.env.REACT_APP_API_URL + "/img/" + track.img + "_full.jpg"} alt={track.name} style={{maxWidth: `300px`, maxHeight: `300px`}}/><br/><br/>
|
||||||
|
{track.mbid && <a rel="noreferrer" target="_blank" href={"https://musicbrainz.org/track/" + track.mbid}>Open on MusicBrainz<br/></a>}
|
||||||
|
{track.spotify_id && <a rel="noreferrer" target="_blank" href={"https://open.spotify.com/track/" + track.spotify_id}>Open on Spotify<br/></a>}
|
||||||
|
Track Length: {length && length}
|
||||||
|
</div>
|
||||||
|
<div style={{width: `600px`, padding: `0 10px 10px 10px`}}>
|
||||||
|
<h3>Top Users</h3>
|
||||||
|
<br/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
Loading…
Reference in New Issue
Block a user