--- nfo/projects/netfraggle/bin/fraggleViewport.py 2004/08/26 23:10:12 1.11 +++ nfo/projects/netfraggle/bin/fraggleViewport.py 2004/09/04 20:26:01 1.18 @@ -1,7 +1,34 @@ #Boa:MDIParent:fraggleViewport -# $Id: fraggleViewport.py,v 1.11 2004/08/26 23:10:12 xabbu Exp $ +# $Id: fraggleViewport.py,v 1.18 2004/09/04 20:26:01 xabbu Exp $ # $Log: fraggleViewport.py,v $ +# Revision 1.18 2004/09/04 20:26:01 xabbu +# +Added a button to the Preferences tab for showing the Modules Dialog. +# Todo: When the module dialog is shown, it is still being blocked by the preferences dialog. I am not sure why but will have to look into it further. +# +# +Added modules directory +# +# Revision 1.17 2004/09/01 21:43:30 xabbu +# +Moved funtion getDefaultDir from FraggleCtlPreferences to FraggleEngine for more convenience +# +FraggleCtlModules class creation for handling content modules +# +# Revision 1.16 2004/08/30 13:06:40 joko +# U now gets preferences via self.engine +# +# Revision 1.15 2004/08/27 21:14:02 xabbu +# TopicDetails can now be closed. +# GUI change on Preferences Dialog in order to prepare multiple server profiles. +# Small bugfixes to get the new topic windows working on posix platform. +# +# Revision 1.14 2004/08/27 04:39:06 joko +# cleanup +# +# Revision 1.13 2004/08/27 03:25:44 joko +# added FraggleTaskBarMenu +# +# Revision 1.12 2004/08/27 00:05:22 joko +# fix for icon-path and wxTaskBarIcon-events +# # Revision 1.11 2004/08/26 23:10:12 xabbu # xmlrpc class added # @@ -18,8 +45,9 @@ from wxPython.wx import * from wxPython.stc import * +from fraggleConstants import * import fraggleDialogPrefs -import fraggleCtlPreferences +import FraggleDialogModules import FraggleAboutDialog import FraggleTopicFrame import FraggleXMLRPC @@ -27,12 +55,11 @@ def create(parent): return fraggleViewport(parent) -[wxID_FRAGGLEVIEWPORT, wxID_FRAGGLEVIEWPORTBUTTONSYNC, - wxID_FRAGGLEVIEWPORTSTYLEDTEXTCTRL1, -] = map(lambda _init_ctrls: wxNewId(), range(3)) +[wxID_FRAGGLEVIEWPORT] = map(lambda _init_ctrls: wxNewId(), range(1)) -[wxID_FRAGGLEVIEWPORTMENU1FPREFS, wxID_FRAGGLEVIEWPORTMENU1ITEMS1, -] = map(lambda _init_coll_menu1_Items: wxNewId(), range(2)) +[wxID_FRAGGLEVIEWPORTMENU1FMODULES, wxID_FRAGGLEVIEWPORTMENU1FPREFS, + wxID_FRAGGLEVIEWPORTMENU1ITEMS1, +] = map(lambda _init_coll_menu1_Items: wxNewId(), range(3)) [wxID_FRAGGLEVIEWPORTMENU2ABOUT, wxID_FRAGGLEVIEWPORTMENU2CONT, ] = map(lambda _init_coll_menu2_Items: wxNewId(), range(2)) @@ -40,7 +67,25 @@ [wxID_FRAGGLEVIEWPORTMENU2ABOUT, wxID_FRAGGLEVIEWPORTMENU2CONT, ] = map(lambda _init_coll_menu2_Items: wxNewId(), range(2)) +[wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSEXIT, + wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSRESTORE, + wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSSYNC, +] = map(lambda _init_coll_FraggleTaskBarMenu_Items: wxNewId(), range(3)) + class fraggleViewport(wxMDIParentFrame): + def _init_coll_FraggleTaskBarMenu_Items(self, parent): + # generated method, don't edit + + parent.Append(helpString='Restore', + id=wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSRESTORE, + item='Restore', kind=wxITEM_NORMAL) + parent.Append(helpString='Sync enabled', + id=wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSSYNC, + item='Sync enabled', kind=wxITEM_CHECK) + parent.Append(helpString='Exit', + id=wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSEXIT, item='Exit', + kind=wxITEM_NORMAL) + def _init_coll_menu2_Items(self, parent): # generated method, don't edit @@ -52,12 +97,19 @@ def _init_coll_menu1_Items(self, parent): # generated method, don't edit + parent.Append(helpString='Configure Modules', + id=wxID_FRAGGLEVIEWPORTMENU1FMODULES, item='Modules', + kind=wxITEM_NORMAL) 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) + EVT_MENU(self, wxID_FRAGGLEVIEWPORTMENU1FMODULES, + self.OnMenu1FmodulesMenu) + EVT_MENU(self, wxID_FRAGGLEVIEWPORTMENU1FPREFS, self.OnMenu1FprefsMenu) + EVT_MENU(self, wxID_FRAGGLEVIEWPORTMENU1ITEMS1, self.OnMenu1Items1Menu) def _init_coll_menuBar1_Menus(self, parent): # generated method, don't edit @@ -71,61 +123,66 @@ self.menuBar1.SetAutoLayout(1) self.menu1 = wxMenu(title='') - self._init_coll_menu1_Items(self.menu1) self.menu2 = wxMenu(title='') - self._init_coll_menu2_Items(self.menu2) + + self.FraggleTaskBarMenu = wxMenu(title=u'NetFraggle') self._init_coll_menuBar1_Menus(self.menuBar1) + self._init_coll_menu1_Items(self.menu1) + self._init_coll_menu2_Items(self.menu2) + self._init_coll_FraggleTaskBarMenu_Items(self.FraggleTaskBarMenu) def _init_ctrls(self, prnt): # generated method, don't edit wxMDIParentFrame.__init__(self, id=wxID_FRAGGLEVIEWPORT, - name='fraggleViewport', parent=prnt, pos=wxPoint(525, 292), - size=wxSize(341, 296), + name='fraggleViewport', parent=prnt, pos=wxPoint(335, 382), + size=wxSize(435, 273), style=wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL, title='NetFraggle 0.0.1') self._init_utils() - self.SetClientSize(wxSize(341, 273)) + self.SetClientSize(wxSize(427, 246)) 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_modules__(self): + self.modulesCtl = self.engine.modules + self.dialogModules = FraggleDialogModules.create(self) + def __init_preferences__(self): - self.preferencesCtl = fraggleCtlPreferences.create(self) + self.preferencesCtl = self.engine.preferences self.dialogPrefs = fraggleDialogPrefs.create(self) self.dialogPrefs.loadConfig() self.dialogPrefs.updateConfig() # new as of 2004-08-26: TopicFrame + # new as of 2004-08-27: pass configList to TopicFrame self.topicFrame = FraggleTopicFrame.create(self) - self.topicFrame.Move(wxPoint(10, 10)) + self.topicFrame.Move(wxPoint(5, 5)) #frame.Show() #frame.Destroy() def __init_xmlrpc__(self): - self.xml_rpc = FraggleXMLRPC.create(self, self.preferencesCtl.configList) + #self.xml_rpc = FraggleXMLRPC.create(self, self.preferencesCtl.configList) + pass def __init_taskbar_icon__(self): if os.name == 'posix': pass elif os.name == 'nt': self.tbicon = wxTaskBarIcon() - icon = wxIcon('mixxx.ico', wxBITMAP_TYPE_ICO) + #icon = wxIcon('mixxx.ico', wxBITMAP_TYPE_ICO) + icon = wxIcon(os.path.join(APPLOCATION, '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) - + EVT_TASKBAR_LEFT_DCLICK(self.tbicon, self.OnTaskBarLeftDClick) + EVT_TASKBAR_RIGHT_UP(self.tbicon, self.OnTaskBarRightClick) + EVT_MENU(self.tbicon, wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSRESTORE, self.OnTaskBarAppRestore) + EVT_MENU(self.tbicon, wxID_FRAGGLEVIEWPORTFRAGGLETASKBARMENUITEMSEXIT, self.OnTaskBarAppExit) + def __init__(self, parent): + import __main__ + self.engine = __main__.engine self._init_ctrls(parent) + self.__init_modules__() self.__init_preferences__() self.__init_taskbar_icon__() self.__init_xmlrpc__() @@ -156,18 +213,32 @@ dlg.Destroy() def OnTaskBarLeftDClick(self, event): - event.Skip() + #event.Skip() + #self.SetFocus() + if self.IsIconized(): + self.Restore() + else: + self.Iconize() def OnTaskBarRightClick(self, event): + #event.Skip() + self.tbicon.PopupMenu(self.FraggleTaskBarMenu) + + def OnTaskBarAppRestore(self, event): + self.Restore() + #event.Skip() + + def OnTaskBarAppExit(self, event): + #event.Skip() + #self.Destroy() + self.Close(True) + + def OnMenu1FmodulesMenu(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 + def OnMenu1FprefsMenu(self, event): + event.Skip() + + def OnMenu1Items1Menu(self, event): + event.Skip() +