literate-dotfiles/dotfiles/i3.org

8.4 KiB

I3 Configuration

Basic configuration

Colors

  set $bg  #32302f
  set $bg1 #3c3836
  set $bg2 #504945
  set $bg3 #665c54
  set $bg4 #7c6f64

  set $fg  #ebdbb2
  set $fg1 #ebdbb2
  set $fg2 #d5c4a1
  set $fg3 #bdae93
  set $fg4 #a89984

  set $gray   #a89984
  set $red    #cc241d
  set $green  #98971a
  set $yellow #d79921
  set $blue   #458588
  set $purple #b16286
  set $aqua   #689d6a
  set $orange #d65d0e

Mod Key

Set mod key (Mod1=<Alt>, Mod4=<Super>)

  set $mod Mod4

Border Style

  # Configure border style <normal|1pixel|pixel xx|none|pixel>
  new_window pixel 1
  new_float normal

  # Hide borders
  hide_edge_borders smart

Font for window titles

  font Hack Nerd Font 11

Color palette used for the terminal ( ~/.Xresources file )

Colors are gathered based on the documentation https://i3wm.org/docs/userguide.html#xresources.

  set_from_resource $darkred     color1  #000000
  set_from_resource $red         color9  #000000
  set_from_resource $darkgreen   color2  #000000
  set_from_resource $green       color10 #000000
  set_from_resource $darkyellow  color3  #000000
  set_from_resource $yellow      color11 #000000
  set_from_resource $darkblue    color4  #000000
  set_from_resource $blue        color12 #000000
  set_from_resource $darkmagenta color5  #000000
  set_from_resource $magenta     color13 #000000
  set_from_resource $darkcyan    color6  #000000
  set_from_resource $cyan        color14 #000000
  set_from_resource $darkwhite   color7  #000000
  set_from_resource $white       color15 #000000

  # Use custom colors for black
  set $black       #282828
  set $darkblack   #1d2021
  set $transparent #00000000

  # set_from_resource $term_background background
  # set_from_resource $term_foreground foreground
  # set_from_resource $term_color0     color0
  # set_from_resource $term_color1     color1
  # set_from_resource $term_color2     color2
  # set_from_resource $term_color3     color3
  # set_from_resource $term_color4     color4
  # set_from_resource $term_color5     color5
  # set_from_resource $term_color6     color6
  # set_from_resource $term_color7     color7
  # set_from_resource $term_color8     color8
  # set_from_resource $term_color9     color9
  # set_from_resource $term_color10    color10
  # set_from_resource $term_color11    color11
  # set_from_resource $term_color12    color12
  # set_from_resource $term_color13    color13
  # set_from_resource $term_color14    color14
  # set_from_resource $term_color15    color15

Theme colors

  # class                 border  backgr. text    indic.   child_border
  client.focused          $blue   $blue   $fg     $blue
  client.focused_inactive $bg     $bg     $fg     $bg
  client.urgent           $bg     $bg     $fg     $bg
  client.unfocused        $bg     $bg     $fg     $bg
  client.placeholder      $bg     $bg     $fg     $bg

  client.background       #32302F

Settings for i3-gaps

  # Set inner/outer gaps
  gaps inner 10
  gaps outer -2

  # Additionally, you can issue commands with the following syntax. This is useful to bind keys to changing the gap size.
  # gaps inner|outer current|all set|plus|minus <px>
  # gaps inner all set 10
  # gaps outer all plus 5

  # Smart gaps (gaps used if only more than one container on the workspace)
  # smart_gaps on

  # Smart borders (draw borders around container only if it is not the only container on this workspace)
  # on|no_gaps (on=always activate and no_gaps=only activate if the gap size to the edge of the screen is 0)
  # smart_borders on

  # Press $mod+Shift+g to enter the gap mode. Choose o or i for modifying outer/inner gaps. Press one of + / - (in-/decrement for current workspace) or 0 (remove gaps for current workspace). If you also press Shift with these keys, the change will be global for all workspaces.
  set $mode_gaps Gaps: (o) outer, (i) inner
  set $mode_gaps_outer Outer Gaps: +|-|0 (local), Shift + +|-|0 (global)
  set $mode_gaps_inner Inner Gaps: +|-|0 (local), Shift + +|-|0 (global)
  bindsym $mod+Shift+g mode "$mode_gaps"

  mode "$mode_gaps" {
    bindsym o      mode "$mode_gaps_outer"
    bindsym i      mode "$mode_gaps_inner"
    bindsym Return mode "default"
    bindsym Escape mode "default"
  }
  mode "$mode_gaps_inner" {
    bindsym plus  gaps inner current plus 5
    bindsym minus gaps inner current minus 5

    bindsym 0     gaps inner current set 0

    bindsym Shift+plus  gaps inner all plus 5
    bindsym Shift+minus gaps inner all minus 5
    bindsym Shift+0     gaps inner all set 0

    bindsym Return mode "default"
    bindsym Escape mode "default"
  }
  mode "$mode_gaps_outer" {
    bindsym plus  gaps outer current plus 5
    bindsym minus gaps outer current minus 5
    bindsym 0     gaps outer current set 0

    bindsym Shift+plus  gaps outer all plus 5
    bindsym Shift+minus gaps outer all minus 5
    bindsym Shift+0     gaps outer all set 0

    bindsym Return mode "default"
    bindsym Escape mode "default"
  }

Workspace names

To display names or symbols instead of plain workspace numbers you can use something like: set $ws1 1:mail and set $ws2 2:.

  set $ws1 1
  set $ws2 2
  set $ws3 3
  set $ws4 4
  set $ws5 5
  set $ws6 6
  set $ws7 7
  set $ws8 8

Use Mouse+$mod to drag floating windows

  floating_modifier $mod

Back and Forth

  workspace_auto_back_and_forth yes

Application Specific

Open applications on specific workspaces

  # Matlab Figures
  assign[title="^Fig"] $ws6
  for_window [title="^Fig"] layout tabbed
  assign[title="^HG_Peer"] $ws6 # Name of window when export figure with matlab

Open specific applications in floating mode

  for_window [title="File Transfer*"] floating enable
  for_window [class="GParted"] floating enable border normal
  for_window [title="i3_help"] floating enable sticky enable border normal
  for_window [class="Lightdm-settings"] floating enable
  for_window [class="Lxappearance"] floating enable sticky enable border normal
  for_window [class="Manjaro Settings Manager"] floating enable border normal
  for_window [class="Pamac-manager"] floating enable
  for_window [class="Pavucontrol"] floating enable
  for_window [class="qt5ct"] floating enable sticky enable border normal
  for_window [class="Qtconfig-qt4"] floating enable sticky enable border normal
  for_window [class="Simple-scan"] floating enable border normal
  for_window [class="(?i)System-config-printer.py"] floating enable border normal
  for_window [class="Timeset-gui"] floating enable border normal
  for_window [class="(?i)virtualbox"] floating enable border normal
  for_window [class="Xfburn"] floating enable
  for_window [title="^Documentation -"] floating enable border normal
  for_window [class="Yad"] floating enable
  for_window [title="Bluetooth Devices"] floating enable
  for_window [title="Simulink Library Browser"] floating enable

Scratchpad

  # move the currently focused window to the scratchpad
  bindsym $mod+Shift+BackSpace 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+BackSpace scratchpad show

Run Polybar and SXHKD

  exec_always --no-startup-id $HOME/.config/polybar/scripts/launch.sh
  exec_always --no-startup-id sxhkd -m 1 -c ~/.config/sxhkd/sxhkdrc.i3