Fix for not correctly setting Element.ttk_style_name and Element.ttk_style

This commit is contained in:
PySimpleGUI 2022-11-28 06:45:50 -05:00
parent 331774cb5f
commit f869052f8e
1 changed files with 21 additions and 23 deletions

View File

@ -1,6 +1,6 @@
#!/usr/bin/python3
version = __version__ = "4.60.4.122 Unreleased"
version = __version__ = "4.60.4.123 Unreleased"
_change_log = """
Changelog since 4.60.0 released to PyPI on 8-May-2022
@ -308,6 +308,10 @@ _change_log = """
4.60.4.122
Swapped Push and Stretch, VPush and VStretch. Made Push and VPush the function and Stratch and VStresth the aliases. Did this because
Push is used almost universally, not Stretch.
4.60.4.123
Fix for incorrect values for Element.ttk_style and Element.ttk_style_name. Some elements had values overwritten if a scrollbar, etc, was used
Changed a number of the ttk elements (Button for example) to use the base name as the parm to creating the custom style to achieve
a more predictable naming style (relies on the formula used in the create style function rather than ad hoc adding "custom" onto name)
"""
__version__ = version.split()[0] # For PEP 396 and PEP 345
@ -1334,8 +1338,8 @@ class Element():
self.TKText = None
self.TKEntry = None
self.TKImage = None
self.ttk_style_name = '' # set in the packer function
self.ttk_style_name = '' # The ttk style name (if this is a ttk widget)
self.ttk_style = None # The ttk Style object (if this is a ttk widget)
self._metadata = None # type: Any
self.ParentForm = None # type: Window
@ -4909,7 +4913,6 @@ class Button(Element):
self.Disabled = disabled
self.ChangeSubmits = change_submits or enable_events
self.UseTtkButtons = use_ttk_buttons
self.ttk_style_name = '' # set in the packer function
self._files_delimiter = BROWSE_FILES_DELIMITER # used by the file browse button. used when multiple files are selected by user
if use_ttk_buttons is None and running_mac():
self.UseTtkButtons = True
@ -5642,7 +5645,6 @@ class ProgressBar(Element):
self.NotRunning = True
self.Orientation = orientation if orientation else DEFAULT_METER_ORIENTATION
self.RightClickMenu = right_click_menu
self.ttk_style_name = None # set in the pack function so can use in the update
# Progress Bar colors can be a tuple (text, background) or a string with format "bar on background" - examples "red on white" or ("red", "white")
if bar_color is None:
bar_color = DEFAULT_PROGRESS_BAR_COLOR
@ -9026,7 +9028,6 @@ class Table(Element):
self.BorderWidth = border_width
self.HeaderRelief = header_relief
self.table_ttk_style_name = None # the ttk style name for the Table itself
self.ttk_style = None # the ttk style for the Table
if selected_row_colors == (None, None):
# selected_row_colors = DEFAULT_TABLE_AND_TREE_SELECTED_ROW_COLORS
selected_row_colors = theme_button_color()
@ -15237,9 +15238,10 @@ def _change_ttk_theme(style, theme_name):
# style.configure(ttkstyle, **kwargs)
# return ttkstyle
def _make_ttk_style_name(base_style, element):
def _make_ttk_style_name(base_style, element, primary_style=False):
Window._counter_for_ttk_widgets += 1
style_name = str(Window._counter_for_ttk_widgets) + '___' + str(element.Key) + base_style
if primary_style:
element.ttk_style_name = style_name
return style_name
@ -16001,8 +16003,9 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
else:
tkbutton.bind('<ButtonRelease-1>', element.ButtonReleaseCallBack)
tkbutton.bind('<ButtonPress-1>', element.ButtonPressCallBack)
style_name = _make_ttk_style_name('.custombutton.TButton', element)
style_name = _make_ttk_style_name('.TButton', element, primary_style=True)
button_style = ttk.Style()
element.ttk_style = button_style
_change_ttk_theme(button_style, toplevel_form.TtkTheme)
button_style.configure(style_name, font=font)
@ -16250,14 +16253,13 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
else:
width = max_line_len + 1
element.TKStringVar = tk.StringVar()
style_name = _make_ttk_style_name('.TCombobox', element)
style_name = _make_ttk_style_name('.TCombobox', element, primary_style=True)
combostyle = ttk.Style()
element.ttk_style = combostyle
_change_ttk_theme(combostyle, toplevel_form.TtkTheme)
# Creates a unique name for each field element(Sure there is a better way to do this)
unique_field = _make_ttk_style_name('.TCombobox.field', element)
# unique_field = _make_ttk_style_name('.TCombobox.field', element)
# Set individual widget options
@ -16300,11 +16302,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
if element.BackgroundColor not in (None, COLOR_SYSTEM_DEFAULT) and \
element.TextColor not in (None, COLOR_SYSTEM_DEFAULT):
element.Widget.tk.eval(
'[ttk::combobox::PopdownWindow {}].f.l configure -foreground {} -background {} -selectforeground {} -selectbackground {}'.format(element.Widget,
element.TextColor,
element.BackgroundColor,
element.BackgroundColor,
element.TextColor))
'[ttk::combobox::PopdownWindow {}].f.l configure -foreground {} -background {} -selectforeground {} -selectbackground {}'.format(element.Widget, element.TextColor, element.BackgroundColor, element.BackgroundColor, element.TextColor))
except Exception as e:
pass # going to let this one slide
@ -16634,7 +16632,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
base_style_name = ".Horizontal.TProgressbar"
else:
base_style_name = ".Vertical.TProgressbar"
style_name = _make_ttk_style_name(base_style_name, element)
style_name = _make_ttk_style_name(base_style_name, element, primary_style=True)
element.TKProgressBar = TKProgressBar(tk_row_frame, element.MaxValue, progress_length, progress_width,
orientation=direction, BarColor=bar_color,
border_width=element.BorderWidth, relief=element.Relief,
@ -16983,7 +16981,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
elif element_type == ELEM_TYPE_TAB_GROUP:
element = element # type: TabGroup
# custom_style = str(element.Key) + 'customtab.TNotebook'
custom_style = _make_ttk_style_name('.customtab.TNotebook', element)
custom_style = _make_ttk_style_name('.TNotebook', element, primary_style=True)
style = ttk.Style()
_change_ttk_theme(style, toplevel_form.TtkTheme)
@ -17177,7 +17175,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
treeview.tag_configure(row_def[0], background=row_def[2], foreground=row_def[1])
# ------ Do Styling of Colors -----
# style_name = str(element.Key) + 'customtable.Treeview'
style_name = _make_ttk_style_name( '.customtable.Treeview', element)
style_name = _make_ttk_style_name( '.Treeview', element, primary_style=True)
element.table_ttk_style_name = style_name
table_style = ttk.Style()
element.ttk_style = table_style
@ -17368,7 +17366,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
# ----- configure colors -----
# style_name = str(element.Key) + '.Treeview'
style_name = _make_ttk_style_name('.Treeview', element)
style_name = _make_ttk_style_name('.Treeview', element, primary_style=True)
tree_style = ttk.Style()
_change_ttk_theme(tree_style, toplevel_form.TtkTheme)
@ -17467,7 +17465,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
elif element_type == ELEM_TYPE_SEPARATOR:
element = element # type: VerticalSeparator
# style_name = str(element.Key) + "Line.TSeparator"
style_name = _make_ttk_style_name(".Line.TSeparator", element)
style_name = _make_ttk_style_name(".Line.TSeparator", element, primary_style=True)
style = ttk.Style()
_change_ttk_theme(style, toplevel_form.TtkTheme)
@ -26069,4 +26067,4 @@ if __name__ == '__main__':
exit(0)
main()
exit(0)
#5d0ef65bb69d1be31982327b209e01bde205fea10f008d977f89a43211cc1eab811681e31811d6d3ec6dda2e444a5e42b11e2db9819a1fbf4b62c4dd4fa7c4a25883c074a9aa15706c157a4c9c271df26ee0d0646d8074780541356f13486a40206ef6592026a311fc2e60fc49b87027ae05c1a0fb4b0a2c613a278adf7b1f9cb39ed33ba5954fa829098f6e1c85444a31cad45e3a6f8ea36790f367c6c3f08edec50e5bb21e152e895fa10f1349a65a6f0376964bc1f8e7ff271215a43ae35c13aabcdbb7c397d19fb0febd475a0a077ef6d5f68e0193ae8db1edec15a14f3a23bb1fad7714c9b6c39d258e9c4d6dee24f50cbf3e61b5634e4275356869f8798f64c25636ae1abbafc256254e35954ff42c7360a345f9e327d2260950c382ff0da597a4a7044319a596c9cf9bc73c9e81fb0f5ab3fe72d207ed521526bc8fb5b039c353f26edbac03d5786f57017831578dcd653fa126468d967bf4a4a145f06ec81990e36f7ae52dc8b2d111dfdfde51df480d73d557ebc6b6be2d1799fe69de1fc5f612e5b9f723845b52dc906c547a31a175bb178cba2b2554fb2173660296bd0200bd3c568f179cea38c18e6a93f96325a1b6cb810c5f0938a75c6c06bf0b1176595099c32e77f0b043dff492f69abb95f990e587576eac4dcea46005efe7333f879b86fb3abe9b8b19d373a919272c8be538403e707613b4fc27400761
#2eedb2b0b3467939c996f6c8fc62c3e1b8d533eed2a235bdde9f0e1b37035bc577f8e062f1dc279281b144ecc779951387eef766090e07e5b66f1fa77144d2a4f9ae99a7c7518f6e6485fceb909f5ca5c5f3e02fc52dbc88834392c3bc764101e3d1593400eabcecb287c6c3b23f64f2ab427b20da45af28acdf3cd35cbc055060a77cbcf439ed34261f35040f0ade1231ef7f4374df306692914b2a43796ddd367cf3faf9cc9b3833b60a2ce4bdfaac4fd1db890d04aa9e70421679ada14e7b02a76a81c9d18c44558d97c375c51476bcebf5a70765029cd2ad18e1e14eda0e29da6e4f4624c8eac559c42e1fa7ef11834efbb4cf8e5fe3540ccaf11a974c0e6299e2472198785cea07e0d665f956b1640e0b66730ed217c63d27b86708197ca4c57b29c6bdc8ec648f3d460928b451a0daf9de71c6b1164fcf9e6a3ad9e52610061800ff276328ae8125aa32e786c19ff0c806749656233764942a043e7078d8a94bee49ad9aac8001d33235106ba3441e1632bba4ffdeb13695b7687290ffcbc10109a49b85cb28d333093eacab4d95dd8322fc8e94f3fe09799715f72f3e5ac02fae3c7398ebcdff2912a6951e2665b5eaa2ebf600430fcc7eeb04f68b0b961ecf1bc15d4f0df7892429aec0595c8ce2d9f86544834e22be5611424bd81c4e310f55515e790a80f5168c448514d10a1075277689c87750baff231bf3e848