Merge pull request #4358 from PySimpleGUI/Dev-latest
Better Button error handling when Unicode chars are used or if a bad …
This commit is contained in:
commit
46a8223cbc
|
@ -1,6 +1,6 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
|
|
||||||
version = __version__ = "4.43.0.3 Unreleased\nChanged get_versions string to be more clear, removed canvas from return values, cwd is automatically set to the folder of the application being launched when execute_py_file is called with cwd=None, popup_get_file changed to set parent=None if running on Mac"
|
version = __version__ = "4.43.0.4 Unreleased\nChanged get_versions string to be more clear, removed canvas from return values, cwd is automatically set to the folder of the application being launched when execute_py_file is called with cwd=None, popup_get_file changed to set parent=None if running on Mac, better Button error handling when bad Unicode chars are used or bad colors"
|
||||||
|
|
||||||
__version__ = version.split()[0] # For PEP 396 and PEP 345
|
__version__ = version.split()[0] # For PEP 396 and PEP 345
|
||||||
|
|
||||||
|
@ -12620,6 +12620,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
|
||||||
|
|
||||||
bd = element.BorderWidth
|
bd = element.BorderWidth
|
||||||
|
|
||||||
|
try:
|
||||||
if btype != BUTTON_TYPE_REALTIME:
|
if btype != BUTTON_TYPE_REALTIME:
|
||||||
tkbutton = element.Widget = tk.Button(tk_row_frame, text=btext, width=width, height=height,
|
tkbutton = element.Widget = tk.Button(tk_row_frame, text=btext, width=width, height=height,
|
||||||
command=element.ButtonCallBack, justify=tk.CENTER, bd=bd, font=font)
|
command=element.ButtonCallBack, justify=tk.CENTER, bd=bd, font=font)
|
||||||
|
@ -12629,20 +12630,21 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
|
||||||
tkbutton.bind('<ButtonRelease-1>', element.ButtonReleaseCallBack)
|
tkbutton.bind('<ButtonRelease-1>', element.ButtonReleaseCallBack)
|
||||||
tkbutton.bind('<ButtonPress-1>', element.ButtonPressCallBack)
|
tkbutton.bind('<ButtonPress-1>', element.ButtonPressCallBack)
|
||||||
if bc != (None, None) and COLOR_SYSTEM_DEFAULT not in bc:
|
if bc != (None, None) and COLOR_SYSTEM_DEFAULT not in bc:
|
||||||
try:
|
|
||||||
tkbutton.config(foreground=bc[0], background=bc[1], activebackground=bc[1])
|
tkbutton.config(foreground=bc[0], background=bc[1], activebackground=bc[1])
|
||||||
except Exception as e:
|
|
||||||
_error_popup_with_traceback('Button has bad color string',
|
|
||||||
'Error {}'.format(e),
|
|
||||||
'Button Text: {}'.format(btext),
|
|
||||||
'Button key: {}'.format(element.Key),
|
|
||||||
'Color string: {}'.format(bc),
|
|
||||||
"Parent Window's Title: {}".format(toplevel_form.Title))
|
|
||||||
else:
|
else:
|
||||||
if bc[0] != COLOR_SYSTEM_DEFAULT:
|
if bc[0] != COLOR_SYSTEM_DEFAULT:
|
||||||
tkbutton.config(foreground=bc[0])
|
tkbutton.config(foreground=bc[0])
|
||||||
if bc[1] != COLOR_SYSTEM_DEFAULT:
|
if bc[1] != COLOR_SYSTEM_DEFAULT:
|
||||||
tkbutton.config(background=bc[1])
|
tkbutton.config(background=bc[1])
|
||||||
|
except Exception as e:
|
||||||
|
_error_popup_with_traceback('Button has a problem....',
|
||||||
|
'The traceback information will not show the line in your layout with the problem, but it does tell you which window.',
|
||||||
|
'Error {}'.format(e),
|
||||||
|
# 'Button Text: {}'.format(btext),
|
||||||
|
# 'Button key: {}'.format(element.Key),
|
||||||
|
# 'Color string: {}'.format(bc),
|
||||||
|
"Parent Window's Title: {}".format(toplevel_form.Title))
|
||||||
|
|
||||||
|
|
||||||
if bd == 0 and not running_mac():
|
if bd == 0 and not running_mac():
|
||||||
tkbutton.config(relief=tk.FLAT)
|
tkbutton.config(relief=tk.FLAT)
|
||||||
|
|
Loading…
Reference in New Issue