Fixed docstring error in set_options. A quick & dirty addition of shortcut character for buttons. Due to backwards compatibility, must be enabled using set_options.

This commit is contained in:
PySimpleGUI 2022-08-21 17:32:25 -04:00
parent add16aa4ee
commit 43702eff5f
1 changed files with 59 additions and 10 deletions

View File

@ -1,6 +1,6 @@
#!/usr/bin/python3
version = __version__ = "4.60.3.79 Unreleased"
version = __version__ = "4.60.3.80 Unreleased"
_change_log = """
Changelog since 4.60.0 released to PyPI on 8-May-2022
@ -203,10 +203,14 @@ _change_log = """
4.60.3.78
Custom Titlebar - Support added to Window.minimize, Window.maximize, and Window.normal
4.60.3.79
Fix for Mulitline showing constand error messages after a Window is closed.
Fix for Mulitline showing constant error messages after a Window is closed.
Fix for correctly restoring stdout, stderr after they've been rerouted. THIS CODE IS NOT YET COMPLETE! Shooting for this weekend to get it done!
Image element - more speicific with tkinter when chaning to a new image so that pypy would stop crashing due to garbage collect not running.
This change didn't fix the pypy problem but it also didn't hurt the code to have it
4.60.3.80
Quick and dirty addition of Alt-shortcuts for Buttons (like exists for Menus)
For backward compatablity, must be enabled using set_options with use_button_shortcuts=True
Fixed docstring errors in set_options docstring
"""
__version__ = version.split()[0] # For PEP 396 and PEP 345
@ -637,6 +641,7 @@ DEFAULT_ALPHA_CHANNEL = 1.0
DEFAULT_HIDE_WINDOW_WHEN_CREATING = True
TOOLTIP_BACKGROUND_COLOR = "#ffffe0"
TOOLTIP_FONT = None
DEFAULT_USE_BUTTON_SHORTCUTS = False
#################### COLOR STUFF ####################
BLUES = ("#082567", "#0A37A3", "#00345B")
PURPLES = ("#480656", "#4F2398", "#380474")
@ -4954,6 +4959,13 @@ class Button(Element):
# self.UseTtkButtons = False # if an image is to be displayed, then force the button to not be a TTK Button
if key is None and k is None:
_key = self.ButtonText
if DEFAULT_USE_BUTTON_SHORTCUTS is True:
pos = _key.find(MENU_SHORTCUT_CHARACTER)
if pos != -1:
if pos < len(MENU_SHORTCUT_CHARACTER) or _key[pos - len(MENU_SHORTCUT_CHARACTER)] != "\\":
_key = _key[:pos] + _key[pos + len(MENU_SHORTCUT_CHARACTER):]
else:
_key = _key.replace('\\'+MENU_SHORTCUT_CHARACTER, MENU_SHORTCUT_CHARACTER)
else:
_key = key if key is not None else k
if highlight_colors is not None:
@ -5244,7 +5256,18 @@ class Button(Element):
# style_name = str(self.Key) + 'custombutton.TButton'
button_style = ttk.Style()
if text is not None:
self.TKButton.configure(text=text)
btext = text
if DEFAULT_USE_BUTTON_SHORTCUTS is True:
pos = btext.find(MENU_SHORTCUT_CHARACTER)
if pos != -1:
if pos < len(MENU_SHORTCUT_CHARACTER) or btext[pos - len(MENU_SHORTCUT_CHARACTER)] != "\\":
btext = btext[:pos] + btext[pos + len(MENU_SHORTCUT_CHARACTER):]
else:
btext = btext.replace('\\'+MENU_SHORTCUT_CHARACTER, MENU_SHORTCUT_CHARACTER)
pos = -1
if pos != -1:
self.TKButton.config(underline=pos)
self.TKButton.configure(text=btext)
self.ButtonText = text
if button_color != (None, None) and button_color != COLOR_SYSTEM_DEFAULT:
bc = button_color_to_tuple(button_color, self.ButtonColor)
@ -15739,8 +15762,18 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
bc = DEFAULT_BUTTON_COLOR
bd = element.BorderWidth
pos = -1
if DEFAULT_USE_BUTTON_SHORTCUTS is True:
pos = btext.find(MENU_SHORTCUT_CHARACTER)
if pos != -1:
if pos < len(MENU_SHORTCUT_CHARACTER) or btext[pos - len(MENU_SHORTCUT_CHARACTER)] != "\\":
btext = btext[:pos] + btext[pos + len(MENU_SHORTCUT_CHARACTER):]
else:
btext = btext.replace('\\'+MENU_SHORTCUT_CHARACTER, MENU_SHORTCUT_CHARACTER)
pos = -1
tkbutton = element.Widget = tk.Button(tk_row_frame, text=btext, width=width, height=height, justify=tk.CENTER, bd=bd, font=font)
if pos != -1:
tkbutton.config(underline=pos)
try:
if btype != BUTTON_TYPE_REALTIME:
tkbutton.config( command=element.ButtonCallBack)
@ -15858,6 +15891,15 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element.TKStringVar = stringvar
element.Location = (row_num, col_num)
btext = element.ButtonText
pos = -1
if DEFAULT_USE_BUTTON_SHORTCUTS is True:
pos = btext.find(MENU_SHORTCUT_CHARACTER)
if pos != -1:
if pos < len(MENU_SHORTCUT_CHARACTER) or btext[pos - len(MENU_SHORTCUT_CHARACTER)] != "\\":
btext = btext[:pos] + btext[pos + len(MENU_SHORTCUT_CHARACTER):]
else:
btext = btext.replace('\\'+MENU_SHORTCUT_CHARACTER, MENU_SHORTCUT_CHARACTER)
pos = -1
btype = element.BType
if element.AutoSizeButton is not None:
auto_size = element.AutoSizeButton
@ -15876,6 +15918,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
bc = DEFAULT_BUTTON_COLOR
bd = element.BorderWidth
tkbutton = element.Widget = ttk.Button(tk_row_frame, text=btext, width=width)
if pos != -1:
tkbutton.config(underline=pos)
if btype != BUTTON_TYPE_REALTIME:
tkbutton.config(command=element.ButtonCallBack)
else:
@ -18539,7 +18583,7 @@ def set_options(icon=None, button_color=None, element_size=(None, None), button_
enable_mac_notitlebar_patch=None, use_custom_titlebar=None, titlebar_background_color=None, titlebar_text_color=None, titlebar_font=None,
titlebar_icon=None, user_settings_path=None, pysimplegui_settings_path=None, pysimplegui_settings_filename=None, keep_on_top=None, dpi_awareness=None, scaling=None, disable_modal_windows=None, force_modal_windows=None, tooltip_offset=(None, None),
sbar_trough_color=None, sbar_background_color=None, sbar_arrow_color=None, sbar_width=None, sbar_arrow_width=None, sbar_frame_color=None, sbar_relief=None, alpha_channel=None,
hide_window_when_creating=None):
hide_window_when_creating=None, use_button_shortcuts=None):
"""
:param icon: Can be either a filename or Base64 value. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO. Most portable is to use a Base64 of a PNG file. This works universally across all OS's
:type icon: bytes | str
@ -18667,10 +18711,12 @@ def set_options(icon=None, button_color=None, element_size=(None, None), button_
:type sbar_frame_color: (str)
:param sbar_relief: Scrollbar relief that will be used for the "thumb" of the scrollbar (the thing you grab that slides). Should be a constant that is defined at starting with "RELIEF_" - RELIEF_RAISED, RELIEF_SUNKEN, RELIEF_FLAT, RELIEF_RIDGE, RELIEF_GROOVE, RELIEF_SOLID
:type sbar_relief: (str)
:param alpha_channel Default alpha channel to be used on all windows
:type alpha_channel (float)
:param hide_window_when_creating If True then alpha will be set to 0 while a window is made and moved to location indicated
:type hide_window_when_creating (bool)
:param alpha_channel: Default alpha channel to be used on all windows
:type alpha_channel: (float)
:param hide_window_when_creating: If True then alpha will be set to 0 while a window is made and moved to location indicated
:type hide_window_when_creating: (bool)
:param use_button_shortcuts: If True then Shortcut Char will be used with Buttons
:type use_button_shortcuts: (bool)
:return: None
:rtype: None
"""
@ -18733,6 +18779,7 @@ def set_options(icon=None, button_color=None, element_size=(None, None), button_
global _pysimplegui_user_settings
global ttk_part_overrides_from_options
global DEFAULT_HIDE_WINDOW_WHEN_CREATING
global DEFAULT_USE_BUTTON_SHORTCUTS
# global _my_windows
if icon:
@ -18945,6 +18992,8 @@ def set_options(icon=None, button_color=None, element_size=(None, None), button_
if hide_window_when_creating is not None:
DEFAULT_HIDE_WINDOW_WHEN_CREATING = hide_window_when_creating
if use_button_shortcuts is not None:
DEFAULT_USE_BUTTON_SHORTCUTS = use_button_shortcuts
return True