- IMPORTS
- SHORTCUT KEYS
- COLOR PALLETE
- WINDOW LAYOUTS
- WORK-SPACES
- BAR AND WIDGETS
- MOUSE CONTROLL
- WINDOW FOCUS
- RUN ON STARTUP
- WINDOW MANAGER NAME
This block of code contains the python libraries and modules that need to bee imported for qtile to function
import os
import re
import socket
import subprocess
from libqtile import qtile
from libqtile.config import Click, Drag, Group, KeyChord, Key, Match, Screen
from libqtile.command import lazy
from libqtile import layout, bar, widget, hook
from libqtile.lazy import lazy
from typing import List # noqa: F401
from libqtile.dgroups import simple_key_binder
This block of code is for the hot key combinations used and reserved by qtile… “mod” is the windows or super key
mod = "mod4"
terminal = "alacritty"
keys = [
# Switch between windows
Key([mod], "h", lazy.layout.left(), desc="Move focus to left"),
Key([mod], "l", lazy.layout.right(), desc="Move focus to right"),
Key([mod], "j", lazy.layout.down(), desc="Move focus down"),
Key([mod], "k", lazy.layout.up(), desc="Move focus up"),
Key([mod], "space", lazy.layout.next(),
desc="Move window focus to other window"),
# Move windows between left/right columns or move up/down in current stack.
# Moving out of range in Columns layout will create new column.
Key([mod, "shift"], "h", lazy.layout.shuffle_left(),
desc="Move window to the left"),
Key([mod, "shift"], "l", lazy.layout.shuffle_right(),
desc="Move window to the right"),
Key([mod, "shift"], "j", lazy.layout.shuffle_down(),
desc="Move window down"),
Key([mod, "shift"], "k", lazy.layout.shuffle_up(), desc="Move window up"),
# Grow windows. If current window is on the edge of screen and direction
# will be to screen edge - window would shrink.
Key([mod, "control"], "h", lazy.layout.grow_left(),
desc="Grow window to the left"),
Key([mod, "control"], "l", lazy.layout.grow_right(),
desc="Grow window to the right"),
Key([mod, "control"], "j", lazy.layout.grow_down(),
desc="Grow window down"),
Key([mod, "control"], "k", lazy.layout.grow_up(),
desc="Grow window up"),
Key([mod], "n", lazy.layout.normalize(), desc="Reset all window sizes"),
Key([mod, "control", "shift"], "h", lazy.layout.shrink(),
desc="Grow window to the left"),
# Toggle between split and unsplit sides of stack.
# Split = all windows displayed
# Unsplit = 1 window displayed, like Max layout, but still with
# multiple stack panes
Key([mod, "shift"], "Return", lazy.layout.toggle_split(),
desc="Toggle between split and unsplit sides of stack"),
Key([mod], "Return", lazy.spawn(terminal), desc="Launch terminal"),
# Toggle between different layouts as defined below
Key([mod], "Tab", lazy.next_layout(), desc="Toggle between layouts"),
Key([mod], "q", lazy.window.kill(), desc="Kill focused window"),
Key([mod, "shift"], "r", lazy.restart(), desc="Restart Qtile"),
Key([mod, "shift"], "q", lazy.shutdown(), desc="Shutdown Qtile"),
]
This block of code is a list of colors used within this config
colors = [["#f8f8f2", "#f8f8f2"], #0 WHITE
["#282a36", "#282a36"], #1 GRAY
["#6272a4", "#6272a4"], #2 PURPLE
["#ff5555", "#ff5555"]] #3 RED
This block of code sets the default layout for all windows
layouts = [
layout.Bsp(
fair = False,
border_focus = '#ff5555',
margin_on_single = None,
margin = 10,
border_width = 4
),
layout.Max(
),
layout.Floating(
),
]
This block of code is a list of the workspaces numbered 1-9.
groups = []
# Allocate layouts and labels
group_names = [
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
]
group_labels = [
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
]
group_matches = [
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["NONE"])],
[Match(wm_class=["discord", "Steam"])],
]
group_layout = [
"",
"",
"",
"",
"",
"",
"",
"",
"max",
]
for i in range(len(group_names)):
groups.append(
Group(
name=group_names[i],
label=group_labels[i],
matches=group_matches[i],
layout=group_layout[i],
))
for i in groups:
keys.extend([
# Workspace navigation
Key([mod], i.name, lazy.group[i.name].toscreen()),
Key([mod], "Tab", lazy.screen.next_group()),
Key([mod, "control"], i.name, lazy.window.togroup(i.name)),
Key([mod, "shift"], i.name, lazy.window.togroup(i.name) , lazy.group[i.name].toscreen()),
])
This block of code is for the bar and all the widgets in the bar.
widget_defaults = dict(
font='MesloLGS NF BOLD',
fontsize=20,
padding=0,
)
extension_defaults = widget_defaults.copy()
screens = [
Screen(
top=bar.Bar(
[
#### LEFT SIDE OF THE BAR ####
##workspaces##
widget.GroupBox(
fontsize = 22,
fmt = ' {} ',
highlight_method = "rounded",
active = colors[0],
inactive = colors[1],
this_current_screen_border = colors[1],
this_screen_border = colors[1],
background = colors[3]
),
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
foreground = colors[3],
background = colors[1]
),
###window name##
widget.WindowName(
fmt = ' {} ',
empty_group_string = 'Welcome OZ',
),
#### RIGHT SIDE OF THE BAR ####
##systray##
widget.Systray(),
### CPU WIDGET ###
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
foreground = colors[2],
background = colors[1],
),
widget.TextBox(
text = ' ',
fontsize = 30,
padding = 0,
foreground = colors[1],
background = colors[2]
),
widget.CPUGraph(
border_width = 3,
border_color = colors[1],
background = colors[2]
),
widget.CPU(
foreground = colors[1],
background = colors[2],
format = ' CPU {freq_current}GHz {load_percent}% '
),
### RAM WIDGET ###
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
foreground = colors[3],
background = colors[2],
),
widget.TextBox(
text = ' ',
fontsize = 30,
padding = 0,
foreground = colors[1],
background = colors[3],
),
widget.MemoryGraph(
border_width = 3,
border_color = colors[1],
background = colors[3],
),
widget.Memory(
background = colors[3],
foreground = colors[1],
format = '{MemUsed: .0f}{mm}/{MemTotal: .0f}{mm} ',
),
### NETWORK WIDGET ###
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
foreground = colors[2],
background = colors[3],
),
widget.TextBox(
text = ' ',
fontsize = 30,
padding = 0,
foreground = colors[1],
background = colors[2],
),
widget.NetGraph(
border_width = 3,
border_color = colors[1],
background = colors[2],
),
widget.Net(
interface = 'wlp5s0',
format = ' ↓{down} ↑{up} ',
foreground = colors[1],
background = colors[2],
),
### CLOCK WIDGET ###
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
background = colors[2],
foreground = colors[3],
),
widget.TextBox(
text = ' ',
fontsize = 30,
padding = 0,
background = colors[3],
foreground = colors[1],
),
widget.Clock(
format='%d-%m %a %I:%M %p ',
background = colors[3],
foreground = colors[1],
),
### VOLUME WIDGET ###
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
background = colors[3],
foreground = colors[2],
),
widget.TextBox(
text = ' ',
fontsize = 30,
padding = 1,
background = colors[2],
foreground = colors[1],
),
widget.Volume(
padding = 5,
format = '{} ',
background = colors[2],
foreground = colors[1],
),
### LOGOUT WIDGET ###
widget.TextBox(
text = '',
fontsize = 22,
padding = 0,
foreground = colors[3],
background = colors[2],
),
widget.QuickExit(
fontsize = 30,
default_text = ' ',
countdown_format = ' {} ',
background = colors[3],
foreground = colors[1],
),
],
30,
background=colors[1],
opacity = 1,
margin = 0,
),
),
]
This block of code enables you to use the mouse to drag windows arround.
# Drag floating layouts.
mouse = [
Drag([mod], "Button1", lazy.window.set_position_floating(),
start=lazy.window.get_position()),
Drag([mod], "Button3", lazy.window.set_size_floating(),
start=lazy.window.get_size()),
Click([mod], "Button2", lazy.window.bring_to_front())
]
This block of code handles window focus and also default float windows for some programs
dgroups_key_binder = None
dgroups_app_rules = [] # type: List
follow_mouse_focus = True
bring_front_click = False
cursor_warp = False
floating_layout = layout.Floating(float_rules=[
# Run the utility of `xprop` to see the wm class and name of an X client.
*layout.Floating.default_float_rules,
Match(wm_class='confirmreset'), # gitk
Match(wm_class='makebranch'), # gitk
Match(wm_class='maketag'), # gitk
Match(wm_class='ssh-askpass'), # ssh-askpass
Match(title='branchdialog'), # gitk
Match(title='pinentry'), # GPG key password entry
])
auto_fullscreen = True
focus_on_window_activation = "smart"
reconfigure_screens = True
This block of code runs a shellscript on first startup, this launches startup apps
auto_minimize = True
@hook.subscribe.startup_once
def start_once():
home = os.path.expanduser('~')
subprocess.call([home + '/.config/qtile/autostart.sh'])
This block is for certain java apps
# XXX: Gasp! We're lying here. In fact, nobody really uses or cares about this
# string besides java UI toolkits; you can see several discussions on the
# mailing lists, GitHub issues, and other WM documentation that suggest setting
# this string if your java app doesn't work correctly. We may as well just lie
# and say that we're a working one by default.
#
# We choose LG3D to maximize irony: it is a 3D non-reparenting WM written in
# java that happens to be on java's whitelist.
wmname = "LG3D"