X-Git-Url: http://git.maemo.org/git/?p=jamaendo;a=blobdiff_plain;f=jamaui%2Fui.py;h=dda0eccd0014c8d4bfa507d4e4a1c1f1f42c3193;hp=9b6300dea1cbf01ac153f29783066e4ef70b26a1;hb=61536ca548691b15e7f63340a0fbfb5a3055d5be;hpb=6c2ba5c5bfff0446b6043ebfa606680106be8083 diff --git a/jamaui/ui.py b/jamaui/ui.py index 9b6300d..dda0ecc 100644 --- a/jamaui/ui.py +++ b/jamaui/ui.py @@ -38,7 +38,7 @@ gobject.threads_init() log = logging.getLogger(__name__) -VERSION = '0.1' +VERSION = '0.2' try: import hildon @@ -47,8 +47,8 @@ except: log.critical('Using GTK widgets, install "python2.5-hildon" ' 'for this to work properly.') else: - log.critical('This ui only works in maemo') - sys.exit(1) + log.critical('This ui (probably) only works in maemo') + import helldon as hildon from dbus.mainloop.glib import DBusGMainLoop @@ -62,16 +62,8 @@ from search import SearchWindow from featured import FeaturedWindow from radios import RadiosWindow from favorites import FavoritesWindow - -class PlaylistsWindow(hildon.StackableWindow): - def __init__(self): - hildon.StackableWindow.__init__(self) - self.set_title("Playlists") - - label = gtk.Label("Playlists") - vbox = gtk.VBox(False, 0) - vbox.pack_start(label, True, True, 0) - self.add(vbox) +from playlists import PlaylistsWindow +from listbox import ButtonListDialog class Jamaui(object): def __init__(self): @@ -95,11 +87,9 @@ class Jamaui(object): settings.load() postoffice.connect('request-album-cover', self, self.on_request_cover) + postoffice.connect('request-images', self, self.on_request_images) log.debug("Created main window.") - def save_settings(self): - settings.save() - def create_menu(self): self.menu = hildon.AppMenu() @@ -118,10 +108,10 @@ class Jamaui(object): player.connect("clicked", self.on_favorites) self.menu.append(player) - #player = hildon.GtkButton(gtk.HILDON_SIZE_AUTO) - #player.set_label("Playlists") - #player.connect("clicked", self.on_playlists) - #self.menu.append(player) + player = hildon.GtkButton(gtk.HILDON_SIZE_AUTO) + player.set_label("Playlists") + player.connect("clicked", self.on_playlists) + self.menu.append(player) player = hildon.GtkButton(gtk.HILDON_SIZE_AUTO) player.set_label("Settings") @@ -176,9 +166,15 @@ class Jamaui(object): def on_request_cover(self, albumid, size): jamaendo.get_album_cover_async(self.got_album_cover, int(albumid), size) + def on_request_images(self, urls): + jamaendo.get_images_async(self.got_images, urls) + def got_album_cover(self, albumid, size, cover): postoffice.notify('album-cover', albumid, size, cover) + def got_images(self, images): + postoffice.notify('images', images) + #def add_featured_button(self): # self.featured_sel = hildon.TouchSelector(text=True) # self.featured_sel.append_text("Albums of the week") @@ -193,8 +189,8 @@ class Jamaui(object): # self.bbox.add(btn) def destroy(self, widget): - postoffice.disconnect('request-album-cover', self) - self.save_settings() + postoffice.disconnect(['request-album-cover', 'request-images'], self) + settings.save() from player import the_player if the_player: the_player.stop() @@ -260,16 +256,15 @@ JAMENDO is an online platform that distributes musical works under Creative Comm # dialog.hide() def on_featured(self, button): - dialog = hildon.PickerDialog(self.window) - sel = hildon.TouchSelector(text=True) - for feature, _ in FeaturedWindow.features: - sel.append_text(feature) - dialog.set_selector(sel) - dialog.set_title("Featured") - if dialog.run() == gtk.RESPONSE_OK: - txt = sel.get_current_text() - self.featuredwnd = FeaturedWindow(txt) + dialog = ButtonListDialog('Featured', self.window) + def fn(btn, feature): + self.featuredwnd = FeaturedWindow(feature) self.featuredwnd.show_all() + dialog.response(gtk.RESPONSE_OK) + for feature, _ in FeaturedWindow.features: + dialog.add_button(feature, fn, feature) + dialog.show_all() + dialog.run() dialog.destroy() def on_radios(self, button): @@ -305,7 +300,7 @@ JAMENDO is an online platform that distributes musical works under Creative Comm if val and result == gtk.RESPONSE_OK: #print "new user name:", val settings.user = val - self.save_settings() + settings.save() def on_favorites(self, button):