AN
anthony-bernaert/ctk-sidebar
A sidebar navigation control for CustomTkinter
Sidebar Control for CustomTkinter
This is a custom widget that adds a sidebar to your CustomTkinter app and handles navigation.
Features
- Modern look
- Handles navigation: each menu item gets a separate view
- Easy to configure
- Customizable styles
- Supports submenus (tree structure)
Installation
Get the latest version from PyPI:
pip install ctk-sidebar
Getting started
Import required modules:
import customtkinter
from ctksidebar import CTkSidebarNavigationInstantiate a CTkSidebarNavigation component on your app's toplevel and get a reference to the sidebar:
app = customtkinter.CTk()
app.geometry("640x480")
nav = CTkSidebarNavigation(master=app)
nav.pack(fill="both", expand=True)
side = nav.sidebarAdd a header:
header = customtkinter.CTkLabel(side, text="My App", font=customtkinter.CTkFont(size=20, weight="bold"), fg_color="transparent", anchor="center", height=70)
side.add_frame(header)Add some menu items:
side.add_item(id="home", text="Dashboard")
side.add_item(id="orders", text="Orders")
side.add_item(id="customers", text="Customers")Populate the view of each menu item by using nav.view(<your_id>) as the master:
home_view = customtkinter.CTkLabel(nav.view("home"), text="Home", font=customtkinter.CTkFont(size=20, weight="bold"), fg_color="transparent")
home_view.grid(row=0, column=0, sticky="nsew", padx=20, pady=20)
orders_view = customtkinter.CTkLabel(nav.view("orders"), text="Orders", font=customtkinter.CTkFont(size=20, weight="bold"), fg_color="transparent")
orders_view.grid(row=0, column=0, sticky="nsew", padx=20, pady=20)
customers_view = customtkinter.CTkLabel(nav.view("customers"), text="Customers", font=customtkinter.CTkFont(size=20, weight="bold"), fg_color="transparent")
customers_view.grid(row=0, column=0, sticky="nsew", padx=20, pady=20)Finally, set the startup view and launch the application:
nav.set("home")
app.mainloop()Documentation
See the documentation page for a detailed description of this component.
See the examples folder for the demo applications shown in the screenshots above.
On this page
Languages
Python99.3%Shell0.7%
Contributors
MIT License
Created October 4, 2025
Updated January 29, 2026