From 7bbf799870956728c27c57bf539fe78e9a1125c7 Mon Sep 17 00:00:00 2001 From: gnikit Date: Tue, 30 Jan 2024 22:09:26 +0000 Subject: [PATCH 1/3] refactor: store tkkMessage object in Tooltip class --- tktooltip/tooltip.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/tktooltip/tooltip.py b/tktooltip/tooltip.py index 1bcf3f0..2467d47 100644 --- a/tktooltip/tooltip.py +++ b/tktooltip/tooltip.py @@ -86,7 +86,12 @@ def __init__( self.status = "outside" self.last_moved = 0 # use Message widget to host ToolTip - tk.Message(self, textvariable=self.msgVar, aspect=1000, **message_kwargs).grid() + self.message_widget = tk.Message( + self, + textvariable=self.msgVar, + **message_kwargs, + ) + self.message_widget.grid() # Add bindings to the widget without overriding the existing ones self.widget.bind("", self.on_enter, add="+") self.widget.bind("", self.on_leave, add="+") From ba633111090f02008f39db3fc5acedfa01ce5901 Mon Sep 17 00:00:00 2001 From: gnikit Date: Tue, 30 Jan 2024 22:14:55 +0000 Subject: [PATCH 2/3] refactor: change how default args are defined --- tktooltip/tooltip.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/tktooltip/tooltip.py b/tktooltip/tooltip.py index 2467d47..43c1f9a 100644 --- a/tktooltip/tooltip.py +++ b/tktooltip/tooltip.py @@ -17,6 +17,9 @@ class ToolTip(tk.Toplevel): Creates a ToolTip (pop-up) widget for tkinter """ + DEFAULT_PARENT_KWARGS = {"bg": "black", "padx": 1, "pady": 1} + DEFAULT_MESSAGE_KWARGS = {"aspect": 1000} + def __init__( self, widget: tk.Widget, @@ -26,7 +29,7 @@ def __init__( refresh: float = 1.0, x_offset: int = +10, y_offset: int = +10, - parent_kwargs: dict[Any, Any] = {"bg": "black", "padx": 1, "pady": 1}, + parent_kwargs: dict | None = None, **message_kwargs: Any, ): """Create a ToolTip. Allows for `**kwargs` to be passed on both @@ -59,7 +62,7 @@ def __init__( self.widget = widget # ToolTip should have the same parent as the widget unless stated # otherwise in the `parent_kwargs` - tk.Toplevel.__init__(self, **parent_kwargs) + tk.Toplevel.__init__(self, **(parent_kwargs or self.DEFAULT_PARENT_KWARGS)) self.withdraw() # Hide initially in case there is a delay # Disable ToolTip's title bar self.overrideredirect(True) @@ -86,10 +89,11 @@ def __init__( self.status = "outside" self.last_moved = 0 # use Message widget to host ToolTip + self.message_kwargs: dict = message_kwargs or self.DEFAULT_MESSAGE_KWARGS self.message_widget = tk.Message( self, textvariable=self.msgVar, - **message_kwargs, + **self.message_kwargs, ) self.message_widget.grid() # Add bindings to the widget without overriding the existing ones From 96ca9bf7846b643739578f3fa3ce8228576b699c Mon Sep 17 00:00:00 2001 From: gnikit Date: Wed, 31 Jan 2024 11:50:27 +0000 Subject: [PATCH 3/3] fix(examples): add absolute path to example --- examples/color_changer.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/examples/color_changer.py b/examples/color_changer.py index 09fca3f..97d9aa4 100644 --- a/examples/color_changer.py +++ b/examples/color_changer.py @@ -1,5 +1,6 @@ import re import tkinter as tk +from pathlib import Path from tkinter import ttk import sv_ttk @@ -20,7 +21,7 @@ def __init__(self, parent): def setup_widgets(self): self.color = "0,0,0" # Default color to replace (it's black) - img = "tooltip_logo.png" # image name to loads + img = Path(__file__).parent / "tooltip_logo.png" # image name to loads self.img = Image.open(img).resize((100, 100)) # Load and scale image self.img_tk = ImageTk.PhotoImage(self.img) # Store to stop garbage collection self.img_label = ttk.Label(self, image=self.img_tk) # Create label with image