Merge pull request #5002 from PySimpleGUI/Dev-latest

Addition of col0 heading for Tree element.  Fix for Tables that have …
This commit is contained in:
PySimpleGUI 2021-12-03 14:22:14 -05:00 committed by GitHub
commit e429b3d7e8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 17 additions and 9 deletions

View File

@ -1,5 +1,5 @@
#!/usr/bin/python3 #!/usr/bin/python3
version = __version__ = "4.55.1.11 Unreleased" version = __version__ = "4.55.1.12 Unreleased"
_change_log = """ _change_log = """
Changelog since 4.55.1 released to PyPI on 7-Nov-2021 Changelog since 4.55.1 released to PyPI on 7-Nov-2021
@ -39,7 +39,9 @@ _change_log = """
Tree Element Tree Element
* Always left justify the first column. This is how it's always worked. tkinter 8.6.12 changed the behavior of the first col. This changes it back * Always left justify the first column. This is how it's always worked. tkinter 8.6.12 changed the behavior of the first col. This changes it back
* Better auto-size column. Uses the data as well as the Column header to determine size of column * Better auto-size column. Uses the data as well as the Column header to determine size of column
4.55.1.12
Table Element - fix case when tables have too many headers, thus not matching the data columns
Tree element - addition of a heading for the Column 0 (the main column shown in the Tree). Default is '' which is what's shown today.
""" """
__version__ = version.split()[0] # For PEP 396 and PEP 345 __version__ = version.split()[0] # For PEP 396 and PEP 345
@ -8151,7 +8153,7 @@ class Tree(Element):
to hold the user's data and pass to the element for display. to hold the user's data and pass to the element for display.
""" """
def __init__(self, data=None, headings=None, visible_column_map=None, col_widths=None, col0_width=10, def __init__(self, data=None, headings=None, visible_column_map=None, col_widths=None, col0_width=10, col0_heading='',
def_col_width=10, auto_size_columns=True, max_col_width=20, select_mode=None, show_expanded=False, def_col_width=10, auto_size_columns=True, max_col_width=20, select_mode=None, show_expanded=False,
change_submits=False, enable_events=False, font=None, justification='right', text_color=None, change_submits=False, enable_events=False, font=None, justification='right', text_color=None,
background_color=None, selected_row_colors=(None, None), header_text_color=None, header_background_color=None, header_font=None, num_rows=None, background_color=None, selected_row_colors=(None, None), header_text_color=None, header_background_color=None, header_font=None, num_rows=None,
@ -8168,6 +8170,8 @@ class Tree(Element):
:type col_widths: List[int] :type col_widths: List[int]
:param col0_width: Size of Column 0 which is where the row numbers will be optionally shown :param col0_width: Size of Column 0 which is where the row numbers will be optionally shown
:type col0_width: (int) :type col0_width: (int)
:param col0_heading: Text to be shown in the header for the left-most column
:type col0_heading: (str)
:param def_col_width: default column width :param def_col_width: default column width
:type def_col_width: (int) :type def_col_width: (int)
:param auto_size_columns: if True, the size of a column is determined using the contents of the column :param auto_size_columns: if True, the size of a column is determined using the contents of the column
@ -8256,6 +8260,7 @@ class Tree(Element):
self.ShowExpanded = show_expanded self.ShowExpanded = show_expanded
self.NumRows = num_rows self.NumRows = num_rows
self.Col0Width = col0_width self.Col0Width = col0_width
self.col0_heading = col0_heading
self.TKTreeview = None # type: ttk.Treeview self.TKTreeview = None # type: ttk.Treeview
self.element_frame = None # type: tk.Frame self.element_frame = None # type: tk.Frame
self.SelectedRows = [] self.SelectedRows = []
@ -8499,7 +8504,7 @@ class TreeData(object):
:type level: (int) :type level: (int)
""" """
return '\n'.join( return '\n'.join(
[str(node.key) + ' : ' + str(node.text)] + [str(node.key) + ' : ' + str(node.text) + ' [ ' + ', '.join([str(v) for v in node.values]) +' ]'] +
[' ' * 4 * level + self._NodeStr(child, level + 1) for child in node.children]) [' ' * 4 * level + self._NodeStr(child, level + 1) for child in node.children])
Insert = insert Insert = insert
@ -15190,7 +15195,9 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
for i, heading in enumerate(headings): for i, heading in enumerate(headings):
treeview.heading(heading, text=heading) treeview.heading(heading, text=heading)
if element.AutoSizeColumns: if element.AutoSizeColumns:
width = max(column_widths[i] * _char_width_in_pixels(font), len(heading)*_char_width_in_pixels(element.HeaderFont)) col_width = column_widths.get(i, len(heading)) # in case more headings than there are columns of data
width = max(col_width * _char_width_in_pixels(font), len(heading)*_char_width_in_pixels(element.HeaderFont))
# width = max(column_widths[i] * _char_width_in_pixels(font), len(heading)*_char_width_in_pixels(element.HeaderFont))
else: else:
try: try:
width = element.ColumnWidths[i] * _char_width_in_pixels(font) width = element.ColumnWidths[i] * _char_width_in_pixels(font)
@ -15316,6 +15323,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
if len(str(value)) > max_width: if len(str(value)) > max_width:
max_widths[i] = len(str(value)) max_widths[i] = len(str(value))
for i, heading in enumerate(element.ColumnHeadings): # Configure cols + headings for i, heading in enumerate(element.ColumnHeadings): # Configure cols + headings
treeview.heading(heading, text=heading) treeview.heading(heading, text=heading)
if element.AutoSizeColumns: if element.AutoSizeColumns:
@ -15349,15 +15357,13 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
node.photo = photo node.photo = photo
try: try:
id = treeview.insert(element.KeyToID[node.parent], 'end', iid=None, text=node.text, values=node.values, id = treeview.insert(element.KeyToID[node.parent], 'end', iid=None, text=node.text, values=node.values, open=element.ShowExpanded, image=node.photo)
open=element.ShowExpanded, image=node.photo)
element.IdToKey[id] = node.key element.IdToKey[id] = node.key
element.KeyToID[node.key] = id element.KeyToID[node.key] = id
except Exception as e: except Exception as e:
print('Error inserting image into tree', e) print('Error inserting image into tree', e)
else: else:
id = treeview.insert(element.KeyToID[node.parent], 'end', iid=None, text=node.text, values=node.values, id = treeview.insert(element.KeyToID[node.parent], 'end', iid=None, text=node.text, values=node.values, open=element.ShowExpanded)
open=element.ShowExpanded)
element.IdToKey[id] = node.key element.IdToKey[id] = node.key
element.KeyToID[node.key] = id element.KeyToID[node.key] = id
@ -15366,6 +15372,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
add_treeview_data(element.TreeData.root_node) add_treeview_data(element.TreeData.root_node)
treeview.column('#0', width=element.Col0Width * _char_width_in_pixels(font), anchor=tk.W) treeview.column('#0', width=element.Col0Width * _char_width_in_pixels(font), anchor=tk.W)
treeview.heading('#0', text=element.col0_heading)
# ----- configure colors ----- # ----- configure colors -----
# style_name = str(element.Key) + '.Treeview' # style_name = str(element.Key) + '.Treeview'
style_name = _make_ttk_style_name('.Treeview', element) style_name = _make_ttk_style_name('.Treeview', element)