--- nfo/projects/netfraggle/bin/fraggleViewport.py 2004/08/25 19:54:07 1.5 +++ nfo/projects/netfraggle/bin/fraggleViewport.py 2004/08/26 23:10:12 1.11 @@ -1,41 +1,69 @@ #Boa:MDIParent:fraggleViewport +# $Id: fraggleViewport.py,v 1.11 2004/08/26 23:10:12 xabbu Exp $ +# $Log: fraggleViewport.py,v $ +# Revision 1.11 2004/08/26 23:10:12 xabbu +# xmlrpc class added +# +# Revision 1.10 2004/08/26 18:19:27 joko +# now using FraggleTopicFrame +# +# Revision 1.9 2004/08/26 15:21:13 joko +# renamed namespaces +# added key shortcuts to menu-items +# correct "showAbout" code +# + import os from wxPython.wx import * +from wxPython.stc import * import fraggleDialogPrefs import fraggleCtlPreferences +import FraggleAboutDialog +import FraggleTopicFrame +import FraggleXMLRPC def create(parent): return fraggleViewport(parent) -[wxID_FRAGGLEVIEWPORT] = map(lambda _init_ctrls: wxNewId(), range(1)) +[wxID_FRAGGLEVIEWPORT, wxID_FRAGGLEVIEWPORTBUTTONSYNC, + wxID_FRAGGLEVIEWPORTSTYLEDTEXTCTRL1, +] = map(lambda _init_ctrls: wxNewId(), range(3)) [wxID_FRAGGLEVIEWPORTMENU1FPREFS, wxID_FRAGGLEVIEWPORTMENU1ITEMS1, ] = map(lambda _init_coll_menu1_Items: wxNewId(), range(2)) +[wxID_FRAGGLEVIEWPORTMENU2ABOUT, wxID_FRAGGLEVIEWPORTMENU2CONT, +] = map(lambda _init_coll_menu2_Items: wxNewId(), range(2)) + +[wxID_FRAGGLEVIEWPORTMENU2ABOUT, wxID_FRAGGLEVIEWPORTMENU2CONT, +] = map(lambda _init_coll_menu2_Items: wxNewId(), range(2)) + class fraggleViewport(wxMDIParentFrame): + def _init_coll_menu2_Items(self, parent): + # generated method, don't edit + + parent.Append(helpString='Contents', id=wxID_FRAGGLEVIEWPORTMENU2CONT, + item='Contents', kind=wxITEM_NORMAL) + parent.Append(helpString='About', id=wxID_FRAGGLEVIEWPORTMENU2ABOUT, + item='About', kind=wxITEM_NORMAL) + def _init_coll_menu1_Items(self, parent): # generated method, don't edit - if os.name == "posix": - parent.Append(helpString='Configure Netfraggle', - id=wxID_FRAGGLEVIEWPORTMENU1FPREFS, item='Preferences', - kind=wxITEM_NORMAL) - parent.Append(helpString='Exit Netfraggle', - id=wxID_FRAGGLEVIEWPORTMENU1ITEMS1, item='Exit', - kind=wxITEM_NORMAL) - elif os.name == "nt": - parent.Append(wxID_FRAGGLEVIEWPORTMENU1FPREFS, 'Configure Netfraggle', "", wxITEM_NORMAL) - parent.Append(wxID_FRAGGLEVIEWPORTMENU1FPREFS, 'Exit Netfraggle', "", wxITEM_NORMAL) - - EVT_MENU(self, wxID_FRAGGLEVIEWPORTMENU1FPREFS, self.OnMenu1items0Menu) - EVT_MENU(self, wxID_FRAGGLEVIEWPORTMENU1ITEMS1, self.OnMenu1items1Menu) + parent.Append(helpString='Configure Netfraggle', + id=wxID_FRAGGLEVIEWPORTMENU1FPREFS, item='Preferences', + kind=wxITEM_NORMAL) + parent.Append(helpString='Exit Netfraggle', + id=wxID_FRAGGLEVIEWPORTMENU1ITEMS1, item='Exit', + kind=wxITEM_NORMAL) def _init_coll_menuBar1_Menus(self, parent): # generated method, don't edit - parent.Append(menu=self.menu1, title='File') + parent.Append(menu=self.menu1, title='&File') + parent.Append(menu=self.menu2, title='&Help') def _init_utils(self): # generated method, don't edit @@ -45,36 +73,101 @@ self.menu1 = wxMenu(title='') self._init_coll_menu1_Items(self.menu1) + self.menu2 = wxMenu(title='') + self._init_coll_menu2_Items(self.menu2) + self._init_coll_menuBar1_Menus(self.menuBar1) def _init_ctrls(self, prnt): # generated method, don't edit wxMDIParentFrame.__init__(self, id=wxID_FRAGGLEVIEWPORT, - name='fraggleViewport', parent=prnt, pos=wxPoint(277, 313), - size=wxSize(683, 307), + name='fraggleViewport', parent=prnt, pos=wxPoint(525, 292), + size=wxSize(341, 296), style=wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL, - title='wxMDIParentFrame1') + title='NetFraggle 0.0.1') self._init_utils() - self.SetClientSize(wxSize(683, 284)) + self.SetClientSize(wxSize(341, 273)) self.SetMenuBar(self.menuBar1) + self.buttonsync = wxButton(id=wxID_FRAGGLEVIEWPORTBUTTONSYNC, + label='Sync', name='buttonsync', parent=self, pos=wxPoint(104, + 240), size=wxSize(136, 24), style=0) + EVT_BUTTON(self.buttonsync, wxID_FRAGGLEVIEWPORTBUTTONSYNC, + self.OnButtonsyncButton) + + self.styledTextCtrl1 = wxStyledTextCtrl(id=wxID_FRAGGLEVIEWPORTSTYLEDTEXTCTRL1, + name='styledTextCtrl1', parent=self, pos=wxPoint(8, 16), + size=wxSize(328, 216), style=0) + def __init_preferences__(self): self.preferencesCtl = fraggleCtlPreferences.create(self) self.dialogPrefs = fraggleDialogPrefs.create(self) + self.dialogPrefs.loadConfig() + self.dialogPrefs.updateConfig() + + # new as of 2004-08-26: TopicFrame + self.topicFrame = FraggleTopicFrame.create(self) + self.topicFrame.Move(wxPoint(10, 10)) + #frame.Show() + #frame.Destroy() + def __init_xmlrpc__(self): + self.xml_rpc = FraggleXMLRPC.create(self, self.preferencesCtl.configList) + + def __init_taskbar_icon__(self): + if os.name == 'posix': + pass + elif os.name == 'nt': + self.tbicon = wxTaskBarIcon() + icon = wxIcon('mixxx.ico', wxBITMAP_TYPE_ICO) + self.tbicon.SetIcon(icon, '') + wxEVT_TASKBAR_LEFT_DCLICK(self.tbicon, self.OnTaskBarLeftDClick) + wxEVT_TASKBAR_RIGHT_UP(self.tbicon, self.OnTaskBarRightClick) + def __init__(self, parent): self._init_ctrls(parent) self.__init_preferences__() + self.__init_taskbar_icon__() + self.__init_xmlrpc__() - def OnMenu1items0Menu(self, event): try: self.dialogPrefs.ShowModal() finally: - self.dialogPrefs.Destroy() + self.dialogPrefs.Hide() event.Skip() def OnMenu1items1Menu(self, event): self.Destroy() event.Skip() + + def OnMenu2items0Menu(self, event): + try: + self.dialogPrefs.ShowModal() + finally: + pass + event.Skip() + + def OnMenu2items1Menu(self, event): + """Show about screen""" + dlg = FraggleAboutDialog.create(self) + dlg.ShowModal() + dlg.Destroy() + + def OnTaskBarLeftDClick(self, event): + event.Skip() + + def OnTaskBarRightClick(self, event): + event.Skip() + + def OnButtonsyncButton(self, event): + fragglexml = self.xml_rpc.FraggleSync() + print fragglexml + import codecs + (UTF8_encode, UTF8_decode, + UTF8_streamreader, UTF8_streamwriter) = codecs.lookup('UTF-8') + text = UTF8_decode(repr(fragglexml))[0] + text = fragglexml.data + self.styledTextCtrl1.AddText(text) + event.Skip() \ No newline at end of file