From d86c4a8b6a4f3c6546c1c37582b4bd6842d1c98c Mon Sep 17 00:00:00 2001 From: Gabriel Simmer Date: Fri, 6 Nov 2020 08:51:43 +0000 Subject: [PATCH] Add i3 config Roughly matches sway config, with some tweaks. --- toronto/.config/i3/config | 215 ++++++++++++++++++++++++++++++++++ toronto/.config/i3/display.sh | 44 +++++++ toronto/.config/sway/config | 6 +- 3 files changed, 262 insertions(+), 3 deletions(-) create mode 100644 toronto/.config/i3/config create mode 100755 toronto/.config/i3/display.sh diff --git a/toronto/.config/i3/config b/toronto/.config/i3/config new file mode 100644 index 0000000..cad849b --- /dev/null +++ b/toronto/.config/i3/config @@ -0,0 +1,215 @@ +# i3 config file (v4) +# +# Please see https://i3wm.org/docs/userguide.html for a complete reference! +# +# This config file uses keycodes (bindsym) and was written for the QWERTY +# layout. +# +# To get a config file with the same key positions, but for your current +# layout, use the i3-config-wizard +# +set $mod Mod4 +set $font IBM Plex Mono + +# Font for window titles. Will also be used by the bar unless a different font +# is used in the bar {} block below. +font pango:$font 8 + +# This font is widely installed, provides lots of unicode glyphs, right-to-left +# text rendering and scalability on retina/hidpi displays (thanks to pango). +#font pango:DejaVu Sans Mono 8 + +# The combination of xss-lock, nm-applet and pactl is a popular choice, so +# they are included here as an example. Modify as you see fit. + +# xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the +# screen before suspend. Use loginctl lock-session to lock your screen. +exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork + +# NetworkManager is the most popular way to manage wireless networks on Linux, +# and nm-applet is a desktop environment-independent system tray GUI for it. +exec --no-startup-id nm-applet + +# Use pactl to adjust volume in PulseAudio. +set $refresh_i3status killall -SIGUSR1 i3status +bindsym XF86AudioRaiseVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ +10% && $refresh_i3status +bindsym XF86AudioLowerVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ -10% && $refresh_i3status +bindsym XF86AudioMute exec --no-startup-id pactl set-sink-mute @DEFAULT_SINK@ toggle && $refresh_i3status +bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle && $refresh_i3status + +# use these keys for focus, movement, and resize directions when reaching for +# the arrows is not convenient +set $up l +set $down k +set $left j +set $right semicolon + +# use Mouse+$mod to drag floating windows to their wanted position +floating_modifier $mod + +# start a terminal +bindsym $mod+Return exec alacritty + +# kill focused window +bindsym $mod+Shift+q kill + +# start dmenu (a program launcher) +bindsym $mod+d exec dmenu_run +# There also is the (new) i3-dmenu-desktop which only displays applications +# shipping a .desktop file. It is a wrapper around dmenu, so you need that +# installed. +# bindsym $mod+d exec --no-startup-id i3-dmenu-desktop + +# change focus +bindsym $mod+$left focus left +bindsym $mod+$down focus down +bindsym $mod+$up focus up +bindsym $mod+$right focus right + +# alternatively, you can use the cursor keys: +bindsym $mod+Left focus left +bindsym $mod+Down focus down +bindsym $mod+Up focus up +bindsym $mod+Right focus right + +# move focused window +bindsym $mod+Shift+$left move left +bindsym $mod+Shift+$down move down +bindsym $mod+Shift+$up move up +bindsym $mod+Shift+$right move right + +# alternatively, you can use the cursor keys: +bindsym $mod+Shift+Left move left +bindsym $mod+Shift+Down move down +bindsym $mod+Shift+Up move up +bindsym $mod+Shift+Right move right + +# split in horizontal orientation +bindsym $mod+h split h + +# split in vertical orientation +bindsym $mod+v split v + +# enter fullscreen mode for the focused container +bindsym $mod+f fullscreen toggle + +# change container layout (stacked, tabbed, toggle split) +bindsym $mod+s layout stacking +bindsym $mod+w layout tabbed +bindsym $mod+e layout toggle split + +# toggle tiling / floating +bindsym $mod+Shift+space floating toggle + +# change focus between tiling / floating windows +bindsym $mod+space focus mode_toggle + +# focus the parent container +bindsym $mod+a focus parent + +# focus the child container +#bindsym $mod+d focus child + +# move the currently focused window to the scratchpad +bindsym $mod+Shift+minus move scratchpad + +# Show the next scratchpad window or hide the focused scratchpad window. +# If there are multiple scratchpad windows, this command cycles through them. +bindsym $mod+minus scratchpad show + +# Define names for default workspaces for which we configure key bindings later on. +# We use variables to avoid repeating the names in multiple places. +set $ws1 "1" +set $ws2 "2" +set $ws3 "3" +set $ws4 "4" +set $ws5 "5" +set $ws6 "6" +set $ws7 "7" +set $ws8 "8" +set $ws9 "9" +set $ws10 "10" + +# switch to workspace +bindsym $mod+1 workspace number $ws1 +bindsym $mod+2 workspace number $ws2 +bindsym $mod+3 workspace number $ws3 +bindsym $mod+4 workspace number $ws4 +bindsym $mod+5 workspace number $ws5 +bindsym $mod+6 workspace number $ws6 +bindsym $mod+7 workspace number $ws7 +bindsym $mod+8 workspace number $ws8 +bindsym $mod+9 workspace number $ws9 +bindsym $mod+0 workspace number $ws10 + +# move focused container to workspace +bindsym $mod+Shift+1 move container to workspace number $ws1 +bindsym $mod+Shift+2 move container to workspace number $ws2 +bindsym $mod+Shift+3 move container to workspace number $ws3 +bindsym $mod+Shift+4 move container to workspace number $ws4 +bindsym $mod+Shift+5 move container to workspace number $ws5 +bindsym $mod+Shift+6 move container to workspace number $ws6 +bindsym $mod+Shift+7 move container to workspace number $ws7 +bindsym $mod+Shift+8 move container to workspace number $ws8 +bindsym $mod+Shift+9 move container to workspace number $ws9 +bindsym $mod+Shift+0 move container to workspace number $ws10 + +# reload the configuration file +bindsym $mod+Shift+c reload +# restart i3 inplace (preserves your layout/session, can be used to upgrade i3) +bindsym $mod+Shift+r restart +# exit i3 (logs you out of your X session) +bindsym $mod+Shift+e exec "i3-nagbar -t warning -m 'You pressed the exit shortcut. Do you really want to exit i3? This will end your X session.' -B 'Yes, exit i3' 'i3-msg exit'" + +# resize window (you can also use the mouse for that) +mode "resize" { + # These bindings trigger as soon as you enter the resize mode + + # Pressing left will shrink the window’s width. + # Pressing right will grow the window’s width. + # Pressing up will shrink the window’s height. + # Pressing down will grow the window’s height. + bindsym $left resize shrink width 10 px or 10 ppt + bindsym $down resize grow height 10 px or 10 ppt + bindsym $up resize shrink height 10 px or 10 ppt + bindsym $right resize grow width 10 px or 10 ppt + + # same bindings, but for the arrow keys + bindsym Left resize shrink width 10 px or 10 ppt + bindsym Down resize grow height 10 px or 10 ppt + bindsym Up resize shrink height 10 px or 10 ppt + bindsym Right resize grow width 10 px or 10 ppt + + # back to normal: Enter or Escape or $mod+r + bindsym Return mode "default" + bindsym Escape mode "default" + bindsym $mod+r mode "default" +} + +bindsym $mod+r mode "resize" + +# Start i3bar to display a workspace bar (plus the system information i3status +# finds out, if available) +bar { + position bottom + + # When the status_command prints a new line to stdout, swaybar updates. + # The default just shows the current date and time. + status_command while ~/.config/sway/swaybar.sh; do sleep 1; done + + colors { + statusline #ffffff + background #323232 + # inactive_workspace #32323200 #32323200 #5c5c5c + active_workspace #32323200 #32323200 #5c5c5c + } + font pango:$font 12 +} + +smart_gaps on +smart_borders no_gaps +hide_edge_borders smart_no_gaps +gaps inner 2 + +# Display script +bindsym $mod+p exec --no-startup-id ~/.config/i3/display.sh \ No newline at end of file diff --git a/toronto/.config/i3/display.sh b/toronto/.config/i3/display.sh new file mode 100755 index 0000000..294d21f --- /dev/null +++ b/toronto/.config/i3/display.sh @@ -0,0 +1,44 @@ +#!/bin/bash + +# From https://gist.github.com/amanusk/6b79d407945ca79caa945ce2658fd987 +# (with some mods) + +# This is your default laptop screen, detect by running `xrandr` +INTERNAL_OUTPUT="eDP1" + +# choices will be displayed in dmenu +choices="laptop\ndual\nexternal\nclone" + +# Your choice in dmenu will determine what xrandr command to run +chosen=$(echo -e $choices | dmenu -i) + +if [ `xrandr | grep HDMI-1 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="HDMI-1" +fi +if [ `xrandr | grep HDMI-2 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="HDMI-2" +fi +if [ `xrandr | grep HDMI-3 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="HDMI-3" +fi +if [ `xrandr | grep DP1 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="DP-1" +fi +if [ `xrandr | grep DP-2 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="DP-2" +fi +if [ `xrandr | grep DP-3 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="DP-3" +fi +if [ `xrandr | grep DP2-1 | grep -c ' connected '` -eq 1 ]; then + EXTERNAL_OUTPUT="DP2-1" +fi + +# xrander will run and turn on the display you want, if you have an option for 3 displays, this will need some modifications +case "$chosen" in + external) xrandr --output $INTERNAL_OUTPUT --off --output $EXTERNAL_OUTPUT --auto --primary ;; + laptop) xrandr --output $INTERNAL_OUTPUT --auto --primary --output $EXTERNAL_OUTPUT --off ;; + clone) xrandr --output $INTERNAL_OUTPUT --auto --output $EXTERNAL_OUTPUT --auto --same-as $INTERNAL_OUTPUT ;; + dual) xrandr --output $INTERNAL_OUTPUT --auto --output $EXTERNAL_OUTPUT --auto --right-of $INTERNAL_OUTPUT --primary ;; + +esac diff --git a/toronto/.config/sway/config b/toronto/.config/sway/config index a70e306..fa6d6f0 100644 --- a/toronto/.config/sway/config +++ b/toronto/.config/sway/config @@ -217,7 +217,7 @@ bar { # When the status_command prints a new line to stdout, swaybar updates. # The default just shows the current date and time. - status_command while /home/gsimmer/.config/sway/swaybar.sh; do sleep 1; done + status_command while ~/.config/sway/swaybar.sh; do sleep 1; done colors { statusline #ffffff @@ -225,10 +225,10 @@ bar { # inactive_workspace #32323200 #32323200 #5c5c5c active_workspace #32323200 #32323200 #5c5c5c } - font pango:Fira Code 12 + font pango:IBM Plex Mono 12 } -font pango:Fira Code 10 +font pango:IBM Plex Mono 10 default_border pixel 1 hide_edge_borders smart smart_gaps on