-#######################################################################
-# Admone ZSH prompt. Copyright Armaan Bhojwani, palb91, romkatv. #
-# MIT licensed, see the LICENSE file or #
-# https://www.opensource.org/licenses/MIT for more information. #
-# Git repo at https://codeberg.org/armaan/admone #
-#######################################################################
+# Admone Zsh prompt
+# Copyright Armaan Bhojwani 2021 <me@armaanb.net>
+# MIT licensed, see the LICENSE file for more information.
-#
-# USER CONFIGURATIONS
-#
+PROMPT_CHAR="➤"
-ADMONE_PROMPT_CHAR="❯❯❯"
-ADMONE_PRE_UPPER="╭ "
-ADMONE_PRE_LOWER="╰ "
-ADMONE_BLOCK_SEPARATOR="-"
-ADMONE_BLOCK_LEFT="["
-ADMONE_BLOCK_RIGHT="]"
-ADMONE_VI_MODE_CURSOR="1"
-ADMONE_INCLUDE="admone-pwd;admone-git;admone-exit-code;admone-12hr;admone-time"
+zstyle ':vcs_info:git:*' formats '%f|%F{green}%b%u%c'
+zstyle ':vcs_info:git:*' actionformats '%b|%a%u%c'
+zstyle ':vcs_info:*' unstagedstr ' *'
+zstyle ':vcs_info:*' stagedstr ' +'
-function admone-pwd {
- echo "%F{blue}%~%f%F{240}"
-}
-function admone-git {
- local git_branch="$(git rev-parse --abbrev-ref HEAD 2>/dev/null)"
- echo "%F{green}${git_branch//\%/%%}%f"
-}
-function admone-exit-code {
- echo "%(?,,%F{1}%?%F{240})"
-}
-function admone-date {
- echo $(date -I)
-}
-function admone-12hr {
- echo $(date +%r)
-}
-function admone-24hr {
- echo $(date +%x)
-}
-function admone-time {
- # Intergration with https://codeberg.org/armaan/zsh-command-time
- echo %F{cyan}$timer_show%f
-}
-
-#######################################################################
-
-#
-# BACKEND
-#
+################################################################################
# Cursor shape depends on vi mode
function zle-keymap-select zle-line-init zle-line-finish {
- if [[ $ADMONE_VI_MODE_CURSOR == 1 ]]; then
- case $KEYMAP in
- vicmd)
- print -n -- "\E]50;CursorShape=0\C-G"
- ;;
- viins|main)
- print -n -- "\E]50;CursorShape=1\C-G"
- ;;
- *)
- ;;
- esac
-
- zle reset-prompt
- zle -R
- fi
-}
-
-function set-prompt() {
- upper="${ADMONE_PRE_UPPER}"
- lower="${ADMONE_PRE_LOWER}%B%F{%(?.cyan.red)}${ADMONE_PROMPT_CHAR}%f%b "
-
- NUM_FUNCS="$(echo $ADMONE_INCLUDE | grep -o ';' | wc -l)"
- REAL_NUM_FUNCS=$((NUM_FUNCS+1))
-
- for (( i = 0; i <= $NUM_FUNCS; i++ )); do
- (( val = $i + 1 ))
- THE_COMMAND="$(echo $ADMONE_INCLUDE | cut -d ';' -f $val)"
-
- if [[ $val == 1 ]]; then
- upper+="$ADMONE_BLOCK_LEFT$($THE_COMMAND)$ADMONE_BLOCK_RIGHT"
- else
- upper+="$ADMONE_BLOCK_SEPARATOR$ADMONE_BLOCK_LEFT$($THE_COMMAND)$ADMONE_BLOCK_RIGHT"
- fi
- done
+ case $KEYMAP in
+ vicmd)
+ # Block
+ print -n -- "\E]50;CursorShape=0\C-G"
+ ;;
+ viins|main)
+ # Beam
+ print -n -- "\E]50;CursorShape=1\C-G"
+ ;;
+ esac
+ # zle reset-prompt
+ zle -R
+}
+
+# Set everything!
+set-prompt() {
+ PROMPT="%B%F{%(?.cyan.red)}${PROMPT_CHAR}%f%b "
+ RPROMPT="[%F{blue}%~${vcs_info_msg_0_}%f][%(?,%F{cyan}%?,%F{red}%?)%f]"
[[ -v PS1_NL ]] && echo || PS1_NL=
- PROMPT=$upper$'\n'$lower
}
+zstyle ':vcs_info:*' check-for-changes true
+autoload -Uz add-zsh-hook vcs-info
+add-zsh-hook precmd vcs_info
+add-zsh-hook precmd set-prompt
+
zle -N zle-line-init
zle -N zle-line-finish
zle -N zle-keymap-select
-autoload -Uz add-zsh-hook
-add-zsh-hook precmd set-prompt