aboutsummaryrefslogtreecommitdiff
path: root/.config
diff options
context:
space:
mode:
authoreug-vs <eug-vs@keemail.me>2020-12-07 11:31:00 +0300
committereug-vs <eug-vs@keemail.me>2020-12-07 11:31:00 +0300
commitc9db9689b28dbb746351cb97c22687bf75d26e0e (patch)
tree22460ee974b062155c39adf09c6cf697ab5131c5 /.config
downloaddotfiles-c9db9689b28dbb746351cb97c22687bf75d26e0e.tar.gz
feat: add initial dotfiles
Diffstat (limited to '.config')
-rw-r--r--.config/i3/config208
-rw-r--r--.config/i3/workspace.json64
-rw-r--r--.config/nvim/init.vim5
-rw-r--r--.config/nvim/vim-plug/plugins.vim8
4 files changed, 285 insertions, 0 deletions
diff --git a/.config/i3/config b/.config/i3/config
new file mode 100644
index 0000000..c06ea59
--- /dev/null
+++ b/.config/i3/config
@@ -0,0 +1,208 @@
+# i3 config file (v4)
+set $mod Mod4
+font pango:DejaVu Sans Mono 8
+
+# 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.
+exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork
+
+# 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.
+exec --no-startup-id nm-applet
+
+# Use pactl to adjust volume in PulseAudio and display it in Volnoti
+set $show_volume volnoti-show $(amixer get Master | grep -Po '[0-9]+(?=%)' | head -1)
+bindsym XF86AudioRaiseVolume exec --no-startup-id "pactl set-sink-volume @DEFAULT_SINK@ +5% && $show_volume"
+bindsym XF86AudioLowerVolume exec --no-startup-id "pactl set-sink-volume @DEFAULT_SINK@ -5% && $show_volume"
+bindsym XF86AudioMute exec --no-startup-id "pactl set-sink-mute @DEFAULT_SINK@ toggle && if amixer get Master | grep -Fq '[off]'; then volnoti-show -m; else $show_volume; fi"
+bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle
+
+# Screenshot via ImageMagick
+bindsym --release Shift+Print exec --no-startup-id import screenshot.png && xclip -selection clipboard -target image/png -i < screenshot.png && rm screenshot.png
+bindsym --release Print exec --no-startup-id import -window root screenshot.png && xclip -selection clipboard -target image/png -i < screenshot.png && rm screenshot.png
+
+# Use Mouse+$mod to drag floating windows to their wanted position
+floating_modifier $mod
+
+# start a terminal (default: i3-sensible-terminal)
+bindsym $mod+Return exec alacritty
+
+# kill focused window
+bindsym $mod+Shift+q kill
+
+# start dmenu (a program launcher)
+bindsym $mod+d exec rofi -show combi -theme gruvbox-dark-soft
+
+# change focus
+bindsym $mod+h focus left
+bindsym $mod+j focus down
+bindsym $mod+k focus up
+bindsym $mod+l focus right
+
+# 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
+
+# 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
+
+# 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
+
+# split in horizontal orientation (!) changed to g
+bindsym $mod+g split h
+
+# split in vertical orientation
+bindsym $mod+v split v
+
+# enter fullscreen mode for the focused container
+bindsym $mod+f fullscreen toggle
+
+# change container layout (stacked, tabbed, toggle split)
+bindsym $mod+s layout stacking
+bindsym $mod+w layout tabbed
+bindsym $mod+e layout toggle split
+
+# toggle tiling / floating
+bindsym $mod+Shift+space floating toggle
+
+# change focus between tiling / floating windows
+bindsym $mod+space focus mode_toggle
+
+# focus the parent container
+bindsym $mod+a focus parent
+
+# focus the child container
+#bindsym $mod+d 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"
+
+# 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
+
+# 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
+
+# reload the configuration file
+bindsym $mod+Shift+c reload
+# restart i3 inplace (preserves your layout/session, can be used to upgrade i3)
+bindsym $mod+Shift+r restart
+# exit i3 (logs you out of your X session)
+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'"
+
+# 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"
+}
+
+bindsym $mod+r mode "resize"
+
+# mic crazy bassboost mode
+set $default_volume 17000
+set $bass_volume 90000
+set $change_volume pacmd set-source-volume 1
+bindsym $mod+b mode "bassboost" exec $change_volume $bass_volume
+mode "bassboost" {
+ bindsym --release $mod+b mode "default" exec $change_volume $default_volume
+}
+
+
+# set primary gruvbox colorscheme colors
+set $bg #282828
+set $red #cc241d
+set $green #98971a
+set $yellow #d79921
+set $blue #458588
+set $purple #b16286
+set $aqua #689d68
+set $gray #a89984
+set $darkgray #1d2021
+
+# green gruvbox
+# class border|backgr|text|indicator|child_border
+client.focused $darkgray $yellow $darkgray $purple $darkgray
+client.focused_inactive $darkgray $darkgray $yellow $purple $darkgray
+client.unfocused $darkgray $darkgray $yellow $purple $darkgray
+client.urgent $red $red $white $red $red
+
+# i3gaps
+for_window [class=".*"] border pixel 0
+gaps inner 12
+
+# i3blocks
+bar {
+ status_command i3blocks -c ~/.config/i3blocks.conf
+ position top
+ colors {
+ focused_workspace $yellow $yellow #000000
+ active_workspace #333333 #333333 $purple
+ inactive_workspace #CECECE #333333 #f1f1f1
+ urgent_workspace #eb709b #eb709b #ffffff
+ }
+}
+
+exec volnoti
+exec hsetroot -cover ~/wallpaper.jpg
+exec redshift -P &
+exec picom -c -i 0.9 -D 0 &
+
diff --git a/.config/i3/workspace.json b/.config/i3/workspace.json
new file mode 100644
index 0000000..a58da53
--- /dev/null
+++ b/.config/i3/workspace.json
@@ -0,0 +1,64 @@
+{
+ "border": "normal",
+ "current_border_width": 2,
+ "floating": "auto_off",
+ "geometry": {
+ "height": 436,
+ "width": 724,
+ "x": 0,
+ "y": 0
+ },
+ "percent": 0.7,
+ "swallows": [
+ {
+ "title": "^nvim"
+ }
+ ],
+ "type": "con"
+}
+
+{
+ "border": "normal",
+ "floating": "auto_off",
+ "layout": "splitv",
+ "percent": 0.3,
+ "type": "con",
+ "nodes": [
+ {
+ "border": "normal",
+ "current_border_width": 2,
+ "floating": "auto_off",
+ "geometry": {
+ "height": 436,
+ "width": 724,
+ "x": 0,
+ "y": 0
+ },
+ "percent": 0.7,
+ "swallows": [
+ {
+ "title": "^primary-terminal"
+ }
+ ],
+ "type": "con"
+ },
+ {
+ "border": "normal",
+ "current_border_width": 2,
+ "floating": "auto_off",
+ "geometry": {
+ "height": 436,
+ "width": 724,
+ "x": 0,
+ "y": 0
+ },
+ "percent": 0.3,
+ "swallows": [
+ {
+ "title": "^secondary-terminal"
+ }
+ ],
+ "type": "con"
+ }
+ ]
+}
diff --git a/.config/nvim/init.vim b/.config/nvim/init.vim
new file mode 100644
index 0000000..b16b89f
--- /dev/null
+++ b/.config/nvim/init.vim
@@ -0,0 +1,5 @@
+set runtimepath^=~/.vim runtimepath+=~/.vim/after
+let &packpath = &runtimepath
+source ~/.config/nvim/vim-plug/plugins.vim
+source ~/.vimrc
+
diff --git a/.config/nvim/vim-plug/plugins.vim b/.config/nvim/vim-plug/plugins.vim
new file mode 100644
index 0000000..0663b4f
--- /dev/null
+++ b/.config/nvim/vim-plug/plugins.vim
@@ -0,0 +1,8 @@
+call plug#begin('~/.config/nvim/autoload/plugged')
+ Plug 'mhinz/vim-startify', {'branch': 'center'}
+ Plug 'vimwiki/vimwiki'
+ " Dark-powered file explorer
+ Plug 'shougo/defx.nvim',
+ Plug 'kristijanhusak/defx-icons'
+ Plug 't9md/vim-choosewin'
+call plug#end()