Go back to the old order for loading the demo tabs. When the first

sample is chosen then switch to the demo page, but stay on the current
page for the other selections in case the user switched back to the
overview or demo code pages.


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@28741 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robin Dunn 2004-08-10 01:24:48 +00:00
parent 4b8e2a3466
commit a6780fa226

View File

@ -530,6 +530,7 @@ class DemoCodePanel(wx.Panel):
def ActiveModuleChanged(self): def ActiveModuleChanged(self):
self.LoadDemoSource(self.demoModules.GetSource()) self.LoadDemoSource(self.demoModules.GetSource())
self.UpdateControlState() self.UpdateControlState()
self.ReloadDemo()
def LoadDemoSource(self, source): def LoadDemoSource(self, source):
@ -573,12 +574,11 @@ class DemoCodePanel(wx.Panel):
busy = wx.BusyInfo("Reloading demo module...") busy = wx.BusyInfo("Reloading demo module...")
self.demoModules.SetActive(modSelected) self.demoModules.SetActive(modSelected)
self.ActiveModuleChanged() self.ActiveModuleChanged()
self.ReloadDemo()
def ReloadDemo(self): def ReloadDemo(self):
if self.demoModules.name != __name__: if self.demoModules.name != __name__:
self.mainFrame.RunModule(False) self.mainFrame.RunModule()
def OnCodeModified(self, event): def OnCodeModified(self, event):
@ -624,7 +624,6 @@ class DemoCodePanel(wx.Panel):
busy = wx.BusyInfo("Reloading demo module...") busy = wx.BusyInfo("Reloading demo module...")
self.demoModules.LoadFromFile(modModified, modifiedFilename) self.demoModules.LoadFromFile(modModified, modifiedFilename)
self.ActiveModuleChanged() self.ActiveModuleChanged()
self.ReloadDemo()
def OnRestore(self, event): # Handles the "Delete Modified" button def OnRestore(self, event): # Handles the "Delete Modified" button
@ -633,7 +632,6 @@ class DemoCodePanel(wx.Panel):
os.unlink(modifiedFilename) # Delete the modified copy os.unlink(modifiedFilename) # Delete the modified copy
busy = wx.BusyInfo("Reloading demo module...") busy = wx.BusyInfo("Reloading demo module...")
self.ActiveModuleChanged() self.ActiveModuleChanged()
self.ReloadDemo()
#--------------------------------------------------------------------------- #---------------------------------------------------------------------------
@ -715,8 +713,6 @@ class DemoModules:
# load modified module (if one exists) # load modified module (if one exists)
if DoesModifiedExist(name): if DoesModifiedExist(name):
self.LoadFromFile(modModified, GetModifiedFilename(name)) self.LoadFromFile(modModified, GetModifiedFilename(name))
if (modDefault == modModified):
self.SetActive(modModified)
def LoadFromFile(self, modID, filename): def LoadFromFile(self, modID, filename):
@ -988,8 +984,8 @@ class wxPythonDemo(wx.Frame):
self.curOverview = "" self.curOverview = ""
self.demoPage = None self.demoPage = None
self.codePage = None self.codePage = None
self.useModified = False
self.shell = None self.shell = None
self.firstTime = True
icon = images.getMondrianIcon() icon = images.getMondrianIcon()
self.SetIcon(icon) self.SetIcon(icon)
@ -1262,7 +1258,7 @@ class wxPythonDemo(wx.Frame):
if os.path.exists(GetOriginalFilename(demoName)): if os.path.exists(GetOriginalFilename(demoName)):
wx.LogMessage("Loading demo %s.py..." % demoName) wx.LogMessage("Loading demo %s.py..." % demoName)
self.demoModules = DemoModules(demoName) self.demoModules = DemoModules(demoName)
self.RunModule(True) self.LoadDemoSource()
self.tree.Refresh() self.tree.Refresh()
else: else:
self.SetOverview("wxPython", mainOverview) self.SetOverview("wxPython", mainOverview)
@ -1278,7 +1274,7 @@ class wxPythonDemo(wx.Frame):
self.codePage.LoadDemo(self.demoModules) self.codePage.LoadDemo(self.demoModules)
#--------------------------------------------- #---------------------------------------------
def RunModule(self, loadSource): def RunModule(self):
"""Runs the active module""" """Runs the active module"""
module = self.demoModules.GetActive() module = self.demoModules.GetActive()
@ -1306,11 +1302,16 @@ class wxPythonDemo(wx.Frame):
# There was a previous error in compiling or exec-ing # There was a previous error in compiling or exec-ing
self.demoPage = DemoErrorPanel(self.nb, self.codePage, self.demoPage = DemoErrorPanel(self.nb, self.codePage,
self.demoModules.GetErrorInfo(), self) self.demoModules.GetErrorInfo(), self)
if loadSource:
self.LoadDemoSource()
self.SetOverview(self.demoModules.name + " Overview", overviewText) self.SetOverview(self.demoModules.name + " Overview", overviewText)
self.UpdateNotebook()
if self.firstTime:
# cahnge to the demo page the first time a module is run
self.UpdateNotebook(2)
self.firstTime = False
else:
# otherwise just stay on the same tab in case the user has changed to another one
self.UpdateNotebook()
#--------------------------------------------- #---------------------------------------------
def ShutdownDemoModule(self): def ShutdownDemoModule(self):