Gnu Guix Rice (ofc with stow)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

204 lines
7.0 KiB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
  1. # This file has been auto-generated by i3-config-wizard(1).
  2. # It will not be overwritten, so edit it as you like.
  3. #
  4. # Should you change your keyboard layout some time, delete
  5. # this file and re-run i3-config-wizard(1).
  6. #
  7. # i3 config file (v4)
  8. #
  9. # Please see https://i3wm.org/docs/userguide.html for a complete reference!
  10. set $mod Mod4
  11. # Font for window titles. Will also be used by the bar unless a different font
  12. # is used in the bar {} block below.
  13. #font pango:monospace 8
  14. font pango:JetBrains Mono 8
  15. # This font is widely installed, provides lots of unicode glyphs, right-to-left
  16. # text rendering and scalability on retina/hidpi displays (thanks to pango).
  17. #font pango:DejaVu Sans Mono 8
  18. # gaps
  19. for_window [class="^.*"] border pixel 4
  20. gaps inner 15
  21. gaps outer 10
  22. # restores wallpaper
  23. exec nitrogen --restore &
  24. #picom (for transparency!)
  25. #exec_always --no-startup-id picom --corner-radius 10
  26. exec_always --no-startup-id picom
  27. # Start XDG autostart .desktop files using dex. See also
  28. # https://wiki.archlinux.org/index.php/XDG_Autostart
  29. exec --no-startup-id dex --autostart --environment i3
  30. exec --no-startup-id xrandr -s 1600x900
  31. exec --no-startup-id xmodmap ~/.xmodmap
  32. # The combination of xss-lock, nm-applet and pactl is a popular choice, so
  33. # they are included here as an example. Modify as you see fit.
  34. # xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the
  35. # screen before suspend. Use loginctl lock-session to lock your screen.
  36. exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork
  37. # NetworkManager is the most popular way to manage wireless networks on Linux,
  38. # and nm-applet is a desktop environment-independent system tray GUI for it.
  39. exec --no-startup-id nm-applet
  40. # Use pactl to adjust volume in PulseAudio.
  41. set $refresh_i3status killall -SIGUSR1 i3status
  42. bindsym XF86AudioRaiseVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ +10% && $refresh_i3status
  43. bindsym XF86AudioLowerVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ -10% && $refresh_i3status
  44. bindsym XF86AudioMute exec --no-startup-id pactl set-sink-mute @DEFAULT_SINK@ toggle && $refresh_i3status
  45. bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle && $refresh_i3status
  46. # Use Mouse+$mod to drag floating windows to their wanted position
  47. floating_modifier $mod
  48. # start a terminal
  49. #bindsym $mod+Return exec i3-sensible-terminal
  50. bindsym $mod+Return exec kitty
  51. # kill focused window
  52. bindsym $mod+Shift+q kill
  53. # start dmenu (a program launcher)
  54. bindsym $mod+d exec --no-startup-id dmenu_run
  55. bindsym $mod+Shift+w exec --no-startup-id icecat
  56. bindsym $mod+Shift+s exec --no-startup-id scrot
  57. # A more modern dmenu replacement is rofi:
  58. # bindcode $mod+40 exec "rofi -modi drun,run -show drun"
  59. # There also is i3-dmenu-desktop which only displays applications shipping a
  60. # .desktop file. It is a wrapper around dmenu, so you need that installed.
  61. # bindcode $mod+40 exec --no-startup-id i3-dmenu-desktop
  62. # change focus
  63. bindsym $mod+j focus left
  64. bindsym $mod+k focus down
  65. bindsym $mod+l focus up
  66. bindsym $mod+semicolon focus right
  67. # alternatively, you can use the cursor keys:
  68. bindsym $mod+Left focus left
  69. bindsym $mod+Down focus down
  70. bindsym $mod+Up focus up
  71. bindsym $mod+Right focus right
  72. # move focused window
  73. bindsym $mod+Shift+j move left
  74. bindsym $mod+Shift+k move down
  75. bindsym $mod+Shift+l move up
  76. bindsym $mod+Shift+semicolon move right
  77. # alternatively, you can use the cursor keys:
  78. bindsym $mod+Shift+Left move left
  79. bindsym $mod+Shift+Down move down
  80. bindsym $mod+Shift+Up move up
  81. bindsym $mod+Shift+Right move right
  82. # split in horizontal orientation
  83. bindsym $mod+h split h
  84. # split in vertical orientation
  85. bindsym $mod+v split v
  86. # enter fullscreen mode for the focused container
  87. bindsym $mod+f fullscreen toggle
  88. # change container layout (stacked, tabbed, toggle split)
  89. bindsym $mod+s layout stacking
  90. bindsym $mod+w layout tabbed
  91. #bindsym $mod+e layout toggle split
  92. bindsym $mod+e exec "emacsclient -c"
  93. # toggle tiling / floating
  94. bindsym $mod+Shift+space floating toggle
  95. # change focus between tiling / floating windows
  96. bindsym $mod+space focus mode_toggle
  97. # focus the parent container
  98. bindsym $mod+a focus parent
  99. # focus the child container
  100. #bindsym $mod+d focus child
  101. # Define names for default workspaces for which we configure key bindings later on.
  102. # We use variables to avoid repeating the names in multiple places.
  103. set $ws1 "1"
  104. set $ws2 "2"
  105. set $ws3 "3"
  106. set $ws4 "4"
  107. set $ws5 "5"
  108. set $ws6 "6"
  109. set $ws7 "7"
  110. set $ws8 "8"
  111. set $ws9 "9"
  112. set $ws10 "10"
  113. # switch to workspace
  114. bindsym $mod+1 workspace number $ws1
  115. bindsym $mod+2 workspace number $ws2
  116. bindsym $mod+3 workspace number $ws3
  117. bindsym $mod+4 workspace number $ws4
  118. bindsym $mod+5 workspace number $ws5
  119. bindsym $mod+6 workspace number $ws6
  120. bindsym $mod+7 workspace number $ws7
  121. bindsym $mod+8 workspace number $ws8
  122. bindsym $mod+9 workspace number $ws9
  123. bindsym $mod+0 workspace number $ws10
  124. # move focused container to workspace
  125. bindsym $mod+Shift+1 move container to workspace number $ws1
  126. bindsym $mod+Shift+2 move container to workspace number $ws2
  127. bindsym $mod+Shift+3 move container to workspace number $ws3
  128. bindsym $mod+Shift+4 move container to workspace number $ws4
  129. bindsym $mod+Shift+5 move container to workspace number $ws5
  130. bindsym $mod+Shift+6 move container to workspace number $ws6
  131. bindsym $mod+Shift+7 move container to workspace number $ws7
  132. bindsym $mod+Shift+8 move container to workspace number $ws8
  133. bindsym $mod+Shift+9 move container to workspace number $ws9
  134. bindsym $mod+Shift+0 move container to workspace number $ws10
  135. # reload the configuration file
  136. bindsym $mod+Shift+c reload
  137. # restart i3 inplace (preserves your layout/session, can be used to upgrade i3)
  138. bindsym $mod+Shift+r restart
  139. # exit i3 (logs you out of your X session)
  140. 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'"
  141. # resize window (you can also use the mouse for that)
  142. mode "resize" {
  143. # These bindings trigger as soon as you enter the resize mode
  144. # Pressing left will shrink the window’s width.
  145. # Pressing right will grow the window’s width.
  146. # Pressing up will shrink the window’s height.
  147. # Pressing down will grow the window’s height.
  148. bindsym j resize shrink width 10 px or 10 ppt
  149. bindsym k resize grow height 10 px or 10 ppt
  150. bindsym l resize shrink height 10 px or 10 ppt
  151. bindsym semicolon resize grow width 10 px or 10 ppt
  152. # same bindings, but for the arrow keys
  153. bindsym Left resize shrink width 10 px or 10 ppt
  154. bindsym Down resize grow height 10 px or 10 ppt
  155. bindsym Up resize shrink height 10 px or 10 ppt
  156. bindsym Right resize grow width 10 px or 10 ppt
  157. # back to normal: Enter or Escape or $mod+r
  158. bindsym Return mode "default"
  159. bindsym Escape mode "default"
  160. bindsym $mod+r mode "default"
  161. }
  162. bindsym $mod+r mode "resize"
  163. # Start i3bar to display a workspace bar (plus the system information i3status
  164. # finds out, if available)
  165. bar {
  166. status_command i3status
  167. }