Fixed problem with making elements invisible causing the pack settings to be lost. Converted Text, Input, Multiline, StatusBar, Frame, Combo to see if this is the right approach

This commit is contained in:
PySimpleGUI 2022-04-02 08:57:32 -04:00
parent 789c6f94d7
commit e575a0b8dc
1 changed files with 108 additions and 64 deletions

View File

@ -1,6 +1,6 @@
#!/usr/bin/python3 #!/usr/bin/python3
version = __version__ = "4.57.0.22 Unreleased" version = __version__ = "4.57.0.23 Unreleased"
_change_log = """ _change_log = """
Changelog since 4.57.0 released to PyPI on 13-Feb-2022 Changelog since 4.57.0 released to PyPI on 13-Feb-2022
@ -60,6 +60,10 @@ _change_log = """
Another coupon code. Udemy makes it difficult by only giving a valid period of 5 days for some coupons Another coupon code. Udemy makes it difficult by only giving a valid period of 5 days for some coupons
4.57.0.22 4.57.0.22
Another coupon - changed base price Another coupon - changed base price
4.57.0.23
Fix for expand and other settings being lost when element is made invisible and visible again.
Not ALL elements have been converted over to handle correctly... checking in to get the ball rolling and will complete the others today
So far Text, Input, Multiline, Frame, Statusbar, Combo are done
""" """
__version__ = version.split()[0] # For PEP 396 and PEP 345 __version__ = version.split()[0] # For PEP 396 and PEP 345
@ -989,6 +993,7 @@ class Element():
self.user_bind_event = None # Used when user defines a tkinter binding using bind method - event data from tkinter self.user_bind_event = None # Used when user defines a tkinter binding using bind method - event data from tkinter
self.pad_used = (0, 0) # the amount of pad used when was inserted into the layout self.pad_used = (0, 0) # the amount of pad used when was inserted into the layout
self._popup_menu_location = (None, None) self._popup_menu_location = (None, None)
self.pack_settings = None
if not hasattr(self, 'DisabledTextColor'): if not hasattr(self, 'DisabledTextColor'):
self.DisabledTextColor = None self.DisabledTextColor = None
if not hasattr(self, 'ItemFont'): if not hasattr(self, 'ItemFont'):
@ -1685,12 +1690,25 @@ class Element():
def _pack_forget_save_settings(self, optional_widget=None):
"""
Performs a pack_forget which will make a widget invisible.
This method saves the pack settings so that they can be restored if the element is made visible again
:return:
"""
if optional_widget is not None and self.widget is None:
return
widget = optional_widget if optional_widget is not None else self.widget
self.pack_settings = widget.pack_info()
widget.pack_forget()
def _pack_restore_settings(self, optional_widget=None):
if self.pack_settings is None:
return
widget = optional_widget if optional_widget is not None else self.widget
widget.pack(**self.pack_settings)
def update(self, *args, **kwargs): def update(self, *args, **kwargs):
@ -1881,9 +1899,11 @@ class Input(Element):
if select: if select:
self.TKEntry.select_range(0, 'end') self.TKEntry.select_range(0, 'end')
if visible is False: if visible is False:
self.TKEntry.pack_forget() self._pack_forget_save_settings()
# self.TKEntry.pack_forget()
elif visible is True: elif visible is True:
self.TKEntry.pack(padx=self.pad_used[0], pady=self.pad_used[1]) self._pack_restore_settings()
# self.TKEntry.pack(padx=self.pad_used[0], pady=self.pad_used[1])
# self.TKEntry.pack(padx=self.pad_used[0], pady=self.pad_used[1], in_=self.ParentRowFrame) # self.TKEntry.pack(padx=self.pad_used[0], pady=self.pad_used[1], in_=self.ParentRowFrame)
if visible is not None: if visible is not None:
self._visible = visible self._visible = visible
@ -2093,9 +2113,11 @@ class Combo(Element):
if font is not None: if font is not None:
self.TKCombo.configure(font=font) self.TKCombo.configure(font=font)
if visible is False: if visible is False:
self.TKCombo.pack_forget() self._pack_forget_save_settings()
# self.TKCombo.pack_forget()
elif visible is True: elif visible is True:
self.TKCombo.pack(padx=self.pad_used[0], pady=self.pad_used[1]) self._pack_restore_settings()
# self.TKCombo.pack(padx=self.pad_used[0], pady=self.pad_used[1])
if visible is not None: if visible is not None:
self._visible = visible self._visible = visible
@ -3295,12 +3317,11 @@ class Multiline(Element):
if visible is False: if visible is False:
self.element_frame.pack_forget() self._pack_forget_save_settings(optional_widget=self.element_frame)
# if self.HorizontalScroll: # self.element_frame.pack_forget()
# self.hscrollbar.pack_forget()
elif visible is True: elif visible is True:
self.element_frame.pack(padx=self.pad_used[0], pady=self.pad_used[1]) self._pack_restore_settings(optional_widget=self.element_frame)
# self.hscrollbar.pack(side=tk.BOTTOM, fill='x') # self.element_frame.pack(padx=self.pad_used[0], pady=self.pad_used[1])
if self.AutoRefresh and self.ParentForm: if self.AutoRefresh and self.ParentForm:
try: # in case the window was destroyed try: # in case the window was destroyed
@ -3580,9 +3601,11 @@ class Text(Element):
if font is not None: if font is not None:
self.TKText.configure(font=font) self.TKText.configure(font=font)
if visible is False: if visible is False:
self.TKText.pack_forget() element._pack_forget_save_settings()
# self.TKText.pack_forget()
elif visible is True: elif visible is True:
self.TKText.pack(padx=self.pad_used[0], pady=self.pad_used[1]) self._pack_restore_settings()
# self.TKText.pack(padx=self.pad_used[0], pady=self.pad_used[1])
if visible is not None: if visible is not None:
self._visible = visible self._visible = visible
@ -3920,9 +3943,11 @@ class StatusBar(Element):
if font is not None: if font is not None:
self.TKText.configure(font=font) self.TKText.configure(font=font)
if visible is False: if visible is False:
self.TKText.pack_forget() self._pack_forget_save_settings()
# self.TKText.pack_forget()
elif visible is True: elif visible is True:
self.TKText.pack(padx=self.pad_used[0], pady=self.pad_used[1]) self._pack_restore_settings()
# self.TKText.pack(padx=self.pad_used[0], pady=self.pad_used[1])
if visible is not None: if visible is not None:
self._visible = visible self._visible = visible
@ -6511,9 +6536,11 @@ class Frame(Element):
return return
if visible is False: if visible is False:
self.TKFrame.pack_forget() self._pack_forget_save_settings()
# self.TKFrame.pack_forget()
elif visible is True: elif visible is True:
self.TKFrame.pack(padx=self.pad_used[0], pady=self.pad_used[1]) self._pack_restore_settings()
# self.TKFrame.pack(padx=self.pad_used[0], pady=self.pad_used[1])
if value is not None: if value is not None:
self.TKFrame.config(text=str(value)) self.TKFrame.config(text=str(value))
if visible is not None: if visible is not None:
@ -14332,12 +14359,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
# element.TKColFrame.pack(side=side, padx=elementpad[0], pady=elementpad[1], expand=True, fill='both') # element.TKColFrame.pack(side=side, padx=elementpad[0], pady=elementpad[1], expand=True, fill='both')
if element.visible is False: if element.visible is False:
element.TKColFrame.pack_forget() element._pack_forget_save_settings()
# element.TKColFrame = element.TKColFrame # element.TKColFrame.pack_forget()
# if element.BackgroundColor != COLOR_SYSTEM_DEFAULT and element.BackgroundColor is not None:
# element.TKColFrame.configure(background=element.BackgroundColor,
# highlightbackground=element.BackgroundColor,
# highlightcolor=element.BackgroundColor)
_add_right_click_menu_and_grab(element) _add_right_click_menu_and_grab(element)
# if element.Grab: # if element.Grab:
@ -14375,7 +14398,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element.PanedWindow.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.PanedWindow.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
# element.PanedWindow.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=True, fill='both') # element.PanedWindow.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=True, fill='both')
if element.visible is False: if element.visible is False:
element.PanedWindow.pack_forget() element._pack_forget_save_settings()
# element.PanedWindow.pack_forget()
# ------------------------- TEXT placement element ------------------------- # # ------------------------- TEXT placement element ------------------------- #
elif element_type == ELEM_TYPE_TEXT: elif element_type == ELEM_TYPE_TEXT:
# auto_size_text = element.AutoSizeText # auto_size_text = element.AutoSizeText
@ -14425,7 +14449,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
tktext_label.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) tktext_label.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
tktext_label.pack_forget() element._pack_forget_save_settings()
# tktext_label.pack_forget()
element.TKText = tktext_label element.TKText = tktext_label
if element.ClickSubmits: if element.ClickSubmits:
tktext_label.bind('<Button-1>', element._TextClickedHandler) tktext_label.bind('<Button-1>', element._TextClickedHandler)
@ -14462,13 +14487,12 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
bd = element.BorderWidth bd = element.BorderWidth
tkbutton = element.Widget = tk.Button(tk_row_frame, text=btext, width=width, height=height, justify=tk.CENTER, bd=bd, font=font)
try: 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.config( command=element.ButtonCallBack)
command=element.ButtonCallBack, justify=tk.CENTER, bd=bd, font=font)
else: else:
tkbutton = element.Widget = tk.Button(tk_row_frame, text=btext, width=width, height=height,
justify=tk.CENTER, bd=bd, font=font)
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:
@ -14536,7 +14560,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
tkbutton.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) tkbutton.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
tkbutton.pack_forget() element._pack_forget_save_settings()
# tkbutton.pack_forget()
if element.BindReturnKey: if element.BindReturnKey:
element.TKButton.bind('<Return>', element._ReturnKeyHandler) element.TKButton.bind('<Return>', element._ReturnKeyHandler)
if element.Focus is True or (toplevel_form.UseDefaultFocus and not toplevel_form.FocusSet): if element.Focus is True or (toplevel_form.UseDefaultFocus and not toplevel_form.FocusSet):
@ -14596,10 +14621,10 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
else: else:
bc = DEFAULT_BUTTON_COLOR bc = DEFAULT_BUTTON_COLOR
bd = element.BorderWidth bd = element.BorderWidth
if btype != BUTTON_TYPE_REALTIME:
tkbutton = element.Widget = ttk.Button(tk_row_frame, text=btext, width=width, command=element.ButtonCallBack)
else:
tkbutton = element.Widget = ttk.Button(tk_row_frame, text=btext, width=width) tkbutton = element.Widget = ttk.Button(tk_row_frame, text=btext, width=width)
if btype != BUTTON_TYPE_REALTIME:
tkbutton.config(command=element.ButtonCallBack)
else:
tkbutton.bind('<ButtonRelease-1>', element.ButtonReleaseCallBack) tkbutton.bind('<ButtonRelease-1>', element.ButtonReleaseCallBack)
tkbutton.bind('<ButtonPress-1>', element.ButtonPressCallBack) tkbutton.bind('<ButtonPress-1>', element.ButtonPressCallBack)
# Window._counter_for_ttk_widgets += 1 # Window._counter_for_ttk_widgets += 1
@ -14672,7 +14697,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
tkbutton.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) tkbutton.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
tkbutton.pack_forget() element._pack_forget_save_settings()
# tkbutton.pack_forget()
if element.BindReturnKey: if element.BindReturnKey:
element.TKButton.bind('<Return>', element._ReturnKeyHandler) element.TKButton.bind('<Return>', element._ReturnKeyHandler)
if element.Focus is True or (toplevel_form.UseDefaultFocus and not toplevel_form.FocusSet): if element.Focus is True or (toplevel_form.UseDefaultFocus and not toplevel_form.FocusSet):
@ -14769,7 +14795,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
tkbutton.configure(menu=top_menu) tkbutton.configure(menu=top_menu)
element.TKMenu = top_menu element.TKMenu = top_menu
if element.visible is False: if element.visible is False:
tkbutton.pack_forget() element._pack_forget_save_settings()
# tkbutton.pack_forget()
if element.Disabled == True: if element.Disabled == True:
element.TKButton['state'] = 'disabled' element.TKButton['state'] = 'disabled'
if element.Tooltip is not None: if element.Tooltip is not None:
@ -14811,7 +14838,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKEntry.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKEntry.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKEntry.pack_forget() element._pack_forget_save_settings()
# element.TKEntry.pack_forget()
if element.Focus is True or (toplevel_form.UseDefaultFocus and not toplevel_form.FocusSet): if element.Focus is True or (toplevel_form.UseDefaultFocus and not toplevel_form.FocusSet):
toplevel_form.FocusSet = True toplevel_form.FocusSet = True
element.TKEntry.focus_set() element.TKEntry.focus_set()
@ -14889,7 +14917,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKCombo.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKCombo.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKCombo.pack_forget() element._pack_forget_save_settings()
# element.TKCombo.pack_forget()
if element.DefaultValue is not None: if element.DefaultValue is not None:
element.TKCombo.set(element.DefaultValue) element.TKCombo.set(element.DefaultValue)
# for i, v in enumerate(element.Values): # for i, v in enumerate(element.Values):
@ -14933,7 +14962,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKOptionMenu.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKOptionMenu.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKOptionMenu.pack_forget() element._pack_forget_save_settings()
# element.TKOptionMenu.pack_forget()
if element.Disabled == True: if element.Disabled == True:
element.TKOptionMenu['state'] = 'disabled' element.TKOptionMenu['state'] = 'disabled'
if element.Tooltip is not None: if element.Tooltip is not None:
@ -14992,7 +15022,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element_frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], fill=fill, expand=expand) element_frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], fill=fill, expand=expand)
element.TKListbox.pack(side=tk.LEFT, fill=fill, expand=expand) element.TKListbox.pack(side=tk.LEFT, fill=fill, expand=expand)
if element.visible is False: if element.visible is False:
element_frame.pack_forget() element._pack_forget_save_settings(optional_widget=element_frame)
# element_frame.pack_forget()
if element.BindReturnKey: if element.BindReturnKey:
element.TKListbox.bind('<Return>', element._ListboxSelectHandler) element.TKListbox.bind('<Return>', element._ListboxSelectHandler)
element.TKListbox.bind('<Double-Button-1>', element._ListboxSelectHandler) element.TKListbox.bind('<Double-Button-1>', element._ListboxSelectHandler)
@ -15055,9 +15086,9 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element.element_frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], fill=fill, expand=expand) element.element_frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], fill=fill, expand=expand)
element.Widget.pack(side=tk.LEFT, fill=fill, expand=expand) element.Widget.pack(side=tk.LEFT, fill=fill, expand=expand)
if element.visible is False: if element.visible is False:
element.element_frame.pack_forget() element._pack_forget_save_settings(optional_widget=element_frame)
# element.element_frame.pack_forget()
else: else:
# Chr0nic # Chr0nic
element.TKText.bind("<Enter>", lambda event, em=element: testMouseHook(em)) element.TKText.bind("<Enter>", lambda event, em=element: testMouseHook(em))
@ -15115,7 +15146,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKCheckbutton.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKCheckbutton.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKCheckbutton.pack_forget() element._pack_forget_save_settings()
# element.TKCheckbutton.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element.TKCheckbutton, text=element.Tooltip, element.TooltipObject = ToolTip(element.TKCheckbutton, text=element.Tooltip,
timeout=DEFAULT_TOOLTIP_TIME) timeout=DEFAULT_TOOLTIP_TIME)
@ -15146,11 +15178,12 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
orientation=direction, BarColor=bar_color, orientation=direction, BarColor=bar_color,
border_width=element.BorderWidth, relief=element.Relief, border_width=element.BorderWidth, relief=element.Relief,
ttk_theme=toplevel_form.TtkTheme, key=element.Key, style_name=style_name) ttk_theme=toplevel_form.TtkTheme, key=element.Key, style_name=style_name)
element.Widget = element.TKProgressBar.TKProgressBarForReal
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKProgressBar.TKProgressBarForReal.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKProgressBar.TKProgressBarForReal.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKProgressBar.TKProgressBarForReal.pack_forget() element._pack_forget_save_settings(optional_widget=element.TKProgressBar.TKProgressBarForReal)
element.Widget = element.TKProgressBar.TKProgressBarForReal # element.TKProgressBar.TKProgressBarForReal.pack_forget()
_add_right_click_menu_and_grab(element) _add_right_click_menu_and_grab(element)
# ------------------------- RADIO placement element ------------------------- # # ------------------------- RADIO placement element ------------------------- #
@ -15194,7 +15227,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKRadio.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKRadio.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKRadio.pack_forget() element._pack_forget_save_settings()
# element.TKRadio.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element.TKRadio, text=element.Tooltip, timeout=DEFAULT_TOOLTIP_TIME) element.TooltipObject = ToolTip(element.TKRadio, text=element.Tooltip, timeout=DEFAULT_TOOLTIP_TIME)
_add_right_click_menu_and_grab(element) _add_right_click_menu_and_grab(element)
@ -15218,7 +15252,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKSpinBox.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.TKSpinBox.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.TKSpinBox.pack_forget() element._pack_forget_save_settings()
# element.TKSpinBox.pack_forget()
if text_color is not None and text_color != COLOR_SYSTEM_DEFAULT: if text_color is not None and text_color != COLOR_SYSTEM_DEFAULT:
element.TKSpinBox.configure(fg=text_color) element.TKSpinBox.configure(fg=text_color)
if element.ChangeSubmits: if element.ChangeSubmits:
@ -15250,7 +15285,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element._TKOut.pack(side=tk.LEFT, expand=expand, fill=fill) element._TKOut.pack(side=tk.LEFT, expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element._TKOut.frame.pack_forget() element._pack_forget_save_settings(optional_widget=element._TKOut.frame)
# element._TKOut.frame.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element._TKOut, text=element.Tooltip, timeout=DEFAULT_TOOLTIP_TIME) element.TooltipObject = ToolTip(element._TKOut, text=element.Tooltip, timeout=DEFAULT_TOOLTIP_TIME)
_add_right_click_menu_and_grab(element) _add_right_click_menu_and_grab(element)
@ -15276,14 +15312,15 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
'Look in this Window\'s layout for an Image element that has a key of {}'.format(element.Key), 'Look in this Window\'s layout for an Image element that has a key of {}'.format(element.Key),
'The error occuring is:', e) 'The error occuring is:', e)
element.tktext_label = element.Widget = tk.Label(tk_row_frame, bd=0)
if photo is not None: if photo is not None:
if element_size == (None, None) or element_size is None or element_size == toplevel_form.DefaultElementSize: if element_size == (None, None) or element_size is None or element_size == toplevel_form.DefaultElementSize:
width, height = photo.width(), photo.height() width, height = photo.width(), photo.height()
else: else:
width, height = element_size width, height = element_size
element.tktext_label = tk.Label(tk_row_frame, image=photo, width=width, height=height, bd=0) element.tktext_label.config(image=photo, width=width, height=height)
else:
element.tktext_label = tk.Label(tk_row_frame, bd=0)
if not element.BackgroundColor in (None, COLOR_SYSTEM_DEFAULT): if not element.BackgroundColor in (None, COLOR_SYSTEM_DEFAULT):
element.tktext_label.config(background=element.BackgroundColor) element.tktext_label.config(background=element.BackgroundColor)
@ -15294,13 +15331,13 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element.tktext_label.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element.tktext_label.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element.tktext_label.pack_forget() element._pack_forget_save_settings()
# element.tktext_label.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element.tktext_label, text=element.Tooltip, element.TooltipObject = ToolTip(element.tktext_label, text=element.Tooltip,
timeout=DEFAULT_TOOLTIP_TIME) timeout=DEFAULT_TOOLTIP_TIME)
if element.EnableEvents and element.tktext_label is not None: if element.EnableEvents and element.tktext_label is not None:
element.tktext_label.bind('<ButtonPress-1>', element._ClickHandler) element.tktext_label.bind('<ButtonPress-1>', element._ClickHandler)
element.Widget = element.tktext_label
_add_right_click_menu_and_grab(element) _add_right_click_menu_and_grab(element)
@ -15312,16 +15349,18 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element._TKCanvas = tk.Canvas(tk_row_frame, width=width, height=height, bd=border_depth) element._TKCanvas = tk.Canvas(tk_row_frame, width=width, height=height, bd=border_depth)
else: else:
element._TKCanvas.master = tk_row_frame element._TKCanvas.master = tk_row_frame
element.Widget = element._TKCanvas
if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT: if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT:
element._TKCanvas.configure(background=element.BackgroundColor, highlightthickness=0) element._TKCanvas.configure(background=element.BackgroundColor, highlightthickness=0)
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element._TKCanvas.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element._TKCanvas.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
element._TKCanvas.pack_forget() element._pack_forget_save_settings()
# element._TKCanvas.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element._TKCanvas, text=element.Tooltip, element.TooltipObject = ToolTip(element._TKCanvas, text=element.Tooltip,
timeout=DEFAULT_TOOLTIP_TIME) timeout=DEFAULT_TOOLTIP_TIME)
element.Widget = element._TKCanvas
_add_right_click_menu_and_grab(element) _add_right_click_menu_and_grab(element)
# ------------------------- Graph placement element ------------------------- # # ------------------------- Graph placement element ------------------------- #
@ -15343,8 +15382,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
# element._TKCanvas.configure(background=element.BackgroundColor, highlightthickness=0) # element._TKCanvas.configure(background=element.BackgroundColor, highlightthickness=0)
element._TKCanvas2.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element._TKCanvas2.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
# element._TKCanvas.pack_forget() element._pack_forget_save_settings()
element._TKCanvas2.pack_forget() # element._TKCanvas2.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element._TKCanvas2, text=element.Tooltip, element.TooltipObject = ToolTip(element._TKCanvas2, text=element.Tooltip,
timeout=DEFAULT_TOOLTIP_TIME) timeout=DEFAULT_TOOLTIP_TIME)
@ -15411,7 +15450,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
labeled_frame.config(width=element.Size[0], height=element.Size[1]) labeled_frame.config(width=element.Size[0], height=element.Size[1])
labeled_frame.pack_propagate(0) labeled_frame.pack_propagate(0)
if not element.visible: if not element.visible:
labeled_frame.pack_forget() element._pack_forget_save_settings()
# labeled_frame.pack_forget()
if element.BackgroundColor != COLOR_SYSTEM_DEFAULT and element.BackgroundColor is not None: if element.BackgroundColor != COLOR_SYSTEM_DEFAULT and element.BackgroundColor is not None:
labeled_frame.configure(background=element.BackgroundColor, labeled_frame.configure(background=element.BackgroundColor,
highlightbackground=element.BackgroundColor, highlightbackground=element.BackgroundColor,
@ -15579,7 +15619,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
tkscale.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) tkscale.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False: if element.visible is False:
tkscale.pack_forget() element._pack_forget_save_settings()
# tkscale.pack_forget()
element.TKScale = tkscale element.TKScale = tkscale
if element.Disabled == True: if element.Disabled == True:
element.TKScale['state'] = 'disabled' element.TKScale['state'] = 'disabled'
@ -15724,9 +15765,10 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKTreeview.pack(side=tk.LEFT, padx=0, pady=0, expand=expand, fill=fill) element.TKTreeview.pack(side=tk.LEFT, padx=0, pady=0, expand=expand, fill=fill)
if element.visible is False:
element.TKTreeview.pack_forget()
frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False:
element._pack_forget_save_settings(optional_widget=element_frame) # seems like it should be the frame if following other elements conventions
# element.TKTreeview.pack_forget()
if element.Tooltip is not None: if element.Tooltip is not None:
element.TooltipObject = ToolTip(element.TKTreeview, text=element.Tooltip, element.TooltipObject = ToolTip(element.TKTreeview, text=element.Tooltip,
timeout=DEFAULT_TOOLTIP_TIME) timeout=DEFAULT_TOOLTIP_TIME)
@ -15855,9 +15897,10 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
treeview.configure(yscrollcommand=scrollbar.set) treeview.configure(yscrollcommand=scrollbar.set)
expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction) expand, fill, row_should_expand, row_fill_direction = _add_expansion(element, row_should_expand, row_fill_direction)
element.TKTreeview.pack(side=tk.LEFT, padx=0, pady=0, expand=expand, fill=fill) element.TKTreeview.pack(side=tk.LEFT, padx=0, pady=0, expand=expand, fill=fill)
if element.visible is False:
element.TKTreeview.pack_forget()
element_frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill) element_frame.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], expand=expand, fill=fill)
if element.visible is False:
element._pack_forget_save_settings(optional_widget=element_frame) # seems like it should be the frame if following other elements conventions
# element.TKTreeview.pack_forget()
treeview.bind("<<TreeviewSelect>>", element._treeview_selected) treeview.bind("<<TreeviewSelect>>", element._treeview_selected)
if element.Tooltip is not None: # tooltip if element.Tooltip is not None: # tooltip
element.TooltipObject = ToolTip(element.TKTreeview, text=element.Tooltip, element.TooltipObject = ToolTip(element.TKTreeview, text=element.Tooltip,
@ -15957,7 +16000,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
tktext_label.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], fill=tk.X, expand=True) tktext_label.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1], fill=tk.X, expand=True)
row_fill_direction = tk.X row_fill_direction = tk.X
if element.visible is False: if element.visible is False:
tktext_label.pack_forget() element._pack_forget_save_settings()
# tktext_label.pack_forget()
element.TKText = tktext_label element.TKText = tktext_label
if element.ClickSubmits: if element.ClickSubmits:
tktext_label.bind('<Button-1>', element._TextClickedHandler) tktext_label.bind('<Button-1>', element._TextClickedHandler)