New year, big checkin
[jamaendo] / jamaui / search.py
index a6c818f..4efe294 100644 (file)
@@ -2,6 +2,8 @@ import gtk
 import hildon
 import jamaendo
 from playerwindow import open_playerwindow
+from showartist import ShowArtist
+from showalbum import ShowAlbum
 
 class SearchWindow(hildon.StackableWindow):
     def __init__(self):
@@ -10,51 +12,96 @@ class SearchWindow(hildon.StackableWindow):
 
         vbox = gtk.VBox(False, 0)
 
-        hbox = gtk.HBox()
+
+        # Results list
+        self.panarea = hildon.PannableArea()
+        self.result_store = gtk.ListStore(str, int)
+        #self.result_store.append(['red'])
+        self.result_view = gtk.TreeView(self.result_store)
+        col = gtk.TreeViewColumn('Name')
+        self.result_view.append_column(col)
+        cell = gtk.CellRendererText()
+        col.pack_start(cell, True)
+        col.add_attribute(cell, 'text', 0)
+        self.result_view.set_search_column(0)
+        col.set_sort_column_id(0)
+        self.result_view.connect('row-activated', self.row_activated)
+
+        self.panarea.add(self.result_view)
+        vbox.pack_start(self.panarea, True, True, 0)
+
+
+        # Create selector for search mode
+        self.mode_selector = hildon.TouchSelector(text=True)
+
+        self.mode_selector.append_text("Artists")
+        self.mode_selector.append_text("Albums")
+        self.mode_selector.append_text("Tracks")
+        self.mode = hildon.PickerButton(gtk.HILDON_SIZE_FINGER_HEIGHT,
+                                        hildon.BUTTON_ARRANGEMENT_VERTICAL)
+        self.mode.set_title("Search for")
+        self.mode.set_selector(self.mode_selector)
+        self.mode_selector.connect("changed", self.mode_changed)
+        #vbox.pack_start(self.mode, False)
+        self.mode.set_active(1)
+
+
+        # Search box
+        hbox = gtk.HBox(False, 0)
         self.entry = hildon.Entry(gtk.HILDON_SIZE_FINGER_HEIGHT)
         self.entry.set_placeholder("Search")
         self.entry.connect('activate', self.on_search)
         btn = hildon.GtkButton(gtk.HILDON_SIZE_FINGER_HEIGHT)
-        btn.set_label("Go")
+        btn.set_label(">>")
         btn.connect('clicked', self.on_search)
+        hbox.pack_start(self.mode, False)
         hbox.pack_start(self.entry, True, True, 0)
         hbox.pack_start(btn, False)
-
-        btnbox = gtk.HBox()
-        playbtn = hildon.GtkButton(gtk.HILDON_SIZE_FINGER_HEIGHT)
-        playbtn.set_label("Play selected")
-        playbtn.connect('clicked', self.play_selected)
-        btnbox.pack_start(playbtn, False)
-
-        self.results = hildon.TouchSelector(text=True)
-        self.results.connect("changed", self.selection_changed)
-        self.results.set_column_selection_mode(hildon.TOUCH_SELECTOR_SELECTION_MODE_SINGLE)
-
         vbox.pack_start(hbox, False)
-        vbox.pack_start(self.results, True, True, 0)
-        vbox.pack_start(btnbox, False)
+
 
         self.add(vbox)
 
         self.idmap = {}
 
-        self.pwnd = None
+    def mode_changed(self, selector, user_data):
+        current_selection = selector.get_current_text()
+        print current_selection
 
     def on_search(self, w):
+        mode = self.mode.get_active()
         txt = self.entry.get_text()
-        for album in jamaendo.search_albums(query=txt):
-            title = "%s - %s" % (album.artist_name, album.name)
-            self.idmap[title] = album
-            self.results.append_text(title)
-
-    def selection_changed(self, results, userdata):
-        pass
-
-    def play_selected(self, btn):
-        current_selection = self.results.get_current_text()
-
-        album = self.idmap[current_selection]
-        tracks = jamaendo.get_tracks(album.ID)
-        if tracks:
-            wnd = open_playerwindow(tracks)
-            wnd.on_play(None)
+        self.result_store.clear()
+        if mode == 0:
+            for artist in jamaendo.search_artists(query=txt):
+                title = artist.name
+                self.idmap[artist.ID] = artist
+                self.result_store.append([title, artist.ID])
+        elif mode == 1:
+            for album in jamaendo.search_albums(query=txt):
+                title = "%s - %s" % (album.artist_name, album.name)
+                self.idmap[album.ID] = album
+                self.result_store.append([title, album.ID])
+        elif mode == 2:
+            for track in jamaendo.search_tracks(query=txt):
+                title = "%s - %s" % (track.artist_name, track.name)
+                self.idmap[track.ID] = track
+                self.result_store.append([title, track.ID])
+
+    def row_activated(self, treeview, path, view_column):
+        treeiter = self.result_store.get_iter(path)
+        title, _id = self.result_store.get(treeiter, 0, 1)
+        item = self.idmap[_id]
+        print _id, item
+        self.open_item(item)
+
+    def open_item(self, item):
+        if isinstance(item, jamaendo.Album):
+            wnd = ShowAlbum(item)
+            wnd.show_all()
+        elif isinstance(item, jamaendo.Artist):
+            wnd = ShowArtist(item)
+            wnd.show_all()
+        elif isinstance(item, jamaendo.Track):
+            wnd = open_playerwindow()
+            wnd.play_tracks([item])