Created
          October 1, 2021 11:55 
        
      - 
      
- 
        Save hsnks100/93baa0fe57afe0b4631dd5ab1223ec41 to your computer and use it in GitHub Desktop. 
    i3 config
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | # 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 Mod1 | |
| # Font for window titles. Will also be used by the bar unless a different font | |
| # is used in the bar {} block below. | |
| font pango:monospace 12 | |
| # 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 | |
| # Before i3 v4.8, we used to recommend this one as the default: | |
| # font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1 | |
| # The font above is very space-efficient, that is, it looks good, sharp and | |
| # clear in small sizes. However, its unicode glyph coverage is limited, the old | |
| # X core fonts rendering does not support right-to-left and this being a bitmap | |
| # font, it doesn't scale on retina/hidpi displays. | |
| # use these keys for focus, movement, and resize directions when reaching for | |
| # the arrows is not convenient | |
| set $up k | |
| set $down j | |
| set $left h | |
| set $right l | |
| # use Mouse+$mod to drag floating windows to their wanted position | |
| floating_modifier $mod | |
| # start a terminal | |
| bindsym $mod+Shift+Return exec i3-sensible-terminal | |
| # kill focused window | |
| bindsym $mod+Shift+c kill | |
| # start dmenu (a program launcher) | |
| bindsym $mod+p exec dmenu_run | |
| #bindsym $mod+d exec rofi -show drun | |
| # 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+Shift+v 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 $ws1 | |
| bindsym $mod+2 workspace $ws2 | |
| bindsym $mod+3 workspace $ws3 | |
| bindsym $mod+4 workspace $ws4 | |
| bindsym $mod+5 workspace $ws5 | |
| bindsym $mod+6 workspace $ws6 | |
| bindsym $mod+7 workspace $ws7 | |
| bindsym $mod+8 workspace $ws8 | |
| bindsym $mod+9 workspace $ws9 | |
| bindsym $mod+0 workspace $ws10 | |
| # move focused container to workspace | |
| bindsym $mod+Shift+1 move container to workspace $ws1 | |
| bindsym $mod+Shift+2 move container to workspace $ws2 | |
| bindsym $mod+Shift+3 move container to workspace $ws3 | |
| bindsym $mod+Shift+4 move container to workspace $ws4 | |
| bindsym $mod+Shift+5 move container to workspace $ws5 | |
| bindsym $mod+Shift+6 move container to workspace $ws6 | |
| bindsym $mod+Shift+7 move container to workspace $ws7 | |
| bindsym $mod+Shift+8 move container to workspace $ws8 | |
| bindsym $mod+Shift+9 move container to workspace $ws9 | |
| bindsym $mod+Shift+0 move container to workspace $ws10 | |
| # reload the configuration file | |
| bindsym $mod+Shift+t 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" | |
| # bindsym $mod+Print --release exec "scrot -ue 'mv $f ~/tmp && xclip -selection clipboard -t image/png -i ~/tmp/$n'; sleep 1; exec notify-send 'screenshot has been saved to ~/tmp'" | |
| # Start i3bar to display a workspace bar (plus the system information i3status | |
| # finds out, if available) | |
| bar { | |
| status_command i3status | |
| position top | |
| } | |
| ####################################################################### | |
| # automatically start i3-config-wizard to offer the user to create a | |
| # keysym-based config which used their favorite modifier (alt or windows) | |
| # | |
| # i3-config-wizard will not launch if there already is a config file | |
| # in ~/.i3/config. | |
| # | |
| # Please remove the following exec line: | |
| ####################################################################### | |
| exec i3-config-wizard | |
| client.focused #FF0000 #CC0000 #ffffff #2e9ef4 #ff0000 | |
| for_window [class=".*"] border pixel 10 | |
| bindsym $mod+Shift+s sticky toggle | |
| # Automatically put applications to scratchpad | |
| # for_window [title=".*Chrome.*"] mark "chrome", move scratchpad | |
| for_window [title=".*Shutter.*"] mark "shutter", move scratchpad | |
| bindsym $mod+Shift+p [con_mark="shutter"] scratchpad show | |
| bindsym $mod+t scratchpad show | |
| bindsym $mod+o exec thunar | |
| bindsym $mod+Shift+Ctrl+l exec ~/screenlock.sh | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment