From 1b55d91ce168a7948204abad56fd5a51ef2f5028 Mon Sep 17 00:00:00 2001 From: eneller Date: Sun, 9 Jul 2023 04:07:30 +0200 Subject: [PATCH] Initial commit --- .config/alacritty/alacritty.yml | 36 + .config/autorandr/default/config | 25 + .config/autorandr/default/setup | 1 + .config/autorandr/home_dock/config | 40 + .config/autorandr/home_dock/setup | 3 + .config/autorandr/home_setup/config | 34 + .config/autorandr/home_setup/setup | 2 + .config/autorandr/u_setup/config | 28 + .config/autorandr/u_setup/setup | 2 + .config/dict/dictrc | 9 + .config/dunst/dunstrc | 302 +++ .config/i3/bg.png | Bin 0 -> 110868 bytes .config/i3/conf.d/theme | 46 + .config/i3/config | 159 ++ .config/i3/i3status.conf | 1 + .config/nvim/colors/molokai.vim | 276 +++ .config/nvim/colors/monokai.vim | 109 ++ .config/nvim/ftplugin/python.lua | 0 .config/nvim/init.lua | 43 + .config/nvim/lua/keybinds.lua | 13 + .config/nvim/lua/plugins.lua | 32 + .config/picom.conf | 271 +++ .config/rofi/config.rasi | 173 ++ .config/shell/alias.sh | 58 + .config/tmux/tmux.conf | 29 + .config/zsh/.zshrc | 162 ++ .config/zsh/p10k.zsh | 1643 +++++++++++++++++ .local/bin/displayselect | 85 + .local/bin/dmenumount | 69 + .local/bin/dmenurecord | 125 ++ .local/bin/dmenuumount | 46 + .../applications/firefox-profiles.desktop | 8 + .../applications/thunderbird-profiles.desktop | 8 + .../applications/userapp-Telegram.desktop | 8 + .../applications/userapp-Thunderbird.desktop | 8 + .profile | 46 + 36 files changed, 3900 insertions(+) create mode 100644 .config/alacritty/alacritty.yml create mode 100644 .config/autorandr/default/config create mode 100644 .config/autorandr/default/setup create mode 100644 .config/autorandr/home_dock/config create mode 100644 .config/autorandr/home_dock/setup create mode 100644 .config/autorandr/home_setup/config create mode 100644 .config/autorandr/home_setup/setup create mode 100644 .config/autorandr/u_setup/config create mode 100644 .config/autorandr/u_setup/setup create mode 100644 .config/dict/dictrc create mode 100644 .config/dunst/dunstrc create mode 100644 .config/i3/bg.png create mode 100644 .config/i3/conf.d/theme create mode 100644 .config/i3/config create mode 100644 .config/i3/i3status.conf create mode 100644 .config/nvim/colors/molokai.vim create mode 100644 .config/nvim/colors/monokai.vim create mode 100644 .config/nvim/ftplugin/python.lua create mode 100644 .config/nvim/init.lua create mode 100644 .config/nvim/lua/keybinds.lua create mode 100644 .config/nvim/lua/plugins.lua create mode 100644 .config/picom.conf create mode 100644 .config/rofi/config.rasi create mode 100644 .config/shell/alias.sh create mode 100644 .config/tmux/tmux.conf create mode 100644 .config/zsh/.zshrc create mode 100644 .config/zsh/p10k.zsh create mode 100755 .local/bin/displayselect create mode 100755 .local/bin/dmenumount create mode 100755 .local/bin/dmenurecord create mode 100755 .local/bin/dmenuumount create mode 100644 .local/share/applications/firefox-profiles.desktop create mode 100644 .local/share/applications/thunderbird-profiles.desktop create mode 100644 .local/share/applications/userapp-Telegram.desktop create mode 100644 .local/share/applications/userapp-Thunderbird.desktop create mode 100644 .profile diff --git a/.config/alacritty/alacritty.yml b/.config/alacritty/alacritty.yml new file mode 100644 index 0000000..336bae2 --- /dev/null +++ b/.config/alacritty/alacritty.yml @@ -0,0 +1,36 @@ +env: + TERM: xterm-256color +window: + padding: + x: 5 + y: 7 + opacity: 1.0 + dynamic_title: true + +colors: + # Default colors + primary: + background: '0x272822' + foreground: '0xf8f8f2' + + # Normal colors + normal: + black: '0x272822' + red: '0xf92672' + green: '0xa6e22e' + yellow: '0xf4bf75' + blue: '0x66d9ef' + magenta: '0xae81ff' + cyan: '0xa1efe4' + white: '0xf8f8f2' + + # Bright colors + bright: + black: '0x75715e' + red: '0xf92672' + green: '0xa6e22e' + yellow: '0xf4bf75' + blue: '0x66d9ef' + magenta: '0xae81ff' + cyan: '0xa1efe4' + white: '0xf9f8f5' diff --git a/.config/autorandr/default/config b/.config/autorandr/default/config new file mode 100644 index 0000000..259589e --- /dev/null +++ b/.config/autorandr/default/config @@ -0,0 +1,25 @@ +output DP-1 +off +output HDMI-1 +off +output DP-2 +off +output HDMI-2 +off +output DP-2-1 +off +output DP-2-2 +off +output DP-2-3 +off +output eDP-1 +crtc 0 +mode 1920x1080 +pos 0x0 +primary +rate 60.02 +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 +x-prop-scaling_mode Full aspect diff --git a/.config/autorandr/default/setup b/.config/autorandr/default/setup new file mode 100644 index 0000000..d2e0e09 --- /dev/null +++ b/.config/autorandr/default/setup @@ -0,0 +1 @@ +eDP-1 00ffffffffffff0030e4080600000000001c0104a51f117802e085a3544e9b260e5054000000010101010101010101010101010101012e3680a070381f403020350035ae1000001a542b80a070381f403020350035ae1000001a000000fe004c4720446973706c61790a2020000000fe004c503134305746392d5350463100d5 diff --git a/.config/autorandr/home_dock/config b/.config/autorandr/home_dock/config new file mode 100644 index 0000000..5193960 --- /dev/null +++ b/.config/autorandr/home_dock/config @@ -0,0 +1,40 @@ +output HDMI-1 +off +output DP-2 +off +output HDMI-2 +off +output DP-2-1 +off +output DP-2-2 +off +output eDP-1 +crtc 0 +mode 1920x1080 +pos 0x0 +primary +rate 60.02 +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 +x-prop-scaling_mode Full aspect +output DP-2-3 +crtc 2 +mode 1920x1080 +pos 1920x0 +rate 60.00 +x-prop-audio auto +x-prop-broadcast_rgb Automatic +x-prop-max_bpc 12 +x-prop-non_desktop 0 +output DP-1 +crtc 1 +mode 1920x1080 +pos 3837x0 +rate 60.00 +x-prop-audio auto +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 diff --git a/.config/autorandr/home_dock/setup b/.config/autorandr/home_dock/setup new file mode 100644 index 0000000..a17b6c0 --- /dev/null +++ b/.config/autorandr/home_dock/setup @@ -0,0 +1,3 @@ +DP-1 00ffffffffffff001ab3bf0814600b000b200104a5351e78220565a756529c270f5054a54a00818f81809500b30081c0a9c001010101023a801871382d40582c45000f282100001e000000fd00304c1e5211000a202020202020000000fc004232342d392054530a20202020000000ff00595644433734353439320a20200006 +DP-2-3 00ffffffffffff001ab3c10813fb0a001a1f0104a5351e783a0565a756529c270f5054a54a00818f81809500b30081c0a9c001010101023a801871382d40582c45000f282100001e000000fd00304c1e5211000a202020202020000000fc004232342d392054530a20202020000000ff00595644433731393633350a2020014402031cf14f901f051404031201021113071516062309070783010000023a801871382d40582c45000f282100001e023a80d072382d40102c96800f2821000018011d007251d01e206e2855000f282100001e011d00bc52d01e20b82855400f282100001e8c0ad090204031200c4055000f2821000018000000000000000000e6 +eDP-1 00ffffffffffff0030e4080600000000001c0104a51f117802e085a3544e9b260e5054000000010101010101010101010101010101012e3680a070381f403020350035ae1000001a542b80a070381f403020350035ae1000001a000000fe004c4720446973706c61790a2020000000fe004c503134305746392d5350463100d5 diff --git a/.config/autorandr/home_setup/config b/.config/autorandr/home_setup/config new file mode 100644 index 0000000..f5cc11b --- /dev/null +++ b/.config/autorandr/home_setup/config @@ -0,0 +1,34 @@ +output DP-1 +off +output HDMI-1 +off +output DP-2 +off +output DP-2-1 +off +output DP-2-2 +off +output DP-2-3 +off +output eDP-1 +crtc 0 +mode 1920x1080 +pos 0x0 +primary +rate 60.02 +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 +x-prop-scaling_mode Full aspect +output HDMI-2 +crtc 1 +mode 2560x1440 +pos 1920x0 +rate 59.95 +x-prop-aspect_ratio Automatic +x-prop-audio auto +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 diff --git a/.config/autorandr/home_setup/setup b/.config/autorandr/home_setup/setup new file mode 100644 index 0000000..e3a5f7a --- /dev/null +++ b/.config/autorandr/home_setup/setup @@ -0,0 +1,2 @@ +HDMI-2 00ffffffffffff0010ac5f4157563541281d0103803c2278eeee95a3544c99260f5054a54b00714f8180a940d1c00101010101010101565e00a0a0a029503020350055502100001a000000ff00335a53465253320a2020202020000000fc0044454c4c205532373139440a20000000fd00384c1e5a19000a20202020202001c7020322f14f90050403020716010611121513141f23097f078301000065030c001000023a801871382d40582c450055502100001e7e3900a080381f4030203a0055502100001a011d007251d01e206e28550055502100001ebf1600a08038134030203a0055502100001a00000000000000000000000000000000000000000088 +eDP-1 00ffffffffffff0030e4080600000000001c0104a51f117802e085a3544e9b260e5054000000010101010101010101010101010101012e3680a070381f403020350035ae1000001a542b80a070381f403020350035ae1000001a000000fe004c4720446973706c61790a2020000000fe004c503134305746392d5350463100d5 diff --git a/.config/autorandr/u_setup/config b/.config/autorandr/u_setup/config new file mode 100644 index 0000000..39f99f5 --- /dev/null +++ b/.config/autorandr/u_setup/config @@ -0,0 +1,28 @@ +output DP-1 +off +output HDMI-1 +off +output DP-2 +off +output eDP-1 +crtc 0 +mode 1920x1080 +pos 0x0 +primary +rate 60.02 +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 +x-prop-scaling_mode Full aspect +output HDMI-2 +crtc 1 +mode 2560x1440 +pos 1920x0 +rate 59.95 +x-prop-aspect_ratio Automatic +x-prop-audio auto +x-prop-broadcast_rgb Automatic +x-prop-colorspace Default +x-prop-max_bpc 12 +x-prop-non_desktop 0 diff --git a/.config/autorandr/u_setup/setup b/.config/autorandr/u_setup/setup new file mode 100644 index 0000000..ce520fd --- /dev/null +++ b/.config/autorandr/u_setup/setup @@ -0,0 +1,2 @@ +HDMI-2 00ffffffffffff0010ac56a04c32383013160103803c2278ea8e05ad4f33b0260d5054a54b008100b300714fa9408180010101010101023a801871382d40582c250055502100001e000000ff0047363036543235433038324c0a000000fc0044454c4c2055323731310a2020000000fd00384c1e5111000a202020202020012a020329f15090050403020716010611121513141f20230d7f0767030c001000382d830f0000e3050301023a801871382d40582c250055502100001e011d8018711c1620582c250055502100009e011d007251d01e206e28550055502100001e8c0ad08a20e02d10103e9600555021000018000000000000000000000000000068 +eDP-1 00ffffffffffff0030e4080600000000001c0104a51f117802e085a3544e9b260e5054000000010101010101010101010101010101012e3680a070381f403020350035ae1000001a542b80a070381f403020350035ae1000001a000000fe004c4720446973706c61790a2020000000fe004c503134305746392d5350463100d5 diff --git a/.config/dict/dictrc b/.config/dict/dictrc new file mode 100644 index 0000000..014cdcd --- /dev/null +++ b/.config/dict/dictrc @@ -0,0 +1,9 @@ +# This is the configuration file for dict. +# Usually all you will ever need here is the server keywords. +# Refer to the dict manpage for other options. +# It will only check the second server if the first fails +# localhost uses the dictd service. Configure it to use your local dictionaries. +# see: freedict, /etc/dict/dict.conf, /usr/share/dictd +server localhost +server dict.org + diff --git a/.config/dunst/dunstrc b/.config/dunst/dunstrc new file mode 100644 index 0000000..c2d242e --- /dev/null +++ b/.config/dunst/dunstrc @@ -0,0 +1,302 @@ +[global] + frame_width = 1 + frame_color = "#788388" + + font = Noto Sans 10 + + # Allow a small subset of html markup: + # bold + # italic + # strikethrough + # underline + # + # For a complete reference see + # . + # If markup is not allowed, those tags will be stripped out of the + # message. + markup = yes + + # The format of the message. Possible variables are: + # %a appname + # %s summary + # %b body + # %i iconname (including its path) + # %I iconname (without its path) + # %p progress value if set ([ 0%] to [100%]) or nothing + # Markup is allowed + format = "%s %p\n%b" + + # Sort messages by urgency. + sort = yes + + # Show how many messages are currently hidden (because of geometry). + indicate_hidden = yes + + # Alignment of message text. + # Possible values are "left", "center" and "right". + alignment = left + + # The frequency with wich text that is longer than the notification + # window allows bounces back and forth. + # This option conflicts with "word_wrap". + # Set to 0 to disable. + bounce_freq = 5 + + + # Show age of message if message is older than show_age_threshold + # seconds. + # Set to -1 to disable. + show_age_threshold = 60 + + # Split notifications into multiple lines if they don't fit into + # geometry. + word_wrap = no + + # Ignore newlines '\n' in notifications. + ignore_newline = no + + + # The geometry of the window: + # [{width}]x{height}[+/-{x}+/-{y}] + # The geometry of the message window. + # The height is measured in number of notifications everything else + # in pixels. If the width is omitted but the height is given + # ("-geometry x2"), the message window expands over the whole screen + # (dmenu-like). If width is 0, the window expands to the longest + # message displayed. A positive x is measured from the left, a + # negative from the right side of the screen. Y is measured from + # the top and down respectevly. + # The width can be negative. In this case the actual width is the + # screen width minus the width defined in within the geometry option. + geometry = "0x4-25+25" + + # Shrink window if it's smaller than the width. Will be ignored if + # width is 0. + shrink = yes + + # The transparency of the window. Range: [0; 100]. + # This option will only work if a compositing windowmanager is + # present (e.g. xcompmgr, compiz, etc.). + transparency = 15 + + # Don't remove messages, if the user is idle (no mouse or keyboard input) + # for longer than idle_threshold seconds. + # Set to 0 to disable. + # default 120 + idle_threshold = 120 + + # Which monitor should the notifications be displayed on. + monitor = 0 + + # Display notification on focused monitor. Possible modes are: + # mouse: follow mouse pointer + # keyboard: follow window with keyboard focus + # none: don't follow anything + # + # "keyboard" needs a windowmanager that exports the + # _NET_ACTIVE_WINDOW property. + # This should be the case for almost all modern windowmanagers. + # + # If this option is set to mouse or keyboard, the monitor option + # will be ignored. + follow = mouse + + # Should a notification popped up from history be sticky or timeout + # as if it would normally do. + sticky_history = yes + + # Maximum amount of notifications kept in history + history_length = 20 + + # Display indicators for URLs (U) and actions (A). + show_indicators = yes + + # The height of a single line. If the height is smaller than the + # font height, it will get raised to the font height. + # This adds empty space above and under the text. + line_height = 0 + + # Draw a line of "separator_height" pixel height between two + # notifications. + # Set to 0 to disable. + separator_height = 1 + + # Padding between text and separator. + # padding = 8 + padding = 8 + + # Horizontal padding. + horizontal_padding = 10 + + # Define a color for the separator. + # possible values are: + # * auto: dunst tries to find a color fitting to the background; + # * foreground: use the same color as the foreground; + # * frame: use the same color as the frame; + # * anything else will be interpreted as a X color. + separator_color = #263238 + + # Print a notification on startup. + # This is mainly for error detection, since dbus (re-)starts dunst + # automatically after a crash. + startup_notification = false + + # dmenu path. + dmenu = /usr/bin/dmenu -p dunst: + + # Browser for opening urls in context menu. + browser = palemoon + + # Align icons left/right/off + icon_position = left + + # Paths to default icons. + icon_path = /usr/share/icons/Adwaita/16x16/status/:/usr/share/icons/Adwaita/16x16/devices/ + + # Limit icons size. + max_icon_size=128 + +[shortcuts] + + # Shortcuts are specified as [modifier+][modifier+]...key + # Available modifiers are "ctrl", "mod1" (the alt-key), "mod2", + # "mod3" and "mod4" (windows-key). + # Xev might be helpful to find names for keys. + + # Close notification. + close = mod1+space + + # Close all notifications. + # close_all = ctrl+shift+space + close_all = ctrl+mod1+space + + # Redisplay last message(s). + # On the US keyboard layout "grave" is normally above TAB and left + # of "1". + history = ctrl+mod4+h + + # Context menu. + context = ctrl+mod1+c + +[urgency_low] + # IMPORTANT: colors have to be defined in quotation marks. + # Otherwise the "#" and following would be interpreted as a comment. + background = "#263238" + foreground = "#556064" + timeout = 10 + +[urgency_normal] + background = "#263238" + foreground = "#F9FAF9" + timeout = 10 + +[urgency_critical] + background = "#D62929" + foreground = "#F9FAF9" + timeout = 0 + + +# Every section that isn't one of the above is interpreted as a rules to +# override settings for certain messages. +# Messages can be matched by "appname", "summary", "body", "icon", "category", +# "msg_urgency" and you can override the "timeout", "urgency", "foreground", +# "background", "new_icon" and "format". +# Shell-like globbing will get expanded. +# +# SCRIPTING +# You can specify a script that gets run when the rule matches by +# setting the "script" option. +# The script will be called as follows: +# script appname summary body icon urgency +# where urgency can be "LOW", "NORMAL" or "CRITICAL". +# +# NOTE: if you don't want a notification to be displayed, set the format +# to "". +# NOTE: It might be helpful to run dunst -print in a terminal in order +# to find fitting options for rules. + +#[espeak] +# summary = "*" +# script = dunst_espeak.sh + +#[script-test] +# summary = "*script*" +# script = dunst_test.sh + +#[ignore] +# # This notification will not be displayed +# summary = "foobar" +# format = "" + +#[signed_on] +# appname = Pidgin +# summary = "*signed on*" +# urgency = low +# +#[signed_off] +# appname = Pidgin +# summary = *signed off* +# urgency = low +# +#[says] +# appname = Pidgin +# summary = *says* +# urgency = critical +# +#[twitter] +# appname = Pidgin +# summary = *twitter.com* +# urgency = normal +# +#[Claws Mail] +# appname = claws-mail +# category = email.arrived +# urgency = normal +# background = "#2F899E" +# foreground = "#FFA247" +# +#[mute.sh] +# appname = mute +# category = mute.sound +# script = mute.sh +# +#[JDownloader] +# appname = JDownloader +# category = JD +# background = "#FFA247" +# foreground = "#FFFFFF" +# +#[newsbeuter] +# summary = *Feeds* +# background = "#A8EB41" +# foreground = "#FFFFFF" +# +[irc] + appname = weechat + timeout = 0 + background = "#0033bb" + foreground = "#dddddd" +# +[weechat hl] + appname = weechat + category = weechat.HL + background = "#FF5C47" + foreground = "#FFFFFF" +# +[weechat pn] + appname = weechat + category = weechat.PM + background = "#D53B84" + foreground = "#FFFFFF" +# +#[CMUS] +# appname = CMUS +# category = cmus +# background = "#6C4AB7" +# foreground = "#FFE756" +# +# +# background = "#30AB70" +# foreground = "#F67245" +# +# vim: ft=cfg diff --git a/.config/i3/bg.png b/.config/i3/bg.png new file mode 100644 index 0000000000000000000000000000000000000000..a668cc67b6575539de29a8547e33376f191c5668 GIT binary patch literal 110868 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 literal 0 HcmV?d00001 diff --git a/.config/i3/conf.d/theme b/.config/i3/conf.d/theme new file mode 100644 index 0000000..f7a22ec --- /dev/null +++ b/.config/i3/conf.d/theme @@ -0,0 +1,46 @@ +# vim: filetype=i3config + +font pango:Sans Regular 12 +# THEME, should use same colors as .profile +set $black #272822 +set $white #FFFFFF +set $red #F92672 +set $blue #66D9EF +set $green #A6E22E +set $orange #FD971F +set $yellow #E6DB74 +set $purple #AE81FF + +set $allblack #000000 + +# class border bg. text indicator child_border +client.focused $blue $black $blue $blue $blue +client.focused_inactive $black $black $blue $black $black +client.unfocused $black $black $white $black $black +client.background $black + + +bar { + i3bar_command i3bar + status_command i3status +#--config $XDG_CONFIG_HOME/i3/i3status.conf + mode dock + position top + #tray_output primary +# font xft:Jetbrains mono 20 + strip_workspace_numbers yes + workspace_buttons yes + + colors { + background #000000 + #statusline #F9FAF9 + #separator #454947 + # border bg text + focused_workspace $allblack $blue $allblack + #active_workspace #FFFFFF $black #FFFFFF + #inactive_workspace #FFFFFF $black #FFFFFF + #binding_mode #16a085 #2C2C2C #F9FAF9 + urgent_workspace $red $black $red + } +} + diff --git a/.config/i3/config b/.config/i3/config new file mode 100644 index 0000000..749ceee --- /dev/null +++ b/.config/i3/config @@ -0,0 +1,159 @@ +# vim: filetype=i3config +include ~/.config/i3/conf.d/* + +# this config is based on github.com:LukeSmithxyz/voidrice 884dcbdc4792eed95e558af84491eb3100d314a2 +# to immediately apply a new config, run `i3-msg reload; i3-msg restart` + +# This config file will use environmental variables such as $BROWSER and $TERMINAL. +# You can set these variables in ~/.profile or ~/.bash_profile if you have it as below: + + +# No focus on mouse over (allows scrolling without changing focus) +focus_follows_mouse no +# remove title bar +default_border pixel 1 +default_floating_border pixel 1 +# set modifier key, Mod4 is super (windows), Mod1 = Alt key +set $mod Mod4 +bindsym $mod+F12 restart;reload +bindsym $mod+Escape exec i3lock -c 000000 & sleep 2 && systemctl suspend +bindsym $mod+Shift+Escape exec i3lock -c 000000 & sleep 2 && xset dpms force off + + +# Use Mouse+$mod to drag floating windows to their wanted position +floating_modifier $mod +bindsym $mod+d floating toggle + + + + +# DROPDOWN +# Scratchpad binds +exec bitwarden-desktop +for_window [instance="bitwarden"] move scratchpad +for_window [instance="bitwarden"] sticky enable +bindsym $mod+p [instance="bitwarden"] scratchpad show; + +exec $TERMINAL --class="dropdown_tmux" -e 'tmux' +for_window [class="dropdown_tmux"] move scratchpad +for_window [class="dropdown_tmux"] sticky enable +bindsym $mod+space [class="dropdown_tmux"] scratchpad show; + +# General dropdown window traits. The order can matter. +# sticky allows windows to stay visible even when switching workspaces +#for_window [instance="dropdown_tmux"] resize set 625 450 +#for_window [instance="dropdown_tmux"] border pixel 3 + + + +# i3 BINDS +bindsym $mod+h focus left +bindsym $mod+Shift+h move left +bindsym $mod+j focus down +bindsym $mod+Shift+j move down +bindsym $mod+k focus up +bindsym $mod+Shift+k move up +bindsym $mod+l focus right +bindsym $mod+Shift+l move right +bindsym $mod+Ctrl+h resize grow width 1 px or 1 ppt +bindsym $mod+Ctrl+j resize shrink height 1 px or 1 ppt +bindsym $mod+Ctrl+k resize grow height 1 px or 1 ppt +bindsym $mod+Ctrl+l resize shrink width 1 px or 1 ppt +bindsym $mod+Shift+r exec --no-startup-id winresize +bindsym $mod+f fullscreen toggle +bindsym $mod+q [con_id="__focused__" instance="^(?!dropdown_).*$"] kill +bindsym $mod+t layout toggle tabbed splith +bindsym $mod+Shift+v split h;exec notify-send 'tile horizontally |' +bindsym $mod+v split v;exec notify-send 'tile vertically -' + + +# ARROW KEYS +bindsym $mod+Left move workspace to output left +bindsym $mod+Down move workspace to output down +bindsym $mod+Up move workspace to output up +bindsym $mod+Right move workspace to output right + +# WORKSPACES +# prior and next ar PgUp and PgDown +bindsym $mod+Prior container prev +bindsym $mod+Shift+Prior move container to workspace prev +bindsym $mod+Next workspace next +bindsym $mod+Shift+Next move container to workspace next +bindsym $mod+Tab workspace back_and_forth + +# name workspaces +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 $ws1 +bindsym $mod+Shift+1 move container to workspace $ws1 +bindsym $mod+2 workspace $ws2 +bindsym $mod+Shift+2 move container to workspace $ws2 +bindsym $mod+3 workspace $ws3 +bindsym $mod+Shift+3 move container to workspace $ws3 +bindsym $mod+4 workspace $ws4 +bindsym $mod+Shift+4 move container to workspace $ws4 +bindsym $mod+5 workspace $ws5 +bindsym $mod+Shift+5 move container to workspace $ws5 +bindsym $mod+6 workspace $ws6 +bindsym $mod+Shift+6 move container to workspace $ws6 +bindsym $mod+7 workspace $ws7 +bindsym $mod+Shift+7 move container to workspace $ws7 +bindsym $mod+8 workspace $ws8 +bindsym $mod+Shift+8 move container to workspace $ws8 +bindsym $mod+9 workspace $ws9 +bindsym $mod+Shift+9 move container to workspace $ws9 +bindsym $mod+0 workspace $ws10 +bindsym $mod+Shift+0 move container to workspace $ws10 + + +# APPLICATION SHORTCUTS +bindsym $mod+Return exec --no-startup-id "rofi -show" +bindsym $mod+Shift+space exec --no-startup-id $TERMINAL +bindsym $mod+w exec --no-startup-id $BROWSER +bindsym $mod+Shift+w exec --no-startup-id "$BROWSER -profile ~/.mozilla/firefox/2ustnzbw.shopping" +bindsym $mod+e exec --no-startup-id $EXPLORER +bindsym $mod+m exec --no-startup-id $MAILCLIENT +# TODO add import path/to/img.png to make a screenshot +bindsym --release $mod+s exec "import ~/Pictures/screenshots/$(date '+%y_%m_%d-%H_%M_%S').png" +bindsym $mod+Shift+s exec "import -window root ~/Pictures/screenshots/$(date '+%y_%m_%d-%H_%M_%S').png" +# i3lock for locking, i3-msg exit for logout +# Show selection: +#bindsym $mod+Insert exec --no-startup-id showclip + + + + +# AUTOSTART +# start polkit for pacman +exec --no-startup-id /usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1 +# DESKTOP STUFF +# set background picture +exec --no-startup-id nitrogen --set-zoom-fill $HOME/.config/i3/bg.png + +# try to start tray tools / applets manually +exec --no-startup-id nm-applet +# --sm-disable +exec --no-startup-id blueman-applet +exec --no-startup-id pamac-tray +exec --no-startup-id xfce4-power-manager +#exec --no-startup-id volumeicon +exec --no-startup-id start-pulseaudio-x11 +exec --no-startup-id pa-applet +exec --no-startup-id picom +bindsym $mod+Ctrl+m exec pavucontrol +# detect screen configurations +exec --no-startup-id autorandr -c +# set key repeat delay and rate +exec --no-startup-id xset r rate 200 35 + + diff --git a/.config/i3/i3status.conf b/.config/i3/i3status.conf new file mode 100644 index 0000000..8980cb0 --- /dev/null +++ b/.config/i3/i3status.conf @@ -0,0 +1 @@ +# this is a i3bar config file diff --git a/.config/nvim/colors/molokai.vim b/.config/nvim/colors/molokai.vim new file mode 100644 index 0000000..6d97053 --- /dev/null +++ b/.config/nvim/colors/molokai.vim @@ -0,0 +1,276 @@ +" Vim color file +" +" Author: Tomas Restrepo +" https://github.com/tomasr/molokai +" +" Note: Based on the Monokai theme for TextMate +" by Wimer Hazenberg and its darker variant +" by Hamish Stuart Macpherson +" + +hi clear + +if version > 580 + " no guarantees for version 5.8 and below, but this makes it stop + " complaining + hi clear + if exists("syntax_on") + syntax reset + endif +endif +let g:colors_name="molokai" + +if exists("g:molokai_original") + let s:molokai_original = g:molokai_original +else + let s:molokai_original = 0 +endif + + +hi Boolean guifg=#AE81FF +hi Character guifg=#E6DB74 +hi Number guifg=#AE81FF +hi String guifg=#E6DB74 +hi Conditional guifg=#F92672 gui=bold +hi Constant guifg=#AE81FF gui=bold +hi Cursor guifg=#000000 guibg=#F8F8F0 +hi iCursor guifg=#000000 guibg=#F8F8F0 +hi Debug guifg=#BCA3A3 gui=bold +hi Define guifg=#66D9EF +hi Delimiter guifg=#8F8F8F +hi DiffAdd guibg=#13354A +hi DiffChange guifg=#89807D guibg=#4C4745 +hi DiffDelete guifg=#960050 guibg=#1E0010 +hi DiffText guibg=#4C4745 gui=italic,bold + +hi Directory guifg=#A6E22E gui=bold +hi Error guifg=#E6DB74 guibg=#1E0010 +hi ErrorMsg guifg=#F92672 guibg=#232526 gui=bold +hi Exception guifg=#A6E22E gui=bold +hi Float guifg=#AE81FF +hi FoldColumn guifg=#465457 guibg=#000000 +hi Folded guifg=#465457 guibg=#000000 +hi Function guifg=#A6E22E +hi Identifier guifg=#FD971F +hi Ignore guifg=#808080 guibg=bg +hi IncSearch guifg=#C4BE89 guibg=#000000 + +hi Keyword guifg=#F92672 gui=bold +hi Label guifg=#E6DB74 gui=none +hi Macro guifg=#C4BE89 gui=italic +hi SpecialKey guifg=#66D9EF gui=italic + +hi MatchParen guifg=#000000 guibg=#FD971F gui=bold +hi ModeMsg guifg=#E6DB74 +hi MoreMsg guifg=#E6DB74 +hi Operator guifg=#F92672 + +" complete menu +hi Pmenu guifg=#66D9EF guibg=#000000 +hi PmenuSel guibg=#808080 +hi PmenuSbar guibg=#080808 +hi PmenuThumb guifg=#66D9EF + +hi PreCondit guifg=#A6E22E gui=bold +hi PreProc guifg=#A6E22E +hi Question guifg=#66D9EF +hi Repeat guifg=#F92672 gui=bold +hi Search guifg=#000000 guibg=#FFE792 +" marks +hi SignColumn guifg=#A6E22E guibg=#232526 +hi SpecialChar guifg=#F92672 gui=bold +hi SpecialComment guifg=#7E8E91 gui=bold +hi Special guifg=#66D9EF guibg=bg gui=italic +if has("spell") + hi SpellBad guisp=#FF0000 gui=undercurl + hi SpellCap guisp=#7070F0 gui=undercurl + hi SpellLocal guisp=#70F0F0 gui=undercurl + hi SpellRare guisp=#FFFFFF gui=undercurl +endif +hi Statement guifg=#F92672 gui=bold +hi StatusLine guifg=#455354 guibg=fg +hi StatusLineNC guifg=#808080 guibg=#080808 +hi StorageClass guifg=#FD971F gui=italic +hi Structure guifg=#66D9EF +hi Tag guifg=#F92672 gui=italic +hi Title guifg=#ef5939 +hi Todo guifg=#FFFFFF guibg=bg gui=bold + +hi Typedef guifg=#66D9EF +hi Type guifg=#66D9EF gui=none +hi Underlined guifg=#808080 gui=underline + +hi VertSplit guifg=#808080 guibg=#080808 gui=bold +hi VisualNOS guibg=#403D3D +hi Visual guibg=#403D3D +hi WarningMsg guifg=#FFFFFF guibg=#333333 gui=bold +hi WildMenu guifg=#66D9EF guibg=#000000 + +hi TabLineFill guifg=#1B1D1E guibg=#1B1D1E +hi TabLine guibg=#1B1D1E guifg=#808080 gui=none + +if s:molokai_original == 1 + hi Normal guifg=#F8F8F2 guibg=#272822 + hi Comment guifg=#75715E + hi CursorLine guibg=#3E3D32 + hi CursorLineNr guifg=#FD971F gui=none + hi CursorColumn guibg=#3E3D32 + hi ColorColumn guibg=#3B3A32 + hi LineNr guifg=#BCBCBC guibg=#3B3A32 + hi NonText guifg=#75715E + hi SpecialKey guifg=#75715E +else + hi Normal guifg=#F8F8F2 guibg=#1B1D1E + hi Comment guifg=#7E8E91 + hi CursorLine guibg=#293739 + hi CursorLineNr guifg=#FD971F gui=none + hi CursorColumn guibg=#293739 + hi ColorColumn guibg=#232526 + hi LineNr guifg=#465457 guibg=#232526 + hi NonText guifg=#465457 + hi SpecialKey guifg=#465457 +end + +" +" Support for 256-color terminal +" +if &t_Co > 255 + if s:molokai_original == 1 + hi Normal ctermbg=234 + hi CursorLine ctermbg=235 cterm=none + hi CursorLineNr ctermfg=208 cterm=none + else + hi Normal ctermfg=252 ctermbg=233 + hi CursorLine ctermbg=234 cterm=none + hi CursorLineNr ctermfg=208 cterm=none + endif + hi Boolean ctermfg=135 + hi Character ctermfg=144 + hi Number ctermfg=135 + hi String ctermfg=144 + hi Conditional ctermfg=161 cterm=bold + hi Constant ctermfg=135 cterm=bold + hi Cursor ctermfg=16 ctermbg=253 + hi Debug ctermfg=225 cterm=bold + hi Define ctermfg=81 + hi Delimiter ctermfg=241 + + hi DiffAdd ctermbg=24 + hi DiffChange ctermfg=181 ctermbg=239 + hi DiffDelete ctermfg=162 ctermbg=53 + hi DiffText ctermbg=102 cterm=bold + + hi Directory ctermfg=118 cterm=bold + hi Error ctermfg=219 ctermbg=89 + hi ErrorMsg ctermfg=199 ctermbg=16 cterm=bold + hi Exception ctermfg=118 cterm=bold + hi Float ctermfg=135 + hi FoldColumn ctermfg=67 ctermbg=16 + hi Folded ctermfg=67 ctermbg=16 + hi Function ctermfg=118 + hi Identifier ctermfg=208 cterm=none + hi Ignore ctermfg=244 ctermbg=232 + hi IncSearch ctermfg=193 ctermbg=16 + + hi keyword ctermfg=161 cterm=bold + hi Label ctermfg=229 cterm=none + hi Macro ctermfg=193 + hi SpecialKey ctermfg=81 + + hi MatchParen ctermfg=233 ctermbg=208 cterm=bold + hi ModeMsg ctermfg=229 + hi MoreMsg ctermfg=229 + hi Operator ctermfg=161 + + " complete menu + hi Pmenu ctermfg=81 ctermbg=16 + hi PmenuSel ctermfg=255 ctermbg=242 + hi PmenuSbar ctermbg=232 + hi PmenuThumb ctermfg=81 + + hi PreCondit ctermfg=118 cterm=bold + hi PreProc ctermfg=118 + hi Question ctermfg=81 + hi Repeat ctermfg=161 cterm=bold + hi Search ctermfg=0 ctermbg=222 cterm=NONE + + " marks column + hi SignColumn ctermfg=118 ctermbg=235 + hi SpecialChar ctermfg=161 cterm=bold + hi SpecialComment ctermfg=245 cterm=bold + hi Special ctermfg=81 + if has("spell") + hi SpellBad ctermbg=52 + hi SpellCap ctermbg=17 + hi SpellLocal ctermbg=17 + hi SpellRare ctermfg=none ctermbg=none cterm=reverse + endif + hi Statement ctermfg=161 cterm=bold + hi StatusLine ctermfg=238 ctermbg=253 + hi StatusLineNC ctermfg=244 ctermbg=232 + hi StorageClass ctermfg=208 + hi Structure ctermfg=81 + hi Tag ctermfg=161 + hi Title ctermfg=166 + hi Todo ctermfg=231 ctermbg=232 cterm=bold + + hi Typedef ctermfg=81 + hi Type ctermfg=81 cterm=none + hi Underlined ctermfg=244 cterm=underline + + hi VertSplit ctermfg=244 ctermbg=232 cterm=bold + hi VisualNOS ctermbg=238 + hi Visual ctermbg=235 + hi WarningMsg ctermfg=231 ctermbg=238 cterm=bold + hi WildMenu ctermfg=81 ctermbg=16 + + hi Comment ctermfg=59 + hi CursorColumn ctermbg=236 + hi ColorColumn ctermbg=236 + hi LineNr ctermfg=250 ctermbg=236 + hi NonText ctermfg=59 + + hi SpecialKey ctermfg=59 + + if exists("g:rehash256") && g:rehash256 == 1 + hi Normal ctermfg=252 ctermbg=234 + hi CursorLine ctermbg=236 cterm=none + hi CursorLineNr ctermfg=208 cterm=none + + hi Boolean ctermfg=141 + hi Character ctermfg=222 + hi Number ctermfg=141 + hi String ctermfg=222 + hi Conditional ctermfg=197 cterm=bold + hi Constant ctermfg=141 cterm=bold + + hi DiffDelete ctermfg=125 ctermbg=233 + + hi Directory ctermfg=154 cterm=bold + hi Error ctermfg=222 ctermbg=233 + hi Exception ctermfg=154 cterm=bold + hi Float ctermfg=141 + hi Function ctermfg=154 + hi Identifier ctermfg=208 + + hi Keyword ctermfg=197 cterm=bold + hi Operator ctermfg=197 + hi PreCondit ctermfg=154 cterm=bold + hi PreProc ctermfg=154 + hi Repeat ctermfg=197 cterm=bold + + hi Statement ctermfg=197 cterm=bold + hi Tag ctermfg=197 + hi Title ctermfg=203 + hi Visual ctermbg=238 + + hi Comment ctermfg=244 + hi LineNr ctermfg=239 ctermbg=235 + hi NonText ctermfg=239 + hi SpecialKey ctermfg=239 + endif +end + +" Must be at the end, because of ctermbg=234 bug. +" https://groups.google.com/forum/#!msg/vim_dev/afPqwAFNdrU/nqh6tOM87QUJ +set background=dark diff --git a/.config/nvim/colors/monokai.vim b/.config/nvim/colors/monokai.vim new file mode 100644 index 0000000..1b4f167 --- /dev/null +++ b/.config/nvim/colors/monokai.vim @@ -0,0 +1,109 @@ +" Vim color file +" Converted from Textmate theme Monokai using Coloration v0.3.2 (http://github.com/sickill/coloration) + +set background=dark +highlight clear + +if exists("syntax_on") + syntax reset +endif + +set t_Co=256 +let g:colors_name = "monokai" + +hi Cursor ctermfg=235 ctermbg=231 cterm=NONE guifg=#272822 guibg=#f8f8f0 gui=NONE +hi Visual ctermfg=NONE ctermbg=59 cterm=NONE guifg=NONE guibg=#49483e gui=NONE +hi CursorLine ctermfg=NONE ctermbg=237 cterm=NONE guifg=NONE guibg=#3c3d37 gui=NONE +hi CursorColumn ctermfg=NONE ctermbg=237 cterm=NONE guifg=NONE guibg=#3c3d37 gui=NONE +hi ColorColumn ctermfg=NONE ctermbg=237 cterm=NONE guifg=NONE guibg=#3c3d37 gui=NONE +hi LineNr ctermfg=102 ctermbg=237 cterm=NONE guifg=#90908a guibg=#3c3d37 gui=NONE +hi VertSplit ctermfg=241 ctermbg=241 cterm=NONE guifg=#64645e guibg=#64645e gui=NONE +hi MatchParen ctermfg=197 ctermbg=NONE cterm=underline guifg=#f92672 guibg=NONE gui=underline +hi StatusLine ctermfg=231 ctermbg=241 cterm=bold guifg=#f8f8f2 guibg=#64645e gui=bold +hi StatusLineNC ctermfg=231 ctermbg=241 cterm=NONE guifg=#f8f8f2 guibg=#64645e gui=NONE +hi Pmenu ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi PmenuSel ctermfg=NONE ctermbg=59 cterm=NONE guifg=NONE guibg=#49483e gui=NONE +hi IncSearch term=reverse cterm=reverse ctermfg=193 ctermbg=16 gui=reverse guifg=#C4BE89 guibg=#000000 +hi Search term=reverse cterm=NONE ctermfg=231 ctermbg=24 gui=NONE guifg=#f8f8f2 guibg=#204a87 +hi Directory ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi Folded ctermfg=242 ctermbg=235 cterm=NONE guifg=#75715e guibg=#272822 gui=NONE +hi SignColumn ctermfg=NONE ctermbg=237 cterm=NONE guifg=NONE guibg=#3c3d37 gui=NONE +hi Normal ctermfg=231 ctermbg=235 cterm=NONE guifg=#f8f8f2 guibg=#272822 gui=NONE +hi Boolean ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi Character ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi Comment ctermfg=242 ctermbg=NONE cterm=NONE guifg=#75715e guibg=NONE gui=NONE +hi Conditional ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi Constant ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi Define ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi DiffAdd ctermfg=231 ctermbg=64 cterm=bold guifg=#f8f8f2 guibg=#46830c gui=bold +hi DiffDelete ctermfg=88 ctermbg=NONE cterm=NONE guifg=#8b0807 guibg=NONE gui=NONE +hi DiffChange ctermfg=NONE ctermbg=NONE cterm=NONE guifg=#f8f8f2 guibg=#243955 gui=NONE +hi DiffText ctermfg=231 ctermbg=24 cterm=bold guifg=#f8f8f2 guibg=#204a87 gui=bold +hi ErrorMsg ctermfg=231 ctermbg=197 cterm=NONE guifg=#f8f8f0 guibg=#f92672 gui=NONE +hi WarningMsg ctermfg=231 ctermbg=197 cterm=NONE guifg=#f8f8f0 guibg=#f92672 gui=NONE +hi Float ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi Function ctermfg=148 ctermbg=NONE cterm=NONE guifg=#a6e22e guibg=NONE gui=NONE +hi Identifier ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=italic +hi Keyword ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi Label ctermfg=186 ctermbg=NONE cterm=NONE guifg=#e6db74 guibg=NONE gui=NONE +hi NonText ctermfg=59 ctermbg=236 cterm=NONE guifg=#49483e guibg=#31322c gui=NONE +hi Number ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi Operator ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi PreProc ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi Special ctermfg=231 ctermbg=NONE cterm=NONE guifg=#f8f8f2 guibg=NONE gui=NONE +hi SpecialComment ctermfg=242 ctermbg=NONE cterm=NONE guifg=#75715e guibg=NONE gui=NONE +hi SpecialKey ctermfg=59 ctermbg=237 cterm=NONE guifg=#49483e guibg=#3c3d37 gui=NONE +hi Statement ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi StorageClass ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=italic +hi String ctermfg=186 ctermbg=NONE cterm=NONE guifg=#e6db74 guibg=NONE gui=NONE +hi Tag ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi Title ctermfg=231 ctermbg=NONE cterm=bold guifg=#f8f8f2 guibg=NONE gui=bold +hi Todo ctermfg=95 ctermbg=NONE cterm=inverse,bold guifg=#75715e guibg=NONE gui=inverse,bold +hi Type ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi Underlined ctermfg=NONE ctermbg=NONE cterm=underline guifg=NONE guibg=NONE gui=underline +hi rubyClass ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi rubyFunction ctermfg=148 ctermbg=NONE cterm=NONE guifg=#a6e22e guibg=NONE gui=NONE +hi rubyInterpolationDelimiter ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi rubySymbol ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi rubyConstant ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=italic +hi rubyStringDelimiter ctermfg=186 ctermbg=NONE cterm=NONE guifg=#e6db74 guibg=NONE gui=NONE +hi rubyBlockParameter ctermfg=208 ctermbg=NONE cterm=NONE guifg=#fd971f guibg=NONE gui=italic +hi rubyInstanceVariable ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi rubyInclude ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi rubyGlobalVariable ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi rubyRegexp ctermfg=186 ctermbg=NONE cterm=NONE guifg=#e6db74 guibg=NONE gui=NONE +hi rubyRegexpDelimiter ctermfg=186 ctermbg=NONE cterm=NONE guifg=#e6db74 guibg=NONE gui=NONE +hi rubyEscape ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi rubyControl ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi rubyClassVariable ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi rubyOperator ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi rubyException ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi rubyPseudoVariable ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi rubyRailsUserClass ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=italic +hi rubyRailsARAssociationMethod ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi rubyRailsARMethod ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi rubyRailsRenderMethod ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi rubyRailsMethod ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi erubyDelimiter ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi erubyComment ctermfg=95 ctermbg=NONE cterm=NONE guifg=#75715e guibg=NONE gui=NONE +hi erubyRailsMethod ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi htmlTag ctermfg=148 ctermbg=NONE cterm=NONE guifg=#a6e22e guibg=NONE gui=NONE +hi htmlEndTag ctermfg=148 ctermbg=NONE cterm=NONE guifg=#a6e22e guibg=NONE gui=NONE +hi htmlTagName ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi htmlArg ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi htmlSpecialChar ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi javaScriptFunction ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=italic +hi javaScriptRailsFunction ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi javaScriptBraces ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi yamlKey ctermfg=197 ctermbg=NONE cterm=NONE guifg=#f92672 guibg=NONE gui=NONE +hi yamlAnchor ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi yamlAlias ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE +hi yamlDocumentHeader ctermfg=186 ctermbg=NONE cterm=NONE guifg=#e6db74 guibg=NONE gui=NONE +hi cssURL ctermfg=208 ctermbg=NONE cterm=NONE guifg=#fd971f guibg=NONE gui=italic +hi cssFunctionName ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi cssColor ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi cssPseudoClassId ctermfg=148 ctermbg=NONE cterm=NONE guifg=#a6e22e guibg=NONE gui=NONE +hi cssClassName ctermfg=148 ctermbg=NONE cterm=NONE guifg=#a6e22e guibg=NONE gui=NONE +hi cssValueLength ctermfg=141 ctermbg=NONE cterm=NONE guifg=#ae81ff guibg=NONE gui=NONE +hi cssCommonAttr ctermfg=81 ctermbg=NONE cterm=NONE guifg=#66d9ef guibg=NONE gui=NONE +hi cssBraces ctermfg=NONE ctermbg=NONE cterm=NONE guifg=NONE guibg=NONE gui=NONE diff --git a/.config/nvim/ftplugin/python.lua b/.config/nvim/ftplugin/python.lua new file mode 100644 index 0000000..e69de29 diff --git a/.config/nvim/init.lua b/.config/nvim/init.lua new file mode 100644 index 0000000..6fde757 --- /dev/null +++ b/.config/nvim/init.lua @@ -0,0 +1,43 @@ +require("plugins") +require("keybinds") +--- Functional wrapper for mapping custom keybindings +--- GENERAL SETTINGS +function map(mode, lhs, rhs, opts) + local options = { noremap = true } + if opts then + options = vim.tbl_extend("force", options, opts) + end + vim.api.nvim_set_keymap(mode, lhs, rhs, options) +end +map("i","","") + +vim.o.termguicolors = true +vim.cmd('colorscheme monokai') -- set colorscheme +vim.o.syntax = 'on' +vim.cmd('set title') +vim.opt.titlestring = [[%{v:progname}: %f %h%m%r%w ]] +-- vim.opt.titlestring = [[%f %h%m%r%w %{v:progname} (%{tabpagenr()} of %{tabpagenr('$')})]] +vim.o.errorbells = false +vim.o.smartcase = true +vim.o.showmode = true +vim.o.ignorecase = true -- case-insensitive search +vim.bo.swapfile = false +vim.o.backup = false +vim.o.undodir = vim.fn.stdpath('config') .. '/undodir' +vim.o.undofile = true +vim.o.incsearch = true +vim.o.hidden = true +vim.o.completeopt='menuone,noinsert,noselect' +vim.bo.autoindent = true +vim.bo.smartindent = true +vim.o.tabstop = 2 +vim.o.softtabstop = 2 +vim.o.shiftwidth = 2 +vim.o.expandtab = true +vim.wo.number = true +vim.wo.relativenumber = true +vim.o.scrolloff = 8 +vim.wo.signcolumn = 'yes' +vim.wo.wrap = false +vim.opt.cursorline = true + diff --git a/.config/nvim/lua/keybinds.lua b/.config/nvim/lua/keybinds.lua new file mode 100644 index 0000000..1991f58 --- /dev/null +++ b/.config/nvim/lua/keybinds.lua @@ -0,0 +1,13 @@ +-- filetype-specific keybinds can be found in the ftplugin folder, requires 'filetype plugin on' +function map(mode, lhs, rhs, opts) + local options = { noremap = true } + if opts then + options = vim.tbl_extend("force", options, opts) + end + vim.api.nvim_set_keymap(mode, lhs, rhs, options) +end + +map("n", "", "ik$") +-- map("n", "", "d$Op^") +map("n", "", "i") + diff --git a/.config/nvim/lua/plugins.lua b/.config/nvim/lua/plugins.lua new file mode 100644 index 0000000..78ac519 --- /dev/null +++ b/.config/nvim/lua/plugins.lua @@ -0,0 +1,32 @@ +-- INSTALL PACKER PLUGINS https://github.com/wbthomason/packer.nvim#bootstrapping +local vim = vim +local execute = vim.api.nvim_command +local fn = vim.fn +local install_path = fn.stdpath('data')..'/site/pack/packer/opt/packer.nvim' +if fn.empty(fn.glob(install_path)) > 0 then + execute('!git clone https://github.com/wbthomason/packer.nvim '..install_path) + execute 'packadd packer.nvim' +end +vim.cmd('packadd packer.nvim') +local packer = require'packer' +local util = require'packer.util' +packer.init({ + package_root = util.join_paths(vim.fn.stdpath('data'), 'site', 'pack') +}) +--- startup and add configure plugins +packer.startup(function() + local use = use + use 'neovim/nvim-lspconfig' + use 'nvim-treesitter/nvim-treesitter' + end +) +--[[ PLUGIN CONFIGURATION +local configs = require'nvim-treesitter.configs' +configs.setup { + ensure_installed = "maintained", + highlight = { + enable = true, + } +} +]]-- + diff --git a/.config/picom.conf b/.config/picom.conf new file mode 100644 index 0000000..b380e7b --- /dev/null +++ b/.config/picom.conf @@ -0,0 +1,271 @@ +# Thank you code_nomad: http://9m.no/ꪯ鵞 +# and Arch Wiki contributors: https://wiki.archlinux.org/index.php/Compton + +################################# +# +# Backend +# +################################# + +# Backend to use: "xrender" or "glx". +# GLX backend is typically much faster but depends on a sane driver. +backend = "glx"; + +################################# +# +# GLX backend +# +################################# + +glx-no-stencil = true; + +# GLX backend: Copy unmodified regions from front buffer instead of redrawing them all. +# My tests with nvidia-drivers show a 10% decrease in performance when the whole screen is modified, +# but a 20% increase when only 1/4 is. +# My tests on nouveau show terrible slowdown. +glx-copy-from-front = false; + +# GLX backend: Use MESA_copy_sub_buffer to do partial screen update. +# My tests on nouveau shows a 200% performance boost when only 1/4 of the screen is updated. +# May break VSync and is not available on some drivers. +# Overrides --glx-copy-from-front. +# glx-use-copysubbuffermesa = true; + +# GLX backend: Avoid rebinding pixmap on window damage. +# Probably could improve performance on rapid window content changes, but is known to break things on some drivers (LLVMpipe). +# Recommended if it works. +# glx-no-rebind-pixmap = true; + +# GLX backend: GLX buffer swap method we assume. +# Could be undefined (0), copy (1), exchange (2), 3-6, or buffer-age (-1). +# undefined is the slowest and the safest, and the default value. +# copy is fastest, but may fail on some drivers, +# 2-6 are gradually slower but safer (6 is still faster than 0). +# Usually, double buffer means 2, triple buffer means 3. +# buffer-age means auto-detect using GLX_EXT_buffer_age, supported by some drivers. +# Useless with --glx-use-copysubbuffermesa. +# Partially breaks --resize-damage. +# Defaults to undefined. +#glx-swap-method = "undefined"; #deprecated ! +#use-damage = true + +################################# +# +# Shadows +# +################################# + +# Enabled client-side shadows on windows. +shadow = true; +# The blur radius for shadows. (default 12) +shadow-radius = 5; +# The left offset for shadows. (default -15) +shadow-offset-x = 1; +# The top offset for shadows. (default -15) +shadow-offset-y = 1; +# The translucency for shadows. (default .75) +shadow-opacity = 0.3; + +# Set if you want different colour shadows +# shadow-red = 0.0; +# shadow-green = 0.0; +# shadow-blue = 0.0; + +# The shadow exclude options are helpful if you have shadows enabled. Due to the way picom draws its shadows, certain applications will have visual glitches +# (most applications are fine, only apps that do weird things with xshapes or argb are affected). +# This list includes all the affected apps I found in my testing. The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents a visual glitch with the XFWM alt tab switcher. +shadow-exclude = [ + "! name~=''", + "name = 'Notification'", + "name = 'Plank'", + "name = 'Docky'", + "name = 'Kupfer'", + "name = 'xfce4-notifyd'", + "name *= 'VLC'", + "name *= 'compton'", + "name *= 'picom'", + "name *= 'Chromium'", + "name *= 'Chrome'", + "class_g = 'Firefox' && argb", + "class_g = 'Conky'", + "class_g = 'Kupfer'", + "class_g = 'Synapse'", + "class_g ?= 'Notify-osd'", + "class_g ?= 'Cairo-dock'", + "class_g ?= 'Xfce4-notifyd'", + "class_g ?= 'Xfce4-power-manager'", + "class_g ?= 'Dmenu'", +# "class_g ?= 'Dunst'", +# disables shadows on i3 frames + "class_g ?= 'i3-frame'", + "_GTK_FRAME_EXTENTS@:c", + "_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'" +]; +# Avoid drawing shadow on all shaped windows (see also: --detect-rounded-corners) +shadow-ignore-shaped = false; + +################################# +# +# Opacity +# +################################# + +inactive-opacity = 1; +active-opacity = 1; +frame-opacity = 1; +inactive-opacity-override = false; + +# Dim inactive windows. (0.0 - 1.0) +# inactive-dim = 0.2; +# Do not let dimness adjust based on window opacity. +# inactive-dim-fixed = true; +# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred. +# blur-background = true; +# Blur background of opaque windows with transparent frames as well. +# blur-background-frame = true; +# Do not let blur radius adjust based on window opacity. +blur-background-fixed = false; +blur-background-exclude = [ + "window_type = 'dock'", + "window_type = 'desktop'" +]; + +################################# +# +# Fading +# +################################# + +# Fade windows during opacity changes. +fading = false; +# The time between steps in a fade in milliseconds. (default 10). +fade-delta = 1; +# Opacity change between steps while fading in. (default 0.028). +fade-in-step = 0.03; +# Opacity change between steps while fading out. (default 0.03). +fade-out-step = 0.03; +# Fade windows in/out when opening/closing +# no-fading-openclose = true; + +# Specify a list of conditions of windows that should not be faded. +fade-exclude = [ ]; + +################################# +# +# Other +# +################################# + +# Try to detect WM windows and mark them as active. +mark-wmwin-focused = true; +# Mark all non-WM but override-redirect windows active (e.g. menus). +mark-ovredir-focused = true; +# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events. +# Usually more reliable but depends on a EWMH-compliant WM. +use-ewmh-active-win = true; +# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on. +detect-rounded-corners = true; + +# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows. +# This prevents opacity being ignored for some apps. +# For example without this enabled my xfce4-notifyd is 100% opacity no matter what. +detect-client-opacity = true; + +# Specify refresh rate of the screen. +# If not specified or 0, picom will try detecting this with X RandR extension. +# DEPRECATED +#refresh-rate = 0; + +# Vertical synchronization: match the refresh rate of the monitor +vsync = false; + +# Enable DBE painting mode, intended to use with VSync to (hopefully) eliminate tearing. +# Reported to have no effect, though. +dbe = false; + +# Limit picom to repaint at most once every 1 / refresh_rate second to boost performance. +# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already, +# unless you wish to specify a lower refresh rate than the actual value. +#sw-opti = true; + +# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games. +# Known to cause flickering when redirecting/unredirecting windows. +unredir-if-possible = true; + +# Specify a list of conditions of windows that should always be considered focused. +focus-exclude = [ "class_g = 'Cairo-clock'" ]; + +# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time. +detect-transient = true; +# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time. +# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too. +detect-client-leader = true; + +################################# +# +# Window type settings +# +################################# + +wintypes : +{ + tooltip : + { + fade = true; + shadow = false; + opacity = 0.85; + focus = true; + }; + fullscreen : + { + fade = true; + shadow = false; + opacity = 1; + focus = true; + }; + dropdown_menu = { shadow = false;}; + popup_menu = { shadow = false;}; + utility = { shadow = false;}; +}; + +###################### +# +# XSync +# See: https://github.com/yshui/picom/commit/b18d46bcbdc35a3b5620d817dd46fbc76485c20d +# +###################### + +# Use X Sync fence to sync clients' draw calls. Needed on nvidia-drivers with GLX backend for some users. +xrender-sync-fence = true; + +#opacity-rule = [ +#"99:name *?= 'Call'", +#"99:class_g = 'Chromium'", +#"99:name *?= 'Conky'", +#"99:class_g = 'Darktable'", +#"50:class_g = 'Dmenu'", +#"99:name *?= 'Event'", +#"99:class_g = 'Firefox'", +#"99:class_g = 'GIMP'", +#"99:name *?= 'Image'", +#"99:class_g = 'Lazpaint'", +#"99:class_g = 'Midori'", +#"99:name *?= 'Minitube'", +#"99:class_g = 'Mousepad'", +#"99:name *?= 'MuseScore'", +#"90:name *?= 'Page Info'", +#"99:name *?= 'Pale Moon'", +#"90:name *?= 'Panel'", +#"99:class_g = 'Pinta'", +#"90:name *?= 'Restart'", +#"99:name *?= 'sudo'", +#"99:name *?= 'Screenshot'", +#"99:class_g = 'Viewnior'", +#"99:class_g = 'VirtualBox'", +#"99:name *?= 'VLC'", +#"99:name *?= 'Write'", +#"93:class_g = 'URxvt' && !_NET_WM_STATE@:32a", +#"0:_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'", +#"96:_NET_WM_STATE@:32a *= '_NET_WM_STATE_STICKY'" +#]; + diff --git a/.config/rofi/config.rasi b/.config/rofi/config.rasi new file mode 100644 index 0000000..1a8f3e9 --- /dev/null +++ b/.config/rofi/config.rasi @@ -0,0 +1,173 @@ +// vim: filetype=c +// get dumps via -dump-config and -dump-theme +configuration { + modes: "combi"; + font: "mono 12"; +/* location: 0;*/ +/* yoffset: 0;*/ +/* xoffset: 0;*/ +/* fixed-num-lines: true;*/ + show-icons: true; + terminal: "alacritty"; +/* ssh-client: "ssh";*/ +/* ssh-command: "{terminal} -e {ssh-client} {host} [-p {port}]";*/ +/* run-command: "{cmd}";*/ +/* run-list-command: "";*/ +/* run-shell-command: "{terminal} -e {cmd}";*/ +/* window-command: "wmctrl -i -R {window}";*/ +/* window-match-fields: "all";*/ +/* icon-theme: ;*/ +/* drun-match-fields: "name,generic,exec,categories,keywords";*/ +/* drun-categories: ;*/ +/* drun-show-actions: false;*/ +/* drun-display-format: "{name} [({generic})]";*/ +/* drun-url-launcher: "xdg-open";*/ +/* disable-history: false;*/ +/* ignored-prefixes: "";*/ +/* sort: false;*/ +/* sorting-method: "normal";*/ +/* case-sensitive: false;*/ +/* cycle: true;*/ +/* sidebar-mode: false;*/ +/* hover-select: false;*/ +/* eh: 1;*/ +/* auto-select: false;*/ +/* parse-hosts: false;*/ +/* parse-known-hosts: true;*/ + combi-modes: "window,drun,ssh"; +/* matching: "normal";*/ +/* tokenize: true;*/ +/* m: "-5";*/ +/* filter: ;*/ +/* dpi: -1;*/ +/* threads: 0;*/ +/* scroll-method: 0;*/ +/* window-format: "{w} {c} {t}";*/ +/* click-to-exit: true;*/ +/* max-history-size: 25;*/ + combi-hide-mode-prefix: true; +/* combi-display-format: "{mode} {text}";*/ +/* matching-negate-char: '-' /* unsupported */;*/ +/* cache-dir: ;*/ +/* window-thumbnail: false;*/ +/* drun-use-desktop-cache: false;*/ +/* drun-reload-desktop-cache: false;*/ +/* normalize-match: false;*/ +/* steal-focus: false;*/ +/* application-fallback-icon: ;*/ +/* refilter-timeout-limit: 8192;*/ +/* xserver-i300-workaround: false;*/ + pid: "/run/user/1000/rofi.pid"; +/* display-window: ;*/ +/* display-windowcd: ;*/ +/* display-run: ;*/ +/* display-ssh: ;*/ +/* display-drun: ;*/ +/* display-combi: ;*/ +/* display-keys: ;*/ +/* display-filebrowser: ;*/ +/* kb-primary-paste: "Control+V,Shift+Insert";*/ +/* kb-secondary-paste: "Control+v,Insert";*/ +/* kb-clear-line: "Control+w";*/ +/* kb-move-front: "Control+a";*/ +/* kb-move-end: "Control+e";*/ +/* kb-move-word-back: "Alt+b,Control+Left";*/ +/* kb-move-word-forward: "Alt+f,Control+Right";*/ +/* kb-move-char-back: "Left,Control+b";*/ +/* kb-move-char-forward: "Right,Control+f";*/ +/* kb-remove-word-back: "Control+Alt+h,Control+BackSpace";*/ +/* kb-remove-word-forward: "Control+Alt+d";*/ +/* kb-remove-char-forward: "Delete,Control+d";*/ +/* kb-remove-char-back: "BackSpace,Shift+BackSpace,Control+h";*/ +/* kb-remove-to-eol: "Control+k";*/ +/* kb-remove-to-sol: "Control+u";*/ +/* kb-accept-entry: "Control+j,Control+m,Return,KP_Enter";*/ +/* kb-accept-custom: "Control+Return";*/ +/* kb-accept-custom-alt: "Control+Shift+Return";*/ +/* kb-accept-alt: "Shift+Return";*/ +/* kb-delete-entry: "Shift+Delete";*/ +/* kb-mode-next: "Shift+Right,Control+Tab";*/ +/* kb-mode-previous: "Shift+Left,Control+ISO_Left_Tab";*/ +/* kb-mode-complete: "Control+l";*/ +/* kb-row-left: "Control+Page_Up";*/ +/* kb-row-right: "Control+Page_Down";*/ +/* kb-row-up: "Up,Control+p";*/ +/* kb-row-down: "Down,Control+n";*/ +/* kb-row-tab: "";*/ +/* kb-element-next: "Tab";*/ +/* kb-element-prev: "ISO_Left_Tab";*/ +/* kb-page-prev: "Page_Up";*/ +/* kb-page-next: "Page_Down";*/ +/* kb-row-first: "Home,KP_Home";*/ +/* kb-row-last: "End,KP_End";*/ +/* kb-row-select: "Control+space";*/ +/* kb-screenshot: "Alt+S";*/ +/* kb-ellipsize: "Alt+period";*/ +/* kb-toggle-case-sensitivity: "grave,dead_grave";*/ +/* kb-toggle-sort: "Alt+grave";*/ +/* kb-cancel: "Escape,Control+g,Control+bracketleft";*/ +/* kb-custom-1: "Alt+1";*/ +/* kb-custom-2: "Alt+2";*/ +/* kb-custom-3: "Alt+3";*/ +/* kb-custom-4: "Alt+4";*/ +/* kb-custom-5: "Alt+5";*/ +/* kb-custom-6: "Alt+6";*/ +/* kb-custom-7: "Alt+7";*/ +/* kb-custom-8: "Alt+8";*/ +/* kb-custom-9: "Alt+9";*/ +/* kb-custom-10: "Alt+0";*/ +/* kb-custom-11: "Alt+exclam";*/ +/* kb-custom-12: "Alt+at";*/ +/* kb-custom-13: "Alt+numbersign";*/ +/* kb-custom-14: "Alt+dollar";*/ +/* kb-custom-15: "Alt+percent";*/ +/* kb-custom-16: "Alt+dead_circumflex";*/ +/* kb-custom-17: "Alt+ampersand";*/ +/* kb-custom-18: "Alt+asterisk";*/ +/* kb-custom-19: "Alt+parenleft";*/ +/* ml-row-left: "ScrollLeft";*/ +/* ml-row-right: "ScrollRight";*/ +/* ml-row-up: "ScrollUp";*/ +/* ml-row-down: "ScrollDown";*/ +/* me-select-entry: "MousePrimary";*/ +/* me-accept-entry: "MouseDPrimary";*/ +/* me-accept-custom: "Control+MouseDPrimary";*/ + kb-custom-1: ""; + kb-custom-2: ""; + kb-custom-3: ""; + kb-custom-4: ""; + kb-custom-5: ""; + kb-custom-6: ""; + kb-custom-7: ""; + kb-custom-8: ""; + kb-custom-9: ""; + kb-custom-10: ""; + kb-custom-11: ""; + kb-custom-12: ""; + kb-custom-13: ""; + kb-custom-14: ""; + kb-custom-15: ""; + kb-custom-16: ""; + kb-custom-17: ""; + kb-custom-18: ""; + kb-custom-19: ""; + kb-select-1: "Alt+1"; + kb-select-2: "Alt+2"; + kb-select-3: "Alt+3"; + kb-select-4: "Alt+4"; + kb-select-5: "Alt+5"; + kb-select-6: "Alt+6"; + kb-select-7: "Alt+7"; + kb-select-8: "Alt+8"; + kb-select-9: "Alt+9"; + kb-select-10:"Alt+0"; + timeout { + action: "kb-cancel"; + delay: 0; + } + filebrowser { + directories-first: true; + sorting-method: "name"; + } +} +@theme "theme" // read theme in ./theme.rasi diff --git a/.config/shell/alias.sh b/.config/shell/alias.sh new file mode 100644 index 0000000..9aa9460 --- /dev/null +++ b/.config/shell/alias.sh @@ -0,0 +1,58 @@ + +alias ls='exa' # make output more readable and show directories first +alias ll='ls -l' +alias la='ls --all' +alias less='less --use-color' +alias grep='rg' # colorize grep output, set GREP_COLORS +alias cp="cp -i" # Confirm before overwriting something +alias df='df -h' # Human-readable sizes +alias vi='nvim' # Show sizes in MB +alias r='R' +alias xar="xarchiver" + +# Add an "alert" alias for long running commands. Use like so: 'sleep 10; alert' +alias notify='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"' + +#Add a "dotfiles" alias for .dotfile git repo +alias dotfiles='git --git-dir=$HOME/.dotfiles/ --work-tree=$HOME' +#alias 'dotfiles-update'='dotfiles commit -a && dotfiles push' + + +colors() { + local fgc bgc vals seq0 + + printf "Color escapes are %s\n" '\e[${value};...;${value}m' + printf "Values 30..37 are \e[33mforeground colors\e[m\n" + printf "Values 40..47 are \e[43mbackground colors\e[m\n" + printf "Value 1 gives a \e[1mbold-faced look\e[m\n\n" + + # foreground colors + for fgc in {30..37}; do + # background colors + for bgc in {40..47}; do + fgc=${fgc#37} # white + bgc=${bgc#40} # black + + vals="${fgc:+$fgc;}${bgc}" + vals=${vals%%;} + + seq0="${vals:+\e[${vals}m}" + printf " %-9s" "${seq0:-(default)}" + printf " ${seq0}TEXT\e[m" + printf " \e[${vals:+${vals+$vals;}}1mBOLD\e[m" + done + echo; echo + done +} + +# set title in zsh (for alacritty) +title() +{ + echo -e "\e]2;$1\007"; +} + +pwd() +{ + echo "$PWD/$1" +} + diff --git a/.config/tmux/tmux.conf b/.config/tmux/tmux.conf new file mode 100644 index 0000000..acd9db0 --- /dev/null +++ b/.config/tmux/tmux.conf @@ -0,0 +1,29 @@ +tmux_config_dir="~/.config/tmux" +mod="C-b" +#CONFIGURATION +#if-shell '[[ -n "$SSH_CLIENT"]]' { +# source-file $tmux_config_dir/tmux_remote.conf # use alternative config for tmux inside ssh session +# mod="C-b" +#} + +set-option -g prefix $mod # rebind tmux prefix to CTRL + a because vim uses default CTRL + b +set-window-option -g mode-keys vi # vi mode +set-option -g allow-rename off # dont rename windows on command execution TODO fix +set -s escape-time 0 # dont delay escape key in vim +set -g base-index 0 # start windows numbering at 0 +set-option -g set-titles on +set -g mouse on + +#COLORS +set -g default-terminal "screen-256color" # use default terminal colors +set-option -g pane-border-style fg=white +set-option -g pane-active-border-style fg=blue +set-option -g message-style bg=green,fg=black + +#STATUSBAR +set -g status-position bottom +set -g status-left "" +set -g status-right "#{?window_bigger,[#{window_offset_x}#,#{window_offset_y}] ,}#{=21:pane_title}" +set -g status-style fg=white,bg=black # color for the statusbar +set-window-option -g window-status-current-style fg=black,bg=blue # color for the current window (tab) + diff --git a/.config/zsh/.zshrc b/.config/zsh/.zshrc new file mode 100644 index 0000000..3550440 --- /dev/null +++ b/.config/zsh/.zshrc @@ -0,0 +1,162 @@ +#OPTIONS SECTION + +#unsetopt beep # try disabling annoying beep sounds +setopt nobeep +xset b off +autoload -Uz compinit # load completion +compinit +_comp_options+=(globdots) # Include hidden files. +setopt autocd # allow cd by only entering directory without cd command +setopt extendedglob # Extended globbing. Allows using regular expressions with * +setopt correct # Auto correct mistakes +setopt numericglobsort # Sort filenames numerically when it makes sense +setopt appendhistory # Immediately append history instead of overwriting +HISTFILE=~/.history + +zstyle ':completion:*' special-dirs true # complete hidden directories +zstyle ':completion:*' special-files true # complete hidden files +zstyle ':completion:*' matcher-list 'm:{a-zA-Z}={A-Za-z}' # Case insensitive tab completion +zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" # Colored completion (different colors for dirs/files/etc) +zstyle ':completion:*' menu select # enable navigable menu for completion +zstyle ':completion:*' rehash true # Automatically update PATH entries +zstyle ':completion:*' matcher-list 'r:|[._-]=* r:|=*' # Smart matching of dashed values, e.g. f-b matching foo-bar +zstyle ':completion:*' group-name '' # Group results by category +zstyle ':completion:*' insert-tab false # Don't insert a literal tab when trying to complete in an empty buffer +zstyle ':completion:*' completer _complete _ignored _correct _approximate # Enable approximate completions +zstyle ':completion:*' verbose true # Verbose completion results +#zstyle ':completion:*' show-completer true +#zstyle ':completion:*' matcher-list 'r:|[._-'\''"`´,;:]=** r:|=**' +#zstyle ':completion:*' original true +#zstyle :compinstall filename '/home/en/.zshrc' + # Show message while waiting for completion + +# Pretty messages during pagination +zstyle ':completion:*' list-prompt '%SAt %p: Hit TAB for more, or the character to insert%s' +zstyle ':completion:*' select-prompt '%SScrolling active: current selection at %p%s' + +# Nicer format for completion messages +#zstyle ':completion:*:descriptions' format '%U%B%d%b%u' #shows categories of commands like "built-in" and "external" +#zstyle ':completion:*:corrections' format '%U%F{green}%d (errors: %e)%f%u' +#zstyle ':completion:*:warnings' format '%F{202}%BSorry, no matches for: %F{214}%d%b' + +# Prettier completion for processes +#zstyle ':completion:*:*:*:*:processes' force-list always +zstyle ':completion:*:*:*:*:processes' menu yes select +zstyle ':completion:*:*:*:*:processes' list-colors '=(#b) #([0-9]#) ([0-9a-z-]#)*=01;34=0=01' +zstyle ':completion:*:*:*:*:processes' command "ps -u $USER -o pid,user,args -w -w" + + +autoload -Uz bracketed-paste-magic # allow links to be read without escaping +zle -N bracketed-paste bracketed-paste-magic +autoload -Uz url-quote-magic +zle -N self-insert url-quote-magic + +WORDCHARS=${WORDCHARS//\/[&.;]} # Don't consider certain characters part of the word + + + +source $XDG_CONFIG_HOME/shell/alias.sh + + +#KEYBINDINGS SECTION (use 'cat -v' or 'od -c' to see raw keyboard output) + +bindkey -e # use emacs key layout +bindkey '^[[1;5D' backward-word # 'CTRL + leftarrow' +bindkey '^[[1;5C' forward-word # 'CTRL + rightarrow' +bindkey '^H' backward-kill-word # delete previous word with ctrl+backspace +bindkey '^[[3~' delete-char # enable delete key +bindkey '^[[3;5~' kill-word # 'CTRL + DEL' +bindkey '^Z' undo # 'CTRL + z' undo last action + + +#PLUGIN SECTION + +if [[ -x /usr/lib/command-not-found ]] ; then # try loading suggestions to install when command was not found + function command_not_found_handler() { + /usr/lib/command-not-found --no-failure-msg -- $1 + } +fi + +source /usr/share/zsh-theme-powerlevel10k/powerlevel10k.zsh-theme # load theme +#source /usr/share/doc/find-the-command/ftc.zsh quiet # load command not found, might need `systemctl enable pacman-files.timer` + +#source /usr/share/zsh/plugins/zsh-background-notify/bgnotify.plugin.zsh # load notifications for long comands, customize message? +#bgnotify_threshold=4 +source /usr/share/zsh/plugins/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh # load syntax highlighting, everything except autosuggestions should be loaded before this + ZSH_HIGHLIGHT_HIGHLIGHTERS=(main brackets pattern) + ZSH_HIGHLIGHT_STYLES[default]=none + #ZSH_HIGHLIGHT_STYLES[reserved-word]=fg=009,standout + #ZSH_HIGHLIGHT_STYLES[alias]=fg=white,bold + #ZSH_HIGHLIGHT_STYLES[builtin]=fg=white,bold + #ZSH_HIGHLIGHT_STYLES[function]=fg=white,bold + #ZSH_HIGHLIGHT_STYLES[command]=fg=white,bold + #ZSH_HIGHLIGHT_STYLES[precommand]=fg=#eaff00,bold + #ZSH_HIGHLIGHT_STYLES[commandseparator]=none + #ZSH_HIGHLIGHT_STYLES[hashed-command]=fg=009 + #ZSH_HIGHLIGHT_STYLES[path]=fg=214,underline + #ZSH_HIGHLIGHT_STYLES[globbing]=fg=063 + #ZSH_HIGHLIGHT_STYLES[history-expansion]=fg=white,underline + #ZSH_HIGHLIGHT_STYLES[single-hyphen-option]=none + #ZSH_HIGHLIGHT_STYLES[double-hyphen-option]=none + #ZSH_HIGHLIGHT_STYLES[back-quoted-argument]=none + #ZSH_HIGHLIGHT_STYLES[single-quoted-argument]=fg=063 + #ZSH_HIGHLIGHT_STYLES[double-quoted-argument]=fg=063 + #ZSH_HIGHLIGHT_STYLES[dollar-double-quoted-argument]=fg=009 + #ZSH_HIGHLIGHT_STYLES[back-double-quoted-argument]=fg=009 + #ZSH_HIGHLIGHT_STYLES[assign]=none + + [[ ! -f "$ZDOTDIR/p10k.zsh" ]] || source "$ZDOTDIR/p10k.zsh" # To customize prompt, run `p10k configure` or edit ~/.config/zsh/p10k.zsh + #eval "$(starship init zsh)" # starship.rs prompt to replace p10k + + +source /usr/share/zsh/plugins/zsh-autosuggestions/zsh-autosuggestions.zsh # load fish-completion, needs to be sourced after syntax highlighting + ZSH_AUTOSUGGEST_HIGHLIGHT_STYLE="fg=#737373,bg=translucent" + + + + +#random stuff + +#zstyle ':completion:*' completer _complete _ignored _correct _approximate +#zstyle ':completion:*' matcher-list 'r:|[._-'\''"`´,;:]=** r:|=**' +#zstyle ':completion:*' original true + +#zstyle :compinstall filename '/home/en/.zshrc' + + + + + + +#if [[ -f ~/.dircolors ]] ; then + # eval $(dircolors -b ~/.dircolors) +#elif [[ -f /etc/DIR_COLORS ]] ; then + # eval $(dircolors -b /etc/DIR_COLORS) +#fi +# +function command_not_found_handler { + local purple='\e[1;35m' bright='\e[0;1m' green='\e[1;32m' reset='\e[0m' + printf 'zsh: command not found: %s\n' "$1" + local entries=( + ${(f)"$(/usr/bin/pacman -F --machinereadable -- "/usr/bin/$1")"} + ) + if (( ${#entries[@]} )) + then + printf "${bright}$1${reset} may be found in the following packages:\n" + local pkg + for entry in "${entries[@]}" + do + # (repo package version file) + local fields=( + ${(0)entry} + ) + if [[ "$pkg" != "${fields[2]}" ]] + then + printf "${purple}%s/${bright}%s ${green}%s${reset}\n" "${fields[1]}" "${fields[2]}" "${fields[3]}" + fi + printf ' /%s\n' "${fields[4]}" + pkg="${fields[2]}" + done + fi + return 127 +} diff --git a/.config/zsh/p10k.zsh b/.config/zsh/p10k.zsh new file mode 100644 index 0000000..3d871d1 --- /dev/null +++ b/.config/zsh/p10k.zsh @@ -0,0 +1,1643 @@ +# Generated by Powerlevel10k configuration wizard on 2022-09-17 at 04:19 CEST. +# Based on romkatv/powerlevel10k/config/p10k-classic.zsh, checksum 52170. +# Wizard options: nerdfont-complete + powerline, small icons, classic, unicode, light, +# angled separators, sharp heads, flat tails, 2 lines, disconnected, left frame, sparse, +# few icons, concise, transient_prompt, instant_prompt=verbose. +# Type `p10k configure` to generate another config. +# +# Config for Powerlevel10k with classic powerline prompt style. Type `p10k configure` to generate +# your own config based on it. +# +# Tip: Looking for a nice color? Here's a one-liner to print colormap. +# +# for i in {0..255}; do print -Pn "%K{$i} %k%F{$i}${(l:3::0:)i}%f " ${${(M)$((i%6)):#3}:+$'\n'}; done + +# Temporarily change options. +'builtin' 'local' '-a' 'p10k_config_opts' +[[ ! -o 'aliases' ]] || p10k_config_opts+=('aliases') +[[ ! -o 'sh_glob' ]] || p10k_config_opts+=('sh_glob') +[[ ! -o 'no_brace_expand' ]] || p10k_config_opts+=('no_brace_expand') +'builtin' 'setopt' 'no_aliases' 'no_sh_glob' 'brace_expand' + +() { + emulate -L zsh -o extended_glob + + # Unset all configuration options. This allows you to apply configuration changes without + # restarting zsh. Edit ~/.p10k.zsh and type `source ~/.p10k.zsh`. + unset -m '(POWERLEVEL9K_*|DEFAULT_USER)~POWERLEVEL9K_GITSTATUS_DIR' + + # Zsh >= 5.1 is required. + autoload -Uz is-at-least && is-at-least 5.1 || return + + # The list of segments shown on the left. Fill it with the most important segments. + typeset -g POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=( + # =========================[ Line #1 ]========================= + # os_icon # os identifier + context + dir # current directory + vcs # git status + # =========================[ Line #2 ]========================= + newline # \n + # prompt_char # prompt symbol + ) + + # The list of segments shown on the right. Fill it with less important segments. + # Right prompt on the last prompt line (where you are typing your commands) gets + # automatically hidden when the input line reaches it. Right prompt above the + # last prompt line gets hidden if it would overlap with left prompt. + typeset -g POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS=( + # =========================[ Line #1 ]========================= + status # exit code of the last command + command_execution_time # duration of the last command + background_jobs # presence of background jobs + direnv # direnv status (https://direnv.net/) + asdf # asdf version manager (https://github.com/asdf-vm/asdf) + virtualenv # python virtual environment (https://docs.python.org/3/library/venv.html) + anaconda # conda environment (https://conda.io/) + pyenv # python environment (https://github.com/pyenv/pyenv) + goenv # go environment (https://github.com/syndbg/goenv) + nodenv # node.js version from nodenv (https://github.com/nodenv/nodenv) + nvm # node.js version from nvm (https://github.com/nvm-sh/nvm) + nodeenv # node.js environment (https://github.com/ekalinin/nodeenv) + # node_version # node.js version + go_version # go version (https://golang.org) + rust_version # rustc version (https://www.rust-lang.org) + # dotnet_version # .NET version (https://dotnet.microsoft.com) + # php_version # php version (https://www.php.net/) + # laravel_version # laravel php framework version (https://laravel.com/) + java_version # java version (https://www.java.com/) + # package # name@version from package.json (https://docs.npmjs.com/files/package.json) + rbenv # ruby version from rbenv (https://github.com/rbenv/rbenv) + rvm # ruby version from rvm (https://rvm.io) + fvm # flutter version management (https://github.com/leoafarias/fvm) + luaenv # lua version from luaenv (https://github.com/cehoffman/luaenv) + jenv # java version from jenv (https://github.com/jenv/jenv) + plenv # perl version from plenv (https://github.com/tokuhirom/plenv) + phpenv # php version from phpenv (https://github.com/phpenv/phpenv) + scalaenv # scala version from scalaenv (https://github.com/scalaenv/scalaenv) + haskell_stack # haskell version from stack (https://haskellstack.org/) + kubecontext # current kubernetes context (https://kubernetes.io/) + terraform # terraform workspace (https://www.terraform.io) + # terraform_version # terraform version (https://www.terraform.io) + aws # aws profile (https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-profiles.html) + aws_eb_env # aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) + azure # azure account name (https://docs.microsoft.com/en-us/cli/azure) + gcloud # google cloud cli account and project (https://cloud.google.com/) + google_app_cred # google application credentials (https://cloud.google.com/docs/authentication/production) + toolbox # toolbox name (https://github.com/containers/toolbox) + context # user@hostname + nordvpn # nordvpn connection status, linux only (https://nordvpn.com/) + ranger # ranger shell (https://github.com/ranger/ranger) + nnn # nnn shell (https://github.com/jarun/nnn) + xplr # xplr shell (https://github.com/sayanarijit/xplr) + vim_shell # vim shell indicator (:sh) + midnight_commander # midnight commander shell (https://midnight-commander.org/) + nix_shell # nix shell (https://nixos.org/nixos/nix-pills/developing-with-nix-shell.html) + vi_mode # vi mode (you don't need this if you've enabled prompt_char) + # vpn_ip # virtual private network indicator + # load # CPU load + # disk_usage # disk usage + # ram # free RAM + # swap # used swap + todo # todo items (https://github.com/todotxt/todo.txt-cli) + timewarrior # timewarrior tracking status (https://timewarrior.net/) + taskwarrior # taskwarrior task count (https://taskwarrior.org/) + # time # current time + # =========================[ Line #2 ]========================= + newline # \n + # ip # ip address and bandwidth usage for a specified network interface + # public_ip # public IP address + # proxy # system-wide http/https/ftp proxy + # battery # internal battery + # wifi # wifi speed + # example # example user-defined segment (see prompt_example function below) + ) + + # Defines character set used by powerlevel10k. It's best to let `p10k configure` set it for you. + typeset -g POWERLEVEL9K_MODE=nerdfont-complete + # When set to `moderate`, some icons will have an extra space after them. This is meant to avoid + # icon overlap when using non-monospace fonts. When set to `none`, spaces are not added. + typeset -g POWERLEVEL9K_ICON_PADDING=none + + # When set to true, icons appear before content on both sides of the prompt. When set + # to false, icons go after content. If empty or not set, icons go before content in the left + # prompt and after content in the right prompt. + # + # You can also override it for a specific segment: + # + # POWERLEVEL9K_STATUS_ICON_BEFORE_CONTENT=false + # + # Or for a specific segment in specific state: + # + # POWERLEVEL9K_DIR_NOT_WRITABLE_ICON_BEFORE_CONTENT=false + typeset -g POWERLEVEL9K_ICON_BEFORE_CONTENT= + + # Add an empty line before each prompt. + typeset -g POWERLEVEL9K_PROMPT_ADD_NEWLINE=true + + # Connect left prompt lines with these symbols. You'll probably want to use the same color + # as POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_FOREGROUND below. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_PREFIX='%242F╭─' + typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_PREFIX='%242F├─' + typeset -g POWERLEVEL9K_MULTILINE_LAST_PROMPT_PREFIX='%242F╰─' + # Connect right prompt lines with these symbols. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_SUFFIX= + typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_SUFFIX= + typeset -g POWERLEVEL9K_MULTILINE_LAST_PROMPT_SUFFIX= + + # Filler between left and right prompt on the first prompt line. You can set it to ' ', '·' or + # '─'. The last two make it easier to see the alignment between left and right prompt and to + # separate prompt from command output. You might want to set POWERLEVEL9K_PROMPT_ADD_NEWLINE=false + # for more compact prompt if using this option. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR=' ' + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_BACKGROUND= + typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_GAP_BACKGROUND= + if [[ $POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR != ' ' ]]; then + # The color of the filler. You'll probably want to match the color of POWERLEVEL9K_MULTILINE + # ornaments defined above. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_FOREGROUND=242 + # Start filler from the edge of the screen if there are no left segments on the first line. + typeset -g POWERLEVEL9K_EMPTY_LINE_LEFT_PROMPT_FIRST_SEGMENT_END_SYMBOL='%{%}' + # End filler on the edge of the screen if there are no right segments on the first line. + typeset -g POWERLEVEL9K_EMPTY_LINE_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL='%{%}' + fi + + # Default background color. + typeset -g POWERLEVEL9K_BACKGROUND=238 + + # Separator between same-color segments on the left. + typeset -g POWERLEVEL9K_LEFT_SUBSEGMENT_SEPARATOR='%246F\uE0B1' + # Separator between same-color segments on the right. + typeset -g POWERLEVEL9K_RIGHT_SUBSEGMENT_SEPARATOR='%246F\uE0B3' + # Separator between different-color segments on the left. + typeset -g POWERLEVEL9K_LEFT_SEGMENT_SEPARATOR='\uE0B0' + # Separator between different-color segments on the right. + typeset -g POWERLEVEL9K_RIGHT_SEGMENT_SEPARATOR='\uE0B2' + # The right end of left prompt. + typeset -g POWERLEVEL9K_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL='\uE0B0' + # The left end of right prompt. + typeset -g POWERLEVEL9K_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL='\uE0B2' + # The left end of left prompt. + typeset -g POWERLEVEL9K_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL='' + # The right end of right prompt. + typeset -g POWERLEVEL9K_RIGHT_PROMPT_LAST_SEGMENT_END_SYMBOL='' + # Left prompt terminator for lines without any segments. + typeset -g POWERLEVEL9K_EMPTY_LINE_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL= + + #################################[ os_icon: os identifier ]################################## + # OS identifier color. + typeset -g POWERLEVEL9K_OS_ICON_FOREGROUND=255 + # Custom icon. + # typeset -g POWERLEVEL9K_OS_ICON_CONTENT_EXPANSION='⭐' + + ################################[ prompt_char: prompt symbol ]################################ + # Transparent background. + typeset -g POWERLEVEL9K_PROMPT_CHAR_BACKGROUND= + # Green prompt symbol if the last command succeeded. + typeset -g POWERLEVEL9K_PROMPT_CHAR_OK_{VIINS,VICMD,VIVIS,VIOWR}_FOREGROUND=76 + # Red prompt symbol if the last command failed. + typeset -g POWERLEVEL9K_PROMPT_CHAR_ERROR_{VIINS,VICMD,VIVIS,VIOWR}_FOREGROUND=196 + # Default prompt symbol. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIINS_CONTENT_EXPANSION='❯' + # Prompt symbol in command vi mode. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VICMD_CONTENT_EXPANSION='❮' + # Prompt symbol in visual vi mode. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIVIS_CONTENT_EXPANSION='V' + # Prompt symbol in overwrite vi mode. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIOWR_CONTENT_EXPANSION='▶' + typeset -g POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE=true + # No line terminator if prompt_char is the last segment. + typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL= + # No line introducer if prompt_char is the first segment. + typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL= + # No surrounding whitespace. + typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_{LEFT,RIGHT}_WHITESPACE= + + ##################################[ dir: current directory ]################################## + # Default current directory color. + typeset -g POWERLEVEL9K_DIR_FOREGROUND=31 + # If directory is too long, shorten some of its segments to the shortest possible unique + # prefix. The shortened directory can be tab-completed to the original. + typeset -g POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique + # Replace removed segment suffixes with this symbol. + typeset -g POWERLEVEL9K_SHORTEN_DELIMITER= + # Color of the shortened directory segments. + typeset -g POWERLEVEL9K_DIR_SHORTENED_FOREGROUND=103 + # Color of the anchor directory segments. Anchor segments are never shortened. The first + # segment is always an anchor. + typeset -g POWERLEVEL9K_DIR_ANCHOR_FOREGROUND=39 + # Display anchor directory segments in bold. + typeset -g POWERLEVEL9K_DIR_ANCHOR_BOLD=true + # Don't shorten directories that contain any of these files. They are anchors. + local anchor_files=( + .bzr + .citc + .git + .hg + .node-version + .python-version + .go-version + .ruby-version + .lua-version + .java-version + .perl-version + .php-version + .tool-version + .shorten_folder_marker + .svn + .terraform + CVS + Cargo.toml + composer.json + go.mod + package.json + stack.yaml + ) + typeset -g POWERLEVEL9K_SHORTEN_FOLDER_MARKER="(${(j:|:)anchor_files})" + # If set to "first" ("last"), remove everything before the first (last) subdirectory that contains + # files matching $POWERLEVEL9K_SHORTEN_FOLDER_MARKER. For example, when the current directory is + # /foo/bar/git_repo/nested_git_repo/baz, prompt will display git_repo/nested_git_repo/baz (first) + # or nested_git_repo/baz (last). This assumes that git_repo and nested_git_repo contain markers + # and other directories don't. + # + # Optionally, "first" and "last" can be followed by ":" where is an integer. + # This moves the truncation point to the right (positive offset) or to the left (negative offset) + # relative to the marker. Plain "first" and "last" are equivalent to "first:0" and "last:0" + # respectively. + typeset -g POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER=false + # Don't shorten this many last directory segments. They are anchors. + typeset -g POWERLEVEL9K_SHORTEN_DIR_LENGTH=1 + # Shorten directory if it's longer than this even if there is space for it. The value can + # be either absolute (e.g., '80') or a percentage of terminal width (e.g, '50%'). If empty, + # directory will be shortened only when prompt doesn't fit or when other parameters demand it + # (see POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS and POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT below). + # If set to `0`, directory will always be shortened to its minimum length. + typeset -g POWERLEVEL9K_DIR_MAX_LENGTH=80 + # When `dir` segment is on the last prompt line, try to shorten it enough to leave at least this + # many columns for typing commands. + typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS=40 + # When `dir` segment is on the last prompt line, try to shorten it enough to leave at least + # COLUMNS * POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT * 0.01 columns for typing commands. + typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT=50 + # If set to true, embed a hyperlink into the directory. Useful for quickly + # opening a directory in the file manager simply by clicking the link. + # Can also be handy when the directory is shortened, as it allows you to see + # the full directory that was used in previous commands. + typeset -g POWERLEVEL9K_DIR_HYPERLINK=false + + # Enable special styling for non-writable and non-existent directories. See POWERLEVEL9K_LOCK_ICON + # and POWERLEVEL9K_DIR_CLASSES below. + typeset -g POWERLEVEL9K_DIR_SHOW_WRITABLE=v3 + + # The default icon shown next to non-writable and non-existent directories when + # POWERLEVEL9K_DIR_SHOW_WRITABLE is set to v3. + # typeset -g POWERLEVEL9K_LOCK_ICON='⭐' + + # POWERLEVEL9K_DIR_CLASSES allows you to specify custom icons and colors for different + # directories. It must be an array with 3 * N elements. Each triplet consists of: + # + # 1. A pattern against which the current directory ($PWD) is matched. Matching is done with + # extended_glob option enabled. + # 2. Directory class for the purpose of styling. + # 3. An empty string. + # + # Triplets are tried in order. The first triplet whose pattern matches $PWD wins. + # + # If POWERLEVEL9K_DIR_SHOW_WRITABLE is set to v3, non-writable and non-existent directories + # acquire class suffix _NOT_WRITABLE and NON_EXISTENT respectively. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_DIR_CLASSES=( + # '~/work(|/*)' WORK '' + # '~(|/*)' HOME '' + # '*' DEFAULT '') + # + # Whenever the current directory is ~/work or a subdirectory of ~/work, it gets styled with one + # of the following classes depending on its writability and existence: WORK, WORK_NOT_WRITABLE or + # WORK_NON_EXISTENT. + # + # Simply assigning classes to directories doesn't have any visible effects. It merely gives you an + # option to define custom colors and icons for different directory classes. + # + # # Styling for WORK. + # typeset -g POWERLEVEL9K_DIR_WORK_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_DIR_WORK_FOREGROUND=31 + # typeset -g POWERLEVEL9K_DIR_WORK_SHORTENED_FOREGROUND=103 + # typeset -g POWERLEVEL9K_DIR_WORK_ANCHOR_FOREGROUND=39 + # + # # Styling for WORK_NOT_WRITABLE. + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_FOREGROUND=31 + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_SHORTENED_FOREGROUND=103 + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_ANCHOR_FOREGROUND=39 + # + # # Styling for WORK_NON_EXISTENT. + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_FOREGROUND=31 + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_SHORTENED_FOREGROUND=103 + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_ANCHOR_FOREGROUND=39 + # + # If a styling parameter isn't explicitly defined for some class, it falls back to the classless + # parameter. For example, if POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_FOREGROUND is not set, it falls + # back to POWERLEVEL9K_DIR_FOREGROUND. + # + typeset -g POWERLEVEL9K_DIR_CLASSES=() + + # Custom prefix. + # typeset -g POWERLEVEL9K_DIR_PREFIX='%248Fin ' + + #####################################[ vcs: git status ]###################################### + # Branch icon. Set this parameter to '\uF126 ' for the popular Powerline branch icon. + typeset -g POWERLEVEL9K_VCS_BRANCH_ICON= + + # Untracked files icon. It's really a question mark, your font isn't broken. + # Change the value of this parameter to show a different icon. + typeset -g POWERLEVEL9K_VCS_UNTRACKED_ICON='?' + + # Formatter for Git status. + # + # Example output: master wip ⇣42⇡42 *42 merge ~42 +42 !42 ?42. + # + # You can edit the function to customize how Git status looks. + # + # VCS_STATUS_* parameters are set by gitstatus plugin. See reference: + # https://github.com/romkatv/gitstatus/blob/master/gitstatus.plugin.zsh. + function my_git_formatter() { + emulate -L zsh + + if [[ -n $P9K_CONTENT ]]; then + # If P9K_CONTENT is not empty, use it. It's either "loading" or from vcs_info (not from + # gitstatus plugin). VCS_STATUS_* parameters are not available in this case. + typeset -g my_git_format=$P9K_CONTENT + return + fi + + if (( $1 )); then + # Styling for up-to-date Git status. + local meta='%248F' # grey foreground + local clean='%76F' # green foreground + local modified='%178F' # yellow foreground + local untracked='%39F' # blue foreground + local conflicted='%196F' # red foreground + else + # Styling for incomplete and stale Git status. + local meta='%244F' # grey foreground + local clean='%244F' # grey foreground + local modified='%244F' # grey foreground + local untracked='%244F' # grey foreground + local conflicted='%244F' # grey foreground + fi + + local res + + if [[ -n $VCS_STATUS_LOCAL_BRANCH ]]; then + local branch=${(V)VCS_STATUS_LOCAL_BRANCH} + # If local branch name is at most 32 characters long, show it in full. + # Otherwise show the first 12 … the last 12. + # Tip: To always show local branch name in full without truncation, delete the next line. + (( $#branch > 32 )) && branch[13,-13]="…" # <-- this line + res+="${clean}${(g::)POWERLEVEL9K_VCS_BRANCH_ICON}${branch//\%/%%}" + fi + + if [[ -n $VCS_STATUS_TAG + # Show tag only if not on a branch. + # Tip: To always show tag, delete the next line. + && -z $VCS_STATUS_LOCAL_BRANCH # <-- this line + ]]; then + local tag=${(V)VCS_STATUS_TAG} + # If tag name is at most 32 characters long, show it in full. + # Otherwise show the first 12 … the last 12. + # Tip: To always show tag name in full without truncation, delete the next line. + (( $#tag > 32 )) && tag[13,-13]="…" # <-- this line + res+="${meta}#${clean}${tag//\%/%%}" + fi + + # Display the current Git commit if there is no branch and no tag. + # Tip: To always display the current Git commit, delete the next line. + [[ -z $VCS_STATUS_LOCAL_BRANCH && -z $VCS_STATUS_TAG ]] && # <-- this line + res+="${meta}@${clean}${VCS_STATUS_COMMIT[1,8]}" + + # Show tracking branch name if it differs from local branch. + if [[ -n ${VCS_STATUS_REMOTE_BRANCH:#$VCS_STATUS_LOCAL_BRANCH} ]]; then + res+="${meta}:${clean}${(V)VCS_STATUS_REMOTE_BRANCH//\%/%%}" + fi + + # Display "wip" if the latest commit's summary contains "wip" or "WIP". + if [[ $VCS_STATUS_COMMIT_SUMMARY == (|*[^[:alnum:]])(wip|WIP)(|[^[:alnum:]]*) ]]; then + res+=" ${modified}wip" + fi + + # ⇣42 if behind the remote. + (( VCS_STATUS_COMMITS_BEHIND )) && res+=" ${clean}⇣${VCS_STATUS_COMMITS_BEHIND}" + # ⇡42 if ahead of the remote; no leading space if also behind the remote: ⇣42⇡42. + (( VCS_STATUS_COMMITS_AHEAD && !VCS_STATUS_COMMITS_BEHIND )) && res+=" " + (( VCS_STATUS_COMMITS_AHEAD )) && res+="${clean}⇡${VCS_STATUS_COMMITS_AHEAD}" + # ⇠42 if behind the push remote. + (( VCS_STATUS_PUSH_COMMITS_BEHIND )) && res+=" ${clean}⇠${VCS_STATUS_PUSH_COMMITS_BEHIND}" + (( VCS_STATUS_PUSH_COMMITS_AHEAD && !VCS_STATUS_PUSH_COMMITS_BEHIND )) && res+=" " + # ⇢42 if ahead of the push remote; no leading space if also behind: ⇠42⇢42. + (( VCS_STATUS_PUSH_COMMITS_AHEAD )) && res+="${clean}⇢${VCS_STATUS_PUSH_COMMITS_AHEAD}" + # *42 if have stashes. + (( VCS_STATUS_STASHES )) && res+=" ${clean}*${VCS_STATUS_STASHES}" + # 'merge' if the repo is in an unusual state. + [[ -n $VCS_STATUS_ACTION ]] && res+=" ${conflicted}${VCS_STATUS_ACTION}" + # ~42 if have merge conflicts. + (( VCS_STATUS_NUM_CONFLICTED )) && res+=" ${conflicted}~${VCS_STATUS_NUM_CONFLICTED}" + # +42 if have staged changes. + (( VCS_STATUS_NUM_STAGED )) && res+=" ${modified}+${VCS_STATUS_NUM_STAGED}" + # !42 if have unstaged changes. + (( VCS_STATUS_NUM_UNSTAGED )) && res+=" ${modified}!${VCS_STATUS_NUM_UNSTAGED}" + # ?42 if have untracked files. It's really a question mark, your font isn't broken. + # See POWERLEVEL9K_VCS_UNTRACKED_ICON above if you want to use a different icon. + # Remove the next line if you don't want to see untracked files at all. + (( VCS_STATUS_NUM_UNTRACKED )) && res+=" ${untracked}${(g::)POWERLEVEL9K_VCS_UNTRACKED_ICON}${VCS_STATUS_NUM_UNTRACKED}" + # "─" if the number of unstaged files is unknown. This can happen due to + # POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY (see below) being set to a non-negative number lower + # than the number of files in the Git index, or due to bash.showDirtyState being set to false + # in the repository config. The number of staged and untracked files may also be unknown + # in this case. + (( VCS_STATUS_HAS_UNSTAGED == -1 )) && res+=" ${modified}─" + + typeset -g my_git_format=$res + } + functions -M my_git_formatter 2>/dev/null + + # Don't count the number of unstaged, untracked and conflicted files in Git repositories with + # more than this many files in the index. Negative value means infinity. + # + # If you are working in Git repositories with tens of millions of files and seeing performance + # sagging, try setting POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY to a number lower than the output + # of `git ls-files | wc -l`. Alternatively, add `bash.showDirtyState = false` to the repository's + # config: `git config bash.showDirtyState false`. + typeset -g POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY=-1 + + # Don't show Git status in prompt for repositories whose workdir matches this pattern. + # For example, if set to '~', the Git repository at $HOME/.git will be ignored. + # Multiple patterns can be combined with '|': '~(|/foo)|/bar/baz/*'. + typeset -g POWERLEVEL9K_VCS_DISABLED_WORKDIR_PATTERN='~' + + # Disable the default Git status formatting. + typeset -g POWERLEVEL9K_VCS_DISABLE_GITSTATUS_FORMATTING=true + # Install our own Git status formatter. + typeset -g POWERLEVEL9K_VCS_CONTENT_EXPANSION='${$((my_git_formatter(1)))+${my_git_format}}' + typeset -g POWERLEVEL9K_VCS_LOADING_CONTENT_EXPANSION='${$((my_git_formatter(0)))+${my_git_format}}' + # Enable counters for staged, unstaged, etc. + typeset -g POWERLEVEL9K_VCS_{STAGED,UNSTAGED,UNTRACKED,CONFLICTED,COMMITS_AHEAD,COMMITS_BEHIND}_MAX_NUM=-1 + + # Icon color. + typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_COLOR=76 + typeset -g POWERLEVEL9K_VCS_LOADING_VISUAL_IDENTIFIER_COLOR=244 + # Custom icon. + typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_EXPANSION= + # Custom prefix. + # typeset -g POWERLEVEL9K_VCS_PREFIX='%248Fon ' + + # Show status of repositories of these types. You can add svn and/or hg if you are + # using them. If you do, your prompt may become slow even when your current directory + # isn't in an svn or hg reposotiry. + typeset -g POWERLEVEL9K_VCS_BACKENDS=(git) + + # These settings are used for repositories other than Git or when gitstatusd fails and + # Powerlevel10k has to fall back to using vcs_info. + typeset -g POWERLEVEL9K_VCS_CLEAN_FOREGROUND=76 + typeset -g POWERLEVEL9K_VCS_UNTRACKED_FOREGROUND=76 + typeset -g POWERLEVEL9K_VCS_MODIFIED_FOREGROUND=178 + + ##########################[ status: exit code of the last command ]########################### + # Enable OK_PIPE, ERROR_PIPE and ERROR_SIGNAL status states to allow us to enable, disable and + # style them independently from the regular OK and ERROR state. + typeset -g POWERLEVEL9K_STATUS_EXTENDED_STATES=true + + # Status on success. No content, just an icon. No need to show it if prompt_char is enabled as + # it will signify success by turning green. + typeset -g POWERLEVEL9K_STATUS_OK=true + typeset -g POWERLEVEL9K_STATUS_OK_FOREGROUND=70 + typeset -g POWERLEVEL9K_STATUS_OK_VISUAL_IDENTIFIER_EXPANSION='✔' + + # Status when some part of a pipe command fails but the overall exit status is zero. It may look + # like this: 1|0. + typeset -g POWERLEVEL9K_STATUS_OK_PIPE=true + typeset -g POWERLEVEL9K_STATUS_OK_PIPE_FOREGROUND=70 + typeset -g POWERLEVEL9K_STATUS_OK_PIPE_VISUAL_IDENTIFIER_EXPANSION='✔' + + # Status when it's just an error code (e.g., '1'). No need to show it if prompt_char is enabled as + # it will signify error by turning red. + typeset -g POWERLEVEL9K_STATUS_ERROR=true + typeset -g POWERLEVEL9K_STATUS_ERROR_FOREGROUND=160 + typeset -g POWERLEVEL9K_STATUS_ERROR_VISUAL_IDENTIFIER_EXPANSION='✘' + + # Status when the last command was terminated by a signal. + typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL=true + typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_FOREGROUND=160 + # Use terse signal names: "INT" instead of "SIGINT(2)". + typeset -g POWERLEVEL9K_STATUS_VERBOSE_SIGNAME=false + typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_VISUAL_IDENTIFIER_EXPANSION='✘' + + # Status when some part of a pipe command fails and the overall exit status is also non-zero. + # It may look like this: 1|0. + typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE=true + typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_FOREGROUND=160 + typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_VISUAL_IDENTIFIER_EXPANSION='✘' + + ###################[ command_execution_time: duration of the last command ]################### + # Show duration of the last command if takes at least this many seconds. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=3 + # Show this many fractional digits. Zero means round to seconds. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=0 + # Execution time color. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FOREGROUND=248 + # Duration format: 1d 2h 3m 4s. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FORMAT='d h m s' + # Custom icon. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_VISUAL_IDENTIFIER_EXPANSION= + # Custom prefix. + # typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PREFIX='%248Ftook ' + + #######################[ background_jobs: presence of background jobs ]####################### + # Don't show the number of background jobs. + typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE=false + # Background jobs color. + typeset -g POWERLEVEL9K_BACKGROUND_JOBS_FOREGROUND=37 + # Custom icon. + # typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######################[ direnv: direnv status (https://direnv.net/) ]######################## + # Direnv color. + typeset -g POWERLEVEL9K_DIRENV_FOREGROUND=178 + # Custom icon. + # typeset -g POWERLEVEL9K_DIRENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###############[ asdf: asdf version manager (https://github.com/asdf-vm/asdf) ]############### + # Default asdf color. Only used to display tools for which there is no color override (see below). + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_FOREGROUND. + typeset -g POWERLEVEL9K_ASDF_FOREGROUND=66 + + # There are four parameters that can be used to hide asdf tools. Each parameter describes + # conditions under which a tool gets hidden. Parameters can hide tools but not unhide them. If at + # least one parameter decides to hide a tool, that tool gets hidden. If no parameter decides to + # hide a tool, it gets shown. + # + # Special note on the difference between POWERLEVEL9K_ASDF_SOURCES and + # POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW. Consider the effect of the following commands: + # + # asdf local python 3.8.1 + # asdf global python 3.8.1 + # + # After running both commands the current python version is 3.8.1 and its source is "local" as + # it takes precedence over "global". If POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW is set to false, + # it'll hide python version in this case because 3.8.1 is the same as the global version. + # POWERLEVEL9K_ASDF_SOURCES will hide python version only if the value of this parameter doesn't + # contain "local". + + # Hide tool versions that don't come from one of these sources. + # + # Available sources: + # + # - shell `asdf current` says "set by ASDF_${TOOL}_VERSION environment variable" + # - local `asdf current` says "set by /some/not/home/directory/file" + # - global `asdf current` says "set by /home/username/file" + # + # Note: If this parameter is set to (shell local global), it won't hide tools. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SOURCES. + typeset -g POWERLEVEL9K_ASDF_SOURCES=(shell local global) + + # If set to false, hide tool versions that are the same as global. + # + # Note: The name of this parameter doesn't reflect its meaning at all. + # Note: If this parameter is set to true, it won't hide tools. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_PROMPT_ALWAYS_SHOW. + typeset -g POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW=false + + # If set to false, hide tool versions that are equal to "system". + # + # Note: If this parameter is set to true, it won't hide tools. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SHOW_SYSTEM. + typeset -g POWERLEVEL9K_ASDF_SHOW_SYSTEM=true + + # If set to non-empty value, hide tools unless there is a file matching the specified file pattern + # in the current directory, or its parent directory, or its grandparent directory, and so on. + # + # Note: If this parameter is set to empty value, it won't hide tools. + # Note: SHOW_ON_UPGLOB isn't specific to asdf. It works with all prompt segments. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SHOW_ON_UPGLOB. + # + # Example: Hide nodejs version when there is no package.json and no *.js files in the current + # directory, in `..`, in `../..` and so on. + # + # typeset -g POWERLEVEL9K_ASDF_NODEJS_SHOW_ON_UPGLOB='*.js|package.json' + typeset -g POWERLEVEL9K_ASDF_SHOW_ON_UPGLOB= + + # Ruby version from asdf. + typeset -g POWERLEVEL9K_ASDF_RUBY_FOREGROUND=168 + # typeset -g POWERLEVEL9K_ASDF_RUBY_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_RUBY_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Python version from asdf. + typeset -g POWERLEVEL9K_ASDF_PYTHON_FOREGROUND=37 + # typeset -g POWERLEVEL9K_ASDF_PYTHON_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_PYTHON_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Go version from asdf. + typeset -g POWERLEVEL9K_ASDF_GOLANG_FOREGROUND=37 + # typeset -g POWERLEVEL9K_ASDF_GOLANG_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_GOLANG_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Node.js version from asdf. + typeset -g POWERLEVEL9K_ASDF_NODEJS_FOREGROUND=70 + # typeset -g POWERLEVEL9K_ASDF_NODEJS_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_NODEJS_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Rust version from asdf. + typeset -g POWERLEVEL9K_ASDF_RUST_FOREGROUND=37 + # typeset -g POWERLEVEL9K_ASDF_RUST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_RUST_SHOW_ON_UPGLOB='*.foo|*.bar' + + # .NET Core version from asdf. + typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_FOREGROUND=134 + # typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Flutter version from asdf. + typeset -g POWERLEVEL9K_ASDF_FLUTTER_FOREGROUND=38 + # typeset -g POWERLEVEL9K_ASDF_FLUTTER_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_FLUTTER_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Lua version from asdf. + typeset -g POWERLEVEL9K_ASDF_LUA_FOREGROUND=32 + # typeset -g POWERLEVEL9K_ASDF_LUA_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_LUA_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Java version from asdf. + typeset -g POWERLEVEL9K_ASDF_JAVA_FOREGROUND=32 + # typeset -g POWERLEVEL9K_ASDF_JAVA_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_JAVA_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Perl version from asdf. + typeset -g POWERLEVEL9K_ASDF_PERL_FOREGROUND=67 + # typeset -g POWERLEVEL9K_ASDF_PERL_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_PERL_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Erlang version from asdf. + typeset -g POWERLEVEL9K_ASDF_ERLANG_FOREGROUND=125 + # typeset -g POWERLEVEL9K_ASDF_ERLANG_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_ERLANG_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Elixir version from asdf. + typeset -g POWERLEVEL9K_ASDF_ELIXIR_FOREGROUND=129 + # typeset -g POWERLEVEL9K_ASDF_ELIXIR_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_ELIXIR_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Postgres version from asdf. + typeset -g POWERLEVEL9K_ASDF_POSTGRES_FOREGROUND=31 + # typeset -g POWERLEVEL9K_ASDF_POSTGRES_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_POSTGRES_SHOW_ON_UPGLOB='*.foo|*.bar' + + # PHP version from asdf. + typeset -g POWERLEVEL9K_ASDF_PHP_FOREGROUND=99 + # typeset -g POWERLEVEL9K_ASDF_PHP_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_PHP_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Haskell version from asdf. + typeset -g POWERLEVEL9K_ASDF_HASKELL_FOREGROUND=172 + # typeset -g POWERLEVEL9K_ASDF_HASKELL_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_HASKELL_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Julia version from asdf. + typeset -g POWERLEVEL9K_ASDF_JULIA_FOREGROUND=70 + # typeset -g POWERLEVEL9K_ASDF_JULIA_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_JULIA_SHOW_ON_UPGLOB='*.foo|*.bar' + + ##########[ nordvpn: nordvpn connection status, linux only (https://nordvpn.com/) ]########### + # NordVPN connection indicator color. + typeset -g POWERLEVEL9K_NORDVPN_FOREGROUND=39 + # Hide NordVPN connection indicator when not connected. + typeset -g POWERLEVEL9K_NORDVPN_{DISCONNECTED,CONNECTING,DISCONNECTING}_CONTENT_EXPANSION= + typeset -g POWERLEVEL9K_NORDVPN_{DISCONNECTED,CONNECTING,DISCONNECTING}_VISUAL_IDENTIFIER_EXPANSION= + # Custom icon. + # typeset -g POWERLEVEL9K_NORDVPN_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #################[ ranger: ranger shell (https://github.com/ranger/ranger) ]################## + # Ranger shell color. + typeset -g POWERLEVEL9K_RANGER_FOREGROUND=178 + # Custom icon. + # typeset -g POWERLEVEL9K_RANGER_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######################[ nnn: nnn shell (https://github.com/jarun/nnn) ]####################### + # Nnn shell color. + typeset -g POWERLEVEL9K_NNN_FOREGROUND=72 + # Custom icon. + # typeset -g POWERLEVEL9K_NNN_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##################[ xplr: xplr shell (https://github.com/sayanarijit/xplr) ]################## + # xplr shell color. + typeset -g POWERLEVEL9K_XPLR_FOREGROUND=72 + # Custom icon. + # typeset -g POWERLEVEL9K_XPLR_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########################[ vim_shell: vim shell indicator (:sh) ]########################### + # Vim shell indicator color. + typeset -g POWERLEVEL9K_VIM_SHELL_FOREGROUND=34 + # Custom icon. + # typeset -g POWERLEVEL9K_VIM_SHELL_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######[ midnight_commander: midnight commander shell (https://midnight-commander.org/) ]###### + # Midnight Commander shell color. + typeset -g POWERLEVEL9K_MIDNIGHT_COMMANDER_FOREGROUND=178 + # Custom icon. + # typeset -g POWERLEVEL9K_MIDNIGHT_COMMANDER_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #[ nix_shell: nix shell (https://nixos.org/nixos/nix-pills/developing-with-nix-shell.html) ]## + # Nix shell color. + typeset -g POWERLEVEL9K_NIX_SHELL_FOREGROUND=74 + + # Tip: If you want to see just the icon without "pure" and "impure", uncomment the next line. + # typeset -g POWERLEVEL9K_NIX_SHELL_CONTENT_EXPANSION= + + # Custom icon. + # typeset -g POWERLEVEL9K_NIX_SHELL_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##################################[ disk_usage: disk usage ]################################## + # Colors for different levels of disk usage. + typeset -g POWERLEVEL9K_DISK_USAGE_NORMAL_FOREGROUND=35 + typeset -g POWERLEVEL9K_DISK_USAGE_WARNING_FOREGROUND=220 + typeset -g POWERLEVEL9K_DISK_USAGE_CRITICAL_FOREGROUND=160 + # Thresholds for different levels of disk usage (percentage points). + typeset -g POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL=90 + typeset -g POWERLEVEL9K_DISK_USAGE_CRITICAL_LEVEL=95 + # If set to true, hide disk usage when below $POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL percent. + typeset -g POWERLEVEL9K_DISK_USAGE_ONLY_WARNING=false + # Custom icon. + # typeset -g POWERLEVEL9K_DISK_USAGE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ vi_mode: vi mode (you don't need this if you've enabled prompt_char) ]########### + # Text and color for normal (a.k.a. command) vi mode. + typeset -g POWERLEVEL9K_VI_COMMAND_MODE_STRING=NORMAL + typeset -g POWERLEVEL9K_VI_MODE_NORMAL_FOREGROUND=106 + # Text and color for visual vi mode. + typeset -g POWERLEVEL9K_VI_VISUAL_MODE_STRING=VISUAL + typeset -g POWERLEVEL9K_VI_MODE_VISUAL_FOREGROUND=68 + # Text and color for overtype (a.k.a. overwrite and replace) vi mode. + typeset -g POWERLEVEL9K_VI_OVERWRITE_MODE_STRING=OVERTYPE + typeset -g POWERLEVEL9K_VI_MODE_OVERWRITE_FOREGROUND=172 + # Text and color for insert vi mode. + typeset -g POWERLEVEL9K_VI_INSERT_MODE_STRING= + typeset -g POWERLEVEL9K_VI_MODE_INSERT_FOREGROUND=66 + + # Custom icon. + # typeset -g POWERLEVEL9K_RANGER_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######################################[ ram: free RAM ]####################################### + # RAM color. + typeset -g POWERLEVEL9K_RAM_FOREGROUND=66 + # Custom icon. + # typeset -g POWERLEVEL9K_RAM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #####################################[ swap: used swap ]###################################### + # Swap color. + typeset -g POWERLEVEL9K_SWAP_FOREGROUND=96 + # Custom icon. + # typeset -g POWERLEVEL9K_SWAP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######################################[ load: CPU load ]###################################### + # Show average CPU load over this many last minutes. Valid values are 1, 5 and 15. + typeset -g POWERLEVEL9K_LOAD_WHICH=5 + # Load color when load is under 50%. + typeset -g POWERLEVEL9K_LOAD_NORMAL_FOREGROUND=66 + # Load color when load is between 50% and 70%. + typeset -g POWERLEVEL9K_LOAD_WARNING_FOREGROUND=178 + # Load color when load is over 70%. + typeset -g POWERLEVEL9K_LOAD_CRITICAL_FOREGROUND=166 + # Custom icon. + # typeset -g POWERLEVEL9K_LOAD_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ todo: todo items (https://github.com/todotxt/todo.txt-cli) ]################ + # Todo color. + typeset -g POWERLEVEL9K_TODO_FOREGROUND=110 + # Hide todo when the total number of tasks is zero. + typeset -g POWERLEVEL9K_TODO_HIDE_ZERO_TOTAL=true + # Hide todo when the number of tasks after filtering is zero. + typeset -g POWERLEVEL9K_TODO_HIDE_ZERO_FILTERED=false + + # Todo format. The following parameters are available within the expansion. + # + # - P9K_TODO_TOTAL_TASK_COUNT The total number of tasks. + # - P9K_TODO_FILTERED_TASK_COUNT The number of tasks after filtering. + # + # These variables correspond to the last line of the output of `todo.sh -p ls`: + # + # TODO: 24 of 42 tasks shown + # + # Here 24 is P9K_TODO_FILTERED_TASK_COUNT and 42 is P9K_TODO_TOTAL_TASK_COUNT. + # + # typeset -g POWERLEVEL9K_TODO_CONTENT_EXPANSION='$P9K_TODO_FILTERED_TASK_COUNT' + + # Custom icon. + # typeset -g POWERLEVEL9K_TODO_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ timewarrior: timewarrior tracking status (https://timewarrior.net/) ]############ + # Timewarrior color. + typeset -g POWERLEVEL9K_TIMEWARRIOR_FOREGROUND=110 + # If the tracked task is longer than 24 characters, truncate and append "…". + # Tip: To always display tasks without truncation, delete the following parameter. + # Tip: To hide task names and display just the icon when time tracking is enabled, set the + # value of the following parameter to "". + typeset -g POWERLEVEL9K_TIMEWARRIOR_CONTENT_EXPANSION='${P9K_CONTENT:0:24}${${P9K_CONTENT:24}:+…}' + + # Custom icon. + # typeset -g POWERLEVEL9K_TIMEWARRIOR_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##############[ taskwarrior: taskwarrior task count (https://taskwarrior.org/) ]############## + # Taskwarrior color. + typeset -g POWERLEVEL9K_TASKWARRIOR_FOREGROUND=74 + + # Taskwarrior segment format. The following parameters are available within the expansion. + # + # - P9K_TASKWARRIOR_PENDING_COUNT The number of pending tasks: `task +PENDING count`. + # - P9K_TASKWARRIOR_OVERDUE_COUNT The number of overdue tasks: `task +OVERDUE count`. + # + # Zero values are represented as empty parameters. + # + # The default format: + # + # '${P9K_TASKWARRIOR_OVERDUE_COUNT:+"!$P9K_TASKWARRIOR_OVERDUE_COUNT/"}$P9K_TASKWARRIOR_PENDING_COUNT' + # + # typeset -g POWERLEVEL9K_TASKWARRIOR_CONTENT_EXPANSION='$P9K_TASKWARRIOR_PENDING_COUNT' + + # Custom icon. + # typeset -g POWERLEVEL9K_TASKWARRIOR_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##################################[ context: user@hostname ]################################## + # Context color when running with privileges. + typeset -g POWERLEVEL9K_CONTEXT_ROOT_FOREGROUND=178 + # Context color in SSH without privileges. + typeset -g POWERLEVEL9K_CONTEXT_{REMOTE,REMOTE_SUDO}_FOREGROUND=180 + # Default context color (no privileges, no SSH). + typeset -g POWERLEVEL9K_CONTEXT_FOREGROUND=180 + + # Context format when running with privileges: bold user@hostname. + typeset -g POWERLEVEL9K_CONTEXT_ROOT_TEMPLATE='%B%n@%m' + # Context format when in SSH without privileges: user@hostname. + typeset -g POWERLEVEL9K_CONTEXT_{REMOTE,REMOTE_SUDO}_TEMPLATE='%n@%m' + # Default context format (no privileges, no SSH): user@hostname. + typeset -g POWERLEVEL9K_CONTEXT_TEMPLATE='%n@%m' + + # Don't show context unless running with privileges or in SSH. + # Tip: Remove the next line to always show context. + typeset -g POWERLEVEL9K_CONTEXT_{DEFAULT,SUDO}_{CONTENT,VISUAL_IDENTIFIER}_EXPANSION= + + # Custom icon. + # typeset -g POWERLEVEL9K_CONTEXT_VISUAL_IDENTIFIER_EXPANSION='⭐' + # Custom prefix. + # typeset -g POWERLEVEL9K_CONTEXT_PREFIX='%248Fwith ' + + ###[ virtualenv: python virtual environment (https://docs.python.org/3/library/venv.html) ]### + # Python virtual environment color. + typeset -g POWERLEVEL9K_VIRTUALENV_FOREGROUND=37 + # Don't show Python version next to the virtual environment name. + typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_PYTHON_VERSION=false + # If set to "false", won't show virtualenv if pyenv is already shown. + # If set to "if-different", won't show virtualenv if it's the same as pyenv. + typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_WITH_PYENV=false + # Separate environment name from Python version only with a space. + typeset -g POWERLEVEL9K_VIRTUALENV_{LEFT,RIGHT}_DELIMITER= + # Custom icon. + # typeset -g POWERLEVEL9K_VIRTUALENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + typeset -g POWERLEVEL9K_VIRTUALENV_GENERIC_NAMES=(virtualenv venv .venv env .env) + + #####################[ anaconda: conda environment (https://conda.io/) ]###################### + # Anaconda environment color. + typeset -g POWERLEVEL9K_ANACONDA_FOREGROUND=37 + + # Anaconda segment format. The following parameters are available within the expansion. + # + # - CONDA_PREFIX Absolute path to the active Anaconda/Miniconda environment. + # - CONDA_DEFAULT_ENV Name of the active Anaconda/Miniconda environment. + # - CONDA_PROMPT_MODIFIER Configurable prompt modifier (see below). + # - P9K_ANACONDA_PYTHON_VERSION Current python version (python --version). + # + # CONDA_PROMPT_MODIFIER can be configured with the following command: + # + # conda config --set env_prompt '({default_env}) ' + # + # The last argument is a Python format string that can use the following variables: + # + # - prefix The same as CONDA_PREFIX. + # - default_env The same as CONDA_DEFAULT_ENV. + # - name The last segment of CONDA_PREFIX. + # - stacked_env Comma-separated list of names in the environment stack. The first element is + # always the same as default_env. + # + # Note: '({default_env}) ' is the default value of env_prompt. + # + # The default value of POWERLEVEL9K_ANACONDA_CONTENT_EXPANSION expands to $CONDA_PROMPT_MODIFIER + # without the surrounding parentheses, or to the last path component of CONDA_PREFIX if the former + # is empty. + typeset -g POWERLEVEL9K_ANACONDA_CONTENT_EXPANSION='${${${${CONDA_PROMPT_MODIFIER#\(}% }%\)}:-${CONDA_PREFIX:t}}' + + # Custom icon. + # typeset -g POWERLEVEL9K_ANACONDA_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ pyenv: python environment (https://github.com/pyenv/pyenv) ]################ + # Pyenv color. + typeset -g POWERLEVEL9K_PYENV_FOREGROUND=37 + # Hide python version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_PYENV_SOURCES=(shell local global) + # If set to false, hide python version if it's the same as global: + # $(pyenv version-name) == $(pyenv global). + typeset -g POWERLEVEL9K_PYENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide python version if it's equal to "system". + typeset -g POWERLEVEL9K_PYENV_SHOW_SYSTEM=true + + # Pyenv segment format. The following parameters are available within the expansion. + # + # - P9K_CONTENT Current pyenv environment (pyenv version-name). + # - P9K_PYENV_PYTHON_VERSION Current python version (python --version). + # + # The default format has the following logic: + # + # 1. Display just "$P9K_CONTENT" if it's equal to "$P9K_PYENV_PYTHON_VERSION" or + # starts with "$P9K_PYENV_PYTHON_VERSION/". + # 2. Otherwise display "$P9K_CONTENT $P9K_PYENV_PYTHON_VERSION". + typeset -g POWERLEVEL9K_PYENV_CONTENT_EXPANSION='${P9K_CONTENT}${${P9K_CONTENT:#$P9K_PYENV_PYTHON_VERSION(|/*)}:+ $P9K_PYENV_PYTHON_VERSION}' + + # Custom icon. + # typeset -g POWERLEVEL9K_PYENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ goenv: go environment (https://github.com/syndbg/goenv) ]################ + # Goenv color. + typeset -g POWERLEVEL9K_GOENV_FOREGROUND=37 + # Hide go version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_GOENV_SOURCES=(shell local global) + # If set to false, hide go version if it's the same as global: + # $(goenv version-name) == $(goenv global). + typeset -g POWERLEVEL9K_GOENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide go version if it's equal to "system". + typeset -g POWERLEVEL9K_GOENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_GOENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ nodenv: node.js version from nodenv (https://github.com/nodenv/nodenv) ]########## + # Nodenv color. + typeset -g POWERLEVEL9K_NODENV_FOREGROUND=70 + # Hide node version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_NODENV_SOURCES=(shell local global) + # If set to false, hide node version if it's the same as global: + # $(nodenv version-name) == $(nodenv global). + typeset -g POWERLEVEL9K_NODENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide node version if it's equal to "system". + typeset -g POWERLEVEL9K_NODENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_NODENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##############[ nvm: node.js version from nvm (https://github.com/nvm-sh/nvm) ]############### + # Nvm color. + typeset -g POWERLEVEL9K_NVM_FOREGROUND=70 + # Custom icon. + # typeset -g POWERLEVEL9K_NVM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ############[ nodeenv: node.js environment (https://github.com/ekalinin/nodeenv) ]############ + # Nodeenv color. + typeset -g POWERLEVEL9K_NODEENV_FOREGROUND=70 + # Don't show Node version next to the environment name. + typeset -g POWERLEVEL9K_NODEENV_SHOW_NODE_VERSION=false + # Separate environment name from Node version only with a space. + typeset -g POWERLEVEL9K_NODEENV_{LEFT,RIGHT}_DELIMITER= + # Custom icon. + # typeset -g POWERLEVEL9K_NODEENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##############################[ node_version: node.js version ]############################### + # Node version color. + typeset -g POWERLEVEL9K_NODE_VERSION_FOREGROUND=70 + # Show node version only when in a directory tree containing package.json. + typeset -g POWERLEVEL9K_NODE_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_NODE_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######################[ go_version: go version (https://golang.org) ]######################## + # Go version color. + typeset -g POWERLEVEL9K_GO_VERSION_FOREGROUND=37 + # Show go version only when in a go project subdirectory. + typeset -g POWERLEVEL9K_GO_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_GO_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #################[ rust_version: rustc version (https://www.rust-lang.org) ]################## + # Rust version color. + typeset -g POWERLEVEL9K_RUST_VERSION_FOREGROUND=37 + # Show rust version only when in a rust project subdirectory. + typeset -g POWERLEVEL9K_RUST_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_RUST_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###############[ dotnet_version: .NET version (https://dotnet.microsoft.com) ]################ + # .NET version color. + typeset -g POWERLEVEL9K_DOTNET_VERSION_FOREGROUND=134 + # Show .NET version only when in a .NET project subdirectory. + typeset -g POWERLEVEL9K_DOTNET_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_DOTNET_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #####################[ php_version: php version (https://www.php.net/) ]###################### + # PHP version color. + typeset -g POWERLEVEL9K_PHP_VERSION_FOREGROUND=99 + # Show PHP version only when in a PHP project subdirectory. + typeset -g POWERLEVEL9K_PHP_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_PHP_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ laravel_version: laravel php framework version (https://laravel.com/) ]########### + # Laravel version color. + typeset -g POWERLEVEL9K_LARAVEL_VERSION_FOREGROUND=161 + # Custom icon. + # typeset -g POWERLEVEL9K_LARAVEL_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ####################[ java_version: java version (https://www.java.com/) ]#################### + # Java version color. + typeset -g POWERLEVEL9K_JAVA_VERSION_FOREGROUND=32 + # Show java version only when in a java project subdirectory. + typeset -g POWERLEVEL9K_JAVA_VERSION_PROJECT_ONLY=true + # Show brief version. + typeset -g POWERLEVEL9K_JAVA_VERSION_FULL=false + # Custom icon. + # typeset -g POWERLEVEL9K_JAVA_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###[ package: name@version from package.json (https://docs.npmjs.com/files/package.json) ]#### + # Package color. + typeset -g POWERLEVEL9K_PACKAGE_FOREGROUND=117 + # Package format. The following parameters are available within the expansion. + # + # - P9K_PACKAGE_NAME The value of `name` field in package.json. + # - P9K_PACKAGE_VERSION The value of `version` field in package.json. + # + # typeset -g POWERLEVEL9K_PACKAGE_CONTENT_EXPANSION='${P9K_PACKAGE_NAME//\%/%%}@${P9K_PACKAGE_VERSION//\%/%%}' + # Custom icon. + # typeset -g POWERLEVEL9K_PACKAGE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #############[ rbenv: ruby version from rbenv (https://github.com/rbenv/rbenv) ]############## + # Rbenv color. + typeset -g POWERLEVEL9K_RBENV_FOREGROUND=168 + # Hide ruby version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_RBENV_SOURCES=(shell local global) + # If set to false, hide ruby version if it's the same as global: + # $(rbenv version-name) == $(rbenv global). + typeset -g POWERLEVEL9K_RBENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide ruby version if it's equal to "system". + typeset -g POWERLEVEL9K_RBENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_RBENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######################[ rvm: ruby version from rvm (https://rvm.io) ]######################## + # Rvm color. + typeset -g POWERLEVEL9K_RVM_FOREGROUND=168 + # Don't show @gemset at the end. + typeset -g POWERLEVEL9K_RVM_SHOW_GEMSET=false + # Don't show ruby- at the front. + typeset -g POWERLEVEL9K_RVM_SHOW_PREFIX=false + # Custom icon. + # typeset -g POWERLEVEL9K_RVM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ fvm: flutter version management (https://github.com/leoafarias/fvm) ]############ + # Fvm color. + typeset -g POWERLEVEL9K_FVM_FOREGROUND=38 + # Custom icon. + # typeset -g POWERLEVEL9K_FVM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ luaenv: lua version from luaenv (https://github.com/cehoffman/luaenv) ]########### + # Lua color. + typeset -g POWERLEVEL9K_LUAENV_FOREGROUND=32 + # Hide lua version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_LUAENV_SOURCES=(shell local global) + # If set to false, hide lua version if it's the same as global: + # $(luaenv version-name) == $(luaenv global). + typeset -g POWERLEVEL9K_LUAENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide lua version if it's equal to "system". + typeset -g POWERLEVEL9K_LUAENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_LUAENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###############[ jenv: java version from jenv (https://github.com/jenv/jenv) ]################ + # Java color. + typeset -g POWERLEVEL9K_JENV_FOREGROUND=32 + # Hide java version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_JENV_SOURCES=(shell local global) + # If set to false, hide java version if it's the same as global: + # $(jenv version-name) == $(jenv global). + typeset -g POWERLEVEL9K_JENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide java version if it's equal to "system". + typeset -g POWERLEVEL9K_JENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_JENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ plenv: perl version from plenv (https://github.com/tokuhirom/plenv) ]############ + # Perl color. + typeset -g POWERLEVEL9K_PLENV_FOREGROUND=67 + # Hide perl version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_PLENV_SOURCES=(shell local global) + # If set to false, hide perl version if it's the same as global: + # $(plenv version-name) == $(plenv global). + typeset -g POWERLEVEL9K_PLENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide perl version if it's equal to "system". + typeset -g POWERLEVEL9K_PLENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_PLENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ############[ phpenv: php version from phpenv (https://github.com/phpenv/phpenv) ]############ + # PHP color. + typeset -g POWERLEVEL9K_PHPENV_FOREGROUND=99 + # Hide php version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_PHPENV_SOURCES=(shell local global) + # If set to false, hide php version if it's the same as global: + # $(phpenv version-name) == $(phpenv global). + typeset -g POWERLEVEL9K_PHPENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide php version if it's equal to "system". + typeset -g POWERLEVEL9K_PHPENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_PHPENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######[ scalaenv: scala version from scalaenv (https://github.com/scalaenv/scalaenv) ]####### + # Scala color. + typeset -g POWERLEVEL9K_SCALAENV_FOREGROUND=160 + # Hide scala version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_SCALAENV_SOURCES=(shell local global) + # If set to false, hide scala version if it's the same as global: + # $(scalaenv version-name) == $(scalaenv global). + typeset -g POWERLEVEL9K_SCALAENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide scala version if it's equal to "system". + typeset -g POWERLEVEL9K_SCALAENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_SCALAENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ haskell_stack: haskell version from stack (https://haskellstack.org/) ]########### + # Haskell color. + typeset -g POWERLEVEL9K_HASKELL_STACK_FOREGROUND=172 + # Hide haskell version if it doesn't come from one of these sources. + # + # shell: version is set by STACK_YAML + # local: version is set by stack.yaml up the directory tree + # global: version is set by the implicit global project (~/.stack/global-project/stack.yaml) + typeset -g POWERLEVEL9K_HASKELL_STACK_SOURCES=(shell local) + # If set to false, hide haskell version if it's the same as in the implicit global project. + typeset -g POWERLEVEL9K_HASKELL_STACK_ALWAYS_SHOW=true + # Custom icon. + # typeset -g POWERLEVEL9K_HASKELL_STACK_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ terraform: terraform workspace (https://www.terraform.io) ]################# + # Don't show terraform workspace if it's literally "default". + typeset -g POWERLEVEL9K_TERRAFORM_SHOW_DEFAULT=false + # POWERLEVEL9K_TERRAFORM_CLASSES is an array with even number of elements. The first element + # in each pair defines a pattern against which the current terraform workspace gets matched. + # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) + # that gets matched. If you unset all POWERLEVEL9K_TERRAFORM_*CONTENT_EXPANSION parameters, + # you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_TERRAFORM_CLASSES defines the workspace class. Patterns are tried in order. The + # first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_TERRAFORM_CLASSES=( + # '*prod*' PROD + # '*test*' TEST + # '*' OTHER) + # + # If your current terraform workspace is "project_test", its class is TEST because "project_test" + # doesn't match the pattern '*prod*' but does match '*test*'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_TERRAFORM_TEST_FOREGROUND=28 + # typeset -g POWERLEVEL9K_TERRAFORM_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_TERRAFORM_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' + typeset -g POWERLEVEL9K_TERRAFORM_CLASSES=( + # '*prod*' PROD # These values are examples that are unlikely + # '*test*' TEST # to match your needs. Customize them as needed. + '*' OTHER) + typeset -g POWERLEVEL9K_TERRAFORM_OTHER_FOREGROUND=38 + # typeset -g POWERLEVEL9K_TERRAFORM_OTHER_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #############[ terraform_version: terraform version (https://www.terraform.io) ]############## + # Terraform version color. + typeset -g POWERLEVEL9K_TERRAFORM_VERSION_FOREGROUND=38 + # Custom icon. + # typeset -g POWERLEVEL9K_TERRAFORM_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #############[ kubecontext: current kubernetes context (https://kubernetes.io/) ]############# + # Show kubecontext only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show kubecontext. + typeset -g POWERLEVEL9K_KUBECONTEXT_SHOW_ON_COMMAND='kubectl|helm|kubens|kubectx|oc|istioctl|kogito|k9s|helmfile|flux|fluxctl|stern' + + # Kubernetes context classes for the purpose of using different colors, icons and expansions with + # different contexts. + # + # POWERLEVEL9K_KUBECONTEXT_CLASSES is an array with even number of elements. The first element + # in each pair defines a pattern against which the current kubernetes context gets matched. + # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) + # that gets matched. If you unset all POWERLEVEL9K_KUBECONTEXT_*CONTENT_EXPANSION parameters, + # you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_KUBECONTEXT_CLASSES defines the context class. Patterns are tried in order. The + # first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_KUBECONTEXT_CLASSES=( + # '*prod*' PROD + # '*test*' TEST + # '*' DEFAULT) + # + # If your current kubernetes context is "deathray-testing/default", its class is TEST + # because "deathray-testing/default" doesn't match the pattern '*prod*' but does match '*test*'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_FOREGROUND=28 + # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' + typeset -g POWERLEVEL9K_KUBECONTEXT_CLASSES=( + # '*prod*' PROD # These values are examples that are unlikely + # '*test*' TEST # to match your needs. Customize them as needed. + '*' DEFAULT) + typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_FOREGROUND=134 + # typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Use POWERLEVEL9K_KUBECONTEXT_CONTENT_EXPANSION to specify the content displayed by kubecontext + # segment. Parameter expansions are very flexible and fast, too. See reference: + # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion. + # + # Within the expansion the following parameters are always available: + # + # - P9K_CONTENT The content that would've been displayed if there was no content + # expansion defined. + # - P9K_KUBECONTEXT_NAME The current context's name. Corresponds to column NAME in the + # output of `kubectl config get-contexts`. + # - P9K_KUBECONTEXT_CLUSTER The current context's cluster. Corresponds to column CLUSTER in the + # output of `kubectl config get-contexts`. + # - P9K_KUBECONTEXT_NAMESPACE The current context's namespace. Corresponds to column NAMESPACE + # in the output of `kubectl config get-contexts`. If there is no + # namespace, the parameter is set to "default". + # - P9K_KUBECONTEXT_USER The current context's user. Corresponds to column AUTHINFO in the + # output of `kubectl config get-contexts`. + # + # If the context points to Google Kubernetes Engine (GKE) or Elastic Kubernetes Service (EKS), + # the following extra parameters are available: + # + # - P9K_KUBECONTEXT_CLOUD_NAME Either "gke" or "eks". + # - P9K_KUBECONTEXT_CLOUD_ACCOUNT Account/project ID. + # - P9K_KUBECONTEXT_CLOUD_ZONE Availability zone. + # - P9K_KUBECONTEXT_CLOUD_CLUSTER Cluster. + # + # P9K_KUBECONTEXT_CLOUD_* parameters are derived from P9K_KUBECONTEXT_CLUSTER. For example, + # if P9K_KUBECONTEXT_CLUSTER is "gke_my-account_us-east1-a_my-cluster-01": + # + # - P9K_KUBECONTEXT_CLOUD_NAME=gke + # - P9K_KUBECONTEXT_CLOUD_ACCOUNT=my-account + # - P9K_KUBECONTEXT_CLOUD_ZONE=us-east1-a + # - P9K_KUBECONTEXT_CLOUD_CLUSTER=my-cluster-01 + # + # If P9K_KUBECONTEXT_CLUSTER is "arn:aws:eks:us-east-1:123456789012:cluster/my-cluster-01": + # + # - P9K_KUBECONTEXT_CLOUD_NAME=eks + # - P9K_KUBECONTEXT_CLOUD_ACCOUNT=123456789012 + # - P9K_KUBECONTEXT_CLOUD_ZONE=us-east-1 + # - P9K_KUBECONTEXT_CLOUD_CLUSTER=my-cluster-01 + typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION= + # Show P9K_KUBECONTEXT_CLOUD_CLUSTER if it's not empty and fall back to P9K_KUBECONTEXT_NAME. + POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION+='${P9K_KUBECONTEXT_CLOUD_CLUSTER:-${P9K_KUBECONTEXT_NAME}}' + # Append the current context's namespace if it's not "default". + POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION+='${${:-/$P9K_KUBECONTEXT_NAMESPACE}:#/default}' + + # Custom prefix. + # typeset -g POWERLEVEL9K_KUBECONTEXT_PREFIX='%248Fat ' + + #[ aws: aws profile (https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-profiles.html) ]# + # Show aws only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show aws. + typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt' + + # POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element + # in each pair defines a pattern against which the current AWS profile gets matched. + # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) + # that gets matched. If you unset all POWERLEVEL9K_AWS_*CONTENT_EXPANSION parameters, + # you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_AWS_CLASSES defines the profile class. Patterns are tried in order. The + # first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_AWS_CLASSES=( + # '*prod*' PROD + # '*test*' TEST + # '*' DEFAULT) + # + # If your current AWS profile is "company_test", its class is TEST + # because "company_test" doesn't match the pattern '*prod*' but does match '*test*'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_AWS_TEST_FOREGROUND=28 + # typeset -g POWERLEVEL9K_AWS_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_AWS_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' + typeset -g POWERLEVEL9K_AWS_CLASSES=( + # '*prod*' PROD # These values are examples that are unlikely + # '*test*' TEST # to match your needs. Customize them as needed. + '*' DEFAULT) + typeset -g POWERLEVEL9K_AWS_DEFAULT_FOREGROUND=208 + # typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # AWS segment format. The following parameters are available within the expansion. + # + # - P9K_AWS_PROFILE The name of the current AWS profile. + # - P9K_AWS_REGION The region associated with the current AWS profile. + typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}' + + #[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]# + # AWS Elastic Beanstalk environment color. + typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=70 + # Custom icon. + # typeset -g POWERLEVEL9K_AWS_EB_ENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ azure: azure account name (https://docs.microsoft.com/en-us/cli/azure) ]########## + # Show azure only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show azure. + typeset -g POWERLEVEL9K_AZURE_SHOW_ON_COMMAND='az|terraform|pulumi|terragrunt' + # Azure account name color. + typeset -g POWERLEVEL9K_AZURE_FOREGROUND=32 + # Custom icon. + # typeset -g POWERLEVEL9K_AZURE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ gcloud: google cloud account and project (https://cloud.google.com/) ]########### + # Show gcloud only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show gcloud. + typeset -g POWERLEVEL9K_GCLOUD_SHOW_ON_COMMAND='gcloud|gcs|gsutil' + # Google cloud color. + typeset -g POWERLEVEL9K_GCLOUD_FOREGROUND=32 + + # Google cloud format. Change the value of POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION and/or + # POWERLEVEL9K_GCLOUD_COMPLETE_CONTENT_EXPANSION if the default is too verbose or not informative + # enough. You can use the following parameters in the expansions. Each of them corresponds to the + # output of `gcloud` tool. + # + # Parameter | Source + # -------------------------|-------------------------------------------------------------------- + # P9K_GCLOUD_CONFIGURATION | gcloud config configurations list --format='value(name)' + # P9K_GCLOUD_ACCOUNT | gcloud config get-value account + # P9K_GCLOUD_PROJECT_ID | gcloud config get-value project + # P9K_GCLOUD_PROJECT_NAME | gcloud projects describe $P9K_GCLOUD_PROJECT_ID --format='value(name)' + # + # Note: ${VARIABLE//\%/%%} expands to ${VARIABLE} with all occurrences of '%' replaced with '%%'. + # + # Obtaining project name requires sending a request to Google servers. This can take a long time + # and even fail. When project name is unknown, P9K_GCLOUD_PROJECT_NAME is not set and gcloud + # prompt segment is in state PARTIAL. When project name gets known, P9K_GCLOUD_PROJECT_NAME gets + # set and gcloud prompt segment transitions to state COMPLETE. + # + # You can customize the format, icon and colors of gcloud segment separately for states PARTIAL + # and COMPLETE. You can also hide gcloud in state PARTIAL by setting + # POWERLEVEL9K_GCLOUD_PARTIAL_VISUAL_IDENTIFIER_EXPANSION and + # POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION to empty. + typeset -g POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION='${P9K_GCLOUD_PROJECT_ID//\%/%%}' + typeset -g POWERLEVEL9K_GCLOUD_COMPLETE_CONTENT_EXPANSION='${P9K_GCLOUD_PROJECT_NAME//\%/%%}' + + # Send a request to Google (by means of `gcloud projects describe ...`) to obtain project name + # this often. Negative value disables periodic polling. In this mode project name is retrieved + # only when the current configuration, account or project id changes. + typeset -g POWERLEVEL9K_GCLOUD_REFRESH_PROJECT_NAME_SECONDS=60 + + # Custom icon. + # typeset -g POWERLEVEL9K_GCLOUD_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #[ google_app_cred: google application credentials (https://cloud.google.com/docs/authentication/production) ]# + # Show google_app_cred only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show google_app_cred. + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_SHOW_ON_COMMAND='terraform|pulumi|terragrunt' + + # Google application credentials classes for the purpose of using different colors, icons and + # expansions with different credentials. + # + # POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES is an array with even number of elements. The first + # element in each pair defines a pattern against which the current kubernetes context gets + # matched. More specifically, it's P9K_CONTENT prior to the application of context expansion + # (see below) that gets matched. If you unset all POWERLEVEL9K_GOOGLE_APP_CRED_*CONTENT_EXPANSION + # parameters, you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES defines the context class. Patterns are tried in order. + # The first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES=( + # '*:*prod*:*' PROD + # '*:*test*:*' TEST + # '*' DEFAULT) + # + # If your current Google application credentials is "service_account deathray-testing x@y.com", + # its class is TEST because it doesn't match the pattern '* *prod* *' but does match '* *test* *'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_FOREGROUND=28 + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_CONTENT_EXPANSION='$P9K_GOOGLE_APP_CRED_PROJECT_ID' + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES=( + # '*:*prod*:*' PROD # These values are examples that are unlikely + # '*:*test*:*' TEST # to match your needs. Customize them as needed. + '*' DEFAULT) + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_FOREGROUND=32 + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Use POWERLEVEL9K_GOOGLE_APP_CRED_CONTENT_EXPANSION to specify the content displayed by + # google_app_cred segment. Parameter expansions are very flexible and fast, too. See reference: + # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion. + # + # You can use the following parameters in the expansion. Each of them corresponds to one of the + # fields in the JSON file pointed to by GOOGLE_APPLICATION_CREDENTIALS. + # + # Parameter | JSON key file field + # ---------------------------------+--------------- + # P9K_GOOGLE_APP_CRED_TYPE | type + # P9K_GOOGLE_APP_CRED_PROJECT_ID | project_id + # P9K_GOOGLE_APP_CRED_CLIENT_EMAIL | client_email + # + # Note: ${VARIABLE//\%/%%} expands to ${VARIABLE} with all occurrences of '%' replaced by '%%'. + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_CONTENT_EXPANSION='${P9K_GOOGLE_APP_CRED_PROJECT_ID//\%/%%}' + + ##############[ toolbox: toolbox name (https://github.com/containers/toolbox) ]############### + # Toolbox color. + typeset -g POWERLEVEL9K_TOOLBOX_FOREGROUND=178 + # Don't display the name of the toolbox if it matches fedora-toolbox-*. + typeset -g POWERLEVEL9K_TOOLBOX_CONTENT_EXPANSION='${P9K_TOOLBOX_NAME:#fedora-toolbox-*}' + # Custom icon. + # typeset -g POWERLEVEL9K_TOOLBOX_VISUAL_IDENTIFIER_EXPANSION='⭐' + # Custom prefix. + # typeset -g POWERLEVEL9K_TOOLBOX_PREFIX='%248Fin ' + + ###############################[ public_ip: public IP address ]############################### + # Public IP color. + typeset -g POWERLEVEL9K_PUBLIC_IP_FOREGROUND=94 + # Custom icon. + # typeset -g POWERLEVEL9K_PUBLIC_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ########################[ vpn_ip: virtual private network indicator ]######################### + # VPN IP color. + typeset -g POWERLEVEL9K_VPN_IP_FOREGROUND=81 + # When on VPN, show just an icon without the IP address. + # Tip: To display the private IP address when on VPN, remove the next line. + typeset -g POWERLEVEL9K_VPN_IP_CONTENT_EXPANSION= + # Regular expression for the VPN network interface. Run `ifconfig` or `ip -4 a show` while on VPN + # to see the name of the interface. + typeset -g POWERLEVEL9K_VPN_IP_INTERFACE='(gpd|wg|(.*tun)|tailscale)[0-9]*' + # If set to true, show one segment per matching network interface. If set to false, show only + # one segment corresponding to the first matching network interface. + # Tip: If you set it to true, you'll probably want to unset POWERLEVEL9K_VPN_IP_CONTENT_EXPANSION. + typeset -g POWERLEVEL9K_VPN_IP_SHOW_ALL=false + # Custom icon. + # typeset -g POWERLEVEL9K_VPN_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ ip: ip address and bandwidth usage for a specified network interface ]########### + # IP color. + typeset -g POWERLEVEL9K_IP_FOREGROUND=38 + # The following parameters are accessible within the expansion: + # + # Parameter | Meaning + # ----------------------+------------------------------------------- + # P9K_IP_IP | IP address + # P9K_IP_INTERFACE | network interface + # P9K_IP_RX_BYTES | total number of bytes received + # P9K_IP_TX_BYTES | total number of bytes sent + # P9K_IP_RX_BYTES_DELTA | number of bytes received since last prompt + # P9K_IP_TX_BYTES_DELTA | number of bytes sent since last prompt + # P9K_IP_RX_RATE | receive rate (since last prompt) + # P9K_IP_TX_RATE | send rate (since last prompt) + typeset -g POWERLEVEL9K_IP_CONTENT_EXPANSION='${P9K_IP_RX_RATE:+%70F⇣$P9K_IP_RX_RATE }${P9K_IP_TX_RATE:+%215F⇡$P9K_IP_TX_RATE }%38F$P9K_IP_IP' + # Show information for the first network interface whose name matches this regular expression. + # Run `ifconfig` or `ip -4 a show` to see the names of all network interfaces. + typeset -g POWERLEVEL9K_IP_INTERFACE='[ew].*' + # Custom icon. + # typeset -g POWERLEVEL9K_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #########################[ proxy: system-wide http/https/ftp proxy ]########################## + # Proxy color. + typeset -g POWERLEVEL9K_PROXY_FOREGROUND=68 + # Custom icon. + # typeset -g POWERLEVEL9K_PROXY_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################################[ battery: internal battery ]################################# + # Show battery in red when it's below this level and not connected to power supply. + typeset -g POWERLEVEL9K_BATTERY_LOW_THRESHOLD=20 + typeset -g POWERLEVEL9K_BATTERY_LOW_FOREGROUND=160 + # Show battery in green when it's charging or fully charged. + typeset -g POWERLEVEL9K_BATTERY_{CHARGING,CHARGED}_FOREGROUND=70 + # Show battery in yellow when it's discharging. + typeset -g POWERLEVEL9K_BATTERY_DISCONNECTED_FOREGROUND=178 + # Battery pictograms going from low to high level of charge. + typeset -g POWERLEVEL9K_BATTERY_STAGES='\uf58d\uf579\uf57a\uf57b\uf57c\uf57d\uf57e\uf57f\uf580\uf581\uf578' + # Don't show the remaining time to charge/discharge. + typeset -g POWERLEVEL9K_BATTERY_VERBOSE=false + + #####################################[ wifi: wifi speed ]##################################### + # WiFi color. + typeset -g POWERLEVEL9K_WIFI_FOREGROUND=68 + # Custom icon. + # typeset -g POWERLEVEL9K_WIFI_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Use different colors and icons depending on signal strength ($P9K_WIFI_BARS). + # + # # Wifi colors and icons for different signal strength levels (low to high). + # typeset -g my_wifi_fg=(68 68 68 68 68) # <-- change these values + # typeset -g my_wifi_icon=('WiFi' 'WiFi' 'WiFi' 'WiFi' 'WiFi') # <-- change these values + # + # typeset -g POWERLEVEL9K_WIFI_CONTENT_EXPANSION='%F{${my_wifi_fg[P9K_WIFI_BARS+1]}}$P9K_WIFI_LAST_TX_RATE Mbps' + # typeset -g POWERLEVEL9K_WIFI_VISUAL_IDENTIFIER_EXPANSION='%F{${my_wifi_fg[P9K_WIFI_BARS+1]}}${my_wifi_icon[P9K_WIFI_BARS+1]}' + # + # The following parameters are accessible within the expansions: + # + # Parameter | Meaning + # ----------------------+--------------- + # P9K_WIFI_SSID | service set identifier, a.k.a. network name + # P9K_WIFI_LINK_AUTH | authentication protocol such as "wpa2-psk" or "none"; empty if unknown + # P9K_WIFI_LAST_TX_RATE | wireless transmit rate in megabits per second + # P9K_WIFI_RSSI | signal strength in dBm, from -120 to 0 + # P9K_WIFI_NOISE | noise in dBm, from -120 to 0 + # P9K_WIFI_BARS | signal strength in bars, from 0 to 4 (derived from P9K_WIFI_RSSI and P9K_WIFI_NOISE) + + ####################################[ time: current time ]#################################### + # Current time color. + typeset -g POWERLEVEL9K_TIME_FOREGROUND=66 + # Format for the current time: 09:51:02. See `man 3 strftime`. + typeset -g POWERLEVEL9K_TIME_FORMAT='%D{%H:%M:%S}' + # If set to true, time will update when you hit enter. This way prompts for the past + # commands will contain the start times of their commands as opposed to the default + # behavior where they contain the end times of their preceding commands. + typeset -g POWERLEVEL9K_TIME_UPDATE_ON_COMMAND=false + # Custom icon. + typeset -g POWERLEVEL9K_TIME_VISUAL_IDENTIFIER_EXPANSION= + # Custom prefix. + # typeset -g POWERLEVEL9K_TIME_PREFIX='%248Fat ' + + # Example of a user-defined prompt segment. Function prompt_example will be called on every + # prompt if `example` prompt segment is added to POWERLEVEL9K_LEFT_PROMPT_ELEMENTS or + # POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS. It displays an icon and orange text greeting the user. + # + # Type `p10k help segment` for documentation and a more sophisticated example. + function prompt_example() { + p10k segment -f 208 -i '⭐' -t 'hello, %n' + } + + # User-defined prompt segments may optionally provide an instant_prompt_* function. Its job + # is to generate the prompt segment for display in instant prompt. See + # https://github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt. + # + # Powerlevel10k will call instant_prompt_* at the same time as the regular prompt_* function + # and will record all `p10k segment` calls it makes. When displaying instant prompt, Powerlevel10k + # will replay these calls without actually calling instant_prompt_*. It is imperative that + # instant_prompt_* always makes the same `p10k segment` calls regardless of environment. If this + # rule is not observed, the content of instant prompt will be incorrect. + # + # Usually, you should either not define instant_prompt_* or simply call prompt_* from it. If + # instant_prompt_* is not defined for a segment, the segment won't be shown in instant prompt. + function instant_prompt_example() { + # Since prompt_example always makes the same `p10k segment` calls, we can call it from + # instant_prompt_example. This will give us the same `example` prompt segment in the instant + # and regular prompts. + prompt_example + } + + # User-defined prompt segments can be customized the same way as built-in segments. + # typeset -g POWERLEVEL9K_EXAMPLE_FOREGROUND=208 + # typeset -g POWERLEVEL9K_EXAMPLE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Transient prompt works similarly to the builtin transient_rprompt option. It trims down prompt + # when accepting a command line. Supported values: + # + # - off: Don't change prompt when accepting a command line. + # - always: Trim down prompt when accepting a command line. + # - same-dir: Trim down prompt when accepting a command line unless this is the first command + # typed after changing current working directory. + typeset -g POWERLEVEL9K_TRANSIENT_PROMPT=always + + # Instant prompt mode. + # + # - off: Disable instant prompt. Choose this if you've tried instant prompt and found + # it incompatible with your zsh configuration files. + # - quiet: Enable instant prompt and don't print warnings when detecting console output + # during zsh initialization. Choose this if you've read and understood + # https://github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt. + # - verbose: Enable instant prompt and print a warning when detecting console output during + # zsh initialization. Choose this if you've never tried instant prompt, haven't + # seen the warning, or if you are unsure what this all means. + typeset -g POWERLEVEL9K_INSTANT_PROMPT=verbose + + # Hot reload allows you to change POWERLEVEL9K options after Powerlevel10k has been initialized. + # For example, you can type POWERLEVEL9K_BACKGROUND=red and see your prompt turn red. Hot reload + # can slow down prompt by 1-2 milliseconds, so it's better to keep it turned off unless you + # really need it. + typeset -g POWERLEVEL9K_DISABLE_HOT_RELOAD=true + + # If p10k is already loaded, reload configuration. + # This works even with POWERLEVEL9K_DISABLE_HOT_RELOAD=true. + (( ! $+functions[p10k] )) || p10k reload +} + +# Tell `p10k configure` which file it should overwrite. +typeset -g POWERLEVEL9K_CONFIG_FILE=${${(%):-%x}:a} + +(( ${#p10k_config_opts} )) && setopt ${p10k_config_opts[@]} +'builtin' 'unset' 'p10k_config_opts' diff --git a/.local/bin/displayselect b/.local/bin/displayselect new file mode 100755 index 0000000..ff93ae0 --- /dev/null +++ b/.local/bin/displayselect @@ -0,0 +1,85 @@ +#!/bin/sh + +# taken from https://github.com/LukeSmithxyz/voidrice/blob/master/.local/bin/displayselect +# A UI for detecting and selecting all displays. Probes xrandr for connected +# displays and lets user select one to use. User may also select "manual +# selection" which opens arandr. + +twoscreen() { # If multi-monitor is selected and there are two screens. + + mirror=$(printf "no\\nyes" | dmenu -i -p "Mirror displays?") + # Mirror displays using native resolution of external display and a scaled + # version for the internal display + if [ "$mirror" = "yes" ]; then + external=$(echo "$screens" | dmenu -i -p "Optimize resolution for:") + internal=$(echo "$screens" | grep -v "$external") + + res_external=$(xrandr --query | sed -n "/^$external/,/\+/p" | \ + tail -n 1 | awk '{print $1}') + res_internal=$(xrandr --query | sed -n "/^$internal/,/\+/p" | \ + tail -n 1 | awk '{print $1}') + + res_ext_x=$(echo "$res_external" | sed 's/x.*//') + res_ext_y=$(echo "$res_external" | sed 's/.*x//') + res_int_x=$(echo "$res_internal" | sed 's/x.*//') + res_int_y=$(echo "$res_internal" | sed 's/.*x//') + + scale_x=$(echo "$res_ext_x / $res_int_x" | bc -l) + scale_y=$(echo "$res_ext_y / $res_int_y" | bc -l) + + xrandr --output "$external" --auto --scale 1.0x1.0 \ + --output "$internal" --auto --same-as "$external" \ + --scale "$scale_x"x"$scale_y" + else + + primary=$(echo "$screens" | dmenu -i -p "Select primary display:") + secondary=$(echo "$screens" | grep -v "$primary") + direction=$(printf "left\\nright" | dmenu -i -p "What side of $primary should $secondary be on?") + xrandr --output "$primary" --auto --scale 1.0x1.0 --output "$secondary" --"$direction"-of "$primary" --auto --scale 1.0x1.0 + fi + } + +morescreen() { # If multi-monitor is selected and there are more than two screens. + primary=$(echo "$screens" | dmenu -i -p "Select primary display:") + secondary=$(echo "$screens" | grep -v "$primary" | dmenu -i -p "Select secondary display:") + direction=$(printf "left\\nright" | dmenu -i -p "What side of $primary should $secondary be on?") + tertiary=$(echo "$screens" | grep -v "$primary" | grep -v "$secondary" | dmenu -i -p "Select third display:") + xrandr --output "$primary" --auto --output "$secondary" --"$direction"-of "$primary" --auto --output "$tertiary" --"$(printf "left\\nright" | grep -v "$direction")"-of "$primary" --auto + } + +multimon() { # Multi-monitor handler. + case "$(echo "$screens" | wc -l)" in + 2) twoscreen ;; + *) morescreen ;; + esac ;} + +onescreen() { # If only one output available or chosen. + xrandr --output "$1" --auto --scale 1.0x1.0 $(echo "$allposs" | grep -v "\b$1" | awk '{print "--output", $1, "--off"}' | paste -sd ' ' -) + } + +postrun() { # Stuff to run to clean up. + setbg # Fix background if screen size/arangement has changed. + remaps # Re-remap keys if keyboard added (for laptop bases) + { killall dunst ; setsid -f dunst ;} >/dev/null 2>&1 # Restart dunst to ensure proper location on screen + } + +# Get all possible displays +allposs=$(xrandr -q | grep "connected") + +# Get all connected screens. +screens=$(echo "$allposs" | awk '/ connected/ {print $1}') + +# If there's only one screen +[ "$(echo "$screens" | wc -l)" -lt 2 ] && + { onescreen "$screens"; postrun; notify-send "💻 Only one screen detected." "Using it in its optimal settings..."; exit ;} + +# Get user choice including multi-monitor and manual selection: +chosen=$(printf "%s\\nmulti-monitor\\nmanual selection" "$screens" | dmenu -i -p "Select display arangement:") && +case "$chosen" in + "manual selection") arandr ; exit ;; + "multi-monitor") multimon ;; + *) onescreen "$chosen" ;; +esac + +postrun + diff --git a/.local/bin/dmenumount b/.local/bin/dmenumount new file mode 100755 index 0000000..80f2913 --- /dev/null +++ b/.local/bin/dmenumount @@ -0,0 +1,69 @@ +#!/bin/sh + +# from https://github.com/LukeSmithxyz/voidrice/blob/master/.local/bin/dmenumount +# Gives a dmenu prompt to mount unmounted drives and Android phones. If +# they're in /etc/fstab, they'll be mounted automatically. Otherwise, you'll +# be prompted to give a mountpoint from already existsing directories. If you +# input a novel directory, it will prompt you to create that directory. + +getmount() { \ + [ -z "$chosen" ] && exit 1 + # shellcheck disable=SC2086 + mp="$(find $1 2>/dev/null | dmenu -i -p "Type in mount point.")" || exit 1 + test -z "$mp" && exit 1 + if [ ! -d "$mp" ]; then + mkdiryn=$(printf "No\\nYes" | dmenu -i -p "$mp does not exist. Create it?") || exit 1 + [ "$mkdiryn" = "Yes" ] && (mkdir -p "$mp" || sudo -A mkdir -p "$mp") + fi + } + +mountusb() { \ + chosen="$(echo "$usbdrives" | dmenu -i -p "Mount which drive?")" || exit 1 + chosen="$(echo "$chosen" | awk '{print $1}')" + sudo -A mount "$chosen" 2>/dev/null && notify-send "💻 USB mounting" "$chosen mounted." && exit 0 + alreadymounted=$(lsblk -nrpo "name,type,mountpoint" | awk '$3!~/\/boot|\/home$|SWAP/&&length($3)>1{printf "-not ( -path *%s -prune ) ",$3}') + getmount "/mnt /media /mount /home -maxdepth 5 -type d $alreadymounted" + partitiontype="$(lsblk -no "fstype" "$chosen")" + case "$partitiontype" in + "vfat") sudo -A mount -t vfat "$chosen" "$mp" -o rw,umask=0000;; + "exfat") sudo -A mount "$chosen" "$mp" -o uid="$(id -u)",gid="$(id -g)";; + *) sudo -A mount "$chosen" "$mp"; user="$(whoami)"; ug="$(groups | awk '{print $1}')"; sudo -A chown "$user":"$ug" "$mp";; + esac + notify-send "💻 USB mounting" "$chosen mounted to $mp." + } + +mountandroid() { \ + chosen="$(echo "$anddrives" | dmenu -i -p "Which Android device?")" || exit 1 + chosen="$(echo "$chosen" | cut -d : -f 1)" + getmount "$HOME -maxdepth 3 -type d" + simple-mtpfs --device "$chosen" "$mp" + echo "OK" | dmenu -i -p "Tap Allow on your phone if it asks for permission and then press enter" || exit 1 + simple-mtpfs --device "$chosen" "$mp" + notify-send "🤖 Android Mounting" "Android device mounted to $mp." + } + +asktype() { \ + choice="$(printf "USB\\nAndroid" | dmenu -i -p "Mount a USB drive or Android device?")" || exit 1 + case $choice in + USB) mountusb ;; + Android) mountandroid ;; + esac + } + +anddrives=$(simple-mtpfs -l 2>/dev/null) +usbdrives="$(lsblk -rpo "name,type,size,mountpoint" | grep 'part\|rom' | awk '$4==""{printf "%s (%s)\n",$1,$3}')" + +if [ -z "$usbdrives" ]; then + [ -z "$anddrives" ] && echo "No USB drive or Android device detected" && exit + echo "Android device(s) detected." + mountandroid +else + if [ -z "$anddrives" ]; then + echo "USB drive(s) detected." + mountusb + else + echo "Mountable USB drive(s) and Android device(s) detected." + asktype + fi +fi + diff --git a/.local/bin/dmenurecord b/.local/bin/dmenurecord new file mode 100755 index 0000000..ac97ee9 --- /dev/null +++ b/.local/bin/dmenurecord @@ -0,0 +1,125 @@ +#!/bin/sh + +# taken from https://github.com/LukeSmithxyz/voidrice/blob/master/.local/bin/dmenurecord +# Usage: +# `$0`: Ask for recording type via dmenu +# `$0 screencast`: Record both audio and screen +# `$0 video`: Record only screen +# `$0 audio`: Record only audio +# `$0 kill`: Kill existing recording +# +# If there is already a running instance, user will be prompted to end it. + +updateicon() { \ + echo "$1" > /tmp/recordingicon + pkill -RTMIN+9 "${STATUSBAR:-dwmblocks}" + } + +killrecording() { + recpid="$(cat /tmp/recordingpid)" + # kill with SIGTERM, allowing finishing touches. + kill -15 "$recpid" + rm -f /tmp/recordingpid + updateicon "" + pkill -RTMIN+9 "${STATUSBAR:-dwmblocks}" + # even after SIGTERM, ffmpeg may still run, so SIGKILL it. + sleep 3 + kill -9 "$recpid" + exit + } + +screencast() { \ + ffmpeg -y \ + -f x11grab \ + -framerate 60 \ + -s "$(xdpyinfo | awk '/dimensions/ {print $2;}')" \ + -i "$DISPLAY" \ + -f alsa -i default \ + -r 30 \ + -c:v h264 -crf 0 -preset ultrafast -c:a aac \ + "$HOME/screencast-$(date '+%y%m%d-%H%M-%S').mp4" & + echo $! > /tmp/recordingpid + updateicon "⏺️🎙️" + } + +video() { ffmpeg \ + -f x11grab \ + -s "$(xdpyinfo | awk '/dimensions/ {print $2;}')" \ + -i "$DISPLAY" \ + -c:v libx264 -qp 0 -r 30 \ + "$HOME/video-$(date '+%y%m%d-%H%M-%S').mkv" & + echo $! > /tmp/recordingpid + updateicon "⏺️" + } + +webcamhidef() { ffmpeg \ + -f v4l2 \ + -i /dev/video0 \ + -video_size 1920x1080 \ + "$HOME/webcam-$(date '+%y%m%d-%H%M-%S').mkv" & + echo $! > /tmp/recordingpid + updateicon "🎥" + } + +webcam() { ffmpeg \ + -f v4l2 \ + -i /dev/video0 \ + -video_size 640x480 \ + "$HOME/webcam-$(date '+%y%m%d-%H%M-%S').mkv" & + echo $! > /tmp/recordingpid + updateicon "🎥" + } + + +audio() { \ + ffmpeg \ + -f alsa -i default \ + -c:a flac \ + "$HOME/audio-$(date '+%y%m%d-%H%M-%S').flac" & + echo $! > /tmp/recordingpid + updateicon "🎙️" + } + +askrecording() { \ + choice=$(printf "screencast\\nvideo\\nvideo selected\\naudio\\nwebcam\\nwebcam (hi-def)" | dmenu -i -p "Select recording style:") + case "$choice" in + screencast) screencast;; + audio) audio;; + video) video;; + *selected) videoselected;; + webcam) webcam;; + "webcam (hi-def)") webcamhidef;; + esac + } + +asktoend() { \ + response=$(printf "No\\nYes" | dmenu -i -p "Recording still active. End recording?") && + [ "$response" = "Yes" ] && killrecording + } + +videoselected() +{ + slop -f "%x %y %w %h" > /tmp/slop + read -r X Y W H < /tmp/slop + rm /tmp/slop + + ffmpeg \ + -f x11grab \ + -framerate 60 \ + -video_size "$W"x"$H" \ + -i :0.0+"$X,$Y" \ + -c:v libx264 -qp 0 -r 30 \ + "$HOME/box-$(date '+%y%m%d-%H%M-%S').mkv" & + echo $! > /tmp/recordingpid + updateicon "⏺️" +} + +case "$1" in + screencast) screencast;; + audio) audio;; + video) video;; + *selected) videoselected;; + kill) killrecording;; + *) ([ -f /tmp/recordingpid ] && asktoend && exit) || askrecording;; +esac + diff --git a/.local/bin/dmenuumount b/.local/bin/dmenuumount new file mode 100755 index 0000000..5a86c9e --- /dev/null +++ b/.local/bin/dmenuumount @@ -0,0 +1,46 @@ +#!/bin/sh + +# taken from https://github.com/LukeSmithxyz/voidrice/blob/master/.local/bin/dmenuumount +# A dmenu prompt to unmount drives. +# Provides you with mounted partitions, select one to unmount. +# Drives mounted at /, /boot and /home will not be options to unmount. + +unmountusb() { + [ -z "$drives" ] && exit + chosen="$(echo "$drives" | dmenu -i -p "Unmount which drive?")" || exit 1 + chosen="$(echo "$chosen" | awk '{print $1}')" + [ -z "$chosen" ] && exit + sudo -A umount "$chosen" && notify-send "💻 USB unmounting" "$chosen unmounted." + } + +unmountandroid() { \ + chosen="$(awk '/simple-mtpfs/ {print $2}' /etc/mtab | dmenu -i -p "Unmount which device?")" || exit 1 + [ -z "$chosen" ] && exit + sudo -A umount -l "$chosen" && notify-send "🤖 Android unmounting" "$chosen unmounted." + } + +asktype() { \ + choice="$(printf "USB\\nAndroid" | dmenu -i -p "Unmount a USB drive or Android device?")" || exit 1 + case "$choice" in + USB) unmountusb ;; + Android) unmountandroid ;; + esac + } + +drives=$(lsblk -nrpo "name,type,size,mountpoint,label" | awk -F':' '{gsub(/ /,":")}$4!~/\/boot|\/efi|\/home$|SWAP/&&length($4)>1{printf "%s (%s) %s\n",$4,$3,$5}') + +if ! grep simple-mtpfs /etc/mtab; then + [ -z "$drives" ] && echo "No drives to unmount." && exit + echo "Unmountable USB drive detected." + unmountusb +else + if [ -z "$drives" ] + then + echo "Unmountable Android device detected." + unmountandroid + else + echo "Unmountable USB drive(s) and Android device(s) detected." + asktype + fi +fi + diff --git a/.local/share/applications/firefox-profiles.desktop b/.local/share/applications/firefox-profiles.desktop new file mode 100644 index 0000000..ee2cc13 --- /dev/null +++ b/.local/share/applications/firefox-profiles.desktop @@ -0,0 +1,8 @@ +[Desktop Entry] +Encoding=UTF-8 +Version=1.0 +Type=Application +Terminal=False +Exec=/usr/lib/firefox/firefox -P +Name=Firefox Profiles +Comment=Custom profile for Firefox diff --git a/.local/share/applications/thunderbird-profiles.desktop b/.local/share/applications/thunderbird-profiles.desktop new file mode 100644 index 0000000..9625c53 --- /dev/null +++ b/.local/share/applications/thunderbird-profiles.desktop @@ -0,0 +1,8 @@ +[Desktop Entry] +Encoding=UTF-8 +Version=1.0 +Type=Application +Terminal=False +Exec=/usr/lib/thunderbird/thunderbird -P +Name=Thunderbird Profiles +Comment=Custom profile for Thunderbird diff --git a/.local/share/applications/userapp-Telegram.desktop b/.local/share/applications/userapp-Telegram.desktop new file mode 100644 index 0000000..3f98186 --- /dev/null +++ b/.local/share/applications/userapp-Telegram.desktop @@ -0,0 +1,8 @@ +[Desktop Entry] +Encoding=UTF-8 +Version=1.0 +Type=Application +NoDisplay=true +Exec=/usr/bin/telegram-desktop -- %u +Name=Telegram Desktop +Comment=Custom definition for Telegram Desktop diff --git a/.local/share/applications/userapp-Thunderbird.desktop b/.local/share/applications/userapp-Thunderbird.desktop new file mode 100644 index 0000000..dddaf2e --- /dev/null +++ b/.local/share/applications/userapp-Thunderbird.desktop @@ -0,0 +1,8 @@ +[Desktop Entry] +Encoding=UTF-8 +Version=1.0 +Type=Application +NoDisplay=true +Exec=/usr/lib/thunderbird/thunderbird %u +Name=Thunderbird +Comment=Custom definition for Thunderbird diff --git a/.profile b/.profile new file mode 100644 index 0000000..dee8a2d --- /dev/null +++ b/.profile @@ -0,0 +1,46 @@ +# Basic config +xset r rate 200 35 # set key repeat delay and rate +# Clean Up Home Directory +export XDG_CONFIG_HOME="$HOME/.config" +export XDG_CACHE_HOME="$HOME/.cache" +export XDG_DATA_HOME="$HOME/.local/share" +export XDG_STATE_HOME="$HOME/.local/state" +export TS3_CONFIG_DIR="$XDG_CONFIG_HOME/ts3client" +export GRADLE_USER_HOME="$XDG_DATA_HOME/gradle" +export CARGO_HOME="$XDG_DATA_HOME/cargo" +export JUPYTER_CONFIG_DIR="$XDG_CONFIG_HOME/jupyter" +export _JAVA_OPTIONS=-Djava.util.prefs.userRoot="$XDG_CONFIG_HOME/java" +export CUDA_CACHE_PATH="$XDG_CACHE_HOME/nv" +export ZDOTDIR="$XDG_CONFIG_HOME/zsh" +export WGETRC="$XDG_CONFIG_HOME/wgetrc" +alias vscodium='vscodium --extensions-dir "$XDG_DATA_HOME/vscode"' +export GTK2_RC_FILES="$XDG_CONFIG_HOME/gtk-2.0/gtkrc-2.0" +export CARGO_HOME="$XDG_DATA_HOME/cargo" +alias wget='wget --hsts-file="$XDG_CACHE_HOME/wget-hsts"' +alias yarn='yarn --use-yarnrc "$XDG_CONFIG_HOME/yarn/config"' +alias code='code --extensions-dir "$XDG_DATA_HOME/vscode"' +alias dict='dict -c "$XDG_CONFIG_HOME"/dict/dictrc ' + + +# THEME + +export QT_QPA_PLATFORMTHEME="qt5ct" +export QT_AUTO_SCREEN_SCALE_FACTOR=0 +# global theme colors +export BLACK="#272822" +export WHITE="#FFFFFF" +export RED="#F92672" +export BLUE="#66D9EF" +export GREEN="#A6E22E" +export ORANGE="#FD971F" +export YELLOW="#E6DB74" +export PURPLE="#AE81FF" +export FONT="Noto" +export FONTSIZE="12" + +# default applications +export EDITOR=/usr/bin/nvim +export BROWSER=/usr/bin/firefox +export TERMINAL=/usr/bin/alacritty +export EXPLORER=/usr/bin/thunar +export MAILCLIENT=/usr/bin/thunderbird