Merge pull request #877 from MikeTheWatchGuy/Dev-latest
Table Element Update - added new num_rows parm. Removed the _my_wind…
This commit is contained in:
		
						commit
						e57db04c83
					
				
					 1 changed files with 73 additions and 55 deletions
				
			
		
							
								
								
									
										128
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							
							
						
						
									
										128
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							|  | @ -187,25 +187,6 @@ MENU_DISABLED_CHARACTER = '!' | ||||||
| MENU_KEY_SEPARATOR = '::' | MENU_KEY_SEPARATOR = '::' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # a shameful global variable. This represents the top-level window information. Needed because opening a second window is different than opening the first. |  | ||||||
| class MyWindows(): |  | ||||||
|     def __init__(self): |  | ||||||
|         self.NumOpenWindows = 0 |  | ||||||
|         self.user_defined_icon = None |  | ||||||
|         self.hidden_master_root = None |  | ||||||
| 
 |  | ||||||
|     def Decrement(self): |  | ||||||
|         self.NumOpenWindows -= 1 * (self.NumOpenWindows != 0)  # decrement if not 0 |  | ||||||
|         # print('---- DECREMENTING Num Open Windows = {} ---'.format(self.NumOpenWindows)) |  | ||||||
| 
 |  | ||||||
|     def Increment(self): |  | ||||||
|         self.NumOpenWindows += 1 |  | ||||||
|         # print('++++ INCREMENTING Num Open Windows = {} ++++'.format(self.NumOpenWindows)) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| _my_windows = MyWindows()  # terrible hack using globals... means need a class for collecing windows |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # ====================================================================== # | # ====================================================================== # | ||||||
| # One-liner functions that are handy as f_ck                             # | # One-liner functions that are handy as f_ck                             # | ||||||
| # ====================================================================== # | # ====================================================================== # | ||||||
|  | @ -1408,7 +1389,7 @@ class Button(Element): | ||||||
| 
 | 
 | ||||||
|     # -------  Button Callback  ------- # |     # -------  Button Callback  ------- # | ||||||
|     def ButtonCallBack(self): |     def ButtonCallBack(self): | ||||||
|         global _my_windows |         # global _my_windows | ||||||
| 
 | 
 | ||||||
|         # print('Button callback') |         # print('Button callback') | ||||||
| 
 | 
 | ||||||
|  | @ -1502,7 +1483,8 @@ class Button(Element): | ||||||
|                 self.ParentForm.TKroot.quit() |                 self.ParentForm.TKroot.quit() | ||||||
|             if self.ParentForm.NonBlocking: |             if self.ParentForm.NonBlocking: | ||||||
|                 self.ParentForm.TKroot.destroy() |                 self.ParentForm.TKroot.destroy() | ||||||
|                 _my_windows.Decrement() |                 # _my_windows.Decrement() | ||||||
|  |                 Window.DecrementOpenCount() | ||||||
|         elif self.BType == BUTTON_TYPE_READ_FORM:  # LEAVE THE WINDOW OPEN!! DO NOT CLOSE |         elif self.BType == BUTTON_TYPE_READ_FORM:  # LEAVE THE WINDOW OPEN!! DO NOT CLOSE | ||||||
|             # first, get the results table built |             # first, get the results table built | ||||||
|             # modify the Results table in the parent FlexForm object |             # modify the Results table in the parent FlexForm object | ||||||
|  | @ -1517,7 +1499,8 @@ class Button(Element): | ||||||
|             self.ParentForm._Close() |             self.ParentForm._Close() | ||||||
|             if self.ParentForm.NonBlocking: |             if self.ParentForm.NonBlocking: | ||||||
|                 self.ParentForm.TKroot.destroy() |                 self.ParentForm.TKroot.destroy() | ||||||
|                 _my_windows.Decrement() |                 Window.DecrementOpenCount() | ||||||
|  |                 # _my_windows.Decrement() | ||||||
|         elif self.BType == BUTTON_TYPE_CALENDAR_CHOOSER:  # this is a return type button so GET RESULTS and destroy window |         elif self.BType == BUTTON_TYPE_CALENDAR_CHOOSER:  # this is a return type button so GET RESULTS and destroy window | ||||||
|             should_submit_window = False |             should_submit_window = False | ||||||
|             root = tk.Toplevel() |             root = tk.Toplevel() | ||||||
|  | @ -1621,7 +1604,8 @@ class ProgressBar(Element): | ||||||
|         try: |         try: | ||||||
|             self.ParentForm.TKroot.update() |             self.ParentForm.TKroot.update() | ||||||
|         except: |         except: | ||||||
|             _my_windows.Decrement() |             Window.DecrementOpenCount() | ||||||
|  |             # _my_windows.Decrement() | ||||||
|             return False |             return False | ||||||
|         return True |         return True | ||||||
| 
 | 
 | ||||||
|  | @ -2800,7 +2784,7 @@ class Table(Element): | ||||||
|                          size=size, pad=pad, key=key, tooltip=tooltip, visible=visible) |                          size=size, pad=pad, key=key, tooltip=tooltip, visible=visible) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     def Update(self, values=None, visible=None): |     def Update(self, values=None, num_rows=None, visible=None): | ||||||
|         if values is not None: |         if values is not None: | ||||||
|             children = self.TKTreeview.get_children() |             children = self.TKTreeview.get_children() | ||||||
|             for i in children: |             for i in children: | ||||||
|  | @ -2820,6 +2804,8 @@ class Table(Element): | ||||||
|             self.TKTreeview.pack_forget() |             self.TKTreeview.pack_forget() | ||||||
|         elif visible is True: |         elif visible is True: | ||||||
|             self.TKTreeview.pack() |             self.TKTreeview.pack() | ||||||
|  |         if num_rows is not None: | ||||||
|  |             self.TKTreeview.config(height=num_rows) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     def treeview_selected(self, event): |     def treeview_selected(self, event): | ||||||
|  | @ -3021,6 +3007,9 @@ Stretch = ErrorElement | ||||||
| #                       Window CLASS                                      # | #                       Window CLASS                                      # | ||||||
| # ------------------------------------------------------------------------- # | # ------------------------------------------------------------------------- # | ||||||
| class Window: | class Window: | ||||||
|  |     NumOpenWindows = 0 | ||||||
|  |     user_defined_icon = None | ||||||
|  |     hidden_master_root = None | ||||||
| 
 | 
 | ||||||
|     def __init__(self, title, default_element_size=DEFAULT_ELEMENT_SIZE, default_button_element_size=(None, None), |     def __init__(self, title, default_element_size=DEFAULT_ELEMENT_SIZE, default_button_element_size=(None, None), | ||||||
|                  auto_size_text=None, auto_size_buttons=None, location=(None, None), size=(None, None), element_padding=None, button_color=None, font=None, |                  auto_size_text=None, auto_size_buttons=None, location=(None, None), size=(None, None), element_padding=None, button_color=None, font=None, | ||||||
|  | @ -3070,7 +3059,7 @@ class Window: | ||||||
|         self.Font = font if font else DEFAULT_FONT |         self.Font = font if font else DEFAULT_FONT | ||||||
|         self.RadioDict = {} |         self.RadioDict = {} | ||||||
|         self.BorderDepth = border_depth |         self.BorderDepth = border_depth | ||||||
|         self.WindowIcon = icon if icon is not None else _my_windows.user_defined_icon |         self.WindowIcon = icon if icon is not None else Window.user_defined_icon | ||||||
|         self.AutoClose = auto_close |         self.AutoClose = auto_close | ||||||
|         self.NonBlocking = False |         self.NonBlocking = False | ||||||
|         self.TKroot = None |         self.TKroot = None | ||||||
|  | @ -3108,6 +3097,15 @@ class Window: | ||||||
|         self.XFound = False |         self.XFound = False | ||||||
|         self.ElementPadding = element_padding or DEFAULT_ELEMENT_PADDING |         self.ElementPadding = element_padding or DEFAULT_ELEMENT_PADDING | ||||||
| 
 | 
 | ||||||
|  |     @staticmethod | ||||||
|  |     def IncrementOpenCount(): | ||||||
|  |         Window.NumOpenWindows += 1 | ||||||
|  |         # print('+++++ INCREMENTING Num Open Windows = {} ---'.format(Window.NumOpenWindows)) | ||||||
|  | 
 | ||||||
|  |     @staticmethod | ||||||
|  |     def DecrementOpenCount(): | ||||||
|  |         Window.NumOpenWindows -= 1 * (Window.NumOpenWindows != 0)  # decrement if not 0 | ||||||
|  |         # print('----- DECREMENTING Num Open Windows = {} ---'.format(Window.NumOpenWindows)) | ||||||
| 
 | 
 | ||||||
|     # ------------------------- Add ONE Row to Form ------------------------- # |     # ------------------------- Add ONE Row to Form ------------------------- # | ||||||
|     def AddRow(self, *args): |     def AddRow(self, *args): | ||||||
|  | @ -3254,7 +3252,8 @@ class Window: | ||||||
|                     rc = self.TKroot.update() |                     rc = self.TKroot.update() | ||||||
|                 except: |                 except: | ||||||
|                     self.TKrootDestroyed = True |                     self.TKrootDestroyed = True | ||||||
|                     _my_windows.Decrement() |                     Window.DecrementOpenCount() | ||||||
|  |                     # _my_windows.Decrement() | ||||||
|                     # print('ROOT Destroyed') |                     # print('ROOT Destroyed') | ||||||
|                 results = BuildResults(self, False, self) |                 results = BuildResults(self, False, self) | ||||||
|                 if results[0] != None and results[0] != timeout_key: |                 if results[0] != None and results[0] != timeout_key: | ||||||
|  | @ -3294,12 +3293,14 @@ class Window: | ||||||
|             if self.RootNeedsDestroying: |             if self.RootNeedsDestroying: | ||||||
|                 # print('*** DESTROYING LATE ***') |                 # print('*** DESTROYING LATE ***') | ||||||
|                 self.TKroot.destroy() |                 self.TKroot.destroy() | ||||||
|                 _my_windows.Decrement() |                 Window.DecrementOpenCount() | ||||||
|  |                 # _my_windows.Decrement() | ||||||
|                 self.LastButtonClicked = None |                 self.LastButtonClicked = None | ||||||
|                 return None, None |                 return None, None | ||||||
|             # if form was closed with X |             # if form was closed with X | ||||||
|             if self.LastButtonClicked is None and self.LastKeyboardEvent is None and self.ReturnValues[0] is None: |             if self.LastButtonClicked is None and self.LastKeyboardEvent is None and self.ReturnValues[0] is None: | ||||||
|                 _my_windows.Decrement() |                 Window.DecrementOpenCount() | ||||||
|  |                 # _my_windows.Decrement() | ||||||
|         # Determine return values |         # Determine return values | ||||||
|         if self.LastKeyboardEvent is not None or self.LastButtonClicked is not None: |         if self.LastKeyboardEvent is not None or self.LastButtonClicked is not None: | ||||||
|             results =  BuildResults(self, False, self) |             results =  BuildResults(self, False, self) | ||||||
|  | @ -3330,13 +3331,15 @@ class Window: | ||||||
|             rc = self.TKroot.update() |             rc = self.TKroot.update() | ||||||
|         except: |         except: | ||||||
|             self.TKrootDestroyed = True |             self.TKrootDestroyed = True | ||||||
|             _my_windows.Decrement() |             Window.DecrementOpenCount() | ||||||
|  |             # _my_windows.Decrement() | ||||||
|             # print("read failed") |             # print("read failed") | ||||||
|             # return None, None |             # return None, None | ||||||
|         if self.RootNeedsDestroying: |         if self.RootNeedsDestroying: | ||||||
|             # print('*** DESTROYING LATE ***', self.ReturnValues) |             # print('*** DESTROYING LATE ***', self.ReturnValues) | ||||||
|             self.TKroot.destroy() |             self.TKroot.destroy() | ||||||
|             _my_windows.Decrement() |             Window.DecrementOpenCount() | ||||||
|  |             # _my_windows.Decrement() | ||||||
|             self.Values = None |             self.Values = None | ||||||
|             self.LastButtonClicked = None |             self.LastButtonClicked = None | ||||||
|             return None, None |             return None, None | ||||||
|  | @ -3351,7 +3354,8 @@ class Window: | ||||||
|             rc = self.TKroot.update() |             rc = self.TKroot.update() | ||||||
|         except: |         except: | ||||||
|             self.TKrootDestroyed = True |             self.TKrootDestroyed = True | ||||||
|             _my_windows.Decrement() |             Window.DecrementOpenCount() | ||||||
|  |             # _my_windows.Decrement() | ||||||
|             # return None, None |             # return None, None | ||||||
|         return self |         return self | ||||||
| 
 | 
 | ||||||
|  | @ -3481,7 +3485,8 @@ class Window: | ||||||
|             return |             return | ||||||
|         try: |         try: | ||||||
|             self.TKroot.destroy() |             self.TKroot.destroy() | ||||||
|             _my_windows.Decrement() |             Window.DecrementOpenCount() | ||||||
|  |             # _my_windows.Decrement() | ||||||
|         except: |         except: | ||||||
|             pass |             pass | ||||||
| 
 | 
 | ||||||
|  | @ -3490,7 +3495,7 @@ class Window: | ||||||
| 
 | 
 | ||||||
|     # IT FINALLY WORKED! 29-Oct-2018 was the first time this damned thing got called |     # IT FINALLY WORKED! 29-Oct-2018 was the first time this damned thing got called | ||||||
|     def OnClosingCallback(self): |     def OnClosingCallback(self): | ||||||
|         global _my_windows |         # global _my_windows | ||||||
|         # print('Got closing callback', self.DisableClose) |         # print('Got closing callback', self.DisableClose) | ||||||
|         if self.DisableClose: |         if self.DisableClose: | ||||||
|             return |             return | ||||||
|  | @ -5225,21 +5230,28 @@ def ConvertFlexToTK(MyFlexForm): | ||||||
| 
 | 
 | ||||||
| # ----====----====----====----====----==== STARTUP TK ====----====----====----====----====----# | # ----====----====----====----====----==== STARTUP TK ====----====----====----====----====----# | ||||||
| def StartupTK(my_flex_form): | def StartupTK(my_flex_form): | ||||||
|     global _my_windows |     # global _my_windows | ||||||
| 
 |  | ||||||
|     ow = _my_windows.NumOpenWindows |  | ||||||
| 
 | 
 | ||||||
|  |     # ow = _my_windows.NumOpenWindows | ||||||
|  |     ow = Window.NumOpenWindows | ||||||
|  |     print(ow) | ||||||
|     # print('Starting TK open Windows = {}'.format(ow)) |     # print('Starting TK open Windows = {}'.format(ow)) | ||||||
|     if not ow and not my_flex_form.ForceTopLevel: |     if not ow and not my_flex_form.ForceTopLevel: | ||||||
|         # if first window being created, make a throwaway, hidden master root.  This stops one user |         # if first window being created, make a throwaway, hidden master root.  This stops one user | ||||||
|         # window from becoming the child of another user window. All windows are children of this |         # window from becoming the child of another user window. All windows are children of this | ||||||
|         # hidden window |         # hidden window | ||||||
|         _my_windows.Increment() |         print("******") | ||||||
|         _my_windows.hidden_master_root = tk.Tk() |         Window.IncrementOpenCount() | ||||||
|         _my_windows.hidden_master_root.attributes('-alpha', 0)  # HIDE this window really really really good |         Window.hidden_master_root = tk.Tk() | ||||||
|         _my_windows.hidden_master_root.wm_overrideredirect(True) # damn, what did this do again? |         Window.hidden_master_root.attributes('-alpha', 0)  # HIDE this window really really really | ||||||
|         _my_windows.hidden_master_root.withdraw()               # no, REALLY hide it |         Window.hidden_master_root.wm_overrideredirect(True) | ||||||
|         # root = tk.Tk()            # users windows are no longer using tk.Tk. They are all Toplevel windows |         Window.hidden_master_root.withdraw() | ||||||
|  |         #  good | ||||||
|  |         # _my_windows.Increment() | ||||||
|  |         # _my_windows.hidden_master_root = tk.Tk() | ||||||
|  |         # _my_windows.hidden_master_root.attributes('-alpha', 0)  # HIDE this window really really really good | ||||||
|  |         # _my_windows.hidden_master_root.wm_overrideredirect(True) # damn, what did this do again? | ||||||
|  |         # _my_windows.hidden_master_root.withdraw()               # no, REALLY hide it | ||||||
|         root = tk.Toplevel() |         root = tk.Toplevel() | ||||||
|     else: |     else: | ||||||
|         root = tk.Toplevel() |         root = tk.Toplevel() | ||||||
|  | @ -5248,10 +5260,10 @@ def StartupTK(my_flex_form): | ||||||
|         root.attributes('-alpha', 0)  # hide window while building it. makes for smoother 'paint' |         root.attributes('-alpha', 0)  # hide window while building it. makes for smoother 'paint' | ||||||
|     except: |     except: | ||||||
|         pass |         pass | ||||||
|     # root.wm_overrideredirect(True) |  | ||||||
|     if my_flex_form.BackgroundColor is not None and my_flex_form.BackgroundColor != COLOR_SYSTEM_DEFAULT: |     if my_flex_form.BackgroundColor is not None and my_flex_form.BackgroundColor != COLOR_SYSTEM_DEFAULT: | ||||||
|         root.configure(background=my_flex_form.BackgroundColor) |         root.configure(background=my_flex_form.BackgroundColor) | ||||||
|     _my_windows.Increment() |     Window.IncrementOpenCount() | ||||||
|  |     # _my_windows.Increment() | ||||||
| 
 | 
 | ||||||
|     my_flex_form.TKroot = root |     my_flex_form.TKroot = root | ||||||
|     # Make moveable window |     # Make moveable window | ||||||
|  | @ -5304,7 +5316,8 @@ def StartupTK(my_flex_form): | ||||||
|         my_flex_form.TimerCancelled = True |         my_flex_form.TimerCancelled = True | ||||||
|         # print('..... BACK from MainLoop') |         # print('..... BACK from MainLoop') | ||||||
|         if not my_flex_form.FormRemainedOpen: |         if not my_flex_form.FormRemainedOpen: | ||||||
|             _my_windows.Decrement() |             Window.DecrementOpenCount() | ||||||
|  |             # _my_windows.Decrement() | ||||||
|         if my_flex_form.RootNeedsDestroying: |         if my_flex_form.RootNeedsDestroying: | ||||||
|             my_flex_form.TKroot.destroy() |             my_flex_form.TKroot.destroy() | ||||||
|             my_flex_form.RootNeedsDestroying = False |             my_flex_form.RootNeedsDestroying = False | ||||||
|  | @ -5400,7 +5413,7 @@ def _ProgressMeterUpdate(bar, value, text_elem, *args): | ||||||
|     :param value: int |     :param value: int | ||||||
|     :return: True if not cancelled, OK....False if Error |     :return: True if not cancelled, OK....False if Error | ||||||
|     ''' |     ''' | ||||||
|     global _my_windows |     # global _my_windows | ||||||
|     if bar == None: return False |     if bar == None: return False | ||||||
|     if bar.BarExpired: return False |     if bar.BarExpired: return False | ||||||
|     message, w, h = ConvertArgsToSingleString(*args) |     message, w, h = ConvertArgsToSingleString(*args) | ||||||
|  | @ -5412,7 +5425,8 @@ def _ProgressMeterUpdate(bar, value, text_elem, *args): | ||||||
|         bar.BarExpired = True |         bar.BarExpired = True | ||||||
|         bar.ParentForm._Close() |         bar.ParentForm._Close() | ||||||
|         if rc:  # if update was OK but bar expired, decrement num windows |         if rc:  # if update was OK but bar expired, decrement num windows | ||||||
|             _my_windows.Decrement() |             # _my_windows.Decrement() | ||||||
|  |             Window.DecrementOpenCount() | ||||||
|     if bar.ParentForm.RootNeedsDestroying: |     if bar.ParentForm.RootNeedsDestroying: | ||||||
|         try: |         try: | ||||||
|             bar.ParentForm.TKroot.destroy() |             bar.ParentForm.TKroot.destroy() | ||||||
|  | @ -5747,14 +5761,15 @@ ScrolledTextBox = PopupScrolled | ||||||
| # Sets the icon to be used by default                # | # Sets the icon to be used by default                # | ||||||
| # ===================================================# | # ===================================================# | ||||||
| def SetGlobalIcon(icon): | def SetGlobalIcon(icon): | ||||||
|     global _my_windows |     # global _my_windows | ||||||
| 
 | 
 | ||||||
|     try: |     try: | ||||||
|         with open(icon, 'r') as icon_file: |         with open(icon, 'r') as icon_file: | ||||||
|             pass |             pass | ||||||
|     except: |     except: | ||||||
|         raise FileNotFoundError |         raise FileNotFoundError | ||||||
|     _my_windows.user_defined_icon = icon |     # _my_windows.user_defined_icon = icon | ||||||
|  |     Window.user_defined_icon = icon | ||||||
|     return True |     return True | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -5804,7 +5819,7 @@ def SetOptions(icon=None, button_color=None, element_size=(None, None), button_e | ||||||
|     global DEFAULT_INPUT_TEXT_COLOR |     global DEFAULT_INPUT_TEXT_COLOR | ||||||
|     global DEFAULT_TOOLTIP_TIME |     global DEFAULT_TOOLTIP_TIME | ||||||
|     global DEFAULT_ERROR_BUTTON_COLOR |     global DEFAULT_ERROR_BUTTON_COLOR | ||||||
|     global _my_windows |     # global _my_windows | ||||||
| 
 | 
 | ||||||
|     if icon: |     if icon: | ||||||
|         try: |         try: | ||||||
|  | @ -5812,7 +5827,8 @@ def SetOptions(icon=None, button_color=None, element_size=(None, None), button_e | ||||||
|                 pass |                 pass | ||||||
|         except: |         except: | ||||||
|             raise FileNotFoundError |             raise FileNotFoundError | ||||||
|         _my_windows.user_defined_icon = icon |         Window.user_defined_icon = icon | ||||||
|  |         # _my_windows.user_defined_icon = icon | ||||||
| 
 | 
 | ||||||
|     if button_color != None: |     if button_color != None: | ||||||
|         DEFAULT_BUTTON_COLOR = button_color |         DEFAULT_BUTTON_COLOR = button_color | ||||||
|  | @ -6723,10 +6739,11 @@ def PopupGetFolder(message, title=None, default_path='', no_window=False, size=( | ||||||
|     :return: Contents of text field. None if closed using X or cancelled |     :return: Contents of text field. None if closed using X or cancelled | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     global _my_windows |     # global _my_windows | ||||||
| 
 | 
 | ||||||
|     if no_window: |     if no_window: | ||||||
|         if _my_windows.NumOpenWindows: |         # if _my_windows.NumOpenWindows: | ||||||
|  |         if Window.NumOpenWindows: | ||||||
|             root = tk.Toplevel() |             root = tk.Toplevel() | ||||||
|         else: |         else: | ||||||
|             root = tk.Tk() |             root = tk.Tk() | ||||||
|  | @ -6783,10 +6800,11 @@ def PopupGetFile(message, title=None, default_path='', default_extension='', sav | ||||||
|     :return:  string representing the path chosen, None if cancelled or window closed with X |     :return:  string representing the path chosen, None if cancelled or window closed with X | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     global _my_windows |     # global _my_windows | ||||||
| 
 | 
 | ||||||
|     if no_window: |     if no_window: | ||||||
|         if _my_windows.NumOpenWindows: |         # if _my_windows.NumOpenWindows: | ||||||
|  |         if Window.NumOpenWindows: | ||||||
|             root = tk.Toplevel() |             root = tk.Toplevel() | ||||||
|         else: |         else: | ||||||
|             root = tk.Tk() |             root = tk.Tk() | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue