ButtonMenu changes and fixes - set default font, allow menu definition to be not set in update, fixed missing colors when updating menu

This commit is contained in:
PySimpleGUI 2021-06-27 19:36:36 -04:00
parent 1c1db88f58
commit 7d2201bfed
1 changed files with 21 additions and 9 deletions

View File

@ -1,6 +1,6 @@
#!/usr/bin/python3 #!/usr/bin/python3
version = __version__ = "4.45.0.1 Unreleased\nAdded autoscroll parameter to Multiline.print & cprint - defaults to True (backward compatible)" version = __version__ = "4.45.0.2 Unreleased\nAdded autoscroll parameter to Multiline.print & cprint - defaults to True (backward compatible), ButtonMenu use font for button as menu font if none is supplied, make a copy of menu definition when making ButtonMenu, made menu definition optional for ButtonMenu so can change only some other settings"
__version__ = version.split()[0] # For PEP 396 and PEP 345 __version__ = version.split()[0] # For PEP 396 and PEP 345
@ -4172,8 +4172,8 @@ class ButtonMenu(Element):
:param metadata: User metadata that can be set to ANYTHING :param metadata: User metadata that can be set to ANYTHING
:type metadata: (Any) :type metadata: (Any)
""" """
self.MenuDefinition = copy.deepcopy(menu_def)
self.MenuDefinition = menu_def
self.AutoSizeButton = auto_size_button self.AutoSizeButton = auto_size_button
self.ButtonText = button_text self.ButtonText = button_text
self.ButtonColor = button_color_to_tuple(button_color) self.ButtonColor = button_color_to_tuple(button_color)
@ -4191,7 +4191,7 @@ class ButtonMenu(Element):
self.Disabled = disabled self.Disabled = disabled
self.IsButtonMenu = True self.IsButtonMenu = True
self.MenuItemChosen = None self.MenuItemChosen = None
self.TKButtonMenu = None # type: tk.Menubutton self.Widget = self.TKButtonMenu = None # type: tk.Menubutton
self.TKMenu = None # type: tk.Menu self.TKMenu = None # type: tk.Menu
self.part_of_custom_menubar = False self.part_of_custom_menubar = False
self.custom_menubar_key = None self.custom_menubar_key = None
@ -4219,7 +4219,8 @@ class ButtonMenu(Element):
# self.ParentForm.TKroot.quit() # kick the users out of the mainloop # self.ParentForm.TKroot.quit() # kick the users out of the mainloop
_exit_mainloop(self.ParentForm) _exit_mainloop(self.ParentForm)
def update(self, menu_definition, visible=None):
def update(self, menu_definition=None, visible=None):
""" """
Changes some of the settings for the ButtonMenu Element. Must call `Window.Read` or `Window.Finalize` prior Changes some of the settings for the ButtonMenu Element. Must call `Window.Read` or `Window.Finalize` prior
@ -4232,11 +4233,20 @@ class ButtonMenu(Element):
if not self._widget_was_created(): # if widget hasn't been created yet, then don't allow if not self._widget_was_created(): # if widget hasn't been created yet, then don't allow
return return
self.MenuDefinition = menu_definition
if menu_definition is not None: if menu_definition is not None:
self.TKMenu = tk.Menu(self.TKButtonMenu, tearoff=self.Tearoff) # create the menubar self.MenuDefinition = copy.deepcopy(menu_definition)
AddMenuItem(self.TKMenu, menu_definition[1], self) top_menu = self.TKMenu = tk.Menu(self.TKButtonMenu, tearoff=self.Tearoff, font=self.ItemFont, tearoffcommand=self._tearoff_menu_callback)
self.TKButtonMenu.configure(menu=self.TKMenu)
if self.BackgroundColor not in (COLOR_SYSTEM_DEFAULT, None):
top_menu.config(bg=self.BackgroundColor)
if self.TextColor not in (COLOR_SYSTEM_DEFAULT, None):
top_menu.config(fg=self.TextColor)
if self.DisabledTextColor not in (COLOR_SYSTEM_DEFAULT, None):
top_menu.config(disabledforeground=self.DisabledTextColor)
if self.ItemFont is not None:
top_menu.config(font=self.ItemFont)
AddMenuItem(self.TKMenu, self.MenuDefinition[1], self)
self.TKButtonMenu.configure(menu=self.TKMenu)
if visible is False: if visible is False:
self.TKButtonMenu.pack_forget() self.TKButtonMenu.pack_forget()
elif visible is True: elif visible is True:
@ -12905,6 +12915,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
else: else:
bc = DEFAULT_BUTTON_COLOR bc = DEFAULT_BUTTON_COLOR
bd = element.BorderWidth bd = element.BorderWidth
if element.ItemFont is None:
element.ItemFont = font
tkbutton = element.Widget = tk.Menubutton(tk_row_frame, text=btext, width=width, height=height, justify=tk.LEFT, bd=bd, font=font) tkbutton = element.Widget = tk.Menubutton(tk_row_frame, text=btext, width=width, height=height, justify=tk.LEFT, bd=bd, font=font)
element.TKButtonMenu = tkbutton element.TKButtonMenu = tkbutton
if bc != (None, None) and bc != COLOR_SYSTEM_DEFAULT and bc[1] != COLOR_SYSTEM_DEFAULT: if bc != (None, None) and bc != COLOR_SYSTEM_DEFAULT and bc[1] != COLOR_SYSTEM_DEFAULT:
@ -12944,7 +12956,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
menu_def = element.MenuDefinition menu_def = element.MenuDefinition
top_menu = tk.Menu(tkbutton, tearoff=element.Tearoff, font=font, tearoffcommand=element._tearoff_menu_callback) element.TKMenu = top_menu = tk.Menu(tkbutton, tearoff=element.Tearoff, font=element.ItemFont, tearoffcommand=element._tearoff_menu_callback)
if element.BackgroundColor not in (COLOR_SYSTEM_DEFAULT, None): if element.BackgroundColor not in (COLOR_SYSTEM_DEFAULT, None):
top_menu.config(bg=element.BackgroundColor) top_menu.config(bg=element.BackgroundColor)