aboutsummaryrefslogtreecommitdiff
path: root/internal
diff options
context:
space:
mode:
Diffstat (limited to 'internal')
-rwxr-xr-xinternal/wizard.zsh76
1 files changed, 70 insertions, 6 deletions
diff --git a/internal/wizard.zsh b/internal/wizard.zsh
index 14d928a5..3f0f124b 100755
--- a/internal/wizard.zsh
+++ b/internal/wizard.zsh
@@ -49,8 +49,8 @@ typeset -ra classic_right=(
typeset -ri prompt_indent=4
-local POWERLEVEL9K_MODE style config_backup gap_char
-local -i num_lines write_config straight empty_line
+local POWERLEVEL9K_MODE style config_backup gap_char=' '
+local -i num_lines write_config straight empty_line frame=1
local -i cap_diamond cap_python cap_narrow_icons cap_lock
function prompt_length() {
@@ -78,6 +78,9 @@ function print_prompt() {
if (( num_lines == 1)); then
left=($left[2] $left[4])
right=($right[1] $right[3])
+ else
+ (( frame < 1 )) && left=('' $left[2] '' '%76F❯%f █')
+ (( frame < 2 )) && right=($right[1] '' '' '')
fi
if (( straight )); then
[[ $POWERLEVEL9K_MODE == nerdfont-complete ]] && local subsep='\uE0BD' || local subsep='|'
@@ -89,7 +92,7 @@ function print_prompt() {
local l=${(g::):-$left[i]$left[i+1]}
local r=${(g::):-$right[i]$right[i+1]}
local -i gap=$((__p9k_wizard_columns - 2 * prompt_indent - $(prompt_length $l$r)))
- (( num_lines == 2 && i == 1 )) && local fill=${gap_char:-' '} || local fill=' '
+ (( num_lines == 2 && i == 1 )) && local fill=$gap_char || local fill=' '
print -n -- ${(pl:$prompt_indent:: :)}
print -nP -- $l
print -nP -- "%240F${(pl:$gap::$fill:)}%f"
@@ -333,11 +336,11 @@ function ask_num_lines() {
clear
centered "%BPrompt Height%b"
print -P ""
- print -P "%B(1) One Line%b"
+ print -P "%B(1) One line%b"
print -P ""
num_lines=1 print_prompt
print -P ""
- print -P "%B(2) Two Lines%b"
+ print -P "%B(2) Two lines%b"
print -P ""
num_lines=2 print_prompt
print -P ""
@@ -394,6 +397,42 @@ function ask_gap_char() {
done
}
+function ask_frame() {
+ if [[ $style != classic || $num_lines != 2 ]]; then
+ frame=0
+ return
+ fi
+ while true; do
+ clear
+ centered "%BPrompt Frame%b"
+ print -P ""
+ print -P "%B(1) No frame%b"
+ print -P ""
+ frame=0 print_prompt
+ print -P ""
+ print -P "%B(2) Only left%b"
+ print -P ""
+ frame=1 print_prompt
+ print -P ""
+ print -P "%B(3) Left and right%b"
+ print -P ""
+ frame=2 print_prompt
+ print -P ""
+ print -P "(r) Restart from the beginning."
+ print -P ""
+ print -P "(q) Quit and do nothing."
+ print -P ""
+
+ local key=
+ read -k key${(%):-"?%BChoice [123rq]: %b"} || return 1
+ case $key in
+ q) quit; return 1;;
+ r) return 2;;
+ 1|2|3) frame=$((key-1)); break;;
+ esac
+ done
+}
+
function ask_empty_line() {
while true; do
clear
@@ -488,10 +527,15 @@ function ask_config_overwrite() {
function generate_config() {
local base && base="$(<$__p9k_root_dir/config/p10k-$style.zsh)" || return
local lines=("${(@f)base}")
+
function sub() {
lines=("${(@)lines/# typeset -g POWERLEVEL9K_$1=*/ typeset -g POWERLEVEL9K_$1=$2}")
}
+ function uncomment() {
+ lines=("${(@)lines/#(#b)([[:space:]]#)\# $1(|[[:space:]]*)/$match[1]$1${match[2]:= $match[2]}}")
+ }
+
sub MODE $POWERLEVEL9K_MODE
if (( cap_narrow_icons )); then
@@ -528,6 +572,20 @@ function generate_config() {
sub MULTILINE_FIRST_PROMPT_GAP_CHAR "'$gap_char'"
+ if (( frame < 2 )); then
+ sub MULTILINE_FIRST_PROMPT_SUFFIX ''
+ sub MULTILINE_NEWLINE_PROMPT_SUFFIX ''
+ sub MULTILINE_LAST_PROMPT_SUFFIX ''
+ if (( frame < 1 )); then
+ sub MULTILINE_FIRST_PROMPT_PREFIX ''
+ sub MULTILINE_NEWLINE_PROMPT_PREFIX ''
+ sub MULTILINE_LAST_PROMPT_PREFIX ''
+ uncomment prompt_char
+ sub STATUS_OK false
+ sub STATUS_ERROR false
+ fi
+ fi
+
(( empty_line )) && sub PROMPT_ADD_NEWLINE true || sub PROMPT_ADD_NEWLINE false
local header=${(%):-"# Generated by Powerlevel10k configuration wizard on %D{%Y-%m-%d at %H:%M %Z}."}$'\n'
@@ -540,7 +598,7 @@ function generate_config() {
fi
header+=$'.\n'
header+="# Wizard options: $POWERLEVEL9K_MODE"
- (( cap_narrow_icons )) && header+=", narrow icons" || header+=", wide icons"
+ (( cap_narrow_icons )) && header+=", small icons" || header+=", big icons"
if [[ $style == classic ]]; then
(( straight )) && header+=", straight" || header+=", angled"
fi
@@ -550,6 +608,11 @@ function generate_config() {
'·') header+=", dotted";;
'─') header+=", solid";;
esac
+ case $frame in
+ 0) header+=", no frame";;
+ 1) header+=", left frame";;
+ 2) header+=", full frame";;
+ esac
(( empty_line )) && header+=", sparse" || header+=", compact";
header+=$'.\n#'
@@ -617,6 +680,7 @@ while true; do
ask_straight || { (( $? == 2 )) && continue || return }
ask_num_lines || { (( $? == 2 )) && continue || return }
ask_gap_char || { (( $? == 2 )) && continue || return }
+ ask_frame || { (( $? == 2 )) && continue || return }
ask_empty_line || { (( $? == 2 )) && continue || return }
ask_confirm || { (( $? == 2 )) && continue || return }
ask_config_overwrite || { (( $? == 2 )) && continue || return }