1
0
mirror of https://github.com/tw93/Mole.git synced 2026-02-04 14:26:46 +00:00

Add inline spinners for better UI feedback and integrate recent items cleanup into the main flow.

This commit is contained in:
Tw93
2025-12-27 10:15:58 +08:00
parent ee9b34a4ca
commit 36e480333b

View File

@@ -98,9 +98,9 @@ if [[ ${#WHITELIST_PATTERNS[@]} -gt 0 ]]; then
fi
done
fi
total_items=0
# Tracking variables
# Global tracking variables (initialized in perform_cleanup)
total_items=0
TRACK_SECTION=0
SECTION_ACTIVITY=0
files_cleaned=0
@@ -154,6 +154,10 @@ start_section() {
echo ""
echo -e "${PURPLE_BOLD}${ICON_ARROW} $1${NC}"
if [[ -t 1 ]]; then
MOLE_SPINNER_PREFIX=" " start_inline_spinner "Preparing..."
fi
# Write section header to export list in dry-run mode
if [[ "$DRY_RUN" == "true" ]]; then
ensure_user_file "$EXPORT_LIST_FILE"
@@ -163,6 +167,8 @@ start_section() {
}
end_section() {
stop_section_spinner
if [[ $TRACK_SECTION -eq 1 && $SECTION_ACTIVITY -eq 0 ]]; then
echo -e " ${GREEN}${ICON_SUCCESS}${NC} Nothing to clean"
fi
@@ -174,6 +180,10 @@ safe_clean() {
return 0
fi
if [[ $TRACK_SECTION -eq 1 && $SECTION_ACTIVITY -eq 0 ]]; then
stop_section_spinner
fi
local description
local -a targets
@@ -192,6 +202,12 @@ safe_clean() {
local total_count=0
local skipped_count=0
local show_scan_feedback=false
if [[ ${#targets[@]} -gt 20 && -t 1 ]]; then
show_scan_feedback=true
MOLE_SPINNER_PREFIX=" " start_inline_spinner "Scanning ${#targets[@]} items..."
fi
# Optimized parallel processing for better performance
local -a existing_paths=()
for path in "${targets[@]}"; do
@@ -221,6 +237,10 @@ safe_clean() {
[[ -e "$path" ]] && existing_paths+=("$path")
done
if [[ "$show_scan_feedback" == "true" ]]; then
stop_section_spinner
fi
debug_log "Cleaning: $description (${#existing_paths[@]} items)"
# Update global whitelist skip counter
@@ -232,10 +252,15 @@ safe_clean() {
return 0
fi
# Show progress indicator for potentially slow operations
if [[ ${#existing_paths[@]} -gt 3 ]]; then
# Only show spinner if we have enough items to justify it (>10 items)
local show_spinner=false
if [[ ${#existing_paths[@]} -gt 10 ]]; then
show_spinner=true
local total_paths=${#existing_paths[@]}
if [[ -t 1 ]]; then MOLE_SPINNER_PREFIX=" " start_inline_spinner "Scanning items..."; fi
fi
if [[ ${#existing_paths[@]} -gt 3 ]]; then
local temp_dir
# create_temp_dir uses mktemp -d for secure temporary directory creation
temp_dir=$(create_temp_dir)
@@ -244,6 +269,9 @@ safe_clean() {
local -a pids=()
local idx=0
local completed=0
local last_progress_update=$(date +%s)
local total_paths=${#existing_paths[@]}
for path in "${existing_paths[@]}"; do
(
local size
@@ -266,12 +294,22 @@ safe_clean() {
wait "${pids[0]}" 2> /dev/null || true
pids=("${pids[@]:1}")
((completed++))
# Update progress using helper function
if [[ "$show_spinner" == "true" && -t 1 ]]; then
update_progress_if_needed "$completed" "$total_paths" last_progress_update 2 || true
fi
fi
done
for pid in "${pids[@]}"; do
wait "$pid" 2> /dev/null || true
((completed++))
# Update progress using helper function
if [[ "$show_spinner" == "true" && -t 1 ]]; then
update_progress_if_needed "$completed" "$total_paths" last_progress_update 2 || true
fi
done
# Read results using same index
@@ -299,10 +337,6 @@ safe_clean() {
# Temp dir will be auto-cleaned by cleanup_temp_files
else
# Show progress for small batches too (simpler jobs)
local total_paths=${#existing_paths[@]}
if [[ -t 1 ]]; then MOLE_SPINNER_PREFIX=" " start_inline_spinner "Scanning items..."; fi
local idx=0
for path in "${existing_paths[@]}"; do
local size_bytes
@@ -326,14 +360,11 @@ safe_clean() {
done
fi
# Clear progress / stop spinner before showing result
if [[ -t 1 ]]; then
stop_inline_spinner
echo -ne "\r\033[K"
if [[ "$show_spinner" == "true" ]]; then
stop_section_spinner
fi
if [[ $removed_any -eq 1 ]]; then
# Convert KB to bytes for bytes_to_human()
local size_human=$(bytes_to_human "$((total_size_bytes * 1024))")
local label="$description"
@@ -342,7 +373,7 @@ safe_clean() {
fi
if [[ "$DRY_RUN" == "true" ]]; then
echo -e " ${YELLOW}${NC} $label ${YELLOW}($size_human dry)${NC}"
echo -e " ${YELLOW}${ICON_DRY_RUN}${NC} $label ${YELLOW}($size_human dry)${NC}"
# Group paths by parent directory for export (Bash 3.2 compatible)
local paths_temp=$(create_temp_file)
@@ -351,11 +382,9 @@ safe_clean() {
for path in "${existing_paths[@]}"; do
local size=0
# Get size from result file if it exists (parallel processing with temp_dir)
if [[ -n "${temp_dir:-}" && -f "$temp_dir/result_${idx}" ]]; then
read -r size count < "$temp_dir/result_${idx}" 2> /dev/null || true
else
# Get size directly (small batch processing or no temp_dir)
size=$(get_path_size_kb "$path" 2> /dev/null || echo "0")
fi
@@ -364,7 +393,6 @@ safe_clean() {
continue
}
# Write parent|size|path to temp file
echo "$(dirname "$path")|$size|$path" >> "$paths_temp"
((idx++))
done
@@ -491,8 +519,8 @@ EOF
SYSTEM_CLEAN=false
echo ""
echo "Running in non-interactive mode"
echo " System-level cleanup skipped (requires interaction)"
echo " User-level cleanup will proceed automatically"
echo " ${ICON_LIST} System-level cleanup skipped (requires interaction)"
echo " ${ICON_LIST} User-level cleanup will proceed automatically"
echo ""
fi
}
@@ -537,7 +565,6 @@ perform_cleanup() {
fi
fi
# Initialize counters
total_items=0
files_cleaned=0
total_size_cleaned=0
@@ -575,6 +602,8 @@ perform_cleanup() {
start_section "macOS system caches"
# macOS system caches cleanup (delegated to clean_user_data module)
clean_macos_system_caches
clean_recent_items
clean_mail_downloads
end_section
# ===== 4. Sandboxed app caches =====