From 1bf88375f8fd17d090eb7118a97e3c86ecec19bb Mon Sep 17 00:00:00 2001 From: "stephan.raabe" Date: Mon, 23 Jan 2023 17:14:35 +0100 Subject: [PATCH] Add qtile --- picom/picon.conf | 4 +- polybar/config.ini | 22 +-- qtile/__pycache__/config.cpython-310.pyc | Bin 0 -> 4015 bytes qtile/autostart.sh | 5 + qtile/config.py | 206 +++++++++++++++++++++++ 5 files changed, 225 insertions(+), 12 deletions(-) create mode 100644 qtile/__pycache__/config.cpython-310.pyc create mode 100755 qtile/autostart.sh create mode 100644 qtile/config.py diff --git a/picom/picon.conf b/picom/picon.conf index b523937..84256b3 100644 --- a/picom/picon.conf +++ b/picom/picon.conf @@ -103,7 +103,7 @@ fade-out-step = 0.03; # Opacity of inactive windows. (0.1 - 1.0, defaults to 1.0) # inactive-opacity = 1 -inactive-opacity = 0.95; +inactive-opacity = 0.7; # Opacity of window titlebars and borders. (0.1 - 1.0, disabled by default) # frame-opacity = 1.0 @@ -143,7 +143,7 @@ focus-exclude = [ "class_g = 'Cairo-clock'" ]; # Sets the radius of rounded window corners. When > 0, the compositor will # round the corners of windows. Does not interact well with # `transparent-clipping`. -corner-radius = 0 +corner-radius = 5 # Exclude conditions for rounded corners. rounded-corners-exclude = [ diff --git a/polybar/config.ini b/polybar/config.ini index 950b0f1..903bcce 100644 --- a/polybar/config.ini +++ b/polybar/config.ini @@ -17,25 +17,27 @@ ;========================================================== [colors] -background = #282A2E -background-alt = #373B41 -foreground = #C5C8C6 -primary = #F0C674 -secondary = #8ABEB7 -alert = #A54242 -disabled = #707880 +;background = #282A2E +;transparency +background = #00000000 +background-alt = #00000000 +foreground = #FFFF00 +primary = #FFFFFF +secondary = #FFFFFF +alert = #FFFFFF +disabled = #FFFFFF [bar/example] width = 100% -height = 20pt -radius = 6 +height = 16pt +radius = 0 ; dpi = 96 background = ${colors.background} foreground = ${colors.foreground} -line-size = 1pt +line-size = 0pt border-size = 4pt border-color = #00000000 diff --git a/qtile/__pycache__/config.cpython-310.pyc b/qtile/__pycache__/config.cpython-310.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8797d6b03d75f0d29cbec2384714b3de5ba02b07 GIT binary patch literal 4015 zcmZuz-E-T<5yt@_2vH;@QL-#6a!kjO6WZ2?E!*;k;y9N46-%-$$#IM}!vT3m5E8z8 z07473`{F!CGtGZM^(~M6J37-p;9mPu&vd4bZBsk$-hrejPk_N;?{|Bq<>@}=*y1mDu&{!hU#XFjH?+M;^T^w zb#+5`2aEwXXXM;LW6;eTdADE`#JK7d-63O0&>3gg9Wh3L){GJvc`X^EWRR3BgtKI5 zTWyc+OIXJPduj*G3G@h{gMDaTpyPlR`p}|4j{-W>hYkyL0??5zic6N<(RU2+(L;Eu zaT4&cLwKt5BfyUw!c(nNfRFd^qdob@0iQU8r}94r{MaEpm45>8$wPQ5zYO?CT^zhM zC02D3(BoZHtm=t)371lGu&jJ0si-IoBSplrVG3$tN2A{!ae~|FG73noH&XTh$(s%R5IdY~wlkPD& zw>=A5=lK7a)SidAGwt)d2ljR%fv>H@H@$sdjX%v z7r^obd=X#TQ;6EWxG!0OLg0Jo=#v)m4U)h(8tE51b_BE1eU*DIYT@vjV zqP@Y}?Jw~)eBDNP34Z~rxv?h$b`yVzZ{n{y^exc1%<1-5V#Y1Jf^Y93=r4oj9KN$J z6YRbFbflmEVWRPshF%*xk<9z0Q~}<~E(c(cQ|l~VZ09x^sS z_9p(u*nGOUv+UUQ9j2~O(_)#s)Q$$x-lFtD}*x_(1w^40NRTkEGK35s;3&WPF2!Br2PZ z(-j`t2??3DL86#?$=sH2Sq>@JNYsMuDTje$1G|UIv6s@J4PGz%jdB>7^_^sB)r`G* zv)tP@Wy`E3;~$7ggCu0Am5e^HLAlsUg1bING#S|-j&EYIQt(2xjo_=aJzLhn}! z=Z0`U2-kD(zLeV1z64bSt;3=-aS#ytGbFNSy5zv&v<$3FUvf;hhRqv4LQl9;m*@qc zVT%g&CM+wg)_upPAuICv)ri6Z8a{QCA|?$pb|Q!p5lGoipU%VdWbzS(LQ_8NMAz45 z=xHmu&ix7b-{R#c2NDS11`j7=)6Zt6-I-}zo;J(V_peQ_m8S#X(YO{fdNaYTK}?B! zNZng;6#3qH=x4yqH0mM?UE;zWmKO$57Yrc0g6S={T6fGaWI5N|AvIV5)W$5QBhyL- z!>~DHhC2c0$fu*&HXYyMS|U4g2-5@GBTzJW2_0-e3Pn{KJCM?u5H=P{;OgCll{y&O zd-$&K9TvMX1w&es~KZtrWj(oAk*|1s3Fxd~8 z8ki7EIr1Watc*iKSuTugkd<}tHOoBmgS6Q5O!{!A2YT}U3f6=?S@ZHRqU%6Zeoybg zk3N8g>5g3!c}ICvQN9SuxoHL(W2igYNl~itp)7BB?9l<<@U)g%5?`} z@&E)}E1i=QWI7>*1$S1!oYmv8=kR>YN1|9)MPU{v7}zq%?Wi7{%KRi_>JAiLR-mH9 zLe_|^(7^yvTbV9`zwTmSB)f1L@c0ixdV()s19`;5^gQom#0Yr955@US7de^*L&OQ6 zUG|;W^+KksnJ-wjTlQ6K*CRHR7Uyaw86jrsJ`~Q9kRRH2T-4F@_+&7jTA1)#Tk7Kxx+tzt@amR_6Ql>T5zfTR-vNWp8AL@a)+o%VMt-$Hd9BR2KEysN z;naau@Mg6JMnXD_bTKmsIvHAO_>KenE+(ZFnvJ9qg*Ye;{0=o(k7?-BYRjYn)9>&U z=Vp#}{FvI+5joUdMK=P5cy3i2vE!txW|Qej01Hmet1laXbcZQ+4dPPNhB&DDUY&?6?#p;_td@Dy=u41T zP^xb5f)xG(8huhn6LJ~l;Zm4{`REhFunp5fdYXyh-*d88>h zz~q0)qw+u1_v-tp6H};!)OV`J<)<&mkmX->MSiEN@>`JhKV6f5(X;Y@bzT0C_Fl~k NK2=rJoTe1f{{fP3;VJ+C literal 0 HcmV?d00001 diff --git a/qtile/autostart.sh b/qtile/autostart.sh new file mode 100755 index 0000000..d477a30 --- /dev/null +++ b/qtile/autostart.sh @@ -0,0 +1,5 @@ +#!/bin/sh + +picom -b & +nitrogen --restore & + diff --git a/qtile/config.py b/qtile/config.py new file mode 100644 index 0000000..c0b10b0 --- /dev/null +++ b/qtile/config.py @@ -0,0 +1,206 @@ +# Copyright (c) 2010 Aldo Cortesi +# Copyright (c) 2010, 2014 dequis +# Copyright (c) 2012 Randall Ma +# Copyright (c) 2012-2014 Tycho Andersen +# Copyright (c) 2012 Craig Barnes +# Copyright (c) 2013 horsik +# Copyright (c) 2013 Tao Sauvage +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +import os +import subprocess + +from libqtile import bar, layout, widget, hook +from libqtile.config import Click, Drag, Group, Key, Match, Screen +from libqtile.lazy import lazy +from libqtile.utils import guess_terminal + +mod = "mod4" +terminal = guess_terminal() + +keys = [ + # A list of available commands that can be bound to keys can be found + # at https://docs.qtile.org/en/latest/manual/config/lazy.html + # Switch between windows + Key([mod], "Left", lazy.layout.left(), desc="Move focus to left"), + Key([mod], "Right", lazy.layout.right(), desc="Move focus to right"), + Key([mod], "Down", lazy.layout.down(), desc="Move focus down"), + Key([mod], "Up", 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"], "Left", lazy.layout.shuffle_left(), desc="Move window to the left"), + Key([mod, "shift"], "Right", lazy.layout.shuffle_right(), desc="Move window to the right"), + Key([mod, "shift"], "Down", lazy.layout.shuffle_down(), desc="Move window down"), + Key([mod, "shift"], "Up", 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"], "Left", lazy.layout.grow_left(), desc="Grow window to the left"), + Key([mod, "control"], "Right", lazy.layout.grow_right(), desc="Grow window to the right"), + Key([mod, "control"], "Down", lazy.layout.grow_down(), desc="Grow window down"), + Key([mod, "control"], "Up", lazy.layout.grow_up(), desc="Grow window up"), + Key([mod], "n", lazy.layout.normalize(), desc="Reset all window sizes"), + # 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], "w", lazy.window.kill(), desc="Kill focused window"), + Key([mod, "control"], "r", lazy.reload_config(), desc="Reload the config"), + Key([mod, "control"], "q", lazy.shutdown(), desc="Shutdown Qtile"), + Key([mod], "r", lazy.spawncmd(), desc="Spawn a command using a prompt widget"), +] + +groups = [Group(i) for i in "123456789"] + +for i in groups: + keys.extend( + [ + # mod1 + letter of group = switch to group + Key( + [mod], + i.name, + lazy.group[i.name].toscreen(), + desc="Switch to group {}".format(i.name), + ), + # mod1 + shift + letter of group = switch to & move focused window to group + Key( + [mod, "shift"], + i.name, + lazy.window.togroup(i.name, switch_group=True), + desc="Switch to & move focused window to group {}".format(i.name), + ), + # Or, use below if you prefer not to switch to that group. + # # mod1 + shift + letter of group = move focused window to group + # Key([mod, "shift"], i.name, lazy.window.togroup(i.name), + # desc="move focused window to group {}".format(i.name)), + ] + ) + +layouts = [ + layout.Columns(border_focus_stack=["#d75f5f", "#8f3d3d"], border_width=1, margin=10), + layout.Max(), + # Try more layouts by unleashing below layouts. + # layout.Stack(num_stacks=2), + # layout.Bsp(), + # layout.Matrix(), + # layout.MonadTall(), + # layout.MonadWide(), + # layout.RatioTile(), + # layout.Tile(), + # layout.TreeTab(), + # layout.VerticalTile(), + # layout.Zoomy(), +] + +widget_defaults = dict( + font="sans", + fontsize=12, + padding=3, +) +extension_defaults = widget_defaults.copy() + +screens = [ + Screen( + top=bar.Bar( + [ + widget.CurrentLayout(), + widget.GroupBox(), + widget.Prompt(), + widget.WindowName(), + widget.Chord( + chords_colors={ + "launch": ("#ff0000", "#ffffff"), + }, + name_transform=lambda name: name.upper(), + ), + widget.TextBox("default config", name="default"), + widget.TextBox("Press <M-r> to spawn", foreground="#d75f5f"), + # NB Systray is incompatible with Wayland, consider using StatusNotifier instead + # widget.StatusNotifier(), + widget.Systray(), + widget.Clock(format="%Y-%m-%d %a %I:%M %p"), + widget.QuickExit(), + ], + 24, + # border_width=[2, 0, 2, 0], # Draw top and bottom borders + # border_color=["ff00ff", "000000", "ff00ff", "000000"] # Borders are magenta + ), + ), +] + +# 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()), +] + +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 + +# If things like steam games want to auto-minimize themselves when losing +# focus, should we respect this or not? +auto_minimize = True + +# When using the Wayland backend, this can be used to configure input devices. +wl_input_rules = None + +# 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" + +# HOOK startup +@hook.subscribe.startup_once +def autostart(): + home = os.path.expanduser('~/.config/qtile/autostart.sh') + subprocess.Popen([home])