def __init__(self): style = ttk.Style("cosmo") self._root = style.master self._root.title("FBSerial") self._root.resizable(False, False) # self._root.attributes("-topmost", True) self._root.protocol("WM_DELETE_WINDOW", self.shutdown) frame = ttk.LabelFrame(self._root, text="串口选择") frame.pack(padx=5, pady=5) self._portsCombo = ttk.Combobox(frame, state="readonly", width=23) self._portsCombo.pack(side="left", padx=5, pady=5) self._conButton = ttk.Button(frame, text="连接", command=self._connect) self._refreshButton = ttk.Button(frame, text="刷新", command=self._getPorts) self._conButton.pack(side="left", padx=5, pady=5) self._refreshButton.pack(side="left", padx=5, pady=5) self._prePort = None self._connected = False self._ser = FBSerial() self._ser.registerConnectCallback(self._conCB) self._ser.registerDisconnectCallback(self._disconCB)
def create_stopwatch_controls(self): """Create the control frame with buttons""" container = ttk.Frame(self, padding=10) container.pack(fill=X) self.buttons = [] self.buttons.append( ttk.Button( master=container, text="Start", width=10, bootstyle=INFO, command=self.on_toggle, )) self.buttons.append( ttk.Button( master=container, text="Reset", width=10, bootstyle=SUCCESS, command=self.on_reset, )) self.buttons.append( ttk.Button( master=container, text="Quit", width=10, bootstyle=DANGER, command=self.on_quit, )) for button in self.buttons: button.pack(side=LEFT, fill=X, expand=YES, pady=10, padx=5)
def create_buttonbox(self, master): frame = ttk.Frame(master, padding=(5, 5)) # OK button ok = ttk.Button(frame, bootstyle=PRIMARY, width=6, text=MessageCatalog.translate('OK')) ok.bind("<Return>", lambda _: ok.invoke()) ok.configure(command=lambda b=ok: self.on_button_press(b)) ok.pack(padx=2, side=RIGHT) # Cancel button cancel = ttk.Button(frame, bootstyle=SECONDARY, width=6, text=MessageCatalog.translate('Cancel')) cancel.bind("<Return>", lambda _: cancel.invoke()) cancel.configure(command=lambda b=cancel: self.on_button_press(b)) cancel.pack(padx=2, side=RIGHT) # color dropper (not supported on Mac OS) if self._toplevel.winsys != 'aqua': dropper = ttk.Label(frame, text=PEN, font=('-size 16')) ToolTip(dropper, MessageCatalog.translate('color dropper')) # add tooltip dropper.pack(side=RIGHT, padx=2) dropper.bind("<Button-1>", self.on_show_colordropper) frame.pack(side=BOTTOM, fill=X, anchor=S)
def button_style_frame(bootstyle, style, widget_name): frame = ttk.Frame(root, padding=5) title = ttk.Label( master=frame, text=widget_name, anchor=tk.CENTER ) title.pack(padx=5, pady=2, fill=tk.BOTH) ttk.Separator(frame).pack(padx=5, pady=5, fill=tk.X) ttk.Button( master=frame, text='default', bootstyle=bootstyle ).pack(padx=5, pady=5) for color in style.colors: ttk.Button( master=frame, text=color, bootstyle=f'{color}-{bootstyle}' ).pack(padx=5, pady=5) ttk.Button( master=frame, text='disabled', state=tk.DISABLED, bootstyle=bootstyle ).pack(padx=5, pady=5) return frame
def load_sidebar(): folders = [ 'Desktop', 'Documents', 'Music', 'Pictures', 'Videos', 'Downloads' ] if app.winsys == 'x11': sidebar: ttk.Frame = app.nametowidget('sidebar') home = pathlib.Path.home() b_ = ttk.Button( master=sidebar, text=home.parent.name, image=images['Home'], compound=LEFT, bootstyle=LINK, command=lambda x=home: load_treeview_items(x) ) b_.pack(anchor=W) sidebar: ttk.Frame = app.nametowidget('sidebar') home = pathlib.Path.home() b_ = ttk.Button( master=sidebar, text=home.parent.name, image=images['User'], compound=LEFT, bootstyle=LINK, command=lambda x=home: load_treeview_items(x) ) b_.pack(anchor=W) else: sidebar: ttk.Frame = app.nametowidget('sidebar') home = pathlib.Path.home() b_ = ttk.Button( master=sidebar, text=home.name, image=images['Home'], compound=LEFT, bootstyle=LINK, command=lambda x=home: load_treeview_items(x) ) b_.pack(anchor=W) for folder in folders: p = Path(home / folder) if p.exists(): b_ = ttk.Button( master=sidebar, text=p.name, image=images[p.name], compound=LEFT, bootstyle=LINK, command=lambda x=p: load_treeview_items(x) ) b_.pack(anchor=W)
def __init__(self, master, color, style): super().__init__(master, padding=(5, 2)) self.colorname = color self.style = style self.label = ttk.Label(self, text=color, width=12) self.label.pack(side=LEFT) self.patch = Frame(master=self, background=self.style.colors.get(color), width=15) self.patch.pack(side=LEFT, fill=BOTH, padx=2) self.entry = ttk.Entry(self, width=12) self.entry.pack(side=LEFT, fill=X, expand=YES) self.entry.bind("<FocusOut>", self.enter_color) self.color_picker = ttk.Button( master=self, text="...", bootstyle=SECONDARY, command=self.pick_color, ) self.color_picker.pack(side=LEFT, padx=2) # set initial color value and patch color self.color_value = self.style.colors.get(color) self.update_patch_color()
def __init__(self) -> None: style = ttk.Style("cosmo") self._root = style.master self._root.title("FBMapDraw - 左键删除 右键添加") self._root.rowconfigure(0, weight=1) self._root.columnconfigure(0, weight=1) self._plotFrame = ttk.Frame(self._root) self._plotFrame.grid(row=0, column=0, sticky="wesn") self._plotFrame.rowconfigure(0, weight=1) self._plotFrame.columnconfigure(0, weight=1) self._fig = plt.Figure() self._setA4Size() self._canvas = FigureCanvasTkAgg(self._fig, master=self._plotFrame) self._canvas.get_tk_widget().grid(row=0, column=0, sticky="wesn") self._ax = self._fig.add_subplot(1, 1, 1) self._ax.set_picker(True) self._ax.set_aspect("equal") self._canvas.mpl_connect("pick_event", self._onPick) self._opFrame = ttk.Frame(self._root) self._opFrame.grid(row=1, column=0, sticky="we") self._clearButton = ttk.Button(self._opFrame, text="清空", command=self.clear) self._saveButton = ttk.Button(self._opFrame, text="保存", command=self.save) self._loadButton = ttk.Button(self._opFrame, text="读取", command=self.load) self._clearButton.pack(side="left", padx=5, pady=5) self._saveButton.pack(side="left", padx=5, pady=5) self._loadButton.pack(side="left", padx=5, pady=5) ttk.Label( self._opFrame, text=f"保存路径: {os.path.join(SAVE_DIR, SAVE_NAME_TXT)}\t点数: ").pack( side="left", pady=5) self.pointCnt = tk.IntVar(self._root, value=0) ttk.Label(self._opFrame, textvariable=self.pointCnt).pack(side="left", pady=5) self.circles = {}
def create_path_row(self): """Add path row to labelframe""" path_row = ttk.Frame(self.option_lf) path_row.pack(fill=X, expand=YES) path_lbl = ttk.Label(path_row, text="Path", width=8) path_lbl.pack(side=LEFT, padx=(15, 0)) path_ent = ttk.Entry(path_row, textvariable=self.path_var) path_ent.pack(side=LEFT, fill=X, expand=YES, padx=5) browse_btn = ttk.Button(master=path_row, text="Browse", command=self.on_browse, width=8) browse_btn.pack(side=LEFT, padx=5)
def add(self, child, title="", bootstyle=PRIMARY, **kwargs): """Add a child to the collapsible frame Parameters: child (Frame): The child frame to add to the widget. title (str): The title appearing on the collapsible section header. bootstyle (str): The style to apply to the collapsible section header. **kwargs (Dict): Other optional keyword arguments. """ if child.winfo_class() != 'TFrame': return style_color = Bootstyle.ttkstyle_widget_color(bootstyle) frm = ttk.Frame(self, bootstyle=style_color) frm.grid(row=self.cumulative_rows, column=0, sticky=EW) # header title header = ttk.Label( master=frm, text=title, bootstyle=(style_color, INVERSE) ) if kwargs.get('textvariable'): header.configure(textvariable=kwargs.get('textvariable')) header.pack(side=LEFT, fill=BOTH, padx=10) # header toggle button def _func(c=child): return self._toggle_open_close(c) btn = ttk.Button( master=frm, image=self.images[0], bootstyle=style_color, command=_func ) btn.pack(side=RIGHT) # assign toggle button to child so that it can be toggled child.btn = btn child.grid(row=self.cumulative_rows + 1, column=0, sticky=NSEW) # increment the row assignment self.cumulative_rows += 2
def create_buttonbox(self): """Create the application buttonbox""" container = ttk.Frame(self) container.pack(fill=X, expand=YES, pady=(15, 10)) sub_btn = ttk.Button( master=container, text="Submit", command=self.on_submit, bootstyle=SUCCESS, width=6, ) sub_btn.pack(side=RIGHT, padx=5) sub_btn.focus_set() cnl_btn = ttk.Button( master=container, text="Cancel", command=self.on_cancel, bootstyle=DANGER, width=6, ) cnl_btn.pack(side=RIGHT, padx=5)
def create_term_row(self): """Add term row to labelframe""" term_row = ttk.Frame(self.option_lf) term_row.pack(fill=X, expand=YES, pady=15) term_lbl = ttk.Label(term_row, text="Term", width=8) term_lbl.pack(side=LEFT, padx=(15, 0)) term_ent = ttk.Entry(term_row, textvariable=self.term_var) term_ent.pack(side=LEFT, fill=X, expand=YES, padx=5) search_btn = ttk.Button(master=term_row, text="Search", command=self.on_search, bootstyle=OUTLINE, width=8) search_btn.pack(side=LEFT, padx=5)
def create_button(self, master, text): if text == "=": bootstyle = SUCCESS elif not isinstance(text, int): bootstyle = SECONDARY else: bootstyle = PRIMARY return ttk.Button( master=master, text=text, command=lambda x=text: self.on_button_pressed(x), bootstyle=bootstyle, width=2, padding=10, )
def __init__(self, parent_widget, label_name, value=None, **kw): super().__init__(parent_widget, **kw) self.parent = parent_widget self.lbl_name = ttk.StringVar() self.lbl_name.set(label_name) self.value = value self.configure(borderwidth=1, relief="solid") lbl = ttk.Label(self, textvariable=self.lbl_name, bootstyle='inverse-secondary', padding=PADDING) lbl.pack(side='left') close_btn = ttk.Button(self, text='x', bootstyle='secondary', padding=PADDING) close_btn.pack(side='left') close_btn['command'] = self.destroy
def create_buttonbox(self): """Create buttonbox with media controls""" container = ttk.Frame(self) container.pack(fill=X, expand=YES) ttk.Style().configure('TButton', font="-size 14") rev_btn = ttk.Button( master=container, text=Emoji.get( 'black left-pointing double triangle with vertical bar'), padding=10, ) rev_btn.pack(side=LEFT, fill=X, expand=YES) play_btn = ttk.Button( master=container, text=Emoji.get('black right-pointing triangle'), padding=10, ) play_btn.pack(side=LEFT, fill=X, expand=YES) fwd_btn = ttk.Button( master=container, text=Emoji.get( 'black right-pointing double triangle with vertical bar'), padding=10, ) fwd_btn.pack(side=LEFT, fill=X, expand=YES) pause_btn = ttk.Button( master=container, text=Emoji.get('double vertical bar'), padding=10, ) pause_btn.pack(side=LEFT, fill=X, expand=YES) stop_btn = ttk.Button( master=container, text=Emoji.get('black square for stop'), padding=10, ) stop_btn.pack(side=LEFT, fill=X, expand=YES) stop_btn = ttk.Button(master=container, text=Emoji.get('open file folder'), bootstyle=SECONDARY, padding=10) stop_btn.pack(side=LEFT, fill=X, expand=YES)
def create_elements(self): """Create the layout elements.""" container = ttk.Frame(self, padding=10) container.pack(fill=BOTH, expand=YES) _text = ("Click the START button to begin a long-running task " + "that will last approximately 1 to 15 seconds.") wrapped = '\n'.join(textwrap.wrap(_text, width=35)) lbl = ttk.Label(container, text=wrapped, justify=LEFT) lbl.pack(fill=X, pady=10, expand=YES) self.start_btn = ttk.Button(master=container, text='START', command=self.start_task) self.start_btn.pack(fill=X, pady=10) self.progressbar = ttk.Progressbar(master=container, maximum=10, bootstyle=(STRIPED, SUCCESS)) self.progressbar.pack(fill=X, expand=YES) msg_lbl = ttk.Label(container, textvariable=self.message, anchor=CENTER) msg_lbl.pack(fill=X, pady=10)
#region Tk Interface variables window = TkBootstrap.Window() window.title("Wicked Engine Installer") window.resizable(False, False) style = TkBootstrap.Style("darkly") screenWidth = int(window.winfo_screenwidth() / 3) screenHeight = int(window.winfo_screenheight() / 5) #endregion #region Tk Interface widgets button_install = TkBootstrap.Button(text="start install", bootstyle='success', command=Install) button_path = TkBootstrap.Button(text="select source folder", bootstyle='default', command=SelectDirectory) checkButton_denoiser = TkBootstrap.Checkbutton( text="add denoising", bootstyle='outline-toolbutton') checkButton_settings = TkBootstrap.Checkbutton( text="copy settings", bootstyle='outline-toolbutton') entry_path = TkBootstrap.Entry(text="root directory", bootstyle='default') label_info = TkBootstrap.Label(text="Wicked Engine folder:") #endregion #region Window changes, widget packing/placing, etc.
sidebar.pack(side=LEFT, fill=X, anchor=N) contents_tv = ttk.Treeview(name='contentsview', show=TREEHEADINGS, columns=[0, 1, 2]) contents_tv.pack(side=LEFT, fill=ttk.BOTH, expand=ttk.YES) contents_tv.column('#0', width=500) contents_tv.heading('#0', text='Name', anchor=W) contents_tv.heading(0, text='Date modified', anchor=W) contents_tv.column(0, stretch=False) contents_tv.column(1, stretch=False, width=125) contents_tv.heading(1, text='Type', anchor=W) contents_tv.column(2, width=125, anchor=E, stretch=False) contents_tv.heading(2, text='Size', anchor=E) contents_tv.tag_configure('dir', image=images['File']) contents_tv.tag_configure('file', image=images['Dir']) ttk.Button(text='Prev', command=on_click_parent_dir).pack() # crumbframe = ttk.Frame() # crumbframe.pack(side=BOTTOM, fill=X) # ttk.Button(crumbframe, name='crumb1', text='crumb1', bootstyle=LINK, padding=0).pack(side=LEFT) # ttk.Button(crumbframe, name='crumb2', text='crumb2', bootstyle=LINK, padding=0).pack(side=LEFT) # ttk.Button(crumbframe, name='crumb3', text='crumb3', bootstyle=LINK, padding=0).pack(side=LEFT) # ttk.Button(crumbframe, name='crumb4', text='crumb4', bootstyle=LINK, padding=0).pack(side=LEFT) load_sidebar() app.update_idletasks() load_treeview_items(item_path) contents_tv.tag_bind('dir', '<Double-Button-1>', on_click_treeview_dir) app.mainloop()
ttk.Label(frm, text='default').pack(fill=tk.BOTH) # color for color in style.theme.colors: frm = ttk.Frame(frame, bootstyle=color, width=150, height=100) frm.pack(padx=5, pady=5) frm.pack_propagate(0) ttk.Label(master=frm, text=color, bootstyle=(color, 'inverse')).pack(fill=tk.BOTH) return frame def change_style(): theme = choice(style.theme_names()) style.theme_use(theme) if __name__ == '__main__': # create visual widget style tests root = tk.Tk() style = ttk.Style() ttk.Button(text="Change Theme", command=change_style).pack(padx=10, pady=10) test1 = create_frame_test('TFrame', style) test1.pack(side=tk.LEFT, fill=tk.BOTH) root.mainloop()
def __init__(self, isServer: bool = False): style = ttk.Style("cosmo") self._root = style.master self._root.title("FBPos") self._root.protocol("WM_DELETE_WINDOW", self.shutdown) self._root.rowconfigure(0, weight=1) self._root.columnconfigure(0, weight=1) self._recv = FBFloatMultiRecv() self._client = FBServer() if isServer else FBClient() self._client.registerRecvCallback(self._recv.input) self._plotFrame = ttk.Frame(self._root) self._plotFrame.grid(row=0, column=0, sticky="wesn") self._plotFrame.rowconfigure(0, weight=1) self._plotFrame.columnconfigure(0, weight=1) self._fig = plt.Figure() self._fig.subplots_adjust(top=0.965, bottom=0.055, left=0.115, right=0.97, wspace=0, hspace=0) self._canvas = FigureCanvasTkAgg(self._fig, master=self._plotFrame) self._canvas.get_tk_widget().grid(row=0, column=0, sticky="wesn") self._ax = self._fig.add_subplot(1, 1, 1) self._ax.set_aspect("equal", adjustable="datalim") self._toolbar = NavigationToolbar2Tk(self._canvas, self._plotFrame, pack_toolbar=False) self._toolbar.update() self._hiddenPanButton = self._toolbar._buttons["Pan"] self._prePanState = False self._canvas.mpl_connect("button_press_event", self._control_on_press) self._canvas.mpl_connect("button_release_event", self._control_on_release) self._canvas.mpl_connect("motion_notify_event", self._control_on_move) self._control_event: SimpleNamespace = None self._control_event_lock = threading.Lock() self._control_arrow = FancyArrow(0, 0, 1, 0, width=0.1) self._ax.add_patch(self._control_arrow) self._control_arrow.set_visible(False) self._opFrame = ttk.Frame(self._root) self._opFrame.grid(row=1, column=0, sticky="we") self._resetLimButton = ttk.Button(self._opFrame, text="视野重置", command=self._resetLim) self._resetLimButton.pack(side="left", padx=5, pady=5) self._panButton = ttk.Checkbutton( self._opFrame, text="拖拽", bootstyle=("warning", "outline", "toolbutton"), command=self._onPanClick, ) self._panButton.pack(side="left", padx=5, pady=5) self._controlButton = ttk.Checkbutton( self._opFrame, text="控制", bootstyle=("error", "outline", "toolbutton"), command=self._onControlClick, ) self._controlButton.pack(side="left", padx=5, pady=5) self._pauseButton = ttk.Checkbutton(self._opFrame, text="暂停", bootstyle=("success", "outline", "toolbutton")) self._pauseButton.pack(side="left", padx=5, pady=5) self._resetPosButton = ttk.Button(self._opFrame, text="重置位置", command=self._resetPos) self._resetPosButton.pack(side="left", padx=5, pady=5) self._stopButton = ttk.Button(self._opFrame, text="停止", command=self._stop) self._stopButton.pack(side="left", padx=5, pady=5) self._robots: List[Robot] = [] self._scatters: List[Scatter] = []
def setup_demo(master): ZEN = """Beautiful is better than ugly. Explicit is better than implicit. Simple is better than complex. Complex is better than complicated. Flat is better than nested. Sparse is better than dense. Readability counts. Special cases aren't special enough to break the rules. Although practicality beats purity. Errors should never pass silently. Unless explicitly silenced. In the face of ambiguity, refuse the temptation to guess. There should be one-- and preferably only one --obvious way to do it. Although that way may not be obvious at first unless you're Dutch. Now is better than never. Although never is often better than *right* now. If the implementation is hard to explain, it's a bad idea. If the implementation is easy to explain, it may be a good idea. Namespaces are one honking great idea -- let's do more of those!""" root = ttk.Frame(master, padding=10) style = ttk.Style() theme_names = style.theme_names() theme_selection = ttk.Frame(root, padding=(10, 10, 10, 0)) theme_selection.pack(fill=X, expand=YES) theme_selected = ttk.Label(master=theme_selection, text="litera", font="-size 24 -weight bold") theme_selected.pack(side=LEFT) lbl = ttk.Label(theme_selection, text="Select a theme:") theme_cbo = ttk.Combobox( master=theme_selection, text=style.theme.name, values=theme_names, ) theme_cbo.pack(padx=10, side=RIGHT) theme_cbo.current(theme_names.index(style.theme.name)) lbl.pack(side=RIGHT) ttk.Separator(root).pack(fill=X, pady=10, padx=10) def change_theme(e): t = cbo.get() style.theme_use(t) theme_selected.configure(text=t) theme_cbo.selection_clear() default.focus_set() theme_cbo.bind("<<ComboboxSelected>>", change_theme) lframe = ttk.Frame(root, padding=5) lframe.pack(side=LEFT, fill=BOTH, expand=YES) rframe = ttk.Frame(root, padding=5) rframe.pack(side=RIGHT, fill=BOTH, expand=YES) color_group = ttk.Labelframe(master=lframe, text="Theme color options", padding=10) color_group.pack(fill=X, side=TOP) for color in style.colors: cb = ttk.Button(color_group, text=color, bootstyle=color) cb.pack(side=LEFT, expand=YES, padx=5, fill=X) rb_group = ttk.Labelframe(lframe, text="Checkbuttons & radiobuttons", padding=10) rb_group.pack(fill=X, pady=10, side=TOP) check1 = ttk.Checkbutton(rb_group, text="selected") check1.pack(side=LEFT, expand=YES, padx=5) check1.invoke() check2 = ttk.Checkbutton(rb_group, text="alternate") check2.pack(side=LEFT, expand=YES, padx=5) check4 = ttk.Checkbutton(rb_group, text="deselected") check4.pack(side=LEFT, expand=YES, padx=5) check4.invoke() check4.invoke() check3 = ttk.Checkbutton(rb_group, text="disabled", state=DISABLED) check3.pack(side=LEFT, expand=YES, padx=5) radio1 = ttk.Radiobutton(rb_group, text="selected", value=1) radio1.pack(side=LEFT, expand=YES, padx=5) radio1.invoke() radio2 = ttk.Radiobutton(rb_group, text="deselected", value=2) radio2.pack(side=LEFT, expand=YES, padx=5) radio3 = ttk.Radiobutton(master=rb_group, text="disabled", value=3, state=DISABLED) radio3.pack(side=LEFT, expand=YES, padx=5) ttframe = ttk.Frame(lframe) ttframe.pack(pady=5, fill=X, side=TOP) table_data = [ ("South Island, New Zealand", 1), ("Paris", 2), ("Bora Bora", 3), ("Maui", 4), ("Tahiti", 5), ] tv = ttk.Treeview(master=ttframe, columns=[0, 1], show=HEADINGS, height=5) for row in table_data: tv.insert("", END, values=row) tv.selection_set("I001") tv.heading(0, text="City") tv.heading(1, text="Rank") tv.column(0, width=300) tv.column(1, width=70, anchor=CENTER) tv.pack(side=LEFT, anchor=NE, fill=X) # # notebook with table and text tabs nb = ttk.Notebook(ttframe) nb.pack(side=LEFT, padx=(10, 0), expand=YES, fill=BOTH) nb_text = "This is a notebook tab.\nYou can put any widget you want here." nb.add(ttk.Label(nb, text=nb_text), text="Tab 1", sticky=NW) nb.add(child=ttk.Label(nb, text="A notebook tab."), text="Tab 2", sticky=NW) nb.add(ttk.Frame(nb), text="Tab 3") nb.add(ttk.Frame(nb), text="Tab 4") nb.add(ttk.Frame(nb), text="Tab 5") # text widget txt = ScrolledText(master=lframe, height=5, width=50, autohide=True) txt.insert(END, ZEN) txt.pack(side=LEFT, anchor=NW, pady=5, fill=BOTH, expand=YES) lframe_inner = ttk.Frame(lframe) lframe_inner.pack(fill=BOTH, expand=YES, padx=10) s1 = ttk.Scale(master=lframe_inner, orient=HORIZONTAL, value=75, from_=100, to=0) s1.pack(fill=X, pady=5, expand=YES) ttk.Progressbar( master=lframe_inner, orient=HORIZONTAL, value=50, ).pack(fill=X, pady=5, expand=YES) ttk.Progressbar( master=lframe_inner, orient=HORIZONTAL, value=75, bootstyle=(SUCCESS, STRIPED), ).pack(fill=X, pady=5, expand=YES) m = ttk.Meter( master=lframe_inner, metersize=150, amountused=45, subtext="meter widget", bootstyle=INFO, interactive=True, ) m.pack(pady=10) sb = ttk.Scrollbar( master=lframe_inner, orient=HORIZONTAL, ) sb.set(0.1, 0.9) sb.pack(fill=X, pady=5, expand=YES) sb = ttk.Scrollbar(master=lframe_inner, orient=HORIZONTAL, bootstyle=(DANGER, ROUND)) sb.set(0.1, 0.9) sb.pack(fill=X, pady=5, expand=YES) btn_group = ttk.Labelframe(master=rframe, text="Buttons", padding=(10, 5)) btn_group.pack(fill=X) menu = ttk.Menu(root) for i, t in enumerate(style.theme_names()): menu.add_radiobutton(label=t, value=i) default = ttk.Button(master=btn_group, text="solid button") default.pack(fill=X, pady=5) default.focus_set() mb = ttk.Menubutton( master=btn_group, text="solid menubutton", bootstyle=SECONDARY, menu=menu, ) mb.pack(fill=X, pady=5) cb = ttk.Checkbutton( master=btn_group, text="solid toolbutton", bootstyle=(SUCCESS, TOOLBUTTON), ) cb.invoke() cb.pack(fill=X, pady=5) ob = ttk.Button( master=btn_group, text="outline button", bootstyle=(INFO, OUTLINE), command=lambda: Messagebox.ok("You pushed an outline button"), ) ob.pack(fill=X, pady=5) mb = ttk.Menubutton( master=btn_group, text="outline menubutton", bootstyle=(WARNING, OUTLINE), menu=menu, ) mb.pack(fill=X, pady=5) cb = ttk.Checkbutton( master=btn_group, text="outline toolbutton", bootstyle=(SUCCESS, OUTLINE, TOOLBUTTON), ) cb.pack(fill=X, pady=5) lb = ttk.Button(master=btn_group, text="link button", bootstyle=LINK) lb.pack(fill=X, pady=5) cb1 = ttk.Checkbutton( master=btn_group, text="rounded toggle", bootstyle=(SUCCESS, ROUND, TOGGLE), ) cb1.invoke() cb1.pack(fill=X, pady=5) cb2 = ttk.Checkbutton(master=btn_group, text="squared toggle", bootstyle=(SQUARE, TOGGLE)) cb2.pack(fill=X, pady=5) cb2.invoke() input_group = ttk.Labelframe(master=rframe, text="Other input widgets", padding=10) input_group.pack(fill=BOTH, pady=(10, 5), expand=YES) entry = ttk.Entry(input_group) entry.pack(fill=X) entry.insert(END, "entry widget") password = ttk.Entry(master=input_group, show="•") password.pack(fill=X, pady=5) password.insert(END, "password") spinbox = ttk.Spinbox(master=input_group, from_=0, to=100) spinbox.pack(fill=X) spinbox.set(45) cbo = ttk.Combobox( master=input_group, text=style.theme.name, values=theme_names, exportselection=False, ) cbo.pack(fill=X, pady=5) cbo.current(theme_names.index(style.theme.name)) de = ttk.DateEntry(input_group) de.pack(fill=X) return root
import tkinter as tk import ttkbootstrap as ttk from random import choice from ttkbootstrap import utility utility.enable_high_dpi_awareness() def change_style(): theme = choice(style.theme_names()) style.theme_use(theme) if __name__ == '__main__': # create visual widget style tests root = tk.Tk() style = ttk.Style() ttk.Label(root, text="Root").pack(padx=10, pady=10) top = tk.Toplevel(root) ttk.Label(top, text="Toplevel").pack(padx=10, pady=10) btn = ttk.Button(top, text="Change Theme", command=change_style) btn.pack(padx=10, pady=10) root.mainloop()
import ttkbootstrap as ttk from ttkbootstrap.constants import * app = ttk.Window() frame = ttk.Frame(padding=5) frame.pack(padx=10, pady=10) b1 = ttk.Button(frame, text="Button 1", bootstyle="success") b1.pack(side=LEFT, padx=5, pady=10) b2 = ttk.Button(frame, text="Button 2", bootstyle="info-outline") b2.pack(side=LEFT, padx=5, pady=10) app.mainloop()
import ttkbootstrap as ttk from ttkbootstrap.constants import * root = ttk.Window() frame = ttk.Frame(padding=5) frame.pack(padx=10, pady=10) b1 = ttk.Button(frame, text="Solid Button", bootstyle="success") b1.pack(side=LEFT, padx=5, pady=10) b2 = ttk.Button(frame, text="Outline Button", bootstyle="success-outline") b2.pack(side=LEFT, padx=5, pady=10) root.mainloop()
style = ttk.Style() frame = ttk.Frame(padding=5) frame.pack(padx=5, pady=5, fill=tk.X) top_frame = ttk.Frame(frame) bot_frame = ttk.Frame(frame) top_frame.pack(fill=tk.X) bot_frame.pack(fill=tk.X) # --- Testing below --- # solid button for i, color in enumerate(['default', *style.colors]): if i < 5: a = ttk.Button(top_frame, text=color, bootstyle=color, width=12) else: a = ttk.Button(bot_frame, text=color, bootstyle=color, width=12) a.pack(side=tk.LEFT, padx=3, pady=10) a = ttk.Button(bot_frame, text='disabled', width=12, state=tk.DISABLED) a.pack(side=tk.LEFT, padx=3, pady=10) # outline button for i, color in enumerate(['default', *style.colors]): if i < 5: a = ttk.Button(top_frame, text=color, bootstyle=color + "outline", width=12) else: a = ttk.Button(bot_frame,
def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.pack(fill=BOTH, expand=YES) image_files = { 'properties-dark': 'icons8_settings_24px.png', 'properties-light': 'icons8_settings_24px_2.png', 'add-to-backup-dark': 'icons8_add_folder_24px.png', 'add-to-backup-light': 'icons8_add_book_24px.png', 'stop-backup-dark': 'icons8_cancel_24px.png', 'stop-backup-light': 'icons8_cancel_24px_1.png', 'play': 'icons8_play_24px_1.png', 'refresh': 'icons8_refresh_24px_1.png', 'stop-dark': 'icons8_stop_24px.png', 'stop-light': 'icons8_stop_24px_1.png', 'opened-folder': 'icons8_opened_folder_24px.png', 'logo': 'backup.png' } self.photoimages = [] imgpath = Path(__file__).parent / 'assets' for key, val in image_files.items(): _path = imgpath / val self.photoimages.append(ttk.PhotoImage(name=key, file=_path)) # buttonbar buttonbar = ttk.Frame(self, style='primary.TFrame') buttonbar.pack(fill=X, pady=1, side=TOP) ## new backup _func = lambda: Messagebox.ok(message='Adding new backup') btn = ttk.Button(master=buttonbar, text='New backup set', image='add-to-backup-light', compound=LEFT, command=_func) btn.pack(side=LEFT, ipadx=5, ipady=5, padx=(1, 0), pady=1) ## backup _func = lambda: Messagebox.ok(message='Backing up...') btn = ttk.Button(master=buttonbar, text='Backup', image='play', compound=LEFT, command=_func) btn.pack(side=LEFT, ipadx=5, ipady=5, padx=0, pady=1) ## refresh _func = lambda: Messagebox.ok(message='Refreshing...') btn = ttk.Button(master=buttonbar, text='Refresh', image='refresh', compound=LEFT, command=_func) btn.pack(side=LEFT, ipadx=5, ipady=5, padx=0, pady=1) ## stop _func = lambda: Messagebox.ok(message='Stopping backup.') btn = ttk.Button(master=buttonbar, text='Stop', image='stop-light', compound=LEFT, command=_func) btn.pack(side=LEFT, ipadx=5, ipady=5, padx=0, pady=1) ## settings _func = lambda: Messagebox.ok(message='Changing settings') btn = ttk.Button(master=buttonbar, text='Settings', image='properties-light', compound=LEFT, command=_func) btn.pack(side=LEFT, ipadx=5, ipady=5, padx=0, pady=1) # left panel left_panel = ttk.Frame(self, style='bg.TFrame') left_panel.pack(side=LEFT, fill=Y) ## backup summary (collapsible) bus_cf = CollapsingFrame(left_panel) bus_cf.pack(fill=X, pady=1) ## container bus_frm = ttk.Frame(bus_cf, padding=5) bus_frm.columnconfigure(1, weight=1) bus_cf.add(child=bus_frm, title='Backup Summary', bootstyle=SECONDARY) ## destination lbl = ttk.Label(bus_frm, text='Destination:') lbl.grid(row=0, column=0, sticky=W, pady=2) lbl = ttk.Label(bus_frm, textvariable='destination') lbl.grid(row=0, column=1, sticky=EW, padx=5, pady=2) self.setvar('destination', 'd:/test/') ## last run lbl = ttk.Label(bus_frm, text='Last Run:') lbl.grid(row=1, column=0, sticky=W, pady=2) lbl = ttk.Label(bus_frm, textvariable='lastrun') lbl.grid(row=1, column=1, sticky=EW, padx=5, pady=2) self.setvar('lastrun', '14.06.2021 19:34:43') ## files Identical lbl = ttk.Label(bus_frm, text='Files Identical:') lbl.grid(row=2, column=0, sticky=W, pady=2) lbl = ttk.Label(bus_frm, textvariable='filesidentical') lbl.grid(row=2, column=1, sticky=EW, padx=5, pady=2) self.setvar('filesidentical', '15%') ## section separator sep = ttk.Separator(bus_frm, bootstyle=SECONDARY) sep.grid(row=3, column=0, columnspan=2, pady=10, sticky=EW) ## properties button _func = lambda: Messagebox.ok(message='Changing properties') bus_prop_btn = ttk.Button(master=bus_frm, text='Properties', image='properties-dark', compound=LEFT, command=_func, bootstyle=LINK) bus_prop_btn.grid(row=4, column=0, columnspan=2, sticky=W) ## add to backup button _func = lambda: Messagebox.ok(message='Adding to backup') add_btn = ttk.Button(master=bus_frm, text='Add to backup', image='add-to-backup-dark', compound=LEFT, command=_func, bootstyle=LINK) add_btn.grid(row=5, column=0, columnspan=2, sticky=W) # backup status (collapsible) status_cf = CollapsingFrame(left_panel) status_cf.pack(fill=BOTH, pady=1) ## container status_frm = ttk.Frame(status_cf, padding=10) status_frm.columnconfigure(1, weight=1) status_cf.add(child=status_frm, title='Backup Status', bootstyle=SECONDARY) ## progress message lbl = ttk.Label(master=status_frm, textvariable='prog-message', font='Helvetica 10 bold') lbl.grid(row=0, column=0, columnspan=2, sticky=W) self.setvar('prog-message', 'Backing up...') ## progress bar pb = ttk.Progressbar(master=status_frm, variable='prog-value', bootstyle=SUCCESS) pb.grid(row=1, column=0, columnspan=2, sticky=EW, pady=(10, 5)) self.setvar('prog-value', 71) ## time started lbl = ttk.Label(status_frm, textvariable='prog-time-started') lbl.grid(row=2, column=0, columnspan=2, sticky=EW, pady=2) self.setvar('prog-time-started', 'Started at: 14.06.2021 19:34:56') ## time elapsed lbl = ttk.Label(status_frm, textvariable='prog-time-elapsed') lbl.grid(row=3, column=0, columnspan=2, sticky=EW, pady=2) self.setvar('prog-time-elapsed', 'Elapsed: 1 sec') ## time remaining lbl = ttk.Label(status_frm, textvariable='prog-time-left') lbl.grid(row=4, column=0, columnspan=2, sticky=EW, pady=2) self.setvar('prog-time-left', 'Left: 0 sec') ## section separator sep = ttk.Separator(status_frm, bootstyle=SECONDARY) sep.grid(row=5, column=0, columnspan=2, pady=10, sticky=EW) ## stop button _func = lambda: Messagebox.ok(message='Stopping backup') btn = ttk.Button(master=status_frm, text='Stop', image='stop-backup-dark', compound=LEFT, command=_func, bootstyle=LINK) btn.grid(row=6, column=0, columnspan=2, sticky=W) ## section separator sep = ttk.Separator(status_frm, bootstyle=SECONDARY) sep.grid(row=7, column=0, columnspan=2, pady=10, sticky=EW) # current file message lbl = ttk.Label(status_frm, textvariable='current-file-msg') lbl.grid(row=8, column=0, columnspan=2, pady=2, sticky=EW) self.setvar('current-file-msg', 'Uploading: d:/test/settings.txt') # logo lbl = ttk.Label(left_panel, image='logo', style='bg.TLabel') lbl.pack(side='bottom') # right panel right_panel = ttk.Frame(self, padding=(2, 1)) right_panel.pack(side=RIGHT, fill=BOTH, expand=YES) ## file input browse_frm = ttk.Frame(right_panel) browse_frm.pack(side=TOP, fill=X, padx=2, pady=1) file_entry = ttk.Entry(browse_frm, textvariable='folder-path') file_entry.pack(side=LEFT, fill=X, expand=YES) btn = ttk.Button(master=browse_frm, image='opened-folder', bootstyle=(LINK, SECONDARY), command=self.get_directory) btn.pack(side=RIGHT) ## Treeview tv = ttk.Treeview(right_panel, show='headings', height=5) tv.configure(columns=('name', 'state', 'last-modified', 'last-run-time', 'size')) tv.column('name', width=150, stretch=True) for col in ['last-modified', 'last-run-time', 'size']: tv.column(col, stretch=False) for col in tv['columns']: tv.heading(col, text=col.title(), anchor=W) tv.pack(fill=X, pady=1) ## scrolling text output scroll_cf = CollapsingFrame(right_panel) scroll_cf.pack(fill=BOTH, expand=YES) output_container = ttk.Frame(scroll_cf, padding=1) _value = 'Log: Backing up... [Uploading file: D:/sample_file_35.txt]' self.setvar('scroll-message', _value) st = ScrolledText(output_container) st.pack(fill=BOTH, expand=YES) scroll_cf.add(output_container, textvariable='scroll-message') # seed with some sample data ## starting sample directory file_entry.insert(END, 'D:/text/myfiles/top-secret/samples/') ## treeview and backup logs for x in range(20, 35): result = choices(['Backup Up', 'Missed in Destination'])[0] st.insert(END, f'19:34:{x}\t\t Uploading: D:/file_{x}.txt\n') st.insert(END, f'19:34:{x}\t\t Upload {result}.\n') timestamp = datetime.now().strftime('%d.%m.%Y %H:%M:%S') tv.insert('', END, x, values=(f'sample_file_{x}.txt', result, timestamp, timestamp, f'{int(x // 3)} MB')) tv.selection_set(20)
import ttkbootstrap as ttk from ttkbootstrap.constants import * from ttkbootstrap.tooltip import ToolTip app = ttk.Window(size=(400, 100)) b1 = ttk.Button(app, text="default tooltip") b1.pack(side=LEFT, padx=10, pady=10, fill=X, expand=YES) ToolTip( b1, text= "This is the default tooltip. This yellow background and black foreground will be applied by default.", ) b2 = ttk.Button(app, text="styled tooltip") b2.pack(side=LEFT, padx=10, pady=10, fill=X, expand=YES) ToolTip( b2, text= "This is a styled tooltip. You can change this style by using the `bootstyle` parameter with label style keywords.", bootstyle="danger-inverse", ) app.mainloop()
def __init__(self, tk_parent, linkedin_conn): self.parent = tk_parent self.linkedin_conn = linkedin_conn self.search_results_df = pd.DataFrame() self.search_thread = None self.quick_search = True # Paned Window self.search_paned_window = ttk.PanedWindow(tk_parent, orient='horizontal') self.search_paned_window.pack(side='top', fill="both", expand=True, padx=10) ## Search fields Canvas/ScrolledFrame search_fields_canvas = ttk.Canvas(self.search_paned_window) search_fields_frame = ScrolledFrame(search_fields_canvas) search_fields_frame.pack(side='top', fill='both', expand=True, padx=5) search_fields_frame.hide_scrollbars() ### Load/Save search load_save_btn_frame = ttk.Frame(search_fields_frame) load_save_btn_frame.pack(pady=5, side='top', fill="x") load_search_btn = ttk.Button(load_save_btn_frame, text="Load param.") load_search_btn.pack(side='left') load_search_btn['command'] = self.load_search_config save_search_btn = ttk.Button(load_save_btn_frame, text="Save param.") save_search_btn.pack(side='right', padx=10) save_search_btn['command'] = self.save_search_config ### KW-Frame kw_frame = ttk.Frame(search_fields_frame) kw_frame.pack(pady=5, side='top', fill="x") ttk.Label(kw_frame, text="Keywords").pack(side='left') self.entry_keywords = ttk.Entry(kw_frame) self.entry_keywords.pack(side='left', padx=10, fill='x', expand=True) ttk.Separator(search_fields_frame, orient='horizontal').pack(side='top', fill='x', pady=5) ### Radio Frame radio_frame = ttk.Frame(search_fields_frame) radio_frame.pack(side='top', fill="x", pady=5, expand=True) radio_frame.grid_columnconfigure(0,weight=0) radio_frame.grid_columnconfigure(1,weight=0) radio_frame.grid_columnconfigure(2,weight=1) #### Sort by ttk.Label(radio_frame, text="Sort by").grid(row=0, column=0, sticky='nwse') self.sort_by = ttk.StringVar(value="R") ttk.Radiobutton(radio_frame, text='Most recent', variable=self.sort_by, value="DD").grid(row=0, column=1, padx=10, sticky='nwse') ttk.Radiobutton(radio_frame, text='Most relevant', variable=self.sort_by, value="R").grid(row=0, column=2, padx=10, sticky='nwse') ttk.Separator(radio_frame, orient='horizontal').grid(row=1, columnspan=3, pady=5, sticky='nwse') #### Date Posted ttk.Label(radio_frame, text="Date Posted").grid(row=2, column=0, sticky='nwse', pady=5) self.date_posted = ttk.IntVar(value=365) # Days since job was posted ttk.Radiobutton(radio_frame, text='Past 24h', variable=self.date_posted, value=1).grid(row=3, column=1, padx=10, pady=4, sticky='nwse') ttk.Radiobutton(radio_frame, text='Past Week', variable=self.date_posted, value=7).grid(row=3, column=2, padx=10, pady=4, sticky='nwse') ttk.Radiobutton(radio_frame, text='Past Month', variable=self.date_posted, value=30).grid(row=4, column=1, padx=10, pady=4, sticky='nwse') ttk.Radiobutton(radio_frame, text='Any Time', variable=self.date_posted, value=365).grid(row=4, column=2, padx=10, pady=4, sticky='nwse') ttk.Separator(search_fields_frame, orient='horizontal').pack(side='top', fill='x', pady=5) ### Experience exp_frame = ttk.Frame(search_fields_frame) exp_frame.pack(side='top', fill="x") exp_frame.grid_columnconfigure(0,weight=0) exp_frame.grid_columnconfigure(1,weight=0) exp_frame.grid_columnconfigure(2,weight=1) ttk.Label(exp_frame, text="Experience").grid(row=0, column=0, pady=4, sticky='nwse') intern_lvl_bool = ttk.BooleanVar() entry_lvl_bool = ttk.BooleanVar() associate_bool = ttk.BooleanVar() mid_senior_bool = ttk.BooleanVar() director_bool = ttk.BooleanVar() executive_bool = ttk.BooleanVar() self.exp_dict_list = [ {'bool_val': intern_lvl_bool, 'name': '1'}, {'bool_val': entry_lvl_bool, 'name': '2'}, {'bool_val': associate_bool, 'name': '3'}, {'bool_val': mid_senior_bool, 'name': '4'}, {'bool_val': director_bool, 'name': '5'}, {'bool_val': executive_bool, 'name': '6'}, ] ttk.Checkbutton(exp_frame, text="Internship", variable=intern_lvl_bool).grid(row=1, column=0, padx=5, pady=4, sticky='nwse') ttk.Checkbutton(exp_frame, text="Entry level", variable=entry_lvl_bool).grid(row=1, column=1, padx=5, pady=4, sticky='nwse') ttk.Checkbutton(exp_frame, text="Associate", variable=associate_bool).grid(row=1, column=2, padx=5, pady=4, sticky='nwse') ttk.Checkbutton(exp_frame, text="Mid-Senior level", variable=mid_senior_bool).grid(row=2, column=0, padx=5, pady=4, sticky='nwse') ttk.Checkbutton(exp_frame, text="Director", variable=director_bool).grid(row=2, column=1, padx=5, pady=4, sticky='nwse') ttk.Checkbutton(exp_frame, text="Executive", variable=executive_bool).grid(row=2, column=2, padx=5, pady=4, sticky='nwse') ttk.Separator(search_fields_frame, orient='horizontal').pack(side='top', fill='x', pady=5) ### Company frame self.comp_frame = SearchFrame(search_fields_frame, title='Company', fetch_fct=lambda x: utils.extract_urn_dict_from_query_results(linkedin_conn[0].get_company_urn_ids, x)) self.comp_frame.pack(side='top', fill="x") ttk.Separator(search_fields_frame, orient='horizontal').pack(side='top', fill='x', pady=5) ### Job Type job_type_frame = ttk.Frame(search_fields_frame) job_type_frame.pack(side='top', fill="x") job_type_frame.grid_columnconfigure(0,weight=0) job_type_frame.grid_columnconfigure(1,weight=0) job_type_frame.grid_columnconfigure(2,weight=1) ttk.Label(job_type_frame, text="Job Type").grid(row=0, column=0, pady=4, sticky='nwse') full_time_bool = ttk.BooleanVar() part_time_bool = ttk.BooleanVar() temporary_bool = ttk.BooleanVar() contract_bool = ttk.BooleanVar() volunteer_bool = ttk.BooleanVar() intern_type_bool = ttk.BooleanVar() other_type_bool = ttk.BooleanVar() self.job_type_dict_list = [ {'bool_val': full_time_bool, 'name': 'F'}, {'bool_val': part_time_bool, 'name': 'P'}, {'bool_val': temporary_bool, 'name': 'T'}, {'bool_val': contract_bool, 'name': 'C'}, {'bool_val': volunteer_bool, 'name': 'V'}, {'bool_val': intern_type_bool, 'name': 'I'}, {'bool_val': other_type_bool, 'name': 'O'}, ] ttk.Checkbutton(job_type_frame, text="Other", variable=other_type_bool).grid(row=0, column=2, padx=10, pady=4, sticky='nwse') ttk.Checkbutton(job_type_frame, text="Full-time", variable=full_time_bool).grid(row=1, column=0, padx=10, pady=4, sticky='nwse') ttk.Checkbutton(job_type_frame, text="Part-time", variable=part_time_bool).grid(row=1, column=1, padx=10, pady=4, sticky='nwse') ttk.Checkbutton(job_type_frame, text="Temporary", variable=temporary_bool).grid(row=1, column=2, padx=10, pady=4, sticky='nwse') ttk.Checkbutton(job_type_frame, text="Contract", variable=contract_bool).grid(row=2, column=0, padx=10, pady=4, sticky='nwse') ttk.Checkbutton(job_type_frame, text="Volunteer", variable=volunteer_bool).grid(row=2, column=1, padx=10, pady=4, sticky='nwse') ttk.Checkbutton(job_type_frame, text="Internship", variable=intern_type_bool).grid(row=2, column=2, padx=10, pady=4, sticky='nwse') ttk.Separator(search_fields_frame, orient='horizontal').pack(side='top', fill='x', pady=5) ### Location Fallback self.loc_fallback_frame = SearchFrame(search_fields_frame, title='General Location', single_choice=True, fetch_fct=lambda x: utils.extract_urn_dict_from_query_results(linkedin_conn[0].get_geo_urn_ids, x), tooltip="Restrict the geographical area of the results. In the browser, your location will be recognized automatically and shown at the top of the search page close to the keyword field.") self.loc_fallback_frame.pack(side='top', fill="x") ### Location Frame self.loc_frame = SearchFrame(search_fields_frame, title='Location', fetch_fct=lambda x: utils.extract_urn_dict_from_query_results(linkedin_conn[0].get_geo_urn_ids, x)) self.loc_frame.pack(side='top', fill="x") ttk.Separator(search_fields_frame, orient='horizontal').pack(side='top', fill='x', pady=5) ### Industry frame self.industry_frame = SearchFrame(search_fields_frame, title='Industry', fetch_fct=lambda x: utils.extract_urn_dict_from_query_results(linkedin_conn[0].get_industry_urn_ids, x)) self.industry_frame.pack(side='top', fill="x", pady=5) self.search_paned_window.add(search_fields_canvas) ## Table frame self.table_main_frame = ttk.Frame(tk_parent) # pandastable self.table_frame = ttk.Frame(self.table_main_frame, bootstyle="secondary", borderwidth=2) self.table_frame.pack(side="top", fill="both", expand=True) self.table = Table(self.table_frame, dataframe=pd.DataFrame(), showtoolbar=False, showstatusbar=True) utils.fit_table_style_to_theme(self.table, ttk.Style()) self.table.unbind_all("<Tab>") self.table.unbind_all("<Return>") self.table.show() self.search_paned_window.add(self.table_main_frame) # Buttons frame btn_frame = ttk.Frame(tk_parent) btn_frame.pack(padx=10, pady=10, side='top', fill="x") quick_search_btn = ttk.Button(btn_frame, text="Quick search") quick_search_btn.pack(side='left', padx=10) quick_search_btn['command'] = self.start_quick_search ToolTip(quick_search_btn, "This is a single request that will yield the same results as in the linkedin search bar. \ \nIt doesn't contain any personal details (only public IDs) \ \nYou're not likely to reach any search limit using this mode.") btn_sub_frame = ttk.Frame(btn_frame) btn_sub_frame.pack(side="left", fill="none", expand=True) start_search_btn = ttk.Button(btn_sub_frame, text="Deep Search", bootstyle='danger') start_search_btn.pack(side='left', padx=10) start_search_btn['command'] = self.start_deep_search ToolTip(start_search_btn, "Each search result will be fetched for additional information. \ \nDepending on the number of results and search frequency, this can trigger the linkedin limit \ after which you'll only be able to get 3 results per search until the end of the month.") # self.get_contact_info = ttk.BooleanVar() # contact_info_chk_btn = ttk.Checkbutton(btn_sub_frame, text="Fetch contact info", # variable=self.get_contact_info, bootstyle="danger") # contact_info_chk_btn.pack(side='left', padx=10) # ToolTip(contact_info_chk_btn, text=f"Fetch contact info by running one additional request per result.") self.export_to_file_btn = ttk.Button(btn_frame, text="Export to File", state="disabled") self.export_to_file_btn.pack(side='left', padx=10) self.export_to_file_btn['command'] = self.prepare_dataframe_and_save_to_xsl # Status frame self.status_frame = ttk.Frame(tk_parent) self.status_frame.pack(padx=10, pady=2, side='bottom', expand=False, fill="x") self.status_str = ttk.StringVar(value="") ttk.Label(self.status_frame, textvariable=self.status_str).pack(side='left', expand=False) ttk.Separator(tk_parent, orient='horizontal').pack(side='bottom', fill='x')
The widget on which to add validation. when (str): Specifies when to apply validation. See the `add_validation` method docstring for a full list of options. """ add_validation(widget, _validate_options, options=options, when=when) if __name__ == "__main__": app = ttk.Window() @validator def myvalidation(event: ValidationEvent) -> bool: print(event.postchangetext) return True entry = ttk.Entry() entry.pack(padx=10, pady=10) entry2 = ttk.Entry() entry2.pack(padx=10, pady=10) # add_validation(entry, validate_range, startrange=5, endrange=10) # add_validation(entry, validate_regex, pattern="israel") add_text_validation(entry, when="key") # prevents from using any numbers add_text_validation(entry2, when="key") # add_option_validation(entry, ['red', 'blue', 'green'], 'focusout') # add_regex_validation(entry, r'\d{4}-\d{2}-\d{2}') ttk.Button(text="Other").pack(padx=10, pady=10) app.mainloop()
def __init__(self, master): super().__init__(master) self.pack(fill=BOTH, expand=YES) self.images = [ PhotoImage(name='reset', file=PATH / 'magic_mouse/icons8_reset_24px.png'), PhotoImage(name='reset-small', file=PATH / 'magic_mouse/icons8_reset_16px.png'), PhotoImage(name='submit', file=PATH / 'magic_mouse/icons8_submit_progress_24px.png'), PhotoImage(name='question', file=PATH / 'magic_mouse/icons8_question_mark_16px.png'), PhotoImage(name='direction', file=PATH / 'magic_mouse/icons8_move_16px.png'), PhotoImage(name='bluetooth', file=PATH / 'magic_mouse/icons8_bluetooth_2_16px.png'), PhotoImage(name='buy', file=PATH / 'magic_mouse/icons8_buy_26px_2.png'), PhotoImage(name='mouse', file=PATH / 'magic_mouse/magic_mouse.png') ] for i in range(3): self.columnconfigure(i, weight=1) self.rowconfigure(0, weight=1) # column 1 col1 = ttk.Frame(self, padding=10) col1.grid(row=0, column=0, sticky=NSEW) # device info dev_info = ttk.Labelframe(col1, text='Device Info', padding=10) dev_info.pack(side=TOP, fill=BOTH, expand=YES) # header dev_info_header = ttk.Frame(dev_info, padding=5) dev_info_header.pack(fill=X) btn = ttk.Button(master=dev_info_header, image='reset', bootstyle=LINK, command=self.callback) btn.pack(side=LEFT) lbl = ttk.Label(dev_info_header, text='Model 2009, 2xAA Batteries') lbl.pack(side=LEFT, fill=X, padx=15) btn = ttk.Button(master=dev_info_header, image='submit', bootstyle=LINK, command=self.callback) btn.pack(side=LEFT) # image ttk.Label(dev_info, image='mouse').pack(fill=X) # progressbar pb = ttk.Progressbar(dev_info, value=66) pb.pack(fill=X, pady=5, padx=5) ttk.Label(pb, text='66%', bootstyle=(PRIMARY, INVERSE)).pack() # progress message self.setvar('progress', 'Battery is discharging.') lbl = ttk.Label(master=dev_info, textvariable='progress', font='Helvetica 8', anchor=CENTER) lbl.pack(fill=X) # licence info lic_info = ttk.Labelframe(col1, text='License Info', padding=20) lic_info.pack(side=TOP, fill=BOTH, expand=YES, pady=(10, 0)) lic_info.rowconfigure(0, weight=1) lic_info.columnconfigure(0, weight=2) lic_title = ttk.Label(master=lic_info, text='Trial Version, 28 days left', anchor=CENTER) lic_title.pack(fill=X, pady=(0, 20)) lbl = ttk.Label(master=lic_info, text='Mouse serial number:', anchor=CENTER, font='Helvetica 8') lbl.pack(fill=X) self.setvar('license', 'dtMM2-XYZGHIJKLMN3') lic_num = ttk.Label(master=lic_info, textvariable='license', bootstyle=PRIMARY, anchor=CENTER) lic_num.pack(fill=X, pady=(0, 20)) buy_now = ttk.Button(master=lic_info, image='buy', text='Buy now', compound=BOTTOM, command=self.callback) buy_now.pack(padx=10, fill=X) # Column 2 col2 = ttk.Frame(self, padding=10) col2.grid(row=0, column=1, sticky=NSEW) # scrolling scrolling = ttk.Labelframe(col2, text='Scrolling', padding=(15, 10)) scrolling.pack(side=TOP, fill=BOTH, expand=YES) op1 = ttk.Checkbutton(scrolling, text='Scrolling', variable='op1') op1.pack(fill=X, pady=5) # no horizontal scrolling op2 = ttk.Checkbutton(master=scrolling, text='No horizontal scrolling', variable='op2') op2.pack(fill=X, padx=(20, 0), pady=5) btn = ttk.Button(master=op2, image='question', bootstyle=LINK, command=self.callback) btn.pack(side=RIGHT) # inverse op3 = ttk.Checkbutton(master=scrolling, text='Inverse scroll directcion vertically', variable='op3') op3.pack(fill=X, padx=(20, 0), pady=5) btn = ttk.Button(master=op3, image='direction', bootstyle=LINK, command=self.callback) btn.pack(side=RIGHT) # Scroll only vertical or horizontal op4 = ttk.Checkbutton(master=scrolling, text='Scroll only vertical or horizontal', state=DISABLED) op4.configure(variable='op4') op4.pack(fill=X, padx=(20, 0), pady=5) # smooth scrolling op5 = ttk.Checkbutton(master=scrolling, text='Smooth scrolling', variable='op5') op5.pack(fill=X, padx=(20, 0), pady=5) btn = ttk.Button(master=op5, image='bluetooth', bootstyle=LINK, command=self.callback) btn.pack(side=RIGHT) # scroll speed scroll_speed_frame = ttk.Frame(scrolling) scroll_speed_frame.pack(fill=X, padx=(20, 0), pady=5) lbl = ttk.Label(scroll_speed_frame, text='Speed:') lbl.pack(side=LEFT) scale = ttk.Scale(scroll_speed_frame, value=35, from_=1, to=100) scale.pack(side=LEFT, fill=X, expand=YES, padx=5) scroll_speed_btn = ttk.Button(master=scroll_speed_frame, image='reset-small', bootstyle=LINK, command=self.callback) scroll_speed_btn.pack(side=LEFT) # scroll sense scroll_sense_frame = ttk.Frame(scrolling) scroll_sense_frame.pack(fill=X, padx=(20, 0), pady=(5, 0)) ttk.Label(scroll_sense_frame, text='Sense:').pack(side=LEFT) scale = ttk.Scale(scroll_sense_frame, value=50, from_=1, to=100) scale.pack(side=LEFT, fill=X, expand=YES, padx=5) scroll_sense_btn = ttk.Button(master=scroll_sense_frame, image='reset-small', bootstyle=LINK, command=self.callback) scroll_sense_btn.pack(side=LEFT) # 1 finger gestures finger_gest = ttk.Labelframe(master=col2, text='1 Finger Gestures', padding=(15, 10)) finger_gest.pack(side=TOP, fill=BOTH, expand=YES, pady=(10, 0)) op6 = ttk.Checkbutton(master=finger_gest, text='Fast swipe left/right', variable='op6') op6.pack(fill=X, pady=5) cb = ttk.Checkbutton(master=finger_gest, text='Swap swipe direction', variable='op7') cb.pack(fill=X, padx=(20, 0), pady=5) # gest sense gest_sense_frame = ttk.Frame(finger_gest) gest_sense_frame.pack(fill=X, padx=(20, 0), pady=(5, 0)) ttk.Label(gest_sense_frame, text='Sense:').pack(side=LEFT) scale = ttk.Scale(gest_sense_frame, value=50, from_=1, to=100) scale.pack(side=LEFT, fill=X, expand=YES, padx=5) btn = ttk.Button(master=gest_sense_frame, image='reset-small', bootstyle=LINK, command=self.callback) btn.pack(side=LEFT) # middle click middle_click = ttk.Labelframe(master=col2, text='Middle Click', padding=(15, 10)) middle_click.pack(side=TOP, fill=BOTH, expand=YES, pady=(10, 0)) cbo = ttk.Combobox(master=middle_click, values=['Any 2 finger', 'Other 1', 'Other 2']) cbo.current(0) cbo.pack(fill=X) # Column 3 col3 = ttk.Frame(self, padding=10) col3.grid(row=0, column=2, sticky=NSEW) # two finger gestures two_finger_gest = ttk.Labelframe(master=col3, text='2 Finger Gestures', padding=10) two_finger_gest.pack(side=TOP, fill=BOTH) op7 = ttk.Checkbutton(master=two_finger_gest, text='Fast swipe left/right', variable='op7') op7.pack(fill=X, pady=5) op8 = ttk.Checkbutton(master=two_finger_gest, text='Swap swipe direction', variable='op8') op8.pack(fill=X, padx=(20, 0), pady=5) # gest sense gest_sense_frame = ttk.Frame(two_finger_gest) gest_sense_frame.pack(fill=X, padx=(20, 0), pady=(5, 0)) ttk.Label(gest_sense_frame, text='Sense:').pack(side=LEFT) scale = ttk.Scale(gest_sense_frame, value=50, from_=1, to=100) scale.pack(side=LEFT, fill=X, expand=YES, padx=5) btn = ttk.Button(master=gest_sense_frame, image='reset-small', bootstyle=LINK, command=self.callback) btn.pack(side=LEFT) # fast two finger swipe down lbl = ttk.Label(master=two_finger_gest, text='On fast 2 finger up/down swipe:') lbl.pack(fill=X, pady=(10, 5)) op9 = ttk.Checkbutton(master=two_finger_gest, text='Swap swipe direction', variable='op9') op9.pack(fill=X, padx=(20, 0), pady=5) op10 = ttk.Checkbutton(master=two_finger_gest, text='Swap swipe direction', variable='op10') op10.pack(fill=X, padx=(20, 0), pady=5) two_finger_cbo = ttk.Combobox( master=two_finger_gest, values=['Cycle Task View | Normal | Desktop View']) two_finger_cbo.current(0) two_finger_cbo.pack(fill=X, padx=(20, 0), pady=5) # two finger sense two_finger_sense_frame = ttk.Frame(two_finger_gest) two_finger_sense_frame.pack(fill=X, padx=(20, 0), pady=(5, 0)) ttk.Label(two_finger_sense_frame, text='Sense:').pack(side=LEFT) scale = ttk.Scale(two_finger_sense_frame, value=50, from_=1, to=100) scale.pack(side=LEFT, fill=X, expand=YES, padx=5) two_finger_sense_btn = ttk.Button(master=two_finger_sense_frame, image='reset-small', bootstyle=LINK) two_finger_sense_btn.configure(command=self.callback) two_finger_sense_btn.pack(side=LEFT) # mouse options mouse_options = ttk.Labelframe(master=col3, text='2 Finger Gestures', padding=(15, 10)) mouse_options.pack(side=TOP, fill=BOTH, expand=YES, pady=(10, 0)) op11 = ttk.Checkbutton(master=mouse_options, text='Ignore input if mouse if lifted', variable='op11') op11.pack(fill=X, pady=5) op12 = ttk.Checkbutton(master=mouse_options, text='Ignore input if mouse if lifted', variable='op12') op12.pack(fill=X, pady=5) op13 = ttk.Checkbutton(master=mouse_options, text='Ignore input if mouse if lifted', variable='op13') op13.pack(fill=X, pady=5) # base speed base_speed_sense_frame = ttk.Frame(mouse_options) base_speed_sense_frame.pack(fill=X, padx=(20, 0), pady=(5, 0)) lbl = ttk.Label(base_speed_sense_frame, text='Base speed:') lbl.pack(side=LEFT) scale = ttk.Scale(base_speed_sense_frame, value=50, from_=1, to=100) scale.pack(side=LEFT, fill=X, expand=YES, padx=5) base_speed_sense_btn = ttk.Button(master=base_speed_sense_frame, image='reset-small', bootstyle=LINK) base_speed_sense_btn.configure(command=self.callback) base_speed_sense_btn.pack(side=LEFT) # turn on all checkbuttons for i in range(1, 14): self.setvar(f'op{i}', 1) # turn off select buttons for j in [2, 9, 12, 13]: self.setvar(f'op{j}', 0)
root.title("LinkedIn Job Search") root.geometry("1280x720") # Login frame login_frame = ttk.Frame(root) login_frame.pack(pady=10, expand=False, fill="x") ttk.Label(login_frame, text="User").pack(side='left', expand=False, padx=5) entry_usr = ttk.Entry(login_frame) entry_usr.pack(side='left', expand=True, fill="x", padx=5) ttk.Label(login_frame, text="Pwd").pack(side='left', expand=False, padx=5) entry_pwd = ttk.Entry(login_frame, show="*") entry_pwd.pack(side='left', expand=True, fill="x", padx=5) connect_btn = ttk.Button(login_frame, text="Connect") connect_btn.pack(side='left', padx=5) linkedin_conn = [None] def connect_linkedin(): # Authenticate using any Linkedin account credentials try: linkedin_conn[0] = Linkedin(entry_usr.get(), entry_pwd.get()) messagebox.showinfo("Success", "Successfully logged into LinkedIn.", icon="info") except Exception as e: messagebox.showinfo("Error", "Login failed!\nCheck username and password.\n2FA must be disabled in LinkedIn settings.", icon="error") return