################################################
#                                              #
#   Uni3valent's Configuration File.           #
#   Make a habit to read this file. You will   #
#   find keybindings and various other         #
#   settings here. Please see                  #
#                                              #
#       https://i3wm.org/docs/userguide.html   #
#                                              #
#   for a complete reference on moving forward #
#   from what I have provided here.            #
#                                              #
################################################



# This is our mod Key. Currently it is set to the Windows Key.
# You can uncomment the line below to set 'Alt' key as the mod key.
#set $mod Mod1
set $mod Mod4

# Font for window titles. Will also be used by the bar.
font pango:IPAPGothic 15

# 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

# start a terminal. We use LXTerm.
bindsym $mod+Return exec i3-sensible-terminal
bindsym Mod1+Control+t exec i3-sensible-terminal

# kill focused window
bindsym $mod+Shift+q kill
bindsym Mod1+F4 kill

# Launch PCManFM-Qt
bindsym $mod+t exec pcmanfm-qt

# start dmenu (a program launcher).
# bindsym $mod+d exec --no-startup-id dmenu_run
# A more modern dmenu replacement is rofi:
# You have 2 options to launch rofi:
# This mode search for .desktop files in /usr/share/applications.
# This is the recommended mode. It searches for the programs as
# defined in .desktop file, with their description, and corresponding
# icons
bindsym $mod+d exec --no-startup-id TERMINAL=xfce4-terminal rofi -show drun -theme Monokai -icon-theme "Oxygen" -show-icons

# The other mode search for applications in /usr/bin or /usr/sbin.
# This should only be used if a program lacks a .desktop file.
bindsym $mod+Shift+d exec --no-startup-id rofi -show run -theme Monokai

# Launch Polybar. Take a look at ~/.confi/polybar/config to
# configure the bar.
exec_always --no-startup-id $HOME/.config/polybar/launch.sh

# Launch cbatticon
exec_always --no-startup-id cbatticon

# Launch clipman
exec_always --no-startup-id xfce4-clipman

# Display Wallpaper, always.
exec_always feh --bg-fill /usr/share/backgrounds/univalent/univalent-wall-blue.png

# Launch Udiskie
exec_always --no-startup-id udiskie -t

# Launch Pamac tray
exec_always --no-startup-id pamac-tray

# Launch Dunst. The config file is ~/.config/dunst/dunstrc
exec_always --no-startup-id dunst

# Launch Fcitx5
exec_always --no-startup-id fcitx5

# Launch volumeicon
exec_always --no-startup-id volumeicon

# Open shortcuts list
bindsym $mod+c exec --no-startup-id xdg-open ~/.config/i3/shortcuts.list

# Provide Gaps to Windows. Increase/Decrease as you like.
gaps inner 10

#Compositor. This helps in transparency and fading.
exec_always picom -f

# Lock Screen This will yield a black lock screen, which
# can be customized to your liking.
bindsym $mod+x exec dm-tool lock

# Shutdown the computer
bindsym $mod+Shift+s exec shutdown now

#Reboot Machine
bindsym $mod+Mod1+r exec systemctl reboot

# Suspend the system to RAM (needs swap space)
bindsym $mod+Mod1+s exec systemctl suspend

# take a screenshot
bindsym Print exec --no-startup-id screengrab

# Exec univalent-tools with terminal emulator
bindsym $mod+u exec i3-sensible-terminal -e univalent-tools

# The combination of xss-lock, nm-applet and pactl is a popular choice, so
# they are included here as an example. Modify as you see fit.

# xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the
# screen before suspend. Use loginctl lock-session to lock your screen.

# The 4 lines of text above come from i3 documentation. Waking up from a suspended
# system will launch betterlockscreen
exec --no-startup-id xss-lock --transfer-sleep-lock -- betterlockscreen -l

# NetworkManager is the most popular way to manage wireless networks on Linux,
# and nm-applet is a desktop environment-independent system tray GUI for it.
# We use this. System dark theme is applied to it.
exec --no-startup-id nm-applet

# Use pactl to adjust volume in PulseAudio.
# These are examples if you would like to use pactl. We will not use this,
# but rather alsamixer.
#set $refresh_i3status killall -SIGUSR1 i3status
#bindsym XF86AudioRaiseVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ +5% && $refresh_i3status
#bindsym XF86AudioLowerVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ -5% && $refresh_i3status
#bindsym XF86AudioMute exec --no-startup-id pactl set-sink-mute @DEFAULT_SINK@ toggle && $refresh_i3status
#bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle && $refresh_i3status

#Volume Control in UVGL i3wm
bindsym XF86AudioRaiseVolume exec amixer -q set Master 5%+ unmute
bindsym XF86AudioLowerVolume exec amixer -q set Master 5%- unmute
bindsym XF86AudioMute exec amixer -q set Master toggle

##Brightness Control in UVGL i3wm
bindsym XF86MonBrightnessUp exec sudo xbacklight -inc 10
bindsym XF86MonBrightnessDown exec sudo xbacklight -dec 10

# Use Mouse+$mod to drag floating windows to their wanted position
floating_modifier $mod

# The keybindings starting from here till the end of the document are
# used for navigation in the window manager

# 1A] change focus
bindsym $mod+h focus left
bindsym $mod+j focus down
bindsym $mod+k focus up
bindsym $mod+l focus right

# 1B] 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

# 2A] move focused window
bindsym $mod+Shift+h move left
bindsym $mod+Shift+j move down
bindsym $mod+Shift+k move up
bindsym $mod+Shift+l move right

# 2B] 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

# 3] split in horizontal orientation
bindsym $mod+g split h

# 4] split in vertical orientation
bindsym $mod+v split v

# 5] enter fullscreen mode for the focused container
bindsym $mod+f fullscreen toggle

# 6] change container layout (stacked, tabbed, toggle split)
bindsym $mod+s layout stacking
bindsym $mod+w layout tabbed
bindsym $mod+e layout toggle split

# 7] toggle tiling / floating
bindsym $mod+Shift+space floating toggle

# 8] change focus between tiling / floating windows
bindsym $mod+space focus mode_toggle

# 9A] focus the parent container
bindsym $mod+a focus parent

# 9B] focus the child container
#bindsym $your_keybinding focus child

# 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"

# 10] switch to workspace
bindsym $mod+1 workspace number $ws1
bindsym $mod+2 workspace number $ws2
bindsym $mod+3 workspace number $ws3
bindsym $mod+4 workspace number $ws4
bindsym $mod+5 workspace number $ws5
bindsym $mod+6 workspace number $ws6
bindsym $mod+7 workspace number $ws7
bindsym $mod+8 workspace number $ws8
bindsym $mod+9 workspace number $ws9
bindsym $mod+0 workspace number $ws10

# 11] move focused container to workspace
bindsym $mod+Shift+1 move container to workspace number $ws1
bindsym $mod+Shift+2 move container to workspace number $ws2
bindsym $mod+Shift+3 move container to workspace number $ws3
bindsym $mod+Shift+4 move container to workspace number $ws4
bindsym $mod+Shift+5 move container to workspace number $ws5
bindsym $mod+Shift+6 move container to workspace number $ws6
bindsym $mod+Shift+7 move container to workspace number $ws7
bindsym $mod+Shift+8 move container to workspace number $ws8
bindsym $mod+Shift+9 move container to workspace number $ws9
bindsym $mod+Shift+0 move container to workspace number $ws10
bindsym $mod+Prior workspace prev
bindsym $mod+Next workspace next

# 12A] reload the configuration file
bindsym $mod+Shift+c reload
# 12B] restart i3 inplace (preserves your layout/session, can be used to upgrade i3)
bindsym $mod+Shift+r restart
# 12C] exit i3 (logs you out of your X session)
bindsym $mod+Shift+e exec "i3-nagbar -t warning -m 'Do you really want to exit i3?' -b 'Log out' 'i3-msg exit' -b 'Shut down' 'shutdown -h now' -b 'Reboot' 'reboot'"

# 13A] 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 h resize shrink width 10 px or 10 ppt
        bindsym j resize grow height 10 px or 10 ppt
        bindsym k resize shrink height 10 px or 10 ppt
        bindsym l 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"
}


# 13B] Enter Resize Mode
bindsym $mod+r mode "resize"

# Start i3bar to display a workspace bar (plus the system information i3status
# finds out, if available). Commented out due to use of polybar. If you want to
# use i3 bars (status or blocks) this are some examples on how you can do it.
# bar {
        #status_command i3status
        #tray_output primary
        #status_command i3status -c ~/.config/i3/i3status.conf
        #status_command i3blocks -c ~/.config/i3/i3blocks.conf
#}

# The following way allows programs to be launched with a
# defined keybinding, on a certain workspace, without
# touching program launcher. Assign Programs to respective
# workspaces.
bindsym $mod+b exec xdg-open https://google.com/


#Multi Monitor (Dual Monitor, extended monitor)
#Replace HDMI2 with DVI-2, VGA-2, DP-2, DVI-2 etc. Get value by typing xrandr in the terminal.
#If X is a natural number, then;
#eDP-X is the display used in Laptops.
#HDMI-X is display used in Desktop connected to monitor with HDMI Cable.
#VGA-X is display used in Desktop connected to monitor with VGA Cable.
exec --no-startup-id xrandr --output HDMI-2 --right-of HDMI-1 --auto
