config 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  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:Iosevka 11
  14. # This font is widely installed, provides lots of unicode glyphs, right-to-left
  15. # text rendering and scalability on retina/hidpi displays (thanks to pango).
  16. font pango:DejaVu Sans Mono 8
  17. # Before i3 v4.8, we used to recommend this one as the default:
  18. # font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
  19. # The font above is very space-efficient, that is, it looks good, sharp and
  20. # clear in small sizes. However, its unicode glyph coverage is limited, the old
  21. # X core fonts rendering does not support right-to-left and this being a bitmap
  22. # font, it doesn’t scale on retina/hidpi displays.
  23. # Use Mouse+$mod to drag floating windows to their wanted position
  24. floating_modifier $mod
  25. exec feh --bg-scale ~/.config/i3/background.png
  26. #exec --no-startup-id betterlockscreen -w
  27. #exec --no-startup-id fish /home/aria/tmuxify.sh
  28. #bindsym $mod+shift+x exec --no-startup-id betterlockscreen -l dimblur
  29. # binds
  30. bindsym $mod+Return exec --no-startup-id kitty
  31. bindsym $mod+a exec --no-startup-id fish -c emacs
  32. bindsym $mod+e exec --no-startup-id fish -c rofimoji
  33. bindsym $mod+p exec --no-startup-id fish -c "i3-quickterm shell"
  34. bindsym $mod+w exec --no-startup-id qutebrowser
  35. bindsym $mod+space exec --no-startup-id rofi-pass
  36. bindsym $mod+shift+space exec --no-startup-id rofi-pass --insert
  37. bindsym Print exec --no-startup-id spectacle
  38. # kill focused window
  39. bindsym $mod+Shift+q kill
  40. # start dmenu (a program launcher)
  41. bindsym $mod+d exec --no-startup-id rofi -show combi
  42. bindsym XF86LaunchA exec --no-startup-id rofi -show combi
  43. # There also is the (new) i3-dmenu-desktop which only displays applications
  44. # shipping a .desktop file. It is a wrapper around dmenu, so you need that
  45. # installed.
  46. # bindsym $mod+d exec --no-startup-id i3-dmenu-desktop
  47. # change focus
  48. bindsym $mod+h focus left
  49. bindsym $mod+j focus down
  50. bindsym $mod+k focus up
  51. bindsym $mod+l focus right
  52. # alternatively, you can use the cursor keys:
  53. bindsym $mod+Left focus left
  54. bindsym $mod+Down focus down
  55. bindsym $mod+Up focus up
  56. bindsym $mod+Right focus right
  57. # move focused window
  58. bindsym $mod+Shift+h move left
  59. bindsym $mod+Shift+j move down
  60. bindsym $mod+Shift+k move up
  61. bindsym $mod+Shift+l move right
  62. # alternatively, you can use the cursor keys:
  63. bindsym $mod+Shift+Left move left
  64. bindsym $mod+Shift+Down move down
  65. bindsym $mod+Shift+Up move up
  66. bindsym $mod+Shift+Right move right
  67. # split in horizontal orientation
  68. bindsym $mod+v split h
  69. # split in vertical orientation
  70. bindsym $mod+s split v
  71. # enter fullscreen mode for the focused container
  72. bindsym $mod+f fullscreen toggle
  73. # change container layout (stacked, tabbed, toggle split)
  74. # bindsym $mod+s layout stacking
  75. # bindsym $mod+w layout tabbed
  76. # bindsym $mod+e layout toggle split
  77. # toggle tiling / floating
  78. # bindsym $mod+Shift+space floating toggle
  79. # change focus between tiling / floating windows
  80. # bindsym $mod+space focus mode_toggle
  81. # focus the parent container
  82. # bindsym $mod+a focus parent
  83. # focus the child container
  84. #bindsym $mod+d focus child
  85. # Define names for default workspaces for which we configure key bindings later on.
  86. # We use variables to avoid repeating the names in multiple places.
  87. set $ws1 1
  88. set $ws2 2
  89. set $ws3 3
  90. set $ws4 4
  91. set $ws5 5
  92. set $ws6 "6"
  93. set $ws7 "7"
  94. set $ws8 "8"
  95. set $ws9 "9"
  96. set $ws10 "10"
  97. # switch to workspace
  98. bindsym $mod+1 workspace $ws1
  99. bindsym $mod+2 workspace $ws2
  100. bindsym $mod+3 workspace $ws3
  101. bindsym $mod+4 workspace $ws4
  102. bindsym $mod+5 workspace $ws5
  103. bindsym $mod+6 workspace $ws6
  104. bindsym $mod+7 workspace $ws7
  105. bindsym $mod+8 workspace $ws8
  106. bindsym $mod+9 workspace $ws9
  107. bindsym $mod+0 workspace $ws10
  108. # move focused container to workspace
  109. bindsym $mod+Shift+1 move container to workspace $ws1; workspace $ws1
  110. bindsym $mod+Shift+2 move container to workspace $ws2; workspace $ws2
  111. bindsym $mod+Shift+3 move container to workspace $ws3; workspace $ws3
  112. bindsym $mod+Shift+4 move container to workspace $ws4; workspace $ws4
  113. bindsym $mod+Shift+5 move container to workspace $ws5; workspace $ws5
  114. bindsym $mod+Shift+6 move container to workspace $ws6; workspace $ws6
  115. bindsym $mod+Shift+7 move container to workspace $ws7; workspace $ws7
  116. bindsym $mod+Shift+8 move container to workspace $ws8; workspace $ws8
  117. bindsym $mod+Shift+9 move container to workspace $ws9; workspace $ws9
  118. bindsym $mod+Shift+0 move container to workspace $ws10; workspace $ws10
  119. # reload the configuration file
  120. bindsym $mod+Shift+c reload
  121. # restart i3 inplace (preserves your layout/session, can be used to upgrade i3)
  122. bindsym $mod+Shift+r restart
  123. # exit i3 (logs you out of your X session)
  124. 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'"
  125. bar {
  126. position top
  127. status_command i3status
  128. }
  129. # resize window (you can also use the mouse for that)
  130. mode "resize" {
  131. # These bindings trigger as soon as you enter the resize mode
  132. # Pressing left will shrink the window’s width.
  133. # Pressing right will grow the window’s width.
  134. # Pressing up will shrink the window’s height.
  135. # Pressing down will grow the window’s height.
  136. bindsym h resize shrink width 10 px or 10 ppt
  137. bindsym j resize grow height 10 px or 10 ppt
  138. bindsym k resize shrink height 10 px or 10 ppt
  139. bindsym l resize grow width 10 px or 10 ppt
  140. # same bindings, but for the arrow keys
  141. bindsym Left resize shrink width 10 px or 10 ppt
  142. bindsym Down resize grow height 10 px or 10 ppt
  143. bindsym Up resize shrink height 10 px or 10 ppt
  144. bindsym Right resize grow width 10 px or 10 ppt
  145. # back to normal: Enter or Escape or $mod+r
  146. bindsym Return mode "default"
  147. bindsym Escape mode "default"
  148. bindsym $mod+r mode "default"
  149. }
  150. bindsym $mod+r mode "resize"
  151. #smart_borders on
  152. #exec_always --no-startup-id ~/.config/i3/polybar.sh
  153. exec --no-startup-id compton &
  154. gaps inner 3
  155. gaps outer 3
  156. gaps horizontal 3
  157. gaps vertical 3
  158. gaps top 3
  159. gaps right 3
  160. gaps bottom 3
  161. gaps left 3
  162. # Global gaps size
  163. # gaps inner 10 gaps outer 15
  164. for_window [class="^.*"] border pixel 3
  165. assign [class="discord"] $ws3
  166. exec --no-startup-id xrdb ~/.Xresources
  167. ## Volume control
  168. # Path to volume control, without trailing slash
  169. set $volumepath ~/.config/i3/i3-volume
  170. # Command for the status line (used with -t, requires -u)
  171. # ie: i3blocks, i3status
  172. set $statuscmd i3status
  173. # Signal used to update the status line (used with -u, requires -t)
  174. # i3blocks uses SIGRTMIN+10 by default
  175. # i3status uses SIGUSR1 by default
  176. set $statussig SIGUSR1
  177. # Amount to increase/decrease volume as a percentage (used with -i, -d)
  178. set $volumestep 10
  179. # alsa-utils settings when not using pulseaudio-utils
  180. #
  181. # To configure a default card, see https://www.alsa-project.org/main/index.php/Asoundrc
  182. #
  183. # Card number to control. (used with -a and -c)
  184. # If not specified, i3-volume will let `amixer` use a default.
  185. # List cards: aplay -l
  186. #set $alsacard 1
  187. # Uncomment to use alsa-utils (append "-c $alsacard" without quotes to override default card)
  188. #bindsym XF86AudioRaiseVolume exec $volumepath/volume -anp -i $volumestep -t $statuscmd -u $statussig
  189. #bindsym XF86AudioLowerVolume exec $volumepath/volume -anp -d $volumestep -t $statuscmd -u $statussig
  190. #bindsym XF86AudioMute exec $volumepath/volume -amn -t $statuscmd -u $statussig
  191. # pulseaudio-utils settings when not using alsa-utils
  192. #
  193. # Symbolic name for sink (numeric index not supported) (used with -s $sinkname)
  194. # Recommended: comment out this setting and omit the -s option to use default sink
  195. # List sink names: pacmd list-sinks | awk -F "[<>]" '/^\s+name: <.*>/{print $2}'
  196. #set $sinkname alsa_output.pci-0000_00_1b.0.analog-stereo
  197. # Using pulseaudio-utils (append "-s $sinkname" without quotes to override default sink)
  198. bindsym XF86AudioRaiseVolume exec $volumepath/volume -np -i $volumestep -t $statuscmd -u $statussig
  199. bindsym XF86AudioLowerVolume exec $volumepath/volume -np -d $volumestep -t $statuscmd -u $statussig
  200. bindsym XF86AudioMute exec $volumepath/volume -mn -t $statuscmd -u $statussig
  201. # Sreen brightness controls
  202. bindsym XF86MonBrightnessUp exec ~/.config/i3/bright.sh -u # increase screen brightness
  203. bindsym XF86MonBrightnessDown exec ~/.config/i3/bright.sh -d # decrease screen brightness
  204. bindsym XF86Search exec ~/.config/i3/bright.sh 1 # decrease screen brightness
  205. bindsym XF86Explorer exec arandr