diff options
Diffstat (limited to 'themes/avit.zsh-theme')
| -rw-r--r-- | themes/avit.zsh-theme | 99 | 
1 files changed, 41 insertions, 58 deletions
| diff --git a/themes/avit.zsh-theme b/themes/avit.zsh-theme index a21a9c8c4..0261f0ff3 100644 --- a/themes/avit.zsh-theme +++ b/themes/avit.zsh-theme @@ -1,18 +1,20 @@  # AVIT ZSH Theme -PROMPT=' -$(_user_host)${_current_dir} $(git_prompt_info) $(_ruby_version) -▶ ' +# settings +typeset +H _current_dir="%{$fg_bold[blue]%}%3~%{$reset_color%} " +typeset +H _return_status="%{$fg_bold[red]%}%(?..⍉)%{$reset_color%}" +typeset +H _hist_no="%{$fg[grey]%}%h%{$reset_color%}" -PROMPT2='%{$fg[grey]%}◀%{$reset_color%} ' +PROMPT=' +$(_user_host)${_current_dir} $(git_prompt_info) $(ruby_prompt_info) +%{%(!.%F{red}.%F{white})%}▶%{$resetcolor%} ' -RPROMPT='$(_vi_status)%{$(echotc UP 1)%}$(_git_time_since_commit) $(git_prompt_status) ${_return_status}%{$(echotc DO 1)%}' +PROMPT2='%{%(!.%F{red}.%F{white})%}◀%{$reset_color%} ' -local _current_dir="%{$fg[blue]%}%3~%{$reset_color%} " -local _return_status="%{$fg[red]%}%(?..⍉)%{$reset_color%}" -local _hist_no="%{$fg[grey]%}%h%{$reset_color%}" +RPROMPT='$(vi_mode_prompt_info)%{$(echotc UP 1)%}$(_git_time_since_commit) $(git_prompt_status) ${_return_status}%{$(echotc DO 1)%}'  function _user_host() { +  local me    if [[ -n $SSH_CONNECTION ]]; then      me="%n@%m"    elif [[ $LOGNAME != $USER ]]; then @@ -23,63 +25,41 @@ function _user_host() {    fi  } -function _vi_status() { -  if {echo $fpath | grep -q "plugins/vi-mode"}; then -    echo "$(vi_mode_prompt_info)" -  fi -} - -function _ruby_version() { -  if {echo $fpath | grep -q "plugins/rvm"}; then -    echo "%{$fg[grey]%}$(rvm_prompt_info)%{$reset_color%}" -  fi -} -  # Determine the time since last commit. If branch is clean,  # use a neutral color, otherwise colors will vary according to time.  function _git_time_since_commit() { -  if git rev-parse --git-dir > /dev/null 2>&1; then -    # Only proceed if there is actually a commit. -    if [[ $(git log 2>&1 > /dev/null | grep -c "^fatal: bad default revision") == 0 ]]; then -      # Get the last commit. -      last_commit=$(git log --pretty=format:'%at' -1 2> /dev/null) -      now=$(date +%s) -      seconds_since_last_commit=$((now-last_commit)) - -      # Totals -      minutes=$((seconds_since_last_commit / 60)) -      hours=$((seconds_since_last_commit/3600)) - -      # Sub-hours and sub-minutes -      days=$((seconds_since_last_commit / 86400)) -      sub_hours=$((hours % 24)) -      sub_minutes=$((minutes % 60)) - -      if [ $hours -gt 24 ]; then -          commit_age="${days}d" -      elif [ $minutes -gt 60 ]; then -          commit_age="${sub_hours}h${sub_minutes}m" -      else -          commit_age="${minutes}m" -      fi - -      color=$ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL -      echo "$color$commit_age%{$reset_color%}" +  local last_commit now seconds_since_last_commit +  local minutes hours days years commit_age +  # Only proceed if there is actually a commit. +  if last_commit=$(git log --pretty=format:'%at' -1 2> /dev/null); then +    now=$(date +%s) +    seconds_since_last_commit=$((now-last_commit)) + +    # Totals +    minutes=$((seconds_since_last_commit / 60)) +    hours=$((minutes / 60)) +    days=$((hours / 24)) +    years=$((days / 365)) + +    if [[ $years -gt 0 ]]; then +      commit_age="${years}y$((days % 365 ))d" +    elif [[ $days -gt 0 ]]; then +      commit_age="${days}d$((hours % 24))h" +    elif [[ $hours -gt 0 ]]; then +      commit_age+="${hours}h$(( minutes % 60 ))m" +    else +      commit_age="${minutes}m"      fi + +    echo "${ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL}${commit_age}%{$reset_color%}"    fi  } -if [[ $USER == "root" ]]; then -  CARETCOLOR="red" -else -  CARETCOLOR="white" -fi -  MODE_INDICATOR="%{$fg_bold[yellow]%}❮%{$reset_color%}%{$fg[yellow]%}❮❮%{$reset_color%}" +# Git prompt settings  ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[green]%}"  ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}" -  ZSH_THEME_GIT_PROMPT_DIRTY=" %{$fg[red]%}✗%{$reset_color%}"  ZSH_THEME_GIT_PROMPT_CLEAN=" %{$fg[green]%}✔%{$reset_color%}"  ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%}✚ " @@ -87,16 +67,19 @@ ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[yellow]%}⚑ "  ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%}✖ "  ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[blue]%}▴ "  ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[cyan]%}§ " -ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[grey]%}◒ " +ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[white]%}◒ " + +# Ruby prompt settings +ZSH_THEME_RUBY_PROMPT_PREFIX="%{$fg[grey]%}" +ZSH_THEME_RUBY_PROMPT_SUFFIX="%{$reset_color%}"  # Colors vary depending on time lapsed.  ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT="%{$fg[green]%}"  ZSH_THEME_GIT_TIME_SHORT_COMMIT_MEDIUM="%{$fg[yellow]%}"  ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG="%{$fg[red]%}" -ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL="%{$fg[grey]%}" +ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL="%{$fg[white]%}" -# LS colors, made with http://geoff.greer.fm/lscolors/ +# LS colors, made with https://geoff.greer.fm/lscolors/  export LSCOLORS="exfxcxdxbxegedabagacad"  export LS_COLORS='di=34;40:ln=35;40:so=32;40:pi=33;40:ex=31;40:bd=34;46:cd=34;43:su=0;41:sg=0;46:tw=0;42:ow=0;43:'  export GREP_COLOR='1;33' - | 
