mirror of
https://github.com/SoongNoonien/mpdevil.git
synced 2023-08-10 21:12:44 +03:00
enabled showing metadata of any song
This commit is contained in:
parent
3c68214b68
commit
864477c602
169
bin/mpdevil.py
169
bin/mpdevil.py
@ -894,6 +894,55 @@ class Settings(Gio.Settings):
|
|||||||
else:
|
else:
|
||||||
return ("artist")
|
return ("artist")
|
||||||
|
|
||||||
|
class SongPopover(Gtk.Popover):
|
||||||
|
def __init__(self, song, rect, relative):
|
||||||
|
Gtk.Popover.__init__(self)
|
||||||
|
rect.y=rect.y+25
|
||||||
|
self.set_pointing_to(rect)
|
||||||
|
self.set_relative_to(relative)
|
||||||
|
# self.set_property("position", Gtk.PositionType.BOTTOM)
|
||||||
|
|
||||||
|
#Store
|
||||||
|
#(tag, display-value, tooltip)
|
||||||
|
self.store=Gtk.ListStore(str, str, str)
|
||||||
|
|
||||||
|
#TreeView
|
||||||
|
self.treeview=Gtk.TreeView(model=self.store)
|
||||||
|
self.treeview.set_can_focus(False)
|
||||||
|
self.treeview.set_search_column(-1)
|
||||||
|
self.treeview.set_tooltip_column(2)
|
||||||
|
self.treeview.set_headers_visible(False)
|
||||||
|
sel=self.treeview.get_selection()
|
||||||
|
sel.set_mode(Gtk.SelectionMode.NONE)
|
||||||
|
|
||||||
|
#Column
|
||||||
|
renderer_text=Gtk.CellRendererText(width_chars=50, ellipsize=Pango.EllipsizeMode.MIDDLE, ellipsize_set=True)
|
||||||
|
renderer_text_ralign=Gtk.CellRendererText(xalign=1.0)
|
||||||
|
|
||||||
|
self.column_tag=Gtk.TreeViewColumn(_("MPD-Tag"), renderer_text_ralign, text=0)
|
||||||
|
self.column_tag.set_property("resizable", False)
|
||||||
|
self.treeview.append_column(self.column_tag)
|
||||||
|
|
||||||
|
self.column_value=Gtk.TreeViewColumn(_("Value"), renderer_text, text=1)
|
||||||
|
self.column_value.set_property("resizable", False)
|
||||||
|
self.treeview.append_column(self.column_value)
|
||||||
|
|
||||||
|
#packing
|
||||||
|
self.add(self.treeview)
|
||||||
|
|
||||||
|
for tag, value in song.items():
|
||||||
|
tooltip=value.replace("&", "&")
|
||||||
|
if tag == "time":
|
||||||
|
self.store.append([tag+":", str(datetime.timedelta(seconds=int(value))), tooltip])
|
||||||
|
elif tag == "last-modified":
|
||||||
|
time=datetime.datetime.strptime(value, '%Y-%m-%dT%H:%M:%SZ')
|
||||||
|
self.store.append([tag+":", time.strftime('%a %d %B %Y, %H:%M UTC'), tooltip])
|
||||||
|
else:
|
||||||
|
self.store.append([tag+":", value, tooltip])
|
||||||
|
self.treeview.show()
|
||||||
|
# self.popup()
|
||||||
|
# self.treeview.queue_resize()
|
||||||
|
|
||||||
class SongsView(Gtk.TreeView):
|
class SongsView(Gtk.TreeView):
|
||||||
def __init__(self, client, show_album=True, sort_enable=True):
|
def __init__(self, client, show_album=True, sort_enable=True):
|
||||||
Gtk.TreeView.__init__(self)
|
Gtk.TreeView.__init__(self)
|
||||||
@ -902,6 +951,7 @@ class SongsView(Gtk.TreeView):
|
|||||||
|
|
||||||
#add vars
|
#add vars
|
||||||
self.client=client
|
self.client=client
|
||||||
|
self.songs=[]
|
||||||
|
|
||||||
#store
|
#store
|
||||||
#(track, title, artist, album, duration, file)
|
#(track, title, artist, album, duration, file)
|
||||||
@ -973,6 +1023,17 @@ class SongsView(Gtk.TreeView):
|
|||||||
self.client.files_to_playlist([self.store[path][5]], True)
|
self.client.files_to_playlist([self.store[path][5]], True)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
elif event.button == 3 and event.type == Gdk.EventType.BUTTON_PRESS:
|
||||||
|
try:
|
||||||
|
path=widget.get_path_at_pos(int(event.x), int(event.y))[0]
|
||||||
|
rect=Gdk.Rectangle()
|
||||||
|
rect.x=event.x
|
||||||
|
rect.y=event.y
|
||||||
|
rect.width = rect.height = 0
|
||||||
|
pop=SongPopover(self.songs[int(str(path))], rect, widget)
|
||||||
|
pop.popup()
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
def on_key_press_event(self, widget, event):
|
def on_key_press_event(self, widget, event):
|
||||||
self.handler_block(self.key_press_event)
|
self.handler_block(self.key_press_event)
|
||||||
@ -988,11 +1049,13 @@ class SongsView(Gtk.TreeView):
|
|||||||
self.handler_unblock(self.key_press_event)
|
self.handler_unblock(self.key_press_event)
|
||||||
|
|
||||||
def populate(self, songs):
|
def populate(self, songs):
|
||||||
|
self.songs=songs
|
||||||
for s in songs:
|
for s in songs:
|
||||||
song=self.client.extend_song_for_display(self.client.song_to_str_dict(s))
|
song=self.client.extend_song_for_display(self.client.song_to_str_dict(s))
|
||||||
self.store.append([int(song["track"]), song["title"], song["artist"], song["album"], song["human_duration"], song["file"]])
|
self.store.append([int(song["track"]), song["title"], song["artist"], song["album"], song["human_duration"], song["file"]])
|
||||||
|
|
||||||
def clear(self):
|
def clear(self):
|
||||||
|
self.songs=[]
|
||||||
self.store.clear()
|
self.store.clear()
|
||||||
|
|
||||||
def count(self):
|
def count(self):
|
||||||
@ -1587,16 +1650,19 @@ class PlaylistView(Gtk.Box):
|
|||||||
|
|
||||||
#audio infos
|
#audio infos
|
||||||
audio=AudioType(self.client)
|
audio=AudioType(self.client)
|
||||||
|
audio.set_margin_end(3)
|
||||||
|
audio.set_xalign(1)
|
||||||
|
audio.set_ellipsize(Pango.EllipsizeMode.END)
|
||||||
|
|
||||||
#playlist info
|
#playlist info
|
||||||
self.playlist_info=Gtk.Label()
|
self.playlist_info=Gtk.Label()
|
||||||
self.playlist_info.set_margin_start(5)
|
self.playlist_info.set_margin_start(3)
|
||||||
self.playlist_info.set_xalign(0)
|
self.playlist_info.set_xalign(0)
|
||||||
self.playlist_info.set_ellipsize(Pango.EllipsizeMode.END)
|
self.playlist_info.set_ellipsize(Pango.EllipsizeMode.END)
|
||||||
|
|
||||||
#status bar
|
#status bar
|
||||||
status_bar=Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=12)
|
status_bar=Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=12)
|
||||||
status_bar.set_property("border-width", 1)
|
status_bar.set_property("border-width", 3)
|
||||||
status_bar.pack_start(self.playlist_info, True, True, 0)
|
status_bar.pack_start(self.playlist_info, True, True, 0)
|
||||||
status_bar.pack_end(audio, False, False, 0)
|
status_bar.pack_end(audio, False, False, 0)
|
||||||
|
|
||||||
@ -1693,6 +1759,17 @@ class PlaylistView(Gtk.Box):
|
|||||||
self.remove_song(path)
|
self.remove_song(path)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
elif event.button == 3 and event.type == Gdk.EventType.BUTTON_PRESS:
|
||||||
|
try:
|
||||||
|
path=widget.get_path_at_pos(int(event.x), int(event.y))[0]
|
||||||
|
rect=Gdk.Rectangle()
|
||||||
|
rect.x=event.x
|
||||||
|
rect.y=event.y
|
||||||
|
rect.width=rect.height = 0
|
||||||
|
pop=SongPopover(self.client.playlistinfo(path)[0], rect, widget)
|
||||||
|
pop.popup()
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
def on_row_activated(self, widget, path, view_column):
|
def on_row_activated(self, widget, path, view_column):
|
||||||
self.client.play(path)
|
self.client.play(path)
|
||||||
@ -2744,99 +2821,37 @@ class PlaybackOptions(Gtk.Box):
|
|||||||
self.volume.set_value(0)
|
self.volume.set_value(0)
|
||||||
self.volume.handler_unblock(self.volume_changed)
|
self.volume.handler_unblock(self.volume_changed)
|
||||||
|
|
||||||
class AudioType(Gtk.Button):
|
class AudioType(Gtk.Label):
|
||||||
def __init__(self, client):
|
def __init__(self, client):
|
||||||
Gtk.Button.__init__(self)
|
Gtk.Label.__init__(self)
|
||||||
self.set_relief(Gtk.ReliefStyle.NONE)
|
|
||||||
self.set_tooltip_text(_("Show additional information"))
|
|
||||||
|
|
||||||
#adding vars
|
#adding vars
|
||||||
self.client=client
|
self.client=client
|
||||||
|
|
||||||
#widgets
|
|
||||||
self.label=Gtk.Label()
|
|
||||||
self.label.set_xalign(1)
|
|
||||||
self.label.set_ellipsize(Pango.EllipsizeMode.END)
|
|
||||||
self.popover=Gtk.Popover()
|
|
||||||
self.popover.set_relative_to(self)
|
|
||||||
|
|
||||||
#Store
|
|
||||||
#(tag, value)
|
|
||||||
self.store=Gtk.ListStore(str, str)
|
|
||||||
|
|
||||||
#TreeView
|
|
||||||
self.treeview=Gtk.TreeView(model=self.store)
|
|
||||||
self.treeview.set_can_focus(False)
|
|
||||||
self.treeview.set_search_column(-1)
|
|
||||||
self.treeview.set_tooltip_column(1)
|
|
||||||
sel=self.treeview.get_selection()
|
|
||||||
sel.set_mode(Gtk.SelectionMode.NONE)
|
|
||||||
|
|
||||||
#Column
|
|
||||||
renderer_text=Gtk.CellRendererText(width_chars=50, ellipsize=Pango.EllipsizeMode.MIDDLE, ellipsize_set=True)
|
|
||||||
renderer_text_ralign=Gtk.CellRendererText(xalign=1.0)
|
|
||||||
|
|
||||||
self.column_tag=Gtk.TreeViewColumn(_("MPD-Tag"), renderer_text_ralign, text=0)
|
|
||||||
self.column_tag.set_property("resizable", False)
|
|
||||||
self.treeview.append_column(self.column_tag)
|
|
||||||
|
|
||||||
self.column_value=Gtk.TreeViewColumn(_("Value"), renderer_text, text=1)
|
|
||||||
self.column_value.set_property("resizable", False)
|
|
||||||
self.treeview.append_column(self.column_value)
|
|
||||||
|
|
||||||
#connect
|
#connect
|
||||||
self.connect("clicked", self.on_clicked)
|
self.client.emitter.connect("periodic_signal", self.refresh) # periodic_signal
|
||||||
#periodic_signal
|
self.client.emitter.connect("disconnected", self.clear)
|
||||||
self.client.emitter.connect("periodic_signal", self.refresh)
|
self.client.emitter.connect("player", self.on_player)
|
||||||
self.client.emitter.connect("disconnected", self.disable)
|
|
||||||
self.client.emitter.connect("reconnected", self.enable)
|
|
||||||
|
|
||||||
#packing
|
def clear(self, *args):
|
||||||
self.popover.add(self.treeview)
|
self.set_text("")
|
||||||
self.add(self.label)
|
|
||||||
|
|
||||||
self.disable()
|
|
||||||
|
|
||||||
def enable(self, *args):
|
|
||||||
self.set_sensitive(True)
|
|
||||||
|
|
||||||
def disable(self, *args):
|
|
||||||
self.set_sensitive(False)
|
|
||||||
self.label.set_text("-")
|
|
||||||
|
|
||||||
def refresh(self, *args):
|
def refresh(self, *args):
|
||||||
try:
|
try:
|
||||||
self.enable()
|
|
||||||
file_type=self.client.currentsong()["file"].split('.')[-1]
|
file_type=self.client.currentsong()["file"].split('.')[-1]
|
||||||
status=self.client.status()
|
status=self.client.status()
|
||||||
freq, res, chan=status["audio"].split(':')
|
freq, res, chan=status["audio"].split(':')
|
||||||
freq=str(float(freq)/1000)
|
freq=str(float(freq)/1000)
|
||||||
brate=status["bitrate"]
|
brate=status["bitrate"]
|
||||||
string=_("%(bitrate)s kb/s, %(frequency)s kHz, %(resolution)s bit, %(channels)s channels, %(file_type)s") % {"bitrate": brate, "frequency": freq, "resolution": res, "channels": chan, "file_type": file_type}
|
string=_("%(bitrate)s kb/s, %(frequency)s kHz, %(resolution)s bit, %(channels)s channels, %(file_type)s") % {"bitrate": brate, "frequency": freq, "resolution": res, "channels": chan, "file_type": file_type}
|
||||||
self.label.set_text(string)
|
self.set_text(string)
|
||||||
except:
|
except:
|
||||||
pass
|
self.clear()
|
||||||
|
|
||||||
def on_clicked(self, *args):
|
def on_player(self, *args):
|
||||||
try:
|
status=self.client.status()
|
||||||
self.store.clear()
|
if status['state'] == "stop":
|
||||||
song=self.client.song_to_str_dict(self.client.currentsong())
|
self.clear()
|
||||||
if song != {}:
|
|
||||||
for tag, value in song.items():
|
|
||||||
if tag == "time":
|
|
||||||
self.store.append([tag+":", str(datetime.timedelta(seconds=int(value)))])
|
|
||||||
elif tag == "last-modified":
|
|
||||||
time=datetime.datetime.strptime(value, '%Y-%m-%dT%H:%M:%SZ')
|
|
||||||
self.store.append([tag+":", time.strftime('%a %d %B %Y, %H:%M UTC')])
|
|
||||||
else:
|
|
||||||
self.store.append([tag+":", value])
|
|
||||||
self.treeview.show()
|
|
||||||
self.popover.popup()
|
|
||||||
self.treeview.queue_resize()
|
|
||||||
else:
|
|
||||||
self.disable()
|
|
||||||
except:
|
|
||||||
self.disable()
|
|
||||||
|
|
||||||
class ProfileSelect(Gtk.ComboBoxText):
|
class ProfileSelect(Gtk.ComboBoxText):
|
||||||
def __init__(self, client, settings):
|
def __init__(self, client, settings):
|
||||||
|
Loading…
Reference in New Issue
Block a user