mirror of
https://github.com/csd4ni3l/music-player.git
synced 2026-01-01 04:03:42 +01:00
Add cover art cache, more caching and optimization for metadata, global metadata search, fix some scaling issues, add example tracks for albums and artists, urls for artists, remove play button
This commit is contained in:
117
menus/global_search.py
Normal file
117
menus/global_search.py
Normal file
@@ -0,0 +1,117 @@
|
||||
import arcade, arcade.gui
|
||||
|
||||
from utils.preload import music_icon, person_icon, button_texture, button_hovered_texture
|
||||
from utils.constants import button_style
|
||||
from utils.utils import Card, MouseAwareScrollArea, get_wordwrapped_text
|
||||
from utils.online_metadata import search_recordings, search_artists, search_albums, get_artists_metadata, get_album_metadata
|
||||
|
||||
from arcade.gui.experimental.focus import UIFocusGroup
|
||||
from arcade.gui.experimental.scroll_area import UIScrollBar
|
||||
|
||||
class GlobalSearch(arcade.gui.UIView):
|
||||
def __init__(self, pypresence_client, *args):
|
||||
super().__init__()
|
||||
|
||||
self.args = args
|
||||
self.pypresence_client = pypresence_client
|
||||
|
||||
self.anchor = self.add_widget(UIFocusGroup(size_hint=(1, 1)))
|
||||
|
||||
def on_show_view(self):
|
||||
super().on_show_view()
|
||||
|
||||
self.anchor.detect_focusable_widgets()
|
||||
|
||||
self.ui_box = self.anchor.add(arcade.gui.UIBoxLayout(size_hint=(0.99, 0.99), space_between=10), anchor_x="center", anchor_y="center")
|
||||
|
||||
self.search_box = self.ui_box.add(arcade.gui.UIBoxLayout(size_hint=(1, 0.075), space_between=10, vertical=False))
|
||||
|
||||
self.back_button = self.search_box.add(arcade.gui.UITextureButton(texture=button_texture, texture_hovered=button_hovered_texture, text='<--', style=button_style, width=100, height=50))
|
||||
self.back_button.on_click = lambda event: self.main_exit()
|
||||
|
||||
self.search_bar = self.search_box.add(arcade.gui.UIInputText(width=self.window.width / 2, height=self.window.height / 20, font_size=20))
|
||||
self.search_bar.on_change = lambda event: self.fix_searchbar_text()
|
||||
self.search_type_dropdown = self.search_box.add(arcade.gui.UIDropdown(options=["Music", "Artist", "Album"], default="Music", primary_style=button_style, active_style=button_style, dropdown_style=button_style, width=self.window.width / 4, height=self.window.height / 20))
|
||||
|
||||
self.scroll_box = self.ui_box.add(arcade.gui.UIBoxLayout(size_hint=(1, 0.925), space_between=15, vertical=False))
|
||||
|
||||
self.scroll_area = MouseAwareScrollArea(size_hint=(1, 1))
|
||||
self.scroll_area.scroll_speed = -50
|
||||
self.scroll_box.add(self.scroll_area)
|
||||
|
||||
self.scrollbar = UIScrollBar(self.scroll_area)
|
||||
self.scrollbar.size_hint = (0.02, 1)
|
||||
self.scroll_box.add(self.scrollbar)
|
||||
|
||||
self.search_results_grid = arcade.gui.UIGridLayout(horizontal_spacing=25, vertical_spacing=25, column_count=8, row_count=999)
|
||||
self.scroll_area.add(self.search_results_grid)
|
||||
|
||||
self.nothing_searched_label = self.anchor.add(arcade.gui.UILabel(text="Search for something to get results!", font_name="Roboto", font_size=24), anchor_x="center", anchor_y="center")
|
||||
self.nothing_searched_label.visible = True
|
||||
|
||||
def fix_searchbar_text(self):
|
||||
self.search_bar.text = self.search_bar.text.encode("ascii", "ignore").decode().strip("\n")
|
||||
|
||||
def on_key_press(self, symbol, modifiers):
|
||||
if symbol == arcade.key.ENTER:
|
||||
self.fix_searchbar_text()
|
||||
self.search()
|
||||
|
||||
def search(self):
|
||||
search_type = self.search_type_dropdown.value
|
||||
search_term = self.search_bar.text
|
||||
|
||||
self.search_results_grid.clear()
|
||||
|
||||
if search_type == "Music":
|
||||
recordings = search_recordings(search_term)
|
||||
|
||||
self.nothing_searched_label.visible = not bool(recordings)
|
||||
|
||||
for n, metadata in enumerate(recordings):
|
||||
row = n // 7
|
||||
col = n % 7
|
||||
|
||||
card = self.search_results_grid.add(Card(music_icon, get_wordwrapped_text(metadata[1]), get_wordwrapped_text(metadata[0]), width=self.window.width / 7, height=self.window.width / 7), row=row, column=col)
|
||||
card.button.on_click = lambda event, metadata=metadata: self.open_metadata_viewer(metadata[2], metadata[0], metadata[1])
|
||||
|
||||
elif search_type == "Artist":
|
||||
artists = search_artists(search_term)
|
||||
|
||||
self.nothing_searched_label.visible = not bool(artists)
|
||||
|
||||
for n, metadata in enumerate(artists):
|
||||
row = n // 7
|
||||
col = n % 7
|
||||
|
||||
card = self.search_results_grid.add(Card(person_icon, get_wordwrapped_text(metadata[0]), None, width=self.window.width / 7, height=self.window.width / 4.5), row=row, column=col)
|
||||
card.button.on_click = lambda event, metadata=metadata: self.open_metadata_viewer(metadata[1])
|
||||
else:
|
||||
albums = search_albums(search_term)
|
||||
|
||||
self.nothing_searched_label.visible = not bool(albums)
|
||||
|
||||
for n, metadata in enumerate(albums):
|
||||
row = n // 7
|
||||
col = n % 7
|
||||
|
||||
card = self.search_results_grid.add(Card(music_icon, get_wordwrapped_text(metadata[1]), get_wordwrapped_text(metadata[0]), width=self.window.width / 7, height=self.window.width / 7), row=row, column=col)
|
||||
card.button.on_click = lambda event, metadata=metadata: self.open_metadata_viewer(metadata[2])
|
||||
|
||||
self.search_results_grid.row_count = row + 1
|
||||
self.search_results_grid._update_size_hints()
|
||||
|
||||
def open_metadata_viewer(self, musicbrainz_id, artist=None, title=None):
|
||||
content_type = self.search_type_dropdown.value.lower()
|
||||
|
||||
from menus.metadata_viewer import MetadataViewer
|
||||
if content_type == "music":
|
||||
self.window.show_view(MetadataViewer(self.pypresence_client, content_type, {"artist": artist, "title": title, "id": musicbrainz_id}, None, *self.args))
|
||||
elif content_type == "artist":
|
||||
self.window.show_view(MetadataViewer(self.pypresence_client, content_type, get_artists_metadata([musicbrainz_id])))
|
||||
elif content_type == "album":
|
||||
self.window.show_view(MetadataViewer(self.pypresence_client, content_type, {musicbrainz_id: get_album_metadata(musicbrainz_id)}))
|
||||
|
||||
def main_exit(self):
|
||||
from menus.main import Main
|
||||
self.window.show_view(Main(self.pypresence_client, *self.args))
|
||||
@@ -3,7 +3,7 @@ import arcade, pyglet
|
||||
|
||||
from utils.preload import *
|
||||
from utils.constants import button_style, slider_style, audio_extensions, discord_presence_id
|
||||
from utils.utils import FakePyPresence, UIFocusTextureButton, MusicItem, MouseAwareScrollArea
|
||||
from utils.utils import FakePyPresence, UIFocusTextureButton, Card, MouseAwareScrollArea, get_wordwrapped_text
|
||||
from utils.music_handling import update_last_play_statistics, extract_metadata_and_thumbnail, adjust_volume, truncate_end
|
||||
from utils.file_watching import watch_directories, watch_files
|
||||
|
||||
@@ -123,7 +123,7 @@ class Main(arcade.gui.UIView):
|
||||
self.scrollbar.size_hint = (0.02, 1)
|
||||
self.scroll_box.add(self.scrollbar)
|
||||
|
||||
self.music_grid = arcade.gui.UIGridLayout(horizontal_spacing=10, vertical_spacing=10, row_count=99, column_count=7)
|
||||
self.music_grid = arcade.gui.UIGridLayout(horizontal_spacing=10, vertical_spacing=10, row_count=99, column_count=8)
|
||||
self.scroll_area.add(self.music_grid)
|
||||
|
||||
# Controls
|
||||
@@ -179,7 +179,10 @@ class Main(arcade.gui.UIView):
|
||||
self.volume_slider.on_change = self.on_volume_slider_change
|
||||
|
||||
self.tools_box = self.anchor.add(arcade.gui.UIBoxLayout(space_between=15, vertical=False), anchor_x="right", anchor_y="bottom", align_x=-15, align_y=15)
|
||||
|
||||
|
||||
self.global_search_button = self.tools_box.add(UIFocusTextureButton(texture=global_search_icon, style=button_style))
|
||||
self.global_search_button.on_click = lambda event: self.global_search()
|
||||
|
||||
self.metadata_button = self.tools_box.add(UIFocusTextureButton(texture=metadata_icon, style=button_style))
|
||||
self.metadata_button.on_click = lambda event: self.view_metadata(self.current_music_path) if self.current_music_path else None
|
||||
|
||||
@@ -291,7 +294,7 @@ class Main(arcade.gui.UIView):
|
||||
|
||||
def view_metadata(self, file_path):
|
||||
from menus.metadata_viewer import MetadataViewer
|
||||
self.window.show_view(MetadataViewer(self.pypresence_client, "music", self.file_metadata[file_path], file_path, self.current_tab, self.current_mode, self.current_music_artist, self.current_music_title, self.current_music_path, self.current_length, self.current_music_player, self.queue, self.loaded_sounds, self.shuffle))
|
||||
self.window.show_view(MetadataViewer(self.pypresence_client, "file", self.file_metadata[file_path], file_path, self.current_tab, self.current_mode, self.current_music_artist, self.current_music_title, self.current_music_path, self.current_length, self.current_music_player, self.queue, self.loaded_sounds, self.shuffle))
|
||||
|
||||
def show_content(self, tab, content_type):
|
||||
for music_button in self.music_buttons.values():
|
||||
@@ -309,8 +312,12 @@ class Main(arcade.gui.UIView):
|
||||
|
||||
if not self.search_term == "":
|
||||
matches = process.extract(self.search_term, original_content, limit=5, processor=lambda text: text.lower(), scorer=fuzz.partial_token_sort_ratio)
|
||||
self.highest_score_file = f"{self.current_tab}/{matches[0][0]}"
|
||||
content_to_show = [match[0] for match in matches]
|
||||
if matches:
|
||||
self.highest_score_file = f"{self.current_tab}/{matches[0][0]}"
|
||||
content_to_show = [match[0] for match in matches]
|
||||
else:
|
||||
self.highest_score_file = ""
|
||||
self.content_to_show = []
|
||||
|
||||
else:
|
||||
self.highest_score_file = ""
|
||||
@@ -321,8 +328,8 @@ class Main(arcade.gui.UIView):
|
||||
row, col = 0, 0
|
||||
|
||||
for n, music_filename in enumerate(content_to_show):
|
||||
row = n // 7
|
||||
col = n % 7
|
||||
row = n // 8
|
||||
col = n % 8
|
||||
|
||||
if self.current_mode == "files":
|
||||
music_path = f"{tab}/{music_filename}"
|
||||
@@ -331,17 +338,17 @@ class Main(arcade.gui.UIView):
|
||||
|
||||
metadata = self.file_metadata[music_path]
|
||||
|
||||
self.music_buttons[music_path] = self.music_grid.add(MusicItem(metadata=metadata, width=self.window.width / 8, height=self.window.height / 5), row=row, column=col)
|
||||
self.music_buttons[music_path] = self.music_grid.add(Card(metadata["thumbnail"], get_wordwrapped_text(metadata["title"]), get_wordwrapped_text(metadata["artist"]), width=self.window.width / 9, height=self.window.width / 9), row=row, column=col)
|
||||
self.music_buttons[music_path].button.on_click = lambda event, music_path=music_path: self.music_button_click(event, music_path)
|
||||
|
||||
row = (n + 1) // 7
|
||||
col = (n + 1) % 7
|
||||
row = (n + 1) // 8
|
||||
col = (n + 1) % 8
|
||||
|
||||
self.music_grid.row_count = row + 1
|
||||
self.music_grid._update_size_hints()
|
||||
|
||||
if self.current_mode == "playlist":
|
||||
self.music_buttons["add_music"] = self.music_grid.add(MusicItem(metadata=None, width=self.window.width / 8, height=self.window.height / 5), row=row, column=col)
|
||||
self.music_buttons["add_music"] = self.music_grid.add(Card(music_icon, "Add Music", None, width=self.window.width / 9, height=self.window.width / 9), row=row, column=col)
|
||||
self.music_buttons["add_music"].button.on_click = lambda event: self.add_music()
|
||||
|
||||
self.anchor.detect_focusable_widgets()
|
||||
@@ -358,8 +365,7 @@ class Main(arcade.gui.UIView):
|
||||
with open("settings.json", "w") as file:
|
||||
file.write(json.dumps(self.settings_dict, indent=4))
|
||||
|
||||
self.window.show_view(Main(self.pypresence_client, self.current_mode, self.current_music_artist, self.current_music_title, self.current_music_path, # temporarily fixes the issue of bad resolution after deletion with less than 2 rows
|
||||
self.current_length, self.current_music_player, self.queue, self.loaded_sounds, self.shuffle))
|
||||
self.window.show_view(Main(self.pypresence_client, self.current_tab, self.current_mode, self.current_music_artist, self.current_music_title, self.current_music_path, self.current_length, self.current_music_player, self.queue, self.loaded_sounds, self.shuffle))
|
||||
|
||||
def load_content(self):
|
||||
self.tab_content.clear()
|
||||
@@ -531,6 +537,12 @@ class Main(arcade.gui.UIView):
|
||||
elif self.current_mode == "playlist":
|
||||
self.show_content(self.current_tab, "playlist")
|
||||
|
||||
def global_search(self):
|
||||
from menus.global_search import GlobalSearch
|
||||
arcade.unschedule(self.update_presence)
|
||||
self.ui.clear()
|
||||
self.window.show_view(GlobalSearch(self.pypresence_client, self.current_tab, self.current_mode, self.current_music_artist, self.current_music_title, self.current_music_path, self.current_length, self.current_music_player, self.queue, self.loaded_sounds, self.shuffle))
|
||||
|
||||
def settings(self):
|
||||
from menus.settings import Settings
|
||||
arcade.unschedule(self.update_presence)
|
||||
|
||||
@@ -3,34 +3,33 @@ import arcade, arcade.gui, webbrowser
|
||||
from arcade.gui.experimental.focus import UIFocusGroup
|
||||
from arcade.gui.experimental.scroll_area import UIScrollArea, UIScrollBar
|
||||
|
||||
from utils.online_metadata import get_music_metadata, get_album_cover_art
|
||||
from utils.online_metadata import get_music_metadata, download_albums_cover_art
|
||||
from utils.constants import button_style
|
||||
from utils.preload import button_texture, button_hovered_texture
|
||||
from utils.utils import convert_seconds_to_date
|
||||
from utils.music_handling import convert_timestamp_to_time_ago
|
||||
from utils.music_handling import convert_timestamp_to_time_ago, truncate_end
|
||||
|
||||
class MetadataViewer(arcade.gui.UIView):
|
||||
def __init__(self, pypresence_client, metadata_type="music", metadata=None, file_path=None, *args):
|
||||
def __init__(self, pypresence_client, metadata_type="file", metadata=None, file_path=None, *args):
|
||||
super().__init__()
|
||||
self.metadata_type = metadata_type
|
||||
if metadata_type == "music":
|
||||
if metadata_type == "file":
|
||||
self.file_metadata = metadata
|
||||
self.artist = self.file_metadata["artist"]
|
||||
self.file_path = file_path
|
||||
if self.artist == "Unknown":
|
||||
self.artist = None
|
||||
|
||||
self.artist = self.file_metadata["artist"] if not self.file_metadata["artist"] == "Unknown" else None
|
||||
self.title = self.file_metadata["title"]
|
||||
|
||||
self.online_metadata = get_music_metadata(self.artist, self.title)
|
||||
self.music_metadata, self.artist_metadata, self.album_metadata, self.lyrics_metadata = get_music_metadata(self.artist, self.title)
|
||||
elif metadata_type == "music":
|
||||
self.artist = metadata["artist"]
|
||||
self.title = metadata["title"]
|
||||
|
||||
self.music_metadata, self.artist_metadata, self.album_metadata, self.lyrics_metadata = get_music_metadata(musicbrainz_id=metadata["id"])
|
||||
elif metadata_type == "artist":
|
||||
self.artist_metadata = metadata
|
||||
elif metadata_type == "album":
|
||||
self.album_metadata = metadata
|
||||
elif metadata_type:
|
||||
self.artist = metadata["artist"]
|
||||
self.title = metadata["title"]
|
||||
self.music_lyrics = metadata["lyrics"]
|
||||
|
||||
self.pypresence_client = pypresence_client
|
||||
self.args = args
|
||||
@@ -42,7 +41,6 @@ class MetadataViewer(arcade.gui.UIView):
|
||||
|
||||
self.anchor = self.add_widget(UIFocusGroup(size_hint=(1, 1)))
|
||||
self.back_button = self.anchor.add(arcade.gui.UITextureButton(texture=button_texture, texture_hovered=button_hovered_texture, text='<--', style=button_style, width=100, height=50), anchor_x="left", anchor_y="top", align_x=5, align_y=-5)
|
||||
self.back_button.on_click = lambda event: self.main_exit()
|
||||
|
||||
self.scroll_area = UIScrollArea(size_hint=(0.6, 0.8)) # center on screen
|
||||
self.scroll_area.scroll_speed = -50
|
||||
@@ -52,24 +50,43 @@ class MetadataViewer(arcade.gui.UIView):
|
||||
self.scrollbar.size_hint = (0.02, 1)
|
||||
self.anchor.add(self.scrollbar, anchor_x="right", anchor_y="center")
|
||||
|
||||
self.box = arcade.gui.UIBoxLayout(space_between=10, align='top')
|
||||
self.box = arcade.gui.UIBoxLayout(space_between=10, align='center')
|
||||
self.scroll_area.add(self.box)
|
||||
|
||||
self.more_metadata_box = self.anchor.add(arcade.gui.UIBoxLayout(space_between=10, vertical=False), anchor_x="left", anchor_y="bottom", align_x=10, align_y=10)
|
||||
|
||||
if self.metadata_type == "music":
|
||||
tags = ', '.join(self.online_metadata[0]['tags'])
|
||||
albums = ', '.join(list(self.online_metadata[2].keys()))
|
||||
name = f"{self.file_metadata['artist']} - {self.file_metadata['title']} Metadata"
|
||||
metadata_text = f'''File path: {self.file_path}
|
||||
File Artist(s): {self.file_metadata['artist']}
|
||||
MusicBrainz Artist(s): {', '.join([artist for artist in self.online_metadata[1]])}
|
||||
Title: {self.file_metadata['title']}
|
||||
MusicBrainz ID: {self.online_metadata[0]['musicbrainz_id']}
|
||||
ISRC(s): {', '.join(self.online_metadata[0]['isrc-list']) if self.online_metadata[0]['isrc-list'] else "None"}
|
||||
MusicBrainz Rating: {self.online_metadata[0]['musicbrainz_rating']}
|
||||
self.show_metadata()
|
||||
|
||||
def show_metadata(self):
|
||||
if self.metadata_type == "file":
|
||||
self.back_button.on_click = lambda event: self.main_exit()
|
||||
elif self.metadata_type == "music":
|
||||
self.back_button.on_click = lambda event: self.global_search()
|
||||
else:
|
||||
self.back_button.on_click = lambda event: self.reset_to_music_view()
|
||||
|
||||
self.more_metadata_buttons.clear()
|
||||
self.metadata_labels.clear()
|
||||
|
||||
self.box.clear()
|
||||
self.more_metadata_box.clear()
|
||||
|
||||
if self.metadata_type in ["file", "music"]:
|
||||
tags = ', '.join(self.music_metadata['tags'])
|
||||
albums = truncate_end(', '.join([album["album_name"] for album in self.album_metadata.values()]), 50)
|
||||
name = f"{self.artist} - {self.title} Metadata"
|
||||
musicbrainz_metadata_text = f'''MusicBrainz Artist(s): {', '.join([artist for artist in self.artist_metadata])}
|
||||
MusicBrainz ID: {self.music_metadata['musicbrainz_id']}
|
||||
ISRC(s): {', '.join(self.music_metadata['isrc-list']) if self.music_metadata['isrc-list'] else "None"}
|
||||
MusicBrainz Rating: {self.music_metadata['musicbrainz_rating']}
|
||||
Tags: {tags if tags else 'None'}
|
||||
Albums: {albums if albums else 'None'}
|
||||
Albums: {albums if albums else 'None'}'''
|
||||
if self.metadata_type == "file":
|
||||
metadata_text = f'''File path: {self.file_path}
|
||||
File Artist(s): {self.file_metadata['artist']}
|
||||
Title: {self.file_metadata['title']}
|
||||
|
||||
{musicbrainz_metadata_text}
|
||||
|
||||
File size: {self.file_metadata['file_size']}MiB
|
||||
Upload Year: {self.file_metadata['upload_year'] or 'Unknown'}
|
||||
@@ -77,25 +94,26 @@ Amount of times played: {self.file_metadata['play_count']}
|
||||
Last Played: {convert_timestamp_to_time_ago(int(self.file_metadata['last_played']))}
|
||||
Sound length: {convert_seconds_to_date(int(self.file_metadata['sound_length']))}
|
||||
Bitrate: {self.file_metadata['bitrate']}Kbps
|
||||
Sample rate: {self.file_metadata['sample_rate']}KHz
|
||||
'''
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Artist Metadata", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 5.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: self.window.show_view(MetadataViewer(self.pypresence_client, "artist", self.online_metadata[1], None, *self.args))
|
||||
Sample rate: {self.file_metadata['sample_rate']}KHz'''
|
||||
else:
|
||||
metadata_text = musicbrainz_metadata_text
|
||||
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Album Metadata", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 5.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: self.window.show_view(MetadataViewer(self.pypresence_client, "album", self.online_metadata[2], None, *self.args))
|
||||
metadata_text += f"\n\nLyrics:\n{self.lyrics_metadata}"
|
||||
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Lyrics", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 5.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: self.window.show_view(MetadataViewer(self.pypresence_client, "lyrics", {"artist": self.artist, "title": self.title, "lyrics": self.online_metadata[3]}, None, *self.args))
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Artist Metadata", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 4.5 if self.metadata_type == "file" else self.window.width / 2.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: self.show_artist_metadata()
|
||||
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Open Uploader URL", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 5.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: webbrowser.open(self.file_metadata["uploader_url"]) if not self.file_metadata.get("uploader_url", "Unknown") == "Unknown" else None
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Album Metadata", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 4.5 if self.metadata_type == "file" else self.window.width / 2.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: self.show_album_metadata()
|
||||
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Open Source URL", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 5.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: webbrowser.open(self.file_metadata["source_url"]) if not self.file_metadata.get("source_url", "Unknown") == "Unknown" else None
|
||||
if self.metadata_type == "file":
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Open Uploader URL", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 4.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: webbrowser.open(self.file_metadata["uploader_url"]) if not self.file_metadata.get("uploader_url", "Unknown") == "Unknown" else None
|
||||
|
||||
metadata_box = self.box.add(arcade.gui.UIBoxLayout(space_between=10, align='left'))
|
||||
self.more_metadata_buttons.append(self.more_metadata_box.add(arcade.gui.UITextureButton(text="Open Source URL", style=button_style, texture=button_texture, texture_hovered=button_hovered_texture, width=self.window.width / 4.5, height=self.window.height / 15)))
|
||||
self.more_metadata_buttons[-1].on_click = lambda event: webbrowser.open(self.file_metadata["source_url"]) if not self.file_metadata.get("source_url", "Unknown") == "Unknown" else None
|
||||
|
||||
metadata_box = self.box.add(arcade.gui.UIBoxLayout(space_between=10, align='center'))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=name, font_size=20, font_name="Roboto", multiline=True)))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=metadata_text, font_size=18, font_name="Roboto", multiline=True)))
|
||||
|
||||
@@ -103,10 +121,12 @@ Sample rate: {self.file_metadata['sample_rate']}KHz
|
||||
for artist_name, artist_dict in self.artist_metadata.items():
|
||||
ipi_list = ', '.join(artist_dict['ipi-list'])
|
||||
isni_list = ', '.join(artist_dict['isni-list'])
|
||||
tag_list = ','.join(artist_dict['tag-list'])
|
||||
tag_list = ', '.join(artist_dict['tag-list'])
|
||||
example_tracks = ', '.join(artist_dict['example_tracks'])
|
||||
name = f"{artist_name} Metadata"
|
||||
metadata_text = f'''Artist MusicBrainz ID: {artist_dict['musicbrainz_id']}
|
||||
Artist Gender: {artist_dict['gender']}
|
||||
Example Tracks: {example_tracks}
|
||||
Artist Tag(s): {tag_list if tag_list else 'None'}
|
||||
Artist IPI(s): {ipi_list if ipi_list else 'None'}
|
||||
Artist ISNI(s): {isni_list if isni_list else 'None'}
|
||||
@@ -114,7 +134,10 @@ Artist Born: {artist_dict['born']}
|
||||
Artist Dead: {'Yes' if artist_dict['dead'] else 'No'}
|
||||
Artist Comment: {artist_dict['comment']}
|
||||
'''
|
||||
metadata_box = self.box.add(arcade.gui.UIBoxLayout(space_between=10, align='left'))
|
||||
for url_name, url_target in artist_dict["urls"].items():
|
||||
metadata_text += f"\n{url_name.capitalize()} Links: {', '.join(url_target)}"
|
||||
|
||||
metadata_box = self.box.add(arcade.gui.UIBoxLayout(space_between=10, align='center'))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=name, font_size=20, font_name="Roboto", multiline=True)))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=metadata_text, font_size=18, font_name="Roboto", multiline=True)))
|
||||
|
||||
@@ -125,13 +148,16 @@ Artist Comment: {artist_dict['comment']}
|
||||
|
||||
self.cover_art_box = self.box.add(arcade.gui.UIBoxLayout(space_between=100, align="left"))
|
||||
|
||||
for album_name, album_dict in self.album_metadata.items():
|
||||
name = f"{album_name} Metadata"
|
||||
album_cover_arts = download_albums_cover_art([album_id for album_id in self.album_metadata.keys()])
|
||||
|
||||
for album_id, album_dict in self.album_metadata.items():
|
||||
name = f"{album_dict['album_name']} Metadata"
|
||||
metadata_text = f'''
|
||||
MusicBrainz Album ID: {album_dict['musicbrainz_id']}
|
||||
MusicBrainz Album ID: {album_id}
|
||||
Album Name: {album_dict['album_name']}
|
||||
Album Date: {album_dict['album_date']}
|
||||
Album Country: {album_dict['album_country']}
|
||||
Album Country: {album_dict['album_country']}
|
||||
Example Tracks: {", ".join(album_dict['album_tracks'])}
|
||||
'''
|
||||
full_box = self.box.add(arcade.gui.UIBoxLayout(space_between=30, align='center', vertical=False))
|
||||
metadata_box = full_box.add(arcade.gui.UIBoxLayout(space_between=10, align='center'))
|
||||
@@ -139,19 +165,35 @@ Album Country: {album_dict['album_country']}
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=name, font_size=20, font_name="Roboto", multiline=True)))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=metadata_text, font_size=18, font_name="Roboto", multiline=True)))
|
||||
|
||||
cover_art = get_album_cover_art(album_dict["musicbrainz_id"])
|
||||
cover_art = album_cover_arts[album_id]
|
||||
|
||||
if cover_art:
|
||||
full_box.add(arcade.gui.UIImage(texture=cover_art, width=self.window.width / 10, height=self.window.height / 6))
|
||||
else:
|
||||
full_box.add(arcade.gui.UILabel(text="No cover found.", font_size=18, font_name="Roboto"))
|
||||
|
||||
elif self.metadata_type == "lyrics":
|
||||
name = f"{self.artist} - {self.title} Lyrics"
|
||||
metadata_box = self.box.add(arcade.gui.UIBoxLayout(space_between=10, align='left'))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=name, font_size=20, font_name="Roboto", multiline=True)))
|
||||
self.metadata_labels.append(metadata_box.add(arcade.gui.UILabel(text=self.music_lyrics, font_size=18, font_name="Roboto", multiline=True)))
|
||||
def reset_to_music_view(self):
|
||||
if hasattr(self, "file_metadata"):
|
||||
self.metadata_type = "file"
|
||||
elif hasattr(self, "lyrics_metadata"):
|
||||
self.metadata_type = "music"
|
||||
else: # artists and albums from global search
|
||||
self.global_search()
|
||||
return
|
||||
self.show_metadata()
|
||||
|
||||
def show_artist_metadata(self):
|
||||
self.metadata_type = "artist"
|
||||
self.show_metadata()
|
||||
|
||||
def show_album_metadata(self):
|
||||
self.metadata_type = "album"
|
||||
self.show_metadata()
|
||||
|
||||
def main_exit(self):
|
||||
from menus.main import Main
|
||||
self.window.show_view(Main(self.pypresence_client, *self.args))
|
||||
|
||||
def global_search(self):
|
||||
from menus.global_search import GlobalSearch
|
||||
self.window.show_view(GlobalSearch(self.pypresence_client, *self.args))
|
||||
Reference in New Issue
Block a user