### Variables set $left h set $down j set $up k set $right l set $mod Mod4 set $term alacritty # Note: pass the final command to swaymsg so that the resulting window can be opened # on the original workspace that the command was run on. set $menu dmenu_path | dmenu | xargs swaymsg exec -- ### Output configuration # # Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/) output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill # # Example configuration: # # output HDMI-A-1 resolution 1920x1080 position 1920,0 # # You can get the names of your outputs by running: swaymsg -t get_outputs ### Idle configuration # # Example configuration: # exec swayidle -w \ timeout 300 'swaylock -f -c 000000' \ timeout 600 'swaymsg "output * dpms off"' resume 'swaymsg "output * dpms on"' \ before-sleep 'swaylock -f -c 000000' # This will lock your screen after 300 seconds of inactivity, then turn off # your displays after another 300 seconds, and turn your screens back on when # resumed. It will also lock your screen before your computer goes to sleep. ### Input configuration # # Example configuration: # # input "2:14:SynPS/2_Synaptics_TouchPad" { # dwt enabled # tap enabled # natural_scroll enabled # middle_emulation enabled # } # # You can get the names of your inputs by running: swaymsg -t get_inputs # Read `man 5 sway-input` for more information about this section. input * { xkb_layout "de,ir" xkb_options "lv3:caps_switch,grp:lctrl_lwin_toggle,shift:both_shiftlock" } input type:touchpad { tap disabled natural_scroll enabled } ### Key Bindings # `--to-code --no-warn` are used to make bindings layout agnostic. bindsym --to-code --no-warn { $mod+Return exec $term $mod+d exec $menu $mod+Shift+q kill $mod+Shift+c reload $mod+Shift+e exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -b 'Yes, exit sway' 'swaymsg exit' } # Drag floating windows by holding down $mod and left mouse button. # Resize them with right mouse button + $mod. # Despite the name, also works for non-floating windows. # Change normal to inverse to use left mouse button for resizing and right # mouse button for dragging. floating_modifier $mod normal # # Moving around: # # Move your focus around bindsym --to-code $mod+$left focus left bindsym --to-code $mod+$down focus down bindsym --to-code $mod+$up focus up bindsym --to-code $mod+$right focus right # Or use $mod+[up|down|left|right] bindsym --to-code $mod+Left focus left bindsym --to-code $mod+Down focus down bindsym --to-code $mod+Up focus up bindsym --to-code $mod+Right focus right # Move the focused window with the same, but add Shift bindsym --to-code $mod+Shift+$left move left bindsym --to-code $mod+Shift+$down move down bindsym --to-code $mod+Shift+$up move up bindsym --to-code $mod+Shift+$right move right # Ditto, with arrow keys bindsym --to-code $mod+Shift+Left move left bindsym --to-code $mod+Shift+Down move down bindsym --to-code $mod+Shift+Up move up bindsym --to-code $mod+Shift+Right move right # # Workspaces: # # Switch to workspace bindsym --to-code $mod+1 workspace number 1 bindsym --to-code $mod+2 workspace number 2 bindsym --to-code $mod+3 workspace number 3 bindsym --to-code $mod+4 workspace number 4 bindsym --to-code $mod+5 workspace number 5 bindsym --to-code $mod+6 workspace number 6 bindsym --to-code $mod+7 workspace number 7 bindsym --to-code $mod+8 workspace number 8 bindsym --to-code $mod+9 workspace number 9 bindsym --to-code $mod+0 workspace number 10 # Move focused container to workspace bindsym --to-code $mod+Shift+1 move container to workspace number 1 bindsym --to-code $mod+Shift+2 move container to workspace number 2 bindsym --to-code $mod+Shift+3 move container to workspace number 3 bindsym --to-code $mod+Shift+4 move container to workspace number 4 bindsym --to-code $mod+Shift+5 move container to workspace number 5 bindsym --to-code $mod+Shift+6 move container to workspace number 6 bindsym --to-code $mod+Shift+7 move container to workspace number 7 bindsym --to-code $mod+Shift+8 move container to workspace number 8 bindsym --to-code $mod+Shift+9 move container to workspace number 9 bindsym --to-code $mod+Shift+0 move container to workspace number 10 # Note: workspaces can have any name you want, not just numbers. # We just use 1-10 as the default. # # Layout stuff: # # You can "split" the current object of your focus with # $mod+b or $mod+v, for horizontal and vertical splits # respectively. bindsym --to-code $mod+b splith bindsym --to-code $mod+v splitv # Switch the current container between different layout styles bindsym --to-code $mod+s layout stacking bindsym --to-code $mod+w layout tabbed bindsym --to-code $mod+e layout toggle split # Make the current focus fullscreen bindsym --to-code $mod+f fullscreen # Toggle the current focus between tiling and floating mode bindsym --to-code $mod+Shift+space floating toggle # Swap focus between the tiling area and the floating area bindsym --to-code $mod+space focus mode_toggle # Move focus to the parent container bindsym --to-code $mod+a focus parent # # Scratchpad: # # Sway has a "scratchpad", which is a bag of holding for windows. # You can send windows there and get them back later. # Move the currently focused window to the scratchpad bindsym --to-code $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 --to-code $mod+minus scratchpad show # # Resizing containers: # mode "resize" { # left will shrink the containers width # right will grow the containers width # up will shrink the containers height # down will grow the containers height bindsym --to-code $left resize shrink width 10px bindsym --to-code $down resize grow height 10px bindsym --to-code $up resize shrink height 10px bindsym --to-code $right resize grow width 10px # Ditto, with arrow keys bindsym --to-code Left resize shrink width 10px bindsym --to-code Down resize grow height 10px bindsym --to-code Up resize shrink height 10px bindsym --to-code Right resize grow width 10px # Return to default mode bindsym --to-code Return mode "default" bindsym --to-code Escape mode "default" } bindsym --to-code $mod+r mode "resize" # # Multimedia keys - Courtesy of great Arch Linux wiki and its awesome users. # bindsym XF86AudioRaiseVolume exec pactl set-sink-volume @DEFAULT_SINK@ +5% bindsym XF86AudioLowerVolume exec pactl set-sink-volume @DEFAULT_SINK@ -5% bindsym XF86AudioMute exec pactl set-sink-mute @DEFAULT_SINK@ toggle bindsym XF86AudioMicMute exec pactl set-source-mute @DEFAULT_SOURCE@ toggle bindsym XF86MonBrightnessDown exec brightnessctl set 5%- bindsym XF86MonBrightnessUp exec brightnessctl set +5% bindsym XF86AudioPlay exec playerctl play-pause bindsym XF86AudioNext exec playerctl next bindsym XF86AudioPrev exec playerctl previous bindsym XF86Search exec bemenu-run # # Screen capture # Thanks to Gentoo wiki at https://wiki.gentoo.org/wiki/Sway # set $ps1 Print set $ps2 Control+Print set $ps3 Alt+Print set $ps4 Alt+Control+Print bindsym $ps1 exec grim - | wl-copy bindsym $ps2 exec grim -g "$(slurp)" - | wl-copy bindsym $ps3 exec grim $(xdg-user-dir PICTURES)/Screenshots/ps_$(date +"%Y%m%d%H%M%S").png bindsym $ps4 exec grim -g "$(slurp)" $(xdg-user-dir PICTURES)/Screenshots/ps_$(date +"%Y%m%d%H%M%S").png # # Status Bar: # # Read `man 5 sway-bar` for more information about this section. bar { position top # When the status_command prints a new line to stdout, swaybar updates. # The default just shows the current date and time. status_command while date +'%Y-%m-%d %l:%M:%S %p'; do sleep 1; done colors { statusline #ffffff background #323232 inactive_workspace #32323200 #5c5c5c #32323200 } } bar { # i3status does not allow running arbitrary processes. # The man page describes the hack below to make it work. #status_command i3status status_command exec ~/.local/bin/any_position_wrapper.sh } # Load machine specific configuration include ~/.config/sway/`hostname`