bumblebee-status is a modular, theme-able status line generator for the i3 window manager.
Find a file
2020-04-05 10:18:49 +03:00
.github python packaging and allowing for pip install usage 2020-01-31 18:19:50 -05:00
bin Update paths to Arch Linux 2018-05-23 16:54:56 +02:00
build/debian [build] Add preliminary debian package build 2019-01-02 14:40:23 +01:00
bumblebee requirement comment 2020-04-05 10:18:49 +03:00
requirements Add requirement files for bumbleebee modules 2020-01-26 15:00:57 -06:00
screenshots [README] Add nord-powerline 2020-02-08 12:56:15 +01:00
tests [tests/traffic] Fix tests for module traffic 2020-03-06 07:03:18 +01:00
themes [module] New module SMART status checker fo hdd/ssd 2020-03-28 21:12:45 +01:00
.codeclimate.yml [codeclimate] Ignore thirdparty modules 2017-09-30 11:57:04 +02:00
.coveragerc [coveragerc] excludelines somehow broke the build for Python 2.7 2017-03-04 18:54:42 +01:00
.gitattributes python packaging and allowing for pip install usage 2020-01-31 18:19:50 -05:00
.gitignore using pkg_resources 2020-02-04 19:06:26 -05:00
.travis.yml [travis] Add libdbus-1-dev 2019-10-20 15:14:55 +02:00
bumblebee-ctl [bumblebee-ctl] replace name with module 2020-02-14 21:56:35 +01:00
bumblebee-status [core] Fix error widget 2020-02-15 11:38:36 +01:00
CODE_OF_CONDUCT.md Create CODE_OF_CODUCT.md 2017-06-15 12:58:13 +02:00
CONTRIBUTING.md Create CONTRIBUTING.md 2017-06-15 13:08:14 +02:00
Dockerfile Add Docker Support 2019-09-24 20:57:21 -07:00
LICENSE Initial commit 2016-10-30 15:07:21 +01:00
Makefile [build] Add preliminary debian package build 2019-01-02 14:40:23 +01:00
MANIFEST.in reversing symlinks 2020-02-07 13:33:22 -05:00
Modules.md Spell fix and documentation upgrade 2020-03-27 15:40:48 +01:00
README.md [doc] Update module count 2020-03-20 13:18:36 +01:00
runlint.sh [core] Widget creation/update overhaul 2016-12-08 08:44:54 +01:00
runtests.sh add test for util.which 2018-08-28 14:52:17 +02:00
setup.cfg [setup.cfg] Hopefully fix syntax error 2020-02-01 14:27:45 +01:00
setup.py [pip] Add themes & icons and make lookup work 2020-02-01 14:04:34 +01:00
testjson.sh Clarify testjson.sh output, fix json files 2019-03-30 23:40:50 +07:00
versioneer.py python packaging and allowing for pip install usage 2020-01-31 18:19:50 -05:00

bumblebee-status

Build Status Code Climate Test Coverage Issue Count

Many, many thanks to all contributors! As of now, 56 of the modules are from various contributors (!), and only 19 from myself.

List of modules

Solarized Powerline

bumblebee-status is a modular, theme-able status line generator for the i3 window manager.

How to install

# from AUR:
git clone https://aur.archlinux.org/bumblebee-status.git
cd bumblebee-status
makepkg -sicr

# from PyPI (thanks @tony):
# will install bumblebee-status into ~/.local/bin/bumblebee-status
pip install --user bumblebee-status

Focus is on:

  • Ease of use (no configuration files!)
  • Theme support
  • Extensibility (of course...)

One thing I like in particular: You can use the mouse wheel up/down to switch workspaces forward and back everywhere throughout the bar (unless you have mapped the mouse wheel buttons to another action for a widget, in which case this doesn't work while hovering that particular widget).

I hope you like it and appreciate any kind of feedback: Bug reports, Feature requests, etc. :)

Thanks a lot!

Required i3wm version: 4.12+ (in earlier versions, blocks won't have background colors)

Supported Python versions: 2.7, 3.3, 3.4, 3.5, 3.6

Supported FontAwesome version: 4 (free version of 5 doesn't include some of the icons)

Explicitly unsupported Python versions: 3.2 (missing unicode literals)

The Font Awesome is required for all themes that contain icons (because that is the font that includes these icons). Please refer to your distribution's package management on how to install them, or get them from their website directly. Also, please note that Font Awesome removed some icons used by bumblebee-status from the free set in version 5, so if possible, stick with 4.

# Font Awesome installation instructions

# Arch Linux
$ sudo pacman -S awesome-terminal-fonts

# FreeBSD
$ sudo pkg install font-awesome
$ sudo pkg install py36-tzlocal py36-pytz py36-netifaces py36-psutil py36-requests #for dependencies

# Other
# see https://github.com/gabrielelana/awesome-terminal-fonts

Example usage:

bar {
	status_command <path>/bumblebee-status -m cpu memory battery time pasink pasource -p time.format="%H:%M" -t solarized
}

Documentation

See the wiki for documentation.

See FAQ for, well, FAQs.

Other resources:

User contributions:

@somospocos:bumblebee-status-contrib: Collected resources and useful tricks by @somospocos

@somospocos:bumblebee-bridge-dwm: Bridge bumblebee-status output into dwm status bar

@somospocos:bumblebee-bridge-dzen2: Bridge bumblebee-status output into dzen2

Installation

$ git clone git://github.com/tobi-wan-kenobi/bumblebee-status

Dependencies

Available modules lists the dependencies (Python modules and external executables) for each module. If you are not using a module, you don't need the dependencies.

Usage

Normal usage

In your i3wm configuration, modify the status_command for your i3bar like this:

bar {
	status_command <path to bumblebee-status/bumblebee-status> \
		-m <list of modules> \
		-p <list of module parameters> \
		-t <theme>
}

You can retrieve a list of modules (and their parameters) and themes by entering:

$ cd bumblebee-status
$ ./bumblebee-status -l themes
$ ./bumblebee-status -l modules

Any parameter you can specify with -p <name>=<value>, you can alternatively specify in ~/.bumblebee-status.conf or ~/.config/bumblebee-status.conf. This parameters act as a fallback, so values specified with -p have priority.

Parameters can also be used to override theme settings, such as:

$ ./bumblebee-status -p <module>.theme.<theme field>=<value>
# for example, to get a spacer with a red background:
$ ./bumblebee-status -m spacer -p spacer.theme.bg=#ff0000

Configuration files have a format like this:

$ cat ~/.bumblebee-status.conf
[module-parameters]
<key> = <value>

For example:

$ cat ~/.bumblebee-status.conf
[module-parameters]
github.token=abcdefabcdef12345

To change the update interval, use:

$ ./bumblebee-status -m <list of modules> -p interval=<interval in seconds>

As a simple example, this is what my i3 configuration looks like:

bar {
	font pango:Inconsolata 10
	position top
	tray_output none
	status_command ~/.i3/bumblebee-status/bumblebee-status -m nic disk:root cpu memory battery date time pasink pasource dnf -p root.path=/ time.format="%H:%M CW %V" date.format="%a, %b %d %Y" -t solarized-powerline
}

Restart i3wm and - that's it!

Events

By default, the following events are handled:

  • Mouse-Wheel on any module moves to the next/previous i3 workspace
  • Left-click on the "disk" module opens the specified path in nautilus
  • Left-click on either "memory" or "cpu" opens gnome-system-monitor
  • Left-click on a "pulseaudio" (or pasource/pasink) module toggles the mute state
  • Right-click on a "pulseaudio" module opens pavucontrol
  • Mouse-Wheel up/down on a "pulseaudio" module raises/lowers the volume

By default, the Mouse-Wheel wraps for the current output. You can disable this behavior by providing the parameter engine.workspacewrap=false (starting with version 1.4.5). Also, you can completely disable output switching by using engine.workspacewheel=false.

You can provide your own handlers to any module by using the following "special" configuration parameters:

  • left-click
  • right-click
  • middle-click
  • wheel-up
  • wheel-down For example, to execute "pavucontrol" whenever you left-click on the nic module, you could write:

$ bumblebee-status -p nic.left-click="pavucontrol"

In the string, you can use the following format identifiers:

  • name
  • instance
  • button

For example:

$ bumblebee-status -p disk.left-click="nautilus {instance}"

Advanced usage:

You can also "programmatically" trigger click events like this:

$ bumblebee-ctl --button <button> --id <ID of the widget> --module <name of the module>

For that to work, you need to know the ID of the widget - this can be configured by adding the <name>.id parameter - it's a comma-separated list with one entry per widget (for multi-widget modules).

Example:

$ bumblebee-status -m cmus -p cmus.id="prev,main,next,shuffle,repeat"
# to "simulate" a left-click on "next":
$ bumblebee-ctl --button left-mouse --module cmus --id next

For a full synopsis, please see bumblebee-ctl --help.

Errors

If errors occur, you should see them in the i3bar itself. If that does not work, or you need more information for troubleshooting, you can activate a debug log using the -d or --debug switch:

$ ./bumblebee-status -d -m <list of modules>

This will create a file called ~/bumblebee-status-debug.log by default. The file name can be changed by using the -f or --logfile option.

Advanced Usage

If you want to have a minimal bar that stays out of the way, you can use the -a or --autohide switch to specify a list of module names. All those modules will only be displayed when (and as long as) their state is either warning or critical (high CPU usage, low disk space, etc.). As long as the module is in a "normal" state and does not require attention, it will remain hidden. Note that this parameter is specified in addition to -m (i.e. to autohide the CPU module, you would use bumblebee-status -m cpu memory traffic -a cpu).

Required Modules

Modules and commandline utilities are only required for modules, the core itself has no external dependencies at all.

  • psutil (for the modules 'cpu', 'memory', 'traffic')
  • netifaces (for the modules 'nic', 'traffic')
  • requests (for the modules 'weather', 'github', 'getcrypto', 'stock', 'currency', 'sun')
  • power (for the module 'battery')
  • dbus (for the module 'spotify', 'deezer')
  • i3ipc (for the module 'title')
  • pacman-contrib (for module 'arch-update')
  • docker (for the module 'docker_ps')
  • pytz (for the module 'datetimetz')
  • localtz (for the module 'datetimetz')
  • suntime (for the module 'sun')
  • feedparser (for the module 'rss')

Required commandline utilities

  • xset (for the module 'caffeine')
  • notify-send (for the module 'caffeine')
  • cmus-remote (for the module 'cmus')
  • dnf (for the module 'dnf')
  • gpmdp-remote (for the module 'gpmdp')
  • setxkbmap (for the module 'layout')
  • fakeroot (for the module 'pacman')
  • pacman (for the module 'pacman')
  • pactl (for the module 'pulseaudio')
  • ping (for the module 'ping')
  • redshift (for the module 'redshift')
  • xrandr (for the module 'xrandr')
  • mpc (for the module 'mpd')
  • bluez / blueman (for module 'bluetooth')
  • dbus-send (for module 'bluetooth')
  • nvidia-smi (for module 'nvidiagpu')
  • sensors (for module 'sensors', as fallback)
  • zpool (for module 'zpool')
  • progress (for module 'progress')
  • i3exit (for module 'system')
  • dunst (for module 'dunst')
  • hddtemp (for module 'hddtemp')

Examples

Here are some screenshots for all themes that currently exist:

Some themes (all 'Powerline' themes) require Font Awesome and a powerline-compatible font (powerline-fonts, for example) to display all icons correctly.

If you want to add your own theme, just drop it into ~/.config/bumblebee-status/themes/

Gruvbox Powerline (-t gruvbox-powerline) (contributed by @TheEdgeOfRage):

Gruvbox Powerline

Gruvbox Powerline Light (-t gruvbox-powerline-light) (contributed by freed00m):

Gruvbox Powerline Light

Solarized Powerline (-t solarized-powerline):

Solarized Powerline

Gruvbox (-t gruvbox):

Gruvbox

Gruvbox Light (-t gruvbox-light) (contributed by freed00m):

Gruvbox Light

Solarized (-t solarized):

Solarized

Powerline (-t powerline):

Powerline

Greyish Powerline (-t greyish-powerline) (contributed by Joshua Bark):

Greyish Powerline

Iceberg (-t iceberg) (contributed by whzup):

Iceberg

Iceberg Powerline (-t iceberg-powerline) (contributed by whzup):

Iceberg Powerline

Iceberg Dark Powerline (-t iceberg-dark-powerline) (contributed by gkeep):

Iceberg Dark Powerline

Iceberg Rainbow (-t iceberg-rainbow) (contributed by whzup):

Iceberg Rainbow

One Dark Powerline (-t onedark-powerline) (contributed by dillasyx):

One Dark Powerline

Dracula Powerline (-t dracula-powerline) (contributed by xsteadfastx):

Dracula Powerline

Nord Powerline (-t nord-powerline) (contributed by uselessthird):

Nord Powerline

Default (nothing or -t default):

Default