# Default config for sway
#
# Copy this to ~/.config/sway/config and edit it to your liking.
#
# Read `man 5 sway` for a complete reference.

### Variables
#
# Logo key. Use Mod1 for Alt.
set $mod Mod4
set $alt Mod1
# Home row direction keys, like vim
set $left h
set $down j
set $up k
set $right l
# Your preferred terminal emulator
set $term wezterm
# Your preferred application launcher
# 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 wofi -d -S drun
# set $menu rofi -show drun

include /etc/sway/config-vars.d/*

### 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
# output DP-2 {
# mode 1920x1080@143.855Hz
# pos 1360 0
# }
set $main DP-1
set $second HDMI-A-2
set $TV HDMI-A-4
output $second resolution 1360x768 pos 3130 100
output $TV {
mode 1360x768
disable
}
output $main {
mode 1920x1080@143.855Hz
pos 1210 100
}
focus output $main
output $second {
resolution 1280x1024 pos 0 0
transform 270
scale 0.85
}


#
# 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 * power off"' resume 'swaymsg "output * power 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.
#
# or input <identifier>
input "type:keyboard" {
	xkb_layout us-escape-grave,ara
	xkb_variant ,ergoarabic
	xkb_options grp:alt_shift_toggle,compose:ralt,caps:escape
}
input "type:tablet_tool" {
	map_to_output DP-1
	left_handed enable
}
#-layout us,ara -variant ,ergoarabic -option "compose:ralt"  -option "caps:escape" -option "grp:alt_shift_toggle"
}
default_border pixel 3
default_floating_border pixel 2
font Miracode 10
titlebar_padding 1
titlebar_border_thickness 1
for_window [title=".*"] title_format "%title"
### Key bindings
#
# Basics:
#
	# Start a terminal
	bindsym $mod+Return exec $term

	# Kill focused window
	bindsym $mod+Shift+q kill

	# Start your launcher
	bindsym $mod+d exec $menu

	# 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

	# Reload the configuration file
	bindsym $mod+Shift+c reload

	# Exit sway (logs you out of your Wayland session)
	bindsym $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'
#
# Moving around:
#
	# Move your focus around
	bindsym $mod+$left focus left
	bindsym $mod+$down focus down
	bindsym $mod+$up focus up
	bindsym $mod+$right focus right
	# Or use $mod+[up|down|left|right]
	bindsym $mod+Left focus left
	bindsym $mod+Down focus down
	bindsym $mod+Up focus up
	bindsym $mod+Right focus right

	# Move the focused window with the same, but add Shift
	bindsym $mod+Shift+$left move left
	bindsym $mod+Shift+$down move down
	bindsym $mod+Shift+$up move up
	bindsym $mod+Shift+$right move right
	# Ditto, with arrow 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
#
# Workspaces:
#
# 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 $Terminal "1"
set $Browsers "2"
set $Code "3"
set $IRC "4"
set $Media "5"
set $Reading "6"
set $Youtube "7"
set $Steam "8"
set $Vm "9"
set $Mail "10"
set $Game "11"
set $Notes "12"



# switch to workspace
bindsym $mod+1 workspace number $Terminal
bindsym $mod+2 workspace number $Browsers
bindsym $mod+3 workspace number $Code
bindsym $mod+4 workspace number $IRC
bindsym $mod+5 workspace number $Media
bindsym $mod+6 workspace number $Reading
bindsym $mod+7 workspace number $Youtube
bindsym $mod+8 workspace number $Steam
bindsym $mod+9 workspace number $Vm
bindsym $mod+0 workspace number $Mail
bindsym $mod+g workspace number $Game
bindsym $mod+c workspace number $Notes

# move focused container to workspace
bindsym $mod+Shift+1 move container to workspace number $Terminal
bindsym $mod+Shift+2 move container to workspace number $Browsers
bindsym $mod+Shift+3 move container to workspace number $Code
bindsym $mod+Shift+4 move container to workspace number $IRC
bindsym $mod+Shift+5 move container to workspace number $Media
bindsym $mod+Shift+6 move container to workspace number $Reading
bindsym $mod+Shift+7 move container to workspace number $Youtube
bindsym $mod+Shift+8 move container to workspace number $Steam
bindsym $mod+Shift+9 move container to workspace number $Vm
bindsym $mod+Shift+0 move container to workspace number $Mail
bindsym $mod+Shift+minus move container to workspace number $Notes
bindsym $mod+Shift+g move container to workspace number $Game
#
# Layout stuff:
#
	# You can "split" the current object of your focus with
	# $mod+b or $mod+v, for horizontal and vertical splits
	# respectively.
	bindsym $mod+b splith
	bindsym $mod+v splitv

	# Switch the current container between different layout styles
	bindsym $mod+s layout stacking
	bindsym $mod+w layout tabbed
	bindsym $mod+e layout toggle split

	# Make the current focus fullscreen
	bindsym $mod+f fullscreen

	# Toggle the current focus between tiling and floating mode
	bindsym $mod+Shift+space floating toggle

	# Swap focus between the tiling area and the floating area
	bindsym $mod+space focus mode_toggle

	# Move focus to the parent container
	bindsym $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 $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
#
# 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 $left resize shrink width 10px
	bindsym $down resize grow height 10px
	bindsym $up resize shrink height 10px
	bindsym $right resize grow width 10px

	# Ditto, with arrow keys
	bindsym Left resize shrink width 10px
	bindsym Down resize grow height 10px
	bindsym Up resize shrink height 10px
	bindsym Right resize grow width 10px

	# Return to default mode
	bindsym Return mode "default"
	bindsym Escape mode "default"
}
bindsym $mod+r mode "resize"


# set $mode_system "What to do? (l) lock, (e) logout, (r) reboot, (s) suspend, (Shift+s) shutdown"
# mode $mode_system {
# 	 bindsym l exec $screenlock; mode "default"
# 	 bindsym e exec i3-msg exit; mode "default"
# 	 bindsym r exec systemctl reboot; mode "default"
# 	 bindsym s exec systemctl suspend; mode "default"
# 	 bindsym Shift+s exec systemctl poweroff; mode "default"

# back to normal: Enter or Escape
#   bindsym Return mode "default"
#   bindsym Escape mode "default"
# }
# unbindsym $mod+Shift+e
# bindsym $mod+Shift+e mode $mode_system
#
# 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 i3status

# 	colors {
# 		# Whole color settings
# 		background #3c3836
# 		statusline #ebdbb2
# 		separator  #666666


# 		focused_workspace  #458588 #458588 #ebdbb2
# 		active_workspace   #83a598 #83a598 #ebdbb2
# 		inactive_workspace #504945 #504945 #ebdbb2
# 		urgent_workspace   #cc241d #cc241d #504945
# 	}
# }

include $HOME/.config/sway/config.d/*
# for_window [class=".*"] border pixel 2
