X-Git-Url: https://vcs.maemo.org/git/?a=blobdiff_plain;f=src%2Fedit_panel_tm.py;h=3ebe339e4e25af3accc4aa287bdd85a566e0a451;hb=1024f31ed7121aaf10c122d860aa25a931975bb0;hp=201035be6b23191e474a2979a8d86519e5bddf88;hpb=aff36248e380b212927e164fe16930daeda3229c;p=mussorgsky diff --git a/src/edit_panel_tm.py b/src/edit_panel_tm.py index 201035b..3ebe339 100644 --- a/src/edit_panel_tm.py +++ b/src/edit_panel_tm.py @@ -3,29 +3,43 @@ import hildon import gtk, gobject from mutagen_backend import MutagenBackend from player_backend import MediaPlayer +from utils import escape_html import album_art_spec import os # Fields in the tuple! -FILE_URI = 0 -ARTIST_KEY = 2 -TITLE_KEY = 3 -ALBUM_KEY = 4 -MIME_KEY = 5 +# Shared with browse_panel +URI_COLUMN = 0 +ARTIST_COLUMN = 2 +TITLE_COLUMN = 3 +ALBUM_COLUMN = 4 +MIME_COLUMN = 5 +UI_COLUMN = 6 +SEARCH_COLUMN = 7 class MussorgskyEditPanel (hildon.StackableWindow): def __init__ (self): hildon.StackableWindow.__init__ (self) self.set_border_width (12) - self.album_callback_id = -1 self.album_change_handler = -1 self.artist_change_handler = -1 self.writer = MutagenBackend () self.player = MediaPlayer () self.__create_view () self.data_loaded = False + self.artist_list = None + self.albums_list = None + self.connect ("delete-event", self.close_function) + def close_function (self, widget, event): + if (not self.data_loaded): + return + + if self.__is_view_dirty (): + self.save_metadata () + + def update_title (self): self.set_title ("Edit (%d/%d)" % (self.model.get_path (self.current)[0] + 1, len (self.model))) @@ -36,15 +50,31 @@ class MussorgskyEditPanel (hildon.StackableWindow): return self.model.get (self.current, 0, 1, 2, 3, 4, 5) def set_model (self, model, current=None): + try: + if self.artists_list or self.albums_list: + pass + except AttributeError, e: + print "**** Set album and artist alternatives before setting a model" + raise e + self.model = model if (current): self.current = current else: self.current = self.model.get_iter_first () + self.data_loaded = True + self.set_data_in_view (self.get_current_row ()) + self.update_title () + def set_current (self, current): + """ + Iterator to current element + """ + self.current = current self.set_data_in_view (self.get_current_row ()) self.update_title () + def set_artist_alternatives (self, alternatives): self.artists_list = alternatives artist_selector = hildon.TouchSelectorEntry (text=True) @@ -64,39 +94,34 @@ class MussorgskyEditPanel (hildon.StackableWindow): if (self.player.is_playing ()): self.player.stop () - if (self.album_callback_id != -1): - gobject.source_remove (self.album_callback_id) - self.album_callback_id = -1 - if self.__is_view_dirty (): print "Modified data. Save!" self.save_metadata () - self.current = self.model.iter_next (self.current) - if (not self.current): + path = self.model.get_path (self.current) + if (path[0] == 0): self.destroy () - - self.set_data_in_view (self.get_current_row ()) + else: + new_path = ( path[0] -1, ) + self.current = self.model.get_iter (new_path) + self.set_data_in_view (self.get_current_row ()) + self.update_title () def press_next_cb (self, widget): if (self.player.is_playing ()): self.player.stop () - if (self.album_callback_id != -1): - gobject.source_remove (self.album_callback_id) - self.album_callback_id = -1 - if self.__is_view_dirty (): print "Modified data. Save!" self.save_metadata () self.current = self.model.iter_next (self.current) if (not self.current): - print "Destroy" self.destroy () else: self.set_data_in_view (self.get_current_row ()) self.update_title () + def save_metadata (self): # Save the data in the online model to show the appropiate data @@ -107,29 +132,42 @@ class MussorgskyEditPanel (hildon.StackableWindow): # 5 - mimetype -> doesn't change if (type (self.model) == gtk.TreeModelFilter): m = self.model.get_model () + c = self.model.convert_iter_to_child_iter (self.current) else: + # Very unlikely m = self.model - m.set (self.current, - 2, self.artist_button.get_value (), - 3, self.title_entry.get_text (), - 4, self.album_button.get_value ()) + c = self.current + + artist = self.artist_button.get_value () + title = self.title_entry.get_text () + album = self.album_button.get_value () + text = "%s\n%s" % (escape_html (title), + escape_html (artist) + " / " + escape_html (album)) + search_str = artist.lower () + " " + title.lower () + " " + album.lower () + + m.set (c, + ARTIST_COLUMN, artist, + TITLE_COLUMN, title, + ALBUM_COLUMN, album, + UI_COLUMN, text, + SEARCH_COLUMN, search_str) new_song = self.get_current_row () try: - self.writer.save_metadata_on_file (new_song[FILE_URI], - new_song[MIME_KEY], + self.writer.save_metadata_on_file (new_song[URI_COLUMN], + new_song[MIME_COLUMN], self.artist_button.get_value (), self.title_entry.get_text (), self.album_button.get_value ()) except IOError, e: # This error in case of tracker returning unexistent files. # Uhm.... for instance after removing a memory card we are editing! - dialog = gtk.MessageDialog (self, - gtk.DIALOG_DESTROY_WITH_PARENT, - gtk.MESSAGE_ERROR, - gtk.BUTTONS_CLOSE, - "%s" % str(e)); - dialog.run () - + pass + #dialog = gtk.MessageDialog (self, + # gtk.DIALOG_DESTROY_WITH_PARENT, + # gtk.MESSAGE_ERROR, + # gtk.BUTTONS_CLOSE, + # "%s" % str(e)); + #dialog.run () def __is_view_dirty (self): @@ -138,26 +176,23 @@ class MussorgskyEditPanel (hildon.StackableWindow): """ song = self.get_current_row () - return not (self.filename_data.get_text() == song[FILE_URI] and - self.artist_button.get_value () == song[ARTIST_KEY] and - self.title_entry.get_text () == song[TITLE_KEY] and - self.album_button.get_value () == song[ALBUM_KEY] ) + return not (self.filename_data.get_text() == song[URI_COLUMN] and + self.artist_button.get_value () == song[ARTIST_COLUMN] and + self.title_entry.get_text () == song[TITLE_COLUMN] and + self.album_button.get_value () == song[ALBUM_COLUMN] ) def __create_view (self): view_vbox = gtk.VBox (homogeneous=False, spacing = 12) filename_row = gtk.HBox () - filename_label = gtk.Label ("Filename:") + filename_label = gtk.Label () + filename_label.set_markup ("Filename:") filename_row.pack_start (filename_label, expand=False, padding=12); self.filename_data = gtk.Label ("") filename_row.pack_start (self.filename_data, expand=True) - play_button = hildon.Button (hildon.BUTTON_STYLE_NORMAL, hildon.BUTTON_ARRANGEMENT_HORIZONTAL) - img = gtk.image_new_from_stock (gtk.STOCK_MEDIA_PLAY, gtk.ICON_SIZE_BUTTON) - play_button.set_image (img) - play_button.connect ("clicked", self.clicked_play) - filename_row.pack_start (play_button, expand=False, fill=False) + #filename_row.pack_start (play_button, expand=False, fill=False) view_vbox.pack_start (filename_row, expand=False); central_panel = gtk.HBox (spacing=12) @@ -172,11 +207,11 @@ class MussorgskyEditPanel (hildon.StackableWindow): # Title row label_title = gtk.Label ("Title:") table.attach (label_title, 0, 1, 0, 1, 0) - self.title_entry = gtk.Entry() + self.title_entry = hildon.Entry(gtk.HILDON_SIZE_FINGER_HEIGHT) table.attach (self.title_entry, 1, 2, 0, 1) # Artist row - self.artist_button = hildon.PickerButton (hildon.BUTTON_STYLE_NORMAL, + self.artist_button = hildon.PickerButton (gtk.HILDON_SIZE_THUMB_HEIGHT, hildon.BUTTON_ARRANGEMENT_HORIZONTAL) self.artist_button.set_title ("Artist: ") # Set data will set the selector @@ -184,11 +219,11 @@ class MussorgskyEditPanel (hildon.StackableWindow): # Album row - self.album_button = hildon.PickerButton (hildon.BUTTON_STYLE_NORMAL, + self.album_button = hildon.PickerButton (gtk.HILDON_SIZE_THUMB_HEIGHT, hildon.BUTTON_ARRANGEMENT_HORIZONTAL) self.album_button.set_title ("Album: ") # set_data will set the selector - table.attach (self.album_button, 0, 2, 2, 3) + table.attach (self.album_button, 0, 2, 2, 3) # Album art space @@ -197,29 +232,36 @@ class MussorgskyEditPanel (hildon.StackableWindow): central_panel.pack_start (self.album_art, expand=False, fill=False) # Buttons row - button_box = gtk.HButtonBox () - button_box.set_layout (gtk.BUTTONBOX_END) + button_box = gtk.Toolbar () - back_button = hildon.Button (hildon.BUTTON_STYLE_NORMAL, hildon.BUTTON_ARRANGEMENT_HORIZONTAL) - img = gtk.image_new_from_stock (gtk.STOCK_GO_BACK, gtk.ICON_SIZE_BUTTON) - back_button.set_image (img) - back_button.connect ("clicked", self.press_back_cb) - button_box.pack_start (back_button, expand=True, fill=True, padding=6) + play_button = gtk.ToolButton (gtk.image_new_from_stock (gtk.STOCK_MEDIA_PLAY, gtk.ICON_SIZE_BUTTON)) + play_button.connect ("clicked", self.clicked_play) + play_button.set_expand (True) + button_box.insert (play_button, -1) - next_button = hildon.Button (hildon.BUTTON_STYLE_NORMAL, hildon.BUTTON_ARRANGEMENT_HORIZONTAL) - img = gtk.image_new_from_stock (gtk.STOCK_GO_FORWARD, gtk.ICON_SIZE_BUTTON) - next_button.set_image (img) + separator = gtk.SeparatorToolItem () + separator.set_expand (True) + button_box.insert (separator, -1) + + back_img = gtk.Image () + back_img.set_from_icon_name ("general_back", gtk.ICON_SIZE_BUTTON) + back_button = gtk.ToolButton (back_img) + back_button.connect ("clicked", self.press_back_cb) + back_button.set_expand (True) + button_box.insert (back_button, -1) + + next_img = gtk.Image () + next_img.set_from_icon_name ("general_forward", gtk.ICON_SIZE_BUTTON) + next_button = gtk.ToolButton (next_img) next_button.connect ("clicked", self.press_next_cb) - button_box.pack_start (next_button, expand=True, fill=True, padding=6) - - view_vbox.pack_start (button_box, expand=False, fill=True, padding=6) + next_button.set_expand (True) + button_box.insert (next_button, -1) + + self.add_toolbar (button_box) self.add (view_vbox) - def go_to_cb (self, widget): - pass - def set_data_in_view (self, song): """ Place in the screen the song information. @@ -227,8 +269,8 @@ class MussorgskyEditPanel (hildon.StackableWindow): """ assert len (song) == 6 - self.filename_data.set_text (song[FILE_URI]) - self.title_entry.set_text (song[TITLE_KEY]) + self.filename_data.set_markup ("" + song[URI_COLUMN] + "") + self.title_entry.set_text (song[TITLE_COLUMN]) # Disconnect the value-change signal to avoid extra album art retrievals @@ -240,16 +282,20 @@ class MussorgskyEditPanel (hildon.StackableWindow): # Set values in the picker buttons try: - self.artist_button.set_active (self.artists_list.index(song[ARTIST_KEY])) + self.artist_button.set_active (self.artists_list.index(song[ARTIST_COLUMN])) except ValueError: - print "'%s' not in artist list!?" % (song[ARTIST_KEY]) + print "'%s' not in artist list!?" % (song[ARTIST_COLUMN]) self.artist_button.set_value ("") + except AttributeError: + print "WARNING: Use set_artist_alternatives method to set a list of artists" try: - self.album_button.set_active (self.albums_list.index (song[ALBUM_KEY])) + self.album_button.set_active (self.albums_list.index (song[ALBUM_COLUMN])) except ValueError: - print "'%s' is not in the album list!?" % (song[ALBUM_KEY]) + print "'%s' is not in the album list!?" % (song[ALBUM_COLUMN]) self.album_button.set_value ("") + except AttributeError: + print "WARNING: Use set_album_alternatives method to set a list of artists" # Reconnect the signals! self.album_change_handler = self.album_button.connect ("value-changed", @@ -259,9 +305,9 @@ class MussorgskyEditPanel (hildon.StackableWindow): self.artist_selection_cb) # Set the album art given the current data - self.set_album_art (song[ALBUM_KEY]) + self.set_album_art (song[ALBUM_COLUMN]) - if (not song[MIME_KEY] in self.writer.get_supported_mimes ()): + if (not song[MIME_COLUMN] in self.writer.get_supported_mimes ()): self.artist_button.set_sensitive (False) self.album_button.set_sensitive (False) self.title_entry.set_sensitive (False) @@ -287,11 +333,8 @@ class MussorgskyEditPanel (hildon.StackableWindow): if (self.player.is_playing ()): self.player.stop () else: - song = self.songs_list [self.song_counter] - self.player.play ("file://" + song[FILE_URI]) - - def clicked_album_art (self, widget): - print "implement me, please" + song = self.get_current_row () + self.player.play ("file://" + song[URI_COLUMN]) def album_selection_cb (self, widget): """ @@ -315,7 +358,7 @@ class MussorgskyEditPanel (hildon.StackableWindow): print "Inserting artist", widget.get_value () widget.get_selector ().prepend_text (widget.get_value ()) self.artists_list.insert (0, widget.get_value ()) - + # Testing porpuses if __name__ == "__main__": @@ -329,6 +372,8 @@ if __name__ == "__main__": model.append (t) window = MussorgskyEditPanel () + window.set_artist_alternatives (["", "Bob Dylan"]) + window.set_album_alternatives (["", "Bring it all back home", "Album 2", "Album 9", "Album 3"]) window.set_model (model) window.connect ("destroy", gtk.main_quit) window.show_all ()