Added experimental changes for musicDL
This commit is contained in:
@@ -7,6 +7,7 @@ except ImportError:
|
||||
pass
|
||||
import application
|
||||
import widgetUtils
|
||||
from .search import searchPanel
|
||||
|
||||
class mainWindow(wx.Frame):
|
||||
def makeMenu(self):
|
||||
@@ -40,22 +41,10 @@ class mainWindow(wx.Frame):
|
||||
self.panel = wx.Panel(self)
|
||||
self.sizer = wx.BoxSizer(wx.VERTICAL)
|
||||
self.sb = self.CreateStatusBar()
|
||||
lbl2 = wx.StaticText(self.panel, wx.NewId(), _(u"search"))
|
||||
self.text = wx.TextCtrl(self.panel, wx.NewId())
|
||||
box = wx.BoxSizer(wx.HORIZONTAL)
|
||||
box.Add(lbl2, 0, wx.GROW)
|
||||
box.Add(self.text, 1, wx.GROW)
|
||||
box.Add(wx.StaticText(self.panel, wx.NewId(), _(u"Search in")), 0, wx.GROW)
|
||||
self.extractor = wx.ComboBox(self.panel, wx.NewId(), choices=extractors, value=extractors[0], style=wx.CB_READONLY)
|
||||
box.Add(self.extractor, 1, wx.GROW)
|
||||
self.search = wx.Button(self.panel, wx.NewId(), _(u"Search"))
|
||||
self.search.SetDefault()
|
||||
box.Add(self.search, 0, wx.GROW)
|
||||
self.sizer.Add(box, 0, wx.GROW)
|
||||
lbl = wx.StaticText(self.panel, wx.NewId(), _(u"Results"))
|
||||
self.list = wx.ListBox(self.panel, wx.NewId())
|
||||
self.sizer.Add(lbl, 0, wx.GROW)
|
||||
self.sizer.Add(self.list, 1, wx.GROW)
|
||||
self.tb = wx.Treebook(self.panel, -1)
|
||||
search = searchPanel(extractors, parent=self.tb)
|
||||
self.add_buffer(search, _("Search"))
|
||||
self.sizer.Add(self.tb, 1, wx.ALL|wx.EXPAND, 5)
|
||||
box1 = wx.BoxSizer(wx.HORIZONTAL)
|
||||
box2 = wx.BoxSizer(wx.HORIZONTAL)
|
||||
box1.Add(wx.StaticText(self.panel, wx.NewId(), _(u"Position")), 0, wx.GROW)
|
||||
@@ -77,9 +66,6 @@ class mainWindow(wx.Frame):
|
||||
self.progressbar = wx.Gauge(self.panel, wx.NewId(), range=100, style=wx.GA_HORIZONTAL)
|
||||
self.sizer.Add(self.progressbar, 0, wx.ALL, 5)
|
||||
self.panel.SetSizerAndFit(self.sizer)
|
||||
# self.SetClientSize(self.sizer.CalcMin())
|
||||
# self.Layout()
|
||||
# self.SetSize(self.GetBestSize())
|
||||
|
||||
def change_status(self, status):
|
||||
self.sb.SetStatusText(status)
|
||||
@@ -102,14 +88,6 @@ class mainWindow(wx.Frame):
|
||||
except:
|
||||
wx.AboutBox(info)
|
||||
|
||||
def get_text(self):
|
||||
t = self.text.GetValue()
|
||||
self.text.ChangeValue("")
|
||||
return t
|
||||
|
||||
def get_item(self):
|
||||
return self.list.GetSelection()
|
||||
|
||||
def get_destination_path(self, filename):
|
||||
saveFileDialog = wx.FileDialog(self, _(u"Save this file"), "", filename, _(u"Audio Files(*.mp3)|*.mp3"), wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT)
|
||||
if saveFileDialog.ShowModal() == wx.ID_OK:
|
||||
@@ -121,4 +99,46 @@ class mainWindow(wx.Frame):
|
||||
self.notification = wx.adv.NotificationMessage(title, text, parent=self)
|
||||
except AttributeError:
|
||||
self.notification = wx.NotificationMessage(title, text)
|
||||
self.notification.Show()
|
||||
self.notification.Show()
|
||||
|
||||
def get_buffer_count(self):
|
||||
return self.tb.GetPageCount()
|
||||
|
||||
def add_buffer(self, buffer, name):
|
||||
self.tb.AddPage(buffer, name)
|
||||
|
||||
def insert_buffer(self, buffer, name, pos):
|
||||
return self.tb.InsertSubPage(pos, buffer, name)
|
||||
|
||||
def search(self, name_):
|
||||
for i in range(0, self.tb.GetPageCount()):
|
||||
if self.tb.GetPage(i).name == name_: return i
|
||||
|
||||
def get_current_buffer(self):
|
||||
return self.tb.GetCurrentPage()
|
||||
|
||||
def get_current_buffer_pos(self):
|
||||
return self.tb.GetSelection()
|
||||
|
||||
def get_buffer(self, pos):
|
||||
return self.tb.GetPage(pos)
|
||||
|
||||
def change_buffer(self, position):
|
||||
self.tb.ChangeSelection(position)
|
||||
|
||||
def get_buffer_text(self, pos=None):
|
||||
if pos == None:
|
||||
pos = self.tb.GetSelection()
|
||||
return self.tb.GetPageText(pos)
|
||||
|
||||
def get_buffer_by_id(self, id):
|
||||
return self.tb.FindWindowById(id)
|
||||
|
||||
def advance_selection(self, forward):
|
||||
self.tb.AdvanceSelection(forward)
|
||||
|
||||
def remove_buffer(self, pos):
|
||||
self.tb.DeletePage(pos)
|
||||
|
||||
def remove_buffer_from_position(self, pos):
|
||||
return self.tb.RemovePage(pos)
|
||||
|
41
src/wxUI/search.py
Normal file
41
src/wxUI/search.py
Normal file
@@ -0,0 +1,41 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
import wx
|
||||
from pubsub import pub
|
||||
|
||||
class searchPanel(wx.Panel):
|
||||
|
||||
def __init__(self, services=[], *args, **kwargs):
|
||||
super(searchPanel, self).__init__(*args, **kwargs)
|
||||
sizer = wx.BoxSizer(wx.VERTICAL)
|
||||
lbl2 = wx.StaticText(self, wx.NewId(), _("search"))
|
||||
self.text = wx.TextCtrl(self, wx.NewId())
|
||||
box = wx.BoxSizer(wx.HORIZONTAL)
|
||||
box.Add(lbl2, 0, wx.GROW)
|
||||
box.Add(self.text, 1, wx.GROW)
|
||||
box.Add(wx.StaticText(self, wx.NewId(), _(u"Search in")), 0, wx.GROW)
|
||||
self.service = wx.ComboBox(self, wx.NewId(), choices=services, value=services[0], style=wx.CB_READONLY)
|
||||
box.Add(self.service, 1, wx.GROW)
|
||||
self.search = wx.Button(self, wx.NewId(), _(u"Search"))
|
||||
self.search.SetDefault()
|
||||
self.search.Bind(wx.EVT_BUTTON, self.on_search)
|
||||
box.Add(self.search, 0, wx.GROW)
|
||||
sizer.Add(box, 0, wx.GROW)
|
||||
lbl = wx.StaticText(self, wx.NewId(), _(u"Results"))
|
||||
self.list = wx.ListBox(self, wx.NewId())
|
||||
sizer.Add(lbl, 0, wx.GROW)
|
||||
sizer.Add(self.list, 1, wx.GROW)
|
||||
self.SetSizer(sizer)
|
||||
|
||||
def get_text(self):
|
||||
t = self.text.GetValue()
|
||||
self.text.ChangeValue("")
|
||||
return t
|
||||
|
||||
def get_item(self):
|
||||
return self.list.GetSelection()
|
||||
|
||||
def on_search(self, event, *args, **kwargs):
|
||||
text = self.get_text()
|
||||
service = self.service.GetValue()
|
||||
pub.sendMessage("search", service=service, text=text)
|
||||
event.Skip()
|
Reference in New Issue
Block a user