]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/SingleChoiceDialog.py
Ensure the button still exists after the Notify before doing anything
[wxWidgets.git] / wxPython / demo / SingleChoiceDialog.py
index 34c6f50b5fb53d8146deff1ec73ce8f7d983038b..2317d7e398306a33caedee12b153fea70ab754f7 100644 (file)
@@ -1,24 +1,37 @@
-# 11/21/2003 - Jeff Grimmett (grimmtooth@softhome.net)
-#
-# o Updated for wx namespace
-# 
 
 import  wx
 
 #---------------------------------------------------------------------------
 
 
 import  wx
 
 #---------------------------------------------------------------------------
 
-def runTest(frame, nb, log):
-    dlg = wx.SingleChoiceDialog(
-            frame, 'Test Single Choice', 'The Caption',
-            ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight'], 
-            wx.CHOICEDLG_STYLE
-            )
+class TestPanel(wx.Panel):
+    def __init__(self, parent, log):
+        self.log = log
+        wx.Panel.__init__(self, parent, -1)
+
+        b = wx.Button(self, -1, "Create and Show a SingleChoiceDialog", (50,50))
+        self.Bind(wx.EVT_BUTTON, self.OnButton, b)
+
+
+    def OnButton(self, evt):
+        dlg = wx.SingleChoiceDialog(
+                self, 'Test Single Choice', 'The Caption',
+                ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight'], 
+                wx.CHOICEDLG_STYLE
+                )
+
+        if dlg.ShowModal() == wx.ID_OK:
+            self.log.WriteText('You selected: %s\n' % dlg.GetStringSelection())
 
 
-    if dlg.ShowModal() == wx.ID_OK:
-        log.WriteText('You selected: %s\n' % dlg.GetStringSelection())
+        dlg.Destroy()
 
 
-    dlg.Destroy()
 
 
+
+#---------------------------------------------------------------------------
+
+
+def runTest(frame, nb, log):
+    win = TestPanel(nb, log)
+    return win
 #---------------------------------------------------------------------------
 
 
 #---------------------------------------------------------------------------
 
 
@@ -38,5 +51,5 @@ destroy the dialog.
 if __name__ == '__main__':
     import sys,os
     import run
 if __name__ == '__main__':
     import sys,os
     import run
-    run.main(['', os.path.basename(sys.argv[0])])
+    run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])