to set powerline symbols
March 11, 2026 ยท View on GitHub
tmux2k is a highly customizable framework designed to enhance your tmux status bar, providing you with a sleek and informative interface for your terminal sessions.

โจ Features
- Informative Display: Essential system stats, git info, weather, and more.
- Plugin Ecosystem: Extensive plugins for system monitoring and version control.
- Easy Customization: Intuitive configuration and flexible architecture.
- Real-Time Updates: Dynamic content rendering for a responsive experience.
โก Setup
โ๏ธ Requirements
Important
bash 5.2 or newer is required for colors to work correctly, macOS users can install it using brew install bash
The default macOS terminal is not supported, I would recommend Kitty, Alacritty or another modern terminal emulator
- A patched nerd font for
powerlineand glyphs support.
๐ป Installation
If you are a tpm user, you can install the theme and keep up to date by adding the following to your .tmux.conf file:
set -g @plugin '2kabhishek/tmux2k'
Run tmux and use the tpm install command: prefix + I (default prefix is ctrl+b)
You can also directly clone the repo to your ~/.tmux/plugins/ folder.
๐จ Available Themes:
- default

- default icons

- catppuccin

- catppuccin icons

- gruvbox

- gruvbox icons

- monokai

- monokai icons

- onedark

- onedark icons

- duo

- duo icons

- duo blue

- default no powerline

To use themes:
# use a theme
set -g @tmux2k-theme 'onedark'
# to show icons only
set -g @tmux2k-icons-only true
# to customize duo bg and fg
set -g @tmux2k-duo-fg "#1688f0" # this will get you duo blue shown above
set -g @tmux2k-duo-bg "#000000" # this will set the bg for duo theme
# to set powerline symbols
set -g @tmux2k-right-sep ๎ด # alternate right status bar sep
set -g @tmux2k-window-list-right-sep ๎ฒ # alternate window list right sep
# to not show powerline
set -g @tmux2k-show-powerline false
# set session icon, accepts: `session`, `window`, or any string
set -g @tmux2k-session-icon "๎ฏ #S" # `#W` for window name
๐๏ธ Customize Theme Colors
Available Colors:
Base Colors
white,gray,blacklight_blue,blue,dark_bluelight_green,green,dark_greenlight_orange,orange,dark_orangelight_pink,pink,dark_pinklight_purple,purple,dark_purplelight_red,red,dark_redlight_yellow,yellow,dark_yellow
UI Colors
text: Text color. Default:blackbg_main: Background color. Default:blackbg_alt: Alt Background color. Default:graymessage_bg: Message background color. Default:bluemessage_fg: Message text color. Default:blackpane_active_border: Active pane border color. Default:bluepane_active_border_bg: Active pane border color. Default:blackpane_border: Inactive pane border color. Default:graypane_border_bg: Inactive pane border color. Default:blackprefix_highlight: Highlight color for active prefix. Default:blue
To customize theme colors:
set -g @tmux2k-light-yellow '#f8c800' # change light yellow base color
set -g @tmux2k-bg-main '#ffffff' # change bg to white
set -g @tmux2k-prefix-highlight '#f8c800' # change prefix color
You may have to restart
tmuxfor some changes to reflect
๐ Gradient Colors
Gradients dynamically color plugin output values based on their magnitude โ lower values use colors from the start of the gradient, higher values from the end.

Each color represents a percentage range determined by the gradient's length. Given a 5-color gradient (5 ranges of 20%), a value of 25% applies color 2 of 5.
Named Gradients
Gradient colors can be reversed by prepending a
!to the gradient name, e.g.:!gruvbox
| Gradient | Colors |
|---|---|
catppuccin | catppuccin-dark | ![]() |
gruvbox | gruvbox-dark | ![]() |
monokai | monokai-dark | ![]() |
onedark | onedark-dark | ![]() |
heat | heat-dark | ![]() |
cosmic | cosmic-dark | ![]() |
You can also define a custom gradient as a space-separated list of hex colors:
# 3-color gradient: R=0-32% G=33-65% B=66-100%
set -g @tmux2k-cpu-gradient '#ff0000 #00ff00 #0000ff'
Plugin Options
The following plugins support gradients and expose @tmux2k-[plugin]-gradient and @tmux2k-[plugin]-icon-link-to values :
| Plugin | icon-link-to values |
|---|---|
cpu | usage, 1m,5m,15m |
ram | usage |
gpu | usage |
battery | usage |
set -g @tmux2k-[plugin]-gradient 'heat'
set -g @tmux2k-[plugin]-icon-link-to 'usage'
# example for cpu plugin:
set -g @tmux2k-cpu-gradient 'catppuccin' # Use 'catppuccin' themed gradient
set -g @tmux2k-cpu-icon-link-to 'usage' # Share usage value color with icon
๐งฉ Available Plugins
bandwidth
Show network bandwidth usage
tmux2k-bandwidth-network-name: Network interface to track bandwidth of, default:en0tmux2k-bandwidth-up-icon: Icon for bandwidth upload usage, default:๏ขtmux2k-bandwidth-down-icon: Icon for bandwidth download usage, default:๏ฃ
battery
Show battery stats and percentage
tmux2k-battery-charging-icon: Icon for charging status, default:๏ฆtmux2k-battery-missing-icon: Icon for missing battery, default:๓ฑtmux2k-battery-percentage-0: Icon for 0-25% battery, default:๏tmux2k-battery-percentage-1: Icon for 25-50% battery, default:๏tmux2k-battery-percentage-2: Icon for 50-75% battery, default:๏tmux2k-battery-percentage-3: Icon for 75-90% battery, default:๏tmux2k-battery-percentage-4: Icon for 90-100% battery, default:๏
cpu
Show CPU usage and load information
-
tmux2k-cpu-icon: Icon for CPU usage, default:๏ผ -
tmux2k-cpu-display-usage: Display CPU usage percentage, default:true -
tmux2k-cpu-usage-average: Number of usage values to average, default:0
Display CPU usage as an average of n values over s seconds, where n is the value given to this option and s the value of
tmux2k-refresh-ratemultiplied by n.Example
# Display a 10s avg w/2s refresh rate set -g @tmux2k-refresh-rate 2 set -g @tmux2k-cpu-usage-average 5 # Display a 1m avg w/15s refresh rate set -g @tmux2k-refresh-rate 15 set -g @tmux2k-cpu-usage-average 4
-
tmux2k-cpu-usage-decimal: Display usage with decimal accuracy, default:true -
tmux2k-cpu-display-load: Display CPU load averages, default:false
Displays CPU load averages given by
uptime, each representing the average number of processes using or waiting to use CPU time over 1, 5 and 15 minutes.
-
tmux2k-cpu-load-percent: Display load averages as percentages, default:true -
tmux2k-cpu-load-normalize: Normalize CPU load averages, default:true
When this option is
true, each load average provided byuptimeis divided by the number of logical cores on the system to give a more identifiable reading.
-
tmux2k-cpu-load-averages: CPU load averages to display, default:1m 5m 15m
The
uptimecommand provides averages at 1, 5 and 15 minute intervals. You can define which of the three intervals to display by passing them as a space-separated list.For example, passing
1m 15mwill display the 1 and 15 minute CPU load averages.
cpu-temp
Show CPU temperature
tmux2k-cpu-temp-icon: Icon for CPU temperature, default:๏tmux2k-cpu-temp-delimiter: Decimal delimiter for CPU temperature, default:.tmux2k-cpu-temp-round: Round CPU temperature to the nearest integer, default:false
cwd
Show current working directory
tmux2k-cwd-icon: Icon for directory, default:๏tmux2k-cwd-length: Maximum path length before truncation, default:20tmux2k-cwd-min-depth: Minimum directory depth before mid-truncation, default:4tmux2k-cwd-prefix-chars: Characters to keep from each directory name when truncating, default:2
docker
Show the number of running Docker containers, with support for filtering by grep term.
tmux2k-docker-icon: Icon for docker, default:๏tmux2k-docker-grep: Grep term for filtering containers, default: ``
git
Show Git branch and status information
tmux2k-git-display-status: Control git status display, default:falsetmux2k-git-added-icon: Icon for added files, default:๏tmux2k-git-modified-icon: Icon for modified files, default:๏tmux2k-git-updated-icon: Icon for updated files, default:๏ดtmux2k-git-deleted-icon: Icon for deleted files, default:๏tmux2k-git-repo-icon: Icon for repository, default:๏tmux2k-git-diff-icon: Icon for differences, default:๏tmux2k-git-no-repo-icon: Icon for no repository, default:๎ฎ
github
Show the number of pending GitHub notifications using GitHub CLI (needs gh cli with auth logged in)
tmux2k-github-icon: Icon for GitHub notifications, default:๏
gpu
Show GPU usage information
tmux2k-gpu-icon: Icon for GPU usage, default:๏
group
Group output from several other plugins to present information in more compact manner.
# Define multiple groups
set -g @tmux2k-group1-plugins "cpu ram"
set -g @tmux2k-group1-delimiter " | "
set -g @tmux2k-group2-plugins "battery network"
set -g @tmux2k-group2-delimiter " โข "
set -g @tmux2k-group3-plugins "time uptime"
# Use them in your status bar
set -g @tmux2k-left-plugins "session group1 git"
set -g @tmux2k-right-plugins "group2 group3"
By default, group plugins inherit colors from the plugin before them. To set custom colors:
# Set colors for specific groups
set -g @tmux2k-group1-colors "blue text"
set -g @tmux2k-group2-colors "purple text"
mise
Show active runtime versions managed by mise (dev tool version manager) with language icons
tmux2k-mise-max-tools: Maximum number of tools to display, default:3tmux2k-mise-exclude-tools: Space-separated list of tools to exclude, default:usage
Supports language icons for popular languages out of the box, easy to add more.
network
Show network status and statistics
tmux2k-network-ethernet-icon: Icon for Ethernet connection, default:๓ฐtmux2k-network-wifi-icon: Icon for Wi-Fi connection, default:๏ซtmux2k-network-offline-icon: Icon for offline status, default:๓ฐ
ping
Show network ping statistics
tmux2k-ping-server: Host/port to ping, default:google.comtmux2k-ping-icon: Icon for ping, default:๓ฑ
pomodoro
Shows pomodoro timer, needs tmux-pomodoro-plus (hit prefix + p to start)
ram
Show RAM usage information
tmux2k-ram-icon: Icon for RAM usage, default:๎ฟ
session
Shows Current Session/Window with custom icon
tmux2k-session-format: Format for Tmux session, default:#Stmux2k-session-icon: Icon for Tmux session, default:๎ฏ
time
Show current time and date
@tmux2k-time-format: Sets the format for displaying the time. Default:"%a %I:%M %p"@tmux2k-time-icon: Sets the icon for the time display. Default:๏บ
updates
Show available system updates. The following package managers are supported:
pacman[+yay] (arch, manjaro, endeavourOS)apt(debian, ubuntu, popos, elementaryOS, mint, zorin)brew(macOS)
weather
Show weather information
@tmux2k-weather-scale: Scale to use for temperature. Default:c, options:[c, f, k]@tmux2k-weather-display-condition: Whether to show weather condition name. Default:true@tmux2k-weather-display-location: Whether to show location name. Default:false@tmux2k-weather-location: Fixed location for weather. Default:""
window-list
tmux window list, this plugin is not supposed to be added to left / right plugin arrays, use the alignment option to position it.
@tmux2k-window-list-alignment: Sets the alignment of the window list. Default:'absolute-centre'Available options: left | centre | right | absolute-centre@tmux2k-window-list-left-sep: Sets the left separator for the window list. Default:๎ถ@tmux2k-window-list-right-sep: Sets the right separator for the window list. Default:๎ด@tmux2k-window-list-format: Sets the format for the window list. Default:'#I:#W'@tmux2k-window-list-compact: Enables or disables compact mode for the window list. Default:false
uptime
Show current system uptime
tmux2k-uptime-icon: Icon for system uptime, default:๓ฑซ
tdo
Show pending todo with tdo
@tmux2k-tdo-icon: Sets the icon for the todos display. Default:๏ง
๐ช Add New Plugins
To add a new plugin:
- Copy
plugin/custom.shand rename it to match your plugin name. - Update the new plugin script to
echothe expected output. - Add color declaration for your plugin name into the
plugin_colorsarray inmain.sh
The plugin name and script file name must match e.g: plugin named
fooshould have a file calledscripts/foo.sh
General Plugin Configs
# set the left and right plugin sections
set -g @tmux2k-left-plugins "session git cpu ram"
set -g @tmux2k-right-plugins "battery network time"
# control refresh rate of status bar plugins that display dynamic information
set -g @tmux2k-refresh-rate 5
# to customize plugin colors
set -g @tmux2k-[plugin-name]-colors "[background] [foreground]"
set -g @tmux2k-cpu-colors "red black" # set cpu plugin bg to red, fg to black
๐๏ธ What's Next
- You tell me!
๐งโ๐ป Behind The Code
๐ Inspiration
I came across dracula/tmux sometime back and I wanted to create a more customizable and easy to expand solution.
๐ก Challenges/Learnings
- Learned a lot about the
tmuxandtpmecosystem. - Did some fancy shell scripting.
What's next
To-Do
You tell me!
๐งฐ Tooling
- dots2k โ Dev Environment
- nvim2k โ Personalized Editor
- sway2k โ Desktop Environment
- qute2k โ Personalized Browser
๐ More Info
- tmux-tea โ Simple and powerful tmux session manager
- tmux-tilit โ Turns tmux into a terminal window manager
โญ hit the star button if you found this useful โญ
Source | Blog | Twitter | LinkedIn | More Links | Other Projects





