mirror of
https://github.com/tcsenpai/swingmusic.git
synced 2025-07-28 13:41:42 +00:00
implement show copyright info on album page
+ rewrite server track and album models to use destructuring
This commit is contained in:
parent
7b2e162ed4
commit
327207f1ab
@ -1,8 +1,6 @@
|
||||
"""
|
||||
Contains all the folder routes.
|
||||
"""
|
||||
from app import api
|
||||
from app import helpers
|
||||
from app import settings
|
||||
from app.lib.folderslib import getFnF
|
||||
from flask import Blueprint
|
||||
|
@ -143,6 +143,7 @@ def create_album(track: models.Track) -> dict:
|
||||
"title": track.album,
|
||||
"artist": track.albumartist,
|
||||
"hash": track.albumhash,
|
||||
"copyright": track.copyright,
|
||||
}
|
||||
|
||||
album["date"] = track.date
|
||||
|
@ -3,6 +3,7 @@ Contains all the models for objects generation and typing.
|
||||
"""
|
||||
from dataclasses import dataclass
|
||||
from dataclasses import field
|
||||
from operator import itemgetter
|
||||
from typing import List
|
||||
|
||||
from app import helpers
|
||||
@ -30,21 +31,37 @@ class Track:
|
||||
date: str
|
||||
image: str
|
||||
uniq_hash: str
|
||||
copyright: str
|
||||
|
||||
def __init__(self, tags):
|
||||
(
|
||||
self.title,
|
||||
self.album,
|
||||
self.albumartist,
|
||||
self.genre,
|
||||
self.albumhash,
|
||||
self.date,
|
||||
self.folder,
|
||||
self.filepath,
|
||||
self.copyright,
|
||||
) = itemgetter(
|
||||
"title",
|
||||
"album",
|
||||
"albumartist",
|
||||
"genre",
|
||||
"albumhash",
|
||||
"date",
|
||||
"folder",
|
||||
"filepath",
|
||||
"copyright",
|
||||
)(
|
||||
tags
|
||||
)
|
||||
self.trackid = tags["_id"]["$oid"]
|
||||
self.title = tags["title"]
|
||||
self.artists = tags["artists"].split(", ")
|
||||
self.albumartist = tags["albumartist"]
|
||||
self.album = tags["album"]
|
||||
self.folder = tags["folder"]
|
||||
self.filepath = tags["filepath"]
|
||||
self.genre = tags["genre"]
|
||||
self.bitrate = int(tags["bitrate"])
|
||||
self.length = int(tags["length"])
|
||||
self.discnumber = int(tags["discnumber"])
|
||||
self.albumhash = tags["albumhash"]
|
||||
self.date = tags["date"]
|
||||
self.image = tags["albumhash"] + ".webp"
|
||||
self.tracknumber = int(tags["tracknumber"])
|
||||
|
||||
@ -85,17 +102,21 @@ class Album:
|
||||
image: str
|
||||
count: int = 0
|
||||
duration: int = 0
|
||||
copyright: str = field(default="")
|
||||
is_soundtrack: bool = False
|
||||
is_compilation: bool = False
|
||||
is_single: bool = False
|
||||
colors: List[str] = field(default_factory=list)
|
||||
|
||||
def __init__(self, tags):
|
||||
self.title = tags["title"]
|
||||
self.artist = tags["artist"]
|
||||
self.date = tags["date"]
|
||||
self.image = tags["image"]
|
||||
self.hash = tags["hash"]
|
||||
(
|
||||
self.title,
|
||||
self.artist,
|
||||
self.date,
|
||||
self.image,
|
||||
self.hash,
|
||||
self.copyright,
|
||||
) = itemgetter("title", "artist", "date", "image", "hash", "copyright")(tags)
|
||||
|
||||
try:
|
||||
self.colors = tags["colors"]
|
||||
|
@ -22,6 +22,9 @@
|
||||
<div class="text">No tracks here</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="copyright" v-if="copyright">
|
||||
{{ copyright() }}
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
@ -46,6 +49,7 @@ const props = defineProps<{
|
||||
playlistid?: string;
|
||||
on_album_page?: boolean;
|
||||
disc?: string | number;
|
||||
copyright?: () => string;
|
||||
}>();
|
||||
|
||||
const route = useRoute();
|
||||
@ -140,6 +144,13 @@ function getTrackList() {
|
||||
padding: 1rem;
|
||||
}
|
||||
|
||||
.copyright {
|
||||
font-size: 0.8rem;
|
||||
margin-top: 1rem;
|
||||
text-align: center;
|
||||
opacity: 0.5;
|
||||
}
|
||||
|
||||
.table {
|
||||
height: 100%;
|
||||
overflow-y: hidden;
|
||||
|
@ -17,6 +17,7 @@ export interface Track {
|
||||
discnumber?: number;
|
||||
index?: number;
|
||||
uniq_hash: string;
|
||||
copyright?: string;
|
||||
}
|
||||
|
||||
export interface Folder {
|
||||
@ -40,6 +41,7 @@ export interface AlbumInfo {
|
||||
is_single: boolean;
|
||||
hash: string;
|
||||
colors: string[];
|
||||
copyright?: string;
|
||||
}
|
||||
|
||||
export interface Artist {
|
||||
@ -108,5 +110,3 @@ export interface FetchProps {
|
||||
put?: boolean;
|
||||
headers?: {};
|
||||
}
|
||||
|
||||
|
||||
|
@ -1,7 +1,19 @@
|
||||
<template>
|
||||
<div class="album-tracks rounded">
|
||||
<div v-for="(disc, key) in discs" class="album-disc">
|
||||
<SongList :key="key" :tracks="disc" :on_album_page="true" :disc="key" />
|
||||
<SongList
|
||||
:key="key"
|
||||
:tracks="disc"
|
||||
:on_album_page="true"
|
||||
:disc="key"
|
||||
:copyright="
|
||||
() => {
|
||||
if (isLastDisc(key)) {
|
||||
return copyright;
|
||||
}
|
||||
}
|
||||
"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
@ -10,11 +22,18 @@
|
||||
import { Track } from "@/interfaces";
|
||||
import SongList from "@/components/FolderView/SongList.vue";
|
||||
|
||||
defineProps<{
|
||||
const props = defineProps<{
|
||||
discs: {
|
||||
[key: string]: Track[];
|
||||
};
|
||||
copyright: string;
|
||||
}>();
|
||||
|
||||
// check if the disc is the last disc
|
||||
const isLastDisc = (disc: string | number) => {
|
||||
const discs = Object.keys(props.discs);
|
||||
return discs[discs.length - 1] === disc;
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="scss">
|
||||
|
@ -4,7 +4,7 @@
|
||||
<Header :album="album.info" />
|
||||
</template>
|
||||
<template #content>
|
||||
<Content :discs="album.discs" />
|
||||
<Content :discs="album.discs" :copyright="album.info.copyright" />
|
||||
</template>
|
||||
<template #bottom>
|
||||
<Bottom
|
||||
|
Loading…
x
Reference in New Issue
Block a user